站内搜索
发作品签到
专业版

#第十届立创电赛#AI小智语音聊天机器人

工程标签

272
0
0
0

简介

基于立创开源蓝牙模组SF32LB52-MOD-N16R8实现的AI小智语音聊天机器人。

简介:基于立创开源蓝牙模组SF32LB52-MOD-N16R8实现的AI小智语音聊天机器人。
第十届立创电子设计开源大赛

开源协议

GPL 3.0

创建时间:2025-08-15 19:37:17更新时间:2025-09-08 10:46:59

描述

* 1、项目功能介绍


基于立创开源蓝牙模组 SF32LB52-MOD-N16R8 制作的简易AI语音聊天机器人,实现AI实时语音对话。它能够听懂你的情绪,解答你的疑惑,也能分享你的快乐。是一个集成了语音交互、情感计算和低功耗蓝牙连接的智能终端方案,它很适合开发者复刻和进行二次开发。

*2、项目属性


此项目是基于立创开源蓝牙模组 SF32LB52-MOD-N16R8 制作的简易AI语音聊天机器人属于开源项目。

* 3、开源协议

基于立创开源蓝牙模组SF32LB52-MOD-N16R8实现的AI小智开源协议,旨在构建一个低功耗、高性能的嵌入式AI语音交互平台。该模组搭载Arm Cortex-M33双核处理器,支持蓝牙5.3协议,集成16MB Flash和8MB PSRAM,提供丰富的接口(如I2C、SPI、UART、USB等),适用于智能家居、工业控制等场景。AI小智协议在此基础上整合了MCP(Model Context Protocol)标准,通过JSON-RPC 2.0格式实现设备与云端大模型(如DeepSeek、Qwen等)的交互,支持语音唤醒、多语言识别、设备控制及物联网平台(如ThingsPanel)接入,实现语音指令处理、传感器数据采集和低功耗管理等功能。开源方案覆盖硬件设计、固件及服务端代码,助力开发者快速定制AIoT设备。
免责声明:作者不承担项目使用产生的任何责任。

*4、硬件部分


原理图:

2、PCB图纸:

*5、软件部分


软件全开源,烧录即可体验

烧录和使用方法

前置准备

在开始之前,我们需要进行一些前置工具,请确保完成以下的步骤:
  1. sftool: 用于SF32系列SoC芯片的烧录
  2. 下载固件: 开发板的固件位于 https://github.com/78/xiaozhi-sf32/releases,我们下载最新release版本的压缩包。需要注意的是,我们一共需要bootloader.binER_IROM2.binER_IROM3.binER_IROM1.binftab.bin这五个文件。 建议先下载sftool工具,下载完成后将这些文件放在sftool文件夹中,与sftool.exe同一路径。
  3. 开发板对应固件:小汤圆直插版(立创训练营): sf32lb52-xty-ai-tht.zip

下载sftool

sftool 是一个开源软件,可以在GitHub 上找到它的源码。不过我们现在并不需要关心源码,只需要下载编译好的二进制文件即可。
我们可以在Release 页面中找到最新版本的sftool,其中最靠前的版本并且有着Latest绿色标签的就是最新版本。例如我现在的最新版本上0.1.5,看起来是这样的:
接下来我们需要选择合适的版本。我们需要根据自己的操作系统和CPU架构来选择合适的版本。sftool支持Linux、Windows和MacOS等操作系统,支持x86_64和aarch64等CPU架构。例如我们是Windows 64bit操作系统,我们就应该选择 sftool-0.1.5-x86_64-pc-windows-msvc.zip这个版本,同样的,如果是Windows 32bit的版本,我们就应该选择sftool-0.1.5-i686-pc-windows-msvc.zip这个文件镜像下载。特别的,如果您找不到您系统的文件,那可能需要点击一下Show all assets按钮。
下载完成之后,我们需要解压这个文件,解压之后我们会得到一个命令行工具,在windows上它的后缀是.exe(sftool.exe),在Linux和MacOS上没有后缀(sftool)。需要注意的是,windows的资源管理器可能会忽略文件的后缀名,因此看起来可能也是sftool
对于中国大陆地区用户,可以无法访问Github,因此可使用国内镜像加速链接。例如原链接为:https://github.com/OpenSiFli/sftool/releases/download/0.1.5/sftool-0.1.5-x86_64-pc-windows-msvc.zip,那么我们就将github.com替换为downloads.sifli.com/github_assets,变成https://downloads.sifli.com/github_assets/OpenSiFli/sftool/releases/download/0.1.5/sftool-0.1.5-x86_64-pc-windows-msvc.zip,就可以加速下载了。

sftool 命令格式及使用方法

