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

New acquisition functions #203

Merged
merged 26 commits into from
Apr 29, 2024
Merged

New acquisition functions #203

merged 26 commits into from
Apr 29, 2024

Conversation

Scienfitz
Copy link
Collaborator

@Scienfitz Scienfitz commented Apr 15, 2024

Some progress towards refactoring the acqf interface and enabling more advanced acqfs

Done

  • removed debotorchize
  • incldued some new acqfs, see CHANGELOG
  • enable iteration tests with all acqfs
  • extended hypothesis tests

Not Done Yet:

Issues:

  • some tests with custom surrogates fail, see separate thread resolved since not using botorch factory anymore
  • some of the analytical new acqfs dont seem to work wiht out GP model. Eg when I implement the NEI I get botorch.exceptions.errors.UnsupportedError: Only SingleTaskGP models with known observation noise are currently supported for fantasy-based NEI & LogNE. Also the LogPI is available in botorch, but it is not imported to the top level acqf package in botorch, I ignored it here. I included a reverted commit pair so it can be checked out quickly to reproduce

baybe/acquisition/base.py Outdated Show resolved Hide resolved
@Scienfitz Scienfitz self-assigned this Apr 15, 2024
@Scienfitz Scienfitz added enhancement Expand / change existing functionality new feature New functionality labels Apr 15, 2024
CHANGELOG.md Show resolved Hide resolved
baybe/acquisition/acqfs.py Show resolved Hide resolved
baybe/acquisition/base.py Outdated Show resolved Hide resolved
Copy link
Collaborator

@AdrianSosic AdrianSosic left a comment

Choose a reason for hiding this comment

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

Hi @Scienfitz, thanks for this tricky PR. Here already the first chunk of comments so that you have something to work on while I review the rest

baybe/acquisition/__init__.py Outdated Show resolved Hide resolved
baybe/acquisition/acqfs.py Outdated Show resolved Hide resolved
baybe/acquisition/acqfs.py Outdated Show resolved Hide resolved
@@ -79,7 +79,7 @@ def _recommend_discrete(
except AttributeError as ex:
raise NoMCAcquisitionFunctionError(
f"The '{self.__class__.__name__}' only works with Monte Carlo "
f"acquisition functions."
f"acquisition functions for batch sizes > 1."
Copy link
Collaborator

Choose a reason for hiding this comment

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

I think it actually makes sense to remove the try-catch and instead raise this error in a guard clause at the top under the appropriate condition (i.e. batch_size>1 and non-MC function). Because I've already had weird situations several times that a different AttributeError was thrown (while developing) and this got me completely off track. And I don't see a reason really why should wait for the optimization to fail... Right?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

yes this atttribute error ctach ehre can have several rasons and ive also encountered it for some of the (not included) new acqf functions that complain about something else than our error here. It def needs to be fixed

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

having said that the batch size change you suggest would not be enough for that

Copy link
Collaborator

Choose a reason for hiding this comment

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

What you you mean with batch size change? My suggestion was simply to have an if-condition that checks for batch_size>1 AND not is_mc ...

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

yes i could do that but it wont solve any of the other issues that could cause different attribute errors

Copy link
Collaborator

Choose a reason for hiding this comment

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

Yes, and we can just explicitly link to the original function and then add stuff if that is fine with our linters

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I propose the following

        """Generate recommendations from a discrete search space.

        Note: This method overwrites
        :func:`baybe.recommender.pure.base.PureRecommender._recommend_discrete`
         keeping the same characteristics except the ones mentioned here.

        Raises:
            NoMCAcquisitionFunctionError: If a non-Monte Carlo acquisition function is
                used with a batch size > 1.
        """

its part of this PR via amending the last commit
keep in mind this is wont shown in the doc anyway because its a private function
please let me know if that can go ahead

I notice also inconsistent behavior here, in the same file we have _recommend_hybrid which also overwrites the base class implementation, but has its own completely copypasta docstring with an amended raises section

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

never mind its not possible to do that without violating lots of stuff
image

I would simply follow the approach of _recommend_hybrid

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

and the same problems were also part of conti and hyprid error raising so I changed it there too
Seems our previous workflow was to copy the entire docstirng+amend which I did for those as well

Copy link
Collaborator

Choose a reason for hiding this comment

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

Ok, I'm not a happy guy but I think there is simply no "good" approach, so I'll simply look away 🙈

baybe/utils/basic.py Show resolved Hide resolved
baybe/acquisition/acqfs.py Show resolved Hide resolved
baybe/acquisition/adapter.py Outdated Show resolved Hide resolved
Copy link
Collaborator

@AdrianSosic AdrianSosic left a comment

Choose a reason for hiding this comment

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

Overall, looking great 👍🏼 Here the remaining comments

tests/docs/test_examples.py Show resolved Hide resolved
tests/hypothesis_strategies/acquisition.py Outdated Show resolved Hide resolved
baybe/utils/dataframe.py Show resolved Hide resolved
baybe/acquisition/base.py Show resolved Hide resolved
baybe/acquisition/base.py Show resolved Hide resolved
@Scienfitz Scienfitz changed the title Feature/new acqfs New Acquisition Functions Apr 26, 2024
@AdrianSosic AdrianSosic changed the title New Acquisition Functions New acquisition functions Apr 26, 2024
@Scienfitz Scienfitz force-pushed the feature/new_acqfs branch 2 times, most recently from a75b012 to 386ea9b Compare April 26, 2024 12:55
@AdrianSosic AdrianSosic mentioned this pull request Apr 29, 2024
@Scienfitz Scienfitz merged commit 538ac80 into main Apr 29, 2024
9 of 10 checks passed
@Scienfitz Scienfitz deleted the feature/new_acqfs branch April 29, 2024 12:31
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement Expand / change existing functionality new feature New functionality
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants