Find constructor

Find(
  1. Logic bus, {
  2. bool countOne = true,
  3. Logic? n,
  4. bool generateError = false,
})

Find 1s or 0s

Takes in filter search parameter countOne, default Find 1. If countOne is true Find 1 else Find 0.

By default Find will look for first search parameter 1 or 0. If n is given, Find an nth search from first occurance. n starts from 0 as first find.

Outputs pin index contains position. position starts from 1 based.

Implementation

Find(Logic bus,
    {bool countOne = true, Logic? n, this.generateError = false}) {
  bus = addInput('bus', bus, width: bus.width);
  final oneHotList = <Logic>[];

  if (n != null) {
    n = addInput('n', n, width: n.width);
  }

  for (var i = 0; i < bus.width; i++) {
    // determines if it is what we are looking for?
    final valCheck = countOne ? bus[i] : ~bus[i];

    final count = Count(bus.getRange(0, i + 1), countOne: countOne);

    // Below code will make `n` comparable to `count`
    var paddedCountValue = count.count;
    var paddedNValue = (n ?? Const(0)) + 1;

    if (paddedNValue.width < paddedCountValue.width) {
      paddedNValue = paddedNValue.zeroExtend(paddedCountValue.width);
    } else {
      paddedCountValue = paddedCountValue.zeroExtend(paddedNValue.width);
    }

    // If bus[i] contains search value (0/1) and it is nth position
    // then append Logic `1` else append Logic `0`
    oneHotList.add(valCheck & paddedNValue.eq(paddedCountValue));
  }

  final oneHotBinary =
      OneHotToBinary(oneHotList.rswizzle(), generateError: generateError);
  // Upon search complete, we get the position value in binary `bin` form
  final bin = oneHotBinary.binary;
  addOutput('index', width: bin.width);
  index <= bin;

  if (generateError) {
    addOutput('error');
    error! <= oneHotBinary.error!;
  }
}