In BoFire, all data model entities have a type assigned to them. This type directly impacts the properties required / allowed for these entities. For example, a feature can be of type CategoricalInput
or ContinuousOutput
(among others). Each of these types has a different json schema which describes the properties required in the entity's spec (a json string).
This API can be used to:
- get lists of available types (of available type groups)
- validate if entities comply with its schema
Every type, provided / managed by this API, has the following structure / properties:
{
"group": "group_key",
"key": "type_key",
"name": "Name of this type",
"description": "Description of this type",
"typeSchema": {
"json schema": "provided by the underlying pydantic model",
"this": "can be disregarded by the frontend (for now)."
},
}
All types are grouped into type groups (valid group_keys
), e.g., feature, variable, constraint, objective. To obtain a list of all valid group and type keys, simply send a GET request to the /keys
endpoint. The (potentially outdated) result is:
{
"feature": [
"DiscreteInput",
"CategoricalInput",
"ContinuousOutput",
"ContinuousInput",
"ContinuousDescriptorInput",
"CategoricalDescriptorInput",
"MolecularInput"
],
"constraint": [
"LinearEqualityConstraint",
"LinearInequalityConstraint",
"NonlinearEqualityConstraint",
"NonlinearInequalityConstraint",
"NChooseKConstraint"
],
"objective": [
"MaximizeObjective",
"MinimizeObjective",
"MaximizeSigmoidObjective",
"MinimizeSigmoidObjective",
"TargetObjective",
"CloseToTargetObjective"
],
"variable": [
"NumericalInput",
"NumericalOutput",
"CategoricalInput",
"CategoricalOutput",
"MolecularInput",
"MolecularOutput"
],
"acquisition-function": [
"qNEI",
"qEI",
"qSR",
"qUCB",
"qPI"
],
"kernel": [
"AdditiveKernel",
"MultiplicativeKernel",
"ScaleKernel",
"HammondDistanceKernel",
"LinearKernel",
"MaternKernel",
"RBFKernel"
],
"prior": [
"GammaPrior",
"NormalPrior"
],
"sampler": [
"PolytopeSampler",
"RejectionSampler"
],
"strategy": [
"SoboStrategy",
"AdditiveSoboStrategy",
"MultiplicativeSoboStrategy",
"QehviStrategy",
"QnehviStrategy",
"QparegoStrategy",
"PolytopeSampler",
"RejectionSampler",
"RandomStrategy"
],
"surrogate": [
"EmpiricalSurrogate",
"RandomForestSurrogate",
"SingleTaskGPSurrogate",
"MixedSingleTaskGPSurrogate",
"MLPEnsemble"
]
}
The types API provides the following endpoints:
Returns the keys of all known types, separated into groups.
Returns a dictionary of all known types, separated into groups.
Return all types of the specified group with status code 200.
If an invalid group_key
is provided, an error message with status code 404 is returned.
Return all types of the specified group with status code 200.
If an invalid group_key
or type_key
is provided, an error message with status code 404 is returned.
The data to validate against the typeSchema
must be specified in the request body, e.g.:
{
"name": "my feature"
}
If the data is valid according to the typeSchema
, the following result is returned:
{
"valid": true,
"details": "OK key='qwe' type='DiscreteInput' values=[1.0, 2.0, 3.0]"
}
If the data is invalid, the following result is returned:
{
"valid": false,
"details": "2 validation errors for DiscreteInput\nkey\n field required (type=value_error.missing)\nvalues\n field required (type=value_error.missing)"
}
If an invalid group_key
or type_key
is provided, an error message with status code 404 is returned.
{
"detail": "No type DiscreteInput_ for group feature exists."
}
The following environment variables can be used:
ADD_DUMMY_TYPES
(default: False)- set to True to add dummy types
- this is used / required for testing
Use the following command to set and run the API locally as well as run the unit tests.
pip install -r requirements.txt
export ADD_DUMMY_TYPES=True
uvicorn --app-dir app:app --reload
pytest