Unique

Usage

use Unique;

or

import Unique;

unique finding and counting algorithms these are all based on dense histograms and sparse histograms(assoc domains/arrays)

you could also use a sort if you got into a real bind with really large dense ranges of values and large arrays…

* need to factor in sparsity estimation somehow * for example if (a.max-a.min > a.size) means that a’s are sparse

const uLogger = new Logger(logLevel, logChannel)
proc uniqueSort(a: [?aD] ?eltType, param needCounts = true) throws

sorting based unique finding procedure

Returns a tuple: (UniqueValArray,UniqueValCountsArray) which contains the unique values of a, along with the number of times each unique value appears in a

Arguments:

a : [] int – Array of data to be processed

Returns:

([] int, [] int)

proc uniqueSortWithInverse(a: [?aD] ?eltType, param needIndices = false) throws
proc uniqueFromSorted(sorted: [?aD] ?eltType, param needCounts = true) throws
proc uniqueGroup(str: SegString, returnInverse = false) throws
proc uniqueFromTruth(str: SegString, perm: [?aD] int, truth: [aD] bool) throws