Skip to content
This repository has been archived by the owner on Mar 12, 2024. It is now read-only.

Optuna Integration #215

Merged
merged 4 commits into from
Oct 21, 2021
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 26 additions & 0 deletions hiplot/experiment.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
if tp.TYPE_CHECKING:
import pandas as pd
from .streamlit_helpers import ExperimentStreamlitComponent
import optuna

DisplayableType = tp.Union[bool, int, float, str]

Expand Down Expand Up @@ -502,6 +503,31 @@ def from_dataframe(dataframe: "pd.DataFrame") -> "Experiment": # No type hint t

return experiment

@staticmethod
def from_optuna(study: "optuna.study.Study") -> "Experiment": # No type hint to avoid having optuna as an additional dependency
"""
Creates a HiPlot experiment from a Optuna Study.

:param study: Optuna Study
"""


# Create a list of dictionary objects using study trials
# All parameters are taken using params.copy()

hyper_opt_data = []
for each_trial in study.trials:
trial_params = {}
trial_params["value"] = each_trial.value # name = value, as it could be RMSE / accuracy, or any value that the user selects for tuning
trial_params["uid"] = each_trial.number
trial_params.update(each_trial.params.copy())
hyper_opt_data.append(trial_params)
experiment = Experiment.from_iterable(hyper_opt_data)

return experiment



@staticmethod
def merge(xp_dict: tp.Dict[str, "Experiment"]) -> "Experiment":
"""
Expand Down
19 changes: 19 additions & 0 deletions hiplot/test_experiment.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@

import pytest
import pandas as pd
import optuna

import hiplot as hip

Expand Down Expand Up @@ -39,6 +40,24 @@ def test_from_dataframe() -> None:
xp.validate()
xp._asdict()

def test_from_optuna() -> None:

def objective(trial):
x = trial.suggest_float("x", -1, 1)
return x ** 2
Copy link
Contributor

@danthe3rd danthe3rd Oct 15, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Missing some typing here - let's not worry too much about tests typing tho, this should work

Suggested change
def objective(trial):
x = trial.suggest_float("x", -1, 1)
return x ** 2
def objective(trial: tp.Any) -> float:
x = trial.suggest_float("x", -1, 1)
return x ** 2


study = optuna.create_study()
study.optimize(objective, n_trials=3)

# Create a dataframe from the study.
df = study.trials_dataframe()
assert isinstance(df, pd.DataFrame)
assert df.shape[0] == 3 # n_trials.
xp = hip.Experiment.from_optuna(study)
assert len(xp.datapoints) == 3
xp.validate()
xp._asdict()


def test_from_dataframe_nan_values() -> None:
# Pandas automatically convert numeric-based columns None to NaN in dataframes
Expand Down
1 change: 1 addition & 0 deletions requirements/dev.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,4 @@ pre-commit
pandas
streamlit>=0.63
beautifulsoup4
optuna