intelligent-trading-bot/common/classifier_gb.py

82 lines
2.4 KiB
Python

import numpy as np
import pandas as pd
from sklearn.preprocessing import StandardScaler
import lightgbm as lgbm
def train_predict_gb(df_X, df_y, df_X_test, model_config: dict):
"""
Train model with the specified hyper-parameters and return its predictions for the test data.
"""
model_pair = train_gb(df_X, df_y, model_config)
y_test_hat = predict_gb(model_pair, df_X_test, model_config)
return y_test_hat
def train_gb(df_X, df_y, model_config: dict):
"""
Train model with the specified hyper-parameters and return this model (and scaler if any).
"""
params = model_config.get("params", {})
is_scale = params.get("is_scale", False)
is_regression = params.get("is_regression", False)
#
# Scale
#
if is_scale:
scaler = StandardScaler()
scaler.fit(df_X)
X_train = scaler.transform(df_X)
else:
scaler = None
X_train = df_X.values
y_train = df_y.values
#
# Create model
#
train_conf = model_config.get("train", {})
# See parameters here: https://lightgbm.readthedocs.io/en/latest/Parameters.html
args = train_conf.copy()
model = lgbm.train(
args,
train_set=lgbm.Dataset(X_train, y_train),
#valid_sets=[lgbm.Dataset(X_validate, y_validate)],
)
return (model, scaler)
def predict_gb(models: tuple, df_X_test, model_config: dict):
"""
Use the model(s) to make predictions for the test data.
The first model is a prediction model and the second model (optional) is a scaler.
"""
#
# Scale
#
scaler = models[1]
is_scale = scaler is not None
input_index = df_X_test.index
if is_scale:
df_X_test = scaler.transform(df_X_test)
df_X_test = pd.DataFrame(data=df_X_test, index=input_index)
else:
df_X_test = df_X_test
df_X_test_nonans = df_X_test.dropna() # Drop nans, possibly create gaps in index
nonans_index = df_X_test_nonans.index
y_test_hat_nonans = models[0].predict(df_X_test_nonans.values)
y_test_hat_nonans = pd.Series(data=y_test_hat_nonans, index=nonans_index) # Attach indexes with gaps
df_ret = pd.DataFrame(index=input_index) # Create empty dataframe with original index
df_ret["y_hat"] = y_test_hat_nonans # Join using indexes
sr_ret = df_ret["y_hat"] # This series has all original input indexes but NaNs where input is NaN
return sr_ret