Skip to main content

Experimental tools for converting PyTorch models to ONNX

Project description

PyTorch to ONNX Exporter

Experimental torch ONNX exporter.

[!WARNING] This is an experimental project and is not designed for production use. Use torch.onnx.export for these purposes.

Installation

pip install --upgrade torch-onnx

Usage

import torch
import torch_onnx
from onnxscript import ir
import onnx

# Get an exported program with torch.export
exported = torch.export.export(...)
model = torch_onnx.exported_program_to_ir(exported)
proto = ir.to_proto(model)
# This will give you an ATen dialect graph (un-lowered ONNX graph with ATen ops)
onnx.save(proto, "model.onnx")

# Or patch the torch.onnx export API
# Set error_report=True to get a detailed error report if the export fails
torch_onnx.patch_torch(error_report=True, profile=True)
torch.onnx.export(...)

# Use the analysis API to print an analysis report for unsupported ops
torch_onnx.analyze(exported)

Design

{ExportedProgram, jit} -> {ONNX IR} -> {torchlib} -> {ONNX}

  • Flat graph; Scope info as metadata, not functions
    • Because existing tools are not good at handling them
  • Eager optimization where appropriate
    • Because exsiting tools are not good at optimizing
  • Drop in replacement for torch.onnx.export
    • Minimum migration effort
  • Use ExportedProgram
    • Rely on robustness of the torch.export implementation
    • This does not solve dynamo limitations, but it avoids introducing additional breakage by running fx passes
  • Build graph eagerly, in place
    • Expose shape and dtype information to the op functions; build with IR

Why is this doable?

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

torch_onnx-0.0.12.tar.gz (34.6 kB view details)

Uploaded Source

Built Distribution

torch_onnx-0.0.12-py3-none-any.whl (39.4 kB view details)

Uploaded Python 3

File details

Details for the file torch_onnx-0.0.12.tar.gz.

File metadata

  • Download URL: torch_onnx-0.0.12.tar.gz
  • Upload date:
  • Size: 34.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.1 CPython/3.11.9

File hashes

Hashes for torch_onnx-0.0.12.tar.gz
Algorithm Hash digest
SHA256 3e9022e52f5012b1d6a7e7c9318d92bae0ed14d236e0bfb67f253b9916c91257
MD5 5659341fdd10788f6043f36d267a4fc5
BLAKE2b-256 afc6600cf4e0221e072ab3d33c5f6314b1d90e2d398892faed22c46dcba4c464

See more details on using hashes here.

File details

Details for the file torch_onnx-0.0.12-py3-none-any.whl.

File metadata

  • Download URL: torch_onnx-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 39.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.1 CPython/3.11.9

File hashes

Hashes for torch_onnx-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 dfff4684fcfd9321de359893202f25fb52583ef3ccb56f676499edb2268c8027
MD5 86b3492c8c8253824d1e0fc9414630d4
BLAKE2b-256 45d8c618859649b07543b9801c57cf738510061a615a41d7edbb2616a7a60fd4

See more details on using hashes here.

Supported by

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