-
Notifications
You must be signed in to change notification settings - Fork 60
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Build AI Model images as manifest lists
This allows us to assign annotations to help identify the model. Pull in annotations for the OCI model specification defined in https://github.com/CloudNativeAI/model-spec Then make all of the commands handle models stored in manifest list as well as images. Fix up building and pushing OCI Images Signed-off-by: Daniel J Walsh <[email protected]>
- Loading branch information
Showing
5 changed files
with
257 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
# These annotations are based off the proposed standard: | ||
# https://github.com/CloudNativeAI/model-spec | ||
|
||
# ArtifactTypeModelManifest specifies the media type for a model manifest. | ||
ArtifactTypeModelManifest = "application/vnd.cnai.model.manifest.v1+json" | ||
|
||
# ArtifactTypeModelLayer is the media type used for layers referenced by the | ||
# manifest. | ||
ArtifactTypeModelLayer = "application/vnd.cnai.model.layer.v1.tar" | ||
|
||
# ArtifactTypeModelLayerGzip is the media type used for gzipped layers | ||
# referenced by the manifest. | ||
ArtifactTypeModelLayerGzip = "application/vnd.cnai.model.layer.v1.tar+gzip" | ||
|
||
# AnnotationCreated is the annotation key for the date and time on which the | ||
# model was built (date-time string as defined by RFC 3339). | ||
AnnotationCreated = "org.cnai.model.created" | ||
|
||
# AnnotationAuthors is the annotation key for the contact details of the people | ||
# or organization responsible for the model (freeform string). | ||
AnnotationAuthors = "org.cnai.model.authors" | ||
|
||
# AnnotationURL is the annotation key for the URL to find more information on | ||
# the model. | ||
AnnotationURL = "org.cnai.model.url" | ||
|
||
# AnnotationDocumentation is the annotation key for the URL to get documentation | ||
# on the model. | ||
AnnotationDocumentation = "org.cnai.model.documentation" | ||
|
||
# AnnotationSource is the annotation key for the URL to get source code for | ||
# building the model. | ||
AnnotationSource = "org.cnai.model.source" | ||
|
||
# AnnotationVersion is the annotation key for the version of the packaged | ||
# software. | ||
# The version MAY match a label or tag in the source code repository. | ||
# The version MAY be Semantic versioning-compatible. | ||
AnnotationVersion = "org.cnai.model.version" | ||
|
||
# AnnotationRevision is the annotation key for the source control revision | ||
# identifier for the packaged software. | ||
AnnotationRevision = "org.cnai.model.revision" | ||
|
||
# AnnotationVendor is the annotation key for the name of the distributing | ||
# entity, organization or individual. | ||
AnnotationVendor = "org.cnai.model.vendor" | ||
|
||
# AnnotationLicenses is the annotation key for the license(s) under which | ||
# contained software is distributed as an SPDX License Expression. | ||
AnnotationLicenses = "org.cnai.model.licenses" | ||
|
||
# AnnotationRefName is the annotation key for the name of the reference for a | ||
# target. | ||
# SHOULD only be considered valid when on descriptors on `index.json` within | ||
# model layout. | ||
AnnotationRefName = "org.cnai.model.ref.name" | ||
|
||
# AnnotationTitle is the annotation key for the human-readable title of the | ||
# model. | ||
AnnotationTitle = "org.cnai.model.title" | ||
|
||
# AnnotationDescription is the annotation key for the human-readable description | ||
# of the software packaged in the model. | ||
AnnotationDescription = "org.cnai.model.description" | ||
|
||
# AnnotationArchitecture is the annotation key for the model architecture, such | ||
# as `transformer`, `cnn`, `rnn`, etc. | ||
AnnotationArchitecture = "org.cnai.model.architecture" | ||
|
||
# AnnotationFamily is the annotation key for the model family, such as | ||
# `llama3`, `gpt2`, `qwen2`, etc. | ||
AnnotationFamily = "org.cnai.model.family" | ||
|
||
# AnnotationName is the annotation key for the model name, such as | ||
# `llama3-8b-instruct`, `gpt2-xl`, `qwen2-vl-72b-instruct`, etc. | ||
AnnotationName = "org.cnai.model.name" | ||
|
||
# AnnotationFormat is the annotation key for the model format, such as | ||
# `onnx`, `tensorflow`, `pytorch`, etc. | ||
AnnotationFormat = "org.cnai.model.format" | ||
|
||
# AnnotationParamSize is the annotation key for the size of the model | ||
# parameters. | ||
AnnotationParamSize = "org.cnai.model.param.size" | ||
|
||
# AnnotationPrecision is the annotation key for the model precision, such as | ||
# `bf16`, `fp16`, `int8`, etc. | ||
AnnotationPrecision = "org.cnai.model.precision" | ||
|
||
# AnnotationQuantization is the annotation key for the model quantization, | ||
# such as `awq`, `gptq`, etc. | ||
AnnotationQuantization = "org.cnai.model.quantization" | ||
|
||
# AnnotationReadme is the annotation key for the layer is a README.md file | ||
# (boolean), such as `true` or `false`. | ||
AnnotationReadme = "org.cnai.model.readme" | ||
|
||
# AnnotationLicense is the annotation key for the layer is a license file | ||
# (boolean), such as `true` or `false`. | ||
AnnotationLicense = "org.cnai.model.license" | ||
|
||
# AnnotationConfig is the annotation key for the layer is a configuration file | ||
# (boolean), such as `true` or `false`. | ||
AnnotationConfig = "org.cnai.model.config" | ||
|
||
# AnnotationModel is the annotation key for the layer is a model file (boolean), | ||
# such as `true` or `false`. | ||
AnnotationModel = "org.cnai.model.model" | ||
|
||
# AnnotationFilepath is the annotation key for the file path of the layer. | ||
AnnotationFilepath = "org.cnai.model.filepath" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters