Introduction: Speech to Text(Intel IoT)

Hi everyone this is a project

how to make intel edison as SpeechRecognition module

Step 1: Overview:

This project is about making intel Edison Speech recognition system.

This is an module which can use any where in our IoT project

for example: you can use this module in a remote car , you can control the car using your voice instruction.

First of all configure your edison's ALSA configuration

choose your active microphone Intel can connect with microphone in two ways 1. via USB, 2. via Bluetooth.

I used Bluetooth first but I have some issues in my but device so I shifted to USB device.

Step 2: Hardware Needed for This Experiment:

Intel Edison with extension board

USB sound card

Head set with microphone.

okay lets start hack..

First of all configure your edison's ALSA configuration
choose your active microphone Intel can connect with microphone in two ways 1. via USB, 2. via Bluetooth. I used Bluetooth first but I have some issues in my but device so I shifted to USB device.

Connect your USB sound card to edison

then,

root@edison1:~# lsusb

Bus 001 Device 002: ID 047f:da41 Plantronics, Inc. <<< This is my device Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub

root@edison1:~# aplay -Ll

sysdefault:CARD=Headset
Plantronics USB Headset, USB Audio Default Audio Device **** List of PLAYBACK Hardware Devices **** card 0: Loopback [Loopback], device 0: Loopback PCM [Loopback PCM] Subdevices: 8/8 Subdevice #0: subdevice #0 Subdevice #1: subdevice #1 Subdevice #2: subdevice #2 Subdevice #3: subdevice #3 Subdevice #4: subdevice #4 Subdevice #5: subdevice #5 Subdevice #6: subdevice #6 Subdevice #7: subdevice #7 card 0: Loopback [Loopback], device 1: Loopback PCM [Loopback PCM]

.....

......

root@edison1:~# cat /etc/asound.conf

pcm.!default sysdefault:Headset

test:

root@edison1:~# aplay /usr/share/sounds/alsa/erumbil.wav
Playing WAVE '/usr/share/sounds/alsa/Front_Center.wav' : Signed 16 bit Little Endian, Rate 48000 Hz, Mono root@edison1:~#

if you her song you configure right else you should go through these steps again

Step 3: How to Configure

First of all configure your edison's ALSA configuration
choose your active microphone Intel can connect with microphone in two ways 1. via USB, 2. via Bluetooth. I used Bluetooth first but I have some issues in my but device so I shifted to USB device. Connect your USB sound card to edison then, root@edison1:~# lsusb Bus 001 Device 002: ID 047f:da41 Plantronics, Inc. <<< This is my device Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub root@edison1:~# aplay -Ll sysdefault:CARD=Headset Plantronics USB Headset, USB Audio Default Audio Device **** List of PLAYBACK Hardware Devices **** card 0: Loopback [Loopback], device 0: Loopback PCM [Loopback PCM] Subdevices: 8/8 Subdevice #0: subdevice #0 Subdevice #1: subdevice #1 Subdevice #2: subdevice #2 Subdevice #3: subdevice #3 Subdevice #4: subdevice #4 Subdevice #5: subdevice #5 Subdevice #6: subdevice #6 Subdevice #7: subdevice #7 card 0: Loopback [Loopback], device 1: Loopback PCM [Loopback PCM] ..... ...... root@edison1:~# cat /etc/asound.conf pcm.!default sysdefault:Headset test: root@edison1:~# aplay /usr/share/sounds/alsa/erumbil.wav Playing WAVE '/usr/share/sounds/alsa/Front_Center.wav' : Signed 16 bit Little Endian, Rate 48000 Hz, Mono root@edison1:~# if you her song you configure right else you should go through these steps again

make sure you installed python

install python pip.

using pip install pypi,

install speech_recognition,

instal PyAudio.

Step 4: Code

Then use this code and execute for speech recognition

import speech_recognition as sr

r = sr.Recognizer() with sr.WavFile("test.wav") as source: # use "test.wav" as the audio source

r.energy_threshold = 4000 audio = r.record(source) # extract audio data from the file

try:

print("You said " + r.recognize(audio)) # recognize speech using Google Speech Recognition except IndexError: # the API key didn't work

print("No internet connection")

except KeyError: # the API key didn't work

print("Invalid API key or quota maxed out")

except LookupError: # speech is unintelligible

print("Could not understand audio")

#************