备注
前往结尾 下载完整示例代码。
plot_optimization_history
- optuna.visualization.matplotlib.plot_optimization_history(study, *, target=None, target_name='Objective Value', error_bar=False)[源代码]
使用 Matplotlib 绘制研究中所有试验的优化历史。
参见
备注
你需要使用
plt.tight_layout()或plt.savefig(IMAGE_NAME, bbox_inches='tight')自行调整图表的大小。- 参数:
study (Study | Sequence[Study]) – 一个
Study对象,其试验根据目标值进行绘制。如果你想比较这些优化历史,可以传递多个研究对象。target (Callable[[FrozenTrial], float] | None) –
A function to specify the value to display. If it is
Noneandstudyis being used for single-objective optimization, the objective values are plotted.备注
如果
study用于多目标优化,请指定此参数。target_name (str) – 在轴标签和图例上显示的目标名称。
error_bar (bool) – 一个显示误差线的标志。
- 返回:
一个
matplotlib.axes.Axes对象。- 返回类型:
备注
作为实验性功能在 v2.2.0 中添加。接口可能会在更新版本中未经事先通知而更改。请参阅 https://github.com/optuna/optuna/releases/tag/v2.2.0。
以下代码片段展示了如何绘制优化历史。

/Users/cw/baidu/code/fin_tool/github/optuna/docs/visualization_matplotlib_examples/optuna.visualization.matplotlib.optimization_history.py:26: ExperimentalWarning:
plot_optimization_history is experimental (supported from v2.2.0). The interface can change in the future.
import optuna
import matplotlib.pyplot as plt
def objective(trial):
x = trial.suggest_float("x", -100, 100)
y = trial.suggest_categorical("y", [-1, 0, 1])
return x**2 + y
sampler = optuna.samplers.TPESampler(seed=10)
study = optuna.create_study(sampler=sampler)
study.optimize(objective, n_trials=10)
optuna.visualization.matplotlib.plot_optimization_history(study)
plt.tight_layout()
脚本总运行时间: (0 分钟 0.063 秒)