GaussianProcessSurrogate¶
- class baybe.surrogates.gaussian_process.core.GaussianProcessSurrogate[source]¶
Bases:
Surrogate
A Gaussian process surrogate model.
Public methods
__init__
([kernel_or_factory])Method generated by attrs for class GaussianProcessSurrogate.
fit
(searchspace, objective, measurements)Train the surrogate model on the provided data.
from_dict
(dictionary)Create an object from its dictionary representation.
from_json
(string)Create an object from its JSON representation.
from_preset
(preset)Create a Gaussian process surrogate from one of the defined presets.
posterior
(candidates, /)Compute the posterior for candidates in experimental representation.
Create the botorch-ready representation of the fitted model.
to_dict
()Create an object's dictionary representation.
to_json
()Create an object's JSON representation.
Public attributes and properties
The factory used to create the kernel of the Gaussian process.
Class variable encoding whether or not the surrogate supports transfer learning.
- __init__(kernel_or_factory: Kernel | KernelFactory = NOTHING)¶
Method generated by attrs for class GaussianProcessSurrogate.
For details on the parameters, see Public attributes and properties.
- fit(searchspace: SearchSpace, objective: Objective, measurements: DataFrame)¶
Train the surrogate model on the provided data.
- Parameters:
searchspace (
SearchSpace
) – The search space in which experiments are conducted.objective (
Objective
) – The objective to be optimized.measurements (
DataFrame
) – The training data in experimental representation.
- Raises:
ValueError – If the search space contains task parameters but the selected surrogate model type does not support transfer learning.
NotImplementedError – When using a continuous search space and a non-GP model.
- Return type:
- static from_preset(preset: GaussianProcessPreset)[source]¶
Create a Gaussian process surrogate from one of the defined presets.
- Return type:
- posterior(candidates: DataFrame, /)¶
Compute the posterior for candidates in experimental representation.
Takes a dataframe of parameter configurations in experimental representation and returns the corresponding posterior object. Therefore, the method serves as the user-facing entry point for accessing model predictions.
- Parameters:
candidates (
DataFrame
) – A dataframe containing parameter configurations in experimental representation.- Raises:
ModelNotTrainedError – When called before the model has been trained.
- Return type:
Posterior
- Returns:
A
botorch.posteriors.Posterior
object representing the posterior distribution at the given candidate points, where the posterior is also described in experimental representation. That is, the posterior values lie in the same domain as the modelled targets/objective on which the surrogate was trained viabaybe.surrogates.base.Surrogate.fit()
.
- to_botorch()[source]¶
Create the botorch-ready representation of the fitted model.
The
botorch.models.model.Model
created by this method needs to be configured such that it can be called with candidate points in computational representation, that is, input of the form as obtained viabaybe.searchspace.core.SearchSpace.transform()
.- Return type:
Model
- to_json()¶
Create an object’s JSON representation.
- Return type:
- Returns:
The JSON representation as a string.
- kernel_factory: KernelFactory¶
The factory used to create the kernel of the Gaussian process.
Accepts either a
baybe.kernels.base.Kernel
or akernel_factory.KernelFactory
. When passing abaybe.kernels.base.Kernel
, it gets automatically wrapped into akernel_factory.PlainKernelFactory
.
- supports_transfer_learning: ClassVar[bool] = True¶
Class variable encoding whether or not the surrogate supports transfer learning.