Targets¶
Targets play a crucial role as the connection between observables measured in an
experiment and the machine learning core behind BayBE.
In general, it is expected that you create one Target
object for each of your observables.
The way BayBE treats multiple targets is then controlled via the
Objective
.
NumericalTarget¶
Besides the name
, a NumericalTarget
has the following attributes:
The optimization
mode
: Specifies whether we want to minimize/maximize the target or whether we want to match a specific value.Bounds: Defines
bounds
that constrain the range of target values.A
transformation
function: When bounds are provided, this is used to map target values into the [0, 1] interval.
Below is a visualization of possible choices for transformation
, where lower
and
upper
are the entries provided via bounds
:
MIN and MAX mode¶
Here are two examples for simple maximization and minimization targets:
from baybe.targets import NumericalTarget, TargetMode, TargetTransformation
max_target = NumericalTarget(
name="Target_1",
mode=TargetMode.MAX, # can also be provided as string "MAX"
)
min_target = NumericalTarget(
name="Target_2",
mode="MIN", # can also be provided as TargetMode.MIN
bounds=(0, 100), # optional
transformation=TargetTransformation.LINEAR, # optional, will be applied if bounds are not None
)
MATCH mode¶
If you want to match a desired value, the TargetMode.MATCH
mode is the right choice.
In this mode, bounds
are required and different transformations compared to MIN
and MAX
modes are allowed.
Assume we want to instruct BayBE to match a value of 50 in a target.
We simply need to choose the bounds so that the midpoint is the desired value.
The spread of the bounds interval defines how fast the acceptability of a measurement
falls off away from the match value, also depending on the choice of transformation
.
In the example below, match_targetA
will treat all values < 45 and > 55 as
equally bad, while match_targetB
is more forgiving in that it chooses a bell curve
transformation instead of a triangular one, and also uses a wider interval of bounds.
Both targets are configured such that the midpoint of bounds
(in this case 50)
becomes the optimal value:
from baybe.targets import NumericalTarget, TargetMode, TargetTransformation
match_targetA = NumericalTarget(
name="Target_3A",
mode=TargetMode.MATCH,
bounds=(45, 55), # mandatory in MATCH mode
transformation=TargetTransformation.TRIANGULAR, # optional, applied if bounds are not None
)
match_targetB = NumericalTarget(
name="Target_3B",
mode="MATCH",
bounds=(0, 100), # mandatory in MATCH mode
transformation="BELL", # can also be provided as TargetTransformation.BELL
)
Targets are used in nearly all examples.
Limitations¶
Important
At the moment, BayBE’s only option for targets is the NumericalTarget
.
This enables many use cases due to the real-valued nature of most measurements.
But it can also be used to model categorical targets if they are ordinal.
For example: If your experimental outcome is a categorical ranking into “bad”,
“mediocre” and “good”, you could use a NumericalTarget with bounds (1, 3), where the
categories correspond to values 1, 2 and 3 respectively.
If your target category is not ordinal, the transformation into a numerical target is
not straightforward, which is a current limitation of BayBE.
We are looking into adding more target options in the future.