Skip to main content

pnnx is an open standard for PyTorch model interoperability.

Project description

pnnx

python wrapper of pnnx, only support python 3.7+ now.

Install from pip

pnnx is available as wheel packages for macOS, Windows and Linux distributions, you can install with pip:

pip install pnnx

Build & Install from source

Prerequisites

On Unix (Linux, OS X)

  • A compiler with C++14 support
  • CMake >= 3.4

On Mac

  • A compiler with C++14 support
  • CMake >= 3.4

On Windows

  • Visual Studio 2015 or higher
  • CMake >= 3.4

Build & install

  1. clone ncnn.
git clone https://github.com/Tencent/ncnn.git
  1. install pytorch

install pytorch according to https://pytorch.org/ . Anaconda is strongly recommended for example:

conda install pytorch
  1. install
cd /pathto/ncnntools/pnnx/python
python setup.py install

Note: If torchvision and pnnx2onnx are needed, you can set the following environment variables before 'python setup.py install' to enable them. e.g. on ubuntu:

export TORCHVISION_INSTALL_DIR="/project/torchvision"
export PROTOBUF_INCLUDE_DIR="/project/protobuf/include"
export PROTOBUF_LIBRARIES="/project/protobuf/lib64/libprotobuf.a"
export PROTOBUF_PROTOC_EXECUTABLE="/project/protobuf/bin/protoc" 

To do these, you must install Torchvision and Protobuf first.

Tests

cd /pathto/ncnn/tools/pnnx/python
pytest tests

Usage

  1. export model to pnnx
import torch
import torchvision.models as models
import pnnx

net = models.resnet18(pretrained=True)
x = torch.rand(1, 3, 224, 224)

# You could try disabling checking when torch tracing raises error
# opt_net = pnnx.export(net, "resnet18.pt", x, check_trace=False)
opt_net = pnnx.export(net, "resnet18.pt", x)
  1. convert existing model to pnnx
import torch
import pnnx

x = torch.rand(1, 3, 224, 224)
opt_net = pnnx.convert("resnet18.pt", x)

API Reference

  1. pnnx.export

model (torch.nn.Model): model to be exported.

ptpath (str): the torchscript name.

inputs (torch.Tensor of list of torch.Tensor) expected inputs of the model.

inputs2 (torch.Tensor of list of torch.Tensor) alternative inputs of the model. Usually, it is used with input_shapes to resolve dynamic shape.

input_shapes (Optional, list of int or list of list with int type inside) shapes of model inputs. It is used to resolve tensor shapes in model graph. for example, [1,3,224,224] for the model with only 1 input, [[1,3,224,224],[1,3,224,224]] for the model that have 2 inputs.

input_types (Optional, str or list of str) types of model inputs, it should have the same length with input_shapes. for example, "f32" for the model with only 1 input, ["f32", "f32"] for the model that have 2 inputs.

typename torch type
f32 torch.float32 or torch.float
f64 torch.float64 or torch.double
f16 torch.float16 or torch.half
u8 torch.uint8
i8 torch.int8
i16 torch.int16 or torch.short
i32 torch.int32 or torch.int
i64 torch.int64 or torch.long
c32 torch.complex32
c64 torch.complex64
c128 torch.complex128

input_shapes2 (Optional, list of int or list of list with int type inside) shapes of alternative model inputs, the format is identical to input_shapes. Usually, it is used with input_shapes to resolve dynamic shape (-1) in model graph.

input_types2 (Optional, str or list of str) types of alternative model inputs.

device (Optional, str, default="cpu") device type for the input in TorchScript model, cpu or gpu.

customop (Optional, str or list of str) list of Torch extensions (dynamic library) for custom operators. For example, "/home/nihui/.cache/torch_extensions/fused/fused.so" or ["/home/nihui/.cache/torch_extensions/fused/fused.so",...].

moduleop (Optional, str or list of str) list of modules to keep as one big operator. for example, "models.common.Focus" or ["models.common.Focus","models.yolo.Detect"].

