| 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 |
namespace QuantConnect
{
public partial class BootCampTask : QCAlgorithm
{
private struct _tradeInfo
{
public decimal stopLimit;
public bool isShort;
public TradeBar tradeBar;
}
private Dictionary<string, TradeBar> MyStocks = new Dictionary<string, TradeBar>();
private string[] _stocks = new string[] { "TSLA", "AMD", "BAC", "SYMC", "HP" };
public override void Initialize()
{
SetStartDate(2017, 1, 1);
SetEndDate(2019, 8, 1);
SetCash(10000);
AddEquity("SPY", Resolution.Minute);
for(int i = 0; i < _stocks.Length; i++)
{
AddEquity(_stocks[i], Resolution.Minute);
MyStocks.Add(_stocks[i], null);
Consolidate(_stocks[i], TimeSpan.FromMinutes(30), OnDataConsolidation);
}
Schedule.On(DateRules.EveryDay(), TimeRules.At(13,30), CloseAllPositions);
}
private void OnDataConsolidation(TradeBar bar)
{
if(bar.Time.Hour == 9 && bar.Time.Minute == 30)
{
MyStocks[bar.Symbol] = bar;
}
}
private void CloseAllPositions()
{
for(int i = 0; i < _stocks.Length; i++)
{
Liquidate(_stocks[i]);
MyStocks[_stocks[i]] = null;
}
}
private void ClosePosition(string symbol)
{
Liquidate(symbol);
MyStocks[symbol] = null;
}
public override void OnData(Slice data)
{
for(int i = 0; i < _stocks.Length; i++)
{
if(!Portfolio[_stocks[i]].Invested && MyStocks[_stocks[i]] != null)
{
if(data[_stocks[i]].Close > MyStocks[_stocks[i]].High)
{
SetHoldings(_stocks[i], 1/_stocks.Length);
}
if(data[_stocks[i]].Close < MyStocks[_stocks[i]].Low)
{
SetHoldings(_stocks[i], -1/_stocks.Length);
}
}
}
}
}
}/*
* QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
* Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
using System;
using System.Collections.Generic;
using QuantConnect.Algorithm.Framework.Portfolio;
namespace QuantConnect.Algorithm.Framework.Risk
{
/// <summary>
/// Provides an implementation of <see cref="IRiskManagementModel"/> that limits the drawdown
/// per holding to the specified percentage
/// </summary>
public class MaximumDrawdownPercentPerSecurity : RiskManagementModel
{
private readonly decimal _maximumDrawdownPercent;
/// <summary>
/// Initializes a new instance of the <see cref="MaximumDrawdownPercentPerSecurity"/> class
/// </summary>
/// <param name="maximumDrawdownPercent">The maximum percentage drawdown allowed for any single security holding,
/// defaults to 5% drawdown per security</param>
public MaximumDrawdownPercentPerSecurity(
decimal maximumDrawdownPercent = 0.04m
)
{
_maximumDrawdownPercent = -Math.Abs(maximumDrawdownPercent);
}
/// <summary>
/// Manages the algorithm's risk at each time step
/// </summary>
/// <param name="algorithm">The algorithm instance</param>
/// <param name="targets">The current portfolio targets to be assessed for risk</param>
public override IEnumerable<IPortfolioTarget> ManageRisk(QCAlgorithm algorithm, IPortfolioTarget[] targets)
{
foreach (var kvp in algorithm.Securities)
{
var security = kvp.Value;
if (!security.Invested)
{
continue;
}
var pnl = security.Holdings.UnrealizedProfitPercent;
if (pnl < _maximumDrawdownPercent)
{
// liquidate
yield return new PortfolioTarget(security.Symbol, 0);
}
}
}
}
}