Skip to main content

Efficient in-memory representation for ONNX

Project description

ONNX IR

PyPI - Version PyPI - Python Version Ruff codecov PyPI Downloads

An in-memory IR that supports the full ONNX spec, designed for graph construction, analysis and transformation.

Getting Started

onnx-ir documentation

Installation

Via pip:

pip install onnx-ir

Or from source:

pip install git+https://github.com/onnx/ir-py.git

Features ✨

  • Full ONNX spec support: all valid models representable by ONNX protobuf, and a subset of invalid models (so you can load and fix them).
  • Low memory footprint: mmap'ed external tensors; unified interface for ONNX TensorProto, Numpy arrays and PyTorch Tensors etc. No tensor size limitation. Zero copies.
  • Straightforward access patterns: Access value information and traverse the graph topology at ease.
  • Robust mutation: Create as many iterators as you like on the graph while mutating it.
  • Speed: Performant graph manipulation, serialization/deserialization to Protobuf.
  • Pythonic and familiar APIs: Classes define Pythonic apis and still map to ONNX protobuf concepts in an intuitive way.
  • No protobuf dependency: The IR does not require protobuf once the model is converted to the IR representation, decoupling from the serialization format.

Concept Diagram

Concept Diagram

Code Organization 🗺️

  • _protocols.py: Interfaces defined for all entities in the IR.
  • _core.py: Implementation of the core entities in the IR, including Model, Graph, Node, Value, and others.
  • _enums.py: Definition of the type enums that correspond to the DataType and AttributeType in onnx.proto.
  • _name_authority.py: The authority for giving names to entities in the graph, used internally.
  • _linked_list.py: The data structure as the node container in the graph that supports robust iteration and mutation. Internal.
  • _metadata.py: Metadata store for all entities in the IR.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

onnx_ir-0.1.8.tar.gz (109.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

onnx_ir-0.1.8-py3-none-any.whl (125.3 kB view details)

Uploaded Python 3

File details

Details for the file onnx_ir-0.1.8.tar.gz.

File metadata

  • Download URL: onnx_ir-0.1.8.tar.gz
  • Upload date:
  • Size: 109.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for onnx_ir-0.1.8.tar.gz
Algorithm Hash digest
SHA256 85ea59eaf165b2b107788193480a260e2723cfc7a1dac1bde7085fd0b7e380d7
MD5 690e402de81fa4e1d1092e546006ddd4
BLAKE2b-256 af4a7ea3952e556e7281b8bfe7f7fce016a13fdac85544d6d6af8ebca5cae160

See more details on using hashes here.

Provenance

The following attestation bundles were made for onnx_ir-0.1.8.tar.gz:

Publisher: main.yml on onnx/ir-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file onnx_ir-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: onnx_ir-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 125.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for onnx_ir-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 61a42021b6249e566ff3b89a03342bc88dce4dc2d984b97cfb060f33ef179f8a
MD5 67d7501b7afcf630eb43a8c5ae022795
BLAKE2b-256 0f1c3bb51fa9e278cbc655a1943c8016163d76a6e24137e73e5198ebc20fc965

See more details on using hashes here.

Provenance

The following attestation bundles were made for onnx_ir-0.1.8-py3-none-any.whl:

Publisher: main.yml on onnx/ir-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page