This repository consists of an event-driven backtester, based on a series of articles written by Michael Halls-Moore:
- Event-Driven Backtesting with Python - Part I
- Event-Driven Backtesting with Python - Part II
- Event-Driven Backtesting with Python - Part III
- Event-Driven Backtesting with Python - Part IV
- Event-Driven Backtesting with Python - Part V
- Event-Driven Backtesting with Python - Part VI
- Event-Driven Backtesting with Python - Part VII
The code has been rewritten by hand, and modified for some parts. Indeed, copying and pasting the different parts of the code won't make the code run. The author gave the direction on how to implement a backtester, but some additional work was necessary to make the code function properly.
Some additions have also been added in terms of data handling and strategies implemented:
YahooDataHandler
that allows to get data directly from Yahoo Finance website and update the latest "bar" in a live manner.CryptoCMCDataHandler
for cryptocurrency data, to communicate with the CoinMarketCap API and update the latest "bar" in a live manner.HistoricMySQLDataHandler
designed to read a MySQL database for each requested symbol from disk, and provides an interface to obtain the "latest" bar in a manner identical to a live trading interface.MovingAverageCrossOverStrat
to carry out a basic Moving Average Crossover strategy with a short/long simple weighted moving average.ETFDailyForecastStrategy
to perform a prediction on an ETF price, based on previous daily prices (lag prices).
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.
You need Python 3.x to run the following code. You can have multiple Python versions (2.x and 3.x) installed on the same system without problems. Python needs to be first installed then SciPy and pymysql as there are dependencies on packages.
In Ubuntu, Mint and Debian you can install Python 3 like this:
sudo apt-get install python3 python3-pip
Alongside Python, the SciPy packages are also required. In Ubuntu and Debian, the SciPy ecosystem can be installed by:
sudo apt-get install python-numpy python-scipy python-matplotlib ipython ipython-notebook python-pandas python-sympy python-nose
Finally, the pymysql package for connecting to MySQL databases using Python, which can be installed with pip:
pip install pymysql
For other Linux flavors, OS X and Windows, packages are available at:
http://www.python.org/getit/
https://www.scipy.org/install.html
- 'Backtester_loop.py' in which the Backtest class hierarchy encapsulates the other classes, to carry out a nested while-loop event-driven system in order to handle the events placed on the Event Queue object.
- 'DataHandler.py' which defines a class that gives all subclasses an interface for providing market data to the remaining components within the system. Data can be obtained directly from the web, a database or be read from CSV files for instance.
- 'Events.py' with four types of events (market, signal, order and fill), which allow communication between the above components via an event queue, are implemented.
- 'Execution.py' to simulate the order handling mechanism and ultimately tie into a brokerage or other means of market connectivity.
- 'Main.py' which is the main Python program, englobing all the different subroutines, and where the different parameters to initialize the backtesting simulations are specified.
- 'Performance.py' in which performance assessment criteria are implemented such as the Sharpe ratio and drawdowns.
- 'Plot_Performance.py' to plot figures based on the equity curve obtained after backtesting.
- 'Portfolio.py' that keeps track of the positions within a portfolio, and generates orders of a fixed quantity of stock based on signals.
- 'Strategy.py' to generate a signal event from a particular strategy to communicate to the portfolio.
- In the 'Strategies' directory, different trading strategies are implemented to be used for backtesting:
- 'Buy_and_hold_strat.py' in which a simple buy and hold strategy is coded.
- 'Moving_average_crossover_strat.py' to generate signals from simple moving averages.
- 'ETF_forecast.py' basic forecasting algorithm on ETF such as S&P500 using lagged price data
The different ".py" files need to be placed in the same folder for the main script to be run. The code is then ready to be used, and just requires running the following command:
python Main.py
The code is well commented and easy to understand. The different parameters calculated and used for the simulations are:
data_dir = 'C:/Users/EC-PM-3/Desktop/Quant_Data_science/Backtester_model/Data_directory' # Needs to be specified based on your own path
symbol_list = ['AAPL']
initial_capital = 100000.0
start_date = datetime(2016,1,1,0,0,0)
interval ="1d"
end_date = datetime(2018,1,1,0,0,0)
heartbeat = 0.0
backtest = Backtest(data_dir, # data directory of CSV files
symbol_list, # list of symbols
initial_capital, # initial capital available for trading
heartbeat, # heartbeat to count time in real live trading simulation
start_date, # starting time of the trading
interval, # interval between each data bar
end_date, # ending time of trading for Yahoo finance data
YahooDataHandler, # data management method
SimpleSimulatedExecutionHandler, # Type of execution in relationship to broker
Portfolio, # portfolio management method
MovingAverageCrossOverStrat) # strategy chosen
backtest.simulate_trading()
Running the backtester will generate a CSV file "equity.csv", with PnL curve, returns, drawdowns, etc. By running the following Python script, a plot can be generated to assess the strategy:
python Plot_performance.py
The picture below shows an example with the parameters highlighted above.
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
We use SemVer for versioning. For the versions available, see the tags on this repository.
- David Cicoria - Initial work - DavidCico
See also the list of contributors who participated in this project.