Home

Awesome

Machine Learning Model Extension Specification

hackmd-github-sync-badge

Contributors

<table> <tr> <td><img src="docs/static/crim.png" width="200px" alt="CRIM"></td> <td> <a href="https://www.crim.ca/en/">Computer Research Institute of Montréal</a> <br> <a href="https://www.crim.ca/fr/">Centre de Recherche Informatique de Montréal</a> </td> </tr> <tr> <td><img src="docs/static/wherobots.png" width="200px" alt="Wherobots"></td> <td><a href="https://wherobots.com/">Wherobots</a></td> </tr> <tr> <td><img src="docs/static/terradue.png" width="200px" alt="Terradue"></td> <td><a href="https://terradue.com/">Terradue</a></td> </tr> <tr> <td><img src="docs/static/nrcan.png" width="200px" alt="NRCan"></td> <td> <a href="https://natural-resources.canada.ca/">Natural Resources Canada</a> <br> <a href="https://natural-resources.canada.ca/research-centres-and-labs/canada-centre-for-mapping-and-earth-observation/25735"> Canada Centre for Mapping and Earth Observation (CCMEO) </a> </td> </tr> </table>

Description

The STAC Machine Learning Model (MLM) Extension provides a standard set of fields to describe machine learning models trained on overhead imagery and enable running model inference.

The main objectives of the extension are:

  1. to enable building model collections that can be searched alongside associated STAC datasets
  2. record all necessary bands, parameters, modeling artifact locations, and high-level processing steps to deploy an inference service.

Specifically, this extension records the following information to make ML models searchable and reusable:

  1. Sensor band specifications
  2. Model input transforms including resize and normalization
  3. Model output shape, data type, and its semantic interpretation
  4. An optional, flexible description of the runtime environment to be able to run the model
  5. Scientific references

The MLM specification is biased towards providing metadata fields for supervised machine learning models. However, fields that relate to supervised ML are optional and users can use the fields they need for different tasks.

STAC_MLM

<!-- lint disable -->

Francis Charette-Migneault, Ryan Avery, Brian Pondi, Joses Omojola, Simone Vaccari, Parham Membari, Devis Peressutti, Jia Yu, and Jed Sundwall. 2024. Machine Learning Model Specification for Cataloging Spatio-Temporal Models (Demo Paper). In 3rd ACM SIGSPATIAL International Workshop on Searching and Mining Large Collections of Geospatial Data (GeoSearch’24), October 29–November 1 2024, Atlanta, GA, USA. ACM, New York, NY, USA, 4 pages. https://doi.org/10.1145/3681769.3698586

<!-- lint enable -->

See Best Practices for guidance on what other STAC extensions you should use in conjunction with this extension.

The Machine Learning Model Extension purposely omits and delegates some definitions to other STAC extensions to favor reusability and avoid metadata duplication whenever possible. A properly defined MLM STAC Item/Collection should almost never have the Machine Learning Model Extension exclusively in stac_extensions.

For details about the earlier (legacy) version of the MLM Extension, formerly known as the Deep Learning Model Extension (DLM), please refer to the DLM LEGACY document. DLM was renamed to the current MLM Extension and refactored to form a cohesive definition across all machine learning approaches, regardless of whether the approach constitutes a deep neural network or other statistical approach. It also combines multiple definitions from the predecessor ML-Model extension to synthesize common use cases into a single reference for Machine Learning Models.

For more details about the stac-model Python package, which provides definitions of the MLM extension using both Pydantic and PySTAC connectors, please refer to the STAC Model document.

Resources

Item Properties and Collection Fields

The fields in the table below can be used in these parts of STAC documents:

