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

{dynamo/jit} -> {ExportedProgram} -> {torchlib} -> {ONNX IR} -> {ONNX}

  • Use ExportedProgram
    • Rely on robustness of the torch.export implementation
    • Reduce complexity in the exporter
    • This does not solve dynamo limitations, but it avoids introducing additional breakage by running fx passes
  • 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
  • Build graph eagerly in the exporter
    • Give the exporter full control over the graph being built

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.14.tar.gz (36.1 kB view details)

Uploaded Source

Built Distribution

torch_onnx-0.0.14-py3-none-any.whl (40.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: torch_onnx-0.0.14.tar.gz
  • Upload date:
  • Size: 36.1 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.14.tar.gz
Algorithm Hash digest
SHA256 dc672e7147ef9e9c80803541af360106c63a49cdc03310ff76be41b121340b66
MD5 c4b758f6b72a18ddda39bab7f2ab364f
BLAKE2b-256 a6df0a34819c790970af6dc302c75c58734748f7b6fcb11bd361197164d9374a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: torch_onnx-0.0.14-py3-none-any.whl
  • Upload date:
  • Size: 40.6 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.14-py3-none-any.whl
Algorithm Hash digest
SHA256 62e67cdca3216dbd53a876e937524fa7a704daae1dc6b4244967848ff326d39b
MD5 542ca4a7c4de163a4170bf167252f555
BLAKE2b-256 4ff0d22b902ada5f72e1d5cccf3e0c5b6169c1c55cfdf4ee41f955cc4bb67623

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