mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-01-16 13:45:08 +00:00
Remove unused log2
This commit is contained in:
parent
8807781a8d
commit
449e8a44a4
@ -99,14 +99,7 @@ x x . . . . x *
|
|||||||
|
|
||||||
. are unused nodes, * are used nodes, x are the values we are trying to prove. Notice how despite being a multiproof for 3 values, it requires only 3 auxiliary nodes, only one node more than would be required to prove a single value. Normally the efficiency gains are not quite that extreme, but the savings relative to individual Merkle proofs are still significant. As a rule of thumb, a multiproof for k nodes at the same level of an n-node tree has size `k * (n/k + log(n/k))`.
|
. are unused nodes, * are used nodes, x are the values we are trying to prove. Notice how despite being a multiproof for 3 values, it requires only 3 auxiliary nodes, only one node more than would be required to prove a single value. Normally the efficiency gains are not quite that extreme, but the savings relative to individual Merkle proofs are still significant. As a rule of thumb, a multiproof for k nodes at the same level of an n-node tree has size `k * (n/k + log(n/k))`.
|
||||||
|
|
||||||
Here is code for creating and verifying a multiproof. First a helper:
|
Here is code for creating and verifying a multiproof. First, a method for computing the generalized indices of the auxiliary tree nodes that a proof of a given set of generalized indices will require:
|
||||||
|
|
||||||
```python
|
|
||||||
def log2(x: int) -> int:
|
|
||||||
return 0 if x == 1 else 1 + log2(x // 2)
|
|
||||||
```
|
|
||||||
|
|
||||||
First, a method for computing the generalized indices of the auxiliary tree nodes that a proof of a given set of generalized indices will require:
|
|
||||||
|
|
||||||
```python
|
```python
|
||||||
def get_proof_indices(tree_indices: List[int]) -> List[int]:
|
def get_proof_indices(tree_indices: List[int]) -> List[int]:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user