Field NameTypeDescription
mlm:name <sup>[1]</sup>stringREQUIRED A name for the model. This can include, but must be distinct, from simply naming the model architecture. If there is a publication or other published work related to the model, use the official name of the model.
mlm:architectureModel Architecture stringREQUIRED A generic and well established architecture name of the model.
mlm:tasks[Task Enum]REQUIRED Specifies the Machine Learning tasks for which the model can be used for. If multi-tasks outputs are provided by distinct model heads, specify all available tasks under the main properties and specify respective tasks in each Model Output Object.
mlm:frameworkstringFramework used to train the model (ex: PyTorch, TensorFlow).
mlm:framework_versionstringThe framework library version. Some models require a specific version of the machine learning framework to run.
mlm:memory_sizeintegerThe in-memory size of the model on the accelerator during inference (bytes).
mlm:total_parametersintegerTotal number of model parameters, including trainable and non-trainable parameters.
mlm:pretrainedbooleanIndicates if the model was pretrained. If the model was pretrained, consider providing pretrained_source if it is known.
mlm:pretrained_sourcestring | nullThe source of the pretraining. Can refer to popular pretraining datasets by name (i.e. Imagenet) or less known datasets by URL and description. If trained from scratch (i.e.: pretrained = false), the null value should be set explicitly.
mlm:batch_size_suggestionintegerA suggested batch size for the accelerator and summarized hardware.
mlm:acceleratorAccelerator Type Enum | nullThe intended computational hardware that runs inference. If undefined or set to null explicitly, the model does not require any specific accelerator.
mlm:accelerator_constrainedbooleanIndicates if the intended accelerator is the only accelerator that can run inference. If undefined, it should be assumed false.
mlm:accelerator_summarystringA high level description of the accelerator, such as its specific generation, or other relevant inference details.
mlm:accelerator_countintegerA minimum amount of accelerator instances required to run the model.
mlm:input <sup>[1]</sup>[Model Input Object]REQUIRED Describes the transformation between the EO data and the model input.
mlm:output <sup>[1]</sup>[Model Output Object]REQUIRED Describes each model output and how to interpret it.
mlm:hyperparameters <sup>[1]</sup>Model Hyperparameters ObjectAdditional hyperparameters relevant for the model.
<!-- special heading is done on purpose to correctly render and redirect on GitHub while avoiding linting issues -->

Notes

<b><sup>1</sup> Fields allowed only in Item properties<b>

<!-- lint disable no-undefined-references -->

[!NOTE] Unless stated otherwise by <sup>[1]</sup> in the table, fields can be used at either the Item or Asset level. <br><br> To decide whether above fields should be applied under Item properties or under respective Assets, the context of each field must be considered. For example, the mlm:name should always be provided in the Item properties, since it relates to the model as a whole. In contrast, some models could support multiple mlm:accelerator, which could be handled by distinct source code represented by different Assets. In such case, mlm:accelerator definitions should be nested under their relevant Asset. If a field is defined both at the Item and Asset level, the value at the Asset level would be considered for that specific Asset, and the value at the Item level would be used for other Assets that did not override it for their respective reference. For some of the fields, further details are provided in following sections to provide more precisions regarding some potentially ambiguous use cases.

<!-- lint enable no-undefined-references -->

In addition, fields from the multiple relevant extensions should be defined as applicable. See Best Practices - Recommended Extensions to Compose with the ML Model Extension for more details.

For the Extent Object in STAC Collections and the corresponding spatial and temporal fields in Items, please refer to section Best Practices - Using STAC Common Metadata Fields for the ML Model Extension.

Model Architecture

In most cases, this should correspond to common architecture names defined in the literature, such as ResNet, VGG, GAN or Vision Transformer. For more examples of proper names (including casing), the Papers With Code - Computer Vision Methods can be used. Note that this field is not an explicit "Enum", and is used only as an indicator of common architecture occurrences. If no specific or predefined architecture can be associated with the described model, simply employ unknown or another custom name as deemed appropriate.

Task Enum

It is recommended to define mlm:tasks of the entire model at the STAC Item level, and tasks of respective Model Output Object with the following values. Although other values are permitted to support more use cases, they should be used sparingly to allow better interoperability of models and their representation.

As a general rule of thumb, if a task is not represented below, an appropriate name can be formulated by taking definitions listed in Papers With Code. The names should be normalized to lowercase and use hyphens instead of spaces.

