#hashing #patricia #ethereum #evm #mpt #trie

cita_trie

修改后的Patricia树(即Trie)

25个版本 (10个稳定版)

5.0.1 2023年10月25日
4.2.0 2023年9月11日
4.1.0 2023年7月26日
4.0.0 2022年11月28日
0.2.1 2019年3月26日

#64数据结构

Download history 67/week @ 2024-04-08 1364/week @ 2024-04-15 944/week @ 2024-04-22 919/week @ 2024-04-29 2448/week @ 2024-05-06 1435/week @ 2024-05-13 569/week @ 2024-05-20 502/week @ 2024-05-27 566/week @ 2024-06-03 463/week @ 2024-06-10 467/week @ 2024-06-17 276/week @ 2024-06-24 204/week @ 2024-07-01 392/week @ 2024-07-08 160/week @ 2024-07-15 338/week @ 2024-07-22

1,137 每月下载量
13 个crate(7个直接) 中使用

Apache-2.0

89KB
2K SLoC

CITA-Trie

Latest Version

Rust语言实现的修改后的Patricia树(即Trie),

实现强烈受到go-ethereum trie的启发

特性

  • 修改后的Patricia树实现
  • 自定义哈希算法(默认提供Keccak)
  • 自定义存储接口

示例

use std::sync::Arc;

use hasher::{Hasher, HasherKeccak}; // https://crates.io/crates/hasher

use cita_trie::MemoryDB;
use cita_trie::{PatriciaTrie, Trie};

fn main() {
    let memdb = Arc::new(MemoryDB::new(true));
    let hasher = Arc::new(HasherKeccak::new());

    let key = "test-key".as_bytes();
    let value = "test-value".as_bytes();

    let root = {
        let mut trie = PatriciaTrie::new(Arc::clone(&memdb), Arc::clone(&hasher));
        trie.insert(key.to_vec(), value.to_vec()).unwrap();

        let v = trie.get(key).unwrap();
        assert_eq!(Some(value.to_vec()), v);
        trie.root().unwrap()
    };

    let mut trie = PatriciaTrie::from(Arc::clone(&memdb), Arc::clone(&hasher), &root).unwrap();

    let exists = trie.contains(key).unwrap();
    assert_eq!(exists, true);
    let removed = trie.remove(key).unwrap();
    assert_eq!(removed, true);
    let new_root = trie.root().unwrap();
    println!("new root = {:?}", new_root);

}

基准测试

cargo bench

Gnuplot not found, disabling plotting
insert one              time:   [1.6564 us 1.7287 us 1.7955 us]
                        change: [-2.2715% +1.5151% +5.1789%] (p = 0.42 > 0.05)
                        No change in performance detected.

insert 1k               time:   [1.1620 ms 1.1763 ms 1.1942 ms]
                        change: [-2.3339% +0.7190% +3.7809%] (p = 0.65 > 0.05)
                        No change in performance detected.
Found 16 outliers among 100 measurements (16.00%)
  9 (9.00%) high mild
  7 (7.00%) high severe

insert 10k              time:   [13.491 ms 13.677 ms 13.891 ms]
                        change: [-5.3670% -1.2847% +2.8328%] (p = 0.54 > 0.05)
                        No change in performance detected.
Found 10 outliers among 100 measurements (10.00%)
  9 (9.00%) high mild
  1 (1.00%) high severe

get based 10k           time:   [1.0707 us 1.0965 us 1.1270 us]
                        change: [-10.331% -6.5107% -2.6793%] (p = 0.00 < 0.05)
                        Performance has improved.
Found 11 outliers among 100 measurements (11.00%)
  11 (11.00%) high mild

remove 1k               time:   [538.54 us 545.18 us 553.96 us]
                        change: [-7.3508% -0.7110% +7.0860%] (p = 0.86 > 0.05)
                        No change in performance detected.
Found 12 outliers among 100 measurements (12.00%)
  5 (5.00%) high mild
  7 (7.00%) high severe

remove 10k              time:   [5.7277 ms 5.7780 ms 5.8367 ms]
                        change: [-18.778% -5.4831% +10.503%] (p = 0.51 > 0.05)
                        No change in performance detected.
Found 11 outliers among 100 measurements (11.00%)
  1 (1.00%) high mild
  10 (10.00%) high severe

自定义哈希算法

查看:https://crates.io/crates/hasher

自定义存储

参考

依赖项

~0.6–5.5MB
~16K SLoC