b3check.c

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

C
450
字号
        }/* Check capacitance parameters */        if (pParam->BSIM3clc < 0.0)	{   fprintf(fplog, "Fatal: Clc = %g is negative.\n", pParam->BSIM3clc);	    printf("Fatal: Clc = %g is negative.\n", pParam->BSIM3clc);	    Fatal_Flag = 1;        }              if (pParam->BSIM3moin < 5.0)        {   fprintf(fplog, "Warning: Moin = %g is too small.\n",                    pParam->BSIM3moin);            printf("Warning: Moin = %g is too small.\n", pParam->BSIM3moin);        }        if (pParam->BSIM3moin > 25.0)        {   fprintf(fplog, "Warning: Moin = %g is too large.\n",                    pParam->BSIM3moin);            printf("Warning: Moin = %g is too large.\n", pParam->BSIM3moin);        }	if(model->BSIM3capMod ==3) {        	if (pParam->BSIM3acde < 0.4)        	{   fprintf(fplog, "Warning:  Acde = %g is too small.\n",                    	pParam->BSIM3acde);            	printf("Warning: Acde = %g is too small.\n", pParam->BSIM3acde);        	}        	if (pParam->BSIM3acde > 1.6)        	{   fprintf(fplog, "Warning:  Acde = %g is too large.\n",                    	pParam->BSIM3acde);            	printf("Warning: Acde = %g is too large.\n", pParam->BSIM3acde);        	}	}      if (model->BSIM3paramChk ==1)      {/* Check L and W parameters */ 	if (pParam->BSIM3leff <= 5.0e-8)	{   fprintf(fplog, "Warning: Leff = %g may be too small.\n",	            pParam->BSIM3leff);	    printf("Warning: Leff = %g may be too small.\n",		    pParam->BSIM3leff);	}    		if (pParam->BSIM3leffCV <= 5.0e-8)	{   fprintf(fplog, "Warning: Leff for CV = %g may be too small.\n",		    pParam->BSIM3leffCV);	    printf("Warning: Leff for CV = %g may be too small.\n",		   pParam->BSIM3leffCV);	}  	        if (pParam->BSIM3weff <= 1.0e-7)	{   fprintf(fplog, "Warning: Weff = %g may be too small.\n",		    pParam->BSIM3weff);	    printf("Warning: Weff = %g may be too small.\n",		   pParam->BSIM3weff);	}             		if (pParam->BSIM3weffCV <= 1.0e-7)	{   fprintf(fplog, "Warning: Weff for CV = %g may be too small.\n",		    pParam->BSIM3weffCV);	    printf("Warning: Weff for CV = %g may be too small.\n",		   pParam->BSIM3weffCV);	}        	/* Check threshold voltage parameters */	if (pParam->BSIM3nlx < 0.0)	{   fprintf(fplog, "Warning: Nlx = %g is negative.\n", pParam->BSIM3nlx);	   printf("Warning: Nlx = %g is negative.\n", pParam->BSIM3nlx);        }	 if (model->BSIM3tox < 1.0e-9)	{   fprintf(fplog, "Warning: Tox = %g is less than 10A.\n",	            model->BSIM3tox);	    printf("Warning: Tox = %g is less than 10A.\n", model->BSIM3tox);        }        if (pParam->BSIM3npeak <= 1.0e15)	{   fprintf(fplog, "Warning: Nch = %g may be too small.\n",	            pParam->BSIM3npeak);	    printf("Warning: Nch = %g may be too small.\n",	           pParam->BSIM3npeak);	}	else if (pParam->BSIM3npeak >= 1.0e21)	{   fprintf(fplog, "Warning: Nch = %g may be too large.\n",	            pParam->BSIM3npeak);	    printf("Warning: Nch = %g may be too large.\n",	           pParam->BSIM3npeak);	}	 if (pParam->BSIM3nsub <= 1.0e14)	{   fprintf(fplog, "Warning: Nsub = %g may be too small.\n",	            pParam->BSIM3nsub);	    printf("Warning: Nsub = %g may be too small.\n",	           pParam->BSIM3nsub);	}	else if (pParam->BSIM3nsub >= 1.0e21)	{   fprintf(fplog, "Warning: Nsub = %g may be too large.\n",	            pParam->BSIM3nsub);	    printf("Warning: Nsub = %g may be too large.\n",	           pParam->BSIM3nsub);	}	if ((pParam->BSIM3ngate > 0.0) &&	    (pParam->BSIM3ngate <= 1.e18))	{   fprintf(fplog, "Warning: Ngate = %g is less than 1.E18cm^-3.\n",	            pParam->BSIM3ngate);	    printf("Warning: Ngate = %g is less than 1.E18cm^-3.\n",	           pParam->BSIM3ngate);	}               if (pParam->BSIM3dvt0 < 0.0)	{   fprintf(fplog, "Warning: Dvt0 = %g is negative.\n",		    pParam->BSIM3dvt0);   	    printf("Warning: Dvt0 = %g is negative.\n", pParam->BSIM3dvt0);   	}	    	if (fabs(1.0e-6 / (pParam->BSIM3w0 + pParam->BSIM3weff)) > 10.0)	{   fprintf(fplog, "Warning: (W0 + Weff) may be too small.\n");	    printf("Warning: (W0 + Weff) may be too small.\n");        }/* Check subthreshold parameters */	if (pParam->BSIM3nfactor < 0.0)	{   fprintf(fplog, "Warning: Nfactor = %g is negative.\n",		    pParam->BSIM3nfactor);	    printf("Warning: Nfactor = %g is negative.\n", pParam->BSIM3nfactor);	}	if (pParam->BSIM3cdsc < 0.0)	{   fprintf(fplog, "Warning: Cdsc = %g is negative.\n",		    pParam->BSIM3cdsc);	    printf("Warning: Cdsc = %g is negative.\n", pParam->BSIM3cdsc);	}	if (pParam->BSIM3cdscd < 0.0)	{   fprintf(fplog, "Warning: Cdscd = %g is negative.\n",		    pParam->BSIM3cdscd);	    printf("Warning: Cdscd = %g is negative.\n", pParam->BSIM3cdscd);	}/* Check DIBL parameters */	if (pParam->BSIM3eta0 < 0.0)	{   fprintf(fplog, "Warning: Eta0 = %g is negative.\n",		    pParam->BSIM3eta0); 	    printf("Warning: Eta0 = %g is negative.\n", pParam->BSIM3eta0); 	}	      /* Check Abulk parameters */	    	 if (fabs(1.0e-6 / (pParam->BSIM3b1 + pParam->BSIM3weff)) > 10.0)       	{   fprintf(fplog, "Warning: (B1 + Weff) may be too small.\n");       	    printf("Warning: (B1 + Weff) may be too small.\n");        }        /* Check Saturation parameters */     	if (pParam->BSIM3a2 < 0.01)	{   fprintf(fplog, "Warning: A2 = %g is too small. Set to 0.01.\n", pParam->BSIM3a2);	    printf("Warning: A2 = %g is too small. Set to 0.01.\n",		   pParam->BSIM3a2);	    pParam->BSIM3a2 = 0.01;	}	else if (pParam->BSIM3a2 > 1.0)	{   fprintf(fplog, "Warning: A2 = %g is larger than 1. A2 is set to 1 and A1 is set to 0.\n",		    pParam->BSIM3a2);	    printf("Warning: A2 = %g is larger than 1. A2 is set to 1 and A1 is set to 0.\n",		   pParam->BSIM3a2);	    pParam->BSIM3a2 = 1.0;	    pParam->BSIM3a1 = 0.0;	}	if (pParam->BSIM3rdsw < 0.0)	{   fprintf(fplog, "Warning: Rdsw = %g is negative. Set to zero.\n",		    pParam->BSIM3rdsw);	    printf("Warning: Rdsw = %g is negative. Set to zero.\n",		   pParam->BSIM3rdsw);	    pParam->BSIM3rdsw = 0.0;	    pParam->BSIM3rds0 = 0.0;	}	else if ((pParam->BSIM3rds0 > 0.0) && (pParam->BSIM3rds0 < 0.001))	{   fprintf(fplog, "Warning: Rds at current temperature = %g is less than 0.001 ohm. Set to zero.\n",		    pParam->BSIM3rds0);	    printf("Warning: Rds at current temperature = %g is less than 0.001 ohm. Set to zero.\n",		   pParam->BSIM3rds0);	    pParam->BSIM3rds0 = 0.0;	}	 if (pParam->BSIM3vsattemp < 1.0e3)	{   fprintf(fplog, "Warning: Vsat at current temperature = %g may be too small.\n", pParam->BSIM3vsattemp);	   printf("Warning: Vsat at current temperature = %g may be too small.\n", pParam->BSIM3vsattemp);	}	if (pParam->BSIM3pdibl1 < 0.0)	{   fprintf(fplog, "Warning: Pdibl1 = %g is negative.\n",		    pParam->BSIM3pdibl1);	    printf("Warning: Pdibl1 = %g is negative.\n", pParam->BSIM3pdibl1);	}	if (pParam->BSIM3pdibl2 < 0.0)	{   fprintf(fplog, "Warning: Pdibl2 = %g is negative.\n",		    pParam->BSIM3pdibl2);	    printf("Warning: Pdibl2 = %g is negative.\n", pParam->BSIM3pdibl2);	}/* Check overlap capacitance parameters */        if (model->BSIM3cgdo < 0.0)	{   fprintf(fplog, "Warning: cgdo = %g is negative. Set to zero.\n", model->BSIM3cgdo);	    printf("Warning: cgdo = %g is negative. Set to zero.\n", model->BSIM3cgdo);	    model->BSIM3cgdo = 0.0;        }              if (model->BSIM3cgso < 0.0)	{   fprintf(fplog, "Warning: cgso = %g is negative. Set to zero.\n", model->BSIM3cgso);	    printf("Warning: cgso = %g is negative. Set to zero.\n", model->BSIM3cgso);	    model->BSIM3cgso = 0.0;        }              if (model->BSIM3cgbo < 0.0)	{   fprintf(fplog, "Warning: cgbo = %g is negative. Set to zero.\n", model->BSIM3cgbo);	    printf("Warning: cgbo = %g is negative. Set to zero.\n", model->BSIM3cgbo);	    model->BSIM3cgbo = 0.0;        }     }/* loop for the parameter check for warning messages */      	fclose(fplog);    }    else    {   fprintf(stderr, "Warning: Can't open log file. Parameter checking skipped.\n");    }    return(Fatal_Flag);}

⌨️ 快捷键说明

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