1 package net.mograsim.logic.model.model.components.mi.nandbased;
3 import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
4 import net.mograsim.logic.core.types.Bit;
5 import net.mograsim.logic.core.types.BitVector;
6 import net.mograsim.logic.model.model.ViewModelModifiable;
7 import net.mograsim.logic.model.model.components.submodels.SimpleRectangularSubmodelComponent;
8 import net.mograsim.logic.model.model.wires.GUIWire;
9 import net.mograsim.logic.model.model.wires.Pin;
10 import net.mograsim.logic.model.model.wires.WireCrossPoint;
11 import net.mograsim.logic.model.serializing.IndirectGUIComponentCreator;
13 public class GUIdlatch4 extends SimpleRectangularSubmodelComponent
15 private GUIdlatch dlatch1;
16 private GUIdlatch dlatch2;
17 private GUIdlatch dlatch3;
18 private GUIdlatch dlatch4;
20 public GUIdlatch4(ViewModelModifiable model)
25 public GUIdlatch4(ViewModelModifiable model, String name)
27 super(model, 1, "GUIdlatch4", name);
29 setInputPins("D1", "D2", "D3", "D4", "C");
30 setOutputPins("Q1", "Q2", "Q3", "Q4");
31 initSubmodelComponents();
34 @SuppressWarnings("unused") // for GUIWires being created
35 private void initSubmodelComponents()
37 Pin D1 = getSubmodelPin("D1");
38 Pin D2 = getSubmodelPin("D2");
39 Pin D3 = getSubmodelPin("D3");
40 Pin D4 = getSubmodelPin("D4");
41 Pin C = getSubmodelPin("C");
42 Pin Q1 = getSubmodelPin("Q1");
43 Pin Q2 = getSubmodelPin("Q2");
44 Pin Q3 = getSubmodelPin("Q3");
45 Pin Q4 = getSubmodelPin("Q4");
47 dlatch1 = new GUIdlatch(submodelModifiable);
48 dlatch2 = new GUIdlatch(submodelModifiable);
49 dlatch3 = new GUIdlatch(submodelModifiable);
50 dlatch4 = new GUIdlatch(submodelModifiable);
52 WireCrossPoint cp2 = new WireCrossPoint(submodelModifiable, 1);
53 WireCrossPoint cp3 = new WireCrossPoint(submodelModifiable, 1);
54 WireCrossPoint cp4 = new WireCrossPoint(submodelModifiable, 1);
56 dlatch1.moveTo(30, 7.5);
57 dlatch2.moveTo(30, 32.5);
58 dlatch3.moveTo(30, 57.5);
59 dlatch4.moveTo(30, 82.5);
60 cp2.moveCenterTo(15, 47.5);
61 cp3.moveCenterTo(15, 72.5);
62 cp4.moveCenterTo(15, 97.5);
64 new GUIWire(submodelModifiable, C, cp4, new Point(15, 112.5));
65 new GUIWire(submodelModifiable, cp4, dlatch4.getPin("E"), new Point[0]);
66 new GUIWire(submodelModifiable, cp4, cp3, new Point[0]);
67 new GUIWire(submodelModifiable, cp3, dlatch3.getPin("E"), new Point[0]);
68 new GUIWire(submodelModifiable, cp3, cp2, new Point[0]);
69 new GUIWire(submodelModifiable, cp2, dlatch2.getPin("E"), new Point[0]);
70 new GUIWire(submodelModifiable, cp2, dlatch1.getPin("E"), new Point(15, 22.5));
71 new GUIWire(submodelModifiable, D1, dlatch1.getPin("D"), new Point[0]);
72 new GUIWire(submodelModifiable, D2, dlatch2.getPin("D"), new Point[0]);
73 new GUIWire(submodelModifiable, D3, dlatch3.getPin("D"), new Point[0]);
74 new GUIWire(submodelModifiable, D4, dlatch4.getPin("D"), new Point[0]);
75 new GUIWire(submodelModifiable, dlatch1.getPin("Q"), Q1, new Point[0]);
76 new GUIWire(submodelModifiable, dlatch2.getPin("Q"), Q2, new Point[0]);
77 new GUIWire(submodelModifiable, dlatch3.getPin("Q"), Q3, new Point[0]);
78 new GUIWire(submodelModifiable, dlatch4.getPin("Q"), Q4, new Point[0]);
80 addAtomicHighLevelStateID("q1");
81 addAtomicHighLevelStateID("q2");
82 addAtomicHighLevelStateID("q3");
83 addAtomicHighLevelStateID("q4");
84 addAtomicHighLevelStateID("q");
88 public void setAtomicHighLevelState(String stateID, Object newState)
93 dlatch1.setHighLevelState("q", newState);
96 dlatch2.setHighLevelState("q", newState);
99 dlatch3.setHighLevelState("q", newState);
102 dlatch4.setHighLevelState("q", newState);
105 BitVector newStateCasted = (BitVector) newState;
106 setHighLevelState("q1", newStateCasted.getLSBit(0));
107 setHighLevelState("q2", newStateCasted.getLSBit(1));
108 setHighLevelState("q3", newStateCasted.getLSBit(2));
109 setHighLevelState("q4", newStateCasted.getLSBit(3));
112 // should not happen because we tell SubmodelComponent to only allow these state IDs.
113 throw new IllegalStateException("Illegal atomic state ID: " + stateID);
118 public Object getAtomicHighLevelState(String stateID)
123 return dlatch1.getHighLevelState("q");
125 return dlatch2.getHighLevelState("q");
127 return dlatch3.getHighLevelState("q");
129 return dlatch4.getHighLevelState("q");
131 Bit q1 = (Bit) getHighLevelState("q1");
132 Bit q2 = (Bit) getHighLevelState("q2");
133 Bit q3 = (Bit) getHighLevelState("q3");
134 Bit q4 = (Bit) getHighLevelState("q4");
135 return BitVector.of(q4, q3, q2, q1);
137 // should not happen because we tell SubmodelComponent to only allow these state IDs.
138 throw new IllegalStateException("Illegal atomic state ID: " + stateID);
144 IndirectGUIComponentCreator.setComponentSupplier(GUIdlatch4.class.getCanonicalName(), (m, p, n) -> new GUIdlatch4(m, n));