nim-ethash/README.md

22 lines
1.3 KiB
Markdown
Raw Normal View History

2018-05-28 05:26:38 +00:00
**Nim Ethash**
2018-02-15 10:23:42 +00:00
[![Build Status (Travis)](https://img.shields.io/travis/status-im/nim-ethash/master.svg?label=Linux%20/%20macOS "Linux/macOS build status (Travis)")](https://travis-ci.org/status-im/nim-ethash)[![License: Apache](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0) ![Stability: experimental](https://img.shields.io/badge/stability-experimental-orange.svg)
2018-02-15 10:23:42 +00:00
2018-05-28 05:26:38 +00:00
# Introduction
A pure-Nim implementation of Ethash, the Ethereum proof of work
2018-02-15 10:23:42 +00:00
2018-05-28 05:26:38 +00:00
Implementation is based on the [spec revision 23 (2017-08-03)](https://github.com/ethereum/wiki/wiki/Ethash) and is under the Apache License v2.
2018-02-15 10:23:42 +00:00
2018-05-28 05:26:38 +00:00
# Mining
2018-02-27 10:29:46 +00:00
An unoptimized mining CPU backend is available through the compile-time flag ``-d:ethash_mining``.
It requires compilation through the C++ backend.
2018-05-28 05:26:38 +00:00
# Optimizations
For maximum speed, compile Ethash with `-d:release -d:march_native -d:openmp`.
2018-05-28 05:26:38 +00:00
This will compile Ethash in Nim release mode, with all supported CPU extensions (especially AVX2) and with OpenMP multiprocessing. On MacOS, OpenMP requires installing GCC-7 and can be done through Homebrew.
2018-05-28 05:26:38 +00:00
# Original implementation
2018-02-15 10:23:42 +00:00
Original Ethereum implementation is available [here](https://github.com/ethereum/ethash).
**Warning ⚠ - License notice**: the original implementation is under GPLv3 or LGPLv3 and must not be used in this project.