1 package era.mi.logic.components;
\r
3 import era.mi.logic.types.BitVector;
\r
4 import era.mi.logic.wires.Wire;
\r
5 import era.mi.logic.wires.Wire.WireEnd;
\r
6 import era.mi.logic.wires.WireObserver;
\r
8 public class Splitter implements WireObserver
\r
10 private WireEnd input;
\r
11 private WireEnd[] outputs;
\r
13 public Splitter(WireEnd input, WireEnd... outputs)
\r
16 this.outputs = outputs;
\r
17 input.addObserver(this);
\r
19 for (WireEnd out : outputs)
\r
20 length += out.length();
\r
22 if (input.length() != length)
\r
23 throw new IllegalArgumentException(
\r
24 "The input of splitting one into n WireArrays must have length = a1.length() + a2.length() + ... + an.length().");
\r
27 protected void compute()
\r
29 BitVector inputBits = input.getValues();
\r
31 for (int i = 0; i < outputs.length; i++)
\r
33 outputs[i].feedSignals(inputBits.subVector(startIndex, startIndex + outputs[i].length()));
\r
34 startIndex += outputs[i].length();
\r
39 public void update(Wire initiator, BitVector oldValues)
\r