stable/freqtrade/plugins/pairlist/ShuffleFilter.py

60 lines
2.0 KiB
Python
Raw Normal View History

2020-05-17 23:36:40 +00:00
"""
Shuffle pair list filter
"""
import logging
import random
2020-05-20 10:27:07 +00:00
from typing import Any, Dict, List
2020-05-17 23:36:40 +00:00
2021-11-27 18:41:36 +00:00
from freqtrade.enums.runmode import RunMode
from freqtrade.plugins.pairlist.IPairList import IPairList
2020-05-17 23:36:40 +00:00
logger = logging.getLogger(__name__)
class ShuffleFilter(IPairList):
2020-05-20 10:27:07 +00:00
def __init__(self, exchange, pairlistmanager,
config: Dict[str, Any], pairlistconfig: Dict[str, Any],
2020-05-17 23:36:40 +00:00
pairlist_pos: int) -> None:
super().__init__(exchange, pairlistmanager, config, pairlistconfig, pairlist_pos)
# Apply seed in backtesting mode to get comparable results,
# but not in live modes to get a non-repeating order of pairs during live modes.
2021-11-27 18:41:36 +00:00
if config.get('runmode') in (RunMode.LIVE, RunMode.DRY_RUN):
self._seed = None
2021-11-27 18:41:36 +00:00
logger.info("Live mode detected, not applying seed.")
else:
self._seed = pairlistconfig.get('seed')
2021-11-27 18:41:36 +00:00
logger.info(f"Backtesting mode detected, applying seed value: {self._seed}")
2020-05-17 23:36:40 +00:00
@property
def needstickers(self) -> bool:
"""
Boolean property defining if tickers are necessary.
2020-11-24 19:24:51 +00:00
If no Pairlist requires tickers, an empty Dict is passed
2020-05-17 23:36:40 +00:00
as tickers argument to filter_pairlist
"""
return False
def short_desc(self) -> str:
"""
Short whitelist method description - used for startup-messages
"""
return (f"{self.name} - Shuffling pairs" +
(f", seed = {self._seed}." if self._seed is not None else "."))
def filter_pairlist(self, pairlist: List[str], tickers: Dict) -> List[str]:
"""
Filters and sorts pairlist and returns the whitelist again.
Called on each bot iteration - please use internal caching if necessary
:param pairlist: pairlist to filter or sort
:param tickers: Tickers (from exchange.get_tickers()). May be cached.
:return: new whitelist
"""
# Shuffle is done inplace
random.seed(self._seed)
random.shuffle(pairlist)
2020-05-17 23:36:40 +00:00
return pairlist