Google Assistant on a Raspberry Pi!
by drjhxie in Circuits > Raspberry Pi
20926 Views, 40 Favorites, 0 Comments
Google Assistant on a Raspberry Pi!
Have an old Raspberry Pi sitting around? Then it's time to put it to work! In this project, I will be telling you how to make a google assistant using a Raspberry Pi!
Supplies
- Any Raspberry Pi (Faster is better)
- Micro sd card
- Usb Microphone
- Speakers
Setting Up Raspberry Pi OS
The first step is installing an Operating System. I recommend Raspberry Pi OS, which is what we are using for this tutorial.
If you are new to installing an Operating system on a Raspberry Pi, follow these steps:
- Go to www.raspberrypi.com/software/
- Download the imager by clicking the download button when you scroll down
- Open the App, click "Operating System," click Raspberry Pi OS (Other)
- Scroll down and click Raspberry Pi OS Lite (32-bit or legacy)
- Insert SD Card
- Click Storage and click on your Micro SD card.
- Click Write
- Insert SD card to the Raspberry Pi
- Connect a good power supply to the Raspberry Pi.
Registering for the Google API
Before we get started with setting up the Google Assistant code on the Raspberry Pi itself, we must first register and set up a project on the Google Actions Console.
With your Google account ready to go to the Google Console Actions dashboard.
Once you have logged into your account, you will be greeted with the following screen. On here you will want to click the “Add/Import project” button as shown in our screenshot above.
On this next screen, you will be asked to enter a Project Name In addition to a project name you need to set both your country and your language.
Once you have set the Project Name and chosen your language and country, click the “Create Project” button.
In a new tab, go to the Google developers console and enable the Google Embedded Assistant API.
Now before you go ahead and click the “Enable” button make sure that you have your project selected.
Once you are sure you have your current project selected, click the “Enable” button.
Now back in the other tab where you created the project, scroll down to the bottom of the screen.
You should see some text saying, “Are you looking for device registration? Click here“.
All you need to do to proceed is to click the “click here” text.
You will now be taken to the following screen, click the “Register Model” button to continue.
Register the Model
On this screen, you need to set a “Product Name“, “Manufacturer name”, and set a “Device Type”
Below you can see the data that we entered into it, it doesn’t hugely matter what you set here, but all three boxes do need to be set for you to be able to register your model.
For the “Product Name” we just set this as a simple descriptor of what we are using this for, which in the case of this tutorial is just simply “Ras-pi Google Assistant“.
“Manufacturer name” doesn’t hugely matter as we have no intention of this being a widely used device, so we just set this to our website's name “Pi My Life Up“.
Lastly, we set the “Device Type” as “Speaker” as we felt it matched best what we intend on using the Google Assistant API for on our Raspberry Pi.
Make sure you write down the “Device Model ID” as you will need this later in the tutorial.
Finally, once everything is set, and you have written down the “Device Model ID” click the “Register Model” (3.) button to continue.
Download Credentials
Now that you have registered the model you will now be taken to the “Download credentials” screen.
This screen is crucial as the provided credentials file is what we need for our Raspberry Pi-based Google Assistant to talk with the server.
To get this credentials file click the “Download OAuth 2.0 credentials” button as shown on the screenshot below.
Keep this somewhere safe, as we will the text inside the file to the Raspberry Pi. (Of course, unless you downloaded it directly to your Pi)
Once you have the credentials safely stored on your computer or Raspberry Pi, you need to click the “Next” button.
Finally, you can specify any traits that you might need.
In our case, we don’t need any of these so we just clicked the “Save Traits” button as shown below.
Once everything is done, you should be shown on the screen above.
We now only have one last thing we need to do before we can set up the Google Assistant on the Raspberry Pi itself.
Configure the OAuth Consent Screen
We also need to configure the OAuth consent screen. Without this, Google won’t let us authorize our Raspberry Pi Google Assistant device later in this tutorial.
To do this, you will need to go to the API Credentials OAuth consent screen settings page.
On this first page, make sure that your project is selected in the top dropdown box.
Secondly, you will need to select “External” as the user type. This option will allow anyone with a Google account to utilize the Google Assistant software that we are setting up.
Once all configured, click the “CREATE” button to continue on to setting up the authorization screen.
The Details
This page will allow you to set up the details of the auth screen. As we don’t intend this to be publicly accessible there is only one option we are required to set.
Click the email dropdown to select your account's email address, selecting this will allow us to continue with the guide.
Once everything required has been set, click the “Save” button at the bottom of the page.
Finally, we need to go to the Google My Account activity controls.
On here you will need to activate the following activity controls to ensure that the Google Assistant API works correctly.
- Web & App Activity
- Location History
- Device Information
- Voice & Audio Activity
Setting Up Your Audio for Google Assistant
1. Now that we have set up an account on the Google Actions Console we must configure the audio for it.
The Google Assistant SDK that we will be using has some strict requirements for it to work correctly.
To get started with setting up the audio on the Raspberry Pi we must first obtain the card and device numbers for our various inputs and outputs.
Our steps below will show you have to get the correct numbers for these devices.
1a. Locate your USB microphone by utilizing the following command.
Write down both the card number and the device number for it.
arecord -l Copy
1b. Now to locate your speaker, we will be utilizing the following command.
Again write down the card number and device number.
Note that the Raspberry Pi’s 3.5mm-jack is typically labeled as Analog or bcm2835 ALSA, with the HDMI output being identified as bcm2835 IEC958/HDMI.
aplay -l Copy
2. Now that we have grabbed our device and card numbers for both the microphone and our audio output we need to create a file named .asoundrc in the pi users home directory.
The .asoundrc file helps by defining which audio devices the audio driver should be utilizing.
We can create this file by running the following command within the terminal.
nano /home/pi/.asoundrc Copy
3. Within this file enter the following lines.
Make sure that you replace <card number> and with <device number> their respective values that you retrieved during Step 1.
pcm.!default { type asym capture.pcm "mic" playback.pcm "speaker" } pcm.mic { type plug slave { pcm "hw:<card number>,<device number>" rate 48000 } } pcm.speaker { type plug slave { pcm "hw:<card number>,<device number>" } } Copy
4. With the lines in, and changes made. Save by pressing CTRL + X then Y and finally ENTER.
Testing Your Speakers and Microphone
1. Before we get into all the hard work of setting up our Raspberry Pi Google Assistant and setting up the required API, we will first test to ensure our audio is working.
At this stage, you must have your USB microphone and speakers attached to your Raspberry Pi.
Once you are sure both are connected to the Raspberry Pi, we can test to make sure that the speakers are working correctly by running the following command.
speaker-test -t wav Copy
You should hear sounds from your speakers. This sound will be a person speaking.
If you do not hear anything coming from your speaker double check they are plugged in correctly and are turned up.
2. Now, let’s test our microphone by making a recording, to do this we will run the following command on your Raspberry Pi.
This command will make a short 5-second recording.
arecord --format=S16_LE --duration=5 --rate=16000 --file-type=raw out.raw Copy
If you receive an error when running this command make sure that you have your microphone plugged in. This command will only succeed if it can successfully listen to your microphone.
3. With our recording done we can now run the following command to read in our raw output file and play it back to our speakers.
Doing this will allow you to test the playback volume and also listen to the recording volume.
Doing this is a crucial task as you don’t want your Raspberry Pi picking up every little noise but you also don’t want it being able to barely hear you when you say “Ok Google“.
aplay --format=S16_LE --rate=16000 out.raw Copy
4. If you find the playback volume or recording volume is either too high or too low, then you can run the following command to launch the mixer.
This command will allow you to tweak the output volumes for your various output devices.
From our tests, we recommend you use a level of at least 70, utilize the command in Step 1 of this section to check the volume levels.
alsamixer Copy
Once you have confirmed that your microphone and speakers are working correctly, you can move on to setting up your very own Raspberry Pi Google Assistant!
Downloading and Setting Up Google Assistant
1. With the Google Assistant API now configured and set up there are a few things we need to do.
Let’s first update the Raspberry Pi’s package list by running the following command.
sudo apt update Copy
2. Once the Raspberry Pi has finished updating, we can then proceed with setting up everything we need for running the Google Assistant API.
On your Raspberry Pi, we will be creating a file where we will store the credentials we downloaded earlier on our computer.
To do this run the following two commands to create a folder and begin writing our credential file.
mkdir ~/googleassistant nano ~/googleassistant/credentials.json Copy
3. Within this file, we need to copy the contents of the credentials file that we downloaded to your computer.
You can open the .json file in any text editor and press CTRL + A then CTRL + C to copy the contents.
Now in your SSH window, right-click and click “Paste”.
4. Once you have copied the contents of your credentials over to our nano session, we can then save the file by pressing CTRL + X then Y, and then finally hitting ENTER.
5. Now with the credentials file now saved safely to our Raspberry Pi we will start installing some of the dependencies we rely on.
Run the following command to install Python3 and the Python 3 Virtual Environment to our Raspberry Pi.
sudo apt install python3-dev python3-venv python3-pip libssl-dev libffi-dev libportaudio2 Copy
6. We can now enable python3 as our virtual environment variable by running the following command on our Raspberry Pi.
python3 -m venv env Copy
7. With that now enabled we can go ahead and ensure that we have installed the latest versions of pip and the setuptools.
To update these Python packages, we will need to use the following command on the Raspberry Pi.
env/bin/python3 -m pip install --upgrade pip setuptools --upgrade Copy
8. To get into this new Python environment that we have set up we should run the following command in the terminal.
source env/bin/activate Copy
9. Now that we have all the packages we need to install the Google Assistant Library.
To do this we will run the command below to utilize pip to install the latest version of the Python package.
python3 -m pip install --upgrade google-assistant-library python3 -m pip install --upgrade google-assistant-sdk[samples]
Authorizing Your Raspberry Pi for the Google Assistant
1. Now that we have set up all the prerequisites to running the Google Assistant software on our Raspberry Pi we can finally complete the last few steps to authorize the system.
To do this, we must first install the Google authorization tool to our Raspberry Pi.
This package will allow us to authenticate our device and give ourselves the rights to be able to make Google Assistant queries for your Google Account.
Run the following command on the Raspberry Pi to install the Python authorization tool.
python3 -m pip install --upgrade google-auth-oauthlib[tool] Copy
2. With the Google Authentication library now installed, we need to run it. To do this, we will be running the following command on our Raspberry Pi.
This command will generate a URL you will need to go to in your web browser so be prepared.
google-oauthlib-tool --client-secrets ~/googleassistant/credentials.json \ --scope https://www.googleapis.com/auth/assistant-sdk-prototype \ --scope https://www.googleapis.com/auth/gcm \ --save --headless Copy
3. You will now be presented with the text “Please visit this URL to authorize this application:” followed by a very long URL.
Make sure you copy this URL entirely to your web browser to open it.
4. On this screen log in to your Google account, if you have multiple accounts make sure you select the one you set up your API key with.
Afterward, you should be presented with a screen with the text “Please copy this code, switch to your application and paste it there” followed by a long authentication code.
Copy the authentication code and paste it back into your terminal session and press the ENTER key.
If the authentication was accepted you should see the following line appear on your command line:
“credentials saved: /home/pi/.config/google-oauthlib-tool/credentials.json“
5. Now with the authentication credentials now saved, Google still requires us to agree to some stuff.
With this command make sure you replace <projectid> with the id of your project.
If you don’t know what your Project ID is you can go to Actions Console on Google, click the project you created, then click the Cog in the top left-hand corner then “Project Settings“.
Also, make sure you replace <deviceid> with the device ID that you obtained earlier in the tutorial.
If you have lost your device ID can find it again by going to the Console Actions website, clicking the project you created then going to “Device registration“
To talk with the Assistant press ENTER in the terminal and speak an action such as “What is the time“.
If everything is working as it should be you will hear a verbal response from the assistant.
googlesamples-assistant-pushtotalk --project-id <projectid> --device-model-id <deviceid> Copy
6. If you don’t hear any response from Google Assistant but a new tab does open that contains your results, then you should go back to the “Setting up your Audio for Google Assistant” section and the “Testing your Audio for Google Assistant” section.
In the next section, we will show you how you can rerun the Google Assistant without having to go searching through all the steps again, make sure you keep your “Project ID” and “Device ID” handy as we still need those to utilize the samples.
Using the Google Assistant on the Raspberry Pi
1. Now that we have finally fully authorized our Raspberry Pi we will now walk you through the steps on how to run the Google Assistant software without having to go through the entire tutorial.
To begin with whenever you start a new terminal session you will need to put it back into the environment that we set up the Google Assistant software in.
To do this, run the following command on your Raspberry Pi.
source env/bin/activate Copy
2. You will know whether this has worked correctly by seeing (env) appear at the front of each line.
With (env) appearing it means you can once again make calls to the Google Assistant samples.
To start up the push-to-talk sample you will need to run the following command, lucky for us, this time we do not need to write in the project id or the device id as these were cached when we first utilized the push to talk tool.
googlesamples-assistant-pushtotalk Copy
3. In addition to the push-to-talk sample, there is also the hotword sample code. This sample code will work by listening for certain phrases to trigger it. By default, this will listen for “Ok Google” followed by the command that you want to issue to it.
Starting the hotword sample is very much like the push-to-talk sample, however, you are utilizing the google sample-assistant-hotword utility instead.
googlesamples-assistant-hotword --device-model-id <deviceid> Copy
4. Hopefully, by now you will have successfully set up your Raspberry Pi with the Google Assistant software.
If you run into audio issues, we recommend you go back to our “Setting up your Audio for Google Assistant” section and the “Testing your Audio for Google Assistant” section.
Getting the Google Assistant to Start on Startup
1. Now that you have got your Google Assistant up and running you will likely want to get it to start up on boot rather than having to go to the effort of entering the commands every time.
The easiest way to achieve this is to create a service for it. This service will allow the Google assistant to run in the background on the Raspberry Pi and easily allow us to retain control over it.
To begin, we will write our bash script that will execute the hotword sample. We will be calling this bash script from our service file.
nano /home/pi/start_assistant.sh Copy
2. To this file, you will want to add the following lines.
The first line helps define what should be utilized to run this file, so when the command line interprets it, it will know that it is required to make use of bash.
In the second line we use source to read and execute commands from the activate file, this will put us into the python environment that we created earlier in the tutorial.
Finally, we run the hotwords Google Assistant sample. Make sure you replace <deviceid>with yours.
#!/bin/bash source /home/pi/env/bin/activate googlesamples-assistant-hotword --device-model-id <deviceid> Copy
3. Once you have added those lines to the file, save it by pressing CTRL + X then Y, and finally ENTER.
4. Now that we have created our bash script we can move on to creating our service file for our Google Assistant by running the following command on our Raspberry Pi.
sudo nano /lib/systemd/system/assistant.service Copy
5. Within this file enter the following lines.
These lines tell the operating system how to handle our service, what user to run it with, and if it relies on a particular thing such as that the network is available.
[Unit] Description=Google Assistant Wants=network-online.target After=network-online.target [Service] Type=simple ExecStart=/bin/bash /home/pi/start_assistant.sh Restart=on-abort User=pi Group=pi [Install] WantedBy=multi-user.target Copy
6. With those lines added to the service file, save it by pressing CTRL + X then Y, and finally ENTER.
7. Now that we have created the service we need to enable it so that it will actually start on startup.
To do this we just need to use systemctl, type in the following command to enable our new service.
sudo systemctl enable assistant.service Copy
8. With the service now enabled let’s try starting it, this will allow us to make sure that everything is working as intended.
sudo systemctl start assistant.service Copy
9. You should now be able to use the “Ok Google” hotword to talk and interact with the Google Assistant.
Try it now to ensure the service is working as intended.
If for some reason it is not working you can utilize the command below to display the last output from the Google Assistant sample, keep a lookout for any errors.
sudo systemctl status assistant.service Copy
10. Hopefully, at this point, you will now have your Google Assistant successfully set up to start on boot!
If you hear a response, you have successfully set up your very own Google Assistant on your Raspberry Pi! If you want to provide feedback or discuss this Raspberry Pi Google assistant project, please leave a comment below.
Thank you for reading this project, and I hope you have Google Assistant successfully set up!
Credits
Some code credit to Emmet (Not on Instructables)