Campaign¶
- class baybe.campaign.Campaign[source]¶
Bases:
SerialMixin
Main class for interaction with BayBE.
Campaigns define and record an experimentation process, i.e. the execution of a series of measurements and the iterative sequence of events involved.
- In particular, a campaign:
Defines the objective of an experimentation process.
Defines the search space over which the experimental parameter may vary.
Defines a recommender for exploring the search space.
Records the measurement data collected during the process.
Records metadata about the progress of the experimentation process.
Public methods
__init__
(searchspace[, objective, recommender])Method generated by attrs for class Campaign.
add_measurements
(data[, ...])Add results from a dataframe to the internal database.
from_config
(config_json)Create a campaign from a configuration JSON.
from_dict
(dictionary)Create an object from its dictionary representation.
from_json
(string)Create an object from its JSON representation.
Get the current surrogate model.
posterior
(candidates)Get the posterior predictive distribution for the given candidates.
recommend
(batch_size[, pending_experiments, ...])Provide the recommendations for the next batch of experiments.
to_dict
()Create an object's dictionary representation.
to_json
()Create an object's JSON representation.
validate_config
(config_json)Validate a given campaign configuration JSON.
Public attributes and properties
The search space in which the experiments are conducted.
The optimization objective.
The employed recommender
The number of already processed batches.
The number of fits already done.
The experimental data added to the Campaign.
The parameters of the underlying search space.
The targets of the underlying objective.
- __init__(searchspace: Parameter | SubspaceDiscrete | SubspaceContinuous | SearchSpace, objective: Target | Objective | None = None, recommender: RecommenderProtocol = NOTHING)¶
Method generated by attrs for class Campaign.
For details on the parameters, see Public attributes and properties.
- add_measurements(data: DataFrame, numerical_measurements_must_be_within_tolerance: bool = True)[source]¶
Add results from a dataframe to the internal database.
Each addition of data is considered a new batch. Added results are checked for validity. Categorical values need to have an exact match. For numerical values, a campaign flag determines if values that lie outside a specified tolerance are accepted. Note that this modifies the provided data in-place.
- Parameters:
data (
DataFrame
) – The data to be added (with filled values for targets). Preferably created viabaybe.campaign.Campaign.recommend()
.numerical_measurements_must_be_within_tolerance (
bool
) – Flag indicating if numerical parameters need to be within their tolerances.
- Raises:
ValueError – If one of the targets has missing values or NaNs in the provided dataframe.
TypeError – If the target has non-numeric entries in the provided dataframe.
- Return type:
- get_surrogate()[source]¶
Get the current surrogate model.
- Raises:
RuntimeError – If the current recommender does not provide a surrogate model.
- Returns:
The surrogate of the current recommender.
- Return type:
Note
Currently, this method always returns the surrogate model with respect to the transformed target(s) / objective. This means that if you are using a
SingleTargetObjective
with a transformed target or aDesirabilityObjective
, the model’s output will correspond to the transformed quantities and not the original untransformed target(s).
- posterior(candidates: pd.DataFrame)[source]¶
Get the posterior predictive distribution for the given candidates.
The predictive distribution is based on the surrogate model of the last used recommender.
- Parameters:
candidates (pd.DataFrame) – The candidate points in experimental recommendations. For details, see
baybe.surrogates.base.Surrogate.posterior()
.- Raises:
IncompatibilityError – If the underlying surrogate model exposes no method for computing the posterior distribution.
- Returns:
The corresponding posterior object. For details, see
baybe.surrogates.base.Surrogate.posterior()
.- Return type:
Posterior
- recommend(batch_size: int, pending_experiments: DataFrame | None = None, batch_quantity: int | None = None)[source]¶
Provide the recommendations for the next batch of experiments.
- Parameters:
- Return type:
- Returns:
Dataframe containing the recommendations in experimental representation.
- Raises:
ValueError – If
batch_size
is smaller than 1.
- to_json()¶
Create an object’s JSON representation.
- Return type:
- Returns:
The JSON representation as a string.
- classmethod validate_config(config_json: str)[source]¶
Validate a given campaign configuration JSON.
-
objective:
Objective
|None
¶ The optimization objective. When passing a
baybe.targets.base.Target
, conversion tobaybe.objectives.single.SingleTargetObjective
is automatically applied.
-
recommender:
RecommenderProtocol
¶ The employed recommender
-
searchspace:
SearchSpace
¶ The search space in which the experiments are conducted. When passing a
baybe.parameters.base.Parameter
, abaybe.searchspace.discrete.SubspaceDiscrete
, or a abaybe.searchspace.continuous.SubspaceContinuous
, conversion tobaybe.searchspace.core.SearchSpace
is automatically applied.