Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix INGO implementation #125

Merged
merged 3 commits into from
Aug 2, 2024
Merged

Fix INGO implementation #125

merged 3 commits into from
Aug 2, 2024

Conversation

not522
Copy link
Member

@not522 not522 commented Aug 2, 2024

Contributor Agreements

Please read the contributor agreements and if you agree, please click the checkbox below.

  • I agree to the contributor agreements.

Tip

Please follow the Quick TODO list to smoothly merge your PR.

Motivation

The implementation of ImplicitNaturalGradientSampler contains bugs. This PR fixes them and improves the sampling speed.

Description of the changes

  • Fix direction of optimization
  • Fix queue popping order
  • Use optuna.search_space.IntersectionSearchSpace instead of optuna.samplers.IntersectionSearchSpace
  • Remove unnecessary deepcopy

I have checked the implementation with the following code.

import optuna
import optunahub

def objective_L1_Ellipsoid(trial):
    DIMENSION = 100
    xs = [trial.suggest_float(f"x{n}", -1.0, 1.0) for n in range(DIMENSION)]
    return sum(10**(6*i/(DIMENSION-1))*abs(xs[i]) for i in range(DIMENSION))

mod = optunahub.load_local_module(
    package="samplers/implicit_natural_gradient",
    registry_root="./package",
    force_reload=True,
)

sampler = mod.ImplicitNaturalGradientSampler(seed=42)
study = optuna.create_study(sampler=sampler)
study.optimize(objective_L1_Ellipsoid, n_trials=10000)

The best value:

  • main (with deepcopy=False): 1206069.1983931102
  • This PR: 9595.199471317954

TODO List towards PR Merge

  • Copy ./template/ to create your package
  • Replace <COPYRIGHT HOLDER> in LICENSE of your package with your name
  • Fill out README.md in your package
  • Add import statements of your function or class names to be used in __init__.py
  • Apply the formatter based on the tips in README.md
  • Check whether your module works as intended based on the tips in README.md

@@ -174,7 +174,7 @@ def _pop_from_param_queue(
study._storage.set_trial_system_attr(
trial_id, _GENERATION_ATTR_KEY, self._get_optimizer().generation
)
return self._param_queue.pop()
return self._param_queue.pop(0)
Copy link
Member Author

Choose a reason for hiding this comment

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

The order of popping must be the same as the _z in FastINGO.

Copy link
Contributor

@eukaryo eukaryo left a comment

Choose a reason for hiding this comment

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

LGTM!

@eukaryo eukaryo merged commit e61dcae into optuna:main Aug 2, 2024
4 checks passed
@not522 not522 deleted the fix-ingo branch August 6, 2024 09:25
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants