1 package net.mograsim.logic.ui.model.components.mi.nandbased.am2901;
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.ui.model.ViewModelModifiable;
7 import net.mograsim.logic.ui.model.components.mi.nandbased.GUIand;
8 import net.mograsim.logic.ui.model.components.mi.nandbased.GUIdff;
9 import net.mograsim.logic.ui.model.components.submodels.SimpleRectangularSubmodelComponent;
10 import net.mograsim.logic.ui.model.wires.GUIWire;
11 import net.mograsim.logic.ui.model.wires.Pin;
12 import net.mograsim.logic.ui.model.wires.WireCrossPoint;
13 import net.mograsim.logic.ui.serializing.IndirectGUIComponentCreator;
15 public class GUIAm2901QReg extends SimpleRectangularSubmodelComponent
22 public GUIAm2901QReg(ViewModelModifiable model)
27 public GUIAm2901QReg(ViewModelModifiable model, String name)
29 super(model, 1, "GUIAm2901QReg", name);
31 setInputPins("C", "WE", "D1", "D2", "D3", "D4");
32 setOutputPins("Q1", "Q2", "Q3", "Q4");
33 initSubmodelComponents();
36 @SuppressWarnings("unused") // for GUIWires being created
37 private void initSubmodelComponents()
39 Pin C = getSubmodelPin("C");
40 Pin WE = getSubmodelPin("WE");
41 Pin D1 = getSubmodelPin("D1");
42 Pin D2 = getSubmodelPin("D2");
43 Pin D3 = getSubmodelPin("D3");
44 Pin D4 = getSubmodelPin("D4");
45 Pin Q1 = getSubmodelPin("Q1");
46 Pin Q2 = getSubmodelPin("Q2");
47 Pin Q3 = getSubmodelPin("Q3");
48 Pin Q4 = getSubmodelPin("Q4");
50 GUIand and = new GUIand(submodelModifiable);
51 dff1 = new GUIdff(submodelModifiable);
52 dff2 = new GUIdff(submodelModifiable);
53 dff3 = new GUIdff(submodelModifiable);
54 dff4 = new GUIdff(submodelModifiable);
56 WireCrossPoint cpC1 = new WireCrossPoint(submodelModifiable, 1);
57 WireCrossPoint cpC2 = new WireCrossPoint(submodelModifiable, 1);
58 WireCrossPoint cpC3 = new WireCrossPoint(submodelModifiable, 1);
62 dff2.moveTo(50, 32.5);
63 dff3.moveTo(50, 57.5);
64 dff4.moveTo(50, 82.5);
65 cpC1.moveCenterTo(42.5, 20);
66 cpC2.moveCenterTo(42.5, 37.5);
67 cpC3.moveCenterTo(42.5, 62.5);
69 new GUIWire(submodelModifiable, C, and.getPin("A"));
70 new GUIWire(submodelModifiable, WE, and.getPin("B"));
71 new GUIWire(submodelModifiable, and.getPin("Y"), cpC1, new Point[0]);
72 new GUIWire(submodelModifiable, cpC1, dff1.getPin("C"), new Point(42.5, 12.5));
73 new GUIWire(submodelModifiable, cpC1, cpC2, new Point[0]);
74 new GUIWire(submodelModifiable, cpC2, dff2.getPin("C"), new Point[0]);
75 new GUIWire(submodelModifiable, cpC2, cpC3, new Point[0]);
76 new GUIWire(submodelModifiable, cpC3, dff3.getPin("C"), new Point[0]);
77 new GUIWire(submodelModifiable, cpC3, dff4.getPin("C"), new Point(42.5, 87.5));
78 new GUIWire(submodelModifiable, D1, dff1.getPin("D"), new Point(17.5, 62.5), new Point(17.5, 42.5), new Point(45, 42.5),
80 new GUIWire(submodelModifiable, D2, dff2.getPin("D"), new Point(22.5, 87.5), new Point(22.5, 47.5));
81 new GUIWire(submodelModifiable, D3, dff3.getPin("D"), new Point(27.5, 112.5), new Point(27.5, 72.5));
82 new GUIWire(submodelModifiable, D4, dff4.getPin("D"), new Point(32.5, 137.5), new Point(32.5, 97.5));
83 new GUIWire(submodelModifiable, dff1.getPin("Q"), Q1, new Point[0]);
84 new GUIWire(submodelModifiable, dff2.getPin("Q"), Q2, new Point[0]);
85 new GUIWire(submodelModifiable, dff3.getPin("Q"), Q3, new Point[0]);
86 new GUIWire(submodelModifiable, dff4.getPin("Q"), Q4, new Point[0]);
88 addAtomicHighLevelStateID("q1");
89 addAtomicHighLevelStateID("q2");
90 addAtomicHighLevelStateID("q3");
91 addAtomicHighLevelStateID("q4");
92 addAtomicHighLevelStateID("q");
96 public void setAtomicHighLevelState(String stateID, Object newState)
101 dff1.setHighLevelState("q", newState);
104 dff2.setHighLevelState("q", newState);
107 dff3.setHighLevelState("q", newState);
110 dff4.setHighLevelState("q", newState);
113 BitVector newStateCasted = (BitVector) newState;
114 setHighLevelState("q1", newStateCasted.getBit(0));
115 setHighLevelState("q2", newStateCasted.getBit(1));
116 setHighLevelState("q3", newStateCasted.getBit(2));
117 setHighLevelState("q4", newStateCasted.getBit(3));
120 // should not happen because we tell SubmodelComponent to only allow these state IDs.
121 throw new IllegalStateException("Illegal atomic state ID: " + stateID);
126 public Object getAtomicHighLevelState(String stateID)
131 return dff1.getHighLevelState("q");
133 return dff2.getHighLevelState("q");
135 return dff3.getHighLevelState("q");
137 return dff4.getHighLevelState("q");
139 Bit q1 = (Bit) getHighLevelState("q1");
140 Bit q2 = (Bit) getHighLevelState("q2");
141 Bit q3 = (Bit) getHighLevelState("q3");
142 Bit q4 = (Bit) getHighLevelState("q4");
143 return BitVector.of(q1, q2, q3, q4);
145 // should not happen because we tell SubmodelComponent to only allow these state IDs.
146 throw new IllegalStateException("Illegal atomic state ID: " + stateID);
152 IndirectGUIComponentCreator.setComponentSupplier(GUIAm2901QReg.class.getCanonicalName(), (m, p, n) -> new GUIAm2901QReg(m, n));