Golang set operations using maps and iterators.
There are many mapset
implementations available, but they restrict the values to struct{}
or bool
. In practice this has downsides.
- Maps must be copied even though they already support iteration and O(1) lookup.
- Map values are lost.
- Slices must be copied even if they would have only been iterated.
- Slice ordering is lost.
- Copying effectively means no early exits, e.g., in a subset check.
Since sets are not built-in, they realistically will always be a secondary type. Even in languages with built-in sets, it is common to call set operations on keys while still keeping data in a map, and common to want to retain ordering.
So iterset
is built around generic maps with any
value type. Inspired by Python sets, its methods also support iterators. This integrates well with functions in maps and slices, and addresses the typical mapset
issues.
- Maps can be casted instead of copied.
- Map values are kept without affecting set operations.
- Slices can be iterated using
slices.Values
without copying. - Slice iterators retain ordering.
- Iterators are lazily evaluated, inherently supporting early exits.
There are constructors for all common use cases.
Cast
a mapUnique{By}
iterates keys in orderCompact{By}
iterates consecutive grouped keysCollect
with default valueSet
from variadic argsIndex
retains original positionCount
stores key countsIndexBy
stores values by key functionGroupBy
stores slices grouped by key functionMemoize
caches function call
Methods support iterators, compatible with slices.Values
and maps.Keys
. Implementations are asymptotically optimal, and exit early where relevant.
Equal
IsSubset
IsSuperset
IsDisjoint
Union
Intersect
Difference
ReverseDifference
SymmetricDifference
Scalar operations can be passed as bound methods for functional programming.
Get
Contains
Missing
Add
Delete
Some operations are better expressed as functions, to avoid making unnecessary maps.
Sorted
IsSubset
Intersect
Difference
No dependencies. Go 1.23 required.
go get github.com/coady/iterset
100% code coverage.
go test -cover