Overall Statistics |
Total Trades 1 Average Win 0% Average Loss 0% Compounding Annual Return 0% Drawdown 0% Expectancy 0 Net Profit 0% Sharpe 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 $1.00 Estimated Strategy Capacity $9700000000.00 Lowest Capacity Asset SPY R735QTJ8XC9X |
#region imports using System; using System.Collections; using System.Collections.Generic; using System.Linq; using System.Globalization; using System.Drawing; using QuantConnect; using QuantConnect.Algorithm.Framework; using QuantConnect.Algorithm.Framework.Selection; using QuantConnect.Algorithm.Framework.Alphas; using QuantConnect.Algorithm.Framework.Portfolio; using QuantConnect.Algorithm.Framework.Execution; using QuantConnect.Algorithm.Framework.Risk; using QuantConnect.Parameters; using QuantConnect.Benchmarks; using QuantConnect.Brokerages; using QuantConnect.Util; using QuantConnect.Interfaces; using QuantConnect.Algorithm; using QuantConnect.Indicators; using QuantConnect.Data; using QuantConnect.Data.Consolidators; using QuantConnect.Data.Custom; using QuantConnect.DataSource; using QuantConnect.Data.Fundamental; using QuantConnect.Data.Market; using QuantConnect.Data.UniverseSelection; using QuantConnect.Notifications; using QuantConnect.Orders; using QuantConnect.Orders.Fees; using QuantConnect.Orders.Fills; using QuantConnect.Orders.Slippage; using QuantConnect.Scheduling; using QuantConnect.Securities; using QuantConnect.Securities.Equity; using QuantConnect.Securities.Future; using QuantConnect.Securities.Option; using QuantConnect.Securities.Forex; using QuantConnect.Securities.Crypto; using QuantConnect.Securities.Interfaces; using QuantConnect.Storage; using QuantConnect.Data.Shortable; using QuantConnect.Data.Custom.AlphaStreams; using QCAlgorithmFramework = QuantConnect.Algorithm.QCAlgorithm; using QCAlgorithmFrameworkBridge = QuantConnect.Algorithm.QCAlgorithm; using QuantConnect.Interfaces; #endregion namespace QuantConnect.Algorithm.CSharp { public class FormalYellowSalamander : QCAlgorithm { private bool _bot = false; public override void Initialize() { SetStartDate(2021, 7, 23); //Set Start Date SetCash(100000); //Set Strategy Cash SetBrokerageModel(new MyBrokerageModel()); AddEquity("SPY", Resolution.Minute); } public override void OnData(Slice data) { var quantity = 1; if (Portfolio.Invested) { quantity = -12; // This should result in a -11 short position } MarketOrder("SPY", quantity); } public override void OnOrderEvent(OrderEvent orderEvent) { var msg = $"{Time} -- {orderEvent.Message}"; if (orderEvent.Quantity > 0) { Debug(msg); } else { Quit(msg); } } } class MyShortableProvider : IShortableProvider { public Dictionary<Symbol, long> AllShortableSymbols(DateTime localTime) { return null; } public long? ShortableQuantity(Symbol symbol, DateTime localTime) { return 10; } } class MyBrokerageModel : DefaultBrokerageModel { public override decimal RequiredFreeBuyingPowerPercent { get; } public override IReadOnlyDictionary<SecurityType, string> DefaultMarkets => DefaultMarketMap; public MyBrokerageModel(AccountType accountType = AccountType.Margin) : base(accountType) { ShortableProvider = new MyShortableProvider(); } public override bool CanSubmitOrder(Security security, Order order, out BrokerageMessageEvent message) { return base.CanSubmitOrder(security, order, out message); } public override bool CanUpdateOrder(Security security, Order order, UpdateOrderRequest request, out BrokerageMessageEvent message) { return base.CanUpdateOrder(security, order, request, out message); } public override bool CanExecuteOrder(Security security, Order order) { return base.CanExecuteOrder(security, order); } public override void ApplySplit(List<OrderTicket> tickets, Split split) { base.ApplySplit(tickets, split); } public override decimal GetLeverage(Security security) { return base.GetLeverage(security); } public override IBenchmark GetBenchmark(SecurityManager securities) { return base.GetBenchmark(securities); } public override IFillModel GetFillModel(Security security) { return base.GetFillModel(security); } public override IFeeModel GetFeeModel(Security security) { return base.GetFeeModel(security); } public override ISlippageModel GetSlippageModel(Security security) { return base.GetSlippageModel(security); } public override ISettlementModel GetSettlementModel(Security security) { return base.GetSettlementModel(security); } public override IBuyingPowerModel GetBuyingPowerModel(Security security) { return base.GetBuyingPowerModel(security); } public override IMarginInterestRateModel GetMarginInterestRateModel(Security security) { return base.GetMarginInterestRateModel(security); } public override IShortableProvider GetShortableProvider() { return ShortableProvider; } } }