做一个基于 ChatGPT 的语音助手吧~

虽然有点晚了,但是还是分享一下之前折腾的本地运行一个大语言模型(LLM)语音助手的过程~

做这个来源于在推上看到有人分享了使用大语言模型搭建的语音助手,刚好也想试试大语言模型相关的库和代码什么的。

diy-chatgpt-based-voice-assistant

然后我参照推主的介绍,也使用相关的框架搭建了一个本地的语音助手,不过因为没有 GPU 以及测试的时候小参数量的大语言模型也不是很好用,因此 LLM 这块是使用的 OpenAI 的 API。

整体介绍

这个语音助手主要使用以下几个框架和服务:

  • snowboy:用于声音检测、声音录制等功能,并且还支持静音检测(VAD)
  • faster-whisper:用于语音转文本,这个是使用了 OpenAI 的 whisper 模型,并且重新实现的库,速度比官方的快很多
  • SpeechRecognition:用来进行录音,在使用 snowboy 识别到唤醒词后,就用这个库来将后续的对话进行录制,交给 whisper 语音转文本
  • EmotiVoice:文本转语音,将用户的对话内容通过 API 询问 GPT 之后,再将返回的文本内容生成语音并播放
  • OpenAI:用来分析用户的对话并给出对应的回答

其中 fast-whisper 如果想要速度快的话,最好还是要有 Nvdia 的 GPU,使用 CPU 的话速度会慢不少,不过我在 M1 MacBook 上测试勉强能用。

snowboy

项目主页:https://github.com/Kitt-AI/snowboy

Snowboy is a customizable hotword detection engine



阅读全文 »

DIY电动V8发动机桌面模型,油车和电车都沉默了

先来看看视频,这个桌面 V8 发动机动起来效果怎么样的~

之所以要做这个东西,也是源于在 MakerWorld 上找一些有意思的 3D 模型玩玩的时候,看到一个 V8 发动机模型,对这类东西简直毫无抵抗力啊,立马打印了一个。

diy-v8engine-toy-3

不过原作者设计的模型虽然可以动,但是需要靠自己用的去转一个摇杆,这明显玩起来不够尽兴,刚好手上有一个有刷电机,接上电就可以让这个模型全自动运转起来了,美滋滋。

另外,作为一个发动机,怎么少得了变速呢,搞个变速箱可能比较麻烦,但是给有刷电机调个速还是比较简单的,先拿 DC-DC 降压模块测试了一下,没啥问题,直接画块板子开干。

材料配件

除了 PCB 和 3D 打印的东西之外,还需要其他的一些配件

  • F280 电机:电机不建议买太强力的,电流会比较大,容易超过 DC-DC 降压芯片的工作电流范围
  • 双轴按键摇杆模块:用于调速,让 DC-DC 芯片的电压反馈电阻形成不同比例来调整输出电压

diy-v8engine-toy-3

不过这个摇杆模块的精度也是有点差的,中间行程的电阻值变化不是很线性,不过这个电机调速也不需要那么精确,能有个变速的感觉就可以了 😂。

调速原理

有刷电机的调速靠调速输入电压就可以了,这里用的降压芯片是 SY8088,根据数据手册里给的公式,再根据摇杆模块电阻值的范围,就基本可以确定该如何选择对应的反馈电阻值了。

diy-v8engine-toy-4

在计算电阻前,已经使用可调电源模拟了一下,需要多大的电压驱动电机比较合适,最后试下来是 0.7V 到 0.9V 就差不多了。

然后摇杆模块的电阻值范围是在 5K-1K,为了使得摇杆居中时电压低,摇杆推到底时电压高,得好好算一下 R1 和 R2 的取值。

根据电压范围,最后确定 R1 和 R2 都是 1K,并且摇杆模块串联在 R2 …

阅读全文 »

3D打印一个黑悟空照片吧~配上背光效果很不错~

之前就已经在搞 3D 打印照片的灯板,刚好黑神话悟空发布了,蹭个热点,搞个 3D 打印的黑悟空的照片,配合灯板做个灯光画。

成品效果

3d-photo-light-1

材料清单

这个灯光画涉及的东西有点杂,不过总体成本也不高,可以控制在 20 元以内。

  • 3D 打印灯光照片,耗材不到 20 克,成本不到 1 元
  • PCB 需要的元件加起来不到 5 元,主要是 LED 灯珠、LED PWM 驱动芯片、充电芯片
  • PCB 可以用嘉立创的免费打样券
  • 3D 打印外壳,耗材使用在 40 克左右,成本大概在 2 元左右
  • 磨砂亚克力扩散板,100x100mm 大小,2mm 厚,需要 3 片,可以买一块大的裁切一下

3D 打印照片

最早的时候要生成一个反相照片 STL 模型文件还是比较麻烦的,不过 MakerWorld 上有一个作者搞了个比较好用的脚本,可以一键生成 OpenSCAD 源文件再导出成为切片软件可以用的 STL,并且参数可配置。

