Lean
$LEAN_TAG$
RateOfChange.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
namespace
QuantConnect.Indicators
17
{
18
/// <summary>
19
/// This indicator computes the n-period rate of change in a value using the following:
20
/// (value_0 - value_n) / value_n
21
/// </summary>
22
public
class
RateOfChange
:
WindowIndicator
<IndicatorDataPoint>,
IIndicatorWarmUpPeriodProvider
23
{
24
/// <summary>
25
/// Gets a flag indicating when this indicator is ready and fully initialized.
26
/// </summary>
27
public
override
bool
IsReady
=> Samples >
Period
;
28
29
/// <summary>
30
/// Required period, in data points, for the indicator to be ready and fully initialized.
31
/// Our formula is Period + 1 because we need to fill the window and have one removed before
32
/// it is ready.
33
/// </summary>
34
public
int
WarmUpPeriod
=>
Period
+ 1;
35
36
/// <summary>
37
/// Creates a new RateOfChange indicator with the specified period
38
/// </summary>
39
/// <param name="period">The period over which to perform to computation</param>
40
public
RateOfChange
(
int
period)
41
: base($
"ROC({period})"
, period)
42
{
43
}
44
45
/// <summary>
46
/// Creates a new RateOfChange indicator with the specified period
47
/// </summary>
48
/// <param name="name">The name of this indicator</param>
49
/// <param name="period">The period over which to perform to computation</param>
50
public
RateOfChange
(
string
name,
int
period)
51
: base(name, period)
52
{
53
}
54
55
/// <summary>
56
/// Computes the next value for this indicator from the given state.
57
/// </summary>
58
/// <param name="window">The window of data held in this indicator</param>
59
/// <param name="input">The input value to this indicator on this time step</param>
60
/// <returns>A new value for this indicator</returns>
61
protected
override
decimal
ComputeNextValue
(
IReadOnlyWindow<IndicatorDataPoint>
window,
IndicatorDataPoint
input)
62
{
63
// if we're not ready just grab the first input point in the window
64
var denominator = window.
Samples
<= window.
Size
? window[window.
Count
- 1] : window.
MostRecentlyRemoved
;
65
66
if
(denominator.Value == 0)
67
{
68
return
0;
69
}
70
71
return
(input.
Value
- denominator.Value) / denominator.Value;
72
}
73
}
74
}
Indicators
RateOfChange.cs
Generated by
1.8.17