ContinuousCardinalityConstraint¶
- class baybe.constraints.continuous.ContinuousCardinalityConstraint[source]¶
Bases:
CardinalityConstraint
,ContinuousNonlinearConstraint
Class for continuous cardinality constraints.
Public methods
__init__
(parameters[, min_cardinality, ...])Method generated by attrs for class ContinuousCardinalityConstraint.
from_dict
(dictionary)Create an object from its dictionary representation.
from_json
(string)Create an object from its JSON representation.
get_absolute_thresholds
(bounds, /)Get the absolute thresholds for a given interval.
Get an iterator over all possible combinations of inactive parameters.
sample_inactive_parameters
([batch_size])Sample sets of inactive parameters according to the cardinality constraints.
summary
()Return a custom summarization of the constraint.
to_dict
()Create an object's dictionary representation.
to_json
()Create an object's JSON representation.
Public attributes and properties
A relative threshold for determining if a value is considered zero.
Class variable encoding whether the constraint could be considered during data augmentation.
Class variable encoding whether the condition is evaluated during creation.
Class variable encoding whether the condition is evaluated during modeling.
Boolean indicating if this is a constraint over continuous parameters.
Boolean indicating if this is a constraint over discrete parameters.
The maximum allowed cardinality.
The minimum required cardinality.
The number of possible inactive parameter combinations.
Class variable encoding whether the constraint is valid only for numerical parameters.
The list of parameters used for the constraint.
- __init__(parameters: list[str], min_cardinality: int = 0, max_cardinality: int = NOTHING, relative_threshold=0.001)¶
Method generated by attrs for class ContinuousCardinalityConstraint.
For details on the parameters, see Public attributes and properties.
- get_absolute_thresholds(bounds: Interval, /)[source]¶
Get the absolute thresholds for a given interval.
Turns the relative threshold of the constraint into absolute thresholds for the considered interval. That is, for a given interval
(a, b)
witha <= 0
andb >= 0
, the method returns the interval(r*a, r*b)
, wherer
is the relative threshold defined by the constraint.- Parameters:
bounds (
Interval
) – The specified interval.- Return type:
- Returns:
The absolute thresholds represented as an interval.
- Raises:
ValueError – When the specified interval does not contain zero.
- inactive_parameter_combinations()[source]¶
Get an iterator over all possible combinations of inactive parameters.
- sample_inactive_parameters(batch_size: int = 1)[source]¶
Sample sets of inactive parameters according to the cardinality constraints.
- to_json()¶
Create an object’s JSON representation.
- Return type:
- Returns:
The JSON representation as a string.
- eval_during_augmentation: ClassVar[bool] = False¶
Class variable encoding whether the constraint could be considered during data augmentation.
- eval_during_creation: ClassVar[bool] = False¶
Class variable encoding whether the condition is evaluated during creation.
- eval_during_modeling: ClassVar[bool] = True¶
Class variable encoding whether the condition is evaluated during modeling.
- property is_continuous: bool¶
Boolean indicating if this is a constraint over continuous parameters.
- max_cardinality: int¶
The maximum allowed cardinality.
- min_cardinality: int¶
The minimum required cardinality.
- property n_inactive_parameter_combinations: int¶
The number of possible inactive parameter combinations.
- numerical_only: ClassVar[bool] = True¶
Class variable encoding whether the constraint is valid only for numerical parameters.
- parameters: list[str]¶
The list of parameters used for the constraint.
- relative_threshold: float¶
A relative threshold for determining if a value is considered zero.
The threshold is translated into an asymmetric open interval around zero via
get_absolute_thresholds()
.Note: The interval induced by the threshold is considered open because numerical routines that optimize parameter values on the complementary set (i.e. the value range considered “nonzero”) may push the numerical value exactly to the interval boundary, which should therefore also be considered “nonzero”.