ngspice/src/spicelib/devices/bsim4v5/b4v5par.c

203 lines
6.5 KiB
C

/**** BSIM4.5.0 Released by Xuemei (Jane) Xi 07/29/2005 ****/
/**********
* Copyright 2004 Regents of the University of California. All rights reserved.
* File: b4par.c of BSIM4.5.0.
* Author: 2000 Weidong Liu
* Authors: 2001- Xuemei Xi, Mohan Dunga, Ali Niknejad, Chenming Hu.
* Project Director: Prof. Chenming Hu.
* Modified by Xuemei Xi, 04/06/2001.
* Modified by Xuemei Xi, 11/15/2002.
* Modified by Xuemei Xi, 05/09/2003.
* Modified by Xuemei Xi, Mohan Dunga, 07/29/2005.
**********/
#include "ngspice/ngspice.h"
#include "ngspice/ifsim.h"
#include "bsim4v5def.h"
#include "ngspice/sperror.h"
#include "ngspice/suffix.h"
#include "ngspice/fteext.h"
int
BSIM4v5param(
int param,
IFvalue *value,
GENinstance *inst,
IFvalue *select)
{
double scale;
BSIM4v5instance *here = (BSIM4v5instance*)inst;
NG_IGNORE(select);
if (!cp_getvar("scale", CP_REAL, &scale, 0))
scale = 1;
switch(param)
{ case BSIM4v5_W:
here->BSIM4v5w = value->rValue*scale;
here->BSIM4v5wGiven = TRUE;
break;
case BSIM4v5_L:
here->BSIM4v5l = value->rValue*scale;
here->BSIM4v5lGiven = TRUE;
break;
case BSIM4v5_M:
here->BSIM4v5m = value->rValue;
here->BSIM4v5mGiven = TRUE;
break;
case BSIM4v5_NF:
here->BSIM4v5nf = value->rValue;
here->BSIM4v5nfGiven = TRUE;
break;
case BSIM4v5_MIN:
here->BSIM4v5min = value->iValue;
here->BSIM4v5minGiven = TRUE;
break;
case BSIM4v5_AS:
here->BSIM4v5sourceArea = value->rValue*scale*scale;
here->BSIM4v5sourceAreaGiven = TRUE;
break;
case BSIM4v5_AD:
here->BSIM4v5drainArea = value->rValue*scale*scale;
here->BSIM4v5drainAreaGiven = TRUE;
break;
case BSIM4v5_PS:
here->BSIM4v5sourcePerimeter = value->rValue*scale;
here->BSIM4v5sourcePerimeterGiven = TRUE;
break;
case BSIM4v5_PD:
here->BSIM4v5drainPerimeter = value->rValue*scale;
here->BSIM4v5drainPerimeterGiven = TRUE;
break;
case BSIM4v5_NRS:
here->BSIM4v5sourceSquares = value->rValue;
here->BSIM4v5sourceSquaresGiven = TRUE;
break;
case BSIM4v5_NRD:
here->BSIM4v5drainSquares = value->rValue;
here->BSIM4v5drainSquaresGiven = TRUE;
break;
case BSIM4v5_OFF:
here->BSIM4v5off = value->iValue;
break;
case BSIM4v5_SA:
here->BSIM4v5sa = value->rValue*scale;
here->BSIM4v5saGiven = TRUE;
break;
case BSIM4v5_SB:
here->BSIM4v5sb = value->rValue*scale;
here->BSIM4v5sbGiven = TRUE;
break;
case BSIM4v5_SD:
here->BSIM4v5sd = value->rValue*scale;
here->BSIM4v5sdGiven = TRUE;
break;
case BSIM4v5_SCA:
here->BSIM4v5sca = value->rValue;
here->BSIM4v5scaGiven = TRUE;
break;
case BSIM4v5_SCB:
here->BSIM4v5scb = value->rValue;
here->BSIM4v5scbGiven = TRUE;
break;
case BSIM4v5_SCC:
here->BSIM4v5scc = value->rValue;
here->BSIM4v5sccGiven = TRUE;
break;
case BSIM4v5_SC:
here->BSIM4v5sc = value->rValue*scale;
here->BSIM4v5scGiven = TRUE;
break;
case BSIM4v5_RBSB:
here->BSIM4v5rbsb = value->rValue;
here->BSIM4v5rbsbGiven = TRUE;
break;
case BSIM4v5_RBDB:
here->BSIM4v5rbdb = value->rValue;
here->BSIM4v5rbdbGiven = TRUE;
break;
case BSIM4v5_RBPB:
here->BSIM4v5rbpb = value->rValue;
here->BSIM4v5rbpbGiven = TRUE;
break;
case BSIM4v5_RBPS:
here->BSIM4v5rbps = value->rValue;
here->BSIM4v5rbpsGiven = TRUE;
break;
case BSIM4v5_RBPD:
here->BSIM4v5rbpd = value->rValue;
here->BSIM4v5rbpdGiven = TRUE;
break;
case BSIM4v5_DELVTO:
here->BSIM4v5delvto = value->rValue;
here->BSIM4v5delvtoGiven = TRUE;
break;
case BSIM4v5_XGW:
here->BSIM4v5xgw = value->rValue;
here->BSIM4v5xgwGiven = TRUE;
break;
case BSIM4v5_NGCON:
here->BSIM4v5ngcon = value->rValue;
here->BSIM4v5ngconGiven = TRUE;
break;
case BSIM4v5_TRNQSMOD:
here->BSIM4v5trnqsMod = value->iValue;
here->BSIM4v5trnqsModGiven = TRUE;
break;
case BSIM4v5_ACNQSMOD:
here->BSIM4v5acnqsMod = value->iValue;
here->BSIM4v5acnqsModGiven = TRUE;
break;
case BSIM4v5_RBODYMOD:
here->BSIM4v5rbodyMod = value->iValue;
here->BSIM4v5rbodyModGiven = TRUE;
break;
case BSIM4v5_RGATEMOD:
here->BSIM4v5rgateMod = value->iValue;
here->BSIM4v5rgateModGiven = TRUE;
break;
case BSIM4v5_GEOMOD:
here->BSIM4v5geoMod = value->iValue;
here->BSIM4v5geoModGiven = TRUE;
break;
case BSIM4v5_RGEOMOD:
here->BSIM4v5rgeoMod = value->iValue;
here->BSIM4v5rgeoModGiven = TRUE;
break;
case BSIM4v5_IC_VDS:
here->BSIM4v5icVDS = value->rValue;
here->BSIM4v5icVDSGiven = TRUE;
break;
case BSIM4v5_IC_VGS:
here->BSIM4v5icVGS = value->rValue;
here->BSIM4v5icVGSGiven = TRUE;
break;
case BSIM4v5_IC_VBS:
here->BSIM4v5icVBS = value->rValue;
here->BSIM4v5icVBSGiven = TRUE;
break;
case BSIM4v5_IC:
switch(value->v.numValue)
{ case 3:
here->BSIM4v5icVBS = *(value->v.vec.rVec+2);
here->BSIM4v5icVBSGiven = TRUE;
case 2:
here->BSIM4v5icVGS = *(value->v.vec.rVec+1);
here->BSIM4v5icVGSGiven = TRUE;
case 1:
here->BSIM4v5icVDS = *(value->v.vec.rVec);
here->BSIM4v5icVDSGiven = TRUE;
break;
default:
return(E_BADPARM);
}
break;
default:
return(E_BADPARM);
}
return(OK);
}