MakerWorld 项目地址: https://makerworld.com.cn/zh/models/194195

阅读全文 »

不要浪费闲置机箱风扇,5元把它变成无级调速桌面小风扇

之前拆机箱的时候,闲置了两个 12 厘米的散热风扇,看了下接口还是 4PIN 带调速线的,刚好办公室里缺一个桌面小风扇,这不得顺手改造一个。

机箱散热风扇是 12V 的,因此需要一个升压电路将 USB 输入的 5V 升压到 12V,另外因为风扇本身是支持 PWM 高速的,还需要一个电位器 + PWM 转换芯片来控制转速,整体还是相当简单的一个电路。

成品效果

为了在桌面使用,在 MakerWorld 上找了个可调节角度的 12 厘米风扇支架,刚好配合这个风扇使用。

不过因为原始设计是直接给祼风扇使用的,并没有考虑下面会加额外的 PCB,因此我对支架做了加高处理,要不然风扇的外壳会超出支架。

diy-desktop-fan-1

最终效果如图,使用时感觉还不错。

原理图设计

整个 PCB 仍然是使用立创 EDA 专业版设计的,在更新了 2.2 版本之后,终于流畅度有了不少提升,使用起来舒适了不少。

调速风扇整体电路很简单,就是一个升压 + PWM 输出,其中升压芯片使用了 HX3608,PWM 输出使用了 GP9101。

diy-desktop-fan-2

其中一些可能会有疑问的地方:

  1. HX3608 升压反馈电阻使用了 16K 和 1K,实际升压电压为 10V,驱动 12V


阅读全文 »

来了来了,用单片机 ESP32-S3 跑 RISC-V 模拟器运行 Linux,这次启动只要 8 秒

在之前一篇文章 《用 7 毛钱的 CH32V003 单片机跑 Linux,启动需要 5 分钟》 中介绍了开源项目 linux-ch32v003mini-rv32ima,可以在 7 毛钱的单片机 CH32V003 上配合外置 PSRAM 来运行一个 RSIC-V 模拟器,并且可以运行一个裁剪过的 Linux 系统镜像。

但是 CH32V003 的性能不太强劲,按作者介绍启动 Linux 系统需要 5 分钟,为了更好地学习一下 RSIC-V 模拟器,我决定把它移植到 ESP32-S3 来试一下看看。

PS. 搞这个也是仅供娱乐了,毕竟 ESP32-S3-N16R8 20 多元的价格,可以买像 V3S 这样正经 ARM SoC 来跑 Linux 了。

移植 mini-rv32ima

在上一篇文章中,已经大概介绍了移植 …

阅读全文 »

用 7 毛钱的 CH32V003 单片机跑 Linux,启动需要 5 分钟

在接触到只需要 7 毛钱的单片机 CH32V003 之后,拿它做了好几个 DIY 项目,像钥匙扣游戏机什么的,感觉还是比较有意思的,虽然资源相比 STM32F103 少很多,但是价格实在太便宜了。

在使用 CH32V003 的过程中,也上网搜了一圈使用它的项目,其中有一个 linux-ch32v003 就很有意思,作者的介绍就是“在一个 0.15 美元的单片机上运行 Linux”,我也克隆了这个项目学习了一下。

linux-ch32v003

Linux on a $0.15 RISC-V microcontroller

项目地址: https://github.com/tvlad1234/linux-ch32v003

这个项目主要解决的问题就是 CH32V003 可用内存太少的问题,作者使用了一个外围的 PSRAM 来扩展内存,实现了硬件 SPI 操作相关的库。

模拟器本身,其实是另外一个开源项目 mini-rv32ima,一个 RISC-V 的模拟器。

linux-ch32v003 主要的目录结构如下:

linux-ch32v003-01

项目目录中主要的内容:

  • emulator:模拟器相关代码,来自 mini-rv32ima 项目
  • hardware:测试用的硬件工程,使用 KiCAD 开发
  • hw_spi:硬件 SPI 库
  • linux:编译


阅读全文 »

去吧皮卡丘~啊不,是悬浮灯丝氛围灯

之前做了一个网红悬浮氛围灯,但是用了一段时间之后发现,这个电池似乎续航有点短,经过网友的提醒,发现是 LDO 在持续耗电,检测了一下的确会有这个情况。那这不能忍,去掉 LDO 优化续航的版本安排上~

DIY 悬浮柔性灯丝氛围灯的教程可以看这里: 30 元 DIY 一个柔性灯丝氛围灯

这次顺便使用了嘉立创的彩色丝印工艺,直接将 PCB 暴露在外面,印上喜欢的图案,美滋滋。

成品效果

有了彩色丝印就可以直接拿 PCB 当顶盖了~

diy-led-light-1

静态功耗检测

通过将万用表串联到电池正极和 PCB 电池正极之间,测得了即使氛围灯在没有打开时,仍然有 4mA 左右的电流消耗。

