2021-09-15 09:32:09 -07:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import sys; assert sys.version_info[0] >= 3, "Python 3 required."
|
|
|
|
|
2021-05-06 21:33:09 -07:00
|
|
|
from orchard_pallas import Fp
|
|
|
|
from orchard_poseidon import perm
|
2021-05-06 07:53:12 -07:00
|
|
|
from utils import leos2ip
|
2021-05-06 21:33:09 -07:00
|
|
|
from tv_output import render_args, render_tv
|
|
|
|
from tv_rand import Rand
|
|
|
|
|
|
|
|
# Initial capacity element
|
|
|
|
CAPACITY_ELEMENT = Fp(1 << 65)
|
|
|
|
|
|
|
|
def poseidon_hash(x, y):
|
|
|
|
assert isinstance(x, Fp)
|
|
|
|
assert isinstance(y, Fp)
|
2021-05-06 21:51:40 -07:00
|
|
|
return perm([x, y, CAPACITY_ELEMENT])[0]
|
2021-05-06 21:33:09 -07:00
|
|
|
|
|
|
|
def main():
|
|
|
|
test_vectors = [[Fp.ZERO, Fp(1)]]
|
|
|
|
|
|
|
|
from random import Random
|
|
|
|
rng = Random(0xabad533d)
|
|
|
|
def randbytes(l):
|
|
|
|
ret = []
|
|
|
|
while len(ret) < l:
|
|
|
|
ret.append(rng.randrange(0, 256))
|
|
|
|
return bytes(ret)
|
|
|
|
rand = Rand(randbytes)
|
|
|
|
|
|
|
|
# Generate random test vectors
|
|
|
|
for _ in range(10):
|
|
|
|
test_vectors.append([
|
|
|
|
Fp(leos2ip(rand.b(32))),
|
|
|
|
Fp(leos2ip(rand.b(32))),
|
|
|
|
])
|
|
|
|
|
|
|
|
render_tv(
|
|
|
|
render_args(),
|
2021-05-06 21:51:40 -07:00
|
|
|
'orchard_poseidon_hash',
|
2021-05-06 21:33:09 -07:00
|
|
|
(
|
|
|
|
('input', '[[u8; 32]; 2]'),
|
2021-05-06 21:51:40 -07:00
|
|
|
('output', '[u8; 32]'),
|
2021-05-06 21:33:09 -07:00
|
|
|
),
|
|
|
|
[{
|
|
|
|
'input': list(map(bytes, input)),
|
2021-05-06 21:51:40 -07:00
|
|
|
'output': bytes(poseidon_hash(input[0], input[1])),
|
2021-05-06 21:33:09 -07:00
|
|
|
} for input in test_vectors],
|
|
|
|
)
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|