Added GUIsel2_4
authorFabian Stemmler <stemmler@in.tum.de>
Sat, 8 Jun 2019 15:00:28 +0000 (17:00 +0200)
committerFabian Stemmler <stemmler@in.tum.de>
Sat, 8 Jun 2019 15:00:28 +0000 (17:00 +0200)
net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIsel2_4.java [new file with mode: 0644]

diff --git a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIsel2_4.java b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIsel2_4.java
new file mode 100644 (file)
index 0000000..5294d14
--- /dev/null
@@ -0,0 +1,116 @@
+package net.mograsim.logic.ui.model.components.mi.nandbased;
+
+import net.haspamelodica.swt.helper.swtobjectwrappers.Point;
+import net.mograsim.logic.ui.model.ViewModelModifiable;
+import net.mograsim.logic.ui.model.components.GUINandGate;
+import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent;
+import net.mograsim.logic.ui.model.wires.GUIWire;
+import net.mograsim.logic.ui.model.wires.Pin;
+import net.mograsim.logic.ui.model.wires.WireCrossPoint;
+
+public class GUIsel2_4 extends SimpleRectangularSubmodelComponent
+{
+       public GUIsel2_4(ViewModelModifiable model)
+       {
+               super(model, 1, "GUIsel2_4");
+               setSubmodelScale(.4);
+               setInputCount(10);
+               setOutputCount(4);
+               initSubmodelComponents();
+       }
+
+       @SuppressWarnings("unused") // for GUIWires being created
+       private void initSubmodelComponents()
+       {
+               Pin SA = getInputSubmodelPins().get(0);
+               Pin SB = getInputSubmodelPins().get(1);
+               Pin A1 = getInputSubmodelPins().get(2);
+               Pin A2 = getInputSubmodelPins().get(3);
+               Pin A3 = getInputSubmodelPins().get(4);
+               Pin A4 = getInputSubmodelPins().get(5);
+               Pin B1 = getInputSubmodelPins().get(6);
+               Pin B2 = getInputSubmodelPins().get(7);
+               Pin B3 = getInputSubmodelPins().get(8);
+               Pin B4 = getInputSubmodelPins().get(9);
+               Pin Y1 = getOutputSubmodelPins().get(0);
+               Pin Y2 = getOutputSubmodelPins().get(1);
+               Pin Y3 = getOutputSubmodelPins().get(2);
+               Pin Y4 = getOutputSubmodelPins().get(3);
+
+               GUINandGate nandA1 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandA2 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandA3 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandA4 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandB1 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandB2 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandB3 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandB4 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandY1 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandY2 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandY3 = new GUINandGate(submodelModifiable, 1);
+               GUINandGate nandY4 = new GUINandGate(submodelModifiable, 1);
+
+               WireCrossPoint cpA1 = new WireCrossPoint(submodelModifiable, 1);
+               WireCrossPoint cpA2 = new WireCrossPoint(submodelModifiable, 1);
+               WireCrossPoint cpA3 = new WireCrossPoint(submodelModifiable, 1);
+               WireCrossPoint cpB1 = new WireCrossPoint(submodelModifiable, 1);
+               WireCrossPoint cpB2 = new WireCrossPoint(submodelModifiable, 1);
+               WireCrossPoint cpB3 = new WireCrossPoint(submodelModifiable, 1);
+
+               nandA1.moveCenterTo(20, 2.5);
+               nandB1.moveCenterTo(20, 27.5);
+               nandA2.moveCenterTo(20, 52.5);
+               nandB2.moveCenterTo(20, 77.5);
+               nandA3.moveCenterTo(20, 102.5);
+               nandB3.moveCenterTo(20, 127.5);
+               nandA4.moveCenterTo(20, 152.5);
+               nandB4.moveCenterTo(20, 177.5);
+               nandY1.moveCenterTo(65, 2.5);
+               nandY2.moveCenterTo(65, 27.5);
+               nandY3.moveCenterTo(65, 52.5);
+               nandY4.moveCenterTo(65, 77.5);
+               cpA1.moveCenterTo(7.5, 17.5);
+               cpB1.moveCenterTo(5, 42.5);
+               cpA2.moveCenterTo(7.5, 67.5);
+               cpB2.moveCenterTo(5, 92.5);
+               cpA3.moveCenterTo(7.5, 117.5);
+               cpB3.moveCenterTo(5, 142.5);
+               Point a4 = new Point(7.5, 167.5);
+               Point b4 = new Point(5, 192.5);
+
+               new GUIWire(submodelModifiable, A1, nandA1.getInputPins().get(0), new Point(15, 62.5), new Point(15, 7.5));
+               new GUIWire(submodelModifiable, A2, nandA2.getInputPins().get(0), new Point(17.5, 87.5), new Point(17.5, 57.5));
+               new GUIWire(submodelModifiable, A3, nandA3.getInputPins().get(0), new Point(17.5, 112.5), new Point(17.5, 107.5));
+               new GUIWire(submodelModifiable, A4, nandA4.getInputPins().get(0), new Point(17.5, 137.5), new Point(17.5, 157.5));
+               new GUIWire(submodelModifiable, B1, nandB1.getInputPins().get(0), new Point(10, 162.5), new Point(10, 32.5));
+               new GUIWire(submodelModifiable, B2, nandB2.getInputPins().get(0), new Point(12.5, 187.5), new Point(12.5, 82.5));
+               new GUIWire(submodelModifiable, B3, nandB3.getInputPins().get(0), new Point(15, 212.5), new Point(15, 132.5));
+               new GUIWire(submodelModifiable, B4, nandB4.getInputPins().get(0), new Point(10, 237.5), new Point(10, 182.5));
+               new GUIWire(submodelModifiable, SA, cpA1);
+               new GUIWire(submodelModifiable, SB, cpB1);
+               new GUIWire(submodelModifiable, cpA1, cpA2);
+               new GUIWire(submodelModifiable, cpA1, nandA1.getInputPins().get(1));
+               new GUIWire(submodelModifiable, cpA2, cpA3);
+               new GUIWire(submodelModifiable, cpA2, nandA2.getInputPins().get(1));
+               new GUIWire(submodelModifiable, cpA3, nandA3.getInputPins().get(1));
+               new GUIWire(submodelModifiable, cpA3, nandA4.getInputPins().get(1), a4);
+               new GUIWire(submodelModifiable, cpB1, cpB2);
+               new GUIWire(submodelModifiable, cpB1, nandB1.getInputPins().get(1));
+               new GUIWire(submodelModifiable, cpB2, cpB3);
+               new GUIWire(submodelModifiable, cpB2, nandB2.getInputPins().get(1));
+               new GUIWire(submodelModifiable, cpB3, nandB3.getInputPins().get(1));
+               new GUIWire(submodelModifiable, cpB3, nandB4.getInputPins().get(1), b4);
+               new GUIWire(submodelModifiable, nandA1.getOutputPin(), nandY1.getInputPins().get(0), new Point(40, 12.5), new Point(40, 7.5));
+               new GUIWire(submodelModifiable, nandB1.getOutputPin(), nandY1.getInputPins().get(1), new Point(40, 37.5), new Point(40, 17.5));
+               new GUIWire(submodelModifiable, nandA2.getOutputPin(), nandY2.getInputPins().get(0), new Point(42.5, 62.5), new Point(42.5, 32.5));
+               new GUIWire(submodelModifiable, nandB2.getOutputPin(), nandY2.getInputPins().get(1), new Point(45, 87.5), new Point(45, 42.5));
+               new GUIWire(submodelModifiable, nandA3.getOutputPin(), nandY3.getInputPins().get(0), new Point(47.5, 112.5), new Point(47.5, 57.5));
+               new GUIWire(submodelModifiable, nandB3.getOutputPin(), nandY3.getInputPins().get(1), new Point(50, 137.5), new Point(50, 67.5));
+               new GUIWire(submodelModifiable, nandA4.getOutputPin(), nandY4.getInputPins().get(0), new Point(52.5, 162.5), new Point(52.5, 82.5));
+               new GUIWire(submodelModifiable, nandB4.getOutputPin(), nandY4.getInputPins().get(1), new Point(55, 187.5), new Point(55, 92.5));
+               new GUIWire(submodelModifiable, nandY1.getOutputPin(), Y1, new Point[0]);
+               new GUIWire(submodelModifiable, nandY2.getOutputPin(), Y2, new Point[0]);
+               new GUIWire(submodelModifiable, nandY3.getOutputPin(), Y3, new Point[0]);
+               new GUIWire(submodelModifiable, nandY4.getOutputPin(), Y4, new Point[0]);
+       }
+}
\ No newline at end of file