Surrogates

Surrogate models are used to model and estimate the unknown objective function of the DoE campaign. BayBE offers a diverse array of surrogate models, while also allowing for the utilization of custom models. All surrogate models are based upon the general Surrogate class. Some models even support transfer learning, as indicated by the supports_transfer_learning attribute.

Available Models

BayBE provides a comprehensive selection of surrogate models, empowering you to choose the most suitable option for your specific needs. The following surrogate models are available within BayBE:

Extracting the Model for Advanced Study

In principle, the surrogate model does not need to be a persistent object during Bayesian optimization since each iteration performs a new fit anyway. However, for advanced study, such as investigating the posterior predictions, acquisition functions or feature importance, it can be useful to diretly extract the current surrogate model.

For this, BayBE provides the get_surrogate method, which is available for the Campaign or for recommenders. Below an example of how to utilize this in conjunction with the popular SHAP package:

# Assuming we already have a campaign created and measurements added
data = campaign.measurements[[p.name for p in campaign.parameters]]
model = lambda x: campaign.get_surrogate().posterior(x).mean

# Apply SHAP
explainer = shap.Explainer(model, data)
shap_values = explainer(data)
shap.plots.bar(shap_values)

Current Scalarization Limitations

Currently, get_surrogate 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 a DesirabilityObjective, the model’s output will correspond to the transformed quantities and not the original untransformed target(s). If you are using the model for subsequent analysis this should be kept in mind.

Using Custom Models

BayBE goes one step further by allowing you to incorporate custom models based on the ONNX architecture. Note however that these cannot be retrained. For a detailed explanation on using custom models, refer to the comprehensive examples provided in the corresponding example folder.