forked from QuantConnect/Lean
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAlgorithmConfiguration.cs
137 lines (124 loc) · 5.48 KB
/
AlgorithmConfiguration.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
/*
* 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 Newtonsoft.Json;
using QuantConnect.Util;
using QuantConnect.Packets;
using QuantConnect.Interfaces;
using QuantConnect.Brokerages;
using System.Collections.Generic;
namespace QuantConnect
{
/// <summary>
/// This class includes algorithm configuration settings and parameters.
/// This is used to include configuration parameters in the result packet to be used for report generation.
/// </summary>
public class AlgorithmConfiguration
{
/// <summary>
/// The algorithm's account currency
/// </summary>
[JsonProperty(PropertyName = "AccountCurrency", NullValueHandling = NullValueHandling.Ignore)]
public string AccountCurrency;
/// <summary>
/// The algorithm's brokerage model
/// </summary>
/// <remarks> Required to set the correct brokerage model on report generation.</remarks>
[JsonProperty(PropertyName = "Brokerage")]
public BrokerageName BrokerageName;
/// <summary>
/// The algorithm's account type
/// </summary>
/// <remarks> Required to set the correct brokerage model on report generation.</remarks>
[JsonProperty(PropertyName = "AccountType")]
public AccountType AccountType;
/// <summary>
/// The parameters used by the algorithm
/// </summary>
[JsonProperty(PropertyName = "Parameters")]
public IReadOnlyDictionary<string, string> Parameters;
/// <summary>
/// Backtest maximum end date
/// </summary>
[JsonProperty(PropertyName = "OutOfSampleMaxEndDate")]
public DateTime? OutOfSampleMaxEndDate;
/// <summary>
/// The backtest out of sample day count
/// </summary>
[JsonProperty(PropertyName = "OutOfSampleDays")]
public int OutOfSampleDays;
/// <summary>
/// The backtest start date
/// </summary>
[JsonProperty(PropertyName = "StartDate")]
[JsonConverter(typeof(DateTimeJsonConverter), DateFormat.UI)]
public DateTime StartDate;
/// <summary>
/// The backtest end date
/// </summary>
[JsonProperty(PropertyName = "EndDate")]
[JsonConverter(typeof(DateTimeJsonConverter), DateFormat.UI)]
public DateTime EndDate;
/// <summary>
/// Number of trading days per year for Algorithm's portfolio statistics.
/// </summary>
[JsonProperty(PropertyName = "TradingDaysPerYear")]
public int TradingDaysPerYear;
/// <summary>
/// Initializes a new instance of the <see cref="AlgorithmConfiguration"/> class
/// </summary>
public AlgorithmConfiguration(string accountCurrency, BrokerageName brokerageName, AccountType accountType, IReadOnlyDictionary<string, string> parameters,
DateTime startDate, DateTime endDate, DateTime? outOfSampleMaxEndDate, int outOfSampleDays = 0, int tradingDaysPerYear = 0)
{
OutOfSampleMaxEndDate = outOfSampleMaxEndDate;
TradingDaysPerYear = tradingDaysPerYear;
OutOfSampleDays = outOfSampleDays;
AccountCurrency = accountCurrency;
BrokerageName = brokerageName;
AccountType = accountType;
Parameters = parameters;
StartDate = startDate;
EndDate = endDate;
}
/// <summary>
/// Initializes a new empty instance of the <see cref="AlgorithmConfiguration"/> class
/// </summary>
public AlgorithmConfiguration()
{
// use default value for backwards compatibility
TradingDaysPerYear = 252;
}
/// <summary>
/// Provides a convenience method for creating a <see cref="AlgorithmConfiguration"/> for a given algorithm.
/// </summary>
/// <param name="algorithm">Algorithm for which the configuration object is being created</param>
/// <param name="backtestNodePacket">The associated backtest node packet if any</param>
/// <returns>A new AlgorithmConfiguration object for the specified algorithm</returns>
public static AlgorithmConfiguration Create(IAlgorithm algorithm, BacktestNodePacket backtestNodePacket)
{
return new AlgorithmConfiguration(
algorithm.AccountCurrency,
BrokerageModel.GetBrokerageName(algorithm.BrokerageModel),
algorithm.BrokerageModel.AccountType,
algorithm.GetParameters(),
algorithm.StartDate,
algorithm.EndDate,
backtestNodePacket?.OutOfSampleMaxEndDate,
backtestNodePacket?.OutOfSampleDays ?? 0,
// use value = 252 like default for backwards compatibility
algorithm?.Settings?.TradingDaysPerYear ?? 252);
}
}
}