This project is created by Allan.D.Murray
The MicroDot is a home-made Alexa 'button' designed to be connected to a LattePanda or a Raspberry Pi, with Alexa Sample App installed. It is a small speaker with LED's and touch/speech activation, and is ideal for use on a desktop or in a car.
*The LattePanda for this project was kindly supplied by DFRobot https://www.dfrobot.com/product-1405.html
The LattePanda is a small (about the size of a Raspberry Pi) Windows 10 computer with a built-in Arduino for interfacing to the real world. It really is quite nifty - and is a good replacement to the Raspberry Pi - especially if you (like me) have problems getting to grips with Linux.
I have installed the Alexa Sample App onto the Panda, and have implemented my own wake-word engine based on Windows built-in speech recognition SDK.
The MicroDot consists of a small amplifier and speaker with a touch-sensitive grill and blue/white LED array. The MicroDot was originally designed to be placed on the dash in my car to provide my in-car Alexa solution (to pair with my previous project - Alexa-enabled car stereo). As well as having a wake-word option, I wanted touch-activation because Alexa will have a hard time hearing my wake-word when the music is up loud! (Once activated, the Panda will send a signal to the stereo to turn the volume down while Alexa is listening/speaking).
For those who are more fluent in "Raspberry Pi", I have described at the end of this Instructable how to interface the MicroDot with a Rapsberry Pi 3.
6 x 220R SMD Resistors
2 x 470R SMD Resistors
1 x 10uF SMD Capacitor
1 x TTP223 Touch Sensor Module ( https://www.ebay.com/itm/192097635565 )
1 x PAM8403 3W Amplifier Module ( https://www.ebay.com/itm/221895096190 )
1 x 10K Single Linear Thumb Potentiometer ( https://www.ebay.com/itm/401105807680 )
1 x 50pF Ceramic Capacitor
3 x 3mm Blue LEDs
3 x 3mm White LEDs
1 x 1.7inch 4ohm 3W Speaker
1 x Thin Black Cable from old Earphones
1 x Thin Black 1m USB Extension Cable*
The MicroDot PCB was made by iron on toner method on 0.8mm thick single-sided board - at this thickness it can be cut roughly to shape with sharp scissors and then easily filed to shape. Mount all the surface mount components first.
A wire needs to be connected to the touch surface of the sensor, so a small area needs to be scraped away to solder to. I found that in its raw mode, the sensor was way too sensitive - it worked fine, but once it was mounted in the enclosure it was often false-triggered due to its proximity to the metal speaker. I grounded the metal speaker - which helped somewhat, but I had to eventually refer to the datasheet.
The TTP223 datasheet states that you can adjust the sensitivity by placing a capacitor (0 to 50pf) between the touch sensor and ground. The sensor worked fine with a 50pf capacitor. You can see the placement of this in the picture of the next section.
Two cables are used to connect the MicroDot to the Panda:
- a thin black cable from an old pair of earphones to connect the audio
- a thin USB cable was used to connect to the GPIO (touch sensor/LEDs). You will need a cable with 6 separate connectors (5 internal + shield). *Beware that some cheap USB cables do not have a separate ground-pin/shield, or these two may be connected internally (check this before cutting up your cable by making sure that there is continuity between the outer metal parts of the male and female plugs, and that there is not continuity between the ground pin and the outer metal parts).
Use the USB cable connections:
red=+5v, shield=GND, black=touch sensor, white=white LEDs, green=blue LEDs.
Instead of just cutting the pugs off and hard wiring it, you may want to do what I did and keep the plugs on and cut one long section and one short (say 200mm) section, and plug the two ends of the cable together. This way the unit is detachable. Just make sure you do not plug any actual USB devices into it, or plug it into a regular USB port!
3D PRINTED PARTS
There are four 3D printed parts in the attached zip file:
1. Main MicroDot shell - printed in black PLA
2. MicroDot base - printed in black PLA
3. LED ring - printed in white PLA (clear or translucent may be better to help diffuse the light more evenly)
4. PCB spacer - any colour - sandwiched between speaker and PCB.
M2 bolts and nuts are used to screw the base to the shell. Three M2 bolts need to be melted into the slots on the inside of the shell. These are quite small, and you may need to ''solder'' them in place with some additional filament.
The white and blue LEDs are mounted in the array alternately as shown in the pictures. The leads are bend to 90 degrees against the bottom of the LED and the leads are melted into the ring with a hot soldering iron (note the polarity here). The bottom of the LEDs are filed down so they are flat to the surface of the ring.
The cathodes of the LED's are all connected together with a ring of wire and these connect to the lower-most pin of the header. The other pins of the header must be alternate blue/white for each individual LED
PUTTING IT TOGETHER
The grill was cut from a desktop paper holder (pictured) with a wire soldered to one edge. This is inserted into the shell first, then the LED array (this must be inserted on an angle as shown, with the slot aligned with one of the screw posts). The speaker is next (place some thin tape around the top to insulate it from the edge of the PCB). Then the spacer, and the PCB just sits on top. Screw the base on to keep it all together.
When plugging the audio cable into the LattePanda, I found that I needed to use an audio ground loop filter ( https://www.ebay.com/itm/371801191297 ) to get good sound. Note that in the photos I use the audio-out of my HDMI-VGA video adapter, but it is fine to use the on-board audio output jack.
You will also need a usb microphone (https://www.ebay.com/itm/332148968227).
The Panda comes in 2G/32G and 4G/64G models, with or without Windows 10 License. The model that I used was the 2G/32G version with Windows 10 License: https://www.dfrobot.com/product-1405.html
Please see the official documentation for settting up your LattePanda (http://docs.lattepanda.com) There is nothing too complicated here, but take note of the instructions for powering up your Panda (http://docs.lattepanda.com/content/getStarted/powe...).
Everything seemed to work first time for me (which is a nice change from my Raspberry Pi experiences).
One important thing is that you really need some kind of cooling for the Panda. I used some stick-on heatsinks on the top and bottom (the underside gets particularly hot).
This diagram details the Arduino inputs and outputs: http://docs.lattepanda.com/content/hardware/inputs... We will be using the array of 3 pin connectors on the left-hand side to connect to the MicroDot (D9, D10 and D11), as well as the audio output jack.
The Alexa Sample App is available here:
Press the Clone or Download button and download as .zip
Create a directory on c drive C:\ALEXA, and extract the contents of the zip so that the zipped directory called samples sits directly in the ALEXA directory (ie C:\ALEXA\samples\...)
The official full instructions for how to install on Windows are here:
There are quite a few steps, and it takes a little while, but I found that with Windows everything went smoothly first time.
You will need a good text editor to edit some of the configuration files (Notepad is no good as the files have Linux style line endings). I used Notepad++ which is available here: https://notepad-plus-plus.org/
A few notes regarding the official instructions:
Part 3 - Dependencies
My Panda is 64 bit, so I downloaded all the 64 bit versions, but if you are installing on a 32 bit system you will need to use the 32 bit versions. Note: don't mix 32 and 64 bit versions of the dependancies.
The link shown for VLC media player, will take you to 32 bit version. To get the 64 bit version, go to this link: http://www.videolan.org/vlc/download-windows.htmland on the download button, select the arrow, and then Installer for 64bit version.
For JDK install I used version:jdk-8u144-windows-x64
For nodejs I used: Windows Installer (.msi) 64 bit
For OpenSSL I used:Win64 OpenSSL v1.1.0f
Part 5 - Authentication method
Choose 5a - Nodejs server. If you get an error running npm command, then you need to add your nodejs directory to your path environment variable (it is explained in the instructions how to do this).
Part 6 - Running the sample app
When editing the config.json file, set wakeWordAgentEnabled to true, as we will be installing a custom wake word engine in the next section (the wake word engine included in the sample app only works with Linux).
If you get an error running the mvn command, then you need to add your maven\bin directory to your path environment variable.
When you run the app, you should get the GUI shown in the screenshot. When you click on the icon you will be able to talk to Alexa. This is the basic Alexa app - but we will need more than this!
The next steps will be to install a custom wake-word engine so you can just say "Alexa" to activate, and also have the option to use a touch sensor via Arduino input. We also need to make the app auto-run on startup, and light up some LED's when Alexa is listening and talking.
A WakeWord engine allows Alexa to be awoken by a spoken word (usually ''Alexa"), instead of having to click on a button. The sample app has two options for the WakeWord engine: Sensory or KITT.AI wake word engines. The implementation for these in the sample app, however, only work for Linux. Both these engines are also subject to certain licensing requirements.
Here I will implement a custom wake word engine which is based on Windows 10's own speech recognition SDK. So this is also free of any additional license requirements.
Microsoft Speech Platform - Runtime (Version 11)
x86_SpeechPlatformRuntime\SpeechPlatformRuntime.msi (32 bit) or x64_SpeechPlatformRuntime\SpeechPlatformRuntime.msi (64 bit)
Microsoft Speech Platform - Runtime Languages (Version 11)
My custom WakeWord engine was written in C# in Visual Studio 2017. I have supplied the final executable here and also the source code. If you want to compile it yourself, then you will also need this:
Microsoft Speech Platform - Software Development Kit (SDK) (Version 11)
|x86_MicrosoftSpeechPlatformSDK\MicrosoftSpeechPlatformSDK.msi (32 bit) or x64_MicrosoftSpeechPlatformSDK\MicrosoftSpeechPlatformSDK.msi (64 bit)
Put WakeWordPanda.exe (and alexa_run.bat)into the ALEXA directory. This program does the following tasks:
- Listens for ''Alexa" wake word
- Monitors the touch input sensor
- Controls the BLUE and WHITE LED's
Note that I developed this on another Windows 10 computer so that I did not have to install Visual Studio on the LattePanda, as I didn't want to use up the Gigabytes. I connected an Arduino Uno installed with StandardFirmata (http://www.lattepanda.com/docs/#SetuptheArduino) to the development computer so that I could also develop with the Arduino input/outputs. The Visual Studio source code is also attached if you want to modify and/or compile this yourself.
MODIFY THE JAVA CLIENT
The Java Client needs a few extra lines added to the code. This is to enable to LED's to work correctly:
When Alexa is listening, a PAUSE_WAKE_WORD_ENGINE signal is sent to the WakeWord engine. I used this signal to know when to turn on the BLUE (Alexa listening LED). When the RESUME_WAKE_WORD_ENGINE signal is received, the Blue LED turns off, and the WHITE (Alexa speaking LED) turns on. The extra code sends another RESUME_WAKE_WORD_ENGINE signal when Alexa stops speaking - so that the WakeWord engine knows when to turn off the White LED.
Navigate to: C:\ALEXA\samples\javaclient\src\main\java\com\amazon\alexa\avs and open AVSController.java in your text editor. Copy the code from theExtra_Code.txt file attached. It needs to be inserted in two places:
1. In the function public void onAlexaSpeechFinished() directly after the statement: dependentDirectiveThread.unblock();
2. In the function private void handleAudioPlayerDirective(Directive directive) directly before the statement: player.handleStop();
I have also re-purposed the CONFIRM signal so that the WakeWord engine will know if Alexa has responded. This is to cancel a 5 second timeout that will occur if there is no response. Copy the code from Extra_Code2.txt and insert it in one place:
1. In the functionpublic void onAlexaSpeechStarted() directly after the statement dependentDirectiveThread.block();
You now need to recompile the Java Client. Open a command prompt and navigate to C:\ALEXA\samples\javaclient Enter: mvn install to recompile.
If you start up the Companion Service and Java Alexa app as before, and then also double click on WakeWordPanda.exe, wait for it to connect, and then you should be able to activate Alexa by saying "Alexa".
If you connect the MicroDot's 'USB' cable to the LattePanda as shown in the diagram, and plug in the audio cable, it should now be fully functional. Speaking the wake-word or touching the grill should activate Alexa and the blue LED's should come on. The white LED's should come on as Alexa responds.
SETUP AUTO RUN
Instead of typing in all the commands manually to start everything up, you can use the alexa_run.bat script. This will wait for an internet connection, and then invoke the separate modules (companion service, java client, wake-word engine).
The last step is to make everything run automatically on startup:
1. Right-click on auto-run.bat and select create shortcut.
2. Press ctrl+R and type shell:startup. This will open the startup folder.
3. Drag the shortcut you created into the startup folder.
Alexa will now auto-run on startup (it takes 30 seconds or so to initialise after startup).
(If you want to use a Raspberry Pi 3 instead of a LattePanda).
Download the Alexa Sample App from here: https://github.com/alexa/alexa-avs-sample-app/
Press the Clone or Download button and download as .zip. Unzip so that the alexa-ava-sample-app folder is on the Desktop.
Follow the official full instructions here (note: setup so that the alexa-ava-sample-app folder on the Desktop):
There are plenty of guides for doing this with a Raspberry Pi on the interne. I have installed this a couple of times on the Raspberry Pi, and neither time did it go as smoothly as installing on WIndows 10 (no surprise - Linux gets me every time). The main issues I encountered were:
1. Getting the audio and microphone to work properly. See here https://github.com/alexa-pi/AlexaPi/wiki/Audio-set... if you also have these issues.
2. Problems with the JDK version. See 4.3 in the official instructions, and the note in the pom.xml file that talks about overriding the version when executing the mvn exec:exec command (ie I had to add this switch -Dalpn-boot.version=8.1.6.v20151105). Note that this command is included in my startup script (alexa_startup.sh).
3. Getting the Sensory wake word engine to work ( https://github.com/Sensory/alexa-rpi )
Once you can get it all running with the manual commands as outlined in the instructions, proceed with the MicroDot installation.
You cannot directly attach the MicroDot to the GPIO because it will draw too much current. You will need:
2x 2N3904 transisitors to drive the LED's, 1x2K2 and 1x3K3 resistors to drop the voltage from the touch sensor to 3.3V (the MicroDot will be powered from the 5V supply). Refer to the attached diagram. You might want to make a PCB for this, but I have just mounted these components on the back of a 8 pin female plug.
CUSTOM WAKE ENGINE (TOUCH)
Unzip the contents of the attached zip folder into the alexa-avs-sample-appfolder. There are two files:
wake.py - a python script which is the custom (touch) wake engine for the MicroDot
alexa_autostart.sh - a script to run everything. Right click properties on this, and select execute: anyone on the permissions tab.
You will need python installed to run the wake engine. You will also need the GPIO library (https://makezine.com/projects/tutorial-raspberry-p...) These should already be installed in the latest version of Raspbian.
To run everything, type into terminal:
SET UP AUTORUN
To setup Alexa to auto-run on bootup, open a terminal and type:
sudo nano autostart
and add the line and save:
Reboot and the Alexa app should auto-run.