To fill the historical data run the command:
./zenbot launch map --backfill reduce server run --config 'path to config'
To see live data on the screen change the config_defaults.js and set to true c.trade_log = true c.trade_reducer_log = true
“To follow the path, look to the master, follow the master, walk with the master, see through the master, become the master.” – Zen Proverb
Notice: See the new sticky post: Poll: What do you want to see in Zenbot 3.6?
- New to Zenbot? Watch the slideshow: Introducing Zenbot 3
- Join Zenbot Discord Channel
- Follow Zenbot on Twitter!
- Check out Zenbot's live feed!
- Join the discussion on Reddit!!
- Want to contribute to Zenbot? Read the contributions guide
Description
Zenbot is a lightweight, extendable, artificially intelligent trading bot. Currently Zenbot is capable of:
- High-frequency trading, day trading, week trading
- Multiple asset support for Bitcoin, Ether, Litecoin (and more)
- Multiple currency support for US Dollars, Euros, Chinese Yuan (and more)
- Multiple exchange support for Bitfinex, GDAX, Kraken, Poloniex (and more)
- Realtime consuming and analysis of trade data
- Backtesting your trade strategy
- Outputting data as CSV, JSON, or candlestick graph
Performance
Current simulations on historical data from May - August 2016 show Zenbot 3.5.15 making a 1.531 ROI in only 3 months, using default parameters!
Zenbot is a genius!
HOWEVER. BE AWARE that once you hook up Zenbot to a live exchange, the damage done is your fault, not mine! As with buying crypto currency in general, risk is involved and caution is essential. Crypto currency is an experiment, and so is Zenbot.
Features
- A powerful map/reduce system to live-process data at scale.
- A plugin system to facilitate incremental support for any exchange, currency pair, trade strategy, or reporting medium.
- Out of the box, Zenbot is an AI-powered trade advisor (gives you buy or sell signals while watching live data).
- Default support for GDAX is included, so if you have a GDAX account, enable bot trades by simply putting your GDAX API key in
config.js
and setting what currency pair to trade. - Default support for other exchanges is ongoing.
- Trade strategy is fully exposed in the config file. This allows you to have full control over the bot's actions and logic. For example, instead of trading on GDAX, you could trade on a different exchange or currency pair by implementing a few lines of JavaScript.
- A live candlestick graph is provided via a built-in HTTP server.
Screenshot
In the screenshot below, the pink arrows represent the bot buying (up arrow) and selling (down arrow) as it iterated the historical data of GDAX exchange's BTC/USD product.
RAW data from simulation: https://gist.github.com/carlos8f/afcc18ba0e1f422b1f3b1f67a3b05c8e
Quick-start
Node.js and MongoDB
1. Requirements:Windows - I don't support it.
If you're having an error on Windows and you're about to give up, it's probably because Node.js is generally broken on Windows and you should try running on a Linux docker container (look at step 7 and follow instructions for Windows) or a Mac instead.
If you're still insistent on using Windows, you'll have to fork zenbot, fix it yourself, and I'll accept a Pull Request.
2. Install zenbot 3:
git clone https://github.com/carlos8f/zenbot.git
cd zenbot
npm install
# optional, installs the `zenbot` binary in /usr/local/bin:
npm link
config_sample.js
to config.js
and edit with API keys, database credentials, trade logic, etc.
3. Copy Note: add your GDAX key to config.js
to enable real trading.
4. Run zenbot (single-pair mode)
The following command will run all Zenbot functionality, using the default BTC/USD pair.
./run.sh
Here's how to run a different pair (example: ETH-BTC):
./zenbot launch map --backfill reduce run server --config config_eth_btc.js
4. Run zenbot (multi-pair mode)
The following will run multiple currency pairs along with the reducer and server in separate processes.
Required: reducer (for processing trade data):
./reducer.sh
Optional: server (for candlestick graphs and aggregated log):
./server.sh
Required: one or more run scripts (watches trades of a given pair and performs trade actions on the exchange or simulation)
./run-btc-usd.sh
And/or to trade ETH,
./run-eth-usd.sh
And/or to trade ETH/BTC,
./run-eth-btc.sh
5. If running server, open the live graph URL provided in the console.
To access the CLI,
./zenbot
Usage: ./zenbot [options] [command]
Commands:
server [options] launch the server
launch [options] [cmds...] launch multiple commands
map [options] map
reduce [options] reduce
run run
sim [options] sim
Options:
-h, --help output usage information
-V, --version output the version number
--config <path> specify a path for config.js overrides
The ./run.sh
script combines launch map --backfill reduce run server
, so use the CLI to access the other commands.
6. Simulation
Once backfill has finished (should collect about 84 days of data), run a simulation:
./zenbot sim [--verbose]
Zenbot will return you a list of virtual trades, and an ROI figure. Open the URL provided in the console (while running the server) to see the virtual trades plotted on a candlestick graph. Tweak default_logic.js
for new trade strategies and check your results this way.
Example simulation result: https://gist.github.com/carlos8f/afcc18ba0e1f422b1f3b1f67a3b05c8e
default_logic.js
About the default trade logic in - uses GDAX API
- acts at 5 minute increments (ticks), but you can configure to act quicker or slower.
- computes the latest 14-hour RSI at each 5m tick
- considers
RSI >= 70
an upwards trend andRSI <= 30
a downwards trend - Buys at the beginning of upwards trend, sells at the beginning of downwards trend
- trades 98% of current balance, market price
- Holds for min. 24 hours after a trade
You can tweak the JS from there to trade on Bitfinex, or whatever. After tweaking default_logic.js
, Use ./zenbot sim [--verbose]
to check your strategy against historical trades.
Note that simulations always end on Wednesday 5pm PST, and run for a max 84 days (12 weeks), to ensure input consistency.
Auto-learn support and more exchange support will come soon. Will accept PR's :) With the 3.x plugin architecture, external plugins are possible too (published as their own repo/module).
7. Docker
Install Docker, Docker Compose, Docker Machine (if necessary) You can follow instructions at https://docs.docker.com/compose/install/
After installation
git clone https://github.com/carlos8f/zenbot.git
cd zenbot
docker-compose build
docker-compose up (-d if you don't want to see the log)
8. Web console
When the server is running, and you have visited the ?secret
URL provided in the console, you can access an aggregated, live feed of log messages at http://localhost:3013/logs
. Example:
Update Log
- 3.5.16 (Latest)
- Added Docker support, thanks to @egorbenko, @grigio, and @BarnumD !
- 3.5.15
- Fixed RSI smoothing issue, now RSI is calculated on the run_state instead of the tick. Switched to using heavily smoothed 5m RSI in
default_logic.js
. RSI no longer needs to be backfilled, and is dynamically calculated after applying this update. Raised ROI 1.460 -> 1.531 from last update.
- Fixed RSI smoothing issue, now RSI is calculated on the run_state instead of the tick. Switched to using heavily smoothed 5m RSI in
- 3.5.14
- Fixed #39 404 for trades.csv
- 3.5.13
- Change
check_period
to 5m in trading engine - ROI 1.477 -> 1.720
- Speed up sim by only processing 5m ticks
- Change
- 3.5.12
- Tweaks to default trade params, ROI = 1.364 -> 1.477
- Misc warning text changes
- 3.5.11
- Fix 1m reporter not working in advisor mode.
- 3.5.10
- Fix
run.sh
not starting server. - Remove --verbose from new run script.
- Fix
- 3.5.9
- Add --backfill and --verbose to new run script.
- 3.5.8
- Fix "skipping historical tick" (prevented bot from acting on trends) issue with Zenbrain update.
- Fix ANSI graph range again.
- Added
run.sh
back to run the default pair BTC/USD and reducer/server.
- 3.5.7
- make use of rs.rsi for indicators (instead of querying for rsi tick), spacing for ETA.
- 3.5.6
- Fix ANSI graph range.
- 3.5.5
- ANSI graph now follows RSI instead of SMA.
- 3.5.4
- ETA indicator replaces progress, and removal of
hold_ticks
mechanism in favor of wait params in ms. More warnings in default_logic to show what's going on with the trader.
- ETA indicator replaces progress, and removal of
- 3.5.3
- Fixed
--config
usage with absolute path.
- Fixed
- 3.5.2
- Re-organized some config vars, GDAX key now in
config.js
instead ofconfig_eth_btc.js
etc.
- Re-organized some config vars, GDAX key now in
- 3.5.1
- Bugfixes
- 3.5.0
run.sh
split into 3 scripts. Now you'll need to run./reducer.sh
,./server.sh
, and./run-{asset}-{currency}.sh
in separate windows. Multiple currency pairs can be run in parallel as of Zenbot 3.5.0!
- 3.4.3
- Fix sim URL not having selector in it
min_trade
now controlled byproduct.min_size
- 3.4.2
- Exit default logic if run command and historical tick
- Add balance stats to trade actions
- Add
--config
arg doc. You can switch to using a different config with--config <path>
- Update gist links for newest simulation results.
- Added
config_eth.js
example config for ETH trading.
- 3.4.1
- Slight re-code of
default_logic.js
to fix slipped ROI (1.1 -> 1.8) - Added All Poloniex USDT pairs by @JFD3D, Thanks!
- Slight re-code of
- 3.4.0
- Re-organized the config so
config.js
is git-ignored, so you should copyconfig_sample.js
toconfig.js
.config_defaults.js
provides all options that you can override inconfig.js
. - Many config variable changes, such as
c.watch_exchanges
instead ofc.enabled_plugins
, seeconfig_sample.js
for details. - Zenbrain updated.
- Development now happening in
develop
branch, master will be pushed to only on stable releases going forward.
- Re-organized the config so
- 3.3.1
- Moved ANSI graph column to line up tick_id and num_trades with log_trades columns.
- 3.3.0
- Fees now calculated, default
price * size * 0.0025
. rs.roi
now updated every tick.- ANSI graph, balance, ROI, and SMA indicators added.
- Fix kraken naming by @grigio, Thanks!
- Added contributions guide.
- Updated slideshow: Introducing Zenbot 3
- Fees now calculated, default
- 3.2.4
- Minor reporting cleanup, added some docs. Minor update to Zenbrain.
- 3.2.3
- Fixed some performance issues with RSI backfiller. Updated
update.sh
to rungit stash
before andgit stash pop
after update, to avoid merge conflict when pulling. However you may have to resolve a conflict with yourconfig.js
afterupdate.sh
completes, this is normal when config defaults have been updated.
- Fixed some performance issues with RSI backfiller. Updated
- 3.2.2
- Fixed a non-indexed query in Zenbrain.
- 3.2.1
- Bugfix for techan.js performance patch
- 3.2.0
- Major logic update again.
- Now using 1h RSI by default. Reporter chimes in every 5m. Trade signals should trigger roughly 2-3 times over a few days.
- Way better trend detection in
default_logic.js
, 83-day simulated ROI went from ~10% to 89%! - Poloniex product update by @RDash21, Kraken product update by @grigio. Thanks!
- Logic update by @xangma. Thanks!
- Graph performance patch, submitted to techan.js project at andredumas/techan.js#138
- 3.1.2 - Relaxed backfill timeout. Backfill is slower to let reducer catch up. Reducer report interval -> 30s, Trade report interval -> 30s
- 3.1.1 - Updated zenbrain version.
- 3.1.0
- Major logic update. Much of the default trade logic reprogrammed.
- Moved default logic to
./default_logic.js
. - RSI now backfills by default, reconfigured to 15m intervals.
Update Tips
To update your Zenbot installation, use ./update.sh
. If you have merge conflicts after update, solve them, then run ./run.sh
. If you have runtime JavaScript errors after update, your database might be obsolete. Try dropping your zenbrain
DB and run run.sh
again to start with a clean state.
FAQ
Can I use zenbot with [X] exchange?
Yes! As long as that exchange has a public API, you can find a plugin (or write one) to interact with that exchange. I accept pull requests if you want to contribute [X] exchange support.
Why open source?
There is a general lack of open source bots, especially ones with AI. Since I learned how to code by reverse engineering, I publish code so others can do the same, and by doing so I'm saying thanks to Satoshi, Torvalds, djb, et. al for devoting their lives to open source. It might be against my "selfish interest" but in the end it's best for everyone. Plus, I still own the copyright.
Were there any incidents when the bot's trade made a loss?
I have seen losses in the simulator, so it's possible. It only takes a few minutes of machine learning to gain a comfortable (albeit virtual) profit margin though. If the bot starts losing money, you can always step in and manual trade or shut the bot down to prevent more loss.
Based on what criteria does the bot decide to close a trade?
zenbot always trades with the "market" flag, i.e. the order never goes on the books, and the trade goes through with whatever price the last system trade was at. This way, zenbot never needs to cancel orders or compare prices.
What does [bot] not enough currency to buy! mean?
It means the bot tried to buy, but had not enough USD balance to do that. The volume counter resets anyway. If you feel comfortable investing, you can deposit USD in your account and zenbot will use that the next time the trade signal triggers.
Reading assignment: Systematic trading using neural networks
In mathematical terms, Artificial neural networks (ANNs) are universal function approximators, meaning that given the right data and configured correctly, they can capture and model any input-output relationships. This removes the need for human interpretation of charts to determine entry/exit signals.
As ANNs are essentially non-linear statistical models, their accuracy and prediction capabilities can be both mathematically and empirically tested. In various studies, authors have claimed that neural networks used for generating trading signals given various technical and fundamental inputs have significantly outperformed buy-hold strategies as well as traditional linear technical analysis methods when combined with rule-based expert systems.
While the advanced mathematical nature of such adaptive systems has kept neural networks for financial analysis mostly within academic research circles, in recent years more user friendly neural network software has made the technology more accessible to traders.
Source: Wikipedia
Donate
P.S., some have asked for how to donate to Zenbot development. I accept donations at my Bitcoin address Here:
carlos8f's BTC
187rmNSkSvehgcKpBunre6a5wA5hQQop6W
Patreon
Zenbot is on Patreon! Give some $ per month to support Zenbot 3 development.
GratiPay
Zenbot is on Grati-Pay! Another way to give $ per month to support development.
thanks!
License: MIT
- Copyright (C) 2016 Carlos Rodriguez (http://s8f.org/)
- Copyright (C) 2016 Terra Eclipse, Inc. (http://www.terraeclipse.com/)
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.