Skip to content

A backtesting engine for testing trading strategies over GDAX (Coinbase Pro) marketplace data

Notifications You must be signed in to change notification settings

jrbartola/CryptoBacktester

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CryptoBacktester

A backtesting engine for testing trading strategies over GDAX (Coinbase Pro) marketplace data

Alt text

This tool allows you to try different strategies over sets of historical trading data from Coinbase.

Installation

First, clone or download the repository to your computer.

Front End- Navigate to the www directory and run npm install. Make sure you have the latest version of node.js installed on your computer.

Back End- The server should run with python 3.x. The dependencies are listed in the requirements.txt file, so just do a quick pip install -r requirements.txt.

Running the Application

First, you'll need to use webpack to bundle all of the React .tsx files on the front end. Within the www directory run npm run build.

Next, navigate to the backend directory and run python server.py. Now you're all set! Open up your favorite browser and navigate to http://localhost:5000/ and try it out.

Running a Backtest

Coin Information

Begin by selecting the coin pair you want to trade with. The first coin (the one before the "/") is the base currency-- the one you will be purchsing. The second coin is the quote currency, which is what you will use to buy the base currency. For example, if the coin pair is "ETH/BTC", you will be purchasing ETH using BTC.

"Capital" is the amount of quote currency you want to start out with trading.

"Time Unit" is the duration between each point on the time series of historical data.

"Stop Loss" (optional) is the percentage of base currency below each buy price that you will sell your position at. The smaller the stop loss, the less your risk.

"Start Time" is the starting date that the backtesting engine will run a strategy over.

Creating a Strategy

The next step is to fill in your buy and sell strategy. Each input field takes a condition that will evaluate to true or false based on the current price and indicators provided. Here are some examples:

current-price > sma(9): Evaluates to true when the current price rises above the 9-period simple moving average

sma(15) < sma(9): Evaluates to true when the 15-period simple moving averages drops below the 9-period simple moving average

rsi(14) <= 30 && current-price > ema(15): Evaluates to true when the 14-period RSI is at most 30 and the current price is greater than the 15-period exponential moving average

!(current-price < 1000 || sma(15) < sma(9)): Evaluates to true when the current price is not less than 1000 and the 15-period SMA is not less than the 9-period SMA

In general, the formal context-free grammar is as follows:

<integer>   := /([+-]?[1-9]\d*|0)/
<real>      := /-?\d+(\.\d*)?/


<indicator> := <real>
             | current-price
             | sma(<integer>)
             | ema(<integer>)
             | rsi(<integer>)
             
<op>        := =
             | >
             | <
             | >=
             | <=
             | !=
             
<exp>       := <indicator> <op> <indicator>
             | (<exp>)
             | !(<exp>)
             | <exp> && <exp>
             | <exp> || <exp>

That's It!

Once you've filled out all of the fields, click "Start" to begin the backtesting. Your profit is shown in the bottom-right corner of the upper panel.

What's on the Graph?

Green dots represent buy points. Red dots represent sell points. The purple line is the plot of historical closing prices, and any other indicators will appear as random colors designated by the legend on the plot.

Coming Soon

RSI & MACD indicators, live trading strategies over Coinbase Pro, position report of buys/sells after backtesting

About

A backtesting engine for testing trading strategies over GDAX (Coinbase Pro) marketplace data

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published