当前位置: 首页 > news >正文

使用AI-01开发板和开源后端服务搭建整套小智服务系统

使用AI-01开发板和开源后端服务搭建整套小智服务系统

四博智联的AI-01开发板,基于乐鑫ESP32-C2 + 专属定制的离线语音模组,能够完美的接入小智AI服务平台,再使用开源后端服务,就能够搭建一个完整的小智AI服务系统了。

下面是具体的搭建过程。

硬件连接

AI-01开发板没有板载USB转串口功能,需要自己通过USB转串口工具来连接到电脑,以便下载固件和查看日志输出信息。
参考官方提供的接线指导:下载说明
在这里插入图片描述

具体连线如下:
在这里插入图片描述

在实际使用中,USB转串口工具仅需连接到AI-01开发板的TX、RX、GND即可。然后用Tyep-C数据线给AI-01开发板供电即可。
需要注意的是,因为AI-01开发板没有提供RESET按钮,所以后续需要通过插拔Tyep-C数据线来重新上电,实现AI-01开发板的重启运行。

按照接线指导连接好以后,将USB转串口工具连接到电脑,再打开电脑的设备管理器,确保正确识别到对应的串口,并显示在端口(COM和LPT)中:
在这里插入图片描述

可以拔掉USB转串口工具,对应的设备会消失。然后过几秒,再重新连接到电脑的USB口,会重新出现。

建立ESP-IDF开发环境

小智AI系统硬件设备的开源代码,可以在VSCode中安装ESP-IDF的扩展和编译工具,来进行编译和烧录。

安装ESP-IDF扩展

首先安装VSCode,可以从https://code.visualstudio.com/download下载。
安装后,打开VSCode,点击右则导航栏的3+1方块图标,进入扩展安装,然后搜索esp-idf安装即可:
在这里插入图片描述

安装ESP-IDF编译工具

安装完ESP-IDF扩展后,点击右边导航栏的乐鑫圆形图标,在Advanced中点击配置ESP-IDF扩展,然后选择EXPRESS进入安装配置:
在这里插入图片描述

在安装配置界面中,按照下图选择从中国服务器下载(for China),并选择v5.3.3版本,再点击Install安装:
在这里插入图片描述

然后,耐心等待安装完成:
在这里插入图片描述

设置ESP-IDF扩展

安装完成后,从ESP-IDF扩展的安装界面,先设置图标,在选择设置:
在这里插入图片描述

在设置界面中,先搜索flash,设置烧录的波特率为921600:
在这里插入图片描述

再搜索monitor,设置串口监视的波特率为74880:
在这里插入图片描述

编译运行示例程序

现在开发环境已经安装配置好了,为了确保能够正常使用,可以运行一个示例程序进行检验。

点击右边导航栏的乐鑫圆形图标,在Advanced中点击展示示例项目,在列出的项目中,选择hello_world,然后点击Select location for hello_world project
在这里插入图片描述

点击后,会提示示例项目保存目录,设置一个目录保存即可。
创建成功后,会自动打开新建的hello world的项目工作界面:
在这里插入图片描述

然后按照下图,点击选择之前在设备管理器中显示的USB转串口工具设备端口号,以及芯片类型esp32c2:
在这里插入图片描述

再点击构建图标,即可编译hello_world的源码:
在这里插入图片描述

编译成功后,会显示如下的内存占用情况:
在这里插入图片描述

在下一步操作之前,需要从电脑先断开AI-01开发板的Tyep-C数据线,再按住AI-01开发板上的按键不放,然后重新连接到电脑上,让AI-01开发板进入下载固件模式。连接完成后,可以松开按键。

操作完成后,再点击底部的ESP-IDF:构建、烧录和监视图标,并在顶部弹出列表中选择UART
在这里插入图片描述

随后,会自动完成编译源码,烧录固件到AI-01开发板,并启动串口监视:
在这里插入图片描述

当VSCode下部的窗口,显示上述信息后,重新插拔AI-01开发板的Tyep-C数据线,AI-01开发板将重新上电运行前面烧录的程序,并输出Hello World
在这里插入图片描述

在进行下一步操作之前,需要点击上述信息输出界面右则各任务输出窗口的回收站图标终止任务,否则后续操作中,烧录和监视串口会有问题。
在这里插入图片描述

