Overall Statistics |
Total Orders 0 Average Win 0% Average Loss 0% Compounding Annual Return 0% Drawdown 0% Expectancy 0 Start Equity 100000 End Equity 100000 Net Profit 0% Sharpe Ratio 0 Sortino 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 -2.749 Tracking Error 0.098 Treynor Ratio 0 Total Fees $0.00 Estimated Strategy Capacity $0 Lowest Capacity Asset Portfolio Turnover 0% |
from datetime import timedelta from AlgorithmImports import * class FT1Indexes(QCAlgorithm): def initialize(self): self.set_start_date(2024, 1, 1) # monday = holiday.. self.set_end_date(2024, 2, 1) self.set_cash(100000) self.spy = self.add_equity("SPY", Resolution.HOUR).symbol self.daily_consolidator = TradeBarConsolidator(timedelta(days=1)) self._rsi = RelativeStrengthIndex(14, MovingAverageType.WILDERS) self._sto = Stochastic(14, 3, 3) self.register_indicator(self.spy, self._rsi, self.daily_consolidator) self.register_indicator(self.spy, self._sto, self.daily_consolidator) # warm_up indicator self.warm_up_indicator(self.spy, self._rsi, timedelta(days=1)) self.warm_up_indicator(self.spy, self._sto, timedelta(days=1)) self._rsi_history = RelativeStrengthIndex(14, MovingAverageType.WILDERS) self._sto_history = Stochastic(14, 3, 3) self.register_indicator(self.spy, self._rsi_history, self.daily_consolidator) self.register_indicator(self.spy, self._sto_history, self.daily_consolidator) # history warm up history = self.history[TradeBar](self.spy, 20, Resolution.DAILY) for bar in history: self._rsi_history.update(bar.end_time, bar.close) self._sto_history.update(bar) def on_data(self, data: Slice): if self.is_warming_up: return if data.contains_key(self.spy): chart_name = "warm_up_indicator" self.plot(chart_name, "RSI", self._rsi.current.value) self.plot(chart_name, "STO K", self._sto.stoch_k.current.value) self.plot(chart_name, "STO D", self._sto.stoch_d.current.value) chart_name = "History Warmup" self.plot(chart_name, "RSI", self._rsi_history.current.value) self.plot(chart_name, "STO K", self._sto_history.stoch_k.current.value) self.plot(chart_name, "STO D", self._sto_history.stoch_d.current.value)