| Overall Statistics |
|
Total Trades 103 Average Win 0.68% Average Loss -0.29% Compounding Annual Return 171.957% Drawdown 5.500% Expectancy 1.008 Net Profit 18.537% Sharpe Ratio 4.446 Loss Rate 41% Win Rate 59% Profit-Loss Ratio 2.39 Alpha 0.477 Beta 21.069 Annual Standard Deviation 0.182 Annual Variance 0.033 Information Ratio 4.36 Tracking Error 0.182 Treynor Ratio 0.038 Total Fees $136.54 |
using System;
using System.Collections.Generic;
using System.Linq;
using QuantConnect.Data.Market;
using QuantConnect.Data.UniverseSelection;
namespace QuantConnect.Algorithm.CSharp
{
// In this algorithm we show how you can easily define a
// universe using our coarse selection data. This data includes
// a few properties, including the daily DollarVolume, the daily Volume
// and also the daily closing price via the Value property.
public class CoarseFundamentalTop5Algorithm : QCAlgorithm
{
// initialize our security changes to nothing
SecurityChanges _changes = SecurityChanges.None;
public override void Initialize()
{
// this sets the resolution for securities added via universe selection
UniverseSettings.Resolution = Resolution.Minute;
Schedule.On(DateRules.EveryDay(), TimeRules.At(09, 0), CountUniv);
SetStartDate(2015, 10, 1);
SetEndDate(2015, 12, 1);
SetCash(50000);
// this add universe method accepts a single parameter that is a function that
// accepts an IEnumerable<CoarseFundamental> and returns IEnumerable<Symbol>
AddUniverse(CoarseFunc);
}
// sort the data by daily dollar volume and take the top 5 symbols
public static IEnumerable<Symbol> CoarseFunc(IEnumerable<CoarseFundamental> coarse)
{
// sort descending by daily dollar volume
var sortedByDollarVolume = coarse.OrderByDescending(x => x.DollarVolume);
// take the top 5 entries from our sorted collection
var top5 = sortedByDollarVolume.Take(5);
// we need to return only the symbols
return top5.Select(x => x.Symbol);
}
//Data Event Handler: New data arrives here. "TradeBars" type is a dictionary of strings so you can access it by symbol.
public void OnData(TradeBars data)
{
// if we have no changes, do nothing
if (_changes == SecurityChanges.None) return;
// liquidate removed securities
foreach (var security in _changes.RemovedSecurities)
{
if (security.Invested)
{
Liquidate(security.Symbol);
}
}
// we want 25% allocation in each security in our universe (total of 150% invested)
foreach (var security in _changes.AddedSecurities)
{
SetHoldings(security.Symbol, 0.25m);
}
// reset our changes
_changes = SecurityChanges.None;
}
// this event fires whenever we have changes to our universe
public override void OnSecuritiesChanged(SecurityChanges changes)
{
_changes = changes;
}
public void CountUniv()
{
string[] rpt = {"Count: " ,Securities.Count.ToString(), " ",
"Time: ", Time.ToString(), " ",
"Value: ", Portfolio.TotalPortfolioValue.ToString(), " "
};
Debug(String.Join(" ",rpt));
}
}
}