| 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 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 |
using System;
using System.Globalization;
using QuantConnect.Data;
using QuantConnect.Data.Market;
namespace QuantConnect.Algorithm.CSharp.My_Algorithms
{
public class ES5minData : TradeBar
{
public decimal UpperShadow { get; set; }
public decimal LowerShadow { get; set; }
public decimal HighLow { get; set; }
public decimal RealBody { get; set; }
public decimal UpperShadowPercent { get; set; }
public decimal LowerShadowPercent { get; set; }
public override DateTime EndTime
{
get { return (Time + Period); }
set { Time = (value - Period); }
}
public new TimeSpan Period
{
get { return TimeSpan.FromMinutes(5); }
}
public override SubscriptionDataSource GetSource(SubscriptionDataConfig config, DateTime date, bool isLiveMode)
{
return new SubscriptionDataSource("https://www.dropbox.com/s/2til1kzb6s4snpw/ES%202016-01-04%20-%202016-12-30%20-%20EST.csv?dl=1", SubscriptionTransportMedium.RemoteFile);
}
public override BaseData Reader(SubscriptionDataConfig config, string line, DateTime date, bool isLiveMode)
{
ES5minData cmBar = new ES5minData();
try
{
var data = line.Split(',');
//Required.
cmBar.Symbol = "ES";
if (data[1].Length == 5)
{
var theDate = DateTime.ParseExact(data[0], "yyyyMMdd", CultureInfo.InvariantCulture);
var theTime = TimeSpan.ParseExact(data[1].Insert(0, "0"), "hhmmss", CultureInfo.InvariantCulture);
cmBar.Time = theDate + theTime;
}
else
{
var theDate = DateTime.ParseExact(data[0], "yyyyMMdd", CultureInfo.InvariantCulture);
var theTime = TimeSpan.ParseExact(data[1], "hhmmss", CultureInfo.InvariantCulture);
cmBar.Time = theDate + theTime;
}
cmBar.Open = Convert.ToDecimal(data[2], CultureInfo.InvariantCulture);
cmBar.High = Convert.ToDecimal(data[3], CultureInfo.InvariantCulture);
cmBar.Low = Convert.ToDecimal(data[4], CultureInfo.InvariantCulture);
cmBar.Close = Convert.ToDecimal(data[5], CultureInfo.InvariantCulture);
cmBar.Volume = Convert.ToInt64(data[6], CultureInfo.InvariantCulture);
cmBar.Value = cmBar.Close;
if (cmBar.Close > cmBar.Open)
{
cmBar.UpperShadow = (cmBar.High - cmBar.Close);
cmBar.LowerShadow = (cmBar.Open - cmBar.Low);
cmBar.RealBody = (cmBar.Close - cmBar.Open);
}
else
{
cmBar.UpperShadow = (cmBar.High - cmBar.Open);
cmBar.LowerShadow = (cmBar.Close - cmBar.Low);
cmBar.RealBody = (cmBar.Open - cmBar.Close);
}
cmBar.HighLow = (cmBar.High - cmBar.Low);
cmBar.UpperShadowPercent = (cmBar.UpperShadow / cmBar.HighLow * 100);
cmBar.LowerShadowPercent = (cmBar.LowerShadow / cmBar.HighLow * 100);
}
catch
{
}
return cmBar;
}
}
}using System;
using QuantConnect.Indicators;
using QuantConnect.Indicators.CandlestickPatterns;
namespace QuantConnect.Algorithm.CSharp.My_Algorithms
{
public class SuppCanNrNotAloneLT30_50prct1 : QCAlgorithm
{
private string _symbol = "ES";
public RollingWindow<ES5minData> priorBar = new RollingWindow<ES5minData>(3);
private SpinningTop spinTop = new SpinningTop();
public override void Initialize()
{
SetStartDate(2016, 01, 08); //Set Start Date
SetEndDate(2016, 01, 08); //Set End Date
SetCash(100000); //Set Strategy Cash
AddData<ES5minData>(_symbol);
spinTop = CandlestickPatterns.SpinningTop(_symbol);
}
public void OnData(ES5minData data)
{
if (data.Time.TimeOfDay < new TimeSpan(9, 00, 00) ||
data.Time.TimeOfDay > new TimeSpan(12, 00, 00))
return;
priorBar.Add(data);
if (!priorBar.IsReady) return;
// priorBar[0] = present Bar; priorBar[1] = previous Bar;
decimal lowTail = priorBar[0].LowerShadowPercent.RoundToSignificantDigits(4);
// if Real Body is Down on higher vol + Low Tail is b/n 30-50% of HighLow + after prior Down Candle - expect a Move Down ?
if (priorBar[0].Close < priorBar[0].Open && priorBar[0].Volume > priorBar[1].Volume && priorBar[0].LowerShadowPercent >= 30 &&
priorBar[0].LowerShadowPercent <= 50 && priorBar[1].Close < priorBar[1].Open)
{
if (spinTop != 0) return;
Debug(data.Time + " SuppCanNrNotAloneLT30_50prct "); // time of day - found SuppCanNrNotAloneLT30_50prct
}
}
}
}