| Overall Statistics |
|
Total Trades 903 Average Win 0.51% Average Loss -0.27% Compounding Annual Return 12.911% Drawdown 15.700% Expectancy 1.183 Net Profit 254.607% Sharpe Ratio 1.227 Probabilistic Sharpe Ratio 69.058% Loss Rate 25% Win Rate 75% Profit-Loss Ratio 1.93 Alpha 0 Beta 0 Annual Standard Deviation 0.107 Annual Variance 0.012 Information Ratio 1.227 Tracking Error 0.107 Treynor Ratio 0 Total Fees $1466.13 Estimated Strategy Capacity $88000.00 Lowest Capacity Asset XVZ UZ6Q81R5NIW5 |
from QuantConnect.Data.Custom.CBOE import *
class RetrospectiveFluorescentOrangeScorpion(QCAlgorithm):
def Initialize(self):
self.SetStartDate(2011,1, 1) # Set Start Date
self.SetEndDate(2021,6,1) # Set End Date
self.SetCash(100000) # Set Strategy Cash
self.regime = 0
self.regime_threshold = 22
vix = self.AddData(CBOE, "VIX").Symbol
self.history = self.History(CBOE, vix, 30, Resolution.Daily)
# Define the security universe
self.SetBrokerageModel(BrokerageName.InteractiveBrokersBrokerage)
self.tickers = ['PGJ','GLD','TLT','AIA','VWO','XLF','FXY','IYW','IYG','XVZ',"SPY"]
for symbol in self.tickers:
self.AddEquity(symbol, Resolution.Daily)
self.Schedule.On(self.DateRules.EveryDay(),self.TimeRules.AfterMarketOpen("SPY", 180), self.SignalRefresh)
self.Schedule.On(self.DateRules.MonthStart(),self.TimeRules.AfterMarketOpen("SPY", 180), self.Rebalance)
def Rebalance(self):
# Rebalance portfolio monthly
if self.regime == 0:
self.SetHoldings('PGJ',0.03)
self.SetHoldings('GLD',0.03)
self.SetHoldings('TLT',0.32)
self.SetHoldings('AIA',0.03)
self.SetHoldings('VWO',0.03)
self.SetHoldings('XLF',0.03)
self.SetHoldings('FXY',0.03)
self.SetHoldings('IYW',0.43)
self.SetHoldings('IYG',0.03)
self.SetHoldings('XVZ',0.03)
else:
self.SetHoldings('PGJ',0.34)
self.SetHoldings('GLD',0.03)
self.SetHoldings('TLT',0.09)
self.SetHoldings('AIA',0.09)
self.SetHoldings('VWO',0.03)
self.SetHoldings('XLF',0.05)
self.SetHoldings('FXY',0.039)
self.SetHoldings('IYW',0.08)
self.SetHoldings('IYG',0.03)
self.SetHoldings('XVZ',0.15)
def SignalRefresh(self):
vix = self.AddData(CBOE, "VIX").Symbol
self.history = self.History(CBOE, vix, 30, Resolution.Daily)
self.signal_series = [1 if x>=self.regime_threshold else 0 for x in self.history.close.values]
if 1 in self.signal_series:
if self.regime != 1:
self.regime = 1
self.Rebalance()
else:
if self.regime != 0:
self.regime = 0
self.Rebalance()