You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository was archived by the owner on Jun 8, 2025. It is now read-only.
See ethash.hpp for a list of exported functions and documentation.
Optimizations
This section describes the optimizations, modifications and tweaks applied
in this library in relation to Ethash reference implementation.
The library contains a set of micro-benchmarks. Build and run the ethash-bench
tool.
Seed hash is computed on the fly.
Seed hash is a sequence of keccak256 hashes applied the epoch number of times.
Time needed to compute seed hash is negligible compared to time needed to build
light cache. Computing seed hash for epoch 10000 takes ~ 5 ms, building light
cache for epoch 1 takes ~ 500 ms.
Dataset size is computed on the fly
Computing the size of the full dataset and light cache requires finding the largest
prime number given an upper bound. For similar reasons as with seed hash, this
is computed on the fly. The procedure used is quite naive and forks well only
up to 40-bit number, so some additional improvement can be done in the future.