Merge pull request #37 from zcash-hackworks/orchard-empty-roots

Add Orchard empty root test vectors
This commit is contained in:
str4d 2021-06-29 13:24:22 +01:00 committed by GitHub
commit de3e09de1a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 0 deletions

23
orchard_empty_roots.py Normal file
View File

@ -0,0 +1,23 @@
from orchard_merkle_tree import empty_roots
from orchard_pallas import Fp
from tv_output import render_args, render_tv
from utils import i2lebsp
def main():
args = render_args()
render_tv(
args,
'orchard_empty_roots',
(
('empty_roots', '[[u8; 32]; 33]'),
),
{
'empty_roots': list(map(bytes, empty_roots())),
},
)
if __name__ == '__main__':
main()

View File

@ -11,6 +11,7 @@ from utils import i2lebsp, leos2bsp
# https://zips.z.cash/protocol/nu5.pdf#constants
MERKLE_DEPTH = 32
L_MERKLE = 255
UNCOMMITTED_ORCHARD = Fp(2)
# https://zips.z.cash/protocol/nu5.pdf#orchardmerklecrh
def merkle_crh(layer, left, right):
@ -30,3 +31,10 @@ right = leos2bsp(right)[:L_MERKLE]
parent = Fp(626278560043615083774572461435172561667439770708282630516615972307985967801)
assert merkle_crh(MERKLE_DEPTH - 1 - 25, left, right) == parent
assert merkle_crh(MERKLE_DEPTH - 1 - 26, left, right) != parent
def empty_roots():
empty_roots = [UNCOMMITTED_ORCHARD]
for layer in range(0, MERKLE_DEPTH)[::-1]:
bits = i2lebsp(L_MERKLE, empty_roots[-1].s)
empty_roots.append(merkle_crh(layer, bits, bits))
return empty_roots