-
Notifications
You must be signed in to change notification settings - Fork 0
/
DiacElm.java
109 lines (104 loc) · 3.06 KB
/
DiacElm.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// stub implementation of DiacElm, based on SparkGapElm
// FIXME need to add DiacElm.java to srclist
// FIXME need to uncomment DiacElm line from CirSim.java
import java.awt.*;
import java.util.StringTokenizer;
class DiacElm extends CircuitElm {
double onresistance, offresistance, breakdown, holdcurrent;
boolean state;
public DiacElm(int xx, int yy) {
super(xx, yy);
// FIXME need to adjust defaults to make sense for diac
offresistance = 1e9;
onresistance = 1e3;
breakdown = 1e3;
holdcurrent = 0.001;
state = false;
}
public DiacElm(int xa, int ya, int xb, int yb, int f,
StringTokenizer st) {
super(xa, ya, xb, yb, f);
onresistance = new Double(st.nextToken()).doubleValue();
offresistance = new Double(st.nextToken()).doubleValue();
breakdown = new Double(st.nextToken()).doubleValue();
holdcurrent = new Double(st.nextToken()).doubleValue();
}
boolean nonLinear() {return true;}
int getDumpType() { return 203; }
String dump() {
return super.dump() + " " + onresistance + " " + offresistance + " "
+ breakdown + " " + holdcurrent;
}
Point ps3, ps4;
void setPoints() {
super.setPoints();
calcLeads(32);
ps3 = new Point();
ps4 = new Point();
}
void draw(Graphics g) {
// FIXME need to draw Diac
int i;
double v1 = volts[0];
double v2 = volts[1];
setBbox(point1, point2, 6);
draw2Leads(g);
setPowerColor(g, true);
doDots(g);
drawPosts(g);
}
void calculateCurrent() {
double vd = volts[0] - volts[1];
if(state)
current = vd/onresistance;
else
current = vd/offresistance;
}
void startIteration() {
double vd = volts[0] - volts[1];
if(Math.abs(current) < holdcurrent) state = false;
if(Math.abs(vd) > breakdown) state = true;
//System.out.print(this + " res current set to " + current + "\n");
}
void doStep() {
if(state)
sim.stampResistor(nodes[0], nodes[1], onresistance);
else
sim.stampResistor(nodes[0], nodes[1], offresistance);
}
void stamp() {
sim.stampNonLinear(nodes[0]);
sim.stampNonLinear(nodes[1]);
}
void getInfo(String arr[]) {
// FIXME
arr[0] = "spark gap";
getBasicInfo(arr);
arr[3] = state ? "on" : "off";
arr[4] = "Ron = " + getUnitText(onresistance, sim.ohmString);
arr[5] = "Roff = " + getUnitText(offresistance, sim.ohmString);
arr[6] = "Vbrkdn = " + getUnitText(breakdown, "V");
arr[7] = "Ihold = " + getUnitText(holdcurrent, "A");
}
public EditInfo getEditInfo(int n) {
if (n == 0)
return new EditInfo("On resistance (ohms)", onresistance, 0, 0);
if (n == 1)
return new EditInfo("Off resistance (ohms)", offresistance, 0, 0);
if (n == 2)
return new EditInfo("Breakdown voltage (volts)", breakdown, 0, 0);
if (n == 3)
return new EditInfo("Hold current (amps)", holdcurrent, 0, 0);
return null;
}
public void setEditValue(int n, EditInfo ei) {
if (ei.value > 0 && n == 0)
onresistance = ei.value;
if (ei.value > 0 && n == 1)
offresistance = ei.value;
if (ei.value > 0 && n == 2)
breakdown = ei.value;
if (ei.value > 0 && n == 3)
holdcurrent = ei.value;
}
}