|
|
|
@ -31,416 +31,416 @@ FILE *fplog; |
|
|
|
if ((fplog = fopen("b3v32check.log", "w")) != NULL) |
|
|
|
{ pParam = here->pParam; |
|
|
|
|
|
|
|
fprintf (fplog, |
|
|
|
"BSIM3 Model (Supports: v3.2, v3.2.2, v3.2.3, v3.2.4)\n"); |
|
|
|
fprintf (fplog, "Parameter Checking.\n"); |
|
|
|
fprintf (fplog, "Model = %s\n", model->BSIM3v32modName); |
|
|
|
fprintf (fplog, "W = %g, L = %g, M = %g\n", here->BSIM3v32w, |
|
|
|
here->BSIM3v32l, here->BSIM3v32m); |
|
|
|
|
|
|
|
if ((strcmp(model->BSIM3v32version, "3.2.4")) && (strcmp(model->BSIM3v32version, "3.24")) |
|
|
|
&& (strcmp(model->BSIM3v32version, "3.2.3")) && (strcmp(model->BSIM3v32version, "3.23")) |
|
|
|
&& (strcmp(model->BSIM3v32version, "3.2.2")) && (strcmp(model->BSIM3v32version, "3.22")) |
|
|
|
&& (strcmp(model->BSIM3v32version, "3.2")) && (strcmp(model->BSIM3v32version, "3.20"))) |
|
|
|
{ |
|
|
|
fprintf (fplog, |
|
|
|
"Warning: This model supports BSIM3v3.2, BSIM3v3.2.2, BSIM3v3.2.3, BSIM3v3.2.4\n"); |
|
|
|
fprintf (fplog, |
|
|
|
"You specified a wrong version number. Working now with BSIM3v3.2.4.\n"); |
|
|
|
printf ("Warning: This model supports BSIM3v3.2, BSIM3v3.2.2, BSIM3v3.2.3, BSIM3v3.2.4\n"); |
|
|
|
printf ("You specified a wrong version number. Working now with BSIM3v3.2.4.\n"); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32nlx < -pParam->BSIM3v32leff) |
|
|
|
{ fprintf(fplog, "Fatal: Nlx = %g is less than -Leff.\n", |
|
|
|
pParam->BSIM3v32nlx); |
|
|
|
printf("Fatal: Nlx = %g is less than -Leff.\n", |
|
|
|
pParam->BSIM3v32nlx); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32tox <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Tox = %g is not positive.\n", |
|
|
|
model->BSIM3v32tox); |
|
|
|
printf("Fatal: Tox = %g is not positive.\n", model->BSIM3v32tox); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32toxm <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Toxm = %g is not positive.\n", |
|
|
|
model->BSIM3v32toxm); |
|
|
|
printf("Fatal: Toxm = %g is not positive.\n", model->BSIM3v32toxm); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32npeak <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Nch = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
printf("Fatal: Nch = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32nsub <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Nsub = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
printf("Fatal: Nsub = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32ngate < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Ngate = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
printf("Fatal: Ngate = %g Ngate is not positive.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32ngate > 1.e25) |
|
|
|
{ fprintf(fplog, "Fatal: Ngate = %g is too high.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
printf("Fatal: Ngate = %g Ngate is too high\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32xj <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Xj = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32xj); |
|
|
|
printf("Fatal: Xj = %g is not positive.\n", pParam->BSIM3v32xj); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dvt1 < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Dvt1 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32dvt1); |
|
|
|
printf("Fatal: Dvt1 = %g is negative.\n", pParam->BSIM3v32dvt1); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dvt1w < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Dvt1w = %g is negative.\n", |
|
|
|
pParam->BSIM3v32dvt1w); |
|
|
|
printf("Fatal: Dvt1w = %g is negative.\n", pParam->BSIM3v32dvt1w); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32w0 == -pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Fatal: (W0 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
printf("Fatal: (W0 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dsub < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Dsub = %g is negative.\n", pParam->BSIM3v32dsub); |
|
|
|
printf("Fatal: Dsub = %g is negative.\n", pParam->BSIM3v32dsub); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32b1 == -pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Fatal: (B1 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
printf("Fatal: (B1 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32u0temp <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: u0 at current temperature = %g is not positive.\n", pParam->BSIM3v32u0temp); |
|
|
|
printf("Fatal: u0 at current temperature = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32u0temp); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
fprintf (fplog, |
|
|
|
"BSIM3 Model (Supports: v3.2, v3.2.2, v3.2.3, v3.2.4)\n"); |
|
|
|
fprintf (fplog, "Parameter Checking.\n"); |
|
|
|
fprintf (fplog, "Model = %s\n", model->BSIM3v32modName); |
|
|
|
fprintf (fplog, "W = %g, L = %g, M = %g\n", here->BSIM3v32w, |
|
|
|
here->BSIM3v32l, here->BSIM3v32m); |
|
|
|
|
|
|
|
if ((strcmp(model->BSIM3v32version, "3.2.4")) && (strcmp(model->BSIM3v32version, "3.24")) |
|
|
|
&& (strcmp(model->BSIM3v32version, "3.2.3")) && (strcmp(model->BSIM3v32version, "3.23")) |
|
|
|
&& (strcmp(model->BSIM3v32version, "3.2.2")) && (strcmp(model->BSIM3v32version, "3.22")) |
|
|
|
&& (strcmp(model->BSIM3v32version, "3.2")) && (strcmp(model->BSIM3v32version, "3.20"))) |
|
|
|
{ |
|
|
|
fprintf (fplog, |
|
|
|
"Warning: This model supports BSIM3v3.2, BSIM3v3.2.2, BSIM3v3.2.3, BSIM3v3.2.4\n"); |
|
|
|
fprintf (fplog, |
|
|
|
"You specified a wrong version number. Working now with BSIM3v3.2.4.\n"); |
|
|
|
printf ("Warning: This model supports BSIM3v3.2, BSIM3v3.2.2, BSIM3v3.2.3, BSIM3v3.2.4\n"); |
|
|
|
printf ("You specified a wrong version number. Working now with BSIM3v3.2.4.\n"); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32nlx < -pParam->BSIM3v32leff) |
|
|
|
{ fprintf(fplog, "Fatal: Nlx = %g is less than -Leff.\n", |
|
|
|
pParam->BSIM3v32nlx); |
|
|
|
printf("Fatal: Nlx = %g is less than -Leff.\n", |
|
|
|
pParam->BSIM3v32nlx); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32tox <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Tox = %g is not positive.\n", |
|
|
|
model->BSIM3v32tox); |
|
|
|
printf("Fatal: Tox = %g is not positive.\n", model->BSIM3v32tox); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32toxm <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Toxm = %g is not positive.\n", |
|
|
|
model->BSIM3v32toxm); |
|
|
|
printf("Fatal: Toxm = %g is not positive.\n", model->BSIM3v32toxm); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32npeak <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Nch = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
printf("Fatal: Nch = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32nsub <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Nsub = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
printf("Fatal: Nsub = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32ngate < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Ngate = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
printf("Fatal: Ngate = %g Ngate is not positive.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32ngate > 1.e25) |
|
|
|
{ fprintf(fplog, "Fatal: Ngate = %g is too high.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
printf("Fatal: Ngate = %g Ngate is too high\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32xj <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Xj = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32xj); |
|
|
|
printf("Fatal: Xj = %g is not positive.\n", pParam->BSIM3v32xj); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dvt1 < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Dvt1 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32dvt1); |
|
|
|
printf("Fatal: Dvt1 = %g is negative.\n", pParam->BSIM3v32dvt1); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dvt1w < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Dvt1w = %g is negative.\n", |
|
|
|
pParam->BSIM3v32dvt1w); |
|
|
|
printf("Fatal: Dvt1w = %g is negative.\n", pParam->BSIM3v32dvt1w); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32w0 == -pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Fatal: (W0 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
printf("Fatal: (W0 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dsub < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Dsub = %g is negative.\n", pParam->BSIM3v32dsub); |
|
|
|
printf("Fatal: Dsub = %g is negative.\n", pParam->BSIM3v32dsub); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32b1 == -pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Fatal: (B1 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
printf("Fatal: (B1 + Weff) = 0 causing divided-by-zero.\n"); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32u0temp <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: u0 at current temperature = %g is not positive.\n", pParam->BSIM3v32u0temp); |
|
|
|
printf("Fatal: u0 at current temperature = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32u0temp); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
/* Check delta parameter */ |
|
|
|
if (pParam->BSIM3v32delta < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Delta = %g is less than zero.\n", |
|
|
|
pParam->BSIM3v32delta); |
|
|
|
printf("Fatal: Delta = %g is less than zero.\n", pParam->BSIM3v32delta); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32vsattemp <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Vsat at current temperature = %g is not positive.\n", pParam->BSIM3v32vsattemp); |
|
|
|
printf("Fatal: Vsat at current temperature = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32vsattemp); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32delta < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Delta = %g is less than zero.\n", |
|
|
|
pParam->BSIM3v32delta); |
|
|
|
printf("Fatal: Delta = %g is less than zero.\n", pParam->BSIM3v32delta); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32vsattemp <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Vsat at current temperature = %g is not positive.\n", pParam->BSIM3v32vsattemp); |
|
|
|
printf("Fatal: Vsat at current temperature = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32vsattemp); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
/* Check Rout parameters */ |
|
|
|
if (pParam->BSIM3v32pclm <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Pclm = %g is not positive.\n", pParam->BSIM3v32pclm); |
|
|
|
printf("Fatal: Pclm = %g is not positive.\n", pParam->BSIM3v32pclm); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32drout < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Drout = %g is negative.\n", pParam->BSIM3v32drout); |
|
|
|
printf("Fatal: Drout = %g is negative.\n", pParam->BSIM3v32drout); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32pscbe2 <= 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Pscbe2 = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32pscbe2); |
|
|
|
printf("Warning: Pscbe2 = %g is not positive.\n", pParam->BSIM3v32pscbe2); |
|
|
|
} |
|
|
|
|
|
|
|
/* acm model */ |
|
|
|
if (model->BSIM3v32acmMod == 0) { |
|
|
|
if (model->BSIM3v32unitLengthSidewallJctCap > 0.0 || |
|
|
|
model->BSIM3v32unitLengthGateSidewallJctCap > 0.0) |
|
|
|
{ |
|
|
|
if (here->BSIM3v32drainPerimeter < pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Warning: Pd = %g is less than W.\n", |
|
|
|
here->BSIM3v32drainPerimeter); |
|
|
|
printf("Warning: Pd = %g is less than W.\n", |
|
|
|
here->BSIM3v32drainPerimeter); |
|
|
|
} |
|
|
|
if (here->BSIM3v32sourcePerimeter < pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Warning: Ps = %g is less than W.\n", |
|
|
|
here->BSIM3v32sourcePerimeter); |
|
|
|
printf("Warning: Ps = %g is less than W.\n", |
|
|
|
here->BSIM3v32sourcePerimeter); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32noff < 0.1) |
|
|
|
{ fprintf(fplog, "Warning: Noff = %g is too small.\n", |
|
|
|
pParam->BSIM3v32noff); |
|
|
|
printf("Warning: Noff = %g is too small.\n", pParam->BSIM3v32noff); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32noff > 4.0) |
|
|
|
{ fprintf(fplog, "Warning: Noff = %g is too large.\n", |
|
|
|
pParam->BSIM3v32noff); |
|
|
|
printf("Warning: Noff = %g is too large.\n", pParam->BSIM3v32noff); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32voffcv < -0.5) |
|
|
|
{ fprintf(fplog, "Warning: Voffcv = %g is too small.\n", |
|
|
|
pParam->BSIM3v32voffcv); |
|
|
|
printf("Warning: Voffcv = %g is too small.\n", pParam->BSIM3v32voffcv); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32voffcv > 0.5) |
|
|
|
{ fprintf(fplog, "Warning: Voffcv = %g is too large.\n", |
|
|
|
pParam->BSIM3v32voffcv); |
|
|
|
printf("Warning: Voffcv = %g is too large.\n", pParam->BSIM3v32voffcv); |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32ijth < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Ijth = %g cannot be negative.\n", |
|
|
|
model->BSIM3v32ijth); |
|
|
|
printf("Fatal: Ijth = %g cannot be negative.\n", model->BSIM3v32ijth); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32pclm <= 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Pclm = %g is not positive.\n", pParam->BSIM3v32pclm); |
|
|
|
printf("Fatal: Pclm = %g is not positive.\n", pParam->BSIM3v32pclm); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32drout < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Drout = %g is negative.\n", pParam->BSIM3v32drout); |
|
|
|
printf("Fatal: Drout = %g is negative.\n", pParam->BSIM3v32drout); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32pscbe2 <= 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Pscbe2 = %g is not positive.\n", |
|
|
|
pParam->BSIM3v32pscbe2); |
|
|
|
printf("Warning: Pscbe2 = %g is not positive.\n", pParam->BSIM3v32pscbe2); |
|
|
|
} |
|
|
|
|
|
|
|
/* acm model */ |
|
|
|
if (model->BSIM3v32acmMod == 0) { |
|
|
|
if (model->BSIM3v32unitLengthSidewallJctCap > 0.0 || |
|
|
|
model->BSIM3v32unitLengthGateSidewallJctCap > 0.0) |
|
|
|
{ |
|
|
|
if (here->BSIM3v32drainPerimeter < pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Warning: Pd = %g is less than W.\n", |
|
|
|
here->BSIM3v32drainPerimeter); |
|
|
|
printf("Warning: Pd = %g is less than W.\n", |
|
|
|
here->BSIM3v32drainPerimeter); |
|
|
|
} |
|
|
|
if (here->BSIM3v32sourcePerimeter < pParam->BSIM3v32weff) |
|
|
|
{ fprintf(fplog, "Warning: Ps = %g is less than W.\n", |
|
|
|
here->BSIM3v32sourcePerimeter); |
|
|
|
printf("Warning: Ps = %g is less than W.\n", |
|
|
|
here->BSIM3v32sourcePerimeter); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32noff < 0.1) |
|
|
|
{ fprintf(fplog, "Warning: Noff = %g is too small.\n", |
|
|
|
pParam->BSIM3v32noff); |
|
|
|
printf("Warning: Noff = %g is too small.\n", pParam->BSIM3v32noff); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32noff > 4.0) |
|
|
|
{ fprintf(fplog, "Warning: Noff = %g is too large.\n", |
|
|
|
pParam->BSIM3v32noff); |
|
|
|
printf("Warning: Noff = %g is too large.\n", pParam->BSIM3v32noff); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32voffcv < -0.5) |
|
|
|
{ fprintf(fplog, "Warning: Voffcv = %g is too small.\n", |
|
|
|
pParam->BSIM3v32voffcv); |
|
|
|
printf("Warning: Voffcv = %g is too small.\n", pParam->BSIM3v32voffcv); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32voffcv > 0.5) |
|
|
|
{ fprintf(fplog, "Warning: Voffcv = %g is too large.\n", |
|
|
|
pParam->BSIM3v32voffcv); |
|
|
|
printf("Warning: Voffcv = %g is too large.\n", pParam->BSIM3v32voffcv); |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32ijth < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Ijth = %g cannot be negative.\n", |
|
|
|
model->BSIM3v32ijth); |
|
|
|
printf("Fatal: Ijth = %g cannot be negative.\n", model->BSIM3v32ijth); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
/* Check capacitance parameters */ |
|
|
|
if (pParam->BSIM3v32clc < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Clc = %g is negative.\n", pParam->BSIM3v32clc); |
|
|
|
printf("Fatal: Clc = %g is negative.\n", pParam->BSIM3v32clc); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32moin < 5.0) |
|
|
|
{ fprintf(fplog, "Warning: Moin = %g is too small.\n", |
|
|
|
pParam->BSIM3v32moin); |
|
|
|
printf("Warning: Moin = %g is too small.\n", pParam->BSIM3v32moin); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32moin > 25.0) |
|
|
|
{ fprintf(fplog, "Warning: Moin = %g is too large.\n", |
|
|
|
pParam->BSIM3v32moin); |
|
|
|
printf("Warning: Moin = %g is too large.\n", pParam->BSIM3v32moin); |
|
|
|
} |
|
|
|
|
|
|
|
if(model->BSIM3v32capMod ==3) { |
|
|
|
if (pParam->BSIM3v32acde < 0.4) |
|
|
|
{ fprintf(fplog, "Warning: Acde = %g is too small.\n", |
|
|
|
pParam->BSIM3v32acde); |
|
|
|
printf("Warning: Acde = %g is too small.\n", pParam->BSIM3v32acde); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32acde > 1.6) |
|
|
|
{ fprintf(fplog, "Warning: Acde = %g is too large.\n", |
|
|
|
pParam->BSIM3v32acde); |
|
|
|
printf("Warning: Acde = %g is too large.\n", pParam->BSIM3v32acde); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32paramChk ==1) |
|
|
|
{ |
|
|
|
/* Check L and W parameters */ |
|
|
|
if (pParam->BSIM3v32leff <= 5.0e-8) |
|
|
|
{ fprintf(fplog, "Warning: Leff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leff); |
|
|
|
printf("Warning: Leff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leff); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32leffCV <= 5.0e-8) |
|
|
|
{ fprintf(fplog, "Warning: Leff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leffCV); |
|
|
|
printf("Warning: Leff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leffCV); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32weff <= 1.0e-7) |
|
|
|
{ fprintf(fplog, "Warning: Weff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weff); |
|
|
|
printf("Warning: Weff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weff); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32weffCV <= 1.0e-7) |
|
|
|
{ fprintf(fplog, "Warning: Weff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weffCV); |
|
|
|
printf("Warning: Weff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weffCV); |
|
|
|
} |
|
|
|
|
|
|
|
/* Check threshold voltage parameters */ |
|
|
|
if (pParam->BSIM3v32nlx < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Nlx = %g is negative.\n", pParam->BSIM3v32nlx); |
|
|
|
printf("Warning: Nlx = %g is negative.\n", pParam->BSIM3v32nlx); |
|
|
|
} |
|
|
|
if (model->BSIM3v32tox < 1.0e-9) |
|
|
|
{ fprintf(fplog, "Warning: Tox = %g is less than 10A.\n", |
|
|
|
model->BSIM3v32tox); |
|
|
|
printf("Warning: Tox = %g is less than 10A.\n", model->BSIM3v32tox); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32npeak <= 1.0e15) |
|
|
|
{ fprintf(fplog, "Warning: Nch = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
printf("Warning: Nch = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
} |
|
|
|
else if (pParam->BSIM3v32npeak >= 1.0e21) |
|
|
|
{ fprintf(fplog, "Warning: Nch = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
printf("Warning: Nch = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32nsub <= 1.0e14) |
|
|
|
{ fprintf(fplog, "Warning: Nsub = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
printf("Warning: Nsub = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
} |
|
|
|
else if (pParam->BSIM3v32nsub >= 1.0e21) |
|
|
|
{ fprintf(fplog, "Warning: Nsub = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
printf("Warning: Nsub = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
} |
|
|
|
|
|
|
|
if ((pParam->BSIM3v32ngate > 0.0) && |
|
|
|
(pParam->BSIM3v32ngate <= 1.e18)) |
|
|
|
{ fprintf(fplog, "Warning: Ngate = %g is less than 1.E18cm^-3.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
printf("Warning: Ngate = %g is less than 1.E18cm^-3.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dvt0 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Dvt0 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32dvt0); |
|
|
|
printf("Warning: Dvt0 = %g is negative.\n", pParam->BSIM3v32dvt0); |
|
|
|
} |
|
|
|
|
|
|
|
if (fabs(1.0e-6 / (pParam->BSIM3v32w0 + pParam->BSIM3v32weff)) > 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->BSIM3v32nfactor < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Nfactor = %g is negative.\n", |
|
|
|
pParam->BSIM3v32nfactor); |
|
|
|
printf("Warning: Nfactor = %g is negative.\n", pParam->BSIM3v32nfactor); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32cdsc < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Cdsc = %g is negative.\n", |
|
|
|
pParam->BSIM3v32cdsc); |
|
|
|
printf("Warning: Cdsc = %g is negative.\n", pParam->BSIM3v32cdsc); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32cdscd < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Cdscd = %g is negative.\n", |
|
|
|
pParam->BSIM3v32cdscd); |
|
|
|
printf("Warning: Cdscd = %g is negative.\n", pParam->BSIM3v32cdscd); |
|
|
|
} |
|
|
|
/* Check DIBL parameters */ |
|
|
|
if (pParam->BSIM3v32eta0 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Eta0 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32eta0); |
|
|
|
printf("Warning: Eta0 = %g is negative.\n", pParam->BSIM3v32eta0); |
|
|
|
} |
|
|
|
|
|
|
|
/* Check Abulk parameters */ |
|
|
|
if (fabs(1.0e-6 / (pParam->BSIM3v32b1 + pParam->BSIM3v32weff)) > 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->BSIM3v32a2 < 0.01) |
|
|
|
{ fprintf(fplog, "Warning: A2 = %g is too small. Set to 0.01.\n", pParam->BSIM3v32a2); |
|
|
|
printf("Warning: A2 = %g is too small. Set to 0.01.\n", |
|
|
|
pParam->BSIM3v32a2); |
|
|
|
pParam->BSIM3v32a2 = 0.01; |
|
|
|
} |
|
|
|
else if (pParam->BSIM3v32a2 > 1.0) |
|
|
|
{ fprintf(fplog, "Warning: A2 = %g is larger than 1. A2 is set to 1 and A1 is set to 0.\n", |
|
|
|
pParam->BSIM3v32a2); |
|
|
|
printf("Warning: A2 = %g is larger than 1. A2 is set to 1 and A1 is set to 0.\n", |
|
|
|
pParam->BSIM3v32a2); |
|
|
|
pParam->BSIM3v32a2 = 1.0; |
|
|
|
pParam->BSIM3v32a1 = 0.0; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32rdsw < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Rdsw = %g is negative. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rdsw); |
|
|
|
printf("Warning: Rdsw = %g is negative. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rdsw); |
|
|
|
pParam->BSIM3v32rdsw = 0.0; |
|
|
|
pParam->BSIM3v32rds0 = 0.0; |
|
|
|
} |
|
|
|
else if ((pParam->BSIM3v32rds0 > 0.0) && (pParam->BSIM3v32rds0 < 0.001)) |
|
|
|
{ fprintf(fplog, "Warning: Rds at current temperature = %g is less than 0.001 ohm. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rds0); |
|
|
|
printf("Warning: Rds at current temperature = %g is less than 0.001 ohm. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rds0); |
|
|
|
pParam->BSIM3v32rds0 = 0.0; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32vsattemp < 1.0e3) |
|
|
|
{ fprintf(fplog, "Warning: Vsat at current temperature = %g may be too small.\n", pParam->BSIM3v32vsattemp); |
|
|
|
printf("Warning: Vsat at current temperature = %g may be too small.\n", pParam->BSIM3v32vsattemp); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32pdibl1 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Pdibl1 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32pdibl1); |
|
|
|
printf("Warning: Pdibl1 = %g is negative.\n", pParam->BSIM3v32pdibl1); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32pdibl2 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Pdibl2 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32pdibl2); |
|
|
|
printf("Warning: Pdibl2 = %g is negative.\n", pParam->BSIM3v32pdibl2); |
|
|
|
} |
|
|
|
/* Check overlap capacitance parameters */ |
|
|
|
if (model->BSIM3v32cgdo < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: cgdo = %g is negative. Set to zero.\n", model->BSIM3v32cgdo); |
|
|
|
printf("Warning: cgdo = %g is negative. Set to zero.\n", model->BSIM3v32cgdo); |
|
|
|
model->BSIM3v32cgdo = 0.0; |
|
|
|
} |
|
|
|
if (model->BSIM3v32cgso < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: cgso = %g is negative. Set to zero.\n", model->BSIM3v32cgso); |
|
|
|
printf("Warning: cgso = %g is negative. Set to zero.\n", model->BSIM3v32cgso); |
|
|
|
model->BSIM3v32cgso = 0.0; |
|
|
|
} |
|
|
|
if (model->BSIM3v32cgbo < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: cgbo = %g is negative. Set to zero.\n", model->BSIM3v32cgbo); |
|
|
|
printf("Warning: cgbo = %g is negative. Set to zero.\n", model->BSIM3v32cgbo); |
|
|
|
model->BSIM3v32cgbo = 0.0; |
|
|
|
} |
|
|
|
|
|
|
|
}/* loop for the parameter check for warning messages */ |
|
|
|
fclose(fplog); |
|
|
|
if (pParam->BSIM3v32clc < 0.0) |
|
|
|
{ fprintf(fplog, "Fatal: Clc = %g is negative.\n", pParam->BSIM3v32clc); |
|
|
|
printf("Fatal: Clc = %g is negative.\n", pParam->BSIM3v32clc); |
|
|
|
Fatal_Flag = 1; |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32moin < 5.0) |
|
|
|
{ fprintf(fplog, "Warning: Moin = %g is too small.\n", |
|
|
|
pParam->BSIM3v32moin); |
|
|
|
printf("Warning: Moin = %g is too small.\n", pParam->BSIM3v32moin); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32moin > 25.0) |
|
|
|
{ fprintf(fplog, "Warning: Moin = %g is too large.\n", |
|
|
|
pParam->BSIM3v32moin); |
|
|
|
printf("Warning: Moin = %g is too large.\n", pParam->BSIM3v32moin); |
|
|
|
} |
|
|
|
|
|
|
|
if(model->BSIM3v32capMod ==3) { |
|
|
|
if (pParam->BSIM3v32acde < 0.4) |
|
|
|
{ fprintf(fplog, "Warning: Acde = %g is too small.\n", |
|
|
|
pParam->BSIM3v32acde); |
|
|
|
printf("Warning: Acde = %g is too small.\n", pParam->BSIM3v32acde); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32acde > 1.6) |
|
|
|
{ fprintf(fplog, "Warning: Acde = %g is too large.\n", |
|
|
|
pParam->BSIM3v32acde); |
|
|
|
printf("Warning: Acde = %g is too large.\n", pParam->BSIM3v32acde); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (model->BSIM3v32paramChk ==1) |
|
|
|
{ |
|
|
|
/* Check L and W parameters */ |
|
|
|
if (pParam->BSIM3v32leff <= 5.0e-8) |
|
|
|
{ fprintf(fplog, "Warning: Leff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leff); |
|
|
|
printf("Warning: Leff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leff); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32leffCV <= 5.0e-8) |
|
|
|
{ fprintf(fplog, "Warning: Leff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leffCV); |
|
|
|
printf("Warning: Leff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32leffCV); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32weff <= 1.0e-7) |
|
|
|
{ fprintf(fplog, "Warning: Weff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weff); |
|
|
|
printf("Warning: Weff = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weff); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32weffCV <= 1.0e-7) |
|
|
|
{ fprintf(fplog, "Warning: Weff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weffCV); |
|
|
|
printf("Warning: Weff for CV = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32weffCV); |
|
|
|
} |
|
|
|
|
|
|
|
/* Check threshold voltage parameters */ |
|
|
|
if (pParam->BSIM3v32nlx < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Nlx = %g is negative.\n", pParam->BSIM3v32nlx); |
|
|
|
printf("Warning: Nlx = %g is negative.\n", pParam->BSIM3v32nlx); |
|
|
|
} |
|
|
|
if (model->BSIM3v32tox < 1.0e-9) |
|
|
|
{ fprintf(fplog, "Warning: Tox = %g is less than 10A.\n", |
|
|
|
model->BSIM3v32tox); |
|
|
|
printf("Warning: Tox = %g is less than 10A.\n", model->BSIM3v32tox); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32npeak <= 1.0e15) |
|
|
|
{ fprintf(fplog, "Warning: Nch = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
printf("Warning: Nch = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
} |
|
|
|
else if (pParam->BSIM3v32npeak >= 1.0e21) |
|
|
|
{ fprintf(fplog, "Warning: Nch = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
printf("Warning: Nch = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32npeak); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32nsub <= 1.0e14) |
|
|
|
{ fprintf(fplog, "Warning: Nsub = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
printf("Warning: Nsub = %g may be too small.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
} |
|
|
|
else if (pParam->BSIM3v32nsub >= 1.0e21) |
|
|
|
{ fprintf(fplog, "Warning: Nsub = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
printf("Warning: Nsub = %g may be too large.\n", |
|
|
|
pParam->BSIM3v32nsub); |
|
|
|
} |
|
|
|
|
|
|
|
if ((pParam->BSIM3v32ngate > 0.0) && |
|
|
|
(pParam->BSIM3v32ngate <= 1.e18)) |
|
|
|
{ fprintf(fplog, "Warning: Ngate = %g is less than 1.E18cm^-3.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
printf("Warning: Ngate = %g is less than 1.E18cm^-3.\n", |
|
|
|
pParam->BSIM3v32ngate); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32dvt0 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Dvt0 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32dvt0); |
|
|
|
printf("Warning: Dvt0 = %g is negative.\n", pParam->BSIM3v32dvt0); |
|
|
|
} |
|
|
|
|
|
|
|
if (fabs(1.0e-6 / (pParam->BSIM3v32w0 + pParam->BSIM3v32weff)) > 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->BSIM3v32nfactor < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Nfactor = %g is negative.\n", |
|
|
|
pParam->BSIM3v32nfactor); |
|
|
|
printf("Warning: Nfactor = %g is negative.\n", pParam->BSIM3v32nfactor); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32cdsc < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Cdsc = %g is negative.\n", |
|
|
|
pParam->BSIM3v32cdsc); |
|
|
|
printf("Warning: Cdsc = %g is negative.\n", pParam->BSIM3v32cdsc); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32cdscd < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Cdscd = %g is negative.\n", |
|
|
|
pParam->BSIM3v32cdscd); |
|
|
|
printf("Warning: Cdscd = %g is negative.\n", pParam->BSIM3v32cdscd); |
|
|
|
} |
|
|
|
/* Check DIBL parameters */ |
|
|
|
if (pParam->BSIM3v32eta0 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Eta0 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32eta0); |
|
|
|
printf("Warning: Eta0 = %g is negative.\n", pParam->BSIM3v32eta0); |
|
|
|
} |
|
|
|
|
|
|
|
/* Check Abulk parameters */ |
|
|
|
if (fabs(1.0e-6 / (pParam->BSIM3v32b1 + pParam->BSIM3v32weff)) > 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->BSIM3v32a2 < 0.01) |
|
|
|
{ fprintf(fplog, "Warning: A2 = %g is too small. Set to 0.01.\n", pParam->BSIM3v32a2); |
|
|
|
printf("Warning: A2 = %g is too small. Set to 0.01.\n", |
|
|
|
pParam->BSIM3v32a2); |
|
|
|
pParam->BSIM3v32a2 = 0.01; |
|
|
|
} |
|
|
|
else if (pParam->BSIM3v32a2 > 1.0) |
|
|
|
{ fprintf(fplog, "Warning: A2 = %g is larger than 1. A2 is set to 1 and A1 is set to 0.\n", |
|
|
|
pParam->BSIM3v32a2); |
|
|
|
printf("Warning: A2 = %g is larger than 1. A2 is set to 1 and A1 is set to 0.\n", |
|
|
|
pParam->BSIM3v32a2); |
|
|
|
pParam->BSIM3v32a2 = 1.0; |
|
|
|
pParam->BSIM3v32a1 = 0.0; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32rdsw < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Rdsw = %g is negative. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rdsw); |
|
|
|
printf("Warning: Rdsw = %g is negative. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rdsw); |
|
|
|
pParam->BSIM3v32rdsw = 0.0; |
|
|
|
pParam->BSIM3v32rds0 = 0.0; |
|
|
|
} |
|
|
|
else if ((pParam->BSIM3v32rds0 > 0.0) && (pParam->BSIM3v32rds0 < 0.001)) |
|
|
|
{ fprintf(fplog, "Warning: Rds at current temperature = %g is less than 0.001 ohm. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rds0); |
|
|
|
printf("Warning: Rds at current temperature = %g is less than 0.001 ohm. Set to zero.\n", |
|
|
|
pParam->BSIM3v32rds0); |
|
|
|
pParam->BSIM3v32rds0 = 0.0; |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32vsattemp < 1.0e3) |
|
|
|
{ fprintf(fplog, "Warning: Vsat at current temperature = %g may be too small.\n", pParam->BSIM3v32vsattemp); |
|
|
|
printf("Warning: Vsat at current temperature = %g may be too small.\n", pParam->BSIM3v32vsattemp); |
|
|
|
} |
|
|
|
|
|
|
|
if (pParam->BSIM3v32pdibl1 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Pdibl1 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32pdibl1); |
|
|
|
printf("Warning: Pdibl1 = %g is negative.\n", pParam->BSIM3v32pdibl1); |
|
|
|
} |
|
|
|
if (pParam->BSIM3v32pdibl2 < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: Pdibl2 = %g is negative.\n", |
|
|
|
pParam->BSIM3v32pdibl2); |
|
|
|
printf("Warning: Pdibl2 = %g is negative.\n", pParam->BSIM3v32pdibl2); |
|
|
|
} |
|
|
|
/* Check overlap capacitance parameters */ |
|
|
|
if (model->BSIM3v32cgdo < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: cgdo = %g is negative. Set to zero.\n", model->BSIM3v32cgdo); |
|
|
|
printf("Warning: cgdo = %g is negative. Set to zero.\n", model->BSIM3v32cgdo); |
|
|
|
model->BSIM3v32cgdo = 0.0; |
|
|
|
} |
|
|
|
if (model->BSIM3v32cgso < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: cgso = %g is negative. Set to zero.\n", model->BSIM3v32cgso); |
|
|
|
printf("Warning: cgso = %g is negative. Set to zero.\n", model->BSIM3v32cgso); |
|
|
|
model->BSIM3v32cgso = 0.0; |
|
|
|
} |
|
|
|
if (model->BSIM3v32cgbo < 0.0) |
|
|
|
{ fprintf(fplog, "Warning: cgbo = %g is negative. Set to zero.\n", model->BSIM3v32cgbo); |
|
|
|
printf("Warning: cgbo = %g is negative. Set to zero.\n", model->BSIM3v32cgbo); |
|
|
|
model->BSIM3v32cgbo = 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"); |
|
|
|
|