Skip to content

Latest commit

 

History

History
215 lines (156 loc) · 8.38 KB

README.md

File metadata and controls

215 lines (156 loc) · 8.38 KB

Rpi 4 Smart Mirror AI setup scripts

Scripts for automating Raspberry Pi 4 configuration and MagicMirror² setup on Rpi for creating Smart Mirror touchscreen with face recognition.

I created these scripts since it took me quite a lot of effort to find a relevant documentation of what needs to be setup for complete solution. This is of course spread over many places on the web and includes many manual steps which is time-consuming and error prone. Since I like to keep my infrastructure and software configuration as a code in version control system I ended up with this repo.

This makes also re-installation much easier when you need to start from the scratch and hopefully makes it easier for getting started for new peeps.

This solution is based on fantastic and inspiring work from Eben Kouao which you can read more about at Smart Mirror Touchscreen (with FaceID) Tutorial – Raspberry Pi 4

Software features

  • Touchscreen interaction (requires hardware, see below)
  • Face recognition (requires hardware, see below) with personalised content
  • Integration with home automation system Home Assistant, read more at ha_scripts

What is automated

  • MagicMirror² installation
  • MagicMirror² module MMM-Face-Multi-User-Recognition-SMAI (forked) installation for multi-user face recognition and personalised content
  • MagicMirror² module MMM-Face-Reco-DNN installation with required libs for face recognition with Open CV and Deep Neural Network
  • MagicMirror² module MMM-SmartTouch installation for controlling MagicMirror² using a touchscreen
  • MagicMirror² module MMM-Spotify installation for controlling Spotify (requires manual configuration after setup)
  • MagicMirror² module MMM-GoogleTrafficTimes installation for displaying traffic time between locations (requires manual configuration after setup)
  • PM2 installation for auto starting MagicMirror² on boot
  • Rpi configuration
    • Disable Screen Blanking to avoid screen going black when no interaction
    • Setup WiFi (SSID and password)
    • Enable Rpi Camera Module
    • Enable SSH for easier management of Rpi from other machines
    • Set timezone (default to Europe/Oslo)
    • Set OS locale (default to Norwegian Bokmål)
    • Set Keyboard layout (default to Norwegian)
    • Disable boot splash screen at boot
    • Set boot to Desktop and auto login pi-user
  • Create bash aliases to make CLI commands easier in Rpi
  • Install vim and xclip packages

Hardware requirements

I have only tested with following hardware, but it might work with your spec as well.

Preconditions

  • Fresh installation of Raspberry Pi OS with Desktop (Buster or Bullseye) installed (tip: use Raspberry Pi Imager)
  • You are logged in as default user pi in Rpi
  • Raspberry Pi Camera Module v2 connected
  • Your Rpi is connected to the internet, either through WiFi or wired
  • OpenWeather API key in order to use the default modules weather

Installation

Open Terminal in Rpi and execute these commands (might take a couple of minutes, be patient)

git clone https://github.com/ismarslomic/rpi4-smai-setup.git /home/pi/rpi4-smai-setup

cd /home/pi/rpi4-smai-setup

./setup.sh

The setup.sh script is suitable for initial setup on fresh Raspberry Pi OS and makes sure to run all necessary scripts (in sub-folders).

If you later want to do the adjustments you should avoid doing those directly in MagicMirror folder or in general on Rpi OS, but rather adjust existing scripts or add new one to make sure that all setup is automated and version controlled.

Learning Rpi to recognise your face correctly

If you are new to face recognition (I was at least) I recommend that you spend some time learning about it from these two tutorials: Face recognition with OpenCV, Python, and deep learning and Raspberry Pi Face Recognition

Controlling MagicMirror² via PM2

With your MagicMirror running via PM2, you have some handy tools at hand:

Restarting your MagicMirror²

pm2 restart mm

Reloading your app

pm2 reload mm

Stopping your MagicMirror²

pm2 stop mm

Show the MagicMirror² logs

pm2 logs mm

Monitor all processes

pm2 monit

Connect to your Rpi from other machine

Find IP address of Rpi

hostname -I

You can also just use the Rpi hostname raspberrypi.local.

Connect through ssh

ssh pi@<IP address>

Known issues and FAQ

  1. During running setup.sh I see errors such as perl: warning: Setting locale failed. and locale: Cannot set XX to default locale: No such file or directory. This will be fixed after reboot, don't worry!
  2. I don't see current and forecast weather modules in Magic Mirror. Check your OpenWeather API key in /home/pi/MagicMirror/config/config.js file
  3. MagicMirror doesn't automatically start after reboot. Open terminal, execute command /home/pi/rpi4-smai-setup/pm2/pm2.sh and reboot

Get the latest updated

Upgrade Rpi OS

sudo apt-get update
sudo apt-get upgrade -y

Upgrade MagicMirror

To get latest version of MagicMirror you should follow the Upgrade Guide and also read the Changelog.

cd ~/MagicMirror
git pull && npm install

Upgrade MagicMirror modules

For each module found in folder ~/MagicMirror/modules do following:

cd ~/MagicMirror/modules/<module name>
git pull && npm install

Change the screen orientation

The simplest way to change screen orientation is to use the Desktop:

Pi icon => Preferences => Screen configuration => Orientation => normal/right/inverted/left => Save

Change the IR Frame orientation

# Create new udev rule file to configure libinput
sudo vim /etc/udev/rules.d/99-touchscreen-calibration.rules

# Add following content to the file to rotate 180 degree clockwise
# See https://wayland.freedesktop.org/libinput/doc/1.11.3/udev_config.html
ACTION=="add|change", SUBSYSTEM=="input", ATTRS{name}=="Multi touch   Multi touch overlay device", ENV{LIBINPUT_CALIBRATION_MATRIX}="-1 0 1 0 -1 1"

Confirm changes with use of sudo libinput list-devices

Reboot Rpi for changes to take effect.