成功完成以上各项操作后,ESP-IDF开发环境就准备好了,可以进行后续操作,编译小智AI系统硬件设备的开源代码了。

编译运行DOIT小智AI开源代码

因为AI-01开发板使用的是乐鑫ESP32-C2 + 专属定制的离线语音模组,在小智AI官方的开源代码中没有适配,所以四博智联基于小智AI官方的开源代码,提供了对应的分支版本DOIT_AI,和官方版本的功能没有差异。

下载源码

DOIT_AI的源码,可以从https://github.com/SmartArduino/DOIT_AI下载最新版本:
在这里插入图片描述

在上述界面中,可以使用git工具clone源码,也可以直接下载源码的压缩包。

设置编译参数

使用VSCode打开下载的源码,参考前面hello world,设置串口端口号和芯片类型esp32c2。
另外,还需要通过SDK配置编辑器(menuconfig),开设置Xiaozhi的Board TypeDoit-AI-01-Kit
在这里插入图片描述

保存设置后,点击底部的构建来编译源码:
在这里插入图片描述

编译成功后,显示如下信息:
在这里插入图片描述

烧录运行

在下一步操作之前,需要从电脑先断开AI-01开发板的Tyep-C数据线,再按住AI-01开发板上的按键不放,然后重新连接到电脑上,让AI-01开发板进入下载固件模式。连接完成后,可以松开按键。

操作完成后,再点击底部的ESP-IDF:构建、烧录和监视图标,并在顶部弹出列表中选择UART
在这里插入图片描述

界面会显示如下信息,表示正在烧录固件:
在这里插入图片描述

如果执行后,出现下面的错误,说明串口被占用,或者连接不正确:
在这里插入图片描述

烧录完成后,显示信息如下:
在这里插入图片描述

当VSCode下部的窗口,显示上述信息后,重新插拔AI-01开发板的Tyep-C数据线,AI-01开发板将重新上电运行前面烧录的程序,并输出小智AI运行的信息:
在这里插入图片描述

配网运行

首次烧录运行后,会输出上述配网信息,并语音播报进入配网模式
此时,使用手机连接Xiaozhi开头的热点:
在这里插入图片描述

就能进入配网界面,设置当前环境所使用的WiFi名称和密码:
在这里插入图片描述

配置成功后,AI-01开发板运行的小智AI系统会自动重启,并输出如下的信息:
在这里插入图片描述

激活设备

首次配置网络后,会提示需要激活设备,并语音播报激活信息。
访问小智AI服务平台官网https://xiaozhi.me/,进入控制台注册账号并登录:
在这里插入图片描述

然后,添加新的智能体:
在这里插入图片描述

添加后,点击添加设备:
在这里插入图片描述

然后输入播报或者显示的数字:
在这里插入图片描述

激活成功后,系统会自动重新启动,启动完成,会听到嘟的一声响:
在这里插入图片描述

现在,就可以使用你好小智唤醒小智AI,然后进行对话了。也可以使用按键进行唤醒,然后进行对话。
在这里插入图片描述

搭建开源后端服务

AI-01开发板运行的小智系统,默认会连接到小智AI官方的服务平台。
我们可以使用开源后端服务的源码,来运行自己的小智AI后端服务,让AI-01开发板连接到自己的后端服务。

下载后端服务源码

从https://github.com/xinnan-tech/xiaozhi-esp32-server/releases 可以下载最新发布的开源后端服务的源码:
在这里插入图片描述

下载后解压源码,找到如下的目录,准备后续的操作:
在这里插入图片描述

下载语音识别模型文件

开源后端服务可以在本地运行语音识别服务(ASR),但需要下载对应的模型文件:https://modelscope.cn/models/iic/SenseVoiceSmall/resolve/master/model.pt

下载后,将该文件放置到main/xiaozhi-server/models/目录中:
在这里插入图片描述

安装 Anaconda

要运行开源后端服务,还需要Anaconda来安装python环境运行。
从 https://www.anaconda.com/download/success 下载Windows对应的Anaconda安装包 Anaconda3-2024.10-1-Windows-x86_64.exe
在这里插入图片描述

