Overall Statistics |
Total Trades 1 Average Win 0% Average Loss 0% Compounding Annual Return 0.786% Drawdown 0.000% Expectancy 0 Net Profit 0.038% Sharpe Ratio 5.815 Probabilistic Sharpe Ratio 98.333% Loss Rate 0% Win Rate 0% Profit-Loss Ratio 0 Alpha 0.006 Beta 0.008 Annual Standard Deviation 0.001 Annual Variance 0 Information Ratio 0.998 Tracking Error 0.065 Treynor Ratio 0.724 Total Fees $1.00 Estimated Strategy Capacity $190000000.00 Lowest Capacity Asset ADI 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.Custom.AlphaStreams; using QCAlgorithmFramework = QuantConnect.Algorithm.QCAlgorithm; using QCAlgorithmFrameworkBridge = QuantConnect.Algorithm.QCAlgorithm; #endregion namespace QuantConnect.Algorithm.CSharp { public class HyperActiveBlackPony : QCAlgorithm { bool _setOrder = false; public override void Initialize() { SetStartDate(2015, 5, 15); SetEndDate(2015, 6, 1); SetCash(100000); AddEquity("ADI", Resolution.Hour, dataNormalizationMode: DataNormalizationMode.Raw); //AddEquity("ADI", Resolution.Daily, dataNormalizationMode: DataNormalizationMode.Raw); //AddEquity("AAPL", Resolution.Hour, dataNormalizationMode: DataNormalizationMode.Raw); EMA("ADI", 5, Resolution.Daily); var consolidator = new TradeBarConsolidator(TimeSpan.FromDays(1)); consolidator.DataConsolidated += OnDailyData; SubscriptionManager.AddConsolidator("ADI", consolidator); //SubscriptionManager.AddConsolidator("AAPL", consolidator); } /// OnData event is the primary entry point for your algorithm. Each new data point will be pumped in here. /// Slice object keyed by symbol containing the stock data // public override void OnData(Slice data) // { // var bar = data.Bars["ADI"]; // Log($"Got data on {Time} for {bar.Time} - {bar.EndTime}; O: {bar.Open}; H: {bar.High}; C: {bar.Close}; L: {bar.Low}"); // if(!_setOrder) // { // var order = StopLimitOrder("ADI", 10, 65m, 65.26m); // Log("Order submitted. Status: " + order.Status); // _setOrder = true; // } // } void OnDailyData(object sender, TradeBar consolidatedBar) { Log(consolidatedBar.Symbol); var bar = consolidatedBar; Log($"Got data on {Time} for {bar.Time} - {bar.EndTime}; O: {bar.Open}; H: {bar.High}; C: {bar.Close}; L: {bar.Low}"); if(!_setOrder) { var order = StopLimitOrder("ADI", 10, 65m, 65.26m); Log("Order submitted. Status: " + order.Status); _setOrder = true; } } public override void OnOrderEvent(OrderEvent orderEvent) { Log($"[{Time} - Order Event @ {orderEvent.Symbol}] Status: {orderEvent.Status}; {orderEvent.Quantity}; Fill price: {orderEvent.FillPrice}; Limit Price {orderEvent.LimitPrice}; Stop price: {orderEvent.StopPrice}; Trigger price: {orderEvent.TriggerPrice}; Message: {orderEvent.Message}"); } } }