Archivi tag: blink

Raspberry Pi Pico – Blink di un LED esterno

Nel primo post pubblicato sull’uso di Raspberry Pi Pico, avevo concluso il tutorial mostrando come controllare l’accensione del LED sulla scheda, quello connesso alla pin 25. Il passo successivo, molto semplice, in quanto riprende i medesimi passaggi dell’ultimo esempio mostrato, sarà quello di controllare un LED esterno alla scheda.
Ovviamente sappiamo già che in serie al LED dovrà essere inserita una resistenza per controllare la corrente che fluisce nel LED (per approfondimenti consultare il link). Poiché in questo caso la tensione di alimentazione del LED sarà quella disponibile sulla scheda, 3,3 Volt, considerando un LED rosso, con una corrente di funzionamento di 15 mA ed una tensione di soglia di 1,8V, usando la legge do Ohm il valore della resistenza serie dovrà essere di 100 Ohm. Nel caso non abbiate questo valore potrete utilizzare anche i classici valori, 220 Ohm o 330 Ohm, che trovate in un qualsiasi kit di sperimentazione, valori più grandi di resistenza ovviamente faranno emettere a parità di tensione, una luminosità inferiore.

Colleghiamo un reoforo del resistore al pin digitale 15 (GPIO 15), il restante reoforo all’anodo del LED ed il catodo del LED al GND. Di seguito le immagini del Pin Out del PiPico e schema di collegamento:

Prendendo a riferimento il programma in MicroPython del precedente tutorial, andiamo a variare alcune linee di codice. Bisognerà modificare solamente il numero del pin digitale utilizzato:

# Prof. Maffucci Michele
# Blink LED connesso al pin 15
# 10.09.2021

# libreria che permette di utilizzare MicroPython con il RaspyMicro
import machine

# per la gestione del tempo
import utime

#pin 15 dichiarato come OUTPUT
ledEsterno = machine.Pin(15, machine.Pin.OUT)

# loop infinito, while sempre vero, che scrive, ad intervalli di 1 secondo
# sul pin 15 il valore 1 e 0 
while True:
    ledEsterno.value(1)    # imposta il livello logico 1 sul pin 15
    utime.sleep(1)         # lo stato logico 1 viene mantenuto per 1 secondo
    ledEsterno.value(0)    # imposta il livello logico 0 sul pin 15
    utime.sleep(1)         # lo stato logico 0 viene mantenuto per 1 secondo

Buon coding a tutti 🙂

Blynk – liberi di creare applicazioni per i vostri progetti con Arduino, Raspberry Pi, ESP8266 e molto altro

blynk01

Sì è proprio così Blynk, come afferma il titolo di questo post, è semplicità assoluta nel creare applicazioni e “governare l’elettronica” con estrema semplicità attraverso i vostri dispositivi mobili. I test che sto conducendo questa giornata mi confermano l’utilità del sistema ed aggiungono un mattoncino in più a quanto insegno ai miei allievi. Grazie a Rossano M. che mi ha inviato la segnalazione e che mi chiede di risolvere alcuni dubbi sul suo utilizzo, cercherò di rispondere in prossimi post.

blynk02

Blynk nasce come progetto finanziato mediante Kickstarter e vi consente di controllare i vostri progetti elettronici attraverso dispositivi iOS e Android mediante apposite app per il controllo di Arduino, Raspberry Pi e altri dispositivi.

In estrema sintesi l’app dispone di una dashboard dove potrete costruire un’interfaccia per il vostro progetto semplicemente trascinando e rilasciando i widget.

Come affermato sul sito, confermo perché sperimentato, in 5 minuti sarete in grado di operare e in 5 minuti potrete capire cosa vuol dire Internet Of Your Things.

Partite dal Getting started dopo di che passate seguite i tutorial del sito di riferimento, sono ben fatti.

Buona sperimentazione a tutti.

Arduino – lezione 02: facciamo lampeggiare un led

A distanza di qualche mese sono riuscito a sistemare gli appunti che ho realizzato in bozza per i miei studenti per continuare il corso su Arduino ed in questa lezione vi propongo il canonico esercizio “blink”, che trovate anche su Arduino.cc.
Farò alcune variazioni ed integrazioni all’esempio in modo che possiate entrare nel dettaglio del linguaggio di programmazione.
Userò in questa lezione la scheda Arduino Duemilanove e la versione dell’IDE n. 21 in ambiente Mac, ovviamente la programmazione è identica per tutti i sistemi operativi.

Il programma, sketch in Arduino, che vi consente di far lampeggiare un led è secondo me il primo programma che dovete realizzare per familiarizzare con l’ambiente di sviluppo ma soprattutto per verificare il funzionamento della scheda.

In questa lezione viene dato per scontato che lo studente conosca i concetti di:

  • corrente
  • tensione
  • resistenza

inoltre sappia cosa sono e come funzionano i componenti:

  • diodi led
  • resistori

Se non avete queste nozioni di base nessun problema! Scrivetemi sarò ben lieto di spiegarvi in modo pratico e sintetico i concetti di elettronica necessari che vi permetteranno di proseguire agevolmente nel corso.

Partiamo!

Come potete notare sulla scheda è presente un piccolo diodo led indicato da una “L” che potete utilizzare come trasduttore per la realizzazione del vostro primo programma.

Se però volete incominciare con la pratica potete sfruttare le uscite digitali per pilotare un led più grande. Come mostrato nell’immagine che segue inserite il CATODO del diodo nel foro indicato con GND e l’anodo nel foro indicato con 13.

Aprite il programma Arduino se è la prima volta che avviate il programma verrà immediatamente aperto uno sketch vuoto, altrimenti dal menù File > New aprite un nuovo sketch e salvatelo con il nome che desiderate nella cartella in cui volete collezionare i vostri programmi. In ambiente Mac in fase di installazione viene creata in modo automatico una cartella di nome Arduino nella cartella “Documents” in questo modo se salvate senza indicare la cartella di destinazione ritroverete lo sketch creato in Documents > Arduino

Il programma blink potete trovarlo sul sito Arduino.cc oppure direttamente dal vostro programma:

File > Examples > 1.Basics > Blink

di seguito vi riporto la mia versione che ho rinominato “lampeggiatore led v01” in cui ho inserito i commenti in italiano, se desiderate potete utilizzare la mia versione.


// Esempio 01: far lampeggiare un led

  #define LED 13            // LED collegato al pin digitale 13

void setup() {
  pinMode(LED, OUTPUT);     // imposta il pin digitale come output
}

void loop() {
  digitalWrite(LED, HIGH);  // accende il LED
  delay(1000);              // aspetta un secondo
  digitalWrite(LED, LOW);   // spegne il LED
  delay(1000);              // aspetta un secondo
}

Di seguito l’immagine della schermata del vostro primo sketch

Ora dovete verificare il vostro programma facendo click su “Verify” e se tutto è corretto in basso all’IDE compare il messaggio “Done compiling” ciò indica che l’IDE Arduino ha tradotto il vostro sketch in un programma eseguibile sulla scheda Arduino.

Ora dovete caricare sulla scheda il vostro programma facendo click su “Upload to I/O Board“, in questo modo la scheda interrompe l’esecuzione di ciò che stava eseguendo, carica il nuovo programma in memoria e lo esegue.

Durante la fase di trasferimento accadono due cose:

01. appare il messaggio: Uploading to I/O Board… e la dimensione in byte del vostro sketch e alla fine compare il messaggio: “Done uploading” che indica che il trasferimento del programma alla scheda ha avuto termine;

02. sulla scheda i led identificati con RX e TX lampeggiano, ogni volta che viene inviato un byte e durante la fase di uploading del programma lampeggiano continuamente.

Analizziamo passo passo il codice

Non abbiate paura l’analisi riga per riga vi porterà alla comprensione del linguaggio di programmazione anche se non siete programmatori.

// Esempio 01: far lampeggiare un led

Cone le due barre “//” indichiamo l’inizio di un commento e il testo che lo segue, in questo caso, identifica il titolo del nostro programma.
Molto spesso è importante indicare subito dopo il titolo, la data dell’ultima variazione e il nome dell’autore, in modo che a distanza di tempo possiamo identificare le versioni di sviluppo ed il nome dell’ultimo programmatore che ha eseguito modifiche:

Ad esempio:

// Esempio 01: far lampeggiare un led
// Data ultima modifica: 16.11.2010
// Autore: Michele Maffucci

notate che ogni linea di commento deve essere preceduta da “//”

Se volete evitare di scrivere per ogni linea “//” potete far precedere il testo commento dai caratteri “/*” e farlo concludere con i caratteri “*/”

Ad esempio:

/* Esempio 01: far lampeggiare un led
Data ultima modifica: 16.11.2010
Autore: Michele Maffucci */
#define LED 13               // LED collegato al pin digitale 13

#define consente di sostituire, in fase di compilazione, all’interno del vostro programma il valore 13 ogni volta che compare la parola LED.
Vi ricordo che la compilazione avviene quando fate click su “Verify” oppure quando effettuate l’upload sulla scheda.

void setup()

void indica ad Arduino che stiamo dichiarando una funzione di nome setup(), cioè un porzione di codice che esegue un’operazione specifica

{

La parentesi graffa aperta indica dove incomincia il codice.

  pinMode(LED, OUTPUT);     // imposta il pin digitale come output

pinMode è un’istruzione che dice ad Arduino come usare un determinato pin.
Tra parentesi tonde vengono specificati gli argomenti che possono essere numeri e lettere.
I pin digitali possono essere utilizzati sia come INPUT che come OUTPUT. Nel nostro caso poiché vogliamo far lampeggiare il diodo LED dobbiamo definire il pin di OUTPUT.
Le parole INPUT e OUTPUT sono costanti definite, che non variano mai nel linguaggio di Arduino.

}

La parentesi graffa chiusa indica la fine della funzione setup().

void loop()

Indica la sezione di codice principale, il nucleo del vostro programma, che verrà ripetuto all’infinito fino a quando non si spegne la scheda.

  digitalWrite(LED, HIGH);  // accende il LED

L’istruzione digitalWrite possiede due argomenti, il primo definisce il pin, il secondo indica lo stato.
digitalWrite è un’istruzione in grado di impostare un pin definito come OUTPUT ad un valore HIGH o ad un valore LOW, in modo più semplice permette di accendere o spegnere un led connesso al pin specificato nel primo argomento, nel nostro caso LED.

Tenete conto che dire che su un determinato pin vi è uno stato HIGHT, vuol dire che su di esso viene applicata una tensione di +5 V, mentre se lo stato e LOW vuol dire che sul pin è applicata una tensione di 0V.

  delay(1000);              // aspetta un secondo

delay() è un’istruzione molto semplice che non fa altro che interrompere per un determinato tempo l’esecuzione del programma.
L’istruzione ha un solo argomento numerico che indica il numero di millisecondi di attesa.
Nel nostro caso con “delay(1000)” diciamo che il programma deve bloccarsi per 1000 millisecondi ovvero 1 secondo.

Quindi guardando insieme le due istruzioni:

  digitalWrite(LED, HIGH);  // accende il LED
  delay(1000);              // aspetta un secondo

Diciamo ad Arduino di accendere il diodo led sul pin 13 per 1 secondo.

  digitalWrite(LED, LOW);   // spegne il LED

Ordiniamo al led sul pin 13 di spegnersi

  delay(1000);              // aspetta un secondo

tiene spento il diodo connesso al pin 13 per 1 secondo.

Ora per concludere questa seconda lezione vi invito ad eseguire i seguenti esercizi:

  1. variate il tempo di accensione e spegnimento, con tempi uguali di accensione e spegnimento
  2. variate il tempo di accensione e spegnimento, con tempi diversi di accensione e spegnimento
  3. provate ad eseguire il programma con tempi inferiori ai 500 millisecondi, cosa succede?

Vai alle altre lezioni:

Lezione01: Incominciamo con Arduino Arduino – lezione 02: facciamo lampeggiare un led Arduino – lezione 03: controlliamo un led con un pulsante
Lezione Arduino Lezione Arduino Lezione Arduino
Arduino – lezione 04: realizzare un programma che identifica le variazioni di stato Arduino – lezione 05: controllo presenza  
Lezione Arduino Lezione Arduino