X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=net.mograsim.logic.ui.am2900%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fui%2Fmodel%2Fcomponents%2Fmi%2Fnandbased%2FGUIram4.java;h=c34c50c259f7eb76c0e4000e1b2551db40a46b84;hb=574918bb58faa3c617911ed4f629f90066668364;hp=4f7c30340ad99feef7437cb49b925c42d84e980b;hpb=c2ba1e811b4ebd9e14377e25fadaf5774a28830e;p=Mograsim.git diff --git a/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java b/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java index 4f7c3034..c34c50c2 100644 --- a/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java +++ b/net.mograsim.logic.ui.am2900/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIram4.java @@ -285,128 +285,111 @@ public class GUIram4 extends SimpleRectangularSubmodelComponent new GUIWire(submodelModifiable, andorA11.getPin("Y3"), QA3 , new Point(200, 760), new Point(200, 890), new Point(320, 890), new Point(320, 250)); new GUIWire(submodelModifiable, andorA11.getPin("Y4"), QA4 , new Point(195, 770), new Point(195, 895), new Point(325, 895), new Point(325, 350)); //@formatter:on + + addHighLevelStateSubcomponentID("c00", cell00); + addHighLevelStateSubcomponentID("c10", cell01); + addHighLevelStateSubcomponentID("c01", cell10); + addHighLevelStateSubcomponentID("c11", cell11); + addAtomicHighLevelStateID("q"); } @Override - public Object getHighLevelState(String stateID) + public void setAtomicHighLevelState(String stateID, Object newState) { switch (stateID) { case "q": - BitVector q0000 = (BitVector) getHighLevelState("c0000.q"); - BitVector q0001 = (BitVector) getHighLevelState("c0100.q"); - BitVector q0010 = (BitVector) getHighLevelState("c1000.q"); - BitVector q0011 = (BitVector) getHighLevelState("c1100.q"); - BitVector q0100 = (BitVector) getHighLevelState("c0001.q"); - BitVector q0101 = (BitVector) getHighLevelState("c0101.q"); - BitVector q0110 = (BitVector) getHighLevelState("c1001.q"); - BitVector q0111 = (BitVector) getHighLevelState("c1101.q"); - BitVector q1000 = (BitVector) getHighLevelState("c0010.q"); - BitVector q1001 = (BitVector) getHighLevelState("c0110.q"); - BitVector q1010 = (BitVector) getHighLevelState("c1010.q"); - BitVector q1011 = (BitVector) getHighLevelState("c1110.q"); - BitVector q1100 = (BitVector) getHighLevelState("c0011.q"); - BitVector q1101 = (BitVector) getHighLevelState("c1011.q"); - BitVector q1110 = (BitVector) getHighLevelState("c0111.q"); - BitVector q1111 = (BitVector) getHighLevelState("c1111.q"); - return q0000.concat(q0001).concat(q0010).concat(q0011).concat(q0100).concat(q0101).concat(q0110).concat(q0111).concat(q1000) - .concat(q1001).concat(q1010).concat(q1011).concat(q1100).concat(q1101).concat(q1110).concat(q1111); + BitVector newStateCasted = (BitVector) newState; + setHighLevelState("c00.q", newStateCasted.subVector(0, 16)); + setHighLevelState("c01.q", newStateCasted.subVector(16, 32)); + setHighLevelState("c11.q", newStateCasted.subVector(32, 48)); + setHighLevelState("c11.q", newStateCasted.subVector(48, 64)); + break; + default: + // should not happen because we tell SubmodelComponent to only allow these state IDs. + throw new IllegalStateException("Illegal atomic state ID: " + stateID); + } + } + + @Override + protected void setSubcomponentHighLevelState(String subcomponentID, String subcomponentHighLevelStateID, Object newState) + { + switch (subcomponentID) + { + case "c0000": + case "c0001": + case "c0010": + case "c0011": + cell00.setHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID, newState); + break; + case "c1000": + case "c1001": + case "c1010": + case "c1011": + cell01.setHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID, newState); + break; + case "c0100": + case "c0101": + case "c0110": + case "c0111": + cell10.setHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID, newState); + break; + case "c1100": + case "c1101": + case "c1110": + case "c1111": + cell11.setHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID, newState); + break; default: - int indexOfDot = stateID.indexOf('.'); - if (indexOfDot != -1) - { - String cellID = stateID.substring(0, indexOfDot); - switch (cellID) - { - case "c0000": - case "c0100": - case "c1000": - case "c1100": - return cell00.getHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot)); - case "c0001": - case "c0101": - case "c1001": - case "c1101": - return cell01.getHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot)); - case "c0010": - case "c0110": - case "c1010": - case "c1110": - return cell10.getHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot)); - case "c0011": - case "c0111": - case "c1011": - case "c1111": - return cell11.getHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot)); - default: - return super.getHighLevelState(stateID); - } - } - return super.getHighLevelState(stateID); + super.setSubcomponentHighLevelState(subcomponentID, subcomponentHighLevelStateID, newState); + break; } } @Override - public void setHighLevelState(String stateID, Object newState) + public Object getAtomicHighLevelState(String stateID) { switch (stateID) { case "q": - BitVector newStateCasted = (BitVector) newState; - setHighLevelState("c0000.q", newStateCasted.subVector(0, 4)); - setHighLevelState("c0100.q", newStateCasted.subVector(4, 8)); - setHighLevelState("c1000.q", newStateCasted.subVector(8, 12)); - setHighLevelState("c1100.q", newStateCasted.subVector(12, 16)); - setHighLevelState("c0001.q", newStateCasted.subVector(16, 20)); - setHighLevelState("c0101.q", newStateCasted.subVector(20, 24)); - setHighLevelState("c1001.q", newStateCasted.subVector(24, 28)); - setHighLevelState("c1101.q", newStateCasted.subVector(28, 32)); - setHighLevelState("c0010.q", newStateCasted.subVector(32, 36)); - setHighLevelState("c0110.q", newStateCasted.subVector(36, 40)); - setHighLevelState("c1010.q", newStateCasted.subVector(40, 44)); - setHighLevelState("c1110.q", newStateCasted.subVector(44, 48)); - setHighLevelState("c0011.q", newStateCasted.subVector(48, 52)); - setHighLevelState("c1011.q", newStateCasted.subVector(52, 56)); - setHighLevelState("c0111.q", newStateCasted.subVector(56, 60)); - setHighLevelState("c1111.q", newStateCasted.subVector(60, 64)); - break; + BitVector q00 = (BitVector) getHighLevelState("c00.q"); + BitVector q01 = (BitVector) getHighLevelState("c01.q"); + BitVector q10 = (BitVector) getHighLevelState("c10.q"); + BitVector q11 = (BitVector) getHighLevelState("c11.q"); + return q00.concat(q01).concat(q10).concat(q11); + default: + // should not happen because we tell SubmodelComponent to only allow these state IDs. + throw new IllegalStateException("Illegal atomic state ID: " + stateID); + } + } + + @Override + protected Object getSubcomponentHighLevelState(String subcomponentID, String subcomponentHighLevelStateID) + { + switch (subcomponentID) + { + case "c0000": + case "c0001": + case "c0010": + case "c0011": + return cell00.getHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID); + case "c0100": + case "c0101": + case "c0110": + case "c0111": + return cell01.getHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID); + case "c1000": + case "c1001": + case "c1010": + case "c1011": + return cell10.getHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID); + case "c1100": + case "c1101": + case "c1110": + case "c1111": + return cell11.getHighLevelState('c' + subcomponentID.substring(3, 5) + "." + subcomponentHighLevelStateID); default: - int indexOfDot = stateID.indexOf('.'); - if (indexOfDot != -1) - { - String cellID = stateID.substring(0, indexOfDot); - switch (cellID) - { - case "c0000": - case "c0100": - case "c1000": - case "c1100": - cell00.setHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot), newState); - break; - case "c0001": - case "c0101": - case "c1001": - case "c1101": - cell01.setHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot), newState); - break; - case "c0010": - case "c0110": - case "c1010": - case "c1110": - cell10.setHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot), newState); - break; - case "c0011": - case "c0111": - case "c1011": - case "c1111": - cell11.setHighLevelState(cellID.substring(0, 3) + stateID.substring(indexOfDot), newState); - break; - default: - super.setHighLevelState(stateID, newState); - break; - } - } else - super.setHighLevelState(stateID, newState); + return super.getSubcomponentHighLevelState(subcomponentID, subcomponentHighLevelStateID); } } } \ No newline at end of file