29 lines
631 B
Python
Raw Normal View History

2019-03-26 07:17:08 -06:00
from hashlib import sha256
2019-03-18 12:51:52 -06:00
ZERO_BYTES32 = b'\x00' * 32
2019-03-18 12:51:52 -06:00
def _hash(x):
return sha256(x).digest()
# Minimal collection of (key, value) pairs, for fast hash-retrieval, to save on repetitive computation cost.
# Key = the hash input
# Value = the hash output
hash_cache = []
def add_zero_hashes_to_cache():
zerohashes = [(None, ZERO_BYTES32)]
for layer in range(1, 32):
k = zerohashes[layer - 1][1] + zerohashes[layer - 1][1]
zerohashes.append((k, _hash(k)))
hash_cache.extend(zerohashes[1:])
def hash(x):
for (k, h) in hash_cache:
if x == k:
return h
return _hash(x)