Exporter Recipes Gallery¶
A model can be converted to ONNX if torch.export.export()
is
able to convert that model into a graph. This is not always
possible but usually possible with some code changes.
These changes may not be desired as they may hurt the performance
and make the code more complex than it should be.
The conversion is a necessary step to be able to use
ONNX. Next examples shows some recurrent code patterns and
ways to rewrite them so that the exporter works.
See torch.onnx.export: export to ONNX for an organized version of this gallery.
A couple of examples to illustrate different implementation of dot product (see also sphinx-gallery).
Getting started¶
pytorch nightly build should be installed, see Start Locally.
git clone https://github.com/sdpython/experimental-experiment.git
pip install onnxruntime-gpu pynvml
pip install -r requirements-dev.txt
export PYTHONPATH=$PYTHONPATH:<this folder>
Common Errors¶
Some of them are exposed in the examples. Others may be found at Frequent Exceptions or Errors with the Exporter.
data:image/s3,"s3://crabby-images/4081e/4081e8e0a57cf68ecb2db0b6d809e557bd4b5769" alt=""
Export Phi-3.5-mini-instruct with report_exportability
data:image/s3,"s3://crabby-images/73f80/73f8044b4a74e6e49aeb9456d3e3413bfef26e9e" alt=""
Use DYNAMIC or AUTO when dynamic shapes has constraints
data:image/s3,"s3://crabby-images/1a99a/1a99a7bd97842459d7e9ae4086d16d9fc24f49f3" alt=""
to_onnx and a custom operator registered with a function
data:image/s3,"s3://crabby-images/c6fdf/c6fdf1184368ec9e9471c38db4563f3e71a90ac6" alt=""
to_onnx and padding one dimension to a mulitple of a constant
data:image/s3,"s3://crabby-images/9fa33/9fa33377715d5ae5ae89e21ada770c6c1f207eb4" alt=""
torch.onnx.export and padding one dimension to a mulitple of a constant