Serialization utilities
- 원본 링크 : https://keras.io/api/models/model_saving_apis/serialization_utils/
- 최종 확인 : 2024-11-24
serialize_keras_object
function
keras.saving.serialize_keras_object(obj)
Retrieve the config dict by serializing the Keras object.
serialize_keras_object()
serializes a Keras object to a python dictionary that represents the object, and is a reciprocal function of deserialize_keras_object()
. See deserialize_keras_object()
for more information about the config format.
Arguments
- obj: the Keras object to serialize.
Returns
A python dict that represents the object. The python dict can be deserialized via deserialize_keras_object()
.
deserialize_keras_object
function
keras.saving.deserialize_keras_object(
config, custom_objects=None, safe_mode=True, **kwargs
)
Retrieve the object by deserializing the config dict.
The config dict is a Python dictionary that consists of a set of key-value pairs, and represents a Keras object, such as an Optimizer
, Layer
, Metrics
, etc. The saving and loading library uses the following keys to record information of a Keras object:
class_name
: String. This is the name of the class, as exactly defined in the source code, such as “LossesContainer”.config
: Dict. Library-defined or user-defined key-value pairs that store the configuration of the object, as obtained byobject.get_config()
.module
: String. The path of the python module. Built-in Keras classes expect to have prefixkeras
.registered_name
: String. The key the class is registered under viakeras.saving.register_keras_serializable(package, name)
API. The key has the format of ‘{package}>{name}’, wherepackage
andname
are the arguments passed toregister_keras_serializable()
. Ifname
is not provided, it uses the class name. Ifregistered_name
successfully resolves to a class (that was registered), theclass_name
andconfig
values in the dict will not be used.registered_name
is only used for non-built-in classes.
For example, the following dictionary represents the built-in Adam optimizer with the relevant config:
dict_structure = {
"class_name": "Adam",
"config": {
"amsgrad": false,
"beta_1": 0.8999999761581421,
"beta_2": 0.9990000128746033,
"decay": 0.0,
"epsilon": 1e-07,
"learning_rate": 0.0010000000474974513,
"name": "Adam"
},
"module": "keras.optimizers",
"registered_name": None
}
# Returns an `Adam` instance identical to the original one.
deserialize_keras_object(dict_structure)
If the class does not have an exported Keras namespace, the library tracks it by its module
and class_name
. For example:
dict_structure = {
"class_name": "MetricsList",
"config": {
...
},
"module": "keras.trainers.compile_utils",
"registered_name": "MetricsList"
}
# Returns a `MetricsList` instance identical to the original one.
deserialize_keras_object(dict_structure)
And the following dictionary represents a user-customized MeanSquaredError
loss:
@keras.saving.register_keras_serializable(package='my_package')
class ModifiedMeanSquaredError(keras.losses.MeanSquaredError):
...
dict_structure = {
"class_name": "ModifiedMeanSquaredError",
"config": {
"fn": "mean_squared_error",
"name": "mean_squared_error",
"reduction": "auto"
},
"registered_name": "my_package>ModifiedMeanSquaredError"
}
# Returns the `ModifiedMeanSquaredError` object
deserialize_keras_object(dict_structure)
Arguments
- config: Python dict describing the object.
- custom_objects: Python dict containing a mapping between custom object names the corresponding classes or functions.
- safe_mode: Boolean, whether to disallow unsafe
lambda
deserialization. Whensafe_mode=False
, loading an object has the potential to trigger arbitrary code execution. This argument is only applicable to the Keras v3 model format. Defaults toTrue
.
Returns
The object described by the config
dictionary.
CustomObjectScope
class
keras.saving.custom_object_scope(custom_objects)
Exposes custom classes/functions to Keras deserialization internals.
Under a scope with custom_object_scope(objects_dict)
, Keras methods such as keras.models.load_model()
or keras.models.model_from_config()
will be able to deserialize any custom object referenced by a saved config (e.g. a custom layer or metric).
Example
Consider a custom regularizer my_regularizer
:
layer = Dense(3, kernel_regularizer=my_regularizer)
# Config contains a reference to `my_regularizer`
config = layer.get_config()
...
# Later:
with custom_object_scope({'my_regularizer': my_regularizer}):
layer = Dense.from_config(config)
Arguments
- custom_objects: Dictionary of
{str: object}
pairs, where thestr
key is the object name.
get_custom_objects
function
keras.saving.get_custom_objects()
Retrieves a live reference to the global dictionary of custom objects.
Custom objects set using custom_object_scope()
are not added to the global dictionary of custom objects, and will not appear in the returned dictionary.
Example
get_custom_objects().clear()
get_custom_objects()['MyObject'] = MyObject
Returns
Global dictionary mapping registered class names to classes.
register_keras_serializable
function
keras.saving.register_keras_serializable(package="Custom", name=None)
Registers an object with the Keras serialization framework.
This decorator injects the decorated class or function into the Keras custom object dictionary, so that it can be serialized and deserialized without needing an entry in the user-provided custom object dict. It also injects a function that Keras will call to get the object’s serializable string key.
Note that to be serialized and deserialized, classes must implement the get_config()
method. Functions do not have this requirement.
The object will be registered under the key 'package>name'
where name
, defaults to the object name if not passed.
Example
# Note that `'my_package'` is used as the `package` argument here, and since
# the `name` argument is not provided, `'MyDense'` is used as the `name`.
@register_keras_serializable('my_package')
class MyDense(keras.layers.Dense):
pass
assert get_registered_object('my_package>MyDense') == MyDense
assert get_registered_name(MyDense) == 'my_package>MyDense'
Arguments
- package: The package that this class belongs to. This is used for the
key
(which is"package>name"
) to identify the class. Note that this is the first argument passed into the decorator. - name: The name to serialize this class under in this package. If not provided or
None
, the class’ name will be used (note that this is the case when the decorator is used with only one argument, which becomes thepackage
).
Returns
A decorator that registers the decorated class with the passed names.