Overall Statistics
Total Trades
0
Average Win
0%
Average Loss
0%
Compounding Annual Return
0%
Drawdown
0%
Expectancy
0
Net Profit
0%
Sharpe Ratio
0
Sortino Ratio
0
Probabilistic Sharpe Ratio
0%
Loss Rate
0%
Win Rate
0%
Profit-Loss Ratio
0
Alpha
0
Beta
0
Annual Standard Deviation
0
Annual Variance
0
Information Ratio
0
Tracking Error
0
Treynor Ratio
0
Total Fees
$0.00
Estimated Strategy Capacity
$0
Lowest Capacity Asset
Portfolio Turnover
0%
from AlgorithmImports import *

class TransdimensionalDynamicThrustAssembly(QCAlgorithm):

    def Initialize(self):

        # setting Universe Size and ETF Ticker:
        self.UniverseSize = 9
        self.ETFSymbol = 'ACWI'

        self.SetStartDate(2015, 1, 1)  # Set Start Date
        self.SetEndDate(2020, 1, 1)  # Set End Date
   
        # Set Cash, Brokerage Model, Universe Settings and Warmup
        self.SetCash(100000)  
        self.SetBrokerageModel(BrokerageName.InteractiveBrokersBrokerage, AccountType.Margin)
        self.SetSecurityInitializer(lambda security: security.SetMarketPrice(self.GetLastKnownPrice(security)))
        self.UniverseSettings.Resolution = Resolution.Daily
        self.SetWarmup(150)

        # Define the Universe
        self.AddUniverse(self.Universe.ETF(self.ETFSymbol, Market.USA, self.UniverseSettings, self.ETFConstituentsFilterStatic))

        # everything else to Null
        self.SetPortfolioConstruction(NullPortfolioConstructionModel())
        self.SetAlpha(NullAlphaModel())
        self.SetExecution(NullExecutionModel())
        self.SetRiskManagement(NullRiskManagementModel())

    def ETFConstituentsFilterStatic(self, constituents: List[ETFConstituentData]) -> List[Symbol]:

        # Original Version - select all ETF constituens that have a weight property and sort them by that weight
        selected = sorted([c for c in constituents if c.Weight],
            key=lambda c: c.Weight, reverse=True)

        # Crude Fix to avoid other ETFs being returned as constituents of ACWI - filtering for a list of ETF tickers that have come up in testing so far
        
        # etfs = ['CRED', 'IVV', 'IJH', 'IPAC', 'IEUR', 'IEMG', 'INDA']
        # selected = sorted([c for c in constituents if c.Weight and c.Symbol.Value not in etfs],
        #     key=lambda c: c.Weight, reverse=True)

        # return the self.UniverseSize largest constituents by weight:
        return [c.Symbol for c in selected][:self.UniverseSize]


    def OnSecuritiesChanged(self, changes: SecurityChanges) -> None:

        # List all tickers added to the universe
        if changes.AddedSecurities:
            self.Debug(str(self.Time) + " Adding to universe: " + str(
                [security.Symbol.Value for security in changes.AddedSecurities]))