通过查阅所使用 AMS1117 芯片的数据手册,的确标注了静态电流会有 5-10mA。

diy-led-light-2

因为这个氛围灯没有设计物理电源开关,因此这个问题还是需要解决一下的,要不然一块 1000mAh 电池,光放着一周也没电了。

原理图修改

相比之前的原理图,新版本中去掉了 LDO,电池直接供电到 LED 灯丝。

当然这也会造成一个问题,随着电池电压的下降,在亮度开关是同一档位的情况下,LED 灯丝的亮度会逐渐下降,不过这个问题也不是特别大,不影响使用。

另外因为电池直接供电 LED 灯丝了,电池满电时电压 4.2V,在开启最大亮度时,LED 灯丝的亮度会比使用 LDO 降压后的 3.3V 供电要高不少,可以酌情增大 LED 限流电阻 …

阅读全文 »

硬币大小的游戏机不来一个?能玩小蜜蜂和吃豆人~

在接触沁恒家的 CH32V003 芯片一段时间后,发现了国外有个爱好者用它做了个小型游戏机,还配了不少游戏,例如小蜜蜂、呼吃豆人什么的,这不得自己复刻一个。

不过原作者的项目 PCB 设计体积比较大,不太符合我心中微型游戏机的形象,就自己重新搞了一下,顺便把原项目中的方向键从独立按键换成了摇杆,玩起来更舒适一点。

成品照片

老样子,自己做东西还是得搞个正经点的外壳。

经过极限压缩后的 PCB 大小为 24x40mm,加上电池后,整体外壳不包含钥匙扣环的尺寸为宽 27mm,高 42mm,厚 12mm,正面大小不到 2 个硬币大小 😃。

ch32v003-gameconsole-1

硬件选型

为了和原作者的 ROM 兼容,大部分 BOM 都跟原版 PCB 一样,这里只是将原版的方向按键换成了五向摇杆,其他的都还是保持一致。为了保障 PCB 体积,整体电阻、电容都采用了 0603 封装。

主要的几个元件都可以在某宝上购买,特别是其中的电磁式蜂鸣器,某宝上购买要便宜很多。

另外需要注意,12864 OLED 需要购买窄边框的版本。

位号 元件 备注
BUZZER1 4kHz 电磁式蜂鸣器
H3 PZ254V-11-05P 烧录排针,不焊接
SW1 MSK12C02-HB 电源开关
SW2 TM-4175-B-A 五向摇杆
SW3


阅读全文 »

听人劝吃饱饭,试试CH334R来做USB 2.0 Hub

之前用 SL2.1A 做了个 USB 2.0 Hub,有网友说不如用 CH334R,售价更便宜,还支持更高级的 MTT,这不得马上了解一下。

之前使用 SL2.1A 做 USB Hub 的文章在这里:还在花钱买?5元DIY一个四口USB 2.0 Hub

CH334R 介绍

在 CH334R 的数据手册中找到它的介绍,的确是支持 MTT 的。

CH334 和 CH335 是符合 USB2.0 协议规范的 4 端口 USB HUB 控制器芯片,上行端口支持 USB2.0 高速和 全速,下行端口支持 USB2.0 高速 480Mbps、全速 12Mbps 和低速 1.5Mbps。不但支持低成本的 STT 模式(单 个 TT 分时调度 4



阅读全文 »

整个带屏数字小键盘吧,先搞定 QMK 固件支持 STM32F103 的 I2C Remap

之前参考立创开源平台的夏天大佬,做了一个基于 ATMega32A MCU + QMK 固件的 40% 配列键盘,不过最后又想用起来的时候发现,可能因为 ATMega32A 用的是软件模拟 USB,所以在 Mac 上的兼容性有点问题,因此就想着自己重新搞一个键盘。

在 QMK 固件的 MCU 支持列表里面翻了一下,发现 STM32F103C8T6 也是支持范围,而且搞一个 STM32duino-bootloader 就可以直接通过 USB 刷机,也是相当方便了。

关于 STM32F103 使用 STM32duino-bootloader,之前已经写了篇文章分享 做键盘必备,抛掉ST-Link,STM32F103通过USB烧录,STM32duino-bootloader踩坑记录

免费打样来测试

但是直接搞整个 40% 配列键盘,PCB 的尺寸超过了嘉立创免费打样的范围,因此准备先搞个数字小键盘来验证一下 STM32F103 做键盘的原理图。

照猫画虎搞个原理图

搞键盘主要就是确定行和列的引脚,为了最大能支持 104 键,就把能用的引脚全用上了。

另外为了使用 OLED 屏幕,这里使用了 PB8、PB9 作为 I2C 通信引脚。

qmk-stm32f103-i2c-remap-1

原理图画了之后,先拿开发板测试一下固件能不能用吧,然后就发现 PB9、PB8 …

阅读全文 »