data-structures-crystal

📚 Trying some basic data structures in Crystal

Simple data structures implemented in Crystal as a learning experience.

Build Status

  • LinkedList
  • HashTable
  • DynamicArray
  • Build-up to a hash array mapped trie:
    • String Trie (stores a set of strings)
    • String => Value Trie (stores string => whatever pairs)
    • String Array Mapped Trie (stores a set of strings by hash & a bitmap + array for storage)
  • Hash Array Mapped Trie
  • Handle fancy-shmancy negative indexes
  • Implement real nice APIs like Crystal stdlib

HAMT performance

# [master 74f4a42] implement HAMT
~/projects/crystal-data $ crystal run --release benchmark/hash_array_mapped_trie_benchmark.cr
 Data::HAMT x100        11.22k (±10.35%) 13.49× slower
Stdlib Hash x100       151.37k (± 9.17%)       fastest
 Data::HAMT x10000     145.13  (± 1.22%) 17.62× slower
Stdlib Hash x10000       2.56k (± 1.60%)       fastest
 Data::HAMT x1000000     0.97  (± 7.26%) 15.68× slower
Stdlib Hash x1000000    15.27  (±17.74%)       fastest
Repository

data-structures-crystal

Owner
Statistic
  • 1
  • 0
  • 0
  • 0
  • 0
  • about 9 years ago
  • November 28, 2015
License

Links
Synced at

Tue, 21 Jan 2025 10:37:43 GMT

Languages