mirror of
https://github.com/vacp2p/research.git
synced 2025-02-23 03:38:18 +00:00
adds some revisions
This commit is contained in:
parent
2a5cb55e39
commit
cbb1059ce9
@ -1,20 +1,19 @@
|
||||
# Solution Overview
|
||||
In a Merkle Tree with the capacity of `n` leaves , one can compute the root of the tree by maintaining the root nodes of log(n) number of complete Merkle trees.
|
||||
> In a Merkle Tree with the capacity of `n` leaves , one can compute the root of the tree by maintaining the root nodes of log(n) number of complete Merkle trees.
|
||||
|
||||
We use this fact and define `F` to be an array of size log(n) holding the root of complete Merkle trees (all positioned on the left side of the tree) for levels `[0, d=log(n)+1]`. Each entry of `F` at position `i` holds a pair `(index, H)` where H is the root of the complete subtree at level `i`, and `index` indicates the index of the leaf node whose insertion resulted in `H`.
|
||||
We use the preciding observation and define `F = [(L0,H0,index0), ..., (Ld,Hd,indexd)]` to be an array of size log(n)+1 holding the root of the complete Merkle trees (all positioned on the left side of the tree) for levels `[0, d=log(n)+1]`. Each entry of `F` holds a tuple `(L,index, H)` `H`is the root of the complete subtree at level `L`, and `index` indicates the index of the leaf node whose insertion resulted in `H`.
|
||||
|
||||
`F = [(L0,H0,index0), ..., (Ld,Hd,indexd)]`
|
||||
For the Merkle Tree shown in Figure below, `F = [(L0, N12, leaf5), (L1, N6, leaf6), (L2, N2, leaf4), (L3, N1, leaf6)]` is highlighted in green. Note that none of the gray nodes are stored as part of `F`.
|
||||
|
||||
data:image/s3,"s3://crabby-images/9b5f1/9b5f1a2831eedb9f1026b045d4a447cfa1ba299a" alt="Tree"
|
||||
data:image/s3,"s3://crabby-images/45674/45674b962794bfc3ce6e62009c6a2bba9c05db19" alt="Tree"
|
||||
|
||||
|
||||
|
||||
|
||||
## Deletion
|
||||
## Computing the root after deletion
|
||||
|
||||
Consider the deletion of the `leafi` with the authentication path / (membership proof) of the follwoing form `authpath = [(L0,H0), ..., (Ld,Hd)]`.
|
||||
The authentication path of `leaf2` is illustrated in the following figure. `authpath2 = [(L0, N8), (L1,N5), (L2,N3), (L3,N1)]`.
|
||||
Consider the deletion of the `leafi` with the authentication path / (membership proof) of the follwoing form `authpath = [(L0,H0), ..., (Ld,Hd)]` where `H` values represent the value of the merkle tree nodes at the indicated level `L`.
|
||||
The authentication path of `leaf2` is illustrated in the following figure and consists of `authpath2 = [(L0, N8), (L1,N5), (L2,N3), (L3,N1)]`.
|
||||
|
||||
data:image/s3,"s3://crabby-images/38202/382028d2ec49f2b4eefbcaf4d56bef0e20294832" alt="authPath"
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user