# 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.
from AlgorithmImports import *
###
### Regrssion algorithm to assert we can update indicators that inherit from IndicatorBase with RenkoBar's
###
###
###
###
###
class IndicatorWithRenkoBarsRegressionAlgorithm(QCAlgorithm):
def initialize(self) -> None:
self.set_start_date(2013, 10, 7)
self.set_end_date(2013, 10, 9)
self.add_equity("SPY")
self.add_equity("AIG")
spy_renko_consolidator = RenkoConsolidator(0.1)
spy_renko_consolidator.data_consolidated += self.on_spy_data_consolidated
aig_renko_consolidator = RenkoConsolidator(0.05)
aig_renko_consolidator.data_consolidated += self.on_aig_data_consolidated
self.subscription_manager.add_consolidator("SPY", spy_renko_consolidator)
self.subscription_manager.add_consolidator("AIG", aig_renko_consolidator)
self._mi = MassIndex("MassIndex", 9, 25)
self._wasi = WilderAccumulativeSwingIndex("WilderAccumulativeSwingIndex", 8)
self._wsi = WilderSwingIndex("WilderSwingIndex", 8)
self._b = Beta("Beta", 3, "AIG", "SPY")
self._indicators = [self._mi, self._wasi, self._wsi, self._b]
def on_spy_data_consolidated(self, sender: object, renko_bar: RenkoBar) -> None:
self._mi.update(renko_bar)
self._wasi.update(renko_bar)
self._wsi.update(renko_bar)
self._b.update(renko_bar)
def on_aig_data_consolidated(self, sender: object, renko_bar: RenkoBar) -> None:
self._b.update(renko_bar)
def on_end_of_algorithm(self) -> None:
for indicator in self._indicators:
if not indicator.is_ready:
raise AssertionError(f"{indicator.name} indicator should be ready")
elif indicator.current.value == 0:
raise AssertionError(f"The current value of the {indicator.name} indicator should be different than zero")