Overall Statistics |
Total Trades 64 Average Win 0.93% Average Loss -0.54% Compounding Annual Return 2.962% Drawdown 4.400% Expectancy 0.705 Net Profit 12.675% Sharpe Ratio 0.54 Loss Rate 38% Win Rate 62% Profit-Loss Ratio 1.73 Alpha 0.119 Beta -5.796 Annual Standard Deviation 0.046 Annual Variance 0.002 Information Ratio 0.186 Tracking Error 0.046 Treynor Ratio -0.004 Total Fees $21.52 |
from clr import AddReference AddReference("System") AddReference("QuantConnect.Algorithm") AddReference("QuantConnect.Common") from System import * from QuantConnect import * from QuantConnect.Algorithm import * from QuantConnect.Indicators import * from QuantConnect.Data.Market import TradeBar class RollingWindowAlgorithm(QCAlgorithm): def Initialize(self): self.SetStartDate(2013, 6, 1) #Set Start Date self.SetEndDate(2017, 7, 1) #Set End Date self.SetCash(10000) #Set Strategy Cash self.SetBrokerageModel(BrokerageName.FxcmBrokerage) self.AddForex("EURUSD", Resolution.Daily) self.window = RollingWindow[QuoteBar](2) # create a bollinger band self.Bolband = self.BB("EURUSD", 20, 0.75, MovingAverageType.Simple, Resolution.Daily) self.Bolband.Updated += self.BolbandUpdated self.BolbandWin = RollingWindow[IndicatorDataPoint](5) # set warmup period self.SetWarmUp(20) def BolbandUpdated(self, sender, updated): '''Adds updated values to rolling window''' self.BolbandWin.Add(updated) def OnData(self, data): self.window.Add(data["EURUSD"]) if not (self.window.IsReady and self.BolbandWin.IsReady): return holdings = self.Portfolio["EURUSD"].Quantity price = self.window[0].Close previousPrice = self.window[1].Close Buy_below_lowerband = (previousPrice <= self.Bolband.LowerBand.Current.Value) and (price > self.Bolband.LowerBand.Current.Value) if Buy_below_lowerband: self.SetHoldings("EURUSD", 1.0) if holdings <= 0: if previousPrice <= self.Bolband.LowerBand.Current.Value and price > self.Bolband.LowerBand.Current.Value: self.SetHoldings("EURUSD", 1.0) if holdings > 0: if previousPrice >= self.Bolband.UpperBand.Current.Value and price < self.Bolband.UpperBand.Current.Value: self.Liquidate() if previousPrice <= self.Bolband.LowerBand.Current.Value and price > self.Bolband.LowerBand.Current.Value: self.SetHoldings("EURUSD", 1.0) if Buy_below_lowerband: if price == self.Bolband.MiddleBand.Current.Value: self.Liquidate()