From: Daniel Kirschten Date: Tue, 11 Jun 2019 19:55:28 +0000 (+0200) Subject: Implemented GUIram4 X-Git-Url: https://mograsim.net/gitweb/?a=commitdiff_plain;h=bce800b0d70f37586debea30a6e77faf5da9e714;p=Mograsim.git Implemented GUIram4 --- diff --git a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/examples/SubmodelComponentTestbench.java b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/examples/SubmodelComponentTestbench.java index 616df047..1803f693 100644 --- a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/examples/SubmodelComponentTestbench.java +++ b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/examples/SubmodelComponentTestbench.java @@ -5,7 +5,7 @@ import net.mograsim.logic.ui.model.ViewModelModifiable; import net.mograsim.logic.ui.model.components.GUIBitDisplay; import net.mograsim.logic.ui.model.components.GUIManualSwitch; import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent; -import net.mograsim.logic.ui.model.components.mi.nandbased.GUIram2; +import net.mograsim.logic.ui.model.components.mi.nandbased.GUIram4; import net.mograsim.logic.ui.model.wires.GUIWire; public class SubmodelComponentTestbench @@ -18,7 +18,7 @@ public class SubmodelComponentTestbench @SuppressWarnings("unused") // for GUIWires being created public static void createTestbench(ViewModelModifiable model) { - SimpleRectangularSubmodelComponent comp = new GUIram2(model); + SimpleRectangularSubmodelComponent comp = new GUIram4(model); comp.moveTo(100, 0); for (int i = 0; i < comp.getInputPins().size(); i++) diff --git a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java new file mode 100644 index 00000000..02dc9c32 --- /dev/null +++ b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java @@ -0,0 +1,328 @@ +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.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 GUIram4 extends SimpleRectangularSubmodelComponent +{ + public GUIram4(ViewModelModifiable model) + { + super(model, 1, "GUIram4"); + setSubmodelScale(.1); + setInputCount(13); + setOutputCount(8); + initSubmodelComponents(); + } + + @SuppressWarnings("unused") // for GUIWires being created + private void initSubmodelComponents() + { + //@formatter:off + Pin A0 = getInputSubmodelPins() .get( 0); + Pin A1 = getInputSubmodelPins() .get( 1); + Pin A2 = getInputSubmodelPins() .get( 2); + Pin A3 = getInputSubmodelPins() .get( 3); + Pin B0 = getInputSubmodelPins() .get( 4); + Pin B1 = getInputSubmodelPins() .get( 5); + Pin B2 = getInputSubmodelPins() .get( 6); + Pin B3 = getInputSubmodelPins() .get( 7); + Pin WE = getInputSubmodelPins() .get( 8); + Pin D1 = getInputSubmodelPins() .get( 9); + Pin D2 = getInputSubmodelPins() .get(10); + Pin D3 = getInputSubmodelPins() .get(11); + Pin D4 = getInputSubmodelPins() .get(12); + Pin QA1 = getOutputSubmodelPins().get( 0); + Pin QA2 = getOutputSubmodelPins().get( 1); + Pin QA3 = getOutputSubmodelPins().get( 2); + Pin QA4 = getOutputSubmodelPins().get( 3); + Pin QB1 = getOutputSubmodelPins().get( 4); + Pin QB2 = getOutputSubmodelPins().get( 5); + Pin QB3 = getOutputSubmodelPins().get( 6); + Pin QB4 = getOutputSubmodelPins().get( 7); + + GUIdemux2 demuxA = new GUIdemux2 (submodelModifiable); + GUIdemux2 demuxB = new GUIdemux2 (submodelModifiable); + GUIand41 weAndB = new GUIand41 (submodelModifiable); + GUIram2 cell00 = new GUIram2 (submodelModifiable); + GUIram2 cell01 = new GUIram2 (submodelModifiable); + GUIram2 cell10 = new GUIram2 (submodelModifiable); + GUIram2 cell11 = new GUIram2 (submodelModifiable); + GUIand41 andA00 = new GUIand41 (submodelModifiable); + GUIandor414 andorA01 = new GUIandor414(submodelModifiable); + GUIandor414 andorA10 = new GUIandor414(submodelModifiable); + GUIandor414 andorA11 = new GUIandor414(submodelModifiable); + GUIand41 andB00 = new GUIand41 (submodelModifiable); + GUIandor414 andorB01 = new GUIandor414(submodelModifiable); + GUIandor414 andorB10 = new GUIandor414(submodelModifiable); + GUIandor414 andorB11 = new GUIandor414(submodelModifiable); + + WireCrossPoint cpB00 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpB01 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpB10 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpB11 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_101 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_201 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_301 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_401 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_110 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_210 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_310 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_410 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_111 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_211 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_311 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpD_411 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB101 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB201 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB301 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB401 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB110 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB210 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB310 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB410 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB1in = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB2in = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpAB4in = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ100 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ200 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ300 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ400 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ101 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ201 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ301 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ401 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ110 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ210 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ310 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ410 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ111 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ211 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ311 = new WireCrossPoint(submodelModifiable, 1); + WireCrossPoint cpQ411 = new WireCrossPoint(submodelModifiable, 1); + + demuxA .moveTo( 55, 45); + demuxB .moveTo( 55, 150); + weAndB .moveTo(150, 150); + cell00 .moveTo( 75, 325); + cell01 .moveTo( 75, 475); + cell10 .moveTo( 75, 625); + cell11 .moveTo( 75, 775); + andA00 .moveTo(250, 375); + andorA01.moveTo(250, 485); + andorA10.moveTo(250, 635); + andorA11.moveTo(250, 785); + andB00 .moveTo(155, 325); + andorB01.moveTo(155, 435); + andorB10.moveTo(155, 585); + andorB11.moveTo(155, 735); + cpB00 .moveCenterTo(130, 155); + cpB01 .moveCenterTo(125, 165); + cpB10 .moveCenterTo(120, 175); + cpB11 .moveCenterTo(115, 185); + cpD_101.moveCenterTo( 62.5, 530); + cpD_201.moveCenterTo( 65 , 540); + cpD_301.moveCenterTo( 67.5, 550); + cpD_401.moveCenterTo( 70 , 560); + cpD_110.moveCenterTo( 62.5, 680); + cpD_210.moveCenterTo( 65 , 690); + cpD_310.moveCenterTo( 67.5, 700); + cpD_410.moveCenterTo( 70 , 710); + cpD_111.moveCenterTo( 62.5, 830); + cpD_211.moveCenterTo( 65 , 840); + cpD_311.moveCenterTo( 67.5, 850); + cpD_411.moveCenterTo( 70 , 860); + cpAB101.moveCenterTo( 40, 480); + cpAB201.moveCenterTo( 45, 490); + cpAB301.moveCenterTo( 50, 500); + cpAB401.moveCenterTo( 55, 510); + cpAB110.moveCenterTo( 40, 630); + cpAB210.moveCenterTo( 45, 640); + cpAB310.moveCenterTo( 50, 650); + cpAB410.moveCenterTo( 55, 660); + cpAB1in.moveCenterTo( 40, 330); + cpAB2in.moveCenterTo( 45, 350); + cpAB4in.moveCenterTo( 55, 750); + cpQ100.moveCenterTo(150, 330); + cpQ200.moveCenterTo(145, 340); + cpQ300.moveCenterTo(140, 350); + cpQ400.moveCenterTo(135, 360); + cpQ101.moveCenterTo(150, 480); + cpQ201.moveCenterTo(145, 490); + cpQ301.moveCenterTo(140, 500); + cpQ401.moveCenterTo(135, 510); + cpQ110.moveCenterTo(150, 630); + cpQ210.moveCenterTo(145, 640); + cpQ310.moveCenterTo(140, 650); + cpQ410.moveCenterTo(135, 660); + cpQ111.moveCenterTo(150, 780); + cpQ211.moveCenterTo(145, 790); + cpQ311.moveCenterTo(140, 800); + cpQ411.moveCenterTo(135, 810); + + new GUIWire(submodelModifiable, A0, demuxA.getInputPins().get(0), new Point[0]); + new GUIWire(submodelModifiable, A1, demuxA.getInputPins().get(1), new Point(10, 150), new Point(10, 60)); + new GUIWire(submodelModifiable, B0, demuxB.getInputPins().get(0), new Point( 5, 450), new Point( 5, 155)); + new GUIWire(submodelModifiable, B1, demuxB.getInputPins().get(1), new Point(10, 550), new Point(10, 165)); + new GUIWire(submodelModifiable, demuxB.getOutputPins().get(0), cpB00, new Point[0]); + new GUIWire(submodelModifiable, demuxB.getOutputPins().get(1), cpB01, new Point[0]); + new GUIWire(submodelModifiable, demuxB.getOutputPins().get(2), cpB10, new Point[0]); + new GUIWire(submodelModifiable, demuxB.getOutputPins().get(3), cpB11, new Point[0]); + new GUIWire(submodelModifiable, cpB00, weAndB.getInputPins().get(0), new Point[0]); + new GUIWire(submodelModifiable, cpB01, weAndB.getInputPins().get(1), new Point[0]); + new GUIWire(submodelModifiable, cpB10, weAndB.getInputPins().get(2), new Point[0]); + new GUIWire(submodelModifiable, cpB11, weAndB.getInputPins().get(3), new Point[0]); + new GUIWire(submodelModifiable, WE, weAndB.getInputPins().get(4), new Point(15, 850), new Point(15, 195)); + new GUIWire(submodelModifiable, weAndB.getOutputPins().get(0), cell00.getInputPins().get(4), new Point(205, 155), new Point(205, 230), new Point(35, 230), new Point(35, 370)); + new GUIWire(submodelModifiable, weAndB.getOutputPins().get(1), cell01.getInputPins().get(4), new Point(200, 165), new Point(200, 225), new Point(30, 225), new Point(30, 520)); + new GUIWire(submodelModifiable, weAndB.getOutputPins().get(2), cell10.getInputPins().get(4), new Point(195, 175), new Point(195, 220), new Point(25, 220), new Point(25, 670)); + new GUIWire(submodelModifiable, weAndB.getOutputPins().get(3), cell11.getInputPins().get(4), new Point(190, 185), new Point(190, 215), new Point(20, 215), new Point(20, 820)); + new GUIWire(submodelModifiable, cpAB101, cpAB1in , new Point[0]); + new GUIWire(submodelModifiable, cpAB1in, cell00.getInputPins().get(0), new Point[0]); + new GUIWire(submodelModifiable, cpAB201, cpAB2in , new Point[0]); + new GUIWire(submodelModifiable, cpAB2in, cell00.getInputPins().get(1), new Point(45, 340)); + new GUIWire(submodelModifiable, cpAB301, cell00.getInputPins().get(2), new Point(50, 350)); + new GUIWire(submodelModifiable, cpAB401, cell00.getInputPins().get(3), new Point(55, 360)); + new GUIWire(submodelModifiable, cpAB101, cell01.getInputPins().get(0), new Point[0]); + new GUIWire(submodelModifiable, cpAB201, cell01.getInputPins().get(1), new Point[0]); + new GUIWire(submodelModifiable, cpAB301, cell01.getInputPins().get(2), new Point[0]); + new GUIWire(submodelModifiable, cpAB401, cell01.getInputPins().get(3), new Point[0]); + new GUIWire(submodelModifiable, cpAB101, cpAB110 , new Point[0]); + new GUIWire(submodelModifiable, cpAB201, cpAB210 , new Point[0]); + new GUIWire(submodelModifiable, cpAB301, cpAB310 , new Point[0]); + new GUIWire(submodelModifiable, cpAB401, cpAB410 , new Point[0]); + new GUIWire(submodelModifiable, cpAB110, cell10.getInputPins().get(0), new Point[0]); + new GUIWire(submodelModifiable, cpAB210, cell10.getInputPins().get(1), new Point[0]); + new GUIWire(submodelModifiable, cpAB310, cell10.getInputPins().get(2), new Point[0]); + new GUIWire(submodelModifiable, cpAB410, cell10.getInputPins().get(3), new Point[0]); + new GUIWire(submodelModifiable, cpAB110, cell11.getInputPins().get(0), new Point(40, 780)); + new GUIWire(submodelModifiable, cpAB210, cell11.getInputPins().get(1), new Point(45, 790)); + new GUIWire(submodelModifiable, cpAB310, cell11.getInputPins().get(2), new Point(50, 800)); + new GUIWire(submodelModifiable, cpAB410, cpAB4in , new Point[0]); + new GUIWire(submodelModifiable, cpAB4in, cell11.getInputPins().get(3), new Point(55, 810)); + new GUIWire(submodelModifiable, A2, cpAB1in , new Point(40, 250)); + new GUIWire(submodelModifiable, A3, cpAB2in , new Point[0]); + new GUIWire(submodelModifiable, B2, cpAB310 , new Point[0]); + new GUIWire(submodelModifiable, B3, cpAB4in , new Point[0]); + new GUIWire(submodelModifiable, cpD_101, cell00.getInputPins().get(5), new Point(62.5, 380)); + new GUIWire(submodelModifiable, cpD_201, cell00.getInputPins().get(6), new Point(65 , 390)); + new GUIWire(submodelModifiable, cpD_301, cell00.getInputPins().get(7), new Point(67.5, 400)); + new GUIWire(submodelModifiable, cpD_401, cell00.getInputPins().get(8), new Point(70 , 410)); + new GUIWire(submodelModifiable, cpD_101, cell01.getInputPins().get(5), new Point[0]); + new GUIWire(submodelModifiable, cpD_201, cell01.getInputPins().get(6), new Point[0]); + new GUIWire(submodelModifiable, cpD_301, cell01.getInputPins().get(7), new Point[0]); + new GUIWire(submodelModifiable, cpD_401, cell01.getInputPins().get(8), new Point[0]); + new GUIWire(submodelModifiable, cpD_101, cpD_110 , new Point[0]); + new GUIWire(submodelModifiable, cpD_201, cpD_210 , new Point[0]); + new GUIWire(submodelModifiable, cpD_301, cpD_310 , new Point[0]); + new GUIWire(submodelModifiable, cpD_401, cpD_410 , new Point[0]); + new GUIWire(submodelModifiable, cpD_110, cell10.getInputPins().get(5), new Point[0]); + new GUIWire(submodelModifiable, cpD_210, cell10.getInputPins().get(6), new Point[0]); + new GUIWire(submodelModifiable, cpD_310, cell10.getInputPins().get(7), new Point[0]); + new GUIWire(submodelModifiable, cpD_410, cell10.getInputPins().get(8), new Point[0]); + new GUIWire(submodelModifiable, cpD_110, cpD_111 , new Point[0]); + new GUIWire(submodelModifiable, cpD_210, cpD_211 , new Point[0]); + new GUIWire(submodelModifiable, cpD_310, cpD_311 , new Point[0]); + new GUIWire(submodelModifiable, cpD_410, cpD_411 , new Point[0]); + new GUIWire(submodelModifiable, cpD_111, cell11.getInputPins().get(5), new Point[0]); + new GUIWire(submodelModifiable, cpD_211, cell11.getInputPins().get(6), new Point[0]); + new GUIWire(submodelModifiable, cpD_311, cell11.getInputPins().get(7), new Point[0]); + new GUIWire(submodelModifiable, cpD_411, cell11.getInputPins().get(8), new Point[0]); + new GUIWire(submodelModifiable, D1, cpD_111 , new Point(62.5, 950)); + new GUIWire(submodelModifiable, D2, cpD_211 , new Point(65 , 1050)); + new GUIWire(submodelModifiable, D3, cpD_311 , new Point(67.5, 1150)); + new GUIWire(submodelModifiable, D4, cpD_411 , new Point(70 , 1250)); + new GUIWire(submodelModifiable, cell00.getOutputPins().get(0), cpQ100, new Point[0]); + new GUIWire(submodelModifiable, cell00.getOutputPins().get(1), cpQ200, new Point[0]); + new GUIWire(submodelModifiable, cell00.getOutputPins().get(2), cpQ300, new Point[0]); + new GUIWire(submodelModifiable, cell00.getOutputPins().get(3), cpQ400, new Point[0]); + new GUIWire(submodelModifiable, cell01.getOutputPins().get(0), cpQ101, new Point[0]); + new GUIWire(submodelModifiable, cell01.getOutputPins().get(1), cpQ201, new Point[0]); + new GUIWire(submodelModifiable, cell01.getOutputPins().get(2), cpQ301, new Point[0]); + new GUIWire(submodelModifiable, cell01.getOutputPins().get(3), cpQ401, new Point[0]); + new GUIWire(submodelModifiable, cell10.getOutputPins().get(0), cpQ110, new Point[0]); + new GUIWire(submodelModifiable, cell10.getOutputPins().get(1), cpQ210, new Point[0]); + new GUIWire(submodelModifiable, cell10.getOutputPins().get(2), cpQ310, new Point[0]); + new GUIWire(submodelModifiable, cell10.getOutputPins().get(3), cpQ410, new Point[0]); + new GUIWire(submodelModifiable, cell11.getOutputPins().get(0), cpQ111, new Point[0]); + new GUIWire(submodelModifiable, cell11.getOutputPins().get(1), cpQ211, new Point[0]); + new GUIWire(submodelModifiable, cell11.getOutputPins().get(2), cpQ311, new Point[0]); + new GUIWire(submodelModifiable, cell11.getOutputPins().get(3), cpQ411, new Point[0]); + new GUIWire(submodelModifiable, demuxA.getOutputPins().get(0), andA00 .getInputPins().get(4), new Point(230, 50), new Point(230, 420)); + new GUIWire(submodelModifiable, demuxA.getOutputPins().get(1), andorA01.getInputPins().get(8), new Point(225, 60), new Point(225, 570)); + new GUIWire(submodelModifiable, demuxA.getOutputPins().get(2), andorA10.getInputPins().get(8), new Point(220, 70), new Point(220, 720)); + new GUIWire(submodelModifiable, demuxA.getOutputPins().get(3), andorA11.getInputPins().get(8), new Point(215, 80), new Point(215, 870)); + new GUIWire(submodelModifiable, cpB00 , andB00 .getInputPins().get(4), new Point(130, 370)); + new GUIWire(submodelModifiable, cpB01 , andorB01.getInputPins().get(8), new Point(125, 520)); + new GUIWire(submodelModifiable, cpB10 , andorB10.getInputPins().get(8), new Point(120, 670)); + new GUIWire(submodelModifiable, cpB11 , andorB11.getInputPins().get(8), new Point(115, 820)); + new GUIWire(submodelModifiable, cpQ100, andA00 .getInputPins().get(0), new Point(150, 380)); + new GUIWire(submodelModifiable, cpQ200, andA00 .getInputPins().get(1), new Point(145, 390)); + new GUIWire(submodelModifiable, cpQ300, andA00 .getInputPins().get(2), new Point(140, 400)); + new GUIWire(submodelModifiable, cpQ400, andA00 .getInputPins().get(3), new Point(135, 410)); + new GUIWire(submodelModifiable, cpQ101, andorA01.getInputPins().get(4), new Point(150, 530)); + new GUIWire(submodelModifiable, cpQ201, andorA01.getInputPins().get(5), new Point(145, 540)); + new GUIWire(submodelModifiable, cpQ301, andorA01.getInputPins().get(6), new Point(140, 550)); + new GUIWire(submodelModifiable, cpQ401, andorA01.getInputPins().get(7), new Point(135, 560)); + new GUIWire(submodelModifiable, cpQ110, andorA10.getInputPins().get(4), new Point(150, 680)); + new GUIWire(submodelModifiable, cpQ210, andorA10.getInputPins().get(5), new Point(145, 690)); + new GUIWire(submodelModifiable, cpQ310, andorA10.getInputPins().get(6), new Point(140, 700)); + new GUIWire(submodelModifiable, cpQ410, andorA10.getInputPins().get(7), new Point(135, 710)); + new GUIWire(submodelModifiable, cpQ111, andorA11.getInputPins().get(4), new Point(150, 830)); + new GUIWire(submodelModifiable, cpQ211, andorA11.getInputPins().get(5), new Point(145, 840)); + new GUIWire(submodelModifiable, cpQ311, andorA11.getInputPins().get(6), new Point(140, 850)); + new GUIWire(submodelModifiable, cpQ411, andorA11.getInputPins().get(7), new Point(135, 860)); + new GUIWire(submodelModifiable, cpQ100, andB00 .getInputPins().get(0), new Point[0]); + new GUIWire(submodelModifiable, cpQ200, andB00 .getInputPins().get(1), new Point[0]); + new GUIWire(submodelModifiable, cpQ300, andB00 .getInputPins().get(2), new Point[0]); + new GUIWire(submodelModifiable, cpQ400, andB00 .getInputPins().get(3), new Point[0]); + new GUIWire(submodelModifiable, cpQ101, andorB01.getInputPins().get(4), new Point[0]); + new GUIWire(submodelModifiable, cpQ201, andorB01.getInputPins().get(5), new Point[0]); + new GUIWire(submodelModifiable, cpQ301, andorB01.getInputPins().get(6), new Point[0]); + new GUIWire(submodelModifiable, cpQ401, andorB01.getInputPins().get(7), new Point[0]); + new GUIWire(submodelModifiable, cpQ110, andorB10.getInputPins().get(4), new Point[0]); + new GUIWire(submodelModifiable, cpQ210, andorB10.getInputPins().get(5), new Point[0]); + new GUIWire(submodelModifiable, cpQ310, andorB10.getInputPins().get(6), new Point[0]); + new GUIWire(submodelModifiable, cpQ410, andorB10.getInputPins().get(7), new Point[0]); + new GUIWire(submodelModifiable, cpQ111, andorB11.getInputPins().get(4), new Point[0]); + new GUIWire(submodelModifiable, cpQ211, andorB11.getInputPins().get(5), new Point[0]); + new GUIWire(submodelModifiable, cpQ311, andorB11.getInputPins().get(6), new Point[0]); + new GUIWire(submodelModifiable, cpQ411, andorB11.getInputPins().get(7), new Point[0]); + new GUIWire(submodelModifiable, andA00 .getOutputPins().get(0), andorA01.getInputPins().get(0), new Point(305, 380), new Point(305, 445), new Point(245, 445), new Point(245, 490)); + new GUIWire(submodelModifiable, andA00 .getOutputPins().get(1), andorA01.getInputPins().get(1), new Point(300, 390), new Point(300, 440), new Point(240, 440), new Point(240, 500)); + new GUIWire(submodelModifiable, andA00 .getOutputPins().get(2), andorA01.getInputPins().get(2), new Point(295, 400), new Point(295, 435), new Point(235, 435), new Point(235, 510)); + new GUIWire(submodelModifiable, andA00 .getOutputPins().get(3), andorA01.getInputPins().get(3), new Point(290, 410), new Point(290, 430), new Point(230, 430), new Point(230, 520)); + new GUIWire(submodelModifiable, andorA01.getOutputPins().get(0), andorA10.getInputPins().get(0), new Point(305, 490), new Point(305, 595), new Point(245, 595), new Point(245, 640)); + new GUIWire(submodelModifiable, andorA01.getOutputPins().get(1), andorA10.getInputPins().get(1), new Point(300, 500), new Point(300, 590), new Point(240, 590), new Point(240, 650)); + new GUIWire(submodelModifiable, andorA01.getOutputPins().get(2), andorA10.getInputPins().get(2), new Point(295, 510), new Point(295, 585), new Point(235, 585), new Point(235, 660)); + new GUIWire(submodelModifiable, andorA01.getOutputPins().get(3), andorA10.getInputPins().get(3), new Point(290, 520), new Point(290, 580), new Point(230, 580), new Point(230, 670)); + new GUIWire(submodelModifiable, andorA10.getOutputPins().get(0), andorA11.getInputPins().get(0), new Point(305, 640), new Point(305, 745), new Point(245, 745), new Point(245, 790)); + new GUIWire(submodelModifiable, andorA10.getOutputPins().get(1), andorA11.getInputPins().get(1), new Point(300, 650), new Point(300, 740), new Point(240, 740), new Point(240, 800)); + new GUIWire(submodelModifiable, andorA10.getOutputPins().get(2), andorA11.getInputPins().get(2), new Point(295, 660), new Point(295, 735), new Point(235, 735), new Point(235, 810)); + new GUIWire(submodelModifiable, andorA10.getOutputPins().get(3), andorA11.getInputPins().get(3), new Point(290, 670), new Point(290, 730), new Point(230, 730), new Point(230, 820)); + new GUIWire(submodelModifiable, andorA11.getOutputPins().get(0), QA1 , new Point(310, 790), new Point(310, 50)); + new GUIWire(submodelModifiable, andorA11.getOutputPins().get(1), QA2 , new Point(315, 800), new Point(315, 150)); + new GUIWire(submodelModifiable, andorA11.getOutputPins().get(2), QA3 , new Point(320, 810), new Point(320, 250)); + new GUIWire(submodelModifiable, andorA11.getOutputPins().get(3), QA4 , new Point(325, 820), new Point(325, 350)); + new GUIWire(submodelModifiable, andB00 .getOutputPins().get(0), andorB01.getInputPins().get(0), new Point(210, 330), new Point(210, 430), new Point(150, 430), new Point(150, 440)); + new GUIWire(submodelModifiable, andB00 .getOutputPins().get(1), andorB01.getInputPins().get(1), new Point(205, 340), new Point(205, 425), new Point(145, 425), new Point(145, 450)); + new GUIWire(submodelModifiable, andB00 .getOutputPins().get(2), andorB01.getInputPins().get(2), new Point(200, 350), new Point(200, 420), new Point(140, 420), new Point(140, 460)); + new GUIWire(submodelModifiable, andB00 .getOutputPins().get(3), andorB01.getInputPins().get(3), new Point(195, 360), new Point(195, 415), new Point(135, 415), new Point(135, 470)); + new GUIWire(submodelModifiable, andorB01.getOutputPins().get(0), andorB10.getInputPins().get(0), new Point(210, 440), new Point(210, 580), new Point(150, 580), new Point(150, 590)); + new GUIWire(submodelModifiable, andorB01.getOutputPins().get(1), andorB10.getInputPins().get(1), new Point(205, 450), new Point(205, 575), new Point(145, 575), new Point(145, 600)); + new GUIWire(submodelModifiable, andorB01.getOutputPins().get(2), andorB10.getInputPins().get(2), new Point(200, 460), new Point(200, 570), new Point(140, 570), new Point(140, 610)); + new GUIWire(submodelModifiable, andorB01.getOutputPins().get(3), andorB10.getInputPins().get(3), new Point(195, 470), new Point(195, 565), new Point(135, 565), new Point(135, 620)); + new GUIWire(submodelModifiable, andorB10.getOutputPins().get(0), andorB11.getInputPins().get(0), new Point(210, 590), new Point(210, 730), new Point(150, 730), new Point(150, 740)); + new GUIWire(submodelModifiable, andorB10.getOutputPins().get(1), andorB11.getInputPins().get(1), new Point(205, 600), new Point(205, 725), new Point(145, 725), new Point(145, 750)); + new GUIWire(submodelModifiable, andorB10.getOutputPins().get(2), andorB11.getInputPins().get(2), new Point(200, 610), new Point(200, 720), new Point(140, 720), new Point(140, 760)); + new GUIWire(submodelModifiable, andorB10.getOutputPins().get(3), andorB11.getInputPins().get(3), new Point(195, 620), new Point(195, 715), new Point(135, 715), new Point(135, 770)); + new GUIWire(submodelModifiable, andorB11.getOutputPins().get(0), QB1 , new Point(210, 740), new Point(210, 880), new Point(330, 880), new Point(330, 450)); + new GUIWire(submodelModifiable, andorB11.getOutputPins().get(1), QB2 , new Point(205, 750), new Point(205, 885), new Point(335, 885), new Point(335, 550)); + new GUIWire(submodelModifiable, andorB11.getOutputPins().get(2), QB3 , new Point(200, 760), new Point(200, 890), new Point(340, 890), new Point(340, 650)); + new GUIWire(submodelModifiable, andorB11.getOutputPins().get(3), QB4 , new Point(195, 770), new Point(195, 895), new Point(345, 895), new Point(345, 750)); + //@formatter:on + } +} \ No newline at end of file