Task NameCorresponding label:tasksDescription
regressionregressionGeneric regression that estimates a numeric and continuous value.
classificationclassificationGeneric classification task that assigns class labels to an output.
scene-classificationn/aSpecific classification task where the model assigns a single class label to an entire scene/area.
detectiondetectionGeneric detection of the "presence" of objects or entities, with or without positions.
object-detectionn/aTask corresponding to the identification of positions as bounding boxes of object detected in the scene.
segmentationsegmentationGeneric tasks that regroups all types of segmentations tasks consisting of applying labels to pixels.
semantic-segmentationn/aSpecific segmentation task where all pixels are attributed labels, without consideration for segments as unique objects.
instance-segmentationn/aSpecific segmentation task that assigns distinct labels for groups of pixels corresponding to object instances.
panoptic-segmentationn/aSpecific segmentation task that combines instance segmentation of objects and semantic labels for non-objects.
similarity-searchn/aGeneric task to identify whether a query input corresponds to another reference within a corpus.
generativen/aGeneric task that encompasses all synthetic data generation techniques.
image-captioningn/aSpecific task of describing the content of an image in words.
super-resolutionn/aSpecific task that increases the quality and resolution of an image by increasing its high-frequency details.

If the task falls within the category of supervised machine learning and uses labels during training, this should align with the label:tasks values defined in STAC Label Extension for relevant STAC Collections and Items published with the model described by this extension.

It is to be noted that multiple "generic" tasks names (classification, detection, etc.) are defined to allow correspondance with label:tasks, but these can lead to some ambiguity depending on context. For example, a model that supports classification could mean that the model can predict patch-based classes over an entire scene (i.e.: scene-classification for a single prediction over an entire area of interest as a whole), or that it can predict pixel-wise "classifications", such as land-cover labels for every single pixel coordinate over the area of interest. Maybe counter-intuitively to some users, such a model that produces pixel-wise "classifications" should be attributed the segmentation task (and more specifically semantic-segmentation) rather than classification. To avoid this kind of ambiguity, it is strongly recommended that tasks always aim to provide the most specific definitions possible to explicitly describe what the model accomplishes.

Framework

This should correspond to the common library name of a well-established ML framework. No "Enum" are enforced to allow easy addition of newer frameworks, but it is STRONGLY recommended to use common names when applicable. Below are a few notable entries.

Accelerator Type Enum

It is recommended to define accelerator with one of the following values:

<!-- lint disable no-undefined-references -->

[!WARNING] If mlm:accelerator = amd64, this explicitly indicates that the model does not (and will not try to) use any accelerator, even if some are available from the runtime environment. This is to be distinguished from the value mlm:accelerator = null, which means that the model could make use of some accelerators if provided, but is not constrained by any specific one. To improve comprehension by users, it is recommended that any model using mlm:accelerator = amd64 also set explicitly mlm:accelerator_constrained = true to illustrate that the model WILL NOT use accelerators, although the hardware resolution should be identical nonetheless.

<!-- lint enable no-undefined-references -->

When mlm:accelerator = null is employed, the value of mlm:accelerator_constrained can be ignored, since even if set to true, there would be no accelerator to contain against. To avoid confusion, it is suggested to set the mlm:accelerator_constrained = false or omit the field entirely in this case.

Model Input Object

Field NameTypeDescription
namestringREQUIRED Name of the input variable defined by the model. If no explicit name is defined by the model, an informative name (e.g.: "RGB Time Series") can be used instead.
bands[string | Model Band Object]REQUIRED The raster band references used to train, fine-tune or perform inference with the model, which may be all or a subset of bands available in a STAC Item's Band Object. If no band applies for one input, use an empty array.
inputInput Structure ObjectREQUIRED The N-dimensional array definition that describes the shape, dimension ordering, and data type.
descriptionstringAdditional details about the input such as describing its purpose or expected source that cannot be represented by other properties.
value_scaling[Value Scaling Object] | nullMethod to scale, normalize, or standardize the data inputs values, across dimensions, per corresponding dimension index, or null if none applies. These values often correspond to dataset or sensor statistics employed for training the model, but can come from another source as needed by the model definition. Consider using pre_processing_function for custom implementations or more complex combinations.
resize_typeResize Enum | nullHigh-level descriptor of the resize method to modify the input dimensions shape. Select an appropriate option or null when none applies. Consider using pre_processing_function for custom implementations or more complex combinations.
pre_processing_functionProcessing Expression | nullCustom preprocessing function where rescaling and resize, and any other significant data preparation operations takes place. The pre_processing_function should be applied over all available bands. For respective band operations, see Model Band Object.

