Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/l-tchen/findunion
An imperative implementation of disjoint-set data structure in Haskell
https://github.com/l-tchen/findunion
data-structures disjoint-sets haskell
Last synced: about 1 month ago
JSON representation
An imperative implementation of disjoint-set data structure in Haskell
- Host: GitHub
- URL: https://github.com/l-tchen/findunion
- Owner: L-TChen
- License: mit
- Created: 2019-01-25T21:24:26.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-01-27T20:53:28.000Z (almost 6 years ago)
- Last Synced: 2024-10-30T06:02:00.307Z (3 months ago)
- Topics: data-structures, disjoint-sets, haskell
- Language: Haskell
- Size: 7.81 KB
- Stars: 6
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Find-Union
## An imperative implementation of disjoint-set data structure in Haskell
This implementation is based on the original [Find-Union
algorithm](https://dl.acm.org/citation.cfm?id=321884) by Tarjan. It provides
the standard set of imperative operations in `Data.Union.ST`, i.e. `create`,
`union`, and `find` (also `connected`), and the type of elements can be any
instance of the type class
[`Ix`](https://www.haskell.org/onlinereport/haskell2010/haskellch19.html).
The worst-case time complexity of `union` and `find` in `Data.Union.ST` is
*O(α(n))* where *α(n)* is the inverse Ackermann function. See
[this](https://en.wikipedia.org/wiki/Disjoint-set_data_structure) Wikipedia
page for details.In addition, it provides a pure interface in `Data.Union` with a creation operation
```haskell
buildDS :: (Ix i) => Bound i -> [(i, i)] -> Union i [i]
```
which takes the range of elements and a list of pairs of the same set and
produces a table to check if any two elements are of the same set using
`connected`. This operation constructs the table within the ST monad and
*rebalance* every element so that its time complexity is *O(n * α(n))*,
practically linear, where *n* is the length of range and the time complexity of
`find` and `connected` is only *O(1)*. Unfortunately, I did not implement a
`union` operation for this pure interface, as any update to a persistent array
takes *O(n)* steps in Haskell.Alternatively, you can also use
```haskell
fromList :: (Ix i) => (i, i) -> [[i]] -> Union i [i]
```
to construct a table to look up which takes, again, the range of elements and a
list of lists (instead of pairs) of the same set. Any missing element is
regarded as a singleton set.To the best of my understanding, there is currently no
functional/persistent solution to this problem achieving the same time
complexity. If you happen to know how to do it, please let me know.This package is *not* going to Hackage for now.