| 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