Convert PyTorch models to CoreAI format
Project description
Core AI PyTorch Extensions (coreai-torch)
Core AI PyTorch Extensions (coreai-torch) is a Python package that bridges PyTorch and Core AI. Use it to bring up an existing PyTorch model into Core AI IR, or to author Core AI models directly from PyTorch by composing the built-in composite op library (coreai_torch.composite_ops), authoring new ops via register_torch_lowering, and authoring inline Metal GPU kernels via TorchMetalKernel. The resulting IR can be compiled and executed efficiently by the Core AI inference stack.
🔗 Jump to: Getting started · Documentation · Contributing · Support · License
Overview
coreai-torch traverses a torch.export.ExportedProgram and produces Core AI
IR — the same IR consumed by the Core AI compiler and runtime. The public entry
point is TorchConverter, which lowers PyTorch operators to Core AI dialect
operations, preserves location and module-stack information for debugging, and
provides extension points for custom Metal kernels and submodule
externalization.
Getting started
Installation
pip install coreai-torch
Or from source with uv:
uv sync
Usage
TorchConverter accepts models in two forms. Pick based on what you have and whether you need externalization:
| You have | Use |
|---|---|
A decomposed ExportedProgram |
add_exported_program() |
An nn.Module + need externalization |
add_pytorch_module() with externalize_modules |
An nn.Module, no externalization |
Either method — add_exported_program() is more direct |
From an ExportedProgram
You export and decompose the model yourself, then pass the ExportedProgram directly.
Use get_decomp_table() so that composite ops (instance_norm, pixel_shuffle, scaled_dot_product_attention) are preserved for optimal runtime performance.
import torch
from coreai_torch import TorchConverter, get_decomp_table
model = ... # your nn.Module
model.eval()
# Export and decompose — this is your responsibility
ep = torch.export.export(model, args=(torch.randn(1, 3, 224, 224),))
ep = ep.run_decompositions(get_decomp_table())
# Convert to Core AI IR
converter = TorchConverter().add_exported_program(ep)
coreai_program = converter.to_coreai()
coreai_program.optimize()
From an nn.Module
Pass your model and an export_fn that returns a decomposed ExportedProgram. This is equivalent to calling add_exported_program() with the result of export_fn.
import coreai_torch
from coreai_torch import TorchConverter
model = ... # your nn.Module
model.eval()
sample = (torch.randn(1, 3, 224, 224),)
converter = TorchConverter().add_pytorch_module(
model,
export_fn=lambda m: torch.export.export(m, args=sample).run_decompositions(
coreai_torch.get_decomp_table()
),
)
coreai_program = converter.to_coreai()
coreai_program.optimize()
Documentation
- API reference and conversion guides — see the
docs/directory - Supported model types and ops — see the operator coverage notebooks under
docs/
Building docs locally
uv sync --extra docs
uv run jupyter-book build docs/
open docs/_build/html/index.html
Development
Running tests
uv sync --extra test
uv run pytest tests/ -n auto
Testing notebooks
uv run pytest docs/ --nbmake -v
Contributing
We welcome contributions within a defined scope. Please read CONTRIBUTING.md carefully before opening a pull request or issue — particularly the section on contribution scope.
Support
- GitHub Issues — Bug reports, feature requests, and questions
Security and code of conduct
Security vulnerability reporting and the Code of Conduct for this project are
governed at the org level via the
Apple Open Source .github repository.
License
This project is licensed under the BSD 3-Clause License.
Related projects
- Core AI — Apple's on-device AI inference stack
- Core AI Optimization — model compression for deployment on Apple Silicon
- Core AI Models — ready-to-run optimized models, Python reproduction scripts, and Swift utilities for on-device integration
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file coreai_torch-0.4.1.tar.gz.
File metadata
- Download URL: coreai_torch-0.4.1.tar.gz
- Upload date:
- Size: 212.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.23 {"installer":{"name":"uv","version":"0.11.23","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2499429cc94f9e487122420b36b84c83b39a142505c4a54572572147bccc50fa
|
|
| MD5 |
fd6449d9ab1811f41639f07ded1409c2
|
|
| BLAKE2b-256 |
38c10677a598a38c0c8a6af7156318015bcc2c8f4b59c68d091442690902459d
|
File details
Details for the file coreai_torch-0.4.1-py3-none-any.whl.
File metadata
- Download URL: coreai_torch-0.4.1-py3-none-any.whl
- Upload date:
- Size: 199.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.23 {"installer":{"name":"uv","version":"0.11.23","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e2aae98339413b62c03132363dc397936f2b0d90747766852390ba220d085f54
|
|
| MD5 |
2fb91fa6d17e87f8d2b2c154467a5a52
|
|
| BLAKE2b-256 |
53bd0f377299bfd8d29cb44f3e803dcdadcee345d047097de84ce64199579ed9
|