Lean
$LEAN_TAG$
BacktestingFutureChainProvider.cs
1
/*
2
* QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
3
* Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
4
*
5
* Licensed under the Apache License, Version 2.0 (the "License");
6
* you may not use this file except in compliance with the License.
7
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
8
*
9
* Unless required by applicable law or agreed to in writing, software
10
* distributed under the License is distributed on an "AS IS" BASIS,
11
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
* See the License for the specific language governing permissions and
13
* limitations under the License.
14
*/
15
16
using
System;
17
using
QuantConnect
.
Interfaces
;
18
using
System.Collections.Generic;
19
20
namespace
QuantConnect.Lean.Engine.DataFeeds
21
{
22
/// <summary>
23
/// An implementation of <see cref="IFutureChainProvider"/> that reads the list of contracts from open interest zip data files
24
/// </summary>
25
public
class
BacktestingFutureChainProvider
:
BacktestingChainProvider
,
IFutureChainProvider
26
{
27
/// <summary>
28
/// Creates a new instance
29
/// </summary>
30
/// <param name="dataCacheProvider">The data cache provider instance to use</param>
31
public
BacktestingFutureChainProvider
(
IDataCacheProvider
dataCacheProvider)
32
: base(dataCacheProvider)
33
{
34
}
35
36
/// <summary>
37
/// Gets the list of future contracts for a given underlying symbol
38
/// </summary>
39
/// <param name="symbol">The underlying symbol</param>
40
/// <param name="date">The date for which to request the future chain (only used in backtesting)</param>
41
/// <returns>The list of future contracts</returns>
42
public
virtual
IEnumerable<Symbol>
GetFutureContractList
(
Symbol
symbol, DateTime date)
43
{
44
return
GetSymbols
(
GetSymbol
(symbol), date);
45
}
46
47
/// <summary>
48
/// Helper method to get the symbol to use
49
/// </summary>
50
protected
static
Symbol
GetSymbol
(
Symbol
symbol)
51
{
52
if
(symbol.
SecurityType
!=
SecurityType
.Future)
53
{
54
if
(symbol.
SecurityType
==
SecurityType
.FutureOption && symbol.
Underlying
!=
null
)
55
{
56
// be user friendly and take the underlying
57
symbol = symbol.
Underlying
;
58
}
59
else
60
{
61
throw
new
NotSupportedException($
"BacktestingFutureChainProvider.GetFutureContractList():"
+
62
$
" {nameof(SecurityType.Future)} or {nameof(SecurityType.FutureOption)} is expected but was {symbol.SecurityType}"
);
63
}
64
}
65
66
return
symbol.
Canonical
;
67
}
68
}
69
}
Engine
DataFeeds
BacktestingFutureChainProvider.cs
Generated by
1.8.17