sftool是一个命令行工具,它有一套自己的命令格式,一般的命令规则如下:
sftool [选项] [选项值] [命令] [命令选项]
全局选项
  • -c, --chip : 目标芯片类型 (目前支持SF32LB52)
  • -m, --memory : 存储类型 [nor, nand, sd] (默认: nor)
  • -p, --port : 串行端口设备路径
  • -b, --baud : 闪存/读取时使用的串口波特率 (默认: 1000000)
  • --before : 连接芯片前的操作 [no_reset, soft_reset] (默认: no_reset)
  • --after : 工具完成后的操作 [no_reset, soft_reset] (默认: soft_reset)
  • --connect-attempts : 连接尝试次数,负数或0表示无限次 (默认: 7)
  • --compat : 兼容模式,如果经常出现超时错误或下载后校验失败,则应打开此选项。
写入闪存命令
# Linux/Macsftool -c SF32LB52 -p /dev/ttyUSB0 write_flash [选项] <文件@地址>...# Windowssftool -c SF32LB52 -p COM9 write_flash [选项] <文件@地址>...
写入闪存选项
  • --verify: 验证刚写入的闪存数据
  • -u, --no-compress: 传输期间禁用数据压缩
  • -e, --erase-all: 在编程前擦除所有闪存区域(不仅仅是写入区域)
  • <文件@地址>: 二进制文件及其目标地址,如果文件格式包含地址信息,@地址部分是可选的
示例
Linux/Mac:
# 写入单个文件到闪存sftool -c SF32LB52 -p /dev/ttyUSB0 write_flash app.bin@0x12020000# 写入多个文件到不同地址sftool -c SF32LB52 -p /dev/ttyUSB0 write_flash bootloader.bin@0x12010000 app.bin@0x12020000 ftab.bin@0x12000000# 写入并验证sftool -c SF32LB52 -p /dev/ttyUSB0 write_flash --verify app.bin@0x12020000# 写入前擦除所有闪存sftool -c SF32LB52 -p /dev/ttyUSB0 write_flash -e app.bin@0x12020000
Windows:
# 写入多个文件到不同地址sftool -c SF32LB52 -p COM10 write_flash bootloader.bin@0x12010000 app.bin@0x12020000 ftab.bin@0x12000000# 其它同上

烧录固件

使用sftool工具烧录固件,打开终端之后输入如下命令(Windows): !!!需要注意的是:命令中的 ./sftool.exe 中的斜杠,在不同操作系统中有不同的表现: windows是反斜杠,linux是斜杠。
下面是1.2.0-1.2.2版本的烧录命令:
./sftool.exe -p COM3 -c SF32LB52 write_flash bootloader.bin@0x12010000 ftab.bin@0x12000000 ER_IROM2.bin@0x12A28000 ER_IROM3.bin@0x12228000 ER_IROM1.bin@0x12020000
1.3.0版本则应该使用下列命令:
./sftool.exe -p COM3 -c SF32LB52 write_flash bootloader.bin@0x12010000 ftab.bin@0x12000000 ER_IROM2.bin@0x12A28000 ER_IROM3.bin@0x12268000 ER_IROM1.bin@0x12020000
bootloader.binER_IROM2.binER_IROM3.binER_IROM1.binftab.bin是你下载的固件文件名,建议使用绝对路径引用,如果路径中出现中文或者空格请用"将路径括起来。 其中COM3是你连接开发板的串口号,可能会有所不同,请根据实际情况修改。 可以打开设备管理器查看对应串口号:'COM'后面接着的数字就是串口号
没有意外的话,烧录完成之后会自动重启运行,屏幕应该被点亮。

蓝牙使用注意事项

在连接板子设备之前,请打开手机的蓝牙网络共享功能!!!
Android蓝牙使用注意事项
以下是Android手机的蓝牙设置界面,通过打开个人热点共享中的蓝牙共享网络功能。
   
 
iOS蓝牙使用注意事项
iOS同样需要打开蓝牙共享网络功能,以下是参考步骤
   
 
⚠ 注意 如果iOS在蓝牙列表未看见sifli-pan 设备,请尝试重启手机。

开始使用

正确烧录固件后,开发板初始化界面如下:

激活设备

烧录固件之后,确保蓝牙共享网络已打开,这时,手机就可以连接蓝牙 sifli-pan 设备了。
 
⚠ 注意:一般情况下,Android连接成功后,连接的蓝牙设备会显示正在向设备共享网络(iOS不会显示),我们可以以此确定是否成功开启蓝牙网络共享
⚠ 连接上sifli-pan设备后,开发板会有连接画面提示,此时按下对话按键(参考对应硬件支持查看对话按键),xiaozhi则会提示需要登录到控制面板,填设备码。
 
 
 
⚠ 这个时候,打开浏览器,输入网址:https://xiaozhi.me。浏览器用手机或者电脑都可以。 进入小智 AI 的网页后,点击控制台,用手机号登录。
新建智能体填写,最后添加设备码。
这个时候拔掉开发板上的数据线再接入就可以正常使用了

界面提示含义

出现下方UI提示均是pan断开的情况
     

异常情况:

  1. 对应手机的显示可能是未打开蓝牙共享直接连接sifli-pan设备
  2. 蓝牙共享网络关闭
  3. 蓝牙已断开