Fields that accept the null value can be considered null when omitted entirely for parsing purposes. However, setting null explicitly when this information is known by the model provider can help users understand what is the expected behavior of the model. It is therefore recommended to provide null explicitly when applicable.

Bands and Statistics

Depending on the supported stac_version and other stac_extensions employed by the STAC Item using MLM, the STAC 1.1 - Band Object, the STAC Raster - Band Object or the STAC EO - Band Object can be used for representing bands information, including notably the nodata value, the data_type (see also Data Type Enum), and Common Band Names.

<!-- lint disable no-undefined-references -->

[!WARNING] Only versions v1.x of eo and raster are supported to provide mlm:input band references. Versions 2.x of those extensions rely on the STAC 1.1 - Band Object instead. If those versions are desired, consider migrating your MLM definition to use STAC 1.1 - Band Object as well for referencing mlm:input with band names.

[!NOTE] Due to how the schema for eo:bands is defined, it is not sufficient to only provide the eo:bands property at the STAC Item level. The schema validation of the EO extension explicitly looks for a corresponding set of bands under an Asset, and if none is found, it disallows eo:bands in the Item properties. Therefore, eo:bands should either be specified only under the Asset containing the mlm:model role (see Model Asset), or define them both under the Asset and Item properties. If the second approach is selected, it is recommended that the eo:bands under the Asset contains only the name or the common_name property, such that all other details about the bands are defined and cross-referenced by name with the Item-level band definitions. An example of such representation is provided in examples/item_eo_bands_summarized.json. For an example where eo:bands are entirely defined in the Asset on their own, please refer to examples/item_eo_bands.json instead. <br><br> For more details, refer to stac-extensions/eo#12. <br>

[!NOTE] When using raster:bands, and additional name parameter MUST be provided for each band. This parameter is not defined in raster extension itself, but is permitted. This addition is required to ensure that mlm:input bands referenced by name can be associated to their respective raster:bands definitions.

<!-- lint enable no-undefined-references -->

Only bands used as input to the model should be included in the MLM bands field. To avoid duplicating the information, MLM only uses the name of whichever "Band Object" is defined in the STAC Item. An input's bands definition can either be a plain string or a Model Band Object. When a string is employed directly, the value should be implicitly mapped to the name property of the explicit object representation.

One distinction from the STAC 1.1 - Band Object in MLM is that Band Statistics object (or the corresponding STAC Raster - Statistics for STAC 1.0) are not defined at the "Band Object" level, but at the Model Input level. This is because, in machine learning, it is common to need overall statistics for the dataset used to train the model to normalize all bands, rather than normalizing the values over a single product. Furthermore, statistics could be applied differently for distinct Model Input definitions, in order to adjust for intrinsic properties of the model.

Another distinction is that, depending on the model, statistics could apply to some inputs that have no reference to any bands definition. In such case, defining statistics under bands would not be possible, or would intrude ambiguous definitions.

Finally, contrary to the "statistics" property name employed by Band Statistics, MLM employs the distinct name value_scaling, although similar minimum, maximum, etc. sub-fields are employed. This is done explicitly to disambiguate "informative" band statistics from "applied scaling operations" required by the model inputs. This highlights the fact that value_scaling are not necessarily equal to Band Statistics values, although they are often equal in practice due to the applicable value-range domains they represent. Also, this allows addressing special scaling cases, using additional properties unavailable from Band Statistics, such as value-specific scaling (see Value Scaling Object for more details).

Model Band Object

Field NameTypeDescription
namestringREQUIRED Name of the band referring to an extended band definition (see Bands details).
formatstringThe type of expression that is specified in the expression property.
expression*An expression compliant with the format specified. The expression can be applied to any data type and depends on the format given.
<!-- lint disable no-undefined-references -->

[!NOTE] Although format and expression are not required in this context, they are mutually dependent on each other. <br> See also Processing Expression for more details and examples.

<!-- lint enable no-undefined-references -->

The format and expression properties can serve multiple purpose.

  1. Applying a band-specific pre-processing step, in contrast to pre_processing_function applied over all bands. For example, reshaping a band to align its dimensions with other bands before stacking them.

  2. Defining a derived-band operation or a calculation that produces a virtual band from other band references. For example, computing an indice that applies an arithmetic combination of other bands.

For a concrete example, see examples/item_bands_expression.json.

