1 package net.mograsim.logic.model.examples;
3 import java.util.ArrayList;
4 import java.util.Comparator;
7 import net.mograsim.logic.model.SimpleLogicUIStandalone;
8 import net.mograsim.logic.model.am2900.Am2900Loader;
9 import net.mograsim.logic.model.model.LogicModelModifiable;
10 import net.mograsim.logic.model.model.components.ModelComponent;
11 import net.mograsim.logic.model.model.components.atomic.ModelBitDisplay;
12 import net.mograsim.logic.model.model.components.atomic.ModelManualSwitch;
13 import net.mograsim.logic.model.model.components.atomic.ModelTextComponent;
14 import net.mograsim.logic.model.model.wires.ModelWire;
15 import net.mograsim.logic.model.model.wires.Pin;
16 import net.mograsim.logic.model.model.wires.PinUsage;
17 import net.mograsim.logic.model.serializing.IndirectModelComponentCreator;
19 public class ModelComponentTestbench
21 public static void main(String[] args)
23 SimpleLogicUIStandalone.executeVisualisation(ModelComponentTestbench::createTestbench);
26 @SuppressWarnings("unused") // for ModelWires being created
27 public static void createTestbench(LogicModelModifiable model)
30 // ModelComponent comp = new StrictAm2900MachineDefinition().createNew(model).getAm2900();
31 ModelComponent comp = IndirectModelComponentCreator.createComponent(model, "ram5_12");
33 List<String> inputPinNames = new ArrayList<>();
34 List<String> outputPinNames = new ArrayList<>();
35 for (Pin p : comp.getPins().values())
36 if (p.usage == PinUsage.INPUT)
37 inputPinNames.add(p.name);
39 // TODO handle TRISTATE pins
40 outputPinNames.add(p.name);
42 inputPinNames.sort(Comparator.comparing(comp::getPin, Comparator.comparing(Pin::getRelY)));
43 outputPinNames.sort(Comparator.comparing(comp::getPin, Comparator.comparing(Pin::getRelY)));
46 for (int i = 0; i < inputPinNames.size(); i++)
48 String pinName = inputPinNames.get(i);
49 ModelManualSwitch sw = new ModelManualSwitch(model, comp.getPin(pinName).logicWidth, pinName);
51 new ModelTextComponent(model, pinName).moveTo(20, 20 * i);
52 new ModelWire(model, comp.getPin(pinName), sw.getOutputPin());
54 for (int i = 0; i < outputPinNames.size(); i++)
56 String pinName = outputPinNames.get(i);
57 ModelBitDisplay bd = new ModelBitDisplay(model, comp.getPin(pinName).logicWidth, pinName);
58 bd.moveTo(200, 20 * i);
59 new ModelTextComponent(model, pinName).moveTo(220, 20 * i);
60 new ModelWire(model, comp.getPin(pinName), bd.getInputPin());