Skip to content

formatBCE/Respeaker-Lite-ESPHome-integration

Repository files navigation

Check out Koala Satellite, the next step of evolution for this project!

What is it

This repository contains example code to integrate Seeed Respeaker Lite Voice Kit (with XIAO ESP32-S3 on board) with ESPHome. I'm thankful for continuous help of ESPHome team and Seeed developers, that let me put this thing together. It's using brilliant job of ESPHome team, as well as firmware and guides from Seeed Wiki and their repository for Respeaker.

*Disclaimer

Use this on your own risk. Expect breaking changes.

At the moment, all this is changing at very fast pace. Respeaker board considered alpha, PE (Voice Kit) software is under heavy development. I will try to update YAML and XMOS board firmware as soon as i can, but it can't be instantenuous... If you encounter a problem, before creating ticket here you may go to PE and Seeed repos, linked above, and see if something changed there. I'll gladly accept pull-requests. :)

Why?

I ditched all proprietary assistants for good about 6 months ago, and dove into Assist all-hands. With this board i finally can build device, that will satisfy me and (more important) my family as their trusted voice assistant.

What to do with it?

* Thanks to Mike aka @mikey60 and his fork to nabu_microphone, this project is using 48kHz sample rate for better music playback quality.*

  1. Get Respeaker Lite with ESP32 soldered to it (you may solder it yourself, pins on the back can remain dry, they're not used).
  2. Solder USR to D2 and MUTE to D3 pins.
  3. Flash latest 48kHz I2S firmware to the XMOS board (pay attention to USB port, you need the main board port, not ESP32 one) Make sure you're using 48kHz version, as default one is 16kHz and won't work with this repo.
  4. Flash ESPHome firmware (YAML included, place /config/common/respeaker-satellite-base.yaml into ESPHome common directory, and adjust /config/respeaker-satellite-dashboard-example.yaml to your needs) to ESP32 (use its port).
  5. Add device to Home Assistant.

Current state

  • voice communication: works
  • playing media: works (with exception of files, containing album art, playing from HA media picker - this is getting addressed by ESPHome guys (i can't thank them enough!!!)
  • media ducking while voice communication ongoing: works
  • interactions with HA timers: works
  • LED: works (also can be exposed as light in HA)
  • mute: hardware button works, software button works
  • action button: works, multifunctional, based on PE logic
  • default HA wizard for satellites: works
  • drop-down with wake word selection: works
  • added switches to turn off button sounds, mute/unmute sounds
  • added sensors for next device timer properties (time is updated once per 5 sec, name is available if set)

ToDo

  • DONE software mute switch. Software triggering works, but state read doesn't work so far (needs custom ESPHome component for reading mute status with i2c). Check Arduino example here if you want to help
  • OTA software update for Respeaker board. Can snug this functionality from PE project. Will be part of Koala
  • DONE 48kHz bitrate. Right now the board works on 16kHz, but Seeed already preoared 48kHz firmware. Great guys! It doesn't work yet with ESPHome though, since we need to add resampler for the microphone to downsample it to 16kHz (currently there's no way to use 48kHz for mic). Speaker works though.
  • hardware volume controls. Solved in Koala Would be nice to have, but there's no pins left on ESP32... Thinking... I made some cradle with buttons and resistors to have 3 buttons on single pin - but it's bulky and inconvenient to solder, as well as to use in ESPHome. I decided to skip on it.
  • bigger LED strip. Solved in Koala The problem is same as for hardware volume... But if you want, you can solder strip/ring to the GPIO1 instead of inbuilt LED. I decided that i'm good with one on board so far.

Casing

I made some casing to improve family approval factor. Check it out.

"Buy Me A Coffee"

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published