first commit
This commit is contained in:
88
MultiMa.py
Normal file
88
MultiMa.py
Normal file
@@ -0,0 +1,88 @@
|
||||
# MultiMa Strategy
|
||||
# Author: @Mablue (Masoud Azizi)
|
||||
# github: https://github.com/mablue/
|
||||
# (First Hyperopt it.A hyperopt file is available)
|
||||
#
|
||||
# --- Do not remove these libs ---
|
||||
from freqtrade.strategy.parameters import IntParameter
|
||||
from freqtrade.strategy.interface import IStrategy
|
||||
from pandas import DataFrame
|
||||
|
||||
# --------------------------------
|
||||
|
||||
# Add your lib to import here
|
||||
import ta
|
||||
import freqtrade.vendor.qtpylib.indicators as qtpylib
|
||||
from functools import reduce
|
||||
|
||||
|
||||
class MultiMa(IStrategy):
|
||||
|
||||
buy_ma_count = IntParameter(0, 10, default=10, space="buy")
|
||||
buy_ma_gap = IntParameter(2, 10, default=2, space="buy")
|
||||
buy_ma_shift = IntParameter(0, 10, default=0, space="buy")
|
||||
# buy_ma_rolling = IntParameter(0, 10, default=0, space='buy')
|
||||
|
||||
sell_ma_count = IntParameter(0, 10, default=10, space="sell")
|
||||
sell_ma_gap = IntParameter(2, 10, default=2, space="sell")
|
||||
sell_ma_shift = IntParameter(0, 10, default=0, space="sell")
|
||||
# sell_ma_rolling = IntParameter(0, 10, default=0, space='sell')
|
||||
|
||||
# ROI table:
|
||||
minimal_roi = {"0": 0.30873, "569": 0.16689, "3211": 0.06473, "7617": 0}
|
||||
|
||||
# Stoploss:
|
||||
stoploss = -0.1
|
||||
|
||||
# Buy hypers
|
||||
timeframe = "4h"
|
||||
|
||||
def populate_indicators(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
|
||||
|
||||
# We will dinamicly generate the indicators
|
||||
# cuz this method just run one time in hyperopts
|
||||
# if you have static timeframes you can move first loop of buy and sell trends populators inside this method
|
||||
|
||||
return dataframe
|
||||
|
||||
def populate_buy_trend(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
|
||||
|
||||
for i in self.buy_ma_count.range:
|
||||
dataframe[f"buy-ma-{i+1}"] = ta.SMA(
|
||||
dataframe, timeperiod=int((i + 1) * self.buy_ma_gap.value)
|
||||
)
|
||||
|
||||
conditions = []
|
||||
|
||||
for i in self.buy_ma_count.range:
|
||||
if i > 1:
|
||||
shift = self.buy_ma_shift.value
|
||||
for shift in self.buy_ma_shift.range:
|
||||
conditions.append(
|
||||
dataframe[f"buy-ma-{i}"].shift(shift)
|
||||
> dataframe[f"buy-ma-{i-1}"].shift(shift)
|
||||
)
|
||||
if conditions:
|
||||
dataframe.loc[reduce(lambda x, y: x & y, conditions), "buy"] = 1
|
||||
|
||||
return dataframe
|
||||
|
||||
def populate_sell_trend(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
|
||||
for i in self.sell_ma_count.range:
|
||||
dataframe[f"sell-ma-{i+1}"] = ta.SMA(
|
||||
dataframe, timeperiod=int((i + 1) * self.sell_ma_gap.value)
|
||||
)
|
||||
|
||||
conditions = []
|
||||
|
||||
for i in self.sell_ma_count.range:
|
||||
if i > 1:
|
||||
shift = self.sell_ma_shift.value
|
||||
for shift in self.sell_ma_shift.range:
|
||||
conditions.append(
|
||||
dataframe[f"sell-ma-{i}"].shift(shift)
|
||||
< dataframe[f"sell-ma-{i-1}"].shift(shift)
|
||||
)
|
||||
if conditions:
|
||||
dataframe.loc[reduce(lambda x, y: x & y, conditions), "sell"] = 1
|
||||
return dataframe
|
||||
Reference in New Issue
Block a user