下载完成后,打开安装包安装,并在配置时,全部打钩:
在这里插入图片描述

安装完成后,搜索Anaconda,打开Anaconda Prompt
在这里插入图片描述

打开后,进入xiaozhi-server对应的目录,并执行下面的命令以查看conda版本,检测是否安装成功:

conda -V

在这里插入图片描述

创建Python运行环境

然后,执行下面的命令,创建需要的Python运行环境:

conda create -n xiaozhi-esp32-server python=3.10 -y

执行成功后,会输出如下的信息:
在这里插入图片描述

再依次执行下面的每一条命令,使用创建的环境,并安装需要的支持包:

conda activate xiaozhi-esp32-serverconda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud/conda-forgeconda install libopus -y
conda install ffmpeg -y

在这里插入图片描述

安装完成后,执行下面命令,检验是否安装正确:

python -V
conda list opus
conda list ffmpeg

在这里插入图片描述

最后,执行下面的命令,安装开源后端服务所依赖的包:

pip config set global.index-url https://mirrors.aliyun.com/pypi/simple/
pip install -r requirements.txt

在这里插入图片描述

安装成功后,会输出如下信息:
在这里插入图片描述

获取大模型apikey

开源后端服务运行时,需要调用LLM(大语言模型)接口,完成AI对话工作。

默认的LLM使用的是ChatGLM,去ChatGLM的官网https://bigmodel.cn/注册登录,然后添加新的Api Key,就可以免费使用:
在这里插入图片描述

配置后端服务

要运行小智后端服务,还需要做一些基础的配置。

首先,如果电脑上有多块网卡,或者运行了VMWare等虚拟机服务的话,上面显示的IP地址不一定是实际联网使用的,可以查看网络连接的属性,来获取当前使用的IP地址:
在这里插入图片描述

然后,执行下面的命令生成默认的配置文件:

mkdir data
copy config.yaml data\.config.yaml

在这里插入图片描述

再用VSCode打开后端服务源码目录xiaozhi-server,并打开data目录中的.config.yaml修改配置:
在这里插入图片描述

根据配置中的提示,修改如下位置:

  • websocket地址:
    在这里插入图片描述

修改websocket的地址,使用前面查看网络属性得到的IPv4地址,端口使用8000即可。

  • ChatGLMLLM的api key:
    在这里插入图片描述

将ChatGLMLLM的api_key,设置为前面获取的ChatGLM的apikey即可。

运行后端服务

上述操作都成功完成后,执行下面的命令,运行后端服务:

python app.py

运行成功后,将会出现如下的信息:
在这里插入图片描述

如果出现下面的提示,一定要点击允许:
在这里插入图片描述

根据前面获取的IPv4地址,最终的服务地址如下:

  • OTA接口地址:http://192.168.1.182:8002/xiaozhi/ota/
  • WebSocket接口地址:ws://192.168.1.182:8000/xiaozhi/v1/

测试后端服务

打开如下目录中的test.html,可以通过网页测试后端服务是否正常:
在这里插入图片描述

在测试界面中,填入上一步最终得到的OTA接口地址和WebSocket接口地址,就可以连接测试:
在这里插入图片描述

配置说明

开源后端服务配置文件中,有很多方面参数可以配置。
例如可以设置AI的人设,以及调用的LLM和TTS配置:
在这里插入图片描述

开源后端服务默认使用的LLM是ChatGLM,免费且速度快,但智能的能力并不是最好的,而使用的语音合成(TTS)服务是EdgeTTS,免费但是速度不快。
如果要想使用更好的效果,可以详细查看开源后端服务配置文件的说明,去开通相应平台的账号,获取对应的连接参数填入:
在这里插入图片描述

在这里插入图片描述

并启用对应的配置:
在这里插入图片描述

设置好对应的配置以后,重新启动后端服务即可生效。

另外,上面搭建的是简化版本的开源后端服务,让大家快速体验自己搭建整套小智服务系统。
如果参考开源后端服务的文档,搭建完整版的后端服务,还包括管理界面,功能非常的强大:
在这里插入图片描述

设置AI-01开发板OTA地址

