Skip to content

Commit

Permalink
adding AuxiliarySource as part of Experiment object (#3205)
Browse files Browse the repository at this point in the history
Summary:
Pull Request resolved: #3205

Attaching auxiliary sources to the target TL experiment.

Reviewed By: saitcakmak

Differential Revision: D67205252

fbshipit-source-id: 361bc2b6a05a03f373cf43d1dc078a3ebfe2897c
  • Loading branch information
Jelena Markovic-Voronov authored and facebook-github-bot committed Dec 23, 2024
1 parent 15ff1dd commit ef1af42
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 0 deletions.
1 change: 1 addition & 0 deletions ax/benchmark/benchmark.py
Original file line number Diff line number Diff line change
Expand Up @@ -259,6 +259,7 @@ def benchmark_replication(
optimization_config=problem.optimization_config,
runner=runner,
status_quo=sq_arm,
auxiliary_experiments_by_purpose=problem.auxiliary_experiments_by_purpose,
)

scheduler = Scheduler(
Expand Down
12 changes: 12 additions & 0 deletions ax/benchmark/benchmark_problem.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
from ax.benchmark.benchmark_step_runtime_function import TBenchmarkStepRuntimeFunction
from ax.benchmark.benchmark_test_function import BenchmarkTestFunction
from ax.benchmark.benchmark_test_functions.botorch_test import BoTorchTestFunction
from ax.core.auxiliary import AuxiliaryExperiment, AuxiliaryExperimentPurpose

from ax.core.objective import MultiObjective, Objective
from ax.core.optimization_config import (
Expand Down Expand Up @@ -97,6 +98,8 @@ class BenchmarkProblem(Base):
returns the runtime of an step. If ``step_runtime_function`` is
left as ``None``, each step will take one simulated second. (When
data is not time-series, the whole trial consists of one step.)
auxiliary_experiments_by_purpose: A mapping from experiment purpose to
a list of auxiliary experiments.
"""

name: str
Expand All @@ -112,6 +115,9 @@ class BenchmarkProblem(Base):
step_runtime_function: TBenchmarkStepRuntimeFunction | None = None
target_fidelity_and_task: Mapping[str, TParamValue] = field(default_factory=dict)
status_quo_params: TParameterization | None = None
auxiliary_experiments_by_purpose: (
dict[AuxiliaryExperimentPurpose, list[AuxiliaryExperiment]] | None
) = None

def __post_init__(self) -> None:
# Validate inputs
Expand Down Expand Up @@ -387,6 +393,9 @@ def create_problem_from_botorch(
report_inference_value_as_trace: bool = False,
step_runtime_function: TBenchmarkStepRuntimeFunction | None = None,
status_quo_params: TParameterization | None = None,
auxiliary_experiments_by_purpose: (
dict[AuxiliaryExperimentPurpose, list[AuxiliaryExperiment]] | None
) = None,
) -> BenchmarkProblem:
"""
Create a ``BenchmarkProblem`` from a BoTorch ``BaseTestProblem``.
Expand Down Expand Up @@ -430,6 +439,8 @@ def create_problem_from_botorch(
returns the runtime of an step. If ``step_runtime_function`` is
left as ``None``, each step will take one simulated second. (When
data is not time-series, the whole trial consists of one step.)
auxiliary_experiments_by_purpose: A mapping from experiment purpose to
a list of auxiliary experiments.
Example:
>>> from ax.benchmark.benchmark_problem import create_problem_from_botorch
Expand Down Expand Up @@ -522,4 +533,5 @@ def create_problem_from_botorch(
report_inference_value_as_trace=report_inference_value_as_trace,
step_runtime_function=step_runtime_function,
status_quo_params=status_quo_params,
auxiliary_experiments_by_purpose=auxiliary_experiments_by_purpose,
)

0 comments on commit ef1af42

Please sign in to comment.