Project Icon

flutter-tflite

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

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



平台 Pub 包 文档

公告

更新: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 不会被阻塞,保持响应性。

项目侧边栏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号