stable/.env/bin/user_data/hyperopts/hyper_adausdt.py
crypto_rahino df3c607e57 first
2021-03-20 18:46:56 +02:00

389 lines
20 KiB
Python

# pragma pylint: disable=missing-docstring, invalid-name, pointless-string-statement
# --- Do not remove these libs ---
from functools import reduce
from typing import Any, Callable, Dict, List
import numpy as np # noqa
import pandas as pd # noqa
from pandas import DataFrame
from skopt.space import Categorical, Dimension, Integer, Real # noqa
from freqtrade.optimize.hyperopt_interface import IHyperOpt
# --------------------------------
# Add your lib to import here
import talib.abstract as ta # noqa
import freqtrade.vendor.qtpylib.indicators as qtpylib
class hyper_adausdt(IHyperOpt):
"""
This is a Hyperopt template to get you started.
More information in the documentation: https://www.freqtrade.io/en/latest/hyperopt/
You should:
- Add any lib you need to build your hyperopt.
You must keep:
- The prototypes for the methods: populate_indicators, indicator_space, buy_strategy_generator.
The methods roi_space, generate_roi_table and stoploss_space are not required
and are provided by default.
However, you may override them if you need 'roi' and 'stoploss' spaces that
differ from the defaults offered by Freqtrade.
Sample implementation of these methods will be copied to `user_data/hyperopts` when
creating the user-data directory using `freqtrade create-userdir --userdir user_data`,
or is available online under the following URL:
https://github.com/freqtrade/freqtrade/blob/develop/freqtrade/templates/sample_hyperopt_advanced.py.
"""
@staticmethod
def buy_strategy_generator(params: Dict[str, Any]) -> Callable:
"""
Define the buy strategy parameters to be used by Hyperopt.
"""
def populate_buy_trend(dataframe: DataFrame, metadata: dict) -> DataFrame:
"""
Buy strategy Hyperopt will build and use.
"""
conditions = []
# GUARDS AND TRENDS
if params.get('tsf_long-enabled'):
conditions.append((dataframe['close'] - dataframe['tsf_long']) < params['tsf_long-value'])
if params.get('tsf_mid-enabled'):
conditions.append((dataframe['close'] - dataframe['tsf_mid']) < params['tsf_mid-value'])
if params.get('tsf_short-enabled'):
conditions.append((dataframe['close'] - dataframe['tsf_short']) < params['tsf_short-value'])
if params.get('angle_short-enabled'):
conditions.append(dataframe['angle_short'] > params['angle_short-value'])
if params.get('angle_mid-enabled'):
conditions.append(dataframe['angle_mid'] > params['angle_mid-value'])
if params.get('angle_long-enabled'):
conditions.append(dataframe['angle_long'] > params['angle_long-value'])
if params.get('correl_h_l-enabled'):
conditions.append(params['correl_h_l-value'] < dataframe['correl_h_l'])
if params.get('correl_close_last_close-enabled'):
conditions.append(params['correl_close_last_close-value'] < dataframe['correl_close_last_close'])
if params.get('correl_tsf_long_close-enabled'):
conditions.append(params['correl_tsf_long_close-value'] < dataframe['correl_tsf_long_close'])
if params.get('correl_tsf_mid_close-enabled'):
conditions.append(params['correl_tsf_mid_close-value'] < dataframe['correl_tsf_mid_close'])
if params.get('correl_tsf_short_close-enabled'):
conditions.append(params['correl_tsf_short_close-value'] < dataframe['correl_tsf_short_close'])
if params.get('correl_angle_short_close-enabled'):
conditions.append(params['correl_angle_short_close-value'] < dataframe['correl_angle_short_close'])
if params.get('correl_angle_mid_close-enabled'):
conditions.append(params['correl_angle_mid_close-value'] < dataframe['correl_angle_mid_close'])
if params.get('correl_angle_long_close-enabled'):
conditions.append(params['correl_angle_long_close-value'] < dataframe['correl_angle_long_close'])
if params.get('correl_hist_close-enabled'):
conditions.append(params['correl_hist_close-value'] < dataframe['correl_hist_close'])
if params.get('correl_mfi_close-enabled'):
conditions.append(params['correl_mfi_close-value'] < dataframe['correl_mfi_close'])
if params.get('mfi-enabled'):
conditions.append(params['mfi-value'] < dataframe['mfi'])
if params.get('ema-enabled'):
conditions.append(params['ema-value'] < (dataframe['close'] - dataframe['ema']))
if params.get('ema_bol-enabled'):
conditions.append(params['ema_bol-value'] < (dataframe['ema'] - dataframe['middleband']))
if params.get('macd-enabled'):
conditions.append(params['macdhist-value'] < dataframe['macdhist'])
# TRIGGERS
if 'trigger' in params:
if params['trigger'] == 'macd_cross_signal':
conditions.append(qtpylib.crossed_above(
dataframe['macd'], dataframe['macdsignal']
))
if params['trigger'] == 'bol_low':
conditions.append(qtpylib.crossed_above(
dataframe['close'], dataframe['lowerband']
))
if params['trigger'] == 'bol_mid':
conditions.append(qtpylib.crossed_above(
dataframe['close'], dataframe['middleband']
))
if params['trigger'] == 'mfi':
conditions.append(qtpylib.crossed_above(
dataframe['mfi'], 25))
if params['trigger'] == 'sar':
conditions.append(qtpylib.crossed_below(
dataframe['sar'], dataframe['close']))
if conditions:
dataframe.loc[
reduce(lambda x, y: x & y, conditions),
'buy'] = 1
return dataframe
return populate_buy_trend
@staticmethod
def indicator_space() -> List[Dimension]:
"""
Define your Hyperopt space for searching buy strategy parameters.
"""
return [
Real(0.019, 0.7, name='tsf_long-value'),
Real(0.019, 0.7, name='tsf_mid-value'),
Real(0.17, 0.7, name='tsf_short-value'),
Real(-0.26, 0.23, name='angle_short-value'),
Real(-0.018, 0.023, name='angle_long-value'),
Real(-0.026, 0.028, name='angle_mid-value'),
Real(0, 1, name='correl_h_l-value'),
Real(-1, 1, name='correl_close_last_close-value'),
Real(0, 1, name='correl_tsf_long_close-value'),
Real(-1, 1, name='correl_tsf_mid_close-value'),
Real(-1, 1, name='correl_tsf_short_close-value'),
Real(-1, 1, name='correl_angle_short_close-value'),
Real(0, 1, name='correl_angle_mid_close-value'),
Real(0, 1, name='correl_angle_long_close-value'),
Real(-1, 1, name='correl_hist_close-value'),
Real(-1, 1, name='correl_mfi_close-value'),
Integer(10, 60, name='mfi-value'),
Real(0.18, 0.7, name='ema-value'),
Real(-0.018, 0.015, name='ema_bol-value'),
Real(-0.0042, 0.003, name='macdhist-value'),
Categorical([True, False], name='angle_short-enabled'),
Categorical([True, False], name='angle_long-enabled'),
Categorical([True, False], name='angle_mid-enabled'),
Categorical([True, False], name='tsf_long-enabled'),
Categorical([True, False], name='tsf_mid-enabled'),
Categorical([True, False], name='tsf_short-enabled'),
Categorical([True, False], name='correl_h_l-enabled'),
Categorical([True, False], name='correl_close_last_close-enabled'),
Categorical([True, False], name='correl_tsf_long_close-enabled'),
Categorical([True, False], name='correl_tsf_short_close-enabled'),
Categorical([True, False], name='correl_tsf_mid_close-enabled'),
Categorical([True, False], name='correl_angle_short_close-enabled'),
Categorical([True, False], name='correl_angle_mid_close-enabled'),
Categorical([True, False], name='correl_angle_long_close-enabled'),
Categorical([True, False], name='correl_mfi_close-enabled'),
Categorical([True, False], name='correl_hist_close-enabled'),
Categorical([True, False], name='mfi-enabled'),
Categorical([True, False], name='macd-enabled'),
Categorical([True, False], name='ema-enabled'),
Categorical([True, False], name='ema_bol-enabled'),
Categorical(['sar', 'mfi', 'macd_cross_signal', 'bol_low', 'bol_mid'], name='trigger')
]
@staticmethod
def sell_strategy_generator(params: Dict[str, Any]) -> Callable:
"""
Define the sell strategy parameters to be used by Hyperopt.
"""
def populate_sell_trend(dataframe: DataFrame, metadata: dict) -> DataFrame:
"""
Sell strategy Hyperopt will build and use.
"""
conditions = []
# GUARDS AND TRENDS
if params.get('tsf_long-enabled'):
conditions.append((dataframe['tsf_long'] - dataframe['close']) > params['tsf_long-value_sell'])
if params.get('tsf_mid-enabled'):
conditions.append((dataframe['tsf_mid'] - dataframe['close']) > params['tsf_mid-value_sell'])
if params.get('tsf_short-enabled'):
conditions.append((dataframe['tsf_short'] - dataframe['close']) > params['tsf_short-value_sell'])
if params.get('angle_short-enabled'):
conditions.append(dataframe['angle_short'] > params['angle_short-value_sell'])
if params.get('angle_mid-enabled'):
conditions.append(dataframe['angle_mid'] > params['angle_mid-value_sell'])
if params.get('angle_long-enabled'):
conditions.append(dataframe['angle_long'] > params['angle_long-value_sell'])
if params.get('correl_h_l-enabled'):
conditions.append(params['correl_h_l-value_sell'] < dataframe['correl_h_l'])
if params.get('correl_close_last_close-enabled'):
conditions.append(params['correl_close_last_close-value_sell'] < dataframe['correl_close_last_close'])
if params.get('correl_tsf_long_close-enabled'):
conditions.append(params['correl_tsf_long_close-value_sell'] < dataframe['correl_tsf_long_close'])
if params.get('correl_tsf_mid_close-enabled'):
conditions.append(params['correl_tsf_mid_close-value_sell'] < dataframe['correl_tsf_mid_close'])
if params.get('correl_tsf_short_close-enabled'):
conditions.append(params['correl_tsf_short_close-value_sell'] < dataframe['correl_tsf_short_close'])
if params.get('correl_angle_short_close-enabled'):
conditions.append(params['correl_angle_short_close-value_sell'] < dataframe['correl_angle_short_close'])
if params.get('correl_angle_mid_close-enabled'):
conditions.append(params['correl_angle_mid_close-value_sell'] < dataframe['correl_angle_mid_close'])
if params.get('correl_angle_long_close-enabled'):
conditions.append(params['correl_angle_long_close-value_sell'] < dataframe['correl_angle_long_close'])
if params.get('correl_hist_close-enabled'):
conditions.append(params['correl_hist_close-value_sell'] < dataframe['correl_hist_close'])
if params.get('correl_mfi_close-enabled'):
conditions.append(params['correl_mfi_close-value_sell'] < dataframe['correl_mfi_close'])
if params.get('mfi-enabled'):
conditions.append(params['mfi-value_sell'] > dataframe['mfi'])
if params.get('ema-enabled'):
conditions.append(params['ema-value_sell'] < (dataframe['ema'] - dataframe['close']))
if params.get('sar-enabled'):
conditions.append(params['sar-value_sell'] < (dataframe['close'] - dataframe['sar']))
if params.get('ema_bol-enabled'):
conditions.append(params['ema_bol-value_sell'] < (dataframe['middleband'] - dataframe['ema']))
if params.get('macd-enabled'):
conditions.append(params['macdhist-value_sell'] > dataframe['macdhist'])
# TRIGGERS
if 'trigger' in params:
if params['trigger'] == 'macd_cross_signal':
conditions.append(qtpylib.crossed_below(
dataframe['macd'], dataframe['macdsignal']
))
if params['trigger'] == 'bol_high':
conditions.append(qtpylib.crossed_below(
dataframe['close'], dataframe['upperband']
))
if params['trigger'] == 'bol_mid':
conditions.append(qtpylib.crossed_below(
dataframe['close'], dataframe['middleband']
))
if params['trigger'] == 'sar':
conditions.append(qtpylib.crossed_above(
dataframe['sar'], dataframe['close']))
if conditions:
dataframe.loc[
reduce(lambda x, y: x & y, conditions),
'sell'] = 1
return dataframe
return populate_sell_trend
@staticmethod
def sell_indicator_space() -> List[Dimension]:
"""
Define your Hyperopt space for searching sell strategy parameters.
"""
return [
Real(0.019, 0.7, name='tsf_long-value_sell'),
Real(0.019, 0.7, name='tsf_mid-value_sell'),
Real(0.17, 0.7, name='tsf_short-value_sell'),
Real(-0.26, 0.23, name='angle_short-value_sell'),
Real(-0.018, 0.023, name='angle_long-value_sell'),
Real(-0.026, 0.028, name='angle_mid-value_sell'),
Real(0, 1, name='correl_h_l-value_sell'),
Real(-1, 1, name='correl_close_last_close-value_sell'),
Real(0, 1, name='correl_tsf_long_close-value_sell'),
Real(-1, 1, name='correl_tsf_mid_close-value_sell'),
Real(-1, 1, name='correl_tsf_short_close-value_sell'),
Real(-1, 1, name='correl_angle_short_close-value_sell'),
Real(0, 1, name='correl_angle_mid_close-value_sell'),
Real(0, 1, name='correl_angle_long_close-value_sell'),
Real(-1, 1, name='correl_hist_close-value_sell'),
Real(-1, 1, name='correl_mfi_close-value_sell'),
Real(10, 60, name='mfi-value_sell'),
Real(0.018, 0.7, name='ema-value_sell'),
Real(0.017, 0.7, name='sar-value_sell'),
Real(-0.018, 0.015, name='ema_bol-value_sell'),
Real(-0.0042, 0.003, name='macdhist-value_sell'),
Categorical([True, False], name='angle_short-enabled'),
Categorical([True, False], name='angle_long-enabled'),
Categorical([True, False], name='angle_mid-enabled'),
Categorical([True, False], name='tsf_long-enabled'),
Categorical([True, False], name='tsf_mid-enabled'),
Categorical([True, False], name='tsf_short-enabled'),
Categorical([True, False], name='correl_h_l-enabled'),
Categorical([True, False], name='correl_close_last_close-enabled'),
Categorical([True, False], name='correl_tsf_long_close-enabled'),
Categorical([True, False], name='correl_tsf_short_close-enabled'),
Categorical([True, False], name='correl_tsf_mid_close-enabled'),
Categorical([True, False], name='correl_angle_short_close-enabled'),
Categorical([True, False], name='correl_angle_mid_close-enabled'),
Categorical([True, False], name='correl_angle_long_close-enabled'),
Categorical([True, False], name='correl_mfi_close-enabled'),
Categorical([True, False], name='correl_hist_close-enabled'),
Categorical([True, False], name='mfi-enabled'),
Categorical([True, False], name='macd-enabled'),
Categorical([True, False], name='ema-enabled'),
Categorical([True, False], name='sar-enabled'),
Categorical([True, False], name='ema_bol-enabled'),
Categorical(['sar', 'macd_cross_signal', 'bol_low', 'bol_mid'], name='trigger')
]
@staticmethod
def generate_roi_table(params: Dict) -> Dict[int, float]:
"""
Generate the ROI table that will be used by Hyperopt
This implementation generates the default legacy Freqtrade ROI tables.
Change it if you need different number of steps in the generated
ROI tables or other structure of the ROI tables.
Please keep it aligned with parameters in the 'roi' optimization
hyperspace defined by the roi_space method.
"""
roi_table = {}
roi_table[0] = params['roi_p1'] + params['roi_p2'] + params['roi_p3']
roi_table[params['roi_t3']] = params['roi_p1'] + params['roi_p2']
roi_table[params['roi_t3'] + params['roi_t2']] = params['roi_p1']
roi_table[params['roi_t3'] + params['roi_t2'] + params['roi_t1']] = 0
return roi_table
@staticmethod
def roi_space() -> List[Dimension]:
"""
Values to search for each ROI steps
Override it if you need some different ranges for the parameters in the
'roi' optimization hyperspace.
Please keep it aligned with the implementation of the
generate_roi_table method.
"""
return [
Integer(10, 120, name='roi_t1'),
Integer(10, 60, name='roi_t2'),
Integer(10, 40, name='roi_t3'),
Real(0.01, 0.04, name='roi_p1'),
Real(0.01, 0.07, name='roi_p2'),
Real(0.01, 0.20, name='roi_p3'),
]
@staticmethod
def stoploss_space() -> List[Dimension]:
"""
Stoploss Value to search
Override it if you need some different range for the parameter in the
'stoploss' optimization hyperspace.
"""
return [
Real(-0.25, -0.02, name='stoploss'),
]
@staticmethod
def trailing_space() -> List[Dimension]:
"""
Create a trailing stoploss space.
You may override it in your custom Hyperopt class.
"""
return [
# It was decided to always set trailing_stop is to True if the 'trailing' hyperspace
# is used. Otherwise hyperopt will vary other parameters that won't have effect if
# trailing_stop is set False.
# This parameter is included into the hyperspace dimensions rather than assigning
# it explicitly in the code in order to have it printed in the results along with
# other 'trailing' hyperspace parameters.
Categorical([True], name='trailing_stop'),
Real(0.01, 0.35, name='trailing_stop_positive'),
# 'trailing_stop_positive_offset' should be greater than 'trailing_stop_positive',
# so this intermediate parameter is used as the value of the difference between
# them. The value of the 'trailing_stop_positive_offset' is constructed in the
# generate_trailing_params() method.
# This is similar to the hyperspace dimensions used for constructing the ROI tables.
Real(0.001, 0.1, name='trailing_stop_positive_offset_p1'),
Categorical([True, False], name='trailing_only_offset_is_reached'),
]