1 package net.mograsim.logic.model.am2900.components;
3 import static net.mograsim.logic.core.types.Bit.ONE;
4 import static net.mograsim.logic.core.types.Bit.U;
5 import static net.mograsim.logic.core.types.Bit.X;
6 import static net.mograsim.logic.core.types.Bit.Z;
7 import static net.mograsim.logic.core.types.Bit.ZERO;
11 import net.mograsim.logic.core.types.Bit;
12 import net.mograsim.logic.core.wires.Wire.ReadEnd;
13 import net.mograsim.logic.core.wires.Wire.ReadWriteEnd;
14 import net.mograsim.logic.model.model.ViewModelModifiable;
15 import net.mograsim.logic.model.model.components.atomic.SimpleRectangularHardcodedGUIComponent;
16 import net.mograsim.logic.model.model.wires.Pin;
17 import net.mograsim.logic.model.snippets.symbolrenderers.PinNamesSymbolRenderer.PinNamesParams.Position;
19 public class GUInor12 extends SimpleRectangularHardcodedGUIComponent
21 public GUInor12(ViewModelModifiable model, String name)
23 super(model, name, "=0");
25 addPin(new Pin(this, "D", 12, 0, 10), Usage.INPUT, Position.RIGHT);
26 addPin(new Pin(this, "Y", 1, 30, 10), Usage.OUTPUT, Position.LEFT);
30 protected Object recalculate(Object lastState, Map<String, ReadEnd> readEnds, Map<String, ReadWriteEnd> readWriteEnds)
32 readWriteEnds.get("Y").feedSignals(getResult(readEnds.get("D").getValues().getBits()));
36 private static Bit getResult(Bit[] DValArr)
38 for (int i = 0; i < 12; i++)
41 for (int i = 0; i < 12; i++)
44 for (int i = 0; i < 12; i++)
45 if (DValArr[i] == ONE)
47 for (int i = 0; i < 12; i++)