Data Type Enum

When describing the data_type provided by a Band, whether for defining the Input Structure or the Result Structure, the Data Types from the STAC Raster extension should be used if using STAC 1.0 or earlier, and can use Data Types from STAC 1.1 Core for later versions. Both definitions should define equivalent values.

Input Structure Object

Field NameTypeDescription
shape[integer]REQUIRED Shape of the input n-dimensional array (e.g.: $B \times C \times H \times W$), including the batch size dimension. Each dimension must either be greater than 0 or -1 to indicate a variable dimension size.
dim_order[Dimension Order]REQUIRED Order of the shape dimensions by name.
data_typeData Type EnumREQUIRED The data type of values in the n-dimensional array. For model inputs, this should be the data type of the processed input supplied to the model inference function, not the data type of the source bands.

A common use of -1 for one dimension of shape is to indicate a variable batch-size. However, this value is not strictly reserved for the b dimension. For example, if the model is capable of automatically adjusting its input layer to adapt to the provided input data, then the corresponding dimensions that can be adapted can employ -1 as well.

Dimension Order

Recommended values should use common names as much as possible to allow better interpretation by users and scripts that could need to resolve the dimension ordering for reshaping requirements according to the ML framework employed.

Below are some notable common names recommended for use, but others can be employed as needed.

For example, a tensor of multiple RBG images represented as $B \times C \times H \times W$ should indicate dim_order = ["batch", "channel", "height", "width"].

Value Scaling Object

Select one option from:

typeRequired PropertiesScaling Operation
min-maxminimum, maximum$(data - minimum) / (maximum - minimum)$
z-scoremean, stddev$(data - mean) / stddev$
clipminimum, maximum$\min(\max(data, minimum), maximum)$
clip-minminimum$\max(data, minimum)$
clip-maxmaximum$\min(data, maximum)$
offsetvalue$data - value$
scalevalue$data / value$
processingProcessing Expressionaccording to processing:expression

When a scaling type approach is specified, it is expected that the parameters necessary to perform their calculation are provided for the corresponding input dimension data.

If none of the above values applies for a given dimension, type: null (literal null, not string) should be used instead. If none of the input dimension require scaling, the entire definition can be defined as value_scaling: null or be omitted entirely.

When value_scaling is specified, the amount of objects defined in the array must match the size of the bands/channels/dimensions described by the Model Input. However, the value_scaling array is allowed to contain a single object if the entire input must be rescaled using the same definition across all dimensions. In such case, implicit broadcasting of the unique Value Scaling Object should be performed for all applicable dimensions when running inference with the model.

If a custom scaling operation, or a combination of more complex operations (with or without Resize), must be defined instead, a Processing Expression reference can be specified in place of the Value Scaling Object of the respective input dimension, as shown below.

{
  "value_scaling": [
    {"type": "min-max", "minimum": 0, "maximum": 255},
    {"type": "clip", "minimum": 0, "maximum": 255},
    {"type": "processing", "format": "gdal-calc", "expression": "A * logical_or( A<=177, A>=185 )"}
  ]
}

For operations such as L1 or L2 normalization, Processing Expression should also be employed. This is because, depending on the Model Input dimensions and reference data, there is an ambiguity regarding "how" and "where" such normalization functions must be applied against the input data. A custom mathematical expression should provide explicitly the data manipulation and normalization strategy.

In situations of very complex value_scaling operations, which cannot be represented by any of the previous definition, a pre_processing_function should be used instead (see Model Input Object).

Resize Enum

Select one option from:

See OpenCV - Interpolation Flags for details about the relevant methods. Equivalent methods from other packages are applicable as well.

If none of the above values applies, null (literal, not string) can be used instead. If a custom rescaling operation, or a combination of operations (with or without Value Scaling), must be defined instead, consider using a Processing Expression reference.

Processing Expression

Taking inspiration from Processing Extension - Expression Object, the processing expression defines at the very least a format and the applicable expression for it to perform pre/post-processing operations on MLM inputs/outputs.

Field NameTypeDescription
formatstringREQUIRED The type of the expression that is specified in the expression property.
expression*REQUIRED An expression compliant with the format specified. The expression can be any data type and depends on the format given, e.g. string or object.

