INHOUDSOPGAWE:
2025 Outeur: John Day | [email protected]. Laas verander: 2025-01-13 06:56
Gesigsherkenning word meer en meer algemeen gebruik; ons kan dit gebruik om 'n slim slot te maak.
Stap 1: Dinge wat in hierdie projek gebruik word
Hardeware komponente
- Framboos Pi 3 Model B
- Framboos Pi -kameramodule V2
- Grove - aflos
- LTE Cat 1 Pi HAT (Europa)
- 10,1 duim 1200x1980 HDMI IPS LCD -skerm
Sagteware -programme en aanlyndienste
- WinSCP
- Notepad ++
Stap 2: Hardewareverbinding
In hierdie projek is ons van plan om met Picamera foto's te neem en gesigte daarin te herken, en dan 'n herkenningsresultaat op die skerm weer te gee. As die gesigte bekend is, maak die deur oop en stuur wie die deur oopgemaak het na die gespesifiseerde telefoonnommer per SMS.
U moet dus 'n kamera aan die kamera -koppelvlak van Raspberry Pi koppel, antenna en Grove installeer - Relay na LTE Pi -hoed, en koppel dan HAT aan op u Pi. Die skerm kan via 'n HDMI -kabel aan die Raspberry Pi gekoppel word; moenie vergeet om die krag aan u skerm en Pi te koppel nie.
Stap 3: sagteware programmering
Gesigsherkenning
Dankie vir Adam Geitgey en sy gesigsherkenningsprojek, ons kan die eenvoudigste biblioteek vir gesigsherkenning ter wêreld op Raspberry Pi gebruik. Die volgende stappe sal u wys hoe u gesigsherkenning op Pi kan instel.
Stap 1. Gebruik raspi-config om kamera- en GPU-geheue op te stel.
sudo raspi-config
As u koppelvlakopsies kies - kamera om die picamera in staat te stel, kies dan Advanced Options - Memory Split om GPU -geheue in te stel, moet dit verander word na 64. Herlaai u Raspberry Pi nadat u klaar is.
Stap 2. Installeer vereiste biblioteke.
sudo apt-get update
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
Stap 3. Maak picamerea ondersteun skikking.
sudo pip3 installeer -upgrade picamera [skikking]
Stap 4. Installeer dlib en gesigherkenning.
sudo pip3 installeer dlib
sudo pip3 installeer face_recognition
Stap 5. Laai en voer voorbeeld van gesigsherkenning af
git-kloon-enkele tak
cd./face_recognition/exempels python3 facerec_on_raspberry_pi.py
KENNISGEWING: As u ImportError: libatlas.so.3 gekry het: kan die gedeelde voorwerplêer nie oopgemaak word nie: daar is nie so 'n lêer of gids nie, voer die volgende opdrag uit om dit reg te stel.
Relay
As gesigsherkenning gereed is, kan ons voortgaan om ekstra funksies by te voeg. Ons het Grove - Relay gekoppel aan LTE Cat 1 Pi HAT, maar dit gebruik eerder digitale poort as I2C -poort.
Dit is pin-out vir Raspberry Pi 3B; ons kan die SDA-pen en SCL-pen in die pen 3 en pen 5 van die bord sien.
Sodat ons die relais kan beheer deur die digitale sein na pin 5 te stuur. Begin die luislangprogram op u Raspberry Pi, as niks verkeerd loop nie, hoor u 'n Ti-Ta van die relais.
voer RPi. GPIO in as GPIO
RELAY_PIN = 5 GPIO.setmode (GPIO. BOARD) GPIO.setup (RELAY_PIN, GPIO. OUT) GPIO.output (RELAY_PIN, GPIO. HIGH)
So hier is die idee: ons laai bekende gesigte uit 'n vouer, herken gesigte wat deur fotokamera vasgevang is, as die gesig in die vouer, bedieningsrelais die deur oopmaak. Ons kan dit in 'n klas verpak, hier is die load_known_faces () metode en die unlock () metode, die voltooide program kan aan die einde van hierdie artikel afgelaai word.
def load_known_faces (self):
known_faces = os.listdir (self._ known_faces_path) vir 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_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 ('Deur oopgemaak') time.sleep (5) GPIO.output (self._ relay_pin, GPIO. LOW) self._ reset_recognise_params () return True self._ retry_count += 1 print ('Probeer asseblief weer … { } '. formaat (self._ retry_count)) terugkeer Onwaar
Dink transendentaal, ons kan die prentjie wys wie die biblioteke PIL en matplotlib kan help, onder andere moet matplotlib handmatig geïnstalleer word, voer hierdie opdrag uit in die terminale van u Raspberry Pi.
sudo pip3 installeer matplotlib
Voer dit in u kode in, en verander as u die ontsluitingsmetode () blokkeer soos volg:
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 ('Deur oopgemaak') plt.pause (3) plt.close () GPIO.output (self._ relay_pin, GPIO. LOW) self._ reset_recognise_params () return True
As 'n gesig herken word, word die prentjie in die gids op die skerm vertoon.
SMS
Soms wil ons weet wie in ons kamer is, en nou is daar 'n plek vir LTE Cat 1 Pi HAT. Koppel 'n SIM -kaart daaraan en volg die stappe om te toets of dit werk of nie.
Stap 1. Aktiveer UART0 in Raspberry Pi
Gebruik nano om config.txt in /boot te wysig
sudo nano /boot/config.txt
voeg dtoverlay = pi3-disable-bt onderaan, en skakel hciuart-diens uit
sudo systemctl skakel hciuart uit
verwyder dan console = serial0, 115200 in cmdline.txt in /boot
sudo nano /boot/cmdline.txt
Nadat alles gedoen is, moet u u Raspberry Pi herlaai.
Stap 2. Laai voorbeeld af en voer dit uit.
Maak 'n terminale op u Raspberry Pi oop, tik hierdie opdrag hier reël vir reël.
cd ~
git kloon https://github.com/Seeed-Studio/ublox_lara_r2_pi_hat.git cd ublox_lara_r2_pi_hat sudo python setup.py installeer cd toets sudo python test01.py
As u hierdie uitsette in u terminale sien, werk die LTE Cat 1 Pi HAT goed.
'N 40-pins GPIO-opskrif is opgespoor
Aktiveer CTS0 en RTS0 op GPIO's 16 en 17 rts cts by wakker word … module naam: LARA-R211 RSSI: 3
Nou het ons geweet dat die HAT goed werk, hoe om dit te gebruik om SMS te stuur? Die eerste ding wat u moet weet, is dat die Raspberry Pi met die HAT kommunikeer via stuur AT -opdragte deur UART. U kan AT -opdragte na LTE HAT stuur deur hierdie kode in python uit te voer
vanaf ublox_lara_r2 invoer *
u = Ublox_lara_r2 () u.initialiseer () u.reset_power () # Sluit ontfoutingsmassage u.debug = Onwaar u.sendAT ('')
Die AT -opdrag vir die stuur van SMS is soos volg
AT+CMGF = 1
AT+CMGS =
so hier is _send_sms () metode:
def _send_sms (self):
if self._ phonenum == None: return Onwaar vir unlocker in self._ herken_face_name (): as self._ ublox.sendAT ('AT+CMGF = 1 / r / n'): druk (self._ ublox.response) as self. _ublox.sendAT ('AT+CMGS = "{}" / r / n'.format (self._ phonenum)): druk (self._ ublox.response) as self._ ublox.sendAT (' {} die kamer betree. / x1a'.format (ontgrendelaar)): druk (self._ ublox.response)
KENNISGEWING: Die biblioteek van die LTE Cat 1 Pi HAT, geskryf deur python2, wat nie baie versoenbaar is met python3 nie, as u dit met gesigherkenning wil gebruik, laai dit dan van die skakel af aan die einde van hierdie artikel.