Branch data Line data Source code
1 : : /*
2 : : * photodiode.core.h - device class definitions for photodiode 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 __photodiode_H__
12 : : #define __photodiode_H__
13 : :
14 [ # # ]: 0 : class photodiode : public qucs::circuit
15 : : {
16 : : public:
17 [ # # ]: 208 : CREATOR (photodiode);
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[4];
55 : : nr_double_t _qhs[4];
56 : : nr_double_t _ghs[4];
57 : : nr_double_t _chs[4];
58 : : nr_double_t _jstat[4][4];
59 : : nr_double_t _jdyna[4][4];
60 : : nr_double_t _white_pwr[4][4];
61 : : nr_double_t _flicker_pwr[4][4];
62 : : nr_double_t _flicker_exp[4][4];
63 : : nr_double_t _charges[4][4];
64 : : nr_double_t _caps[4][4][4][4];
65 : :
66 : : // device model parameters
67 : : nr_double_t N;
68 : : nr_double_t Rseries;
69 : : nr_double_t Is;
70 : : nr_double_t Bv;
71 : : nr_double_t Ibv;
72 : : nr_double_t Vj;
73 : : nr_double_t Cj0;
74 : : nr_double_t M;
75 : : nr_double_t Area;
76 : : nr_double_t Tnom;
77 : : nr_double_t Fc;
78 : : nr_double_t Tt;
79 : : nr_double_t Xti;
80 : : nr_double_t Eg;
81 : : nr_double_t Responsivity;
82 : : nr_double_t Rsh;
83 : : nr_double_t QEpercent;
84 : : nr_double_t Lambda;
85 : : int LEVEL;
86 : : nr_double_t Kf;
87 : : nr_double_t Af;
88 : : nr_double_t Ffe;
89 : :
90 : : // global model variables
91 : :
92 : : //
93 : : double F1;
94 : : //
95 : : double F2;
96 : : //
97 : : double F3;
98 : : //
99 : : double Rseries_Area;
100 : : //
101 : : double Vt_T2;
102 : : //
103 : : double Vj_T2;
104 : : //
105 : : double GMIN;
106 : : //
107 : : double Res;
108 : : //
109 : : double con1;
110 : : //
111 : : double con2;
112 : : //
113 : : double con3;
114 : : //
115 : : double con4;
116 : : //
117 : : double con5;
118 : : //
119 : : double con6;
120 : :
121 : :
122 : : };
123 : :
124 : : #endif /* __photodiode_H__ */
|