Branch data Line data Source code
1 : : /*
2 : : * hicumL2V2p31n.core.h - device class definitions for hicumL2V2p31n module
3 : : *
4 : : * This is free software; you can redistribute it and/or modify
5 : : * it under the terms of the GNU General Public License as published by
6 : : * the Free Software Foundation; either version 2, or (at your option)
7 : : * any later version.
8 : : *
9 : : */
10 : :
11 : : #ifndef __hicumL2V2p31n_H__
12 : : #define __hicumL2V2p31n_H__
13 : :
14 [ # # ]: 0 : class hicumL2V2p31n : public qucs::circuit
15 : : {
16 : : public:
17 [ # # ]: 208 : CREATOR (hicumL2V2p31n);
18 : :
19 : : void initDC (void);
20 : : void restartDC (void);
21 : : void calcDC (void);
22 : : void saveOperatingPoints (void);
23 : : void loadOperatingPoints (void);
24 : : void calcOperatingPoints (void);
25 : : void initAC (void);
26 : : void calcAC (nr_double_t);
27 : : void initSP (void);
28 : : void calcSP (nr_double_t);
29 : : void calcNoiseAC (nr_double_t);
30 : : void calcNoiseSP (nr_double_t);
31 : : void initTR (void);
32 : : void calcTR (nr_double_t);
33 : : void initHB (int);
34 : : void calcHB (int);
35 : :
36 : : private:
37 : : void initVerilog (void);
38 : : void calcVerilog (void);
39 : : void initModel (void);
40 : : void loadVariables (void);
41 : : void initializeModel (void);
42 : : void initializeInstance (void);
43 : : void initialStep (void);
44 : : void finalStep (void);
45 : : qucs::matrix calcMatrixY (nr_double_t);
46 : : qucs::matrix calcMatrixCy (nr_double_t);
47 : :
48 : : private:
49 : : int doHB;
50 : : int doAC;
51 : : int doTR;
52 : :
53 : : nr_double_t _freq;
54 : : nr_double_t _rhs[15];
55 : : nr_double_t _qhs[15];
56 : : nr_double_t _ghs[15];
57 : : nr_double_t _chs[15];
58 : : nr_double_t _jstat[15][15];
59 : : nr_double_t _jdyna[15][15];
60 : : nr_double_t _white_pwr[15][15];
61 : : nr_double_t _flicker_pwr[15][15];
62 : : nr_double_t _flicker_exp[15][15];
63 : : nr_double_t _charges[15][15];
64 : : nr_double_t _caps[15][15][15][15];
65 : :
66 : : // device model parameters
67 : : nr_double_t c10;
68 : : nr_double_t qp0;
69 : : nr_double_t ich;
70 : : nr_double_t hf0;
71 : : nr_double_t hfe;
72 : : nr_double_t hfc;
73 : : nr_double_t hjei;
74 : : nr_double_t ahjei;
75 : : nr_double_t rhjei;
76 : : nr_double_t hjci;
77 : : nr_double_t ibeis;
78 : : nr_double_t mbei;
79 : : nr_double_t ireis;
80 : : nr_double_t mrei;
81 : : nr_double_t ibeps;
82 : : nr_double_t mbep;
83 : : nr_double_t ireps;
84 : : nr_double_t mrep;
85 : : nr_double_t mcf;
86 : : nr_double_t tbhrec;
87 : : nr_double_t ibcis;
88 : : nr_double_t mbci;
89 : : nr_double_t ibcxs;
90 : : nr_double_t mbcx;
91 : : nr_double_t ibets;
92 : : nr_double_t abet;
93 : : int tunode;
94 : : nr_double_t favl;
95 : : nr_double_t qavl;
96 : : nr_double_t alfav;
97 : : nr_double_t alqav;
98 : : nr_double_t rbi0;
99 : : nr_double_t rbx;
100 : : nr_double_t fgeo;
101 : : nr_double_t fdqr0;
102 : : nr_double_t fcrbi;
103 : : nr_double_t fqi;
104 : : nr_double_t re;
105 : : nr_double_t rcx;
106 : : nr_double_t itss;
107 : : nr_double_t msf;
108 : : nr_double_t iscs;
109 : : nr_double_t msc;
110 : : nr_double_t tsf;
111 : : nr_double_t rsu;
112 : : nr_double_t csu;
113 : : nr_double_t cjei0;
114 : : nr_double_t vdei;
115 : : nr_double_t zei;
116 : : nr_double_t ajei;
117 : : nr_double_t cjep0;
118 : : nr_double_t vdep;
119 : : nr_double_t zep;
120 : : nr_double_t ajep;
121 : : nr_double_t cjci0;
122 : : nr_double_t vdci;
123 : : nr_double_t zci;
124 : : nr_double_t vptci;
125 : : nr_double_t cjcx0;
126 : : nr_double_t vdcx;
127 : : nr_double_t zcx;
128 : : nr_double_t vptcx;
129 : : nr_double_t fbcpar;
130 : : nr_double_t fbepar;
131 : : nr_double_t cjs0;
132 : : nr_double_t vds;
133 : : nr_double_t zs;
134 : : nr_double_t vpts;
135 : : nr_double_t t0;
136 : : nr_double_t dt0h;
137 : : nr_double_t tbvl;
138 : : nr_double_t tef0;
139 : : nr_double_t gtfe;
140 : : nr_double_t thcs;
141 : : nr_double_t ahc;
142 : : nr_double_t fthc;
143 : : nr_double_t rci0;
144 : : nr_double_t vlim;
145 : : nr_double_t vces;
146 : : nr_double_t vpt;
147 : : nr_double_t tr;
148 : : nr_double_t vcbar;
149 : : nr_double_t icbar;
150 : : nr_double_t acbar;
151 : : nr_double_t delck;
152 : : nr_double_t cbepar;
153 : : nr_double_t cbcpar;
154 : : nr_double_t alqf;
155 : : nr_double_t alit;
156 : : int flnqs;
157 : : nr_double_t kf;
158 : : nr_double_t af;
159 : : int cfbe;
160 : : int flcono;
161 : : nr_double_t kfre;
162 : : nr_double_t afre;
163 : : nr_double_t latb;
164 : : nr_double_t latl;
165 : : nr_double_t vgb;
166 : : nr_double_t alt0;
167 : : nr_double_t kt0;
168 : : nr_double_t zetaci;
169 : : nr_double_t alvs;
170 : : nr_double_t alces;
171 : : nr_double_t zetarbi;
172 : : nr_double_t zetarbx;
173 : : nr_double_t zetarcx;
174 : : nr_double_t zetare;
175 : : nr_double_t zetacx;
176 : : nr_double_t vge;
177 : : nr_double_t vgc;
178 : : nr_double_t vgs;
179 : : nr_double_t f1vg;
180 : : nr_double_t f2vg;
181 : : nr_double_t zetact;
182 : : nr_double_t zetabet;
183 : : nr_double_t alb;
184 : : nr_double_t dvgbe;
185 : : nr_double_t zetahjei;
186 : : nr_double_t zetavgbe;
187 : : int flsh;
188 : : nr_double_t rth;
189 : : nr_double_t zetarth;
190 : : nr_double_t alrth;
191 : : nr_double_t cth;
192 : : nr_double_t flcomp;
193 : : nr_double_t tnom;
194 : : nr_double_t dt;
195 : :
196 : : // global model variables
197 : : double VT;
198 : : double Tdev;
199 : : double qtt0;
200 : : double ln_qtt0;
201 : : double r_VgVT;
202 : : double V_gT;
203 : : double dT;
204 : : double k;
205 : : double ireis_t;
206 : : double ibeis_t;
207 : : double ibcxs_t;
208 : : double ibcis_t;
209 : : double iscs_t;
210 : : double cjci0_t;
211 : : double cjs0_t;
212 : : double rci0_t;
213 : : double vlim_t;
214 : : double vces_t;
215 : : double thcs_t;
216 : : double tef0_t;
217 : : double rbi0_t;
218 : : double rbx_t;
219 : : double rcx_t;
220 : : double re_t;
221 : : double t0_t;
222 : : double vdei_t;
223 : : double vdci_t;
224 : : double vpts_t;
225 : : double itss_t;
226 : : double tsf_t;
227 : : double c10_t;
228 : : double cjei0_t;
229 : : double qp0_t;
230 : : double vdcx_t;
231 : : double vptcx_t;
232 : : double cjcx01_t;
233 : : double cjcx02_t;
234 : : double cratio_t;
235 : : double ibeps_t;
236 : : double ireps_t;
237 : : double cjep0_t;
238 : : double ajei_t;
239 : : double qavl_t;
240 : : double favl_t;
241 : : double ibets_t;
242 : : double abet_t;
243 : : double vptci_t;
244 : : double vdep_t;
245 : : double ajep_t;
246 : : double zetatef;
247 : : double k1;
248 : : double k2;
249 : : double dvg0;
250 : : double vge_t;
251 : : double vgb_t;
252 : : double vgbe_t;
253 : : double vds_t;
254 : : double vt0;
255 : : double Tnom;
256 : : double Tamb;
257 : : double a;
258 : : double avs;
259 : : double zetabci;
260 : : double zetabcxt;
261 : : double zetasct;
262 : : double vgbe0;
263 : : double mg;
264 : : double vgbe_t0;
265 : : double vgbc0;
266 : : double vgsc0;
267 : : double cbcpar1;
268 : : double cbcpar2;
269 : : double cbepar2;
270 : : double cbepar1;
271 : : double Oich;
272 : : double Otbhrec;
273 : : double rth_t;
274 : : double vdj0;
275 : : double vdjt;
276 : : double vdt;
277 : : double cjcx01;
278 : : double cjcx02;
279 : : double hjei0_t;
280 : : double ahjei_t;
281 : : double hf0_t;
282 : : double hfe_t;
283 : : double hfc_t;
284 : :
285 : : //
286 : : double it;
287 : : //
288 : : double ibei;
289 : : //
290 : : double ibci;
291 : : //
292 : : double ibep;
293 : : //
294 : : double iavl;
295 : : //
296 : : double ijbcx;
297 : : //
298 : : double ijsc;
299 : : //
300 : : double rbi;
301 : : //
302 : : double Tf;
303 : : //
304 : : double betadc;
305 : :
306 : :
307 : : };
308 : :
309 : : #endif /* __hicumL2V2p31n_H__ */
|