flutter-tflite

flutter-tflite

Flutter专用的TensorFlow Lite高效集成插件

flutter-tflite是Flutter生态系统中的TensorFlow Lite集成插件。它支持Android和iOS平台,可使用任何TFLite模型,并提供NNAPI和GPU加速。通过直接绑定TFLite C API,该插件实现低延迟操作,并提供类似TFLite Java和Swift的API。开发者可进行简单的模型推理,还能在独立isolate中运行以优化UI性能。

TensorFlow LiteFlutter机器学习移动应用开发跨平台Github开源项目
<p align="center"> <br> <img src="https://yellow-cdn.veclightyear.com/835a84d5/6c371bd7-c34d-4f4c-afd7-3d74902aa887.png"/> </br> </p> <p align="center"> <a href="https://flutter.dev"> <img src="https://img.shields.io/badge/Platform-Flutter-02569B?logo=flutter" alt="平台" /> </a> <a href="https://pub.dartlang.org/packages/tflite_flutter"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/4c085ac1-062c-426b-81b9-4322c1bfc3b5.svg" alt="Pub 包" /> </a> <a href="https://pub.dev/documentation/tflite_flutter/latest/tflite_flutter/tflite_flutter-library.html"> <img alt="文档" src="https://readthedocs.org/projects/hubdb/badge/?version=latest"> </a> <a href="https://opensource.org/licenses/Apache-2.0"><img src="https://yellow-cdn.veclightyear.com/835a84d5/71e9b291-6ab6-40e4-9eba-7827b9dbc545.svg"></a> </a> </p>

公告

更新:2023年4月26日

这个仓库是由TensorFlow管理的、由杰出的Amish Garg创建的tflite_flutter_plugin项目的分支。该项目的目标是支持我们的Flutter社区使用TensorFlow Lite框架创建基于机器学习的应用程序。

这个项目目前正在进行中,我们正在更新它以创建一个符合最新Flutter和TensorFlow Lite标准的工作插件。也就是说,我们非常欢迎拉取请求和贡献,这些将由TensorFlow或Flutter团队成员进行审核。我们感谢您在我们更新过程中的理解。

如果有任何问题,请随时通过在问题或讨论区发帖与我们联系。

谢谢!

  • PaulTR

概述

TensorFlow Lite Flutter插件为访问TensorFlow Lite解释器和执行推理提供了灵活快速的解决方案。其API与TFLite Java和Swift API相似。它直接绑定到TFLite C API,使其高效(低延迟)。在Android上提供NNAPI、GPU委托的加速支持,在iOS上提供Metal和CoreML委托的支持,在桌面平台上提供XNNPack委托的支持。

主要特点

  • 支持Android和iOS多平台
  • 灵活使用任何TFLite模型
  • 使用多线程加速
  • 结构与TensorFlow Lite Java API相似
  • 推理速度接近使用Java API构建的原生Android应用
  • 在不同的isolate中运行推理,防止UI线程出现卡顿

(重要)初始设置:将动态库添加到您的应用

Android 和 iOS

示例和支持现在支持动态库下载!iOS示例可以通过在各自的iOS文件夹中运行以下命令来执行:

flutter build iosflutter install ios

Android可以通过以下命令运行:

flutter build androidflutter install android

注意:这需要设备的最低API级别为26。

注意:TFLite可能在iOS模拟器中无法工作。建议使用物理设备进行测试。

在创建发布存档(IPA)时,Xcode会剥离符号,因此flutter build ipa命令可能会抛出Failed to lookup symbol ... symbol not found错误。要解决这个问题:

  1. 在Xcode中,转到Target Runner > Build Settings > Strip Style
  2. All Symbols更改为Non-Global Symbols

MacOS

对于MacOS,需要手动将TensorFlow Lite动态库添加到项目中。 为此,首先需要构建一个.dylib。您可以按照Bazel构建指南CMake构建指南来构建库。

