Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/antouhou/bitcoin-fee-estimator
bitcoin-core 0.15.x fee estimation algorithm written in js
https://github.com/antouhou/bitcoin-fee-estimator
Last synced: about 1 month ago
JSON representation
bitcoin-core 0.15.x fee estimation algorithm written in js
- Host: GitHub
- URL: https://github.com/antouhou/bitcoin-fee-estimator
- Owner: antouhou
- Created: 2017-11-07T20:11:51.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2017-11-22T09:53:00.000Z (about 7 years ago)
- Last Synced: 2024-12-05T00:09:25.866Z (about 1 month ago)
- Language: JavaScript
- Size: 151 KB
- Stars: 8
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# bitcoin-fee-estimator
Implementation of fee estimation algorithm of bitcoin-core > 0.15.x in javascript## Motivation
bitcoin-core 0.15.x fee estimation algorithm is a big improvement over older versions.
It can estimate fee up to 1000 blocks instead of only 25 blocks
on pre 0.15.x versions. But there are many bitcoin forks that still using older code.
With this library, it is now possible to estimate fees in a new way for every pre-0.15.x fork.## Installation
`npm i bitcoin-fee-estimator --save`## Usage
### Initialization
```javascript
const Estimator = require('bitcoin-fee-estimator');
const estimator = new Estimator();
```### Getting some fee stats
Since estimator uses moving averages of fees, we need to feed to an estimator
a mempool and then submit some blocks with confirmed transactions from mempool:
```javascript
// rawMempool is raw mempool that can be obtained through getrawmempool RPC call to bitcoin node
estimator.processNewMempoolTransactions(rawMempool);
// newBlock is a new incoming block that has some confirmed transactions from mempool.
// can be obtained through getblock RPC call
estimator.processBlock(newBlock.height, newBlock.tx);
// after processing block, new incoming transactions need to be processed:
estimator.processNewMempoolTransactions(newRawMempool);
// This algorithm needs to be run for each new block in order to maintain up to date bitcoin fee statistics.
// After repeating this several times, you can do estimations:
estimator.estimateSmartFee(1).getFeePerK();
// 1 is desired number of blocks before the transaction will be included in the block.
```
**If you collected not enough data, estimator will always return zero.**
**If you collected information only for 25 blocks, estimator will return zero if you will pass target above 25.**## Contributing
To build the library you need to run `npm run build`. This will run eslint, transpile code for older versions of node, run tests.
As this library designed to works on node versions 0.12 and above, in order to make sure everything is fine you need installed 0.12 version of node and run `tools/testOldNode.js` with it.