Find constructor
Find 1
s or 0
s
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 n
th 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!;
}
}