On top of the examples already provided by Processing Extension - Expression Object, the following formats are recommended as alternative scripts and function references.

FormatTypeDescriptionExpression Example
pythonstringA Python entry point reference.my_package.my_module:my_processing_function or my_package.my_module:MyClass.my_method
dockerstringAn URI with image and tag to a Docker.ghcr.io/NAMESPACE/IMAGE_NAME:latest
uristringAn URI to some binary or script.{"href": "https://raw.githubusercontent.com/ORG/REPO/TAG/package/cli.py", "type": "text/x-python"}
<!-- lint disable no-undefined-references -->

[!NOTE] Above definitions are only indicative, and more can be added as desired with even more custom definitions. It is left as an implementation detail for users to resolve how these expressions should be handled at runtime.

[!WARNING] See also discussion regarding additional processing expressions: stac-extensions/processing#31

<!-- lint enable no-undefined-references -->

Model Output Object

Field NameTypeDescription
namestringREQUIRED Name of the output variable defined by the model. If no explicit name is defined by the model, an informative name (e.g.: "CLASSIFICATION") can be used instead.
tasks[Task Enum]REQUIRED Specifies the Machine Learning tasks for which the output can be used for. This can be a subset of mlm:tasks defined under the Item properties as applicable.
resultResult Structure ObjectREQUIRED The structure that describes the resulting output arrays/tensors from one model head.
descriptionstringAdditional details about the output such as describing its purpose or expected result that cannot be represented by other properties.
classification:classes[Class Object]A list of class objects adhering to the Classification Extension.
post_processing_functionProcessing Expression | nullCustom postprocessing function where normalization, rescaling, or any other significant operations takes place.

While only tasks is a required field, all fields are recommended for tasks that produce a fixed shape tensor and have output classes. Outputs that have variable dimensions, can define the result with the appropriate dimension value -1 in the shape field. When the model does not produce specific classes, such as for regression, image-captioning, super-resolution and some generative tasks, to name a few, the classification:classes can be omitted.

Result Structure Object

Field NameTypeDescription
shape[integer]REQUIRED Shape of the n-dimensional result array (e.g.: $B \times H \times W$ or $B \times C$), possibly including a batch size dimension. The dimensions must either be greater than 0 or -1 to indicate a variable size.
dim_order[Dimension Order]REQUIRED Order of the shape dimensions by name for the result array.
data_typeData Type EnumREQUIRED The data type of values in the n-dimensional array. For model outputs, this should be the data type of the result of the model inference without extra post processing.

Class Object

See the documentation for the Class Object.

Model Hyperparameters Object

The hyperparameters are an open JSON object definition that can be used to provide relevant configurations for the model. Those can combine training details, inference runtime parameters, or both. For example, training hyperparameters could indicate the number of epochs that were used, the optimizer employed, the number of estimators contained in an ensemble of models, or the random state value. For inference, parameters such as the model temperature, a confidence cut-off threshold, or a non-maximum suppression threshold to limit proposal could be specified. The specific parameter names, and how they should be employed by the model, are specific to each implementation.

Following is an example of what the hyperparameters definition could look like:

{
  "mlm:hyperparameters": {
    "nms_max_detections": 500,
    "nms_threshold": 0.25,
    "iou_threshold": 0.5,
    "random_state": 12345
  }
}

Assets Objects

Field NameTypeDescription
mlm:modelAsset ObjectREQUIRED Asset object containing the model definition.
mlm:source_codeAsset ObjectRECOMMENDED Source code description. Can describe a Git repository, ZIP archive, etc.
mlm:containerAsset ObjectRECOMMENDED Information to run the model in a container with URI to the container.
mlm:trainingAsset ObjectRECOMMENDED Information to run the training pipeline of the model being described.
mlm:inferenceAsset ObjectRECOMMENDED Information to run the inference pipeline of the model being described.

It is recommended that the Assets defined in a STAC Item using MLM extension use the above field property names for nesting the Assets in order to improve their quick identification, although the specific names employed are left up to user preference. However, the MLM Asset definitions MUST include the appropriate MLM Asset Roles to ensure their discovery.

