copyright | years | lastupdated | title | parent | grand_parent | nav_order |
---|---|---|---|---|---|---|
2020 - 2023 |
2023-02-20 |
Watson speech to text |
Edge service examples |
Using edge services |
5 |
{:new_window: target="blank"} {:shortdesc: .shortdesc} {:screen: .screen} {:codeblock: .codeblock} {:pre: .pre} {:child: .link .ulchildlink} {:childlinks: .ullinks}
{: #watson-speech}
This service listens for the word Watson. When it is detected, the service captures an audio clip and sends it to an instance of Speech to Text. Stop words are removed (optionally), and the transcribed text is sent to {{site.data.keyword.event_streams}}.
Ensure that your system meets these requirements:
- You must register and unregister by performing the steps in Preparing an edge device.
- A USB sound card and microphone is installed on your Raspberry Pi.
This service requires both an instance of {{site.data.keyword.event_streams}} and IBM Speech to Text to run correctly. For instructions about how to deploy an instance of event streams, see Host CPU load percentage example (cpu2evtstreams).
Ensure the necessary {{site.data.keyword.event_streams}} environment variables are set:
echo "$EVTSTREAMS_API_KEY, $EVTSTREAMS_BROKER_URL"
{: codeblock}
The event streams topic this sample uses is myeventstreams
by default, but you can use any topic by setting the following environment variable:
export EVTSTREAMS_TOPIC=<your-topic-name>
{: codeblock}
{: #deploy_watson}
If an instance is deployed currently, obtain the access information and set the environment variables, or follow these steps:
-
Navigate to the IBM Cloud.
-
Click Create resource.
-
Enter
Speech to Text
in the search box. -
Select the
Speech to Text
tile. -
Select a region, select a pricing plan, enter a service name, and click Create to provision the instance.
-
After provisioning is complete, click the instance and note the credentials API Key and URL and export them as the following environment variable:
export STT_IAM_APIKEY=<speech-to-text-api-key> export STT_URL=<speech-to-text-url>
{: codeblock}
-
Go to the Getting Started section for instructions of how to test the Speech to Text service.
{: #watson_reg}
To run the watsons2text service example on your edge node, you must register your edge node with the IBM/pattern-ibm.watsons2text-arm
deployment pattern. Perform the steps in the Using Watson Speech to Text to IBM Event Streams Service with Deployment Pattern {:target="_blank"}{: .externalLink} section of the readme file.
The processtect
example source code is also available in the Horizon GitHub repository as an example for {{site.data.keyword.edge_notm}}development. This source includes the code for all of the four services that run on the edge nodes for this example.
These services include:
- The hotworddetect {:target="_blank"}{: .externalLink} service listens and detects the hot word Watson, and then records an audio clip and published it to the mqtt broker.
- The watsons2text {:target="_blank"}{: .externalLink} service receives an audio clip and sends it to the IBM Speech to Text service and publishes the deciphered text to the mqtt broker.
- The stopwordremoval {:target="_blank"}{: .externalLink}service runs as a WSGI server takes a JSON object, such as {"text": "how are you today"} and removes common stop words and returns {"result": "how you today"}.
- The mqtt2kafka {:target="_blank"}{: .externalLink} service publishes data to {{site.data.keyword.event_streams}} when it receives something on the mqtt topic where it is subscribed.
- The mqtt_broker {:target="_blank"}{: .externalLink} is responsible for all inter-container communication.
-
For instructions about building and publishing your own version of the Offline Voice Assistant Edge Service, see Offline Voice Assistant Edge Service {:target="_blank"}{: .externalLink}. Follow the steps in the
watson_speech2text
directory of the Open Horizon examples repository. -
See the Open Horizon examples repository {:target="_blank"}{: .externalLink}.