Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/raviqqe/hamt

Immutable and Memory-Efficient Maps and Sets in Go
https://github.com/raviqqe/hamt

functional-programming go hamt immutable map set

Last synced: about 4 hours ago
JSON representation

Immutable and Memory-Efficient Maps and Sets in Go

Awesome Lists containing this project

README

        

# hamt

[![GitHub Action](https://img.shields.io/github/actions/workflow/status/raviqqe/hamt/test.yaml?branch=main&style=flat-square)](https://github.com/raviqqe/hamt/actions)
[![Codecov](https://img.shields.io/codecov/c/github/raviqqe/hamt.svg?style=flat-square)](https://codecov.io/gh/raviqqe/hamt)
[![Go Report Card](https://goreportcard.com/badge/github.com/raviqqe/hamt?style=flat-square)](https://goreportcard.com/report/github.com/raviqqe/hamt)
[![License](https://img.shields.io/github/license/raviqqe/hamt.svg?style=flat-square)][unlicense]

> For the old `any`-based API, refer to [the `main` branch](https://github.com/raviqqe/hamt/tree/main).

Immutable and Memory Efficient Maps and Sets in Go.

This package `hamt` provides immutable collection types of maps (associative arrays)
and sets implemented as Hash-Array Mapped Tries (HAMTs).
All operations of the collections, such as insert and delete, are immutable and
create new ones keeping original ones unmodified.

[Hash-Array Mapped Trie (HAMT)](https://en.wikipedia.org/wiki/Hash_array_mapped_trie)
is a data structure popular as a map (a.k.a. associative array or dictionary)
or set.
Its immutable variant is adopted widely by functional programming languages
like Scala and Clojure to implement immutable and memory-efficient associative
arrays and sets.

## Installation

```
go get github.com/raviqqe/hamt/v2
```

## Documentation

[GoDoc](https://godoc.org/github.com/raviqqe/hamt/v2)

## Technical notes

The implementation canonicalizes tree structures of HAMTs by eliminating
intermediate nodes during delete operations as described
in [the CHAMP paper][champ].

## References

- [Ideal Hash Trees](https://infoscience.epfl.ch/record/64398/files/idealhashtrees.pdf)
- [Optimizing Hash-Array Mapped Tries for Fast and Lean Immutable JVM Collections][champ]

## License

[The Unlicense][unlicense]

[champ]: https://michael.steindorfer.name/publications/oopsla15.pdf
[unlicense]: https://unlicense.org/