New Binding Method extended to BSIM2 device

This commit is contained in:
Francesco Lannutti 2013-04-01 22:17:11 +02:00
parent cb424bd94b
commit 7717c748d9
2 changed files with 339 additions and 401 deletions

View File

@ -1,5 +1,5 @@
/**********
Author: 2012 Francesco Lannutti
Author: 2013 Francesco Lannutti
**********/
#include "ngspice/ngspice.h"
@ -7,304 +7,303 @@ Author: 2012 Francesco Lannutti
#include "bsim2def.h"
#include "ngspice/sperror.h"
#include <stdlib.h>
static
int
B2bindCSC(GENmodel *inModel, CKTcircuit *ckt)
BindCompare (const void *a, const void *b)
{
B2model *model = (B2model *)inModel;
int i ;
BindElement *A, *B ;
A = (BindElement *)a ;
B = (BindElement *)b ;
/* loop through all the b2 models */
for( ; model != NULL; model = model->B2nextModel ) {
B2instance *here;
/* loop through all the instances of the model */
for (here = model->B2instances; here != NULL ;
here = here->B2nextInstance) {
i = 0 ;
if ((here-> B2dNode != 0) && (here-> B2dNode != 0)) {
while (here->B2DdPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DdPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2gNode != 0)) {
while (here->B2GgPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2GgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNode != 0) && (here-> B2sNode != 0)) {
while (here->B2SsPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SsPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2bNode != 0)) {
while (here->B2BbPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2BbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2DPdpPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DPdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2SPspPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SPspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2dNode != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2DdpPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2bNode != 0)) {
while (here->B2GbPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2GbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2GdpPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2GdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2GspPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2GspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNode != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2SspPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2BdpPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2BdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2BspPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2BspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2DPspPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DPspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2dNode != 0)) {
while (here->B2DPdPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DPdPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2gNode != 0)) {
while (here->B2BgPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2BgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2gNode != 0)) {
while (here->B2DPgPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DPgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2gNode != 0)) {
while (here->B2SPgPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SPgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2sNode != 0)) {
while (here->B2SPsPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SPsPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2bNode != 0)) {
while (here->B2DPbPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2DPbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2bNode != 0)) {
while (here->B2SPbPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SPbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2SPdpPtr != ckt->CKTmatrix->CKTbind_Sparse [i]) i ++ ;
here->B2SPdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
}
}
return(OK);
return ((int)(A->Sparse - B->Sparse)) ;
}
int
B2bindCSCComplex(GENmodel *inModel, CKTcircuit *ckt)
B2bindCSC (GENmodel *inModel, CKTcircuit *ckt)
{
B2model *model = (B2model *)inModel;
int i ;
B2model *model = (B2model *)inModel ;
B2instance *here ;
double *i ;
BindElement *matched, *BindStruct ;
size_t nz ;
/* loop through all the b2 models */
for( ; model != NULL; model = model->B2nextModel ) {
B2instance *here;
BindStruct = ckt->CKTmatrix->CKTbindStruct ;
nz = (size_t)ckt->CKTmatrix->CKTklunz ;
/* loop through all the B2 models */
for ( ; model != NULL ; model = model->B2nextModel)
{
/* loop through all the instances of the model */
for (here = model->B2instances; here != NULL ;
here = here->B2nextInstance) {
for (here = model->B2instances ; here != NULL ; here = here->B2nextInstance)
{
if ((here-> B2dNode != 0) && (here-> B2dNode != 0))
{
i = here->B2DdPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DdStructPtr = matched ;
here->B2DdPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNode != 0) && (here-> B2dNode != 0)) {
while (here->B2DdPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DdPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2gNode != 0))
{
i = here->B2GgPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2GgStructPtr = matched ;
here->B2GgPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2gNode != 0)) {
while (here->B2GgPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2GgPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNode != 0) && (here-> B2sNode != 0))
{
i = here->B2SsPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SsStructPtr = matched ;
here->B2SsPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNode != 0) && (here-> B2sNode != 0)) {
while (here->B2SsPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SsPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2bNode != 0))
{
i = here->B2BbPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2BbStructPtr = matched ;
here->B2BbPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2bNode != 0)) {
while (here->B2BbPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2BbPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2dNodePrime != 0))
{
i = here->B2DPdpPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DPdpStructPtr = matched ;
here->B2DPdpPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2DPdpPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DPdpPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2sNodePrime != 0))
{
i = here->B2SPspPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SPspStructPtr = matched ;
here->B2SPspPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2SPspPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SPspPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2dNode != 0) && (here-> B2dNodePrime != 0))
{
i = here->B2DdpPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DdpStructPtr = matched ;
here->B2DdpPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNode != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2DdpPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DdpPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2bNode != 0))
{
i = here->B2GbPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2GbStructPtr = matched ;
here->B2GbPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2bNode != 0)) {
while (here->B2GbPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2GbPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2dNodePrime != 0))
{
i = here->B2GdpPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2GdpStructPtr = matched ;
here->B2GdpPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2GdpPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2GdpPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2sNodePrime != 0))
{
i = here->B2GspPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2GspStructPtr = matched ;
here->B2GspPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2gNode != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2GspPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2GspPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNode != 0) && (here-> B2sNodePrime != 0))
{
i = here->B2SspPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SspStructPtr = matched ;
here->B2SspPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNode != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2SspPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SspPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2dNodePrime != 0))
{
i = here->B2BdpPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2BdpStructPtr = matched ;
here->B2BdpPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2BdpPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2BdpPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2sNodePrime != 0))
{
i = here->B2BspPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2BspStructPtr = matched ;
here->B2BspPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2BspPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2BspPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2sNodePrime != 0))
{
i = here->B2DPspPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DPspStructPtr = matched ;
here->B2DPspPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2sNodePrime != 0)) {
while (here->B2DPspPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DPspPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2dNode != 0))
{
i = here->B2DPdPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DPdStructPtr = matched ;
here->B2DPdPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2dNode != 0)) {
while (here->B2DPdPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DPdPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2gNode != 0))
{
i = here->B2BgPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2BgStructPtr = matched ;
here->B2BgPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2bNode != 0) && (here-> B2gNode != 0)) {
while (here->B2BgPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2BgPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2gNode != 0))
{
i = here->B2DPgPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DPgStructPtr = matched ;
here->B2DPgPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2gNode != 0)) {
while (here->B2DPgPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DPgPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2gNode != 0))
{
i = here->B2SPgPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SPgStructPtr = matched ;
here->B2SPgPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2gNode != 0)) {
while (here->B2SPgPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SPgPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2sNode != 0))
{
i = here->B2SPsPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SPsStructPtr = matched ;
here->B2SPsPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2sNode != 0)) {
while (here->B2SPsPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SPsPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2bNode != 0))
{
i = here->B2DPbPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2DPbStructPtr = matched ;
here->B2DPbPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2dNodePrime != 0) && (here-> B2bNode != 0)) {
while (here->B2DPbPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2DPbPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2bNode != 0))
{
i = here->B2SPbPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SPbStructPtr = matched ;
here->B2SPbPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2bNode != 0)) {
while (here->B2SPbPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SPbPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2dNodePrime != 0))
{
i = here->B2SPdpPtr ;
matched = (BindElement *) bsearch (&i, BindStruct, nz, sizeof(BindElement), BindCompare) ;
here->B2SPdpStructPtr = matched ;
here->B2SPdpPtr = matched->CSC ;
}
i = 0 ;
if ((here-> B2sNodePrime != 0) && (here-> B2dNodePrime != 0)) {
while (here->B2SPdpPtr != ckt->CKTmatrix->CKTbind_CSC [i]) i ++ ;
here->B2SPdpPtr = ckt->CKTmatrix->CKTbind_CSC_Complex [i] ;
}
}
}
}
return(OK);
return (OK) ;
}
int
B2bindCSCComplex (GENmodel *inModel, CKTcircuit *ckt)
{
B2model *model = (B2model *)inModel ;
B2instance *here ;
NG_IGNORE (ckt) ;
/* loop through all the B2 models */
for ( ; model != NULL ; model = model->B2nextModel)
{
/* loop through all the instances of the model */
for (here = model->B2instances ; here != NULL ; here = here->B2nextInstance)
{
if ((here-> B2dNode != 0) && (here-> B2dNode != 0))
here->B2DdPtr = here->B2DdStructPtr->CSC_Complex ;
if ((here-> B2gNode != 0) && (here-> B2gNode != 0))
here->B2GgPtr = here->B2GgStructPtr->CSC_Complex ;
if ((here-> B2sNode != 0) && (here-> B2sNode != 0))
here->B2SsPtr = here->B2SsStructPtr->CSC_Complex ;
if ((here-> B2bNode != 0) && (here-> B2bNode != 0))
here->B2BbPtr = here->B2BbStructPtr->CSC_Complex ;
if ((here-> B2dNodePrime != 0) && (here-> B2dNodePrime != 0))
here->B2DPdpPtr = here->B2DPdpStructPtr->CSC_Complex ;
if ((here-> B2sNodePrime != 0) && (here-> B2sNodePrime != 0))
here->B2SPspPtr = here->B2SPspStructPtr->CSC_Complex ;
if ((here-> B2dNode != 0) && (here-> B2dNodePrime != 0))
here->B2DdpPtr = here->B2DdpStructPtr->CSC_Complex ;
if ((here-> B2gNode != 0) && (here-> B2bNode != 0))
here->B2GbPtr = here->B2GbStructPtr->CSC_Complex ;
if ((here-> B2gNode != 0) && (here-> B2dNodePrime != 0))
here->B2GdpPtr = here->B2GdpStructPtr->CSC_Complex ;
if ((here-> B2gNode != 0) && (here-> B2sNodePrime != 0))
here->B2GspPtr = here->B2GspStructPtr->CSC_Complex ;
if ((here-> B2sNode != 0) && (here-> B2sNodePrime != 0))
here->B2SspPtr = here->B2SspStructPtr->CSC_Complex ;
if ((here-> B2bNode != 0) && (here-> B2dNodePrime != 0))
here->B2BdpPtr = here->B2BdpStructPtr->CSC_Complex ;
if ((here-> B2bNode != 0) && (here-> B2sNodePrime != 0))
here->B2BspPtr = here->B2BspStructPtr->CSC_Complex ;
if ((here-> B2dNodePrime != 0) && (here-> B2sNodePrime != 0))
here->B2DPspPtr = here->B2DPspStructPtr->CSC_Complex ;
if ((here-> B2dNodePrime != 0) && (here-> B2dNode != 0))
here->B2DPdPtr = here->B2DPdStructPtr->CSC_Complex ;
if ((here-> B2bNode != 0) && (here-> B2gNode != 0))
here->B2BgPtr = here->B2BgStructPtr->CSC_Complex ;
if ((here-> B2dNodePrime != 0) && (here-> B2gNode != 0))
here->B2DPgPtr = here->B2DPgStructPtr->CSC_Complex ;
if ((here-> B2sNodePrime != 0) && (here-> B2gNode != 0))
here->B2SPgPtr = here->B2SPgStructPtr->CSC_Complex ;
if ((here-> B2sNodePrime != 0) && (here-> B2sNode != 0))
here->B2SPsPtr = here->B2SPsStructPtr->CSC_Complex ;
if ((here-> B2dNodePrime != 0) && (here-> B2bNode != 0))
here->B2DPbPtr = here->B2DPbStructPtr->CSC_Complex ;
if ((here-> B2sNodePrime != 0) && (here-> B2bNode != 0))
here->B2SPbPtr = here->B2SPbStructPtr->CSC_Complex ;
if ((here-> B2sNodePrime != 0) && (here-> B2dNodePrime != 0))
here->B2SPdpPtr = here->B2SPdpStructPtr->CSC_Complex ;
}
}
return (OK) ;
}
int
@ -312,169 +311,83 @@ B2bindCSCComplexToReal (GENmodel *inModel, CKTcircuit *ckt)
{
B2model *model = (B2model *)inModel ;
B2instance *here ;
int i ;
/* loop through all the bsim2 models */
NG_IGNORE (ckt) ;
/* loop through all the B2 models */
for ( ; model != NULL ; model = model->B2nextModel)
{
/* loop through all the instances of the model */
for (here = model->B2instances ; here != NULL ; here = here->B2nextInstance)
{
i = 0 ;
if ((here->B2dNode != 0) && (here->B2dNode != 0))
{
while (here->B2DdPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DdPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNode != 0) && (here-> B2dNode != 0))
here->B2DdPtr = here->B2DdStructPtr->CSC ;
i = 0 ;
if ((here->B2gNode != 0) && (here->B2gNode != 0))
{
while (here->B2GgPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2GgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2gNode != 0))
here->B2GgPtr = here->B2GgStructPtr->CSC ;
i = 0 ;
if ((here->B2sNode != 0) && (here->B2sNode != 0))
{
while (here->B2SsPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SsPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2sNode != 0) && (here-> B2sNode != 0))
here->B2SsPtr = here->B2SsStructPtr->CSC ;
i = 0 ;
if ((here->B2bNode != 0) && (here->B2bNode != 0))
{
while (here->B2BbPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2BbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2bNode != 0))
here->B2BbPtr = here->B2BbStructPtr->CSC ;
i = 0 ;
if ((here->B2dNodePrime != 0) && (here->B2dNodePrime != 0))
{
while (here->B2DPdpPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DPdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2dNodePrime != 0))
here->B2DPdpPtr = here->B2DPdpStructPtr->CSC ;
i = 0 ;
if ((here->B2sNodePrime != 0) && (here->B2sNodePrime != 0))
{
while (here->B2SPspPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SPspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2sNodePrime != 0))
here->B2SPspPtr = here->B2SPspStructPtr->CSC ;
i = 0 ;
if ((here->B2dNode != 0) && (here->B2dNodePrime != 0))
{
while (here->B2DdpPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNode != 0) && (here-> B2dNodePrime != 0))
here->B2DdpPtr = here->B2DdpStructPtr->CSC ;
i = 0 ;
if ((here->B2gNode != 0) && (here->B2bNode != 0))
{
while (here->B2GbPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2GbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2bNode != 0))
here->B2GbPtr = here->B2GbStructPtr->CSC ;
i = 0 ;
if ((here->B2gNode != 0) && (here->B2dNodePrime != 0))
{
while (here->B2GdpPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2GdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2dNodePrime != 0))
here->B2GdpPtr = here->B2GdpStructPtr->CSC ;
i = 0 ;
if ((here->B2gNode != 0) && (here->B2sNodePrime != 0))
{
while (here->B2GspPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2GspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2gNode != 0) && (here-> B2sNodePrime != 0))
here->B2GspPtr = here->B2GspStructPtr->CSC ;
i = 0 ;
if ((here->B2sNode != 0) && (here->B2sNodePrime != 0))
{
while (here->B2SspPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2sNode != 0) && (here-> B2sNodePrime != 0))
here->B2SspPtr = here->B2SspStructPtr->CSC ;
i = 0 ;
if ((here->B2bNode != 0) && (here->B2dNodePrime != 0))
{
while (here->B2BdpPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2BdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2dNodePrime != 0))
here->B2BdpPtr = here->B2BdpStructPtr->CSC ;
i = 0 ;
if ((here->B2bNode != 0) && (here->B2sNodePrime != 0))
{
while (here->B2BspPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2BspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2sNodePrime != 0))
here->B2BspPtr = here->B2BspStructPtr->CSC ;
i = 0 ;
if ((here->B2dNodePrime != 0) && (here->B2sNodePrime != 0))
{
while (here->B2DPspPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DPspPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2sNodePrime != 0))
here->B2DPspPtr = here->B2DPspStructPtr->CSC ;
i = 0 ;
if ((here->B2dNodePrime != 0) && (here->B2dNode != 0))
{
while (here->B2DPdPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DPdPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2dNode != 0))
here->B2DPdPtr = here->B2DPdStructPtr->CSC ;
i = 0 ;
if ((here->B2bNode != 0) && (here->B2gNode != 0))
{
while (here->B2BgPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2BgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2bNode != 0) && (here-> B2gNode != 0))
here->B2BgPtr = here->B2BgStructPtr->CSC ;
i = 0 ;
if ((here->B2dNodePrime != 0) && (here->B2gNode != 0))
{
while (here->B2DPgPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DPgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2gNode != 0))
here->B2DPgPtr = here->B2DPgStructPtr->CSC ;
i = 0 ;
if ((here->B2sNodePrime != 0) && (here->B2gNode != 0))
{
while (here->B2SPgPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SPgPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2gNode != 0))
here->B2SPgPtr = here->B2SPgStructPtr->CSC ;
i = 0 ;
if ((here->B2sNodePrime != 0) && (here->B2sNode != 0))
{
while (here->B2SPsPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SPsPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2sNode != 0))
here->B2SPsPtr = here->B2SPsStructPtr->CSC ;
i = 0 ;
if ((here->B2dNodePrime != 0) && (here->B2bNode != 0))
{
while (here->B2DPbPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2DPbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2dNodePrime != 0) && (here-> B2bNode != 0))
here->B2DPbPtr = here->B2DPbStructPtr->CSC ;
i = 0 ;
if ((here->B2sNodePrime != 0) && (here->B2bNode != 0))
{
while (here->B2SPbPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SPbPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
if ((here-> B2sNodePrime != 0) && (here-> B2bNode != 0))
here->B2SPbPtr = here->B2SPbStructPtr->CSC ;
if ((here-> B2sNodePrime != 0) && (here-> B2dNodePrime != 0))
here->B2SPdpPtr = here->B2SPdpStructPtr->CSC ;
i = 0 ;
if ((here->B2sNodePrime != 0) && (here->B2dNodePrime != 0))
{
while (here->B2SPdpPtr != ckt->CKTmatrix->CKTbind_CSC_Complex [i]) i ++ ;
here->B2SPdpPtr = ckt->CKTmatrix->CKTbind_CSC [i] ;
}
}
}
return (OK) ;
}
}

View File

@ -176,6 +176,31 @@ typedef struct sBSIM2instance {
#define B2numStates 35
#ifdef KLU
BindElement *B2DdStructPtr ;
BindElement *B2GgStructPtr ;
BindElement *B2SsStructPtr ;
BindElement *B2BbStructPtr ;
BindElement *B2DPdpStructPtr ;
BindElement *B2SPspStructPtr ;
BindElement *B2DdpStructPtr ;
BindElement *B2GbStructPtr ;
BindElement *B2GdpStructPtr ;
BindElement *B2GspStructPtr ;
BindElement *B2SspStructPtr ;
BindElement *B2BdpStructPtr ;
BindElement *B2BspStructPtr ;
BindElement *B2DPspStructPtr ;
BindElement *B2DPdStructPtr ;
BindElement *B2BgStructPtr ;
BindElement *B2DPgStructPtr ;
BindElement *B2SPgStructPtr ;
BindElement *B2SPsStructPtr ;
BindElement *B2DPbStructPtr ;
BindElement *B2SPbStructPtr ;
BindElement *B2SPdpStructPtr ;
#endif
} B2instance ;
struct bsim2SizeDependParam