Timeframe
1h
Direction
Long Only
Stoploss
-25.0%
Trailing Stop
No
ROI
0m: 10.0%, 720m: 7.5%, 1440m: 5.0%, 2160m: 2.5%
Interface Version
N/A
Startup Candles
N/A
Indicators
2
freqtrade/freqtrade-strategies
this is an example class, implementing a PSAR based trailing stop loss you are supposed to take the `custom_stoploss()` and `populate_indicators()` parts and adapt it to your own strategy
freqtrade/freqtrade-strategies
freqtrade/freqtrade-strategies
Strategy 003 author@: Gerald Lonlas github@: https://github.com/freqtrade/freqtrade-strategies
# --- Do not remove these libs ---
from freqtrade.strategy import IStrategy
from pandas import DataFrame
from freqtrade.persistence import Trade
from datetime import datetime, timedelta
import talib.abstract as ta
import freqtrade.vendor.qtpylib.indicators as qtpylib
# --------------------------------
class AdxSmasS_v7(IStrategy):
INTERFACE_VERSION: int = 3
# Can this strategy go short?
can_short: bool = True
# Minimal ROI designed for the strategy.
# adjust based on market conditions. We would recommend to keep it low for quick turn arounds
# This attribute will be overridden if the config file contains "minimal_roi"
minimal_roi = {
"2160": 0.025,
"1440": 0.05,
"720": 0.075,
"0": 0.1
}
# Optimal stoploss designed for the strategy
stoploss = -0.25
# Optimal timeframe for the strategy
timeframe = '1h'
use_custom_stoploss = True
@property
def protections(self):
return [
{
"method": "CooldownPeriod",
"stop_duration_candles": 3
},
{
"method": "MaxDrawdown",
"lookback_period_candles": 12,
"trade_limit": 20,
"stop_duration_candles": 3,
"max_allowed_drawdown": 0.075
},
{
"method": "LowProfitPairs",
"lookback_period_candles": 6,
"trade_limit": 2,
"stop_duration_candles": 60,
"required_profit": 0.03
},
{
"method": "LowProfitPairs",
"lookback_period_candles": 24,
"trade_limit": 4,
"stop_duration_candles": 2,
"required_profit": 0.01
}
]
def custom_stoploss(self, pair: str, trade: 'Trade', current_time: datetime,
current_rate: float, current_profit: float, **kwargs) -> float:
# use the initial stoploss until the profit is above 3%
if current_profit < 0.03:
return -1 # return a value bigger than the initial stoploss to keep using the initial stoploss
# After reaching the desired offset, allow the stoploss to trail by half the profit
desired_stoploss = current_profit / 2
# Use a minimum of 2% and a maximum of 7.5%
return max(min(desired_stoploss, 0.075), 0.02)
#if current_profit < 0.001 and current_time - timedelta(minutes=140) > trade.open_date_utc:
# return -0.005
#return 1
def populate_indicators(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
dataframe['adx'] = ta.ADX(dataframe, timeperiod=14)
dataframe['short'] = ta.SMA(dataframe, timeperiod=3)
dataframe['long'] = ta.SMA(dataframe, timeperiod=6)
return dataframe
def populate_entry_trend(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
dataframe.loc[(), ['enter_long', 'enter_tag']] = (0, 'no_long_enter')
dataframe.loc[
(
(dataframe['adx'] < 25) &
(qtpylib.crossed_above(dataframe['long'], dataframe['short']))
),
'enter_short'] = 1
return dataframe
def populate_exit_trend(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
dataframe.loc[(), ['exit_long', 'exit_tag']] = (0, 'no_long_exit')
dataframe.loc[
(
(dataframe['adx'] > 25) &
(qtpylib.crossed_above(dataframe['short'], dataframe['long']))
),
'exit_short'] = 1
return dataframe