b3par.c

来自「ngspice又一个电子CAD仿真软件代码.功能更全」· C语言 代码 · 共 102 行

C
102
字号
/**** BSIM3v3.2.4, Released by Xuemei Xi 12/21/2001 ****//********** * Copyright 2001 Regents of the University of California. All rights reserved. * File: b3par.c of BSIM3v3.2.4 * Author: 1995 Min-Chie Jeng and Mansun Chan * Author: 1997-1999 Weidong Liu. * Author: 2001 Xuemei Xi * Modified by Paolo Nenzi 2002 and Dietmar Warning 2003 **********/#include "ngspice.h"#include "ifsim.h"#include "bsim3def.h"#include "sperror.h"#include "suffix.h"intBSIM3param (int param, IFvalue *value, GENinstance *inst, IFvalue *select){    BSIM3instance *here = (BSIM3instance*)inst;    switch(param)     {   case BSIM3_W:            here->BSIM3w = value->rValue;            here->BSIM3wGiven = TRUE;            break;        case BSIM3_L:            here->BSIM3l = value->rValue;            here->BSIM3lGiven = TRUE;            break;	case BSIM3_M:	    here->BSIM3m = value->rValue;	    here->BSIM3mGiven = TRUE;	    break;        case BSIM3_AS:            here->BSIM3sourceArea = value->rValue;            here->BSIM3sourceAreaGiven = TRUE;            break;        case BSIM3_AD:            here->BSIM3drainArea = value->rValue;            here->BSIM3drainAreaGiven = TRUE;            break;        case BSIM3_PS:            here->BSIM3sourcePerimeter = value->rValue;            here->BSIM3sourcePerimeterGiven = TRUE;            break;        case BSIM3_PD:            here->BSIM3drainPerimeter = value->rValue;            here->BSIM3drainPerimeterGiven = TRUE;            break;        case BSIM3_NRS:            here->BSIM3sourceSquares = value->rValue;            here->BSIM3sourceSquaresGiven = TRUE;            break;        case BSIM3_NRD:            here->BSIM3drainSquares = value->rValue;            here->BSIM3drainSquaresGiven = TRUE;            break;        case BSIM3_OFF:            here->BSIM3off = value->iValue;            break;        case BSIM3_IC_VBS:            here->BSIM3icVBS = value->rValue;            here->BSIM3icVBSGiven = TRUE;            break;        case BSIM3_IC_VDS:            here->BSIM3icVDS = value->rValue;            here->BSIM3icVDSGiven = TRUE;            break;        case BSIM3_IC_VGS:            here->BSIM3icVGS = value->rValue;            here->BSIM3icVGSGiven = TRUE;            break;        case BSIM3_NQSMOD:            here->BSIM3nqsMod = value->iValue;            here->BSIM3nqsModGiven = TRUE;            break;        case BSIM3_IC:            switch(value->v.numValue){                case 3:                    here->BSIM3icVBS = *(value->v.vec.rVec+2);                    here->BSIM3icVBSGiven = TRUE;                case 2:                    here->BSIM3icVGS = *(value->v.vec.rVec+1);                    here->BSIM3icVGSGiven = TRUE;                case 1:                    here->BSIM3icVDS = *(value->v.vec.rVec);                    here->BSIM3icVDSGiven = TRUE;                    break;                default:                    return(E_BADPARM);            }            break;        default:            return(E_BADPARM);    }    return(OK);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?