ax.storage¶
JSON¶
ax.storage.json_store.decoder module¶
-
ax.storage.json_store.decoder.
experiment_from_json
(object_json)[source]¶ Load Ax Experiment from JSON.
Return type: Experiment
-
ax.storage.json_store.decoder.
generator_run_from_json
(object_json)[source]¶ Load Ax GeneratorRun from JSON.
Return type: GeneratorRun
-
ax.storage.json_store.decoder.
object_from_json
(object_json)[source]¶ Recursively load objects from a JSON-serializable dictionary.
Return type: Any
-
ax.storage.json_store.decoder.
parameter_constraints_from_json
(parameter_constraint_json, parameters)[source]¶ Load ParameterConstraints from JSON.
Order and SumConstraint are tied to a search space, and require that SearchSpace’s parameters to be passed in for decoding.
Parameters: Returns: Python classes for parameter constraints.
Return type: parameter_constraints
-
ax.storage.json_store.decoder.
search_space_from_json
(search_space_json)[source]¶ Load a SearchSpace from JSON.
This function is necessary due to the coupled loading of SearchSpace and parameter constraints.
Return type: SearchSpace
-
ax.storage.json_store.decoder.
simple_experiment_from_json
(object_json)[source]¶ Load AE SimpleExperiment from JSON.
Return type: SimpleExperiment
ax.storage.json_store.decoders module¶
-
ax.storage.json_store.decoders.
batch_trial_from_json
(experiment, index, trial_type, status, time_created, time_completed, time_staged, time_run_started, abandoned_reason, run_metadata, generator_run_structs, runner, abandoned_arms_metadata, num_arms_created, status_quo, status_quo_weight)[source]¶ Load Ax BatchTrial from JSON.
Other classes don’t need explicit deserializers, because we can just use their constructors (see decoder.py). However, the constructor for Batch does not allow us to exactly recreate an existing object.
Return type: BatchTrial
-
ax.storage.json_store.decoders.
trial_from_json
(experiment, index, trial_type, status, time_created, time_completed, time_staged, time_run_started, abandoned_reason, run_metadata, generator_run, runner, num_arms_created)[source]¶ Load Ax trial from JSON.
Other classes don’t need explicit deserializers, because we can just use their constructors (see decoder.py). However, the constructor for Trial does not allow us to exactly recreate an existing object.
Return type: Trial
ax.storage.json_store.encoder module¶
-
ax.storage.json_store.encoder.
object_to_json
(object)[source]¶ Convert an Ax object to a JSON-serializable dictionary.
The root node passed to this function should always be an instance of a core Ax class. The sub-fields of this object will then be recursively passed to this function.
e.g. if we pass an instance of Experiment, we will first fall through to the line object_dict = ENCODER_REGISTRY[_type](object), which will convert the Experiment to a (shallow) dictionary, where search subfield remains “unconverted”, i.e.: {“name”: <name: string>, “search_space”: <search space: SearchSpace>}. We then pass each item of the dictionary back into this function to recursively convert the entire object.
Return type: Any
ax.storage.json_store.encoders module¶
-
ax.storage.json_store.encoders.
arm_to_dict
(arm)[source]¶ Convert Ax arm to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
batch_to_dict
(batch)[source]¶ Convert Ax batch to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
choice_parameter_to_dict
(parameter)[source]¶ Convert Ax choice parameter to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
data_to_dict
(data)[source]¶ Convert Ax data to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
experiment_to_dict
(experiment)[source]¶ Convert Ax experiment to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
fixed_parameter_to_dict
(parameter)[source]¶ Convert Ax fixed parameter to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
generator_run_to_dict
(generator_run)[source]¶ Convert Ax generator run to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
metric_to_dict
(metric)[source]¶ Convert Ax metric to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
objective_to_dict
(objective)[source]¶ Convert Ax objective to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
optimization_config_to_dict
(optimization_config)[source]¶ Convert Ax optimization config to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
order_parameter_constraint_to_dict
(parameter_constraint)[source]¶ Convert Ax order parameter constraint to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
outcome_constraint_to_dict
(outcome_constraint)[source]¶ Convert Ax outcome constraint to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
parameter_constraint_to_dict
(parameter_constraint)[source]¶ Convert Ax sum parameter constraint to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
range_parameter_to_dict
(parameter)[source]¶ Convert Ax range parameter to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
runner_to_dict
(runner)[source]¶ Convert Ax synthetic runner to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
search_space_to_dict
(search_space)[source]¶ Convert Ax search space to a dictionary.
Return type: Dict
[str
,Any
]
-
ax.storage.json_store.encoders.
simple_experiment_to_dict
(experiment)[source]¶ Convert AE simple experiment to a dictionary.
Return type: Dict
[str
,Any
]
ax.storage.json_store.load module¶
-
ax.storage.json_store.load.
load_experiment
(filepath)[source]¶ Load experiment from file.
- Read file.
- Convert dictionary to Ax experiment instance.
Return type: Experiment
ax.storage.json_store.registry module¶
SQLAlchemy (MySQL / SQLite)¶
ax.storage.sqa_store.base_decoder module¶
-
class
ax.storage.sqa_store.decoder.
Decoder
(config)[source]¶ Bases:
object
Class that contains methods for loading an Ax experiment from SQLAlchemy.
Instantiate with an instance of Config to customize the functionality. For even more flexibility, create a subclass.
-
config
¶ Metadata needed to save and load an experiment to SQLAlchemy.
-
abandoned_arm_from_sqa
(abandoned_arm_sqa)[source]¶ Convert SQLAlchemy AbandonedArm to Ax AbandonedArm.
Return type: AbandonedArm
-
experiment_from_sqa
(experiment_sqa)[source]¶ Convert SQLAlchemy Experiment to Ax Experiment.
Return type: Experiment
-
generator_run_from_sqa
(generator_run_sqa)[source]¶ Convert SQLAlchemy GeneratorRun to Ax GeneratorRun.
Return type: GeneratorRun
-
get_enum_name
(value, enum)[source]¶ Given an enum value (int) and an enum (of ints), return the corresponding enum name. If the value is not present in the enum, throw an error.
Return type: Optional
[str
]
-
get_init_args_from_properties
(object_sqa, class_)[source]¶ Given a SQAAlchemy instance with a properties blob, extract the arguments required for its class’s initializer.
Return type: Dict
[str
,Any
]
-
metric_from_sqa
(metric_sqa)[source]¶ Convert SQLAlchemy Metric to Ax Metric, Objective, or OutcomeConstraint.
Return type: Union
[Metric
,Objective
,OutcomeConstraint
]
-
opt_config_and_tracking_metrics_from_sqa
(metrics_sqa)[source]¶ Convert a list of SQLAlchemy Metrics to a a tuple of Ax OptimizationConfig and tracking metrics.
Return type: Tuple
[Optional
[OptimizationConfig
],List
[Metric
]]
-
parameter_constraint_from_sqa
(parameter_constraint_sqa, parameters)[source]¶ Convert SQLAlchemy ParameterConstraint to Ax ParameterConstraint.
Return type: ParameterConstraint
-
parameter_from_sqa
(parameter_sqa)[source]¶ Convert SQLAlchemy Parameter to Ax Parameter.
Return type: Parameter
-
search_space_from_sqa
(parameters_sqa, parameter_constraints_sqa)[source]¶ Convert a list of SQLAlchemy Parameters and ParameterConstraints to an Ax SearchSpace.
Return type: Optional
[SearchSpace
]
-
ax.storage.sqa_store.base_encoder module¶
-
class
ax.storage.sqa_store.encoder.
Encoder
(config)[source]¶ Bases:
object
Class that contains methods for storing an Ax experiment to SQLAlchemy.
Instantiate with an instance of Config to customize the functionality. For even more flexibility, create a subclass.
-
config
¶ Metadata needed to save and load an experiment to SQLAlchemy.
-
abandoned_arm_to_sqa
(abandoned_arm)[source]¶ Convert Ax AbandonedArm to SQLAlchemy.
Return type: SQAAbandonedArm
-
data_to_sqa
(data, trial_index, timestamp)[source]¶ Convert AE data to SQLAlchemy.
Return type: SQAData
-
experiment_to_sqa
(experiment)[source]¶ Convert Ax Experiment to SQLAlchemy.
In addition to creating and storing a new Experiment object, we need to create and store copies of the Trials, Metrics, Parameters, ParameterConstraints, and Runner owned by this Experiment.
Return type: SQAExperiment
-
generator_run_to_sqa
(generator_run, weight=None)[source]¶ Convert Ax GeneratorRun to SQLAlchemy.
In addition to creating and storing a new GeneratorRun object, we need to create and store copies of the Arms, Metrics, Parameters, and ParameterConstraints owned by this GeneratorRun.
Return type: SQAGeneratorRun
-
get_enum_value
(value, enum)[source]¶ Given an enum name (string) and an enum (of ints), return the corresponding enum value. If the name is not present in the enum, throw an error.
Return type: Optional
[int
]
-
get_metric_type_and_properties
(metric)[source]¶ Given an Ax Metric, convert its type into a member of MetricType enum, and construct a dictionary to be stored in the database properties json blob.
Return type: Tuple
[int
,Dict
[str
,Any
]]
-
optimization_config_to_sqa
(optimization_config)[source]¶ Convert Ax OptimizationConfig to a list of SQLAlchemy Metrics.
Return type: List
[SQAMetric
]
-
outcome_constraint_to_sqa
(outcome_constraint)[source]¶ Convert Ax OutcomeConstraint to SQLAlchemy.
Return type: SQAMetric
-
parameter_constraint_to_sqa
(parameter_constraint)[source]¶ Convert Ax ParameterConstraint to SQLAlchemy.
Return type: SQAParameterConstraint
-
parameter_to_sqa
(parameter)[source]¶ Convert Ax Parameter to SQLAlchemy.
Return type: SQAParameter
-
search_space_to_sqa
(search_space)[source]¶ Convert Ax SearchSpace to a list of SQLAlchemy Parameters and ParameterConstraints.
Return type: Tuple
[List
[SQAParameter
],List
[SQAParameterConstraint
]]
-
ax.storage.sqa_store.db module¶
-
class
ax.storage.sqa_store.db.
SQABase
[source]¶ Bases:
object
Metaclass for SQLAlchemy classes corresponding to core Ax classes.
-
attributes
¶ Return a list of the column attributes and relationship fields on this SQABase instance. Used for iterating over the fields to determine equality, perform updates, etc.
-
equals
(other)¶
-
fields_equal
(other, field)[source]¶ Check if field on self is equal to field on other.
Return type: bool
-
static
list_equals
(l1, l2)[source]¶ Compare equality of two lists.
- Assumptions:
- – The lists do not contain duplicates
Checking equality is then the same as checking that the lists are the same length, and that one is a subset of the other.
Return type: bool
-
static
list_update
(l1, l2)[source]¶ - Given an existing list (l1) and an new version (l2):
- – update the existing items in l1 that have matching items in l2 – delete existing items in l1 that don’t have matching items in l2 – add items in l2 that don’t exist in l1
- e.g. list_update([1,2,3], [1,5]) => [1,5]
- list_update([Arm(name=”0_0”)], [Arm(name=”0_0”), Arm(name=”0_1”)]) =>
- [Arm(name=”0_0”), Arm(name=”0_1”)] where Arm(name=”0_0”) has been updated, not replaced, so that we don’t delete/recreate the DB row
Return type: List
[~T]
-
-
ax.storage.sqa_store.db.
create_all_tables
(engine)[source]¶ Create all tables that inherit from Base.
Parameters: engine ( Engine
) – a SQLAlchemy engine with a connection to a MySQL or SQLite DB.Note
In order for all tables to be correctly created, all modules that define a mapped class that inherits from Base must be imported.
Return type: None
-
ax.storage.sqa_store.db.
create_mysql_engine_from_creator
(creator, echo=False, pool_recycle=10, **kwargs)[source]¶ Create a SQLAlchemy engine with the MySQL dialect given a creator function.
Parameters: Returns: SQLAlchemy engine with connection to MySQL DB.
Return type: Engine
-
ax.storage.sqa_store.db.
create_mysql_engine_from_url
(url, echo=False, pool_recycle=10, **kwargs)[source]¶ Create a SQLAlchemy engine with the MySQL dialect given a database url.
Parameters: - url (
str
) – a database url that can include username, password, hostname, database name as well as optional keyword arguments for additional configuration. e.g. dialect+driver://username:password@host:port/database. - echo (
bool
) – if True, set engine to be verbose. - pool_recycle (
int
) – number of seconds after which to recycle connections. -1 means no timeout. Default is 10 seconds. - **kwargs – keyword args passed to create_engine
Returns: SQLAlchemy engine with connection to MySQL DB.
Return type: Engine
- url (
-
ax.storage.sqa_store.db.
create_test_engine
(path=None, echo=True)[source]¶ Creates a SQLAlchemy engine object for use in unit tests.
Parameters: Returns: an instance of SQLAlchemy engine.
Return type: Engine
-
ax.storage.sqa_store.db.
get_engine
()[source]¶ Fetch a SQLAlchemy engine, if already initialized.
If not initialized, need to either call init_engine_and_session_factory or get_session explicitly.
Returns: an instance of a SQLAlchemy engine with a connection to a DB. Return type: Engine
-
ax.storage.sqa_store.db.
get_session
()[source]¶ Fetch a SQLAlchemy session with a connection to a DB.
Unless init_engine_and_session_factory is called first with custom args, this will automatically initialize a connection to xdb.adaptive_experiment.
Returns: an instance of a SQLAlchemy session. Return type: Session
-
ax.storage.sqa_store.db.
init_engine_and_session_factory
(url=None, creator=None, echo=False, force_init=False, **kwargs)[source]¶ Initialize the global engine and SESSION_FACTORY for SQLAlchemy.
The initialization needs to only happen once. Note that it is possible to re-initialize the engine by setting the force_init flag to True, but this should only be used if you are absolutely certain that you know what you are doing.
Parameters: - url (
Optional
[str
]) – a database url that can include username, password, hostname, database name as well as optional keyword arguments for additional configuration. e.g. dialect+driver://username:password@host:port/database. Either this argument or creator argument must be specified. - creator (
Optional
[Callable
]) – a callable which returns a DBAPI connection. Either this argument or url argument must be specified. - echo (
bool
) – if True, logging for engine is enabled. - force_init (
bool
) – if True, allows re-initializing engine and session factory. - **kwargs – keyword arguments passed to create_mysql_engine_from_creator
Return type: None
- url (
-
ax.storage.sqa_store.db.
init_test_engine_and_session_factory
(tier_or_path=None, echo=False, force_init=False, **kwargs)[source]¶ Initialize the global engine and SESSION_FACTORY for SQLAlchemy, using an in-memory SQLite database.
The initialization needs to only happen once. Note that it is possible to re-initialize the engine by setting the force_init flag to True, but this should only be used if you are absolutely certain that you know what you are doing.
Parameters: Return type: None
ax.storage.sqa_store.json module¶
-
class
ax.storage.sqa_store.json.
JSONEncodedObject
(object_pairs_hook=None, *args, **kwargs)[source]¶ Bases:
sqlalchemy.sql.type_api.TypeDecorator
Class for JSON-encoding objects in SQLAlchemy.
Represents an object that is automatically marshalled and unmarshalled to/from the corresponding JSON string. By itself, this data structure does not track any changes.
-
impl
= VARCHAR(length=4096)¶
-
process_bind_param
(value, dialect)[source]¶ Receive a bound parameter value to be converted.
Subclasses override this method to return the value that should be passed along to the underlying
TypeEngine
object, and from there to the DBAPIexecute()
method.The operation could be anything desired to perform custom behavior, such as transforming or serializing data. This could also be used as a hook for validating logic.
This operation should be designed with the reverse operation in mind, which would be the process_result_value method of this class.
Parameters: Return type:
-
process_result_value
(value, dialect)[source]¶ Receive a result-row column value to be converted.
Subclasses should implement this method to operate on data fetched from the database.
Subclasses override this method to return the value that should be passed back to the application, given a value that is already processed by the underlying
TypeEngine
object, originally from the DBAPI cursor methodfetchone()
or similar.The operation could be anything desired to perform custom behavior, such as transforming or serializing data. This could also be used as a hook for validating logic.
Parameters: This operation should be designed to be reversible by the “process_bind_param” method of this class.
Return type: Any
-
-
class
ax.storage.sqa_store.json.
JSONEncodedText
(object_pairs_hook=None, *args, **kwargs)[source]¶ Bases:
ax.storage.sqa_store.json.JSONEncodedObject
Class for JSON-encoding objects in SQLAlchemy, backed by TEXT (MySQL).
See description in JSONEncodedObject.
-
impl
¶ alias of
sqlalchemy.sql.sqltypes.Text
-
ax.storage.sqa_store.load module¶
-
ax.storage.sqa_store.load.
load_experiment
(experiment_name, config=None)[source]¶ Load experiment by name (uses default SQAConfig).
Return type: Experiment
ax.storage.sqa_store.save module¶
ax.storage.sqa_store.sqa_classes module¶
-
class
ax.storage.sqa_store.sqa_classes.
SQAAbandonedArm
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
abandoned_reason
= Column(None, String(length=255), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['name', 'time_abandoned']¶
-
name
= Column(None, String(length=100), table=None, nullable=False)¶
-
time_abandoned
= Column(None, IntTimestamp(), table=None, nullable=False, default=ColumnDefault(<function datetime.now>))¶
-
trial_id
= Column(None, Integer(), ForeignKey('trial_v2.id'), table=None)¶
-
unique_id
= 'name'¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAArm
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
generator_run_id
= Column(None, Integer(), ForeignKey('generator_run_v2.id'), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['parameters']¶
-
name
= Column(None, String(length=100), table=None)¶
-
parameters
= Column(None, JSONEncodedText(), table=None, nullable=False)¶
-
unique_id
= 'name'¶
-
weight
= Column(None, Float(), table=None, nullable=False, default=ColumnDefault(1.0))¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAData
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
data_json
= Column(None, Text(), table=None, nullable=False)¶
-
description
= Column(None, String(length=255), table=None)¶
-
experiment_id
= Column(None, Integer(), ForeignKey('experiment_v2.id'), table=None, nullable=False)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
time_created
= Column(None, BigInteger(), table=None, nullable=False)¶
-
trial_index
= Column(None, Integer(), table=None)¶
-
unique_id
= 'time_created'¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAExperiment
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
data
= <RelationshipProperty at 0x1a2bc5ed48; no key>¶
-
description
= Column(None, String(length=255), table=None)¶
-
experiment_type
= Column(None, Integer(), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['name', 'time_created']¶
-
is_test
= Column(None, Boolean(), table=None, nullable=False, default=ColumnDefault(False))¶
-
metrics
= <RelationshipProperty at 0x1a2bc5edc8; no key>¶
-
name
= Column(None, String(length=100), table=None, nullable=False)¶
-
parameter_constraints
= <RelationshipProperty at 0x1a2bc5eec8; no key>¶
-
parameters
= <RelationshipProperty at 0x1a2bc5ee48; no key>¶
-
properties
= Column(None, JSONEncodedText(), table=None, default=ColumnDefault({}))¶
-
runner
= <RelationshipProperty at 0x1a2bc5ef48; no key>¶
-
status_quo_name
= Column(None, String(length=100), table=None)¶
-
status_quo_parameters
= Column(None, JSONEncodedText(), table=None)¶
-
time_created
= Column(None, IntTimestamp(), table=None, nullable=False)¶
-
trials
= <RelationshipProperty at 0x1a2bc6d048; no key>¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAGeneratorRun
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
arms
= <RelationshipProperty at 0x1a2bc48cc8; no key>¶
-
best_arm_name
= Column(None, String(length=100), table=None)¶
-
best_arm_parameters
= Column(None, JSONEncodedText(), table=None)¶
-
best_arm_predictions
= Column(None, JSONEncodedObject(length=4096), table=None)¶
-
fit_time
= Column(None, Float(), table=None)¶
-
gen_time
= Column(None, Float(), table=None)¶
-
generator_run_type
= Column(None, Integer(), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['time_created']¶
-
index
= Column(None, Integer(), table=None)¶
-
metrics
= <RelationshipProperty at 0x1a2bc48d48; no key>¶
-
model_predictions
= Column(None, JSONEncodedObject(length=4096), table=None)¶
-
parameter_constraints
= <RelationshipProperty at 0x1a2bc48e48; no key>¶
-
parameters
= <RelationshipProperty at 0x1a2bc48dc8; no key>¶
-
time_created
= Column(None, IntTimestamp(), table=None, nullable=False, default=ColumnDefault(<function datetime.now>))¶
-
trial_id
= Column(None, Integer(), ForeignKey('trial_v2.id'), table=None)¶
-
unique_id
= 'index'¶
-
weight
= Column(None, Float(), table=None)¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAMetric
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
bound
= Column(None, Float(), table=None)¶
-
experiment_id
= Column(None, Integer(), ForeignKey('experiment_v2.id'), table=None)¶
-
generator_run_id
= Column(None, Integer(), ForeignKey('generator_run_v2.id'), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['name', 'metric_type']¶
-
intent
= Column(None, StringEnum(length=100), table=None, nullable=False)¶
-
lower_is_better
= Column(None, Boolean(), table=None)¶
-
metric_type
= Column(None, Integer(), table=None, nullable=False)¶
-
minimize
= Column(None, Boolean(), table=None)¶
-
name
= Column(None, String(length=255), table=None, nullable=False)¶
-
op
= Column(None, IntEnum(), table=None)¶
-
properties
= Column(None, JSONEncodedText(), table=None, default=ColumnDefault({}))¶
-
relative
= Column(None, Boolean(), table=None)¶
-
unique_id
= 'name'¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAParameter
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
choice_values
= Column(None, JSONEncodedObject(length=4096), table=None)¶
-
digits
= Column(None, Integer(), table=None)¶
-
domain_type
= Column(None, IntEnum(), table=None, nullable=False)¶
-
experiment_id
= Column(None, Integer(), ForeignKey('experiment_v2.id'), table=None)¶
-
fixed_value
= Column(None, JSONEncodedObject(length=4096), table=None)¶
-
generator_run_id
= Column(None, Integer(), ForeignKey('generator_run_v2.id'), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['name', 'parameter_type']¶
-
is_ordered
= Column(None, Boolean(), table=None)¶
-
is_task
= Column(None, Boolean(), table=None)¶
-
log_scale
= Column(None, Boolean(), table=None)¶
-
lower
= Column(None, Float(), table=None)¶
-
name
= Column(None, String(length=100), table=None, nullable=False)¶
-
parameter_type
= Column(None, IntEnum(), table=None, nullable=False)¶
-
unique_id
= 'name'¶
-
upper
= Column(None, Float(), table=None)¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQAParameterConstraint
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
bound
= Column(None, Float(), table=None, nullable=False)¶
-
constraint_dict
= Column(None, JSONEncodedObject(length=4096), table=None, nullable=False)¶
-
experiment_id
= Column(None, Integer(), ForeignKey('experiment_v2.id'), table=None)¶
-
generator_run_id
= Column(None, Integer(), ForeignKey('generator_run_v2.id'), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['type', 'constraint_dict', 'bound']¶
-
type
= Column(None, IntEnum(), table=None, nullable=False)¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQARunner
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
experiment_id
= Column(None, Integer(), ForeignKey('experiment_v2.id'), table=None)¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
properties
= Column(None, JSONEncodedText(), table=None, default=ColumnDefault({}))¶
-
runner_type
= Column(None, Integer(), table=None, nullable=False)¶
-
trial_id
= Column(None, Integer(), ForeignKey('trial_v2.id'), table=None)¶
-
-
class
ax.storage.sqa_store.sqa_classes.
SQATrial
(*args, **kwargs)[source]¶ Bases:
sphinx.ext.autodoc.importer._MockObject
-
abandoned_arms
= <RelationshipProperty at 0x1a2bc5e948; no key>¶
-
abandoned_reason
= Column(None, String(length=100), table=None)¶
-
experiment_id
= Column(None, Integer(), ForeignKey('experiment_v2.id'), table=None)¶
-
generator_runs
= <RelationshipProperty at 0x1a2bc5e9c8; no key>¶
-
id
= Column(None, Integer(), table=None, primary_key=True, nullable=False)¶
-
immutable_fields
= ['is_batch', 'time_created']¶
-
index
= Column(None, Integer(), table=None, nullable=False)¶
-
is_batch
= Column('is_batched', Boolean(), table=None, nullable=False, default=ColumnDefault(True))¶
-
num_arms_created
= Column(None, Integer(), table=None, nullable=False, default=ColumnDefault(0))¶
-
run_metadata
= Column(None, JSONEncodedText(), table=None)¶
-
runner
= <RelationshipProperty at 0x1a2bc5ea48; no key>¶
-
status
= Column(None, IntEnum(), table=None, nullable=False, default=ColumnDefault(<TrialStatus.CANDIDATE: 0>))¶
-
status_quo_name
= Column(None, String(length=100), table=None)¶
-
time_completed
= Column(None, IntTimestamp(), table=None)¶
-
time_created
= Column(None, IntTimestamp(), table=None, nullable=False)¶
-
time_run_started
= Column(None, IntTimestamp(), table=None)¶
-
time_staged
= Column(None, IntTimestamp(), table=None)¶
-
trial_type
= Column(None, String(length=100), table=None)¶
-
unique_id
= 'index'¶
-
ax.storage.sqa_store.sqa_enum module¶
-
class
ax.storage.sqa_store.sqa_enum.
BaseNullableEnum
(enum, *arg, **kw)[source]¶ Bases:
sqlalchemy.sql.type_api.TypeDecorator
-
process_bind_param
(value, dialect)[source]¶ Receive a bound parameter value to be converted.
Subclasses override this method to return the value that should be passed along to the underlying
TypeEngine
object, and from there to the DBAPIexecute()
method.The operation could be anything desired to perform custom behavior, such as transforming or serializing data. This could also be used as a hook for validating logic.
This operation should be designed with the reverse operation in mind, which would be the process_result_value method of this class.
Parameters: Return type:
-
process_result_value
(value, dialect)[source]¶ Receive a result-row column value to be converted.
Subclasses should implement this method to operate on data fetched from the database.
Subclasses override this method to return the value that should be passed back to the application, given a value that is already processed by the underlying
TypeEngine
object, originally from the DBAPI cursor methodfetchone()
or similar.The operation could be anything desired to perform custom behavior, such as transforming or serializing data. This could also be used as a hook for validating logic.
Parameters: This operation should be designed to be reversible by the “process_bind_param” method of this class.
Return type: Any
-
-
class
ax.storage.sqa_store.sqa_enum.
IntEnum
(enum, *arg, **kw)[source]¶ Bases:
ax.storage.sqa_store.sqa_enum.BaseNullableEnum
-
impl
¶ alias of
sqlalchemy.sql.sqltypes.SmallInteger
-
-
class
ax.storage.sqa_store.sqa_enum.
StringEnum
(enum, *arg, **kw)[source]¶ Bases:
ax.storage.sqa_store.sqa_enum.BaseNullableEnum
-
impl
= VARCHAR(length=100)¶
-
ax.storage.sqa_store.timestamp module¶
-
class
ax.storage.sqa_store.timestamp.
IntTimestamp
(*args, **kwargs)[source]¶ Bases:
sqlalchemy.sql.type_api.TypeDecorator
-
impl
¶ alias of
sqlalchemy.sql.sqltypes.Integer
-
process_bind_param
(value, dialect)[source]¶ Receive a bound parameter value to be converted.
Subclasses override this method to return the value that should be passed along to the underlying
TypeEngine
object, and from there to the DBAPIexecute()
method.The operation could be anything desired to perform custom behavior, such as transforming or serializing data. This could also be used as a hook for validating logic.
This operation should be designed with the reverse operation in mind, which would be the process_result_value method of this class.
Parameters: Return type:
-
process_result_value
(value, dialect)[source]¶ Receive a result-row column value to be converted.
Subclasses should implement this method to operate on data fetched from the database.
Subclasses override this method to return the value that should be passed back to the application, given a value that is already processed by the underlying
TypeEngine
object, originally from the DBAPI cursor methodfetchone()
or similar.The operation could be anything desired to perform custom behavior, such as transforming or serializing data. This could also be used as a hook for validating logic.
Parameters: This operation should be designed to be reversible by the “process_bind_param” method of this class.
Return type: Optional
[datetime
]
-
ax.storage.sqa_store.utils module¶
ax.storage.sqa_store.validation module¶
-
ax.storage.sqa_store.validation.
consistency_exactly_one
(instance, exactly_one_fields)[source]¶ Ensure that exactly one of exactly_one_fields has a value set.
Return type: Any
-
ax.storage.sqa_store.validation.
validate_metric
(mapper, connection, target)[source]¶ Return type: None
-
ax.storage.sqa_store.validation.
validate_parameter
(mapper, connection, target)[source]¶ Return type: None
Registries¶
Utilities¶
-
class
ax.storage.utils.
DomainType
[source]¶ Bases:
enum.Enum
Class for enumerating domain types.
-
CHOICE
= 2¶
-
FIXED
= 0¶
-
RANGE
= 1¶
-
-
class
ax.storage.utils.
EncodeDecodeFieldsMap
(python_only, encoded_only, python_to_encoded)[source]¶ Bases:
tuple
-
encoded_only
¶ Alias for field number 1
-
python_only
¶ Alias for field number 0
-
python_to_encoded
¶ Alias for field number 2
-
-
class
ax.storage.utils.
MetricIntent
[source]¶ Bases:
enum.Enum
Class for enumerating metric use types.
-
OBJECTIVE
= 'objective'¶
-
OUTCOME_CONSTRAINT
= 'outcome_constraint'¶
-
TRACKING
= 'tracking'¶
-
-
class
ax.storage.utils.
ParameterConstraintType
[source]¶ Bases:
enum.Enum
Class for enumerating parameter constraint types.
Linear constraint is base type whereas other constraint types are special types of linear constraints.
-
LINEAR
= 0¶
-
ORDER
= 1¶
-
SUM
= 2¶
-