esp32 micropython spiffs_「ESP 教程」ESP32 如何运行 TensorFlow 模型

人工智能之父,艾伦·图灵很早就曾预测“有一天,人们会带着电脑在公园散步,并告诉对方,今天早上我的计算机讲了个很有趣的事。”

人类一直试图让机器具有智能,也就是人工智能(Artificial Intelligence)。从上世纪 50 年代开始,人工智能相继进入了“推理期”和“知识期”,在这两个阶段,机器都是按照人类设定的规则和总结的知识运作,永远无法超越其创造者。机器学习(Machine Learning)方法应运而生,人工智能进入“机器学习时期”。机器学习的核心是“使用算法解析数据,从中学习,然后对世界上的某件事情做出决定或预测”。这意味着,与其显式地编写程序来执行某些任务,不如教计算机如何开发一个算法来完成任务。

随着机器学习领域不断的发展,在移动、嵌入式和 IoT 设备上部署/运行机器学习模型也成为了可能。这篇文章仅介绍在 ESP32 上如何部署/运行 TensorFlow 模型。在 create_sine_model.ipynb 文章中将介绍 “Hello World!” 正弦模型相关代码。

TensorFlow Lite

TensorFlow 是一个端到端开源机器学习平台。它拥有一个包含各种工具、库和社区资源的全面灵活生态系统,可以让研究人员推动机器学习领域的先进技术的发展,并让开发者轻松地构建和部署由机器学习提供支持的应用。

TensorFlow Lite 是一组工具,可帮助开发人员在移动、嵌入式和 IoT 设备上部署/运行 TensorFlow 模型。 TensorFlow Lite 使设备上的机器学习推理具有低延迟的特性,并使可执行文件更小。

TensorFlow Lite 由两个主要组件组成:TensorFlow Lite 解释器 可在许多不同的硬件类型(包括手机,嵌入式 Linux 设备和微控制器)上运行经过优化的模型。

TensorFlow Lite 转换器 将 TensorFlow 模型转换为供解释器使用的有效形式,并且可以优化模型以改善可执行文件大小和性能。

接下来,将介绍如何将 TensorFlow Lite 运行在 ESP32 上,有两种方式:使用 ESP-IDF

使用 PlatformIO 平台

使用 ESP-IDF

1. 搭建 ESP-IDF 开发环境

检查 ESP-IDF 环境是否已经正确安装:检查 IDF_PATH 环境变量是否已经设置

检查 idf.py 和 xtensa-esp32-elf-* 工具链是否在 PATH 环境变量中

2. 克隆 TensorFlow

通过下面的命令,将 TensorFlow 克隆到本地:

git clone https://github.com/tensorflow/tensorflow.git

3. 生成 hello_world 示例项目

在 tensorflow 目录下通过下面的命令,可以生成 hello_world 示例项目:

make -f tensorflow/lite/micro/tools/make/Makefile TARGET=esp generate_hello_world_esp_project

4. 部署到 ESP32

在 hello_world 项目目录下,编译、烧录可执行文件到 ESP32:

cd tensorflow/lite/micro/tools/make/gen/esp_xtensa-esp32/prj/hello_world/esp-idf

idf.py --port /dev/ttyUSB0 flash monitor

运行结果:

使用 PlatformIO 平台

1. 安装 TensorFlow Lite 环境(PlatformIO)

首先,需要安装 PlatformIO ,打开终端输入:

pip install -U platformio

2. 新建 PlatformIO 项目

接下来可以开始搭建软件框架了,详细步骤:创建项目目录,包含 src,lib,include 文件夹

新建 platformio.ini 文件,文件内容:[env:esp32doit-devkit-v1] platform = espressif32 board = esp32doit-devkit-v1 framework = arduino board_build.partitions = custom.csv lib_deps=tfmicro

新建 custom.csv 文件,文件内容:# Name, Type, SubType, Offset, Size, Flags nvs, data, nvs, 0x9000, 20K, otadata, data, ota, 0xe000, 8K, firm, app, ota_0, , 3400K, eeprom, data, 0x99, , 4K, spiffs, data, spiffs, , 444K,

3. 生成 hello_world 示例项目在项目目录所在目录下,克隆 TensorFlow 仓库

git clone https://github.com/tensorflow/tensorflow.git

生成 ESP32 示例项目,获取生成的 tfmicro 库和示例模型,在 Tensorflow 目录下,运行:

make -f tensorflow/lite/micro/tools/make/Makefile TARGET=esp generate_hello_world_esp_project

生成的示例项目位于:

tensorflow/tensorflow/lite/micro/tools/make/gen/esp_xtensa-esp32/prj/hello_world/

4. 修改 PlatformIO 项目在 hello_world/esp-idf 目录中拷贝 tfmicro 文件夹到 项目目录下的 lib 文件夹

在 main 目录中拷贝 http://sin_model_data.cc 到 项目目录下的 src 文件夹,拷贝 sine_model_data.h 到 项目目录下的 include 文件夹

在 third_party/flatbuffers/include 目录中拷贝 flatbuffers 目录到 tfmicro 文件夹.

在 third_party/gemmlowp 目录中拷贝 fixedpoint 和 internal 目录到 tfmicro 文件夹.

在 third_party 目录中拷贝 kissfft 目录到 tfmicro 文件夹.

在 third_party/flatbuffers/include 目录中拷贝 flatbuffers 到 tfmicro 文件夹

在 lib/tfmicro/flatbuffers 目录下打开 base.h, 将以下代码段

#if defined(ARDUINO) && !defined(ARDUINOSTL_M_H) #include #else #include #endif

修改为:

#include

接下来修改 “Hello World!” sin 模型来测试 TensorFlow Lite 是否正常工作,完整的源代码请在 GitHub 仓库中查看

代码结构:

5. 部署到 ESP32

在终端中输入以下命令将可执行文件烧录到 ESP32:

platformio run -t upload --upload-port /dev/ttyUSB0

在终端中输入以下命令将打开串口交互终端,输入一个浮点数,程序将给出 sin 模型预测的值:

screen /dev/ttyUSB0 115200

运行结果:

开发工作流程

这是将 TensorFlow 模型部署到微控制器的过程:创建或获取 TensorFlow 模型

该模型必须非常小,以便在转换后适合您的目标设备。它只能使用支持的操作。如果要使用当前不被支持的操作,可以提供自己的实现。

将模型转换为 TensorFlow Lite FlatBuffer

您将使用 TensorFlow Lite 转换器来将模型转换为标准 TensorFlow Lite 格式。您可能希望输出量化模型,因为它们的尺寸更小、执行效率更高。

将 FlatBuffer 转换为 C byte 数组

模型保存在只读程序存储器中,并以简单的 C 文件的形式提供。标准工具可用于将 FlatBuffer 转换为 C 数组。

集成 TensorFlow Lite for Microcontrollers 的 C++ 库

编写微控制器代码以使用 C++ 库执行推断。

部署到您的设备

构建程序并将其部署到您的设备。

参考链接

你可能感兴趣的:(esp32,micropython,spiffs)