Overall Statistics |
Total Trades 5 Average Win 0.40% Average Loss 0% Compounding Annual Return -2.210% Drawdown 3.700% Expectancy 0 Net Profit -2.605% Sharpe Ratio -1.152 Loss Rate 0% Win Rate 100% Profit-Loss Ratio 0 Alpha -0.022 Beta 0.027 Annual Standard Deviation 0.015 Annual Variance 0 Information Ratio -1.794 Tracking Error 0.095 Treynor Ratio -0.652 Total Fees $9.25 |
from clr import AddReference AddReference("System") AddReference("QuantConnect.Algorithm") AddReference("QuantConnect.Common") from System import * from QuantConnect import * from QuantConnect.Algorithm import * from QuantConnect.Securities import * from datetime import timedelta class BasicTemplateFuturesAlgorithm(QCAlgorithm): '''This example demonstrates how to add futures for a given underlying. It also shows how you can prefilter contracts easily based on expirations. It also shows how you can inspect the futures chain to pick a specific contract to trade.''' def Initialize(self): self.SetStartDate(2013, 10, 07) self.SetEndDate(2014, 12, 11) self.SetCash(1000000) # Subscribe and set our expiry filter for the futures chain # futureES = self.AddFuture(Futures.Indices.SP500EMini) # futureES.SetFilter(timedelta(0), timedelta(182)) # futureGC = self.AddFuture(Futures.Metals.Gold) # futureGC.SetFilter(timedelta(0), timedelta(182)) # self.Log("What is this {0}".format(Futures.Metals.Gold)) futureCL = self.AddFuture("CL") futureCL.SetFilter(timedelta(0), timedelta(182)) def OnData(self,slice): if not self.Portfolio.Invested: for chain in slice.FutureChains: # Get contracts expiring no earlier than in 90 days contracts = filter(lambda x: x.Expiry > self.Time + timedelta(90), chain.Value) # if there is any contract, trade the front contract if len(contracts) == 0: continue front = sorted(contracts, key = lambda x: x.Expiry, reverse=True)[0] self.MarketOrder(front.Symbol , 1) # else: # self.Liquidate() def OnOrderEvent(self, orderEvent): self.Log(str(orderEvent))