9 releases

0.6.1 Nov 22, 2022
0.5.4 Sep 27, 2022
0.5.3 Nov 15, 2021
0.5.2-rc1 Jul 25, 2021
0.1.0-alpha2 Sep 2, 2019

#843 in Data structures

Download history 163/week @ 2024-07-23 373/week @ 2024-07-30 229/week @ 2024-08-06 271/week @ 2024-08-13 245/week @ 2024-08-20 251/week @ 2024-08-27 173/week @ 2024-09-03 151/week @ 2024-09-10 483/week @ 2024-09-17 209/week @ 2024-09-24 224/week @ 2024-10-01 274/week @ 2024-10-08 717/week @ 2024-10-15 1059/week @ 2024-10-22 484/week @ 2024-10-29 161/week @ 2024-11-05

2,493 downloads per month
Used in 14 crates (via ckb-sdk)

MIT license

270KB
7K SLoC

C 4K SLoC // 0.1% comments Rust 3K SLoC // 0.0% comments

Sparse merkle tree

Crates.io Docs

An optimized sparse merkle tree.

size proof size update get merkle proof verify proof
2n + log(n) log(n) log(n) log(n) log(n) log(n)

Features:

  • Multi-leaves existence / non-existence merkle proof
  • Customizable hash function
  • Storage backend agnostic
  • Rust no_std support

This article describes algorithm of this data structure An optimized compacted sparse merkle tree

Construction

A sparse merkle tree is a perfectly balanced tree contains 2 ^ N leaves:

# N = 256 sparse merkle tree
height:
                   0
                /     \
255            0        1

.............................

           /   \          /  \
1         0     1        0    1
         / \   / \      / \   / \
0       0   1 0  1 ... 0   1 0   1
       0x00..00 0x00..01   ...   0x11..11

The above graph demonstrates a sparse merkle tree with 2 ^ 256 leaves, which can mapping every possible H256 value into leaves. The height of the tree is 256, from top to bottom, we denote 0 for each left branch and denote 1 for each right branch, so we can get a 256 bits path, which also can represent in H256, we use the path as the key of leaves, the most left leaf's key is 0x00..00, and the next key is 0x00..01, the most right key is 0x11..11.

License

MIT

Dependencies

~63–345KB