CMake注意事项:

  • 在CMake中进行交叉编译可以使用: -DCMAKE_OSX_ARCHITECTURES=x86_64|arm64

  • 使用lipo捆绑两种架构(arm / x86): lipo -create arm64/libtensorflowlite_c.dylib x86/libtensorflowlite_c.dylib -output libtensorflowlite_c.dylib 作为第二步,需要将库添加到你的应用程序的XCode项目中。为此,你可以按照Flutter官方指南中添加动态库的步骤1和2进行操作。

Linux

对于Linux,需要手动将TensorFlow Lite动态库添加到项目中。 首先需要构建一个.so文件。你可以按照Bazel构建指南CMake构建指南来构建库文件。

第二步,需要将库文件添加到你的应用程序项目中。这是一个简单的过程:

  1. 在你的项目顶层创建一个名为blobs的文件夹
  2. libtensorflowlite_c-linux.so复制到这个文件夹中
  3. 在你的linux/CMakeLists.txt文件中添加以下行:
... # 获取tf lite二进制文件 install( FILES ${PROJECT_BUILD_DIR}/../blobs/libtensorflowlite_c-linux.so DESTINATION ${INSTALL_BUNDLE_DATA_DIR}/../blobs/ )

Windows

对于Windows,需要手动将TensorFlow Lite动态库添加到项目中。 首先需要构建一个.dll文件。你可以按照Bazel构建指南CMake构建指南来构建库文件。

第二步,需要将库文件添加到你的应用程序项目中。这是一个简单的过程:

  1. 在你的项目顶层创建一个名为blobs的文件夹
  2. libtensorflowlite_c-win.dll复制到这个文件夹中
  3. 在你的windows/CMakeLists.txt文件中添加以下行:
... # 获取tf lite二进制文件 install( FILES ${PROJECT_BUILD_DIR}/../blobs/libtensorflowlite_c-win.dll DESTINATION ${INSTALL_BUNDLE_DATA_DIR}/../blobs/ )

TFLite Flutter辅助库

辅助库已被弃用。新的替代开发正在进行中,地址为https://github.com/google/flutter-mediapipe。当前计划是在2023年8月底前提供广泛支持。

导入

import 'package:tflite_flutter/tflite_flutter.dart';

使用说明

导入库

pubspec.yaml文件的依赖部分,添加tflite_flutter: ^0.10.1(根据最新发布版本相应调整版本号)

创建解释器

  • 从资源文件创建

    your_model.tflite放在assets目录下。确保在pubspec.yaml中包含了assets。

    final interpreter = await Interpreter.fromAsset('assets/your_model.tflite');

参考文档以了解如何从缓冲区或文件创建解释器。

执行推理

  • 单一输入和输出

    使用void run(Object input, Object output)

    // 例如:如果输入张量形状为[1,5],类型为float32 var input = [[1.23, 6.54, 7.81, 3.21, 2.22]]; // 如果输出张量形状为[1,2],类型为float32 var output = List.filled(1*2, 0).reshape([1,2]); // 推理 interpreter.run(input, output); // 打印输出 print(output);
  • 多个输入和输出

    使用void runForMultipleInputs(List<Object> inputs, Map<int, Object> outputs)

    var input0 = [1.23]; var input1 = [2.43]; // 输入:List<Object> var inputs = [input0, input1, input0, input1]; var output0 = List<double>.filled(1, 0); var output1 = List<double>.filled(1, 0); // 输出:Map<int, Object> var outputs = {0: output0, 1: output1}; // 推理 interpreter.runForMultipleInputs(inputs, outputs); // 打印输出 print(outputs)

关闭解释器

interpreter.close();

使用IsolateInterpreter进行异步推理

要使用异步推理,首先创建你的Interpreter,然后用IsolateInterpreter包装它。

final interpreter = await Interpreter.fromAsset('assets/your_model.tflite'); final isolateInterpreter = await IsolateInterpreter.create(address: interpreter.address);

isolateInterpreterrunrunForMultipleInputs 方法都是异步的:

await isolateInterpreter.run(input, output); await isolateInterpreter.runForMultipleInputs(inputs, outputs);

通过使用 IsolateInterpreter,推理过程在一个单独的 isolate 中运行。这确保了负责 UI 任务的主 isolate 不会被阻塞,保持响应性。

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多