Raspberry Pi 4 Benchmarks¶
- Raspberry Pi 4 Benchmarks
Fig.1. Raspberry Pi 4 model B
Raspberry Pi 4 - new module¶
All current XIMEA USB cameras are compatible with the Raspberry Pi 4 Model B.
The XIMEA software package for Linux can be installed on the Raspberry Pi, but (depending on the choice of the operating system) the XIMEA CamTool may not be available.
Performance on the Raspberry Pi depends on the camera model as well as on the application.
It may not be possible to reach the advertised frame rate of a camera.
The following hardware was used during testing:
- Raspberry Pi 4 Model B, 4GB RAM
- Armor Case/Heatsink for the Raspberry Pi
- Official Raspberry Pi Power Supply
- Micro SD card (32GB)
- Micro HDMI Adapter
- Standard USB Mouse and Keyboard
- Standard Monitor with HDMI input
- USB cable (CBL-U3-3M0)
- XIMEA USB camera (xiC, xiQ and xiMU family)
It is possible to install the XIMEA software package on a system running the official Raspberry Pi OS, but there are some restrictions.
At the time of testing only the 32bit version of this OS has been officially released.
The XIMEA CamTool is not supported on 32bit operating systems, so it couldn't be used.
Ubuntu 21.04 (64 bit) is also available for the Raspberry Pi 4.
All components of the XIMEA software package including CamTool can be used on a Raspberry Pi when using Ubuntu 21.04 (64 bit).
Other distribution may also work with XIMEA cameras, but it was not tested.
The tool from the official Raspberry Pi website can be used to prepare a Micro SD card with the operating system.
The following instructions assume that you have used this method to install Ubuntu 21.04 (64bit) and no other software has been installed on the system.
A working internet connection will be necessary to run all necessary libraries.
Make sure all packages installed on your system are up-to-date by running the following commands:
sudo apt update
sudo apt upgrade
Installing the XIMEA software package¶
Either download the XIMEA software package for Linux from the XIMEA website:
Or run the following command:
Afterward, unpack the installer and run it:
tar xzf XIMEA_Linux_SP.tgz
You will need "sudo" privileges to run the installer.
Increase USB memory limit¶
The default memory limit for buffers allocated for USB devices (usually 16MB) is too low for XIMEA USB cameras.
This can be changed permanently following these steps:
1. Open the file /boot/firmware/cmdline.txt in your preferred texteditor
2. Append the following (in the same line):
3. Reboot the system
4. Check if the changes are applied. The following command should print 0:
After installing the XIMEA software package and increasing the USB memory limit, you can connect the camera and run this basic example to see if the camera is working:
The XIMEA CamTool has some additional dependencies that may not be installed yet.
You can install them using the following command:
sudo apt install libpcre16-3
Afterward, you can launch the XIMEA CamTool:
The xiApiPlusOpenCV example located in /opt/XIMEA/examples/xiApiPlusOpenCV is available as source code and needs to be compiled.
It requires some build tools as well as OpenCV to be installed.
sudo apt install build-essential libopencv-dev
The current version of OpenCV (4.5) requires a slightly different include path compared to the version originally used in this example.
To be able to compile the example with this version, open the Makefile in your preferred editor and change all occurrences of /usr/local/include/ to /usr/include/opencv4.
Afterward, you can compile and run the example:
USB bandwidth is consistently measured as 392 MByte/s which is slower than some other USB controllers, but should generally not be an issue.
Frame rate in RAW8
With the image data format set to RAW8, minimal exposure and bandwidth limited to 95% of the available bandwidth, it was possible to get very close to the specified full frame rate (according to the XIMEA technical manual) and in some cases even exceed it.
Note that during this test, no image processing, rendering or recording was performed.
|Measured frame rate
|Spec. frame rate
*With ZeroROT enabled