The Raspberry Pi 4 is a versatile Linux development board with a quad-core processor running at 1.5GHz, a GPIO header to connect sensors, and the ability to easily add an external microphone or camera - and it’s fully supported by Edge Impulse. You’ll be able to sample raw data, build models, and deploy trained machine learning models directly from the Studio.
In addition to the Raspberry Pi 4 we recommend that you also add a camera and / or a microphone. Most popular USB webcams and the Camera Module work fine on the development board out of the box.
Prerequisites
Headless Setup
You can set up your Raspberry Pi without a screen. To do so:
- Flash the Raspberry Pi OS image to an SD card using the Raspberry Pi Imager.
You must use 64-bit OS with _aarch64 and 32-bit OS with armv7l_*
- During the flashing process, access the advanced options menu in the Raspberry Pi Imager to preconfigure your WiFi and enable SSH.
- wpa_supplicant.conf cannot be used from Bookworm onward. You must use the Pi Imager or the advanced menuraspi-configtool to set up WiFi.
- 
Insert the SD card into your Raspberry Pi 4, and let the device boot up.
- 
Find the IP address of your Raspberry Pi. You can either do this through the DHCP logs in your router or by scanning your network. E.g., on macOS and Linux via:
$ arp -na | grep -i dc:a6:32
? (192.168.1.19) at dc:a6:32:f5:b6:7e on en0 ifscope [ethernet]
 
192.168.1.19is your IP address.
- 
Connect to the Raspberry Pi over SSH. Open a terminal window and run:
ssh <username>@192.168.1.19
 
- 
Log in with the default username piand passwordraspberry.
Setup with a Screen
If you have a screen and a keyboard/mouse attached to your Raspberry Pi:
- Flash the Raspberry Pi OS image to an SD card.
- Insert the SD card into your Raspberry Pi 4, and let the device boot up.
- Connect to your WiFi network.
- Click the ‘Terminal’ icon in the top bar of the Raspberry Pi.
Installing dependencies
To set this device up in Edge Impulse, run the following commands:
sudo apt update
curl -sL https://deb.nodesource.com/setup_20.x | sudo bash -
sudo apt install -y gcc g++ make build-essential nodejs sox gstreamer1.0-tools gstreamer1.0-plugins-good gstreamer1.0-plugins-base gstreamer1.0-plugins-base-apps
sudo npm install edge-impulse-linux -g --unsafe-perm
Important: Edge Impulse requires Node.js version 20.x or later. Using older versions may lead to installation issues or runtime errors. Please ensure you have the correct version installed before proceeding with the setup.
Install with Docker
If you want to install Edge Impulse on your Raspberry Pi using Docker you can run the following commands:
docker run -it --rm --privileged --network=host -v /dev/:/dev/ --env UDEV=1 --device /dev:/dev --entrypoint /bin/bash ubuntu:20.04
apt-get update
apt-get install wget -y
wget https://deb.nodesource.com/setup_20.x
bash setup_20.x
apt install -y gcc g++ make build-essential nodejs sox gstreamer1.0-tools gstreamer1.0-plugins-good gstreamer1.0-plugins-base gstreamer1.0-plugins-base-apps vim v4l-utils usbutils udev
apt-get install npm -y
npm install edge-impulse-linux -g --unsafe-perm
/lib/systemd/systemd-udevd --daemon
Connecting to Edge Impulse
With all software set up, connect your camera or microphone to your Raspberry Pi (see ‘Next steps’ further on this page if you want to connect a different sensor), and run:
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.
Verifying that your device is connected
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.
Next steps: building a machine learning model
With everything set up you can now build your first machine learning model with these tutorials:
Looking to connect different sensors? Our Linux SDK lets you easily send data from any sensor and any programming language (with examples in Node.js, Python, Go and C++) into Edge Impulse.
Deploying back to device
To run your impulse locally, just connect to your Raspberry Pi again, and run:
edge-impulse-linux-runner
Image model?
If you have an image model then you can get a peek of what your device sees by being on the same network as your device, and finding the ‘Want to see a feed of the camera and live classification in your browser’ message in the console. Open the URL in a browser and both the camera feed and the classification are shown:
Live feed with classification results
Troubleshooting
Wrong OS bits
If you see the following error when trying to deploy a .eim model to your Raspberry Pi:
Failed to run impulse Error: Unsupported architecture “aarch64”
uname -m
uname -a
getconf LONG_BIT
$ uname -m
aarch64
$ uname -a
Linux raspberrypi 6.1.21-v8+ #1642 SMP PREEMPT Mon Apr  3 17:24:20 BST 2023 aarch64 GNU/Linux
$ getconf LONG_BIT
32
aarch64 when you run uname -m.