Innehållsförteckning:
2025 Författare: John Day | [email protected]. Senast ändrad: 2025-01-13 06:58
Ansiktsigenkänning blir mer och mer allmänt använd, vi kan använda det för att skapa ett smart lås.
Steg 1: Saker som används i detta projekt
Hårdvarukomponenter
- Raspberry Pi 3 Modell B
- Raspberry Pi kameramodul V2
- Grove - stafett
- LTE Cat 1 Pi HAT (Europa)
- 10,1 tum 1200x1980 HDMI IPS LCD -skärm
Programvaruappar och onlinetjänster
- WinSCP
- Anteckningsblock ++
Steg 2: Maskinvaruanslutning
I detta projekt planerar vi att ta bilder med picamera och känna igen ansikten i dem och sedan visa igenkänningsresultat på skärmen. Om ansikten är kända, öppna dörren och skicka vem som öppnade dörren till ett specifikt telefonnummer via SMS.
Så du måste ansluta en kamera till Raspberry Pi: s kameragränssnitt och installera antenn och Grove - Relä till LTE Pi -hatt och anslut sedan HAT till din Pi. Skärmen kan anslutas till Raspberry Pi via en HDMI -kabel, glöm inte att ansluta ström till din skärm och Pi.
Steg 3: Programvaruprogrammering
Ansiktsigenkänning
Tack för Adam Geitgey och hans ansiktsigenkänningsprojekt, vi kan använda världens enklaste ansiktsigenkänningsbibliotek på Raspberry Pi. Följande steg visar hur du konfigurerar ansiktsigenkänning på Pi.
Steg 1. Använd raspi-config för att konfigurera kamera och GPU-minne.
sudo raspi-config
Välja gränssnittsalternativ - kamera för att aktivera picamera, sedan välja Avancerade alternativ - Memory Split för att ställa in GPU -minne, det bör ändras till 64. Efter avslutad starta om din Raspberry Pi.
Steg 2. Installera nödvändiga bibliotek.
sudo apt-get uppdatering
sudo apt-get upgrade sudo apt-get install build-essential / cmake / gfortran / git / wget / curl / graphicsmagick / libgraphicsmagick1-dev / libatlas-dev / libavcodec-dev / libavformat-dev / libboost-all-dev / libgtk2. 0-dev / libjpeg-dev / liblapack-dev / libswscale-dev / pkg-config / python3-dev / python3-numpy / python3-picamera / python3-pip / zip sudo apt-get clean
Steg 3. Gör picamerea stöder array.
sudo pip3 installera -uppgradera picamera [array]
Steg 4. Installera dlib och ansiktsigenkänning.
sudo pip3 installera dlib
sudo pip3 installera face_recognition
Steg 5. Ladda ner och kör ansiktsigenkänningsexempel
git clone --single-branch
cd./face_recognition/examples python3 facerec_on_raspberry_pi.py
ANMÄRKNING: Om du fick ImportError: libatlas.so.3: kan inte öppna delad objektfil: Ingen sådan fil eller katalog, kör följande kommando för att fixa det.
Relä
När ansiktsigenkänning är klar kan vi fortsätta att lägga till ytterligare funktioner. Vi kopplade Grove - Relay till LTE Cat 1 Pi HAT, men den använder digital port istället för I2C -port.
Detta är pin-out för Raspberry Pi 3B, vi kan se SDA-stift och SCL-stift som finns i kortets stift 3 och stift 5.
Så vi kan styra reläet genom att mata ut digital signal till pin 5. Kör ned pythonprogrammet på din Raspberry Pi, om inget går fel hör du en Ti-Ta från relä.
importera RPi. GPIO som GPIO
RELAY_PIN = 5 GPIO.setmode (GPIO. BOARD) GPIO.setup (RELAY_PIN, GPIO. OUT) GPIO.output (RELAY_PIN, GPIO. HIGH)
Så här är tanken, vi laddar kända ansikten från en mapp, känner igen ansikten som fångas av picamera, om ansiktet i mappen, styrrelä för att låsa upp dörren. Vi kan paketera dem till en klass, här är metoden load_known_faces () och upplåsning (), det färdiga programmet kan laddas ner i slutet av denna artikel.
def load_known_faces (self):
known_faces = os.listdir (self._ known_faces_path) för known_face in known_faces: self._ known_faces_name.append (known_face [0: len (known_face) - len ('. jpg')]) known_face_image = face_recognition.load_image_file (self._ known_faces_pface) self._ known_faces_encoding.append (face_recognition.face_encodings (known_face_image) [0]) return len (self._ known_faces_encoding) def unlock (self): if self._ matched.count (True)> 0: GPIO.output (self._ relay_pin, GPIO. HIGH) print ('Dörr öppnad') time.sleep (5) GPIO.output (self._ relay_pin, GPIO. LOW) self._ reset_recognise_params () return True true._ retry_count += 1 print ('Försök igen … { } '. format (self._ retry_count)) return False
Tänk transcendentalt, vi kan visa bilden vem som kände igen, bibliotek PIL och matplotlib kan vara till hjälp, bland dem måste matplotlib installeras manuellt, kör det här kommandot i din Raspberry Pi -terminal.
sudo pip3 installera matplotlib
Importera dem i din kod och ändra om blockera i unlock () -metoden så här:
img = Image.open ('{}/{}. jpg'.format (self._ known_faces_path, self._ known_faces_name [0]))
plt.imshow (img) plt.ion () GPIO.output (self._ relay_pin, GPIO. HIGH) print ('Door closed') plt.pause (3) plt.close () GPIO.output (self._ relay_pin, GPIO. LOW) self._ reset_recognise_params () return True
Om ett ansikte känns igen kommer bilden i mappen att visas på skärmen.
SMS
Ibland vill vi veta vem som är i vårt rum, och nu finns det en plats för LTE Cat 1 Pi HAT. Anslut ett SIM -kort till det och följ stegen för att testa om det fungerar eller inte.
Steg 1. Aktivera UART0 i Raspberry Pi
Använd nano för att redigera config.txt i /boot
sudo nano /boot/config.txt
lägg till dtoverlay = pi3-disable-bt till botten av det och inaktivera hciuart-tjänsten
sudo systemctl inaktivera hciuart
radera sedan console = serial0, 115200 i cmdline.txt in /boot
sudo nano /boot/cmdline.txt
När allt är gjort bör du starta om din Raspberry Pi.
Steg 2. Ladda ner exemplet och kör det.
Öppna en terminal på din Raspberry Pi, skriv dessa kommandon till den rad för rad.
cd ~
git klon https://github.com/Seeed-Studio/ublox_lara_r2_pi_hat.git cd ublox_lara_r2_pi_hat sudo python setup.py installera cd test sudo python test01.py
Om du ser dessa utgångar i din terminal fungerar LTE Cat 1 Pi HAT bra.
40-stifts GPIO-rubrik upptäckt
Aktivera CTS0 och RTS0 på GPIO 16 och 17 rt cts vid väckning … modulnamn: LARA-R211 RSSI: 3
Nu visste vi att HAT fungerar bra, hur man använder den för att skicka SMS? Det första du behöver veta är att Raspberry Pi kommunicerar med HAT via skicka AT -kommandon från UART. Du kan skicka AT -kommandon till LTE HAT genom att köra den här koden i python
från ublox_lara_r2 import *
u = Ublox_lara_r2 () u.initialize () u.reset_power () # Stäng felsökningsmassage u.debug = Falskt u.sendAT ('')
AT -kommandot för att skicka SMS är följande
AT+CMGF = 1
AT+CMGS =
så här är _send_sms () -metoden:
def _send_sms (själv):
if self._ phonenum == None: return False för unlocker i self._ igenkänna_face_namn (): if self._ ublox.sendAT ('AT+CMGF = 1 / r / n'): print (self._ ublox.response) if self. _ublox.sendAT ('AT+CMGS = "{}" / r / n'.format (self._ phonenum)): print (self._ ublox.response) if self._ ublox.sendAT (' {} gå in i rummet. / x1a'.format (upplåsning)): print (self._ ublox.response)
ANMÄRKNING: LTE Cat 1 Pi HAT: s bibliotek skrivet av python2, som inte är särskilt kompatibelt med python3, om du vill använda det med ansiktsigenkänning, ladda ner det från länken från slutet av denna artikel.