A project using the OpenMV cam with Raspberry Pi for face detection
TBC
- OpenMV Cam H7 (R2 or Plus) (USB)
- OpenMV Ultra Wide lens
- Raspberry Pi 4 Model B (2GB)
- Raspberry Pi Power Cable
- Micro SD Card (minimum 8GB)
- USB A to micro B Cable
- High Speed 4K UHD HDMI Lead, Male to Micro D Male
You will need a separate computer or laptop to configure the components and load required software. You may also need an SD card reader and/or Micro SD adapter so that you can write the Raspberry Pi OS to the Micro SD using your computer or laptop (Windows or Mac).
- OpenMV IDE 2.6.9
- OpenMV Firmware 4.0.2
- OpenMV RPC Python Module (Compatible with Python 2 and 3. For convenience this script is included within this project under MIT licence)
A number of other Python modules are required for the project.
- Pyserial
- Pygame
These modules are installed using the provided script setup.sh
. Further instructions below.
The following guide assumes the use of a Windows PC for downloading and configuring the OpenMV camera and Raspberry Pi. This process will differ if you are using an Apple Mac or Linux computer.
- Download the PUTTY SSH client (Windows): https://www.putty.org/
- Open the associated PUTTYgen application.
- Click the 'Generate' button to create private and public keys for your Raspberry Pi device.
- Move your mouse in the box provided by the application to generate random data.
- Set a name for the SSH key e.g. 'OpenMV2RaspPi' so you remember what key is required when connecting to the device in future.
- Enter a 'Key passphrase' for added security.
- Save the public and private keys on your computer. Remember the location as you will need these later to connect to Raspberry Pi device using PUTTY.
- Finally, you can 'Copy' the long public key so that it can be pasted into the Raspberry Pi Imager application to setup your device.
- You are now ready to setup the Raspberry Pi.
- Download, install and run Raspberry Pi Imager (Windows or Mac): https://www.raspberrypi.org/software/
- Click 'Choose OS' button.
- Select 'Raspberry Pi OS (other)'.
- Select 'Raspberry Pi OS Lite (32-bit)'.
- Insert the Micro SD card into your computer.
- Click 'Choose SD Card'.
IMPORTANT: Ensure that you select the correct SD card as this process will overwrite the data on the drive you select.
- Open the hidden 'Advanced options' section by pressing CTRL+SHIFT+X on the keyboard.
- Check 'Set hostname' option and provide name e.g.
raspberrypi
. This will be the device's wireless network name or SSID.
NOTE: Choosing a unique SSID for the device can be useful for allowing you to access the it from another machine on the same local network. This can help you connect to the device via SSH before you have established what IP address it has been assigned on that network.
- Check 'Enable SSH' to allow remote access to the device.
- Select 'Allow public-key authentication only'.
NOTE: You can select 'Use password authentication' and provide a password instead. However, this is not recommended for devices connected directly to the internet or on public networks as they will be vulnerable to brute force password hacking attacks.
- Paste the public key generated with PUTTYgen into the field 'Set authorized_keys...'.
IMPORTANT: Ensure you remove and overwrite the default value. If you don't place the public key into this field correctly you will not be able to log in to the Raspberry Pi using the corresponding private key.
- If the device is to connect to the internet via wifi, check 'Configure wifi' and provide the SSID and password for the network the device is intended to connect to. Also set the wifi country from the dropdown e.g. 'GB'.
- Check 'Set locale settings' and select timezone (e.g. Europe/London) and keyboard layout (e.g. 'gb').
- Check 'Skip first-run wizard'.
IMPORTANT: The first-run wizard requires monitor, keyboard an mouse so must be disabled to successfully start the Raspberry Pi in headless mode.
- Uncheck each of the 'Persistent settings' options.
- Click 'Save'.
- Click 'Write'.
- Disconect the Micro SD card.
- Place the Micro SD card in the Raspberry Pi and switch on the device.
- Wait 5 minutes for the device to start up and connect to the network.
- You can now connect to the Raspberry Pi and login.
You can connect to the Raspberry Pi with SSH via WiFi or an physical Ethernet connection. If you are on the same network you can access the device using the SSID you gave it when setting up the device. If you intend to access the device remotely via the internet you will need to assign the device a static private IP address and fixed public address. That goes beyond the scope of this guide.
- Open PUTTY on your computer (Windows).
- Set the 'Connection type' to 'SSH'.
- Set the 'Port' value to '22'.
- Enter the hostname for your Raspberry Pi device. If your computer is on the same local network as the device you can use the device name or SSID chosen in Raspberry Pi Imager. Otherwise you should use the numberic IP address.
- Select 'Connection' > 'SSH' > 'Auth' in the Category list on the left of the PUTTYgen UI.
- Click 'Browse', navigate to the location where you stored the private key from PUTTYgen, and select the private key (.ppk file) for authentication.
- Click the 'Open' button to start the connection.
- If the PUTTY Security Alert popup appears click 'Accept'.
- Enter 'pi' as the login.
- Enter the passphrase you chose when generating the private key in PUTTYgen.
- You are now remotely logged into the Raspberry Pi.
- You can check the device's private IP address by typing
ipconfig
. The 'inet' numbers listed against 'wlan0' and/or 'eth0' interfaces are the IP addresses for the first available wifi and ethernet connections for the device.
- Login to the Raspberry Pi over SSH.
- Install pip package manager:
sudo apt-get install python-pip
. - Install Pyserial:
pip install pyserial
. - Install Pygame:
pip install pygame
.
- Download WinSCP (Windows): https://winscp.net/
- Open the application
- Set the 'File Protocol' to 'SFTP'.
- Enter the hostname for your Raspberry Pi device (SSID or IP address).
- Set 'Port Number' as '22'.
- Click 'Advanced' button.
- Select 'SSH' > 'Autentication'.
- Click on the breadcrumbs '...' next to the text box 'Private key file' and navigate to the location where you stored the private key from PUTTYgen. Select the private key (.ppk file) for authentication.
- Click 'Ok'.
- Click 'Login'.
- Enter username 'pi' followed by the passphrase associated with the private key (same as with SSH login via PUTTY above).
- You now have remote access to the file system on the Raspberry Pi. Files can be dragged and dropped onto the device.
- Copy the files from this repos RaspberryPi folder onto the device.
- Download OpenMV IDE (Windows/Mac/Linux): https://openmv.io/pages/download
- Install the OpenMV IDE on you system: https://docs.openmv.io/openmvcam/tutorial/software_setup.html#
- Setup the OpenMV hardware: https://docs.openmv.io/openmvcam/tutorial/hardware_setup.html
- Connect the IDE to the camera: https://docs.openmv.io/openmvcam/tutorial/openmvide_overview.html#connecting-to-your-openmv-cam
- Open the script
rpc_remote.py
in the OpenMV IDE. - Copy the script to the camera device as
main.py
by clicking the following: 'Tools' > 'Save open script to OpenMV Cam (as main.py)'. Alternatively you can manually rename the file and copy it onto the device flash drive.
- As you cannot use USB VCP while the OpenMV IDE device is connected, debugging issues on the remote device can be difficult.
- Iteration can be hindered by the device going into 'panic' mode when reconnecting the IDE to deploy code updates. Doing so requires the developer to go through the device unbricking process (see Troubleshooting below).
- Start the OpenMVIDE.
- Press connect when the camera is not attached.
- Follow the onscreen prompts. When the popup says 'Do you have an OpenMV Cam connected and is it bricked?' click 'Yes'. Ensure to select the correct camera model when prompted. If you have your data backed up you can erase the devices file system.
- Connect or disconnect and reconnect the device when prompted.
- The OpenMV IDE will now clear the camera's flash memory and load the lastest firmware version available.
- The device is now ready for use.