From c67107739d54bc48ec5ffa05c22dad529e819510 Mon Sep 17 00:00:00 2001 From: Sait Cakmak Date: Tue, 29 Oct 2024 14:28:36 -0700 Subject: [PATCH] Rename `fast_optimize` to `mock_optimize` (#2599) Summary: Pull Request resolved: https://github.com/pytorch/botorch/pull/2599 Updates the name to clarify that this is just a mock and does not magically speed up optimization without consequences. Reviewed By: sdaulton, Balandat Differential Revision: D65146794 fbshipit-source-id: 8e0ed887bafe8191f305ddbadae3fcdaf0a7e969 --- botorch/test_utils/__init__.py | 4 ++-- botorch/test_utils/mock.py | 16 ++++++++-------- test/acquisition/test_input_constructors.py | 4 ++-- test/test_utils/test_mock.py | 20 ++++++++++---------- 4 files changed, 22 insertions(+), 22 deletions(-) diff --git a/botorch/test_utils/__init__.py b/botorch/test_utils/__init__.py index 3a89f80f66..aa035bf7eb 100644 --- a/botorch/test_utils/__init__.py +++ b/botorch/test_utils/__init__.py @@ -11,6 +11,6 @@ 'botorch/'. """ -from botorch.test_utils.mock import fast_optimize +from botorch.test_utils.mock import mock_optimize -__all__ = ["fast_optimize"] +__all__ = ["mock_optimize"] diff --git a/botorch/test_utils/mock.py b/botorch/test_utils/mock.py index 5ae8940c7a..c860d260e9 100644 --- a/botorch/test_utils/mock.py +++ b/botorch/test_utils/mock.py @@ -27,12 +27,12 @@ @contextmanager -def fast_optimize_context_manager( +def mock_optimize_context_manager( force: bool = False, ) -> Generator[None, None, None]: - """A context manager to force botorch to speed up optimization. Currently, the - primary tactic is to force the underlying scipy methods to stop after just one - iteration. + """A context manager that uses mocks to speed up optimization for testing. + Currently, the primary tactic is to force the underlying scipy methods to stop + after just one iteration. force: If True will not raise an AssertionError if no mocks are called. USE RESPONSIBLY. @@ -116,17 +116,17 @@ def minimal_gen_os_ics(*args: Any, **kwargs: Any) -> Tensor | None: ): raise AssertionError( "No mocks were called in the context manager. Please remove unused " - "fast_optimize_context_manager()." + "mock_optimize_context_manager()." ) -def fast_optimize(f: Callable) -> Callable: - """Wraps f in the fast_botorch_optimize_context_manager for use as a decorator.""" +def mock_optimize(f: Callable) -> Callable: + """Wraps `f` in `mock_optimize_context_manager` for use as a decorator.""" @wraps(f) # pyre-fixme[3]: Return type must be annotated. def inner(*args: Any, **kwargs: Any): - with fast_optimize_context_manager(): + with mock_optimize_context_manager(): return f(*args, **kwargs) return inner diff --git a/test/acquisition/test_input_constructors.py b/test/acquisition/test_input_constructors.py index 90dc93bc65..53120d1325 100644 --- a/test/acquisition/test_input_constructors.py +++ b/test/acquisition/test_input_constructors.py @@ -109,7 +109,7 @@ from botorch.models.deterministic import FixedSingleSampleModel from botorch.models.model_list_gp_regression import ModelListGP from botorch.sampling.normal import IIDNormalSampler, SobolQMCNormalSampler -from botorch.test_utils.mock import fast_optimize +from botorch.test_utils.mock import mock_optimize from botorch.utils.constraints import get_outcome_constraint_transforms from botorch.utils.datasets import SupervisedDataset from botorch.utils.multi_objective.box_decompositions.non_dominated import ( @@ -1841,7 +1841,7 @@ def setUp(self, suppress_input_warnings: bool = True) -> None: }, ) - @fast_optimize + @mock_optimize def test_constructors_can_instantiate(self) -> None: for key, (classes, input_constructor_kwargs) in self.cases.items(): with self.subTest( diff --git a/test/test_utils/test_mock.py b/test/test_utils/test_mock.py index 8e8d8bda22..19dc68eee6 100644 --- a/test/test_utils/test_mock.py +++ b/test/test_utils/test_mock.py @@ -22,7 +22,7 @@ get_nearest_neighbors, optimize_acqf_mixed_alternating, ) -from botorch.test_utils.mock import fast_optimize, fast_optimize_context_manager +from botorch.test_utils.mock import mock_optimize, mock_optimize_context_manager from botorch.utils.testing import BotorchTestCase, MockAcquisitionFunction @@ -37,14 +37,14 @@ def __call__(self, X): class TestMock(BotorchTestCase): - def test_fast_optimize_context_manager(self) -> None: + def test_mock_optimize_context_manager(self) -> None: with self.subTest("gen_candidates_scipy"): - with fast_optimize_context_manager(): + with mock_optimize_context_manager(): cand, value = gen_candidates_scipy( initial_conditions=torch.tensor([[0.0]]), acquisition_function=SinAcqusitionFunction(), ) - # When not using `fast_optimize`, the value is 1.0. With it, the value is + # When not using `mock_optimize`, the value is 1.0. With it, the value is # around 0.84 self.assertLess(value.item(), 0.99) @@ -54,14 +54,14 @@ def test_fast_optimize_context_manager(self) -> None: def closure(): return torch.sin(x), [torch.cos(x)] - with fast_optimize_context_manager(): + with mock_optimize_context_manager(): result = scipy_minimize(closure=closure, parameters={"x": x}) self.assertEqual( result.message, "STOP: TOTAL NO. of ITERATIONS REACHED LIMIT" ) with self.subTest("optimize_acqf"): - with fast_optimize_context_manager(): + with mock_optimize_context_manager(): cand, value = optimize_acqf( acq_function=SinAcqusitionFunction(), bounds=torch.tensor([[-2.0], [2.0]]), @@ -72,7 +72,7 @@ def closure(): self.assertLess(value.item(), 0.99) with self.subTest("gen_batch_initial_conditions"): - with fast_optimize_context_manager(), patch( + with mock_optimize_context_manager(), patch( "botorch.optim.initializers.initialize_q_batch", wraps=initialize_q_batch, ) as mock_init_q_batch: @@ -85,7 +85,7 @@ def closure(): ) self.assertEqual(mock_init_q_batch.call_args[1]["n"], 2) - def test_fast_optimize_mixed_alternating(self) -> None: + def test_mock_optimize_mixed_alternating(self) -> None: with patch( "botorch.optim.optimize_mixed.discrete_step", wraps=discrete_step, @@ -110,7 +110,7 @@ def test_fast_optimize_mixed_alternating(self) -> None: # `mock_discrete`, which should total to 1. mock_neighbors.assert_called_once() - @fast_optimize + @mock_optimize def test_decorator(self) -> None: model = SingleTaskGP( train_X=torch.tensor([[0.0]], dtype=torch.double), @@ -137,5 +137,5 @@ def test_decorator(self) -> None: def test_raises_when_unused(self) -> None: with self.assertRaisesRegex(AssertionError, "No mocks were called"): - with fast_optimize_context_manager(): + with mock_optimize_context_manager(): pass