A valid STAC MLM Item definition requires at least one Asset with the mlm:model role, as well as, an accompanying mlm:artifact_type property that describes how to employ it. An Asset described with this role is considered the "main" Model Asset being described by the STAC Item definition. Typically, there will be only one asset containing the mlm:model role. However, multiple Assets employing the mlm:model role are permitted to provide alternate interfaces of the same model (e.g.: using different frameworks or compilations), but those assets should have exactly the same model interfaces (i.e.: identical mlm:input, mlm:output, etc.). In such case, the mlm:artifact_type property should be used to distinguish them.

Additional definitions such as the Source Code Asset and the Container Asset are considered "side-car" Assets that help understand how to employ the model, such as through the reference training script that produced the model or a preconfigured inference runtime environment. These additional Assets are optional, but it is STRONGLY RECOMMENDED to provide them in order to help correct adoption and use of the described model by users.

MLM Asset Roles

Asset roles should include relevant names that describe them. This does not only include the Recommended Asset Roles from the core specification, such as data or metadata, but also descriptors such as mlm:model, mlm:weights and so on, as applicable for the relevant MLM Assets being described. Please refer to the following sections for roles requirements by specific MLM Assets.

Note that mlm: prefixed roles are used for identification purpose of the Assets, but non-prefixed roles can be provided as well to offer generic descriptors. For example, ["mlm:model", "model", "data"] could be considered for the Model Asset.

In order to provide more context, the following roles are also recommended were applicable:

Asset RoleAdditional RolesDescription
mlm:inference-runtime (*)runtimeDescribes an Asset that provides runtime reference to perform model inference.
mlm:training-runtime (*)runtimeDescribes an Asset that provides runtime reference to perform model training.
mlm:checkpoint (*)weights, checkpointDescribes an Asset that provides a model checkpoint with embedded model configurations.
mlm:weightsweights, checkpointDescribes an Asset that provides a model weights (typically some Tensor representation).
mlm:modelmodelREQUIRED Role for Model Asset.
mlm:source_codecodeRECOMMENDED Role for Source Code Asset.
<!-- lint disable no-undefined-references -->

[!NOTE] (*) These roles are offered as direct conversions from the previous extension that provided ML-Model Asset Roles to provide easier upgrade to the MLM extension.

<!-- lint enable no-undefined-references -->

Model Asset