解决方案:打开蓝牙共享网络重新连接设备
 

唤醒 & 重连

唤醒
长时间未对话小智会进入休眠,此时需要按下唤醒键进行唤醒(参考对应硬件支持查看唤醒键)
重连
支持重连操作:若无主动删除手机匹配列表下的sifli-pan设备,当按下唤醒键也可进行蓝牙重连(参考对应硬件支持查看唤醒键)
  
 

*6、BOM清单

BOM清单:
 
序号 名称 Footprint 用量 位号 编号
1 贴片磁质电容 0603 0.01uF 50V J  X7R  国巨 1 C1 C100042
2 贴片磁质电容 0603 0.1uF 50V J  X7R(指定X7R) 国巨 2 C2,C3 C14663
3 贴片磁质电容 0603 1uF 50V  K X7R 国巨 3 C4,C5,C6 C559769
4 贴片磁质电容 0805 10uF 50V  K 2 C7,C8 C15850
5 贴片连接器 A1251-SV02(1.25-2AB)联和 无铅 1 CN1 C393945
6 贴片连接器 PH-2AWB(A2001-SR02)白色 卧式 联和 1 CN2 C20598817
7 排针 单排3P F=2.54mm (镀金) 无铅 1 H1 C2937625
8 发光二极管 Φ3 透明 翠绿 高亮 平筋  无铅 1 LED1 C2895476
9 贴片发光二极管 0603 红绿双色 高亮 1 LED2 C24477
10 咪头 MIC-TH_BD6.0-P1.90-D0.4-L-FD_GMI6050P-2CXXDB 1 MIC1 C233939
11 精密贴片电阻 0603 10K 1% 7 R1,R2,R3,R4,R5,R6,R9 C98220
12 精密贴片电阻 0603 2K 1% 2 R7,R8 C98220
13 精密贴片电阻 0603 5.1K 1% 2 R10,R11 C23186
14 精密贴片电阻 0603 1K 1% 2 R12,R13 C22548
15 精密贴片电阻 0603 1.2K 1% 1 R14 C114605
16 拨动开关 SK12D07VG5  SW-TH_SK12D07VG5-1 1 SW1 C431548
17 贴片轻触按键 6*6*11   260G 2 SW2,SW3 C2685899
18 蓝牙模块 COMM-SMD_L27.9-W18.0-P1.10_SF32LB52-MOD-1-N16R8 1 U1 C42924267
19 IC LM4871MX/NOPB SOIC-8_L4.9-W3.9-P1.27-LS6.0-BL 1 U3 C7554
20 IC TP4056 ESOP-8  拓品微 1 U4 C16581
21 贴片USB 单SMT/6P/6.80L 固定脚加长 KS-T31-003-02-B7 1 USB1 C668623
22 液晶屏 1.69寸300*240 TFT LCD 1 U2  

 

*7、大赛LOGO验证


           

                            

* 8、演示您的项目并录制成视频上传

视频链接
https://www.bilibili.com/video/BV173hzzTE9h/?buvid=XU2E2492A0E6C2F6CEE9FB81A322896C3D318&is_story_h5=false&mid=%2B5YMLMKR%2FnoIpE0M6vUV0X8FTQ%2FSZMtL1rElX6M3iMo%3D&plat_id=240&share_from=ugc&share_medium=android&share_plat=android&share_source=WEIXIN&share_tag=s_i&spmid=dt.space-dt.0.0×tamp=1756563154&unique_k=IEAlgee&up_id=3546698139830447&wxfid=o7omF0QHmxLKuUd8oYnF_Khe3lx4&share_times=1&share_source=weixin

 

 

设计图

未生成预览图,请在编辑器重新保存一次

BOM

暂无BOM

3D模型

序号文件名称下载次数
暂无数据

附件

序号文件名称下载次数
1
sf32lb52-xty-ai-tht2025.8.25(1.3.0).zip
0
2
3DShell_AI小智语音聊天机器人.zip
0
3
Panel_Panel_1_2025-09-01.epanm
0
克隆工程
添加到专辑
0
0
分享
侵权投诉
知识产权声明&复刻说明

本项目为开源硬件项目,其相关的知识产权归创作者所有。创作者在本平台上传该硬件项目仅供平台用户用于学习交流及研究,不包括任何商业性使用,请勿用于商业售卖或其他盈利性的用途;如您认为本项目涉嫌侵犯了您的相关权益,请点击上方“侵权投诉”按钮,我们将按照嘉立创《侵权投诉与申诉规则》进行处理。

请在进行项目复刻时自行验证电路的可行性,并自行辨别该项目是否对您适用。您对复刻项目的任何后果负责,无论何种情况,本平台将不对您在复刻项目时,遇到的任何因开源项目电路设计问题所导致的直接、间接等损害负责。

评论

全部评论(1
按时间排序|按热度排序
粉丝0|获赞0
相关工程
暂无相关工程

底部导航