Ambiq Apollo4 family of SoCs

Ambiq®, the leader in low-power System-on-Chip (SoC) solutions, has once again raised the bar with the Apollo4 Family of SoCs. With the lowest dynamic and sleep mode power on the market, the Apollo4 allows designers of next-generation edge AI devices to take their innovative products to the next level. Built upon Ambiq’s proprietary Subthreshold Power-Optimized Technology (SPOT®) platform, the Apollo4 Family of SoCs is a complete hardware and software solution that enables the battery-powered endpoint devices of tomorrow to achieve a higher level of intelligence without sacrificing battery life. Edge Impulse support is available on the Apollo4 Plus, Apollo4 Blue Plus, Apollo4 Lite, and Apollo4 Blue Lite. See below for how to get started on the Apollo4 Plus and Apollo4 Blue Plus SoCs.

The Apollo4 Plus is built on the 32-bit Arm® Cortex®-M4 core with Floating Point Unit (FPU). With up to 2 MB of NVM and 2.75 MB of SRAM, the Apollo4 Plus has more than enough compute and storage to handle complex algorithms and neural networks while displaying vibrant, crystal clear, and smooth graphics. If additional memory is required, an external memory is supported through Ambiq’s multi-bit SPI and eMMC interfaces. The Apollo4 Plus is purpose-built to serve as both an application processor and a co-processor for battery-powered endpoint devices, including predictive health and maintenance sensors, smart home devices, livestock trackers, wrist-based wearables, smart rings, smart voice devices, and more. The Apollo4 Plus is available now in BGA packaging. The Apollo4 Blue Plus incorporates an optional BLE 5.4 radio.

Ambiq Apollo4 Blue Plus KXR Eval Board

Installing dependencies

To set this device up in Edge Impulse, you will need to install the following software:

Connecting the Apollo4 Audio Add-on Board (Models with Audio Input Only)

This step is only needed when using models requiring microphone input, such as the example below. Skip this section if you are testing other models that do not need audio input.

Remove the pin header protectors on the Apollo4 Plus EVB (AMAP4PEVB) or Apollo4 Blue Plus KXR EVB (AMAP4BPXEVB), and carefully plug the Apollo4 Audio Add-onBoard (AMA4AUD) into the development board. Pay special attention to the highspeed connector with film tape, which must be removed before connecting the boards. Place the digital and analog microphone modules onto the shield, as shown in the image below, and connect cables to both type-C connectors on the evaluation board.

Apollo4 Blue Plus and Apollo4 Audio Add-on Board connected to computer

Connecting an ArduCam Mega 5MP SPI

This step is only needed when using models requiring camera input. Skip this section if you are testing other models that do not need camera input.

The ArduCam Mega 5MP SPI connects to the Apollo4 Plus EVB and Apollo4 Blue Plus KXR EVB pins as shown in the table below:

Camera Pin
EVB Pin

GND

Any EVB GND

5V/VDD

Any EVB 5V

SCK

Pin 8

MISO

Pin 10

MOSI

Pin 9

CS

Pin 11

ArduCam connected

Flashing pre-built firmware

Pre-built image with only audio support and "Hello World" detector example here

Pre-built image with full video and audio data collection and FOMO Face detector example here

Get started by extracting the archive and choose the appropriate script for your system architecture to flash the firmware:

Flashing new firmware

Connecting to Edge Impulse

Using the daemon

From a command prompt or terminal, run:

edge-impulse-daemon

This will start a wizard which will ask you to log in and choose an Edge Impulse project. If you want to switch projects run the command with --clean.

Alternatively, you can access the project API Key as shown below by navigating to the Dashboard section on the left pane of your Studio project and select the Keys tab, then click the copy/paste icon next to the API Key to copy the entire text to your clipboard, then run:

edge-impulse-daemon --api-key [paste your key here]
edge-impulse-api-key

Connecting to Studio

Run the edge-impulse-daemon and connect to your project, you will be prompted to name your device:

Connecting to Edge Impulse.

That's all! Your device is now connected to Edge Impulse. To verify this, go to your Edge Impulse project, and click Devices. The device will be listed here.

Device connected to Edge Impulse.

Collecting data

Audio

With the device connected to Studio, you can use it to collect audio data up to 5 seconds in length for training and testing your model. Navigate to the Data acquisition tab and start collecting samples:

How to collect an audio sample

Daemon output during sampling:

Collecting an audio sample
Example sample

Video

How to collect an image sample

Sampling images:

Collecting an image sample

Three supported sizes 96x96, 128x128, 160x160:

Three different options

Next steps: building a machine learning model

With everything set up you can now build your first machine learning model with these tutorials:

If you flashed the pre-built binary with FOMO Face Detection example from above then just connect your board and run edge-impulse-run-impulse to see an output similar to this:

FOMO Face detect output

Example project

Start by going to your Studio projects then create a new project and navigate to the Create impulse section of Impulse design, at which point you will be prompted to select your target, choose the Apollo4 Plus:

Choosing target hardware

Then add the DSP block:

DSP

Then the keyword spotting learn block:

KWS

And finally save the impulse:

Saving it all

DSP

Now select the DSP block:

Select DSP

And go to Generate features:

Generate features

Click the button and wait for the job to finish, when it does you'll see something like this:

DSP complete

Training

Select the learning block:

Select learning block

Then click Save & train and you'll eventually see an output like this:

Training

Testing

Go to the Model testing section and enable int8 testing:

Select int8 testing

And run the test:

Test results

Deploying

Navigate to the Deployment section and choose the Apollo4 Blue Plus:

Selecting the Apollo4

Now click Build and wait for the job to finish, when it does a zip archive will be downloaded to your computer:

Building the binary

Flashing

See the previous section on flashing the board.

Running the impulse

You can run your impulse by using edge-impulse-run-impulse:

Running the impulse

Troubleshooting

If you have problems with the flashing script make sure you are using USB cables with data and not just power-only cables.

Reach out to us on the forum and have fun making machine learning models on the Apollo4 Family of SoCs from Ambiq!

Last updated

Was this helpful?

Revision created

api outlinking