⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 isrcload.c

📁 spice中支持多层次元件模型仿真的可单独运行的插件源码
💻 C
字号:
/**********Copyright 1990 Regents of the University of California.  All rights reserved.Author: 1985 Thomas L. Quarles**********/#include "spice.h"#include <stdio.h>#include "cktdefs.h"#include "isrcdefs.h"#include "util.h"#include "trandefs.h"#include "sperror.h"#include "suffix.h"intISRCload(inModel,ckt)    GENmodel *inModel;    register CKTcircuit *ckt;        /* actually load the current current value into the          * sparse matrix previously provided          */{    register ISRCmodel *model = (ISRCmodel*)inModel;    register ISRCinstance *here;    double value;    double time;    /*  loop through all the current source models */    for( ; model != NULL; model = model->ISRCnextModel ) {        /* loop through all the instances of the model */        for (here = model->ISRCinstances; here != NULL ;                here=here->ISRCnextInstance) {	    if (here->ISRCowner != ARCHme) continue;                        if( (ckt->CKTmode & (MODEDCOP | MODEDCTRANCURVE)) &&                    here->ISRCdcGiven ) {                /* load using DC value */                value = here->ISRCdcValue * ckt->CKTsrcFact;            } else {                if(ckt->CKTmode & (MODEDC)) {                    time = 0;                } else {                    time = ckt->CKTtime;                }                /* use transient function */                switch(here->ISRCfunctionType) {                case PULSE: {		    double	V1, V2, TD, TR, TF, PW, PER;                    double	basetime = 0;		    V1 = here->ISRCcoeffs[0];		    V2 = here->ISRCcoeffs[1];		    TD = here->ISRCfunctionOrder > 2			? here->ISRCcoeffs[2] : 0.0;		    TR = here->ISRCfunctionOrder > 3			&& here->ISRCcoeffs[3] != 0.0			? here->ISRCcoeffs[3] : ckt->CKTstep;		    TF = here->ISRCfunctionOrder > 4			&& here->ISRCcoeffs[4] != 0.0			? here->ISRCcoeffs[4] : ckt->CKTstep;		    PW = here->ISRCfunctionOrder > 5			&& here->ISRCcoeffs[5] != 0.0			? here->ISRCcoeffs[5] : ckt->CKTfinalTime;		    PER = here->ISRCfunctionOrder > 6			&& here->ISRCcoeffs[6] != 0.0			? here->ISRCcoeffs[6] : ckt->CKTfinalTime;                    time -= TD;                    if(time > PER) {                        /* repeating signal - figure out where we are */                        /* in period */                        basetime = PER * floor(time/PER);                        time -= basetime;                    }                    if( time <= 0 || time >= TR + PW + TF) {                        value = V1;                    } else  if ( time >= TR && time <= TR + PW) {                        value = V2;                    } else if (time > 0 && time < TR) {                        value = V1 + (V2 - V1) * (time) / TR;                    } else { /* time > TR + PW && < TR + PW + TF */                        value = V2 + (V1 - V2) * (time - (TR + PW)) / TF;                    }                }                break;                case SINE: {#define VO    (*(here->ISRCcoeffs))#define VA    (*(here->ISRCcoeffs+1))#define FREQ  (((here->ISRCfunctionOrder >=3) && (*(here->ISRCcoeffs+2)))? \    (*(here->ISRCcoeffs+2)):(1/ckt->CKTfinalTime))#define TD    ((here->ISRCfunctionOrder >=4)?(*(here->ISRCcoeffs+3)):(0.0))#define THETA ((here->ISRCfunctionOrder >=5)?(*(here->ISRCcoeffs+4)):(0.0))                    time -= TD;                    if (time <= 0) {                        value = VO;                    } else {                        value = VO + VA * sin(FREQ*time * 2.0 * M_PI) *                         exp(-time*THETA);                    }#undef VO#undef VA#undef FREQ#undef TD#undef THETA                }                break;                case EXP: {                    double td1;                    double td2;#define V1 (*(here->ISRCcoeffs))#define V2 (*(here->ISRCcoeffs+1))#define TD1 ((here->ISRCfunctionOrder >=3)?(*(here->ISRCcoeffs+2)):\    ckt->CKTstep)#define TAU1 (((here->ISRCfunctionOrder >=4) && (*(here->ISRCcoeffs+3)))? \    (*(here->ISRCcoeffs+3)):ckt->CKTstep)#define TD2 (((here->ISRCfunctionOrder >=5) && (*(here->ISRCcoeffs+4)))? \    (*(here->ISRCcoeffs+4)):TD1+ckt->CKTstep)#define TAU2 (((here->ISRCfunctionOrder >=6) && (*(here->ISRCcoeffs+5)))? \    (*(here->ISRCcoeffs+5)):ckt->CKTstep)                    td1 = TD1;                    td2 = TD2;                    if(time <= td1)  {                        value = V1;                    } else if (time <= td2) {                        value = V1 + (V2-V1)*(1-exp(-(time-td1)/TAU1));                    } else {                        value = V1 + (V2-V1)*(1-exp(-(time-td1)/TAU1)) +                                     (V1-V2)*(1-exp(-(time-td2)/TAU2)) ;                    }#undef V1#undef V2#undef TD1#undef TAU1#undef TD2#undef TAU2                }                break;                case SFFM:{#define VO (*(here->ISRCcoeffs))#define VA (*(here->ISRCcoeffs+1))#define FC (((here->ISRCfunctionOrder >=3) && (*(here->ISRCcoeffs+2)))? \    (*(here->ISRCcoeffs+2)):(1/ckt->CKTfinalTime))#define MDI ((here->ISRCfunctionOrder>=4)?(*(here->ISRCcoeffs+3)):0.0)#define FS (((here->ISRCfunctionOrder >=5) && (*(here->ISRCcoeffs+4)))? \    (*(here->ISRCcoeffs+4)):(1/ckt->CKTfinalTime))                    value = VO + VA *                         sin((2.0 * M_PI * FC * time) +                        MDI * sin(2.0 * M_PI * FS * time));#undef VO#undef VA#undef FC#undef MDI#undef FS                }                break;                default:                    value = here->ISRCdcValue * ckt->CKTsrcFact;                    break;                case PWL: {                    register int i;                    if(time< *(here->ISRCcoeffs)) {                        value = *(here->ISRCcoeffs + 1) ;                        break;                    }                    for(i=0;i<=(here->ISRCfunctionOrder/2)-1;i++) {                        if((*(here->ISRCcoeffs+2*i)==time)) {                            value = *(here->ISRCcoeffs+2*i+1);                            goto loadDone;                        }                        if((*(here->ISRCcoeffs+2*i)<time) &&                                (*(here->ISRCcoeffs+2*(i+1)) >time)) {                            value = *(here->ISRCcoeffs+2*i+1) +                                (((time-*(here->ISRCcoeffs+2*i))/                                (*(here->ISRCcoeffs+2*(i+1)) -                                  *(here->ISRCcoeffs+2*i))) *                                (*(here->ISRCcoeffs+2*i+3) -                                  *(here->ISRCcoeffs+2*i+1)));                            goto loadDone;                        }                    }                    value = *(here->ISRCcoeffs+ here->ISRCfunctionOrder-1) ;                    break;                }                }            }loadDone:            *(ckt->CKTrhs + (here->ISRCposNode)) += value;            *(ckt->CKTrhs + (here->ISRCnegNode)) -= value;        }    }    return(OK);}

⌨️ 快捷键说明

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