ethereumjs / node-ethash

Node bindings for the C++ Ethash implementation.
MIT License
7 stars 14 forks source link

node-ethash

js-standard-style

Native node bindings for Ethash cpp implementation. This library is experimental. Use at your own risk. Currently working on Linux only. Tested on node v5.10.1.

For details on this project, please see the Ethereum wiki (https://github.com/ethereum/wiki/wiki/Ethash) and ethereumjs/ethashjs (https://github.com/ethereumjs/ethashjs).

Installation

$ git clone https://github.com/ethereumjs/node-ethash.git
$ cd node-ethash/
$ git submodule init
$ git submodule update
$ npm install

API

new Ethash([cacheDB])

Creates a new instance of Ethash.

Parameters

ethash.verifyPOW(block, cb)

Verifies the POW on a block and its uncles.

Note: uses ethash.loadEpoc() to load cache.

Parameters

ethash.mkcache(cacheSize, seed)

Creates a cache.

NOTE: this is automatically done for in ethash.verifyPOW() so you do not need to use this function if you are just validating blocks.

Parameters

ethash.run(val, nonce, fullSize)

Runs ethash on a given val/nonce pair.

NOTE: you need to run ethash.mkcache() first before using this function.

Parameters

Return an Object containing

ethash.loadEpoc(number, cb)

Loads block number epoc's cache from DB.

Parameters

Test

$ npm test

Performance (node-ethash vs ethashjs):

$ node benchmark/benchmark.js
Create 1 fixtures
++++++++++++++++++++++++++++++++++++++++++++++++++
Benchmarking: mkcache
--------------------------------------------------
bindings x 1.47 ops/sec ±2.31% (8 runs sampled)
ethashjs x 0.17 ops/sec ±13.59% (5 runs sampled)
==================================================
Benchmarking: run
--------------------------------------------------
bindings x 571 ops/sec ±3.52% (79 runs sampled)
ethashjs x 17.82 ops/sec ±1.58% (48 runs sampled)
==================================================

TODO:

LICENSE

This library is free and open-source software released under the MIT license.