optlevel (Optional, int, default=2) graph optimization level

option optimization level
0 do not apply optimization
1 do not apply optimization
2 optimization more for inference

pnnxparam (Optional, str, default="*.pnnx.param", * is the model name): PNNX graph definition file.

pnnxbin (Optional, str, default="*.pnnx.bin"): PNNX model weight.

pnnxpy (Optional, str, default="*_pnnx.py"): PyTorch script for inference, including model construction and weight initialization code.

pnnxonnx (Optional, str, default="*.pnnx.onnx"): PNNX model in onnx format.

ncnnparam (Optional, str, default="*.ncnn.param"): ncnn graph definition.

ncnnbin (Optional, str, default="*.ncnn.bin"): ncnn model weight.

ncnnpy (Optional, str, default="*_ncnn.py"): pyncnn script for inference.

  1. pnnx.convert

ptpath (str): torchscript model to be converted.

Other parameters are consistent with pnnx.export

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

pnnx-20250530-py3-none-win_amd64.whl (17.8 MB view details)

Uploaded Python 3Windows x86-64

pnnx-20250530-py3-none-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (24.9 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

pnnx-20250530-py3-none-manylinux2014_aarch64.manylinux_2_17_aarch64.whl (21.7 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

pnnx-20250530-py3-none-macosx_10_9_universal2.macosx_10_9_x86_64.macosx_11_0_arm64.whl (50.5 MB view details)

Uploaded Python 3macOS 10.9+ universal2 (ARM64, x86-64)macOS 10.9+ x86-64macOS 11.0+ ARM64

File details

Details for the file pnnx-20250530-py3-none-win_amd64.whl.

File metadata

  • Download URL: pnnx-20250530-py3-none-win_amd64.whl
  • Upload date:
  • Size: 17.8 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for pnnx-20250530-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 c1135aaf2a175b1d305407ac733d946898737159b5822ef858e19f4a50af77cd
MD5 5e8935654550c50c7e599ca9d6b6d6d0
BLAKE2b-256 54248543f4cbd4abf9ff1b7d5832797f52200ee4c106d0cd7af5a764676eb309

See more details on using hashes here.

File details

Details for the file pnnx-20250530-py3-none-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for pnnx-20250530-py3-none-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 99f20658091de43a786781efb2a7cec38b4f6d50a7eb38eb85661c42ffc3f3e6
MD5 8b5fa92f3829ade8b775309c62ccea43
BLAKE2b-256 979ff954ed6301ca5c31701ffa0297623ae0cfa242f1dcd53130dbe3aca4b5d4

See more details on using hashes here.

File details

Details for the file pnnx-20250530-py3-none-manylinux2014_aarch64.manylinux_2_17_aarch64.whl.

File metadata

File hashes

Hashes for pnnx-20250530-py3-none-manylinux2014_aarch64.manylinux_2_17_aarch64.whl
Algorithm Hash digest
SHA256 f83a1fb7a7c5a64f690fd6db1cfcc327ff590d53e796c5197e205e7c0418cd50
MD5 0f3b94cf4195b16746b738b548f3daf0
BLAKE2b-256 3a3ccf00c617c30b4746afdfcf5bf8655bc1bda881e6c5cb641cb981ed1df02b

See more details on using hashes here.

File details

Details for the file pnnx-20250530-py3-none-macosx_10_9_universal2.macosx_10_9_x86_64.macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pnnx-20250530-py3-none-macosx_10_9_universal2.macosx_10_9_x86_64.macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 d8ac0427cd84774e3986c12b0420fb8b1d92534d981ce3cd5552b70c95ae7739
MD5 eb3876a5844f6fda27b9adb1212edd7a
BLAKE2b-256 6277fda1e4914b46ff1527ccf42d1be6d3801da7c5ad9de342ea15de58f58eb2

See more details on using hashes here.

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