X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2FSplitter.java;h=8c54d0f9f6e6475ae72aea6c7c8c8f48c22a4abb;hb=6c67a9ff8361cd9fc082f40e2676f2c8b5911fe4;hp=58d48e7c563861d3555d1d862dabd6dca3f68c2c;hpb=ebe86d1517aea138ffb6485b7bd2dff31fdb1253;p=Mograsim.git diff --git a/era.mi/src/era/mi/logic/components/Splitter.java b/era.mi/src/era/mi/logic/components/Splitter.java index 58d48e7c..8c54d0f9 100644 --- a/era.mi/src/era/mi/logic/components/Splitter.java +++ b/era.mi/src/era/mi/logic/components/Splitter.java @@ -1,53 +1,59 @@ package era.mi.logic.components; -import era.mi.logic.Bit; -import era.mi.logic.wires.WireArray; -import era.mi.logic.wires.WireArrayObserver; +import java.util.List; -public class Splitter implements WireArrayObserver +import era.mi.logic.timeline.Timeline; +import era.mi.logic.types.BitVector; +import era.mi.logic.wires.Wire.ReadEnd; +import era.mi.logic.wires.Wire.ReadWriteEnd; +import era.mi.logic.wires.WireObserver; + +public class Splitter extends Component implements WireObserver { - private WireArray input; - private WireArray[] outputs; - - public Splitter(WireArray input, WireArray... outputs) + private ReadEnd input; + private ReadWriteEnd[] outputs; + + public Splitter(Timeline timeline, ReadEnd input, ReadWriteEnd... outputs) { + super(timeline); this.input = input; this.outputs = outputs; input.addObserver(this); int length = 0; - for(WireArray out : outputs) - length += out.length; - - if(input.length != length) - throw new IllegalArgumentException("The input of splitting one into n WireArrays must have length = a1.length() + a2.length() + ... + an.length()."); + for (ReadEnd out : outputs) + length += out.length(); + + if (input.length() != length) + throw new IllegalArgumentException( + "The input of splitting one into n WireArrays must have length = a1.length() + a2.length() + ... + an.length()."); } protected void compute() { + BitVector inputBits = input.getValues(); int startIndex = 0; - Bit[] inputBits = input.getValues(); - for(int i = 0; i < outputs.length; i++) + for (int i = 0; i < outputs.length; i++) { - Bit[] outputBits = new Bit[outputs[i].length]; - System.arraycopy(inputBits, startIndex, outputBits, 0, outputs[i].length); - outputs[i].feedSignals(outputBits); - startIndex += outputs[i].length; + outputs[i].feedSignals(inputBits.subVector(startIndex, startIndex + outputs[i].length())); + startIndex += outputs[i].length(); } } - public WireArray getInput() + @Override + public void update(ReadEnd initiator, BitVector oldValues) { - return input; + compute(); } - - public WireArray[] getOutputs() + + @Override + public List getAllInputs() { - return outputs.clone(); + return List.of(input); } - + @Override - public void update(WireArray initiator) + public List getAllOutputs() { - compute(); + return List.of(outputs); } }