bsimcmg, adms workaround, split T1 into two
This commit is contained in:
parent
7e81a5e93f
commit
5169fcb0d3
|
|
@ -853,7 +853,7 @@ real ni, epssub, epssp, epsratio, Eg, Eg0, Nc;
|
|||
real Lg, deltaL, deltaL1, deltaLCV, Leff, Leff1, LeffCV, LeffCV_acc, Weff0, WeffCV0;
|
||||
real cox, cdsc, cbox;
|
||||
real nbody, phib, deltaPhi;
|
||||
real T0, T1, T2, T2y, T3, T3y, T4, T4a, T5, T6, T7, T8, T9;
|
||||
real T0, T1, T1y, T2, T2y, T3, T3y, T4, T4a, T5, T6, T7, T8, T9;
|
||||
real Vtm, Vtm0, nVtm;
|
||||
real beta, beta0 ;
|
||||
real wf, wr;
|
||||
|
|
@ -2137,16 +2137,16 @@ analog begin
|
|||
// Self-Heating
|
||||
`ifdef __SHMOD__
|
||||
if (SHMOD != 0 && RTH0 > 0.0) begin
|
||||
T1 = WTH0;
|
||||
T1y = WTH0;
|
||||
if (BSHEXP != 0.0) begin
|
||||
T1 = WTH0 * pow(NF, BSHEXP);
|
||||
T1y = WTH0 * pow(NF, BSHEXP);
|
||||
end
|
||||
T2y = FPITCH;
|
||||
if (ASHEXP != 0.0) begin
|
||||
T2y = FPITCH * pow(NFINtotal, ASHEXP);
|
||||
end
|
||||
gth = (T1 + T2y)/ RTH0;
|
||||
cth = CTH0 * (T1 + T2y);
|
||||
gth = (T1y + T2y)/ RTH0;
|
||||
cth = CTH0 * (T1y + T2y);
|
||||
end else begin
|
||||
gth = 1.0;
|
||||
cth = 0.0;
|
||||
|
|
@ -2197,8 +2197,8 @@ analog begin
|
|||
// Component: Spreading Resistance (extension -> hdd)
|
||||
thetarsp = 55.0 * `M_PI / 180.0;
|
||||
afin = min(Arsd, max(1.0e-18, TFIN * (HFIN + min(0.0, HEPI))));
|
||||
T1 = `COT(thetarsp);
|
||||
Rsp = rhorsd * T1 / (sqrt(`M_PI) * NFIN) * (1.0 / sqrt(afin) - 2.0 / sqrt(Arsd) + sqrt(afin / (Arsd*Arsd)));
|
||||
T1y = `COT(thetarsp);
|
||||
Rsp = rhorsd * T1y / (sqrt(`M_PI) * NFIN) * (1.0 / sqrt(afin) - 2.0 / sqrt(Arsd) + sqrt(afin / (Arsd*Arsd)));
|
||||
|
||||
// Component: Contact Resistance
|
||||
arsd_total = Arsd * NFIN + ARSDEND;
|
||||
|
|
@ -2209,9 +2209,9 @@ analog begin
|
|||
|
||||
if (SDTERM == 1.0) begin
|
||||
eta = rhorsd * lt / RHOC;
|
||||
T1 = T0 * (1.0 + eta);
|
||||
T2y = T1 + 1.0 - eta;
|
||||
T3y = T1 - 1.0 + eta;
|
||||
T1y = T0 * (1.0 + eta);
|
||||
T2y = T1y + 1.0 - eta;
|
||||
T3y = T1y - 1.0 + eta;
|
||||
end else begin
|
||||
T2y = T0 + 1.0;
|
||||
T3y = T0 - 1.0;
|
||||
|
|
@ -2293,8 +2293,8 @@ analog begin
|
|||
if (TMASK > 0.0) begin
|
||||
// Capacitance Model by Chung-Hsun Lin (IBM)
|
||||
T0 = 3.467e-11 * lln(1.0e-7 * EPSRSP / (3.9 * LSP));
|
||||
T1 = 0.942 * Hrsd * epssp / LSP;
|
||||
Cgg_top = (T0 + T1) * (TFIN + (FPITCH - TFIN) * CRATIO);
|
||||
T1y = 0.942 * Hrsd * epssp / LSP;
|
||||
Cgg_top = (T0 + T1y) * (TFIN + (FPITCH - TFIN) * CRATIO);
|
||||
end else begin
|
||||
`Cfringe_2d(cfr_top_trigate, Hg, Hrsd, LSP, TFIN, LRSD, Lg, TOXP, 0.85, Cgg_top)
|
||||
end
|
||||
|
|
@ -2388,10 +2388,10 @@ analog begin
|
|||
end
|
||||
|
||||
T0 = TOXG * TOXG;
|
||||
T1 = TOXG * POXEDGE_i;
|
||||
T2y = T1 * T1;
|
||||
T1y = TOXG * POXEDGE_i;
|
||||
T2y = T1y * T1y;
|
||||
Toxratio = lexp(NTOX_i * lln(TOXREF / TOXG)) / T0;
|
||||
Toxratioedge = lexp(NTOX_i * lln(TOXREF / T1)) / T2y;
|
||||
Toxratioedge = lexp(NTOX_i * lln(TOXREF / T1y)) / T2y;
|
||||
igsd_mult0 = Weff0 * Aechvb * Toxratioedge;
|
||||
|
||||
if (TNOM < -`P_CELSIUS0) begin
|
||||
|
|
|
|||
Loading…
Reference in New Issue