Skip to content

Latest commit

 

History

History
133 lines (91 loc) · 5.17 KB

README.md

File metadata and controls

133 lines (91 loc) · 5.17 KB

esphome_sound_source_detection

This component identify sound source based on frequency.

If anybody is interested in supporting my "sleepless" nights (working mostly between 23:00-3:00) on different projects press:

Buy me a coffee

Thank you ;)

Ideas are welcome. But PRs are welcome more ;)

History

My colleague ask me to create software for his HW to be able detect sound source and be able to process that in home assistant. Even my wife :D like this solution and want keep one sample at home.

Source code for sound analyzes are based on this article: Smart door bell and noise meter using FFT on ESP32. You can also find science background to this problematic. So the actual work was integrate this code with esphome.

!!! Never worked with Esphome before, so the code may looks terrible and some parts may need change.

Real case

Intention was be able to detect door bell sound and push notification into Home assistant, which can do whatever user want. E.g. Send notification to the mobile phone

In the video first time it didn't work as i set bell value to 183 and it measured 182. So i need decrease the value i am looking for, or have range. Press click to see video

Dependency

To make the code working i have to create PR in official release, which was accepted quite quickly PRs. In a time writing this doc: Although it was merged at 9.1.2024 it was not yet released. If there will be a official release please let me know, so i can update Readme. By the time you need apply these changes by yourself.

For that reason for building application i was using this steps setup-dev-env and i was flashing image to board using https://web.esphome.io/.

HW

Hw was chosen by colleague and i think it is based on what was used in article mentioned in History section. So in my case ESP32_DEVKIT_V4 + inmp441

++++++++++++++++ ================

yaml

At least two different approach can be used.

  • First approach is do not set any specific binary sensor in yaml. Then in e.g. Home assistant you need to analyze values which are sent from this device and create automatization triggering event, when value match your needs (e.g. if sensor.currentValue is 160 then send notification).
esphome:
  name: sounddetector

esp32:
  board: esp32dev
  framework:
    type: arduino

# logger:
#   level: VERY_VERBOS

# Enable Home Assistant API
api:
  encryption:
    key: "H8sN4oR4ldRe01BuqEU+uQujPqqSdVU+3lICyMZfn94a5Dd="

# Wi-Fi
wifi:
  networks:
  - ssid: "?" #fill your wifi ssid
    password: "" #fill your wifi password
    # Enable fallback hotspot (captive portal) in case wifi connection fails
  ap:
      ssid: "Hotspot_MIC"
      password: "totalySecretPassword"

captive_portal:

i2s_audio:
  i2s_lrclk_pin: GPIO18 # depends your wiring
  i2s_bclk_pin: GPIO23 # depends your wiring

microphone:
  - platform: i2s_audio
    id: external_mic
    adc_type: external # based on article mentioned in History section
    i2s_din_pin: GPIO19 # depends your wiring
    pdm: false # based on article mentioned in History section
    bits_per_sample: 32bit # based on article mentioned in History section
    sample_rate: 22627  # based on article mentioned in History section
    use_apll: true # based on article mentioned in History section

detect_audio: # this component analyzes the input from mic, and its source code is the main part of this PR
  id: "detect_audio_id"

switch:
  - platform: template
    name: "Mic ON"
    turn_on_action:
      - microphone.capture:
    turn_off_action:
      - microphone.stop_capture:
    lambda: return id(external_mic).is_running();

button:

sensor:

binary_sensor:
  • Second approach is to defined sensor directly in yaml file. In this case extend previous yaml ( detect_audio) with configuration array placed in sound_sources:
detect_audio: # this component analyzes the input from mic, and its source code is the main part of this PR
  id: "detect_audio_id"
  sound_sources: [{"name":"bel1","level": 45},
                  {"name":"bel2","level": 182}] # add as many as wanted

I think this solution has its cavities, which are caused as mentioned lack of knowledge of this SDK. So maybe somebody come up with better solution.

Testing

For testing hw + sw you can use real device, but it can be handy if you install any Frequency Generator into your mobile. You can set 1000HZ and you should get peak 45. Also you can enable debug logs and catch them trough usb serial cable connected to your computer.

Last words

I hope my work will help some people to solve their issues, bring some happiness.