IndexedMerkleMap
function IndexedMerkleMap(height: number): typeof IndexedMerkleMapBase
Class factory for an Indexed Merkle Map with a given height.
class MerkleMap extends IndexedMerkleMap(33) {}
let map = new MerkleMap();
map.insert(2n, 14n);
map.insert(1n, 13n);
let x = map.get(2n); // 14
Indexed Merkle maps can be used directly in provable code:
ZkProgram({
methods: {
test: {
privateInputs: [MerkleMap, Field],
method(map: MerkleMap, key: Field) {
// get the value associated with `key`
let value = map.getOption(key).orElse(0n);
// increment the value by 1
map.set(key, value.add(1));
}
}
}
})
Initially, every IndexedMerkleMap
is populated by a single key-value pair: (0, 0)
. The value for key 0
can be updated like any other.
When keys and values are hash outputs, (0, 0)
can serve as a convenient way to represent a dummy update to the tree, since 0 is not
efficiently computable as a hash image, and this update doesn't affect the Merkle root.
Parameters
• height: number
Returns
typeof IndexedMerkleMapBase