Overall Statistics |
Total Trades 11 Average Win 0.88% Average Loss 0% Compounding Annual Return 216.578% Drawdown 8.600% Expectancy 0 Net Profit 6.729% Sharpe Ratio 9.371 Probabilistic Sharpe Ratio 82.450% Loss Rate 0% Win Rate 100% Profit-Loss Ratio 0 Alpha 2.363 Beta -0.421 Annual Standard Deviation 0.233 Annual Variance 0.054 Information Ratio 5.507 Tracking Error 0.319 Treynor Ratio -5.186 Total Fees $20.35 |
from clr import AddReference AddReference("System") AddReference("QuantConnect.Algorithm") AddReference("QuantConnect.Algorithm.Framework") AddReference("QuantConnect.Common") from System import * from QuantConnect import * from QuantConnect.Orders import * from QuantConnect.Securities import * from QuantConnect.Algorithm import * from QuantConnect.Algorithm.Framework import * from QuantConnect.Algorithm.Framework.Alphas import * from QuantConnect.Algorithm.Framework.Portfolio import * from QuantConnect.Algorithm.Framework.Selection import * from Alphas.ConstantAlphaModel import ConstantAlphaModel from Selection.FutureUniverseSelectionModel import FutureUniverseSelectionModel from QuantConnect.Algorithm.Framework.Execution import * from QuantConnect.Algorithm.Framework.Risk import * from datetime import date, timedelta ### <summary> ### Basic template futures framework algorithm uses framework components ### to define an algorithm that trades futures. ### </summary> class ExampleAlgo(QCAlgorithm): def Initialize(self): self.UniverseSettings.Resolution = Resolution.Minute self.SetStartDate(2020, 10, 1) self.SetCash(100000) # set framework models self.SetUniverseSelection(FrontMonthFutureUniverseSelectionModel(self.SelectFutureChainSymbols)) self.SetAlpha(ConstantFutureContractAlphaModel(InsightType.Price, InsightDirection.Up, timedelta(1))) self.SetPortfolioConstruction(SingleSharePortfolioConstructionModel()) self.SetExecution(ImmediateExecutionModel()) self.SetRiskManagement(NullRiskManagementModel()) def SelectFutureChainSymbols(self, utcTime): softTickers = [ Futures.Softs.Cocoa, Futures.Softs.Sugar11CME, ] grainTickers = [ Futures.Grains.Wheat, Futures.Grains.Corn, Futures.Grains.Soybeans, Futures.Grains.SoybeanMeal, Futures.Grains.SoybeanOil, Futures.Grains.Oats, ] grains = [ Symbol.Create(ticker, SecurityType.Future, Market.CBOT) for ticker in grainTickers ] softs = [ Symbol.Create(ticker, SecurityType.Future, Market.NYMEX) for ticker in softTickers ] return grains + softs class FrontMonthFutureUniverseSelectionModel(FutureUniverseSelectionModel): '''Creates futures chain universes that select the front month contract and runs a user defined futureChainSymbolSelector every day to enable choosing different futures chains''' def __init__(self, select_future_chain_symbols): super().__init__(timedelta(1), select_future_chain_symbols) def Filter(self, filter): '''Defines the futures chain universe filter''' return (filter.FrontMonth() .OnlyApplyFilterAtMarketOpen()) class ConstantFutureContractAlphaModel(ConstantAlphaModel): '''Implementation of a constant alpha model that only emits insights for future symbols''' def __init__(self, type, direction, period): super().__init__(type, direction, period) def ShouldEmitInsight(self, utcTime, symbol): # only emit alpha for future symbols and not underlying equity symbols if symbol.SecurityType != SecurityType.Future: return False return super().ShouldEmitInsight(utcTime, symbol) class SingleSharePortfolioConstructionModel(PortfolioConstructionModel): '''Portfolio construction model that sets target quantities to 1 for up insights and -1 for down insights''' def CreateTargets(self, algorithm, insights): targets = [] for insight in insights: targets.append(PortfolioTarget(insight.Symbol, insight.Direction)) return targets