使用 freqAI で何ができるか
- 設定が完了したら、freqAI を使用して取得できます。
freqtrade を使用するためには、準備する必要があります
- 戦略
- 設定ファイル
- モデル
それらのパスはここにあります
freqtrade/templates/FreqaiExampleStrategy.py、freqtrade/freqai/prediction_models/LightGBMRegressor.py、およびconfig_examples/config_freqai.example.json、それぞれ。
設定ファイルを設定する
"freqai": {
"enabled": true,
"purge_old_models": 2,
"train_period_days": 30, //トレーニングデータの日数
"backtest_period_days": 7,
"identifier" : "unique-id",
"feature_parameters" : {
"include_timeframes": ["5m","15m","4h"],
"include_corr_pairlist": [
"ETH/USD",
"LINK/USD",
"BNB/USD"
],
"label_period_candles": 24,
"include_shifted_candles": 2,
"indicator_periods_candles": [10, 20]
},
"data_split_parameters" : {
"test_size": 0.25
}
}
戦略を設定する
startup_candle_count: int = 20
def populate_indicators(self, dataframe: DataFrame, metadata: dict) -> DataFrame:
dataframe = self.freqai.start(dataframe, metadata, self)
return dataframe
def feature_engineering_expand_all(self, dataframe: DataFrame, period, **kwargs) -> DataFrame:
dataframe["%-rsi-period"] = ta.RSI(dataframe, timeperiod=period)
dataframe["%-mfi-period"] = ta.MFI(dataframe, timeperiod=period)
dataframe["%-adx-period"] = ta.ADX(dataframe, timeperiod=period)
dataframe["%-sma-period"] = ta.SMA(dataframe, timeperiod=period)
dataframe["%-ema-period"] = ta.EMA(dataframe, timeperiod=period)
return dataframe
def feature_engineering_expand_basic(self, dataframe: DataFrame, **kwargs) -> DataFrame:
dataframe["%-pct-change"] = dataframe["close"].pct_change()
dataframe["%-raw_volume"] = dataframe["volume"]
dataframe["%-raw_price"] = dataframe["close"]
return dataframe
def feature_engineering_standard(self, dataframe: DataFrame, **kwargs) -> DataFrame:
dataframe["%-day_of_week"] = (dataframe["date"].dt.dayofweek + 1) / 7
dataframe["%-hour_of_day"] = (dataframe["date"].dt.hour + 1) / 25
return dataframe
def set_freqai_targets(self, dataframe: DataFrame, **kwargs) -> DataFrame:
dataframe["&-s_close"] = (
dataframe["close"]
.shift(-self.freqai_info["feature_parameters"]["label_period_candles"])
.rolling(self.freqai_info["feature_parameters"]["label_period_candles"])
.mean()
/ dataframe["close"]
- 1
)
return dataframe
startup_candle_count は、戦略の起動期間を指します。戦略の起動期間は、この時間内に指標の計算に誤差が生じることを意味します。ただし、具体的な起動時間はどれくらいか、この問題を解決するために、戦略に startup_candle_count という属性を割り当てます。この値は、指標の計算に必要な最大期間です。例えば
startup_candle_count = 100
dataframe['ema100'] = ta.EMA(dataframe, timeperiod=100)
ダイナミックバルブ
変数テーブル
タイムキーフレーム
特徴
辞書
インストール要件
注意事項
VolumePairlists とは互換性がありません
ただし、ShufflePairlist とは互換性があります
freqAI の起動
freqtrade trade --config config_examples/config_freqai.example.json --strategy FreqaiExampleStrategy --freqaimodel LightGBMRegressor --strategy-path freqtrade/templates
freqAI を起動すると、すぐに新しいモデルが生成されます。新しいモデルのトレーニングを 30 分後に開始したい場合は、次のようにします。
"freqai": {
"live_retrain_hours": 0.5
}
または、30 分前にトレーニングを開始しないように freqAI に指示することもできます。
"freqai": {
"expired_hours": 0.5
}
古いモデルを削除してディスクスペースを節約したい場合は、次のようにします。
"freqai": {
"purge_old_models": true
}
既にトレーニングされたモデルを使用したい場合は、identifier を指定します。
"freqai": {
"identifier": "example",
}
その後、freqAI はすべての設定に基づいて必要なデータを自動的にダウンロードします(存在しない場合)。
バックテスト
バックテストモードは以前とは異なり、事前にデータをダウンロードする必要があり、時間範囲も大きくする必要があります。
バックテストモードを起動するコマンド
freqtrade backtesting --strategy FreqaiExampleStrategy --strategy-path freqtrade/templates --config config_examples/config_freqai.example.json --freqaimodel LightGBMRegressor --timerange 20210501-20210701