ONNX (.onnx)
- Import partially supports Version 18 and earlier of the standard ONNX operator set.
- Export supports Versions 9 to 18 of the standard ONNX operator set.
Background & Context
-
- Open format for neural network models.
- Stores models and various metadata.
- ONNX is an acronym for Open Neural Network Exchange.
- Binary file format based on Protobuf.
- First released in 2017 by Microsoft and Facebook.
Import & Export
- Import["file.onnx"] imports the net stored in the specified file, returning it as a NetChain, NetGraph or a similar construct.
- Import["file.onnx",elem] imports the specified element elem.
- The import format can be specified with Import["file","ONNX"] or Import["file",{"ONNX",elem,…}].
- Export["file.onnx",net] exports net as an ONNX model.
- The following expressions are supported:
-
NetChain[…] a net represented as a chain of layers NetGraph[…] a net represented as a graph of layers layer any net layer such as LinearLayer, ... - See the following reference pages for full general information:
-
Import, Export import from or export to a file CloudImport, CloudExport import from or export to a cloud object ImportString, ExportString import from or export to a string ImportByteArray, ExportByteArray import from or export to a byte array
Import Elements
- General Import elements:
-
"Elements" list of elements and options available in this file "Summary" summary of the file "Rules" list of rules for all available elements - Import elements include:
-
"ArrayAssociation" parameter arrays as an association "ArrayList" parameter arrays as a list "Description" human-readable description for the model "ONNXGraph" ONNX representation of the net "ModelDomain" model namespace or domain "ModelVersion" integer version number of the model "Net" Wolfram Language representation of the net, including all initialized arrays (default) "NetExternalObject" NetExternalObject representation of the net "IRVersion" version of the ONNX intermediate representation used by the model "OperatorSetVersion" operator sets the model is compatible with "ProducerName" name of the tool used to generate the model "ProducerVersion" version of the generating tool "RawData" full, unprocessed contents of the file, including the graph representation and all metadata "UninitializedNet" Wolfram Language representation of the net, without any arrays
Options
- Import options:
-
"Arrays" None path or list of paths to valid ONNX tensor proto files containing additional arrays for the net - Export options:
-
"Description" None model documentation string in ONNX metadata "ExternalArrays" Automatic export net arrays to separate files "GraphName" Automatic graph name in ONNX metadata "ModelVersion" 0 model version in ONNX metadata "OperatorSetVersion" Automatic version of the standard ONNX operator set used by the model - Option "ExternalArrays" can be set to the following:
-
Automatic create external files for net arrays depending on the model size None include net arrays in the model file All export net arrays to separate files, one file per array "Single" export all net arrays to a single file - Setting Automatic for "ExternalArrays" is equivalent to None when the total model size is less than 2GB and to "Single" when above 2GB. For settings All and "Single", array files are created in the same directory of the main model file. Any ONNX importer will expect such files to be in the same relative path.
Examples
open allclose allBasic Examples (2)
Show the Import elements available in this file:
Import Elements (14)
NetExternalObject (1)
Import the ONNX model as a NetExternalObject:
Import Options (1)
Export Options (5)
"ExternalArrays" (1)
Create a simple net and export it with multiple external array files:
Every array of the net was exported to an individual file named after the array, for example, "1_Weights":
The main model file keeps a reference to the relative path of all array files, so the arrays are automatically included when the model is imported:
Export the net with all external arrays in a single file:
A single file called "Arrays" is created that contains all the arrays of the net:
The main model file keeps a reference to the relative path of the combined array file, so the arrays are automatically included when the model is imported:
When the model size is larger than 2GB, a single external array file is automatically created and a warning message is emitted:
"OperatorSetVersion" (1)
Create a PaddingLayer and export it in operator set 10:
Check the operator set version:
In operator set 10, the ONNX "Pad" operator takes one input and has static attributes for its padding sizes and values:
The model file can be converted back because Import supports operator set 10:
Export the same layer in operator set 11:
Check the operator set version:
In operator set 11, padding sizes and values of the "Pad" operator were moved from attributes to inputs. The operator now has two additional inputs and two fewer attributes:
The model file can be converted back because Import supports operator set 11:
Possible Issues (1)
Any NetEncoder or NetDecoder is automatically removed by Export, as ONNX does not support them. Create a net with a NetEncoder and a NetDecoder and export it:
Importing the model back shows that no NetEncoder or NetDecoder are present: