Project Icon

ai-edge-torch

PyTorch模型转TensorFlow Lite的开源解决方案

ai-edge-torch是一个开源Python库,用于将PyTorch模型转换为TensorFlow Lite格式。它支持在Android、iOS和IoT设备上本地运行模型,提供广泛的CPU支持和初步的GPU、NPU支持。该项目还包含生成式API,用于优化大型语言模型在设备端的性能。ai-edge-torch与PyTorch紧密集成,为边缘AI开发提供了实用的工具。

AI Edge Torch

AI Edge Torch 是一个 Python 库,支持将 PyTorch 模型转换为 .tflite 格式,然后可以使用 TensorFlow Lite 和 MediaPipe 运行。这使得 Android、iOS 和 IoT 应用程序能够完全在设备上运行模型。AI Edge Torch 提供广泛的 CPU 支持,并初步支持 GPU 和 NPU。AI Edge Torch 致力于与 PyTorch 紧密集成,基于 torch.export() 构建,并提供对核心 ATen 运算符的良好覆盖。

要开始将 PyTorch 模型转换为 TF Lite,请参阅 PyTorch 转换器 部分的更多详细信息。对于大型语言模型(LLM)和基于 Transformer 的模型,生成式 API 支持模型创作和量化,以提高设备上的性能。

虽然同属一个 PyPi 包,但 PyTorch 转换器是 Beta 版本,而生成式 API 是 Alpha 版本。请查看发布说明以获取更多信息。

PyTorch 转换器

以下是将 PyTorch 模型转换为 TFLite flatbuffer 的步骤:

import torch
import torchvision
import ai_edge_torch

# 使用预训练权重的 resnet18。
resnet18 = torchvision.models.resnet18(torchvision.models.ResNet18_Weights.IMAGENET1K_V1)
sample_inputs = (torch.randn(1, 3, 224, 224),)

# 转换并序列化 PyTorch 模型为 tflite flatbuffer。注意在转换前
# 我们将模型设置为评估模式。
edge_model = ai_edge_torch.convert(resnet18.eval(), sample_inputs)
edge_model.export("resnet18.tflite")

入门指南 Jupyter notebook 提供了转换过程的初步演示,可以在 Google Colab 中尝试。

PyTorch 转换器的更多技术细节请见此处

生成式 API

AI Edge Torch 生成式 API 是一个用于创作移动优化 PyTorch Transformer 模型的 Torch 原生库,这些模型可以转换为 TFLite,让用户轻松在移动设备上部署大型语言模型(LLM)。用户可以使用 AI Edge Torch PyTorch 转换器转换模型,并通过 TensorFlow Lite 运行时运行它们。参见此处

移动应用开发者还可以使用 Edge 生成式 API 将 PyTorch LLM 直接与 MediaPipe LLM 推理 API 集成,以便在应用程序代码中轻松整合。参见此处

更详细的文档可以在这里找到。

生成式 API 目前仅支持 CPU,计划未来支持 GPU 和 NPU。未来的另一个方向是与 PyTorch 社区合作,确保常用的 transformer 抽象可以直接支持,无需重新创作。

构建状态

构建类型状态
生成式 API (Linux)
模型覆盖率 (Linux)
单元测试 (Linux)
每日构建

安装

要求和依赖

  • Python 版本:3.9、3.10、3.11
  • 操作系统:Linux
  • PyTorch: torch
  • TensorFlow: tf-nightly

Python 虚拟环境

设置 Python 虚拟环境:

python -m venv --prompt ai-edge-torch venv
source venv/bin/activate

可以通过以下命令安装最新的稳定版本:

pip install ai-edge-torch

或者,可以通过以下命令安装每日构建版本:

pip install ai-edge-torch-nightly

如有必要,更新 LD_LIBRARY_PATH

Torch XLA 构建了一个共享库 _XLAC.so,需要链接到其构建时使用的 Python 版本(目前是 3.10 或 3.11)。为确保 import _XLAC 能够成功,请将 LD_LIBRARY_PATH 更新到您的 Python 环境的 lib 目录:

export LD_LIBRARY_PATH=<Python 安装路径>/lib:$LD_LIBRARY_PATH
  • 版本发布列表可以在这里查看。
  • 完整的 PyPi 发布列表(包括每日构建)可以在这里查看。

贡献

请参阅我们的贡献文档

获取帮助

如有任何问题,请创建 GitHub issue

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号