Overall Statistics |
Total Trades 0 Average Win 0% Average Loss 0% Compounding Annual Return 0% Drawdown 0% Expectancy 0 Net Profit 0% Sharpe Ratio 0 Probabilistic Sharpe Ratio 0% Loss Rate 0% Win Rate 0% Profit-Loss Ratio 0 Alpha 0 Beta 0 Annual Standard Deviation 0 Annual Variance 0 Information Ratio -0.9 Tracking Error 0.115 Treynor Ratio 0 Total Fees $0.00 Estimated Strategy Capacity $0 Lowest Capacity Asset |
# sma_ratio_spread # --------------- MA = 21; SMA = 5; # --------------- class SmaRatioSpread(QCAlgorithm): def Initialize(self): self.SetStartDate(2021, 1, 1) self.SetEndDate(2022, 2, 22) self.SetCash(1000000) self.pep = self.AddEquity("PEP", Resolution.Daily).Symbol self.coke = self.AddEquity("COKE", Resolution.Daily).Symbol price_pep = self.SMA(self.pep, 1, Resolution.Daily) price_coke = self.SMA(self.coke, 1, Resolution.Daily) sma_pep = self.SMA(self.pep, MA, Resolution.Daily) sma_coke = self.SMA(self.coke, MA, Resolution.Daily) ratio_pep = IndicatorExtensions.Over(price_pep, sma_pep) ratio_coke = IndicatorExtensions.Over(price_coke, sma_coke) self.ratio_spread = IndicatorExtensions.Minus(ratio_pep, ratio_coke) self.sma_ratio_spread = IndicatorExtensions.SMA(self.ratio_spread, SMA) self.SetWarmUp(MA + SMA, Resolution.Daily) def OnData(self, data): if self.IsWarmingUp: return if not self.ratio_spread.IsReady: return if not self.sma_ratio_spread.IsReady: return self.Plot("Spread","ratio_spread", self.ratio_spread.Current.Value) self.Plot("Spread","sma_ratio_spread", self.sma_ratio_spread.Current.Value)