Project Icon

react-native-fast-tflite

React Native TensorFlow Lite库,支持JSI和GPU加速

这是一个高效的React Native TensorFlow Lite库,支持JSI和零拷贝ArrayBuffers,采用低级C/C++ TensorFlow Lite核心API实现直接内存访问,支持运行时模型交换和GPU加速(CoreML/Metal/OpenGL),并易于集成VisionCamera。该库允许轻松添加和加载TensorFlow Lite模型,支持从本地文件系统或远程URL加载模型,非常适合需要高效且灵活AI推理功能的React Native开发者,在应用中实现先进的计算机视觉和AI功能。

项目介绍:react-native-fast-tflite

react-native-fast-tflite 是一个为 React Native 开发的高性能 TensorFlow Lite 库。该库旨在为开发者提供快速高效的机器学习模型推理能力,以下是其主要特性:

特性

  • 🔥 JSI 驱动:利用 JavaScript Interface (JSI) 提升性能。
  • 💨 零拷贝 ArrayBuffers:通过零拷贝机制,提升数据传输速度。
  • 🔧 低级 C/C++ API:使用 TensorFlow Lite 的核心 API,直接进行内存访问。
  • 🔄 动态模型切换:支持在运行时替换 TensorFlow 模型。
  • 🖥️ GPU 加速:支持使用诸如 CoreML、Metal 及 OpenGL 等 GPU 加速器。
  • 📸 便捷的 VisionCamera 集成:与 VisionCamera 无缝集成,增强视觉处理能力。

安装步骤

  1. 添加 npm 包:
    yarn add react-native-fast-tflite
    
  2. 修改 metro.config.js,将 tflite 添加为支持的资源扩展:
    module.exports = {
        resolver: {
            assetExts: ['tflite', // ...其他资源
        }
    }
    
    这样,您就能在不重建应用的情况下,随时替换 .tflite 文件。
  3. (可选)如需启用 GPU 委托,请查看下文的“使用 GPU 委托”部分。
  4. 运行您的应用:
    yarn android
    # 或者
    npx pod-install && yarn ios
    

使用方法

  1. 找到需要使用的 TensorFlow Lite (.tflite) 模型,您可以在 tfhub.dev 上找到大量公共模型。
  2. 将该模型拖入 React Native 应用的资源文件夹中(如 src/assets/my-model.tflite)。
  3. 加载模型:
    • 选项 A:独立函数加载
    const model = await loadTensorflowModel(require('assets/my-model.tflite'))
    
    • 选项 B:在函数组件中使用 Hook 加载
    const plugin = useTensorflowModel(require('assets/my-model.tflite'))
    
  4. 调用模型:
    const inputData = ...
    const outputData = await model.run(inputData)
    console.log(outputData)
    

模型加载

模型可以通过 require(..) 从 React Native 包中加载,也可以从任意 URI/URL(如 http://..file://..)加载:

// 从 React Native 包中加载
loadTensorflowModel(require('assets/my-model.tflite'))
// 从本地文件系统加载
loadTensorflowModel({ url: 'file:///var/mobile/.../my-model.tflite' })
// 从远程 URL 加载
loadTensorflowModel({ url: 'https://tfhub.dev/google/lite-model/object_detection_v1.tflite' })

加载过程是异步的,因为需要分配 Buffers。在加载模型时务必检查潜在的错误。

输入和输出数据

TensorFlow 使用 tensors 作为输入和输出格式。由于 TensorFlow Lite 针对固定数组大小的字节缓冲区进行了优化,因此需要自行解释原始数据。

要检查 TensorFlow Lite 模型上的输入和输出 tensors,可以在 Netron 中打开模型。比如,在 tfhub.dev 上找到的 object_detection_mobile_object_localizer_v1_1_default_1.tflite 模型有 1 个输入张量4 个输出张量

使用(VisionCamera)

如果使用 VisionCamera 的帧处理器来运行该模型,需要将帧转化为 192 x 192 x 3 的字节数组。可以使用 vision-camera-resize-plugin 进行转换。具体实现代码在文档中有详细示例。

使用 GPU 委托

利用 GPU 委托可以加快计算速度。可以启用不同的 GPU 委托,如:

CoreML(iOS)

要在 iOS 上启用 CoreML 委托,必须在项目构建中包含它。在 Expo 和直接使用的 React Native 项目中有不同的启用方法,具体参考下文内容。

Android GPU/NNAPI(Android)

在 Android 上启用 GPU 或 NNAPI 委托,可能需要在 AndroidManifest.xml 中包含 OpenCL 库。

<uses-native-library android:name="libOpenCL.so" android:required="false" />

具体使用和配置方法请参考文档提供的示例代码和注意事项。

社区交流

加入 Margelo 社区 Discord,以交流关于 react-native-fast-tflite 或其他 Margelo 库的问题和经验。

贡献

如果希望为项目贡献力量,可以克隆仓库,根据开发指南进行设置和开发。

开源协议

该项目基于 MIT 开源协议。

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

豆包MarsCode

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

Project Cover

AI写歌

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

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

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

Project Cover

Kimi

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

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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