.. note::
Ciao, benvenuto nella SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts Community su Facebook! Approfondisci Raspberry Pi, Arduino ed ESP32 insieme ad altri appassionati.
**Perché unirti a noi?**
- **Supporto esperto**: Risolvi i problemi post-vendita e le sfide tecniche grazie all'aiuto della nostra comunità e del nostro team.
- **Impara e condividi**: Scambia suggerimenti e tutorial per migliorare le tue competenze.
- **Anteprime esclusive**: Ottieni l'accesso anticipato agli annunci dei nuovi prodotti e anteprime esclusive.
- **Sconti speciali**: Approfitta di sconti esclusivi sui nostri prodotti più recenti.
- **Promozioni festive e omaggi**: Partecipa a omaggi e promozioni festive.
👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi!
.. _py_pi5_alarm:
3.1.3 Allarme Retromarcia
======================================
Introduzione
----------------
In questo progetto, utilizzeremo un display LCD, un buzzer e sensori a
ultrasuoni per creare un sistema di assistenza alla retromarcia. Puoi
installarlo su un veicolo telecomandato per simulare il processo di
retromarcia in un garage.
Componenti necessari
------------------------------
Per questo progetto, abbiamo bisogno dei seguenti componenti.
.. image:: ../python_pi5/img/4.1.9_reversing_alarm_list.png
:width: 800
:align: center
.. È sicuramente conveniente acquistare un kit completo, ecco il link:
.. .. list-table::
.. :widths: 20 20 20
.. :header-rows: 1
.. * - Nome
.. - COMPONENTI IN QUESTO KIT
.. - LINK
.. * - Kit Raphael
.. - 337
.. - |link_Raphael_kit|
.. Puoi anche acquistarli separatamente dai link qui sotto.
.. .. list-table::
.. :widths: 30 20
.. :header-rows: 1
.. * - INTRODUZIONE COMPONENTE
.. - LINK ACQUISTO
.. * - :ref:`gpio_extension_board`
.. - |link_gpio_board_buy|
.. * - :ref:`breadboard`
.. - |link_breadboard_buy|
.. * - :ref:`wires`
.. - |link_wires_buy|
.. * - :ref:`resistor`
.. - |link_resistor_buy|
.. * - :ref:`buzzer`
.. - \-
.. * - :ref:`transistor`
.. - |link_transistor_buy|
.. * - :ref:`ultrasonic_sensor`
.. - |link_ultrasonic_buy|
.. * - :ref:`i2c_lcd1602`
.. - |link_i2clcd1602_buy|
Schema elettrico
--------------------
Il sensore a ultrasuoni rileva la distanza tra sé e l'ostacolo, visualizzando
il risultato sul display LCD in forma numerica. Allo stesso tempo, il sensore
ultrasuoni attiva il buzzer, emettendo suoni di allerta con frequenze differenti
a seconda della distanza rilevata.
============ ======== ======== ===
T-Board Name physical wiringPi BCM
GPIO23 Pin 16 4 23
GPIO24 Pin 18 5 24
GPIO17 Pin 11 0 17
SDA1 Pin 3
SCL1 Pin 5
============ ======== ======== ===
.. image:: ../python_pi5/img/4.1.9_reversing_alarm_schematic.png
:align: center
Procedura sperimentale
------------------------
**Passo 1:** Costruisci il circuito.
.. image:: ../python_pi5/img/4.1.9_reversing_alarm_circuit.png
:align: center
**Passo 2:** Cambia la directory.
.. raw:: html
.. code-block::
cd ~/davinci-kit-for-raspberry-pi/python-pi5
**Passo 3:** Esegui il programma.
.. raw:: html
.. code-block::
sudo python3 3.1.3_ReversingAlarm.py
Durante l'esecuzione del codice, il modulo del sensore a ultrasuoni rileva
la distanza dall'ostacolo e visualizza le informazioni relative alla distanza
su LCD1602; inoltre, il buzzer emette un segnale di avviso la cui frequenza
varia con la distanza.
.. note::
* Se ricevi l'errore ``FileNotFoundError: [Errno 2] No such file or directory: '/dev/i2c-1'``, fai riferimento a :ref:`i2c_config` per abilitare I2C.
* Se compare l'errore ``ModuleNotFoundError: No module named 'smbus2'``, esegui ``sudo apt install python3-smbus2``.
* Se ricevi l'errore ``OSError: [Errno 121] Remote I/O error``, significa che il modulo è cablato male o danneggiato.
* Se il codice e il cablaggio sono corretti, ma il display LCD non mostra contenuti, prova a regolare il contrasto girando il potenziometro sul retro.
.. warning::
Se appare l'errore ``RuntimeError: Cannot determine SOC peripheral base address``, fai riferimento a :ref:`faq_soc`
**Codice**
.. note::
Puoi **Modificare/Reimpostare/Copiare/Eseguire/Arrestare** il codice qui sotto. Prima di farlo, assicurati di essere nella directory del codice sorgente come ``davinci-kit-for-raspberry-pi/python-pi5``. Dopo aver modificato il codice, potrai eseguirlo direttamente per vedere l'effetto.
.. raw:: html
.. code-block:: python
#!/usr/bin/env python3
import LCD1602
import time
from gpiozero import DistanceSensor, Buzzer
# Inizializza il sensore a ultrasuoni con i pin GPIO
sensor = DistanceSensor(echo=24, trigger=23) # Pin Echo è GPIO 24, Pin Trigger è GPIO 23
# Inizializza il buzzer collegato al pin GPIO 17
buzzer = Buzzer(17)
def lcdsetup():
# Inizializza il display LCD con l'indirizzo I2C e attiva la retroilluminazione
LCD1602.init(0x27, 1) # 0x27 è l'indirizzo I2C dell'LCD
LCD1602.clear() # Cancella il display LCD
# Visualizza i messaggi di avvio sul display LCD
LCD1602.write(0, 0, 'Ultrasonic Starting')
LCD1602.write(1, 1, 'By SunFounder')
time.sleep(2) # Attesa di 2 secondi
def distance():
# Calcola e restituisce la distanza misurata dal sensore
dis = sensor.distance * 100 # Converte la distanza in centimetri
print('Distance: {:.2f} cm'.format(dis)) # Stampa la distanza con due cifre decimali
time.sleep(0.3) # Attesa di 0,3 secondi prima della prossima misurazione
return dis
def loop():
# Misura continuamente la distanza e aggiorna LCD e buzzer
while True:
dis = distance() # Ottiene la distanza corrente
# Visualizza la distanza e gestisce gli avvisi in base alla distanza
if dis > 400: # Verifica se la distanza è fuori portata
LCD1602.clear()
LCD1602.write(0, 0, 'Error')
LCD1602.write(3, 1, 'Out of range')
time.sleep(0.5)
else:
# Visualizza la distanza corrente sul display LCD
LCD1602.clear()
LCD1602.write(0, 0, 'Distance is')
LCD1602.write(5, 1, str(round(dis, 2)) + ' cm')
# Regola la frequenza del buzzer in base alla distanza
if dis >= 50:
time.sleep(0.5)
elif 20 < dis < 50:
# Distanza media: frequenza media del buzzer
for _ in range(2):
buzzer.on()
time.sleep(0.05)
buzzer.off()
time.sleep(0.2)
elif dis <= 20:
# Distanza ravvicinata: frequenza alta del buzzer
for _ in range(5):
buzzer.on()
time.sleep(0.05)
buzzer.off()
time.sleep(0.05)
try:
lcdsetup() # Configura il display LCD
loop() # Avvia il ciclo di misurazione
except KeyboardInterrupt:
# Spegne il buzzer e cancella l'LCD all'interruzione dell'utente (es. Ctrl+C)
buzzer.off()
LCD1602.clear()
**Spiegazione del Codice**
#. Questo script utilizza diverse librerie per le sue funzionalità. La libreria ``LCD1602`` gestisce il display LCD, mentre ``time`` fornisce funzioni legate alla temporizzazione. La libreria ``gpiozero`` è essenziale per le interazioni con i pin GPIO del Raspberry Pi, in particolare per operare il sensore di distanza e il buzzer.
.. code-block:: python
#!/usr/bin/env python3
import LCD1602
import time
from gpiozero import DistanceSensor, Buzzer
#. Il sensore a ultrasuoni è configurato con i suoi pin echo e trigger collegati ai pin GPIO 24 e 23, rispettivamente. Inoltre, un buzzer è collegato al pin GPIO 17.
.. code-block:: python
# Inizializza il sensore a ultrasuoni con i pin GPIO
sensor = DistanceSensor(echo=24, trigger=23) # Pin Echo è GPIO 24, Pin Trigger è GPIO 23
# Inizializza il buzzer collegato al pin GPIO 17
buzzer = Buzzer(17)
#. L'inizializzazione del display LCD prevede la pulizia del display e la visualizzazione di un messaggio di avvio.
.. code-block:: python
def lcdsetup():
# Inizializza il display LCD con l'indirizzo I2C e attiva la retroilluminazione
LCD1602.init(0x27, 1) # 0x27 è l'indirizzo I2C dell'LCD
LCD1602.clear() # Cancella il display LCD
# Visualizza i messaggi di avvio sul display LCD
LCD1602.write(0, 0, 'Ultrasonic Starting')
LCD1602.write(1, 1, 'By SunFounder')
time.sleep(2) # Attesa di 2 secondi
#. La funzione ``distance`` calcola la distanza misurata dal sensore a ultrasuoni, la visualizza e restituisce il valore in centimetri.
.. code-block:: python
def distance():
# Calcola e restituisce la distanza misurata dal sensore
dis = sensor.distance * 100 # Converte la distanza in centimetri
print('Distance: {:.2f} cm'.format(dis)) # Stampa la distanza con due cifre decimali
time.sleep(0.3) # Attesa di 0,3 secondi prima della prossima misurazione
return dis
#. Il ciclo principale misura continuamente la distanza, aggiornando sia l'LCD che il buzzer. Gestisce diversi intervalli di distanza con azioni specifiche, come la visualizzazione di messaggi di errore o la variazione della frequenza del buzzer in base alla distanza misurata.
.. code-block:: python
def loop():
# Misura continuamente la distanza e aggiorna LCD e buzzer
while True:
dis = distance() # Ottiene la distanza corrente
# Visualizza la distanza e gestisce gli avvisi in base alla distanza
if dis > 400: # Verifica se la distanza è fuori portata
LCD1602.clear()
LCD1602.write(0, 0, 'Error')
LCD1602.write(3, 1, 'Out of range')
time.sleep(0.5)
else:
# Visualizza la distanza corrente sul display LCD
LCD1602.clear()
LCD1602.write(0, 0, 'Distance is')
LCD1602.write(5, 1, str(round(dis, 2)) + ' cm')
# Regola la frequenza del buzzer in base alla distanza
if dis >= 50:
time.sleep(0.5)
elif 20 < dis < 50:
# Distanza media: frequenza media del buzzer
for _ in range(2):
buzzer.on()
time.sleep(0.05)
buzzer.off()
time.sleep(0.2)
elif dis <= 20:
# Distanza ravvicinata: frequenza alta del buzzer
for _ in range(5):
buzzer.on()
time.sleep(0.05)
buzzer.off()
time.sleep(0.05)
#. Al momento dell'esecuzione, lo script configura l'LCD e avvia il ciclo principale. Può essere interrotto con un comando da tastiera (Ctrl+C), che spegne il buzzer e cancella l'LCD.
.. code-block:: python
try:
lcdsetup() # Configura il display LCD
loop() # Avvia il ciclo di misurazione
except KeyboardInterrupt:
# Spegne il buzzer e cancella l'LCD all'interruzione dell'utente (es. Ctrl+C)
buzzer.off()
LCD1602.clear()