# QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals. # Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. from AlgorithmImports import * ### ### Using rolling windows for efficient storage of historical data; which automatically clears after a period of time. ### ### ### ### ### ### ### class RollingWindowAlgorithm(QCAlgorithm): def initialize(self): '''Initialise the data and resolution required, as well as the cash and start-end dates for your algorithm. All algorithms must initialized.''' self.set_start_date(2013,10,1) #Set Start Date self.set_end_date(2013,11,1) #Set End Date self.set_cash(100000) #Set Strategy Cash # Find more symbols here: http://quantconnect.com/data self.add_equity("SPY", Resolution.DAILY) # Creates a Rolling Window indicator to keep the 2 TradeBar self._window = RollingWindow(2) # For other security types, use QuoteBar # Creates an indicator and adds to a rolling window when it is updated self._sma = self.sma("SPY", 5) self._sma.updated += self._sma_updated self._sma_win = RollingWindow(5) def _sma_updated(self, sender, updated): '''Adds updated values to rolling window''' self._sma_win.add(updated) def on_data(self, data): '''OnData event is the primary entry point for your algorithm. Each new data point will be pumped in here.''' # Add SPY TradeBar in rollling window self._window.add(data["SPY"]) # Wait for windows to be ready. if not (self._window.is_ready and self._sma_win.is_ready): return curr_bar = self._window[0] # Current bar had index zero. past_bar = self._window[1] # Past bar has index one. self.log(f"Price: {past_bar.time} -> {past_bar.close} ... {curr_bar.time} -> {curr_bar.close}") curr_sma = self._sma_win[0] # Current SMA had index zero. past_sma = self._sma_win[self._sma_win.count-1] # Oldest SMA has index of window count minus 1. self.log(f"SMA: {past_sma.time} -> {past_sma.value} ... {curr_sma.time} -> {curr_sma.value}") if not self.portfolio.invested and curr_sma.value > past_sma.value: self.set_holdings("SPY", 1)