边缘AI应用的开发流程

描述

如果在没有嵌入式处理器供应商提供的合适工具和软件的支持下,既想设计高能效的边缘人工智能 (AI) 系统,同时又要加快产品上市时间,这项工作难免会冗长乏味。面临的一系列挑战包括选择恰当的深度学习模型、针对性能和精度目标对模型进行训练和优化,以及学习使用在嵌入式边缘处理器上部署模型的专用工具。

从模型选择到在处理器上部署,TI 可免费提供相关工具、软件和服务,为您深度神经网络 (DNN) 开发工作流程的每一步保驾护航。下面让我们来了解如何不借助手动工具或手动编程来选择模型、随时随地训练模型并将其无缝部署到 TI 处理器上,从而实现硬件加速推理。

嵌入式

图 1:边缘 AI 应用的开发流程

第一步:选择模型

边缘 AI 系统开发的首要任务是选择合适的 DNN 模型,同时要兼顾系统的性能、精度和功耗目标。GitHub 上的TI 边缘 AI Model Zoo等工具可助您加速此流程。

Model Zoo 广泛汇集了 TensorFlow、PyTorch 和 MXNet 框架中常用的开源深度学习模型。这些模型在公共数据集上经过预训练和优化,可以在 TI 适用于边缘 AI 的处理器上高效运行。TI 会定期使用开源社区中的新模型以及 TI 设计的模型对 Model Zoo 进行更新,为您提供性能和精度经过优化的广泛模型选择。

Model Zoo 囊括数百个模型,TI 模型选择工具(如图 2 所示)可以帮助您在不编写任何代码的情况下,通过查看和比较性能统计数据(如推理吞吐量、延迟、精度和双倍数据速率带宽),快速比较和找到适合您 AI 任务的模型。

嵌入式

图 2:TI 模型选择工具

第二步:训练和优化模型

选择模型后,下一步是在 TI 处理器上对其进行训练或优化,以获得出色的性能和精度。凭借我们的软件架构和开发环境,您可随时随地训练模型。

从 TI Model Zoo 中选择模型时,借助训练脚本可让您在自定义数据集上为特定任务快速传输和训练模型,而无需花费较长时间从头开始训练或使用手动工具。训练脚本、框架扩展和量化感知培训工具可帮助您优化自己的 DNN 模型。

第三步:评估模型性能

在开发边缘 AI 应用之前,需要在实际硬件上评估模型性能。

TI 提供灵活的软件架构和开发环境,您可以在 TensorFlow Lite、ONNX RunTime 或 TVM 和支持 Neo AI DLR 的 SageMaker Neo 运行环境引擎三者中选择习惯的业界标准 Python 或 C++ 应用编程接口 (API),只需编写几行代码,即可随时随地训练自己的模型,并将模型编译和部署到 TI 硬件上。在这些业界通用运行环境引擎的后端,我们的TI 深度学习 (TIDL) 模型编译和运行环境工具可让您针对 TI 的硬件编译模型,将编译后的图或子图部署到深度学习硬件加速器上,并在无需任何手动工具的情况下实现卓越的处理器推理性能。

在编译步骤中,训练后量化工具可以自动将浮点模型转换为定点模型。该工具可通过配置文件实现层级混合精度量化(8 位和 16 位),从而能够足够灵活地调整模型编译,以获得出色的性能和精度。

不同常用模型的运算方式各不相同。同样位于 GitHub 上的 TI 边缘 AI 基准工具可帮助您为 TI Model Zoo 中的模型无缝匹配 DNN 模型功能,并作为自定义模型的参考。

评估 TI 处理器模型性能的方式有两种:TDA4VM 入门套件评估模块 (EVM) 或 TI Edge AI Cloud,后者是一项免费在线服务,可支持远程访问 TDA4VM EVM,以评估深度学习推理性能。借助针对不同任务和运行时引擎组合的数个示例脚本,五分钟之内便可在 TI 硬件上编程、部署和运行加速推理,同时收集基准测试数据。

第四步:部署边缘 AI 应用程序

您可以使用开源 Linux 和业界通用的 API 来将模型部署到 TI 硬件上。然而,将深度学习模型部署到硬件加速器上只是难题的冰山一角。

为帮助您快速构建高效的边缘 AI 应用,TI 采用了 GStreamer 框架。借助在主机 Arm 内核上运行的 GStreamer 插件,您可以自动将计算密集型任务的端到端信号链加速部署到硬件加速器和数字信号处理内核上。

图 3 展示了适用于边缘 AI 的 Linux Processor SDK 的软件栈和组件。

嵌入式

图 3:适用于边缘 AI 的 Linux Processor SDK 组件

结语

如果您对本文中提及的工具感到陌生或有所担忧,请放宽心,因为即使您想要开发和部署 AI 模型或构建 AI 应用,也不必成为 AI 专家。TI Edge AI Academy 能够帮助您在自学、课堂环境中通过测验学习 AI 基础知识,并深入了解 AI 系统和软件编程。实验室提供了构建“Hello World” AI 应用的分步代码,而带有摄像头捕获和显示功能的端到端高级应用使您能够按照自己的节奏顺利开发 AI 应用。

原文标题:技术干货|嵌入式边缘 AI 应用开发简化指南

文章出处:【微信公众号:德州仪器】欢迎添加关注!文章转载请注明出处。

审核编辑:汤梓红

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分