/Choregraphe-GA

Choregraphe python box with Google Assistant integration (NAO/Zora robot)

GNU Lesser General Public License v3.0LGPL-3.0

Google Assistant for Choregraphe

This repository contains the source of a Choregraphe project that allows robots by Softbank Robotics to behave like a Google Assistant, refereed as GA from now, it responds to normal voice command/questions (eg. "Who is Obama?", "What time is it?", "Turn off the light", etc...) like a normal Google Home would do.

The script provides visual feedback to the user, eyes change colors according to the robot states: red indicates an error, blue indicates that it's listening, white indicate when it's idle. This was tested on a real robot, named Zora, that is based on the Nao robot by Softbank.

This Choregraphe script could be plugged in any other existing projects like a plug-in, it uses only default Python functions, the two only limit is that the robot should have ALSA installed, note that in Zora it's already installed, and a server should be present for communicate with GA (see How it works section).

Download

The last version of the project can be found in the Releases tab, where you can download choregraphe-ga.crg

How to use it

To use this script you'll need to open the downloaded project with Choregraphe, connect it to a real robot and open the "GA" box where you should search and change TCP_IP and TCP_PORT with your server IP and port. Press the play button, say "Hey Zora" and start speaking, if all is going normally the robot should answer without problem.

How it works

For a very general approach, the script works as a client, it sends microphone data to a server and waits for a JSON that contains the GA answer. The server could be installed into the robot (not tested) or in another pc, in any cases an internet connections is needed. It can be schematized as follows:

  1. The robot hears "Hey, Zora" (that triggers the speech recognition box)
  2. GA box starts recording microphone's audio with arecord and every bits it's sent to the server trough a TCP stream
  3. The server start a connection with GA and it forwards microphone's audio sent by the robot
  4. GA sends the response packets to the server
  5. When GA sends an "END_OF_UTTERANCE", the server send a JSON to the client that contains: the transcription of the user input, the text response, the microphone mode and the conversation state (see the documentation for more information)
  6. The robot receive the JSON response and it read the text response that is into it.

Note: an implementation in NodeJS of this server can be found in the GA-Server repository.

Demonstration videos

Play chess with Zora (Google Assistant + custom Google Actions)

Zora controllig light (Google Assistant + smart socket)