Nota

Ciao e benvenuto nella Community di Appassionati di SunFounder per Raspberry Pi, Arduino ed ESP32 su Facebook! Esplora a fondo il mondo di Raspberry Pi, Arduino ed ESP32 insieme a tanti altri appassionati.

Perché Unirsi?

  • Supporto da Esperti: Risolvi problemi post-vendita e sfide tecniche con l’aiuto della nostra community e del nostro team.

  • Impara e Condividi: Scambia consigli e tutorial per migliorare le tue competenze.

  • Anteprime Esclusive: Ottieni accesso anticipato agli annunci dei nuovi prodotti e a contenuti inediti.

  • Sconti Speciali: Approfitta di sconti esclusivi sui nostri prodotti più recenti.

  • Promozioni Festive e Giveaway: Partecipa a concorsi e promozioni festive.

👉 Pronto a esplorare e creare con noi? Clicca su [Qui] e unisciti oggi stesso!

1.3.1 Motore

Introduzione

In questo progetto impareremo a utilizzare L293D per pilotare un motore DC e farlo ruotare in senso orario e antiorario. Poiché il motore DC richiede una corrente maggiore, per motivi di sicurezza utilizziamo il modulo di alimentazione per alimentare i motori.

Componenti Necessari

In questo progetto, abbiamo bisogno dei seguenti componenti.

../_images/1.3.1_motor_list.png

Schema Elettrico

../_images/1.3.1_motor_schematic.png

Procedure Sperimentali

Passo 1: Costruisci il circuito.

../_images/1.3.1_motor_circuit.png

Nota

Il modulo di alimentazione può essere collegato a una batteria da 9V utilizzando il connettore per batteria incluso nel kit. Inserisci il cappuccio del jumper del modulo di alimentazione nelle strisce bus da 5V della breadboard.

../_images/1.3.1_motor_battery.jpeg

Passo 2: Entra nella cartella del codice.

cd ~/davinci-kit-for-raspberry-pi/python-pi5

Passo 3: Esegui.

sudo python3 1.3.1_Motor.py

Quando il codice viene eseguito, il motore ruota prima in senso orario per 5 secondi, quindi si ferma per 5 secondi, dopodiché ruota in senso antiorario per 5 secondi e si ferma successivamente per altri 5 secondi. Questa serie di azioni verrà ripetuta continuamente.

Avvertimento

Se compare l’errore RuntimeError: Cannot determine SOC peripheral base address, consulta Se gpiozero non funziona.

Codice

Nota

Puoi Modificare/Reimpostare/Copiare/Eseguire/Interrompere il codice qui sotto. Prima di farlo, però, vai al percorso del codice sorgente, come davinci-kit-for-raspberry-pi/python-pi5. Dopo aver modificato il codice, potrai eseguirlo direttamente per vedere il risultato.

#!/usr/bin/env python3
from gpiozero import Motor
from time import sleep

# Inizializza il motore con GPIO Zero, specificando i pin GPIO per avanzamento (17), retro (27) e abilitazione (22)
motor = Motor(forward=17, backward=27, enable=22)

try:
    # Funzione principale per controllare la direzione e il movimento del motore.
    # Alterna la rotazione del motore tra senso orario e antiorario con fermate intermedie.
    actions = {'CW': motor.forward, 'CCW': motor.backward, 'STOP': motor.stop}  # Definisce le azioni del motore per leggibilità

    while True:
        # Ciclo per eseguire le azioni definite e controllare la direzione del motore
        for action in ['CW', 'STOP', 'CCW', 'STOP']:
            actions[action]()  # Esegue l'azione corrente (avanzamento, stop, retro, stop)
            print(f"{action}")  # Mostra l'azione corrente nella console
            sleep(5)  # Pausa di 5 secondi prima di passare alla prossima azione

except KeyboardInterrupt:
    # Gestisce l'interruzione da tastiera (es. Ctrl+C) per fermare il programma in modo sicuro
    pass

Spiegazione del Codice

  1. Queste istruzioni di importazione richiamano la classe Motor dalla libreria gpiozero e la funzione sleep dal modulo time.

    #!/usr/bin/env python3
    from gpiozero import Motor
    from time import sleep
    
  2. Questa linea inizializza un oggetto Motor, specificando i pin GPIO per avanzamento (17), retro (27) e abilitazione (22).

    # Inizializza il motore con GPIO Zero, specificando i pin GPIO per avanzamento (17), retro (27) e abilitazione (22)
    motor = Motor(forward=17, backward=27, enable=22)
    
  3. Le azioni per il controllo del motore sono definite in un dizionario per leggibilità. Un ciclo infinito (while True) esegue queste azioni, mantenendole per 5 secondi ciascuna.

    try:
        # Funzione principale per controllare la direzione e il movimento del motore.
        # Alterna la rotazione del motore tra senso orario e antiorario con fermate intermedie.
        actions = {'CW': motor.forward, 'CCW': motor.backward, 'STOP': motor.stop}  # Definisce le azioni del motore per leggibilità
    
        while True:
            # Ciclo per eseguire le azioni definite e controllare la direzione del motore
            for action in ['CW', 'STOP', 'CCW', 'STOP']:
                actions[action]()  # Esegue l'azione corrente (avanzamento, stop, retro, stop)
                print(f"{action}")  # Mostra l'azione corrente nella console
                sleep(5)  # Pausa di 5 secondi prima di passare alla prossima azione
    
  4. Questo segmento consente di terminare il programma in modo sicuro tramite un’interruzione da tastiera (Ctrl+C) senza generare errori.

    except KeyboardInterrupt:
    # Gestisce l'interruzione da tastiera (es. Ctrl+C) per fermare il programma in modo sicuro
    pass