Field NameTypeDescription
titlestringDescription of the model asset.
hrefstringURI to the model artifact.
typestringThe media type of the artifact (see Model Artifact Media-Type.
roles[string]REQUIRED Specify mlm:model. Can include ["mlm:weights", "mlm:checkpoint"] as applicable.
mlm:artifact_typeArtifact TypeSpecifies the kind of model artifact. Typically related to a particular ML framework.

Recommended Asset roles include mlm:weights or mlm:checkpoint for model weights that need to be loaded by a model definition and mlm:compiled for models that can be loaded directly without an intermediate model definition. In each case, the mlm:model MUST be applied as well to indicate that this asset represents the model.

It is also recommended to make use of the file extension for this Asset, as it can provide useful information to validate the contents of the model definition, by comparison with fields file:checksum and file:size for example.

Model Artifact Media-Type

Very few ML framework, libraries or model artifacts provide explicit IANA registered media-type to represent the contents they handle. When those are not provided, custom media-types can be considered. However, "unofficial but well-established" parameters should be reused over custom media-types when possible.

For example, the unofficial application/octet-stream; framework=pytorch definition is appropriate to represent a PyTorch .pt file, since its underlying format is a serialized pickle structure, and its framework parameter provides a clearer indication about the targeted ML framework and its contents. Since artifacts will typically be downloaded using a request stream into a runtime environment in order to employ the model, the application/octet-stream media-type is relevant for representing this type of arbitrary binary data. Being an official media-type, it also has the benefit to increase chances that HTTP clients will handle download of the contents appropriately when performing requests. In contrast, custom media-types such as application/x-pytorch have higher chances to be considered unacceptable (HTTP 406 Not Acceptable) by servers, which is why they should preferably be avoided.

Users can consider adding more parameters to provide additional context, such as profile=compiled to provide an additional hint that the specific PyTorch Ahead-of-Time Compilation profile is used for the artifact described by the media-type. However, users need to remember that those parameters are not official. In order to validate the specific framework and artifact type employed by the model, the MLM properties mlm:framework (see MLM Fields) and mlm:artifact_type (see Model Asset) should be employed instead to perform this validation if needed.

Artifact Type

This value can be used to provide additional details about the specific model artifact being described. For example, PyTorch offers various strategies for providing model definitions, such as Pickle (.pt), TorchScript, or PyTorch Ahead-of-Time Compilation (.pt2) approach. Since they all refer to the same ML framework, the Model Artifact Media-Type can be insufficient in this case to detect which strategy should be used to employ the model definition.

Following are some proposed Artifact Type values for corresponding approaches, but other names are permitted as well. Note that the names are selected using the framework-specific definitions to help the users understand the source explicitly, although this is not strictly required either.

Artifact TypeDescription
torch.saveA model artifact obtained by Serialized Pickle Object (i.e.: .pt).
torch.jit.scriptA model artifact obtained by TorchScript.
torch.exportA model artifact obtained by torch.export (i.e.: .pt2).
torch.compileA model artifact obtained by torch.compile.

Source Code Asset

Field NameTypeDescription
titlestringTitle of the source code.
hrefstringURI to the code repository, a ZIP archive, or an individual code/script file.
typestringMedia-type of the URI.
roles[string]RECOMMENDED Specify one or more of ["model", "code", "metadata"]
descriptionstringDescription of the source code.
mlm:entrypointstringSpecific entrypoint reference in the code to use for running model inference.

If the referenced code does not directly offer a callable script to run the model, the mlm:entrypoint field should be added to the Asset Object in order to provide a pointer to the inference function to execute the model. For example, my_package.my_module:predict would refer to the predict function located in the my_module inside the my_package library provided by the repository.

It is strongly recommended to use a specific media-type such as text/x-python if the source code refers directly to a script of a known programming language. Using the HTML rendering of that source file, such as though GitHub for example, should be avoided. Using the "Raw Contents" endpoint for such cases is preferable. The text/html media-type should be reserved for cases where the URI generally points at a Git repository. Note that the URI including the specific commit hash, release number or target branch should be preferred over other means of referring to checkout procedures, although this specification does not prohibit the use of additional properties to better describe the Asset.

Since the source code of a model provides useful example on how to use it, it is also recommended to define relevant references to documentation using the example extension. See the Best Practices - Example Extension section for more details.

Recommended asset roles include code and metadata, since the source code asset might also refer to more detailed metadata than this specification captures.

Container Asset

Field NameTypeDescription
titlestringDescription of the container.
hrefstringURI of the published container, including the container registry, image and tag.
typestringMedia-type of the container, typically application/vnd.oci.image.index.v1+json.
roles[string]Specify ["runtime"] and any other custom roles.

If you're unsure how to containerize your model, we suggest starting from the latest official container image for your framework that works with your model and pinning the container version.

Examples:

Using a base image for a framework looks like:

# In your Dockerfile, pull the latest base image with all framework dependencies including accelerator drivers
FROM pytorch/pytorch:2.1.2-cuda11.8-cudnn8-runtime

### Your specific environment setup to run your model
RUN pip install my_package

You can also use other base images. Pytorch and Tensorflow offer docker images for serving models for inference.

Relation Types

The following types should be used as applicable rel types in the Link Object of STAC Items describing Band Assets that result from the inference of a model described by the MLM extension.

TypeDescription
derived_fromThis link points to a STAC Collection or Item using MLM.

It is recommended that the link using derived_from referring to another STAC definition using the MLM extension specifies the mlm:name value to make the derived reference more explicit.

Note that a derived product from model inference described by STAC should also consider using additional indications that it came of a model, such as described by the Best Practices - Processing Extension.

Contributing

All contributions are subject to the STAC Specification Code of Conduct. For contributions, please follow the STAC specification contributing guide Instructions for running tests are copied here for convenience.

Running tests

The same checks that run as checks on PRs are part of the repository and can be run locally to verify that changes are valid. To run tests locally, you'll need npm, which is a standard part of any node.js installation.

First, install everything with npm once. Navigate to the root of this repository and on your command line run:

npm install

Then to check Markdown formatting and test the examples against the JSON schema, you can run:

npm test

This will spit out the same texts that you see online, and you can then go and fix your markdown or examples.

If the tests reveal formatting problems with the examples, you can fix them with:

npm run format-examples