现在开源后端服务已经成功运行了,只需要将AI-01开发板OTA地址,设置为上一节中最后获取的OTA接口地址,就可以连接到自己的后端服务了。

配置OTA地址

使用VSCode打开设备端DOIT_AI源码,参考之前设置编译参数,通过SDK配置编辑器(menuconfig),设置OTA地址:
在这里插入图片描述

重新编译源码

设置了OTA参数后,点击底部的构建项目图标,重新编译源码:
在这里插入图片描述

构建成功后,会输出如下信息:

在这里插入图片描述

烧录运行

在烧录运行之前,需要把之前打开的监视窗口关闭,否则串口无法重复连接。
在这里插入图片描述

在下一步操作之前,需要从电脑先断开AI-01开发板的Tyep-C数据线,再按住AI-01开发板上的按键不放,然后重新连接到电脑上,让AI-01开发板进入下载固件模式。连接完成后,可以松开按键。

操作完成后,再点击底部的ESP-IDF:构建、烧录和监视图标,自动完成编译、烧录、监视操作:
在这里插入图片描述

烧录完成后,会输出如下的信息:
在这里插入图片描述

待输出上面信息后,重新插拔AI-01开发板的Tyep-C数据线,AI-01开发板将重新上电运行前面烧录的程序,并输出小智AI运行的信息,并听到嘟的一声响:
在这里插入图片描述

现在,说你好小智唤醒小智AI,或者使用按键唤醒小智AI,开始对话:
在这里插入图片描述

从上面的输出信息可以看到,现在使用的是自己的后台服务地址了。

查看后端服务的输出日志,可以看到请求和返回的过程:
在这里插入图片描述

演示效果

下面的演示中,服务端配置中,使用了DoubaoLLM和DoubaoTTS:

在这里插入图片描述

具体演示效果如下:

全开源:使用四博AI-01开发板搭建自已的AI小智服务系统

从上面的演示中可以看到,使用AI-01开发板和开源后端服务搭建环境,可以顺利的运行提供服务,让我们能够拥有自己的小智服务系统了。
另外,演示环境是在本地电脑搭建的,如果是在服务器上搭建的,反馈的速度会更快。如果有充足的显卡资源,还可以自建LLM服务和TTS服务。

鸣谢

  • 感谢虾哥开源小智AI设备端源码:xiaozhi-esp32
  • 感谢开源团队开发后端服务:xiaozhi-esp32-server
  • 感谢四博智联提供AI-01源码:DOIT_AI

相关文章:

  • Encoder-free无编码器多模态大模型EVEv2模型架构、训练方法浅尝
  • 读书记:《认知红利》
  • 【计算机网络网络层深度解析】从IP协议到路由优化
  • 第二届平航杯wp
  • 深度学习笔记40_中文文本分类-Pytorch实现
  • 数字智慧方案6189丨智慧应急综合解决方案(46页PPT)(文末有下载方式)
  • n8n 使用 AI Agent 和 MCP 社区节点
  • 树与二叉树完全解析:从基础到应用
  • 4.27-5.4学习周报
  • 如何实现服务的自动扩缩容(Auto Scaling)
  • 1️⃣7️⃣three.js_OrbitControls相机控制器
  • 溯因推理思维——AI与思维模型【92】
  • 【免费】2007-2021年上市公司对外投资数据
  • 数字世界的“私人车道“:网络切片如何用Python搭建专属通信高速路?
  • P2196 [NOIP 1996 提高组] 挖地雷
  • Python爬虫基础总结
  • 【算法】动态规划专题一 斐波那契数列模型 1-4
  • SQL基础全面指南:从CRUD操作到高级特性实战
  • GC9D01 和 GC9A01两种TFT 液晶显示驱动芯片
  • IntelliJ IDEA
  • 中国驻日本大使吴江浩就日本民用飞机侵闯我钓鱼岛领空向日方提出严正交涉
  • 五一假期首日,上海外滩客流超55万人次
  • 即日起,“应急使命·2025”演习公开征集新质救援能力
  • 迎接八方来客:全国多地“五一”假期党政机关大院停车场免费开放
  • 中央宣传部、全国总工会联合发布2025年“最美职工”先进事迹
  • 中办、国办印发《安全生产考核巡查办法》