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.SubmodelComponent;
-import net.mograsim.logic.ui.model.components.mi.nandbased.GUInand3;
+import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent;
+import net.mograsim.logic.ui.model.components.mi.nandbased.am2901.GUIAm2901DestDecode;
import net.mograsim.logic.ui.model.wires.GUIWire;
-import net.mograsim.logic.ui.modeladapter.LogicModelParameters;
public class SubmodelComponentTestbench
{
public static void main(String[] args)
{
- LogicModelParameters params = new LogicModelParameters();
- params.gateProcessTime = 1;
- params.wireTravelTime = 1;
- SimpleLogicUIStandalone.executeVisualisation(SubmodelComponentTestbench::createTestbench, params);
+ SimpleLogicUIStandalone.executeVisualisation(SubmodelComponentTestbench::createTestbench);
}
@SuppressWarnings("unused") // for GUIWires being created
public static void createTestbench(ViewModelModifiable model)
{
- SubmodelComponent comp = new GUInand3(model);
- int inputCount = 3;
+ SimpleRectangularSubmodelComponent comp = new GUIAm2901DestDecode(model);
comp.moveTo(100, 0);
- for (int i = 0; i < inputCount; i++)
+ for (int i = 0; i < comp.getInputPins().size(); i++)
{
GUIManualSwitch sw = new GUIManualSwitch(model);
sw.moveTo(0, 20 * i);
- new GUIWire(model, comp.getPins().get(i), sw.getOutputPin());
+ new GUIWire(model, comp.getInputPins().get(i), sw.getOutputPin());
}
- for (int i = inputCount; i < comp.getPins().size(); i++)
+ for (int i = 0; i < comp.getOutputPins().size(); i++)
{
GUIBitDisplay bd = new GUIBitDisplay(model);
- bd.moveTo(200, 20 * (i - inputCount));
- new GUIWire(model, comp.getPins().get(i), bd.getInputPin());
+ bd.moveTo(200, 20 * i);
+ new GUIWire(model, comp.getOutputPins().get(i), bd.getInputPin());
}
}
}
\ No newline at end of file