Product Description#
The XCORE-VOICE Solution consists of example designs and a C-based SDK for the development of audio front-end applications to support far-field voice use cases on the xcore.ai family of chips (XU316). The XCORE-VOICE examples are currently based on FreeRTOS or bare-metal, leveraging the flexibility of the xcore.ai platform and providing designers with a familiar environment to customize and develop products.
XCORE-VOICE example designs include turn-key solutions to enable easier product development for smart home applications such as light switches, thermostats, and home appliances. xcore.ai’s unique architecture providing powerful signal processing and accelerated AI capabilities combined with the XCORE-VOICE framework allows designers to incorporate keyword, event detection, or advanced local dictionary support to create a complete voice interface solution. Bridging designs including PDM microphone to host aggregation are also included showcasing the use of xcore.ai as an interfacing and bridging solution for deployment in existing systems.
The C SDK is composed of the following components:
Peripheral IO libraries including; UART, I2C, I2S, SPI, QSPI, PDM microphones, and USB. These libraries support bare-metal and RTOS application development.
Libraries core to DSP applications, including vectorized math and voice processing DSP. These libraries support bare-metal and RTOS application development.
Libraries for speech recognition applications. These libraries support bare-metal and RTOS application development.
Libraries that enable multi-core FreeRTOS development on xcore including a wide array of RTOS drivers and middleware.
Pre-build and validated audio processing pipelines.
Code Examples - Examples showing a variety of xcore features based on bare-metal and FreeRTOS programming.
Documentation - Tutorials, references and API guides.
Key Features#
The XCORE-VOICE Solution takes advantage of the flexible software-defined xcore-ai architecture to support numerous far-field voice use cases through the available example designs and the ability to construct user-defined audio pipeline from the SW components and libraries in the C-based SDK.
These include:
Voice Processing components
Two PDM microphone interfaces
Digital signal processing pipeline
Full duplex, stereo, Acoustic Echo Cancellation (AEC)
Reference audio via I2S with automatic bulk delay insertion
Point noise suppression via interference canceller
Switchable stationary noise suppressor
Programmable Automatic Gain Control (AGC)
Flexible audio output routing and filtering
Support for Sensory, Cyberon or other 3rd party Automatic Speech Recognition (ASR) software
Device Interface components
Full speed USB2.0 compliant device supporting USB Audio Class (UAC) 2.0
Flexible Peripheral Interfaces
Programmable digital general-purpose inputs and outputs
Example Designs utilizing above components
Far-Field Voice Local Command
Low Power Far-Field Voice Local Command
Far-Field Voice Assistance
Firmware Management
Boot from QSPI Flash
Default firmware image for power-on operation
Option to boot from a local host processor via SPI
Device Firmware Update (DFU) via USB or I2C
Power Consumption
FFD/FFVA: 300-350mW (Typical)
Low Power FFD: 110mW (Full-Power), 54mW (Low-Power), <50mW possible with Sensory’s LPSD under certain conditions.
Obtaining the Hardware#
The XK-VOICE-L71 DevKit and Hardware Manual can be obtained from the XK-VOICE-L71 product information page.
The XK-VOICE-L71 is based on the: XU316-1024-QF60A
The XCORE-AI-EXPLORER DevKit and Hardware Manual used in the Microphone Aggregation example can be obtained from the XK-VOICE-L71 product information page.
Learn more about the The XMOS XS3 Architecture
Obtaining the Software#
Development Tools#
It is recommended that you download and install the latest release of the XTC Tools. XTC Tools 15.3.0 or newer are required. If you already have the XTC Toolchain installed, you can check the version with the following command:
xcc --version
Application Demonstrations#
If you only want to run the example designs, pre-built firmware and other software can be downloaded from the XCORE-VOICE product information page.
Source Code#
If you wish to modify the example designs, a zip archive of all source code can be downloaded from the XCORE-VOICE product information page.
See the Programming Guide for information on:
Prerequisites
Instructions for building, running, and debugging the example designs
Details on the software design and source code
Cloning the Repository#
Alternatively, the source code can be obtained by cloning the public GitHub repository.
Note
Cloning requires a GitHub account configured with SSH key authentication.
Run the following git command to clone the repository and all submodules:
git clone --recurse-submodules git@github.com:xmos/sln_voice.git
If you have previously cloned the repository or downloaded a zip file of source code, the following commands can be used to update and fetch the submodules:
git pull
git submodule update --init --recursive