Convert PyTorch models to LiteRT

AI Edge Torch is a library that lets you convert PyTorch models into a .tflite format, enabling you to run those models with LiteRT and MediaPipe. This is especially helpful for developers creating mobile apps that run models completely on-device. AI Edge Torch offers broad CPU coverage, with initial GPU and NPU support.

To get started converting PyTorch models to LiteRT, use the Pytorch converter quickstart. For more information, see the AI Edge Torch GitHub repo.

If you are specifically converting Large Language Models (LLMs) or transformer-based models, use the Generative Torch API, which handles transformer-specific conversion details like model authoring and quantization.

Conversion workflow

The following steps demonstrate a simple end-to-end conversion of a PyTorch model to LiteRT.

Import AI Edge Torch

Start by importing the AI Edge Torch (ai-edge-torch) pip package, along with PyTorch.

import ai_edge_torch
import torch

For this example, we also require the following packages:

import numpy
import torchvision

Initialize and convert the model

We will convert ResNet18, a popular image recognition model.

resnet18 = torchvision.models.resnet18(torchvision.models.ResNet18_Weights.IMAGENET1K_V1).eval()

Use the convert method from the AI Edge Torch library to convert the PyTorch model.

sample_input = (torch.randn(1, 3, 224, 224),)
edge_model = ai_edge_torch.convert(resnet18.eval(), sample_input)

Use the model

After converting the Pytorch model, you can run inferences with the new converted LiteRT model.

output = edge_model(*sample_inputs)

You can export and save the converted model in the .tflite format for future use.

edge_model.export('resnet.tflite')