Module backtrader.indicators.kama
Expand source code
#!/usr/bin/env python
# -*- coding: utf-8; py-indent-offset:4 -*-
###############################################################################
#
# Copyright (C) 2015-2023 Daniel Rodriguez
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
from __future__ import (absolute_import, division, print_function,
unicode_literals)
from . import (SumN, MovingAverageBase, ExponentialSmoothingDynamic)
class AdaptiveMovingAverage(MovingAverageBase):
'''
Defined by Perry Kaufman in his book `"Smarter Trading"`.
It is A Moving Average with a continuously scaled smoothing factor by
taking into account market direction and volatility. The smoothing factor
is calculated from 2 ExponetialMovingAverage smoothing factors, a fast one
and slow one.
If the market trends the value will tend to the fast ema smoothing
period. If the market doesn't trend it will move towards the slow EMA
smoothing period.
It is a subclass of SmoothingMovingAverage, overriding once to account for
the live nature of the smoothing factor
Formula:
- direction = close - close_period
- volatility = sumN(abs(close - close_n), period)
- effiency_ratio = abs(direction / volatility)
- fast = 2 / (fast_period + 1)
- slow = 2 / (slow_period + 1)
- smfactor = squared(efficienty_ratio * (fast - slow) + slow)
- smfactor1 = 1.0 - smfactor
- The initial seed value is a SimpleMovingAverage
See also:
- http://fxcodebase.com/wiki/index.php/Kaufman's_Adaptive_Moving_Average_(KAMA)
- http://www.metatrader5.com/en/terminal/help/analytics/indicators/trend_indicators/ama
- http://help.cqg.com/cqgic/default.htm#!Documents/adaptivemovingaverag2.htm
'''
alias = ('KAMA', 'MovingAverageAdaptive',)
lines = ('kama',)
params = (('fast', 2), ('slow', 30))
def __init__(self):
# Before super to ensure mixins (right-hand side in subclassing)
# can see the assignment operation and operate on the line
direction = self.data - self.data(-self.p.period)
volatility = SumN(abs(self.data - self.data(-1)), period=self.p.period)
er = abs(direction / volatility) # efficiency ratio
fast = 2.0 / (self.p.fast + 1.0) # fast ema smoothing factor
slow = 2.0 / (self.p.slow + 1.0) # slow ema smoothing factor
sc = pow((er * (fast - slow)) + slow, 2) # scalable constant
self.lines[0] = ExponentialSmoothingDynamic(self.data,
period=self.p.period,
alpha=sc)
super(AdaptiveMovingAverage, self).__init__()
Classes
class AdaptiveMovingAverage
-
Defined by Perry Kaufman in his book
"Smarter Trading"
.It is A Moving Average with a continuously scaled smoothing factor by taking into account market direction and volatility. The smoothing factor is calculated from 2 ExponetialMovingAverage smoothing factors, a fast one and slow one.
If the market trends the value will tend to the fast ema smoothing period. If the market doesn't trend it will move towards the slow EMA smoothing period.
It is a subclass of SmoothingMovingAverage, overriding once to account for the live nature of the smoothing factor
Formula
- direction = close - close_period
- volatility = sumN(abs(close - close_n), period)
- effiency_ratio = abs(direction / volatility)
- fast = 2 / (fast_period + 1)
-
slow = 2 / (slow_period + 1)
-
smfactor = squared(efficienty_ratio * (fast - slow) + slow)
-
smfactor1 = 1.0 - smfactor
-
The initial seed value is a SimpleMovingAverage
See also: - http://fxcodebase.com/wiki/index.php/Kaufman's_Adaptive_Moving_Average_(KAMA) - http://www.metatrader5.com/en/terminal/help/analytics/indicators/trend_indicators/ama - http://help.cqg.com/cqgic/default.htm#!Documents/adaptivemovingaverag2.htm
Expand source code
class AdaptiveMovingAverage(MovingAverageBase): ''' Defined by Perry Kaufman in his book `"Smarter Trading"`. It is A Moving Average with a continuously scaled smoothing factor by taking into account market direction and volatility. The smoothing factor is calculated from 2 ExponetialMovingAverage smoothing factors, a fast one and slow one. If the market trends the value will tend to the fast ema smoothing period. If the market doesn't trend it will move towards the slow EMA smoothing period. It is a subclass of SmoothingMovingAverage, overriding once to account for the live nature of the smoothing factor Formula: - direction = close - close_period - volatility = sumN(abs(close - close_n), period) - effiency_ratio = abs(direction / volatility) - fast = 2 / (fast_period + 1) - slow = 2 / (slow_period + 1) - smfactor = squared(efficienty_ratio * (fast - slow) + slow) - smfactor1 = 1.0 - smfactor - The initial seed value is a SimpleMovingAverage See also: - http://fxcodebase.com/wiki/index.php/Kaufman's_Adaptive_Moving_Average_(KAMA) - http://www.metatrader5.com/en/terminal/help/analytics/indicators/trend_indicators/ama - http://help.cqg.com/cqgic/default.htm#!Documents/adaptivemovingaverag2.htm ''' alias = ('KAMA', 'MovingAverageAdaptive',) lines = ('kama',) params = (('fast', 2), ('slow', 30)) def __init__(self): # Before super to ensure mixins (right-hand side in subclassing) # can see the assignment operation and operate on the line direction = self.data - self.data(-self.p.period) volatility = SumN(abs(self.data - self.data(-1)), period=self.p.period) er = abs(direction / volatility) # efficiency ratio fast = 2.0 / (self.p.fast + 1.0) # fast ema smoothing factor slow = 2.0 / (self.p.slow + 1.0) # slow ema smoothing factor sc = pow((er * (fast - slow)) + slow, 2) # scalable constant self.lines[0] = ExponentialSmoothingDynamic(self.data, period=self.p.period, alpha=sc) super(AdaptiveMovingAverage, self).__init__()
Ancestors
- MovingAverageBase
- Indicator
- IndicatorBase
- DataAccessor
- LineIterator
- LineSeries
- LineMultiple
- LineRoot
Subclasses
Class variables
var alias
var aliased
var frompackages
var linealias
var packages
var params
var plotinfo
var plotlines
Inherited members
class KAMA
-
Defined by Perry Kaufman in his book
"Smarter Trading"
.It is A Moving Average with a continuously scaled smoothing factor by taking into account market direction and volatility. The smoothing factor is calculated from 2 ExponetialMovingAverage smoothing factors, a fast one and slow one.
If the market trends the value will tend to the fast ema smoothing period. If the market doesn't trend it will move towards the slow EMA smoothing period.
It is a subclass of SmoothingMovingAverage, overriding once to account for the live nature of the smoothing factor
Formula
- direction = close - close_period
- volatility = sumN(abs(close - close_n), period)
- effiency_ratio = abs(direction / volatility)
- fast = 2 / (fast_period + 1)
-
slow = 2 / (slow_period + 1)
-
smfactor = squared(efficienty_ratio * (fast - slow) + slow)
-
smfactor1 = 1.0 - smfactor
-
The initial seed value is a SimpleMovingAverage
See also: - http://fxcodebase.com/wiki/index.php/Kaufman's_Adaptive_Moving_Average_(KAMA) - http://www.metatrader5.com/en/terminal/help/analytics/indicators/trend_indicators/ama - http://help.cqg.com/cqgic/default.htm#!Documents/adaptivemovingaverag2.htm
Ancestors
- AdaptiveMovingAverage
- MovingAverageBase
- Indicator
- IndicatorBase
- DataAccessor
- LineIterator
- LineSeries
- LineMultiple
- LineRoot
Class variables
var alias
var aliased
var frompackages
var linealias
var packages
var params
var plotinfo
var plotlines
Inherited members
class MovingAverageAdaptive
-
Defined by Perry Kaufman in his book
"Smarter Trading"
.It is A Moving Average with a continuously scaled smoothing factor by taking into account market direction and volatility. The smoothing factor is calculated from 2 ExponetialMovingAverage smoothing factors, a fast one and slow one.
If the market trends the value will tend to the fast ema smoothing period. If the market doesn't trend it will move towards the slow EMA smoothing period.
It is a subclass of SmoothingMovingAverage, overriding once to account for the live nature of the smoothing factor
Formula
- direction = close - close_period
- volatility = sumN(abs(close - close_n), period)
- effiency_ratio = abs(direction / volatility)
- fast = 2 / (fast_period + 1)
-
slow = 2 / (slow_period + 1)
-
smfactor = squared(efficienty_ratio * (fast - slow) + slow)
-
smfactor1 = 1.0 - smfactor
-
The initial seed value is a SimpleMovingAverage
See also: - http://fxcodebase.com/wiki/index.php/Kaufman's_Adaptive_Moving_Average_(KAMA) - http://www.metatrader5.com/en/terminal/help/analytics/indicators/trend_indicators/ama - http://help.cqg.com/cqgic/default.htm#!Documents/adaptivemovingaverag2.htm
Ancestors
- AdaptiveMovingAverage
- MovingAverageBase
- Indicator
- IndicatorBase
- DataAccessor
- LineIterator
- LineSeries
- LineMultiple
- LineRoot
Class variables
var alias
var aliased
var frompackages
var linealias
var packages
var params
var plotinfo
var plotlines
Inherited members