OPTUNA

Optuna: 一个超参数优化框架

Optuna 是一个自动超参数优化软件框架,特别为机器学习设计。它具有一种命令式的、*定义即运行*风格的用户API。得益于我们的*定义即运行*API,使用Optuna编写的代码具有高模块化,Optuna的用户可以动态构建超参数的搜索空间。

主要特点

Optuna 具有以下现代功能:

基本概念

我们使用术语 研究试验 如下:

  • 研究:基于目标函数的优化

  • 试验:目标函数的单次执行

请参考下面的示例代码。研究 的目标是通过多个 试验 (例如,n_trials=100)找出最优的超参数值集(例如,classifiersvm_c)。Optuna 是一个为优化 研究 的自动化和加速而设计的框架。

|在Colab中打开|

import ...

# Define an objective function to be minimized.
def objective(trial):

    # Invoke suggest methods of a Trial object to generate hyperparameters.
    regressor_name = trial.suggest_categorical('classifier', ['SVR', 'RandomForest'])
    if regressor_name == 'SVR':
        svr_c = trial.suggest_float('svr_c', 1e-10, 1e10, log=True)
        regressor_obj = sklearn.svm.SVR(C=svr_c)
    else:
        rf_max_depth = trial.suggest_int('rf_max_depth', 2, 32)
        regressor_obj = sklearn.ensemble.RandomForestRegressor(max_depth=rf_max_depth)

    X, y = sklearn.datasets.fetch_california_housing(return_X_y=True)
    X_train, X_val, y_train, y_val = sklearn.model_selection.train_test_split(X, y, random_state=0)

    regressor_obj.fit(X_train, y_train)
    y_pred = regressor_obj.predict(X_val)

    error = sklearn.metrics.mean_squared_error(y_val, y_pred)

    return error  # An objective value linked with the Trial object.

study = optuna.create_study()  # Create a new study.
study.optimize(objective, n_trials=100)  # Invoke optimization of the objective function.

Web 仪表板

Optuna Dashboard 是一个 Optuna 的实时网页仪表板。您可以在图表和表格中查看优化历史、超参数重要性等。您无需创建 Python 脚本来调用 Optuna 的可视化 功能。欢迎提出功能请求和错误报告!

https://user-images.githubusercontent.com/5564044/204975098-95c2cb8c-0fb5-4388-abc4-da32f56cb4e5.gif

optuna-dashboard 可以通过 pip 安装:

$ pip install optuna-dashboard

小技巧

请查看 Optuna Dashboard 官方文档的 入门指南 部分。

通信

贡献

欢迎对 Optuna 的任何贡献!当你发送拉取请求时,请遵循 贡献指南

许可证

MIT 许可证(参见 LICENSE)。

Optuna 使用了来自 SciPy 和 fdlibm 项目的代码(参见 第三方许可证)。

参考

Takuya Akiba, Shotaro Sano, Toshihiko Yanase, Takeru Ohta, 和 Masanori Koyama. 2019. Optuna: 下一代超参数优化框架. 在 KDD (arXiv).

索引和表格

  • 总索引

  • 模块索引

  • 搜索