The default metric of the hypopt
package is the the score()
function for whatever model you use, so in your case it is LogisticRegression().score()
which defaults to accuracy.
If you upgrade the hypopt package to version 1.0.8 via pip install hypopt --upgrade
, you can specify any metric of your choosing in the scoring
parameter of GridSearch.fit()
, for example, fit(scoring='f1')
. Here is a simple working example based on your code that uses the F1 metric:
from hypopt import GridSearch
param_grid = {"penalty": ['l1'], 'C': [0.001, 0.01]}
opt = GridSearch(model=LogisticRegression(), param_grid = param_grid)
# This will use f1 score as the scoring metric that you optimize.
opt.fit(X_train, y_train, X_val, y_val, scoring='f1')
hypopt
supports most any scoring function that sklearn
supports.
- For classification,
hypopt
supports these metrics (as strings): 'accuracy', 'brier_score_loss', 'average_precision', 'f1', 'f1_micro', 'f1_macro', 'f1_weighted', 'neg_log_loss', 'precision', 'recall', or 'roc_auc'.
- For regression,
hypopt
supports: "explained_variance", "neg_mean_absolute_error", "neg_mean_squared_error", "neg_mean_squared_log_error", "neg_median_absolute_error", "r2".
You can also create your own metric your_custom_score_func(y_true, y_pred)
by wrapping it into an object like this:
from sklearn.metrics import make_scorer
scorer = make_scorer(your_custom_score_func)
opt.fit(X_train, y_train, X_val, y_val, scoring=scorer)
You can learn more in the hypopt.GridSearch.fit()
docstring here:
You can learn more about creating your own custom scoring metrics here: