Archivi tag: Arduino Sensor Kit

Lezione 6 – Corso di Elettronica Creativa con Arduino Sensor Kit

Sensore di luminosità

Inizio questa lezione con un’informazione che va a correggere quanto scritto sul sito Arduino in riferimento al Grove Light Sensor in cui erroneamente viene indicato il dispositivo come fotoresistenza, in realtà si tratta di un fototransistor e ciò, soprattutto per i neofiti può creare qualche problema di comprensione, soprattutto perché lo sketch presentato non fornisce esattamente quanto indicato.

Fotoresistenza o fototransistor?

  • Versione 1.0 del Grove-Light Sensor – usava una classica CdS LDR GL5528, cioè una vera fotoresistenza.
  • Versione 1.1 / 1.2 (quella montata sullo Shield dell’Arduino Sensor Kit) – per ragioni RoHS (il cadmio delle CdS è vietato) Seeed ha sostituito l’LDR con un LS06-S: si tratta di un sensore a fototransistor lineare (tecnicamente una fotodiodo-transistor) che “mima” la vecchia fotoresistenza ma è più rapido e lineare.

Il sito di Arduino non ha aggiornato la terminologia e continua a chiamarlo “photo-resistor”.

Ora come possiamo fare per non creare problemi a chi inizia?

Innanzi tutto se volete utilizzare una fotoresistenza vi rimando alle mie slide: Alfabeto di Arduino – Lezione 3, ma attenzione in questo caso dovrete usare una breadboard e realizzare un circuito con un resistore da 10Kohm e una fotoresistenza, in questo modo usando lo sketch presente sul sito Arduino o quelli indicati nelle mie slide tutto funzionerà ed avrete valori che variano tra 0 e circa 900, coll’esempio sul sito Arduino avrete un valore massimo più basso.

Dal punto di vista teorico cosa succede (usando una fotoresistenza):

La fotoresistenza (o LDR, Light Dependent Resistor) per rilevare l’intensità della luce:

  • la resistenza della fotoresistenza diminuisce quando l’intensità luminosa aumenta;
  • la resistenza della fotoresistenza aumenta quando l’intensità luminosa diminuisce.

L’ADC dell’Arduino la converte in un numero intero da 0 (buio) a 1023 (molta luce) quindi la lettura avviene tramite l’istruzione analogRead() per questo kit collegheremo direttamente il modulo al pin A3 e quindi nel codice scriveremo: analogRead(A3).

// Prof. Maffucci Michele
// Uso del sensore di luminosità
// 27.05.2025

int sensore_luce = A3;   // pin del sensore di luminosità

void setup() {
  analogReference(INTERNAL);   // 1,1 V; attivare PRIMA di qualsiasi analogRead
  delay(3);                    // attesa minima per la stabilizzazione della reference
  Serial.begin(9600);          // avvia la comunicazione seriale
}

void loop() {
  int luce_grezza = analogRead(sensore_luce);      // legge il valore grezzo dal pin A3
  int luce = map(luce_grezza, 0, 1023, 0, 100);    // converte 0–1023 in 0–100 (percentuale)

Serial.print("Livello di luce: ");
  Serial.println(luce);  // stampa il valore di luce sul Monitor Seriale

delay(1000);           // attende 1 secondo prima della prossima lettura
}

Le cose sono simili con il Grove-Light Sensor sull’Arduino Sensor Kit, ma avrete, come dicevo, valori massimi più bassi, che raggiungo circa i 750 con la torcia dello smartphone direttamente puntata sul fototransistor. Dal punto di vista funzionale nulla cambia ma è importante aver ben presente che siamo lavorando con componenti elettronici diversi che hanno comportamenti simili.

Con lo sketch precedente otterremo sulla serial monitor questi valori:

Il fatto che il valore massimo si fermi attorno a 750 è in realtà perfettamente coerente con l’elettronica del modulo.

Quindi per ora, per chi inizia potete far finta che il componente sull’Arduino Sensor Kit è una fotoresistenza e se desiderate potete fermarvi a questo punto.

Continua a leggere

Lezione 5 – Corso di Elettronica Creativa con Arduino Sensor Kit

Il Buzzer

Quando progettiamo un impianto di automazione abbiamo quasi sempre bisogno di avvisare l’utente di uno stato o di un’anomalia. Oltre alle classiche spie luminose, un modo immediato per “farsi sentire” è impiegare un buzzer, noto colloquialmente come cicalino. Questo piccolo attuatore trasforma un segnale elettrico in un impulso sonoro che può variare da un semplice beep continuo a brevi toni di diversa frequenza.

Tipologie principali di buzzer

Attivo
Contiene un oscillatore interno che genera automaticamente la frequenza fissa non appena viene alimentato.
Con Arduino basta portare il pin di alimentazione a livello HIGH/LOW per abilitare o silenziare il suono.

Passivo
Non possiede oscillatore: necessita di un’onda quadra esterna per farlo vibrare.
Arduino può pilotarlo con PWM (analogWrite) o con la funzione tone() per scegliere la frequenza desiderata.

Tecnologie costruttive

I buzzer – siano essi attivi o passivi – possono realizzarsi con due differenti principi fisici:

  • Magnetici
    una bobina varia il campo magnetico e fa oscillare una sottile membrana metallica.
  • Piezoelettrici
    un disco di materiale piezo si deforma quando riceve tensione, generando la vibrazione acustica.

La scelta fra le due tecnologie dipende principalmente da:

  1. Segnale di pilotaggio disponibile (continua, PWM, ampiezza)
  2. Pressione sonora richiesta (volume)
  3. Spazio e forma concessi dal progetto

Come funziona un buzzer attivo

All’interno è presente un piccolo circuito oscillatore che, alimentato in continua, fa variare il campo magnetico di una bobina. La bobina è rigidamente accoppiata a una membrana, la quale vibra alla frequenza impostata dal circuito e produce un suono costante. In pratica: lo accendiamo – suona; lo spegniamo – tace.

Dati tecnici

  • Tensione nominale: 6V DC
  • Tensione di esercizio: 4-8V DC
  • Corrente nominale: < 30mA
  • Tipo di suono: segnale acustico continuo
  • Frequenza di risonanza: ~2300 Hz

Come funziona un buzzer passivo

Il buzzer passivo è sprovvisto di oscillatore e si comporta come un piccolo altoparlante: emette il tono dell’esatta frequenza del segnale che riceve. Con Arduino possiamo quindi:

  • generare una frequenza fissa con tone(pin, freq);
  • modulare il duty-cycle tramite analogWrite() per variare il volume;
  • creare melodie cambiando velocemente frequenza e durata.

Dati tecnici

  • Tensione nominale: 5V DC
  • Tensione di esercizio: 4-8V DC
  • Corrente nominale massima: ≤ 32 mA
  • Min. Uscita audio a 10 cm: 85 dB
  • Temperatura di esercizio: da 20°C a 45°C

Poiché vogliamo utilizzare il buzzer dell’Arduino Sensor Kit a questo punto possiamo chiederci:

“ma di che tipo è il buzzer di questo kit?”

E’ un buzzer di tipo passivo.

Nelle spiegazioni abbiamo parlato di PWM, di seguito alcuni dettagli, ma se volete approfondire consultate le mie slide: Alfabeto Arduino – Lezione 2 e l’approfondimento su questo sito: Arduino – Approfondimenti sulla modulazione di larghezza di impulso (PWM).

Per uno studio ancora più approfondito: Secrets of Arduino PWM.

Che cos’è il PWM

La modulazione di larghezza d’impulso, o PWM (Pulse Width Modulation), è una tecnica che permette di ottenere effetti analogici usando mezzi digitali. Il controllo digitale genera un’onda quadra, un segnale che passa continuamente da acceso (ON) a spento (OFF). Variando la frazione di tempo in cui il segnale rimane acceso (alto) rispetto a quella in cui rimane spento (basso), è possibile simulare tensioni intermedie tra lo 0 V (spento) e i 5 V (acceso al 100 %). Il periodo in cui il segnale resta acceso si chiama larghezza dell’impulso. Modificando (ovvero modulando) questa larghezza si ottengono valori analogici diversi. Se la commutazione ON/OFF avviene abbastanza velocemente, il segnale risulta percepito come una tensione “media” continua compresa tra 0 V e 5 V.
Questo segnale PWM può dunque essere usato per controllare con facilità un buzzer passivo.
Per generare segnali PWM con Arduino si utilizza la funzione analogWrite(), mentre digitalWrite() produce solo segnali in corrente continua (DC).
Sulla tua scheda ci sono sei pin digitali contrassegnati dal simbolo “~” (tilde), che indica la capacità di gestire un segnale PWM: 3, 5, 6, 9, 10, 11. Questi sono chiamati pin PWM.

Collegamenti

Come abbiamo detto precedentemente Il buzzer del kit è passivo: non produce autonomamente il tono, ma vibra quando riceve un’onda quadra. Con analogWrite() inviate un’onda PWM; variando il duty-cycle (0-255) variate il volume.

Esempio 1:  emissione di un beep

/* Prof. Maffucci Michele
   beep con il buzzer
   14.05.25
*/

const int BuzzerPin = 5;       // D5 ha anche il simbolo ~ = PWM

void setup() {
  pinMode(BuzzerPin, OUTPUT);  // imposta il pin come uscita
}

void loop() {
  analogWrite(BuzzerPin, 128); // 50 % di duty-cycle ≈ volume medio
  delay(1000);                 // suona per 1 s
  analogWrite(BuzzerPin, 0);   // silenzio
  delay(1000);                 // pausa di 1 s
}

Funzionamento del codice

  • pinMode()
    imposta il pin in uscita, così può fornire tensione
  • analogWrite(pin, val)
    genera un’onda quadra a ~490 Hz sul pin; val è il duty-cycle (0 = 0 %, 255 = 100 %)
  • delay(ms)
    pausa del programma – qui determina per quanto tempo il buzzer resta attivo/inattivo

Continua a leggere

Lezione 4 – Corso di Elettronica Creativa con Arduino Sensor Kit

Il potenziometro

I potenziometri sono tra i resistori variabili più diffusi la cui legge di variazione della resistenza dipende da una grandezza meccanica (generalmente la rotazione di un albero, in qualche caso lo spostamento rettilineo di un cursore).

I resistori variabili sono schematicamente indicati con uno dei due simboli riportati di seguito:

Un resistore variabile è caratterizzato dal suo valore ohmico esistente tra i due terminali fissi; esso può essere utilizzato all’interno di un circuito in due modi come reostato, utilizzato come regolatore di corrente o come potenziometro utilizzato come regolatore di tensione, in questa lezione ne vedremo l’utilizzo come potenziometro.

Non tutti i potenziometri sono uguali, nei potenziometri “logaritmici” (usati negli amplificatori audio) la variazione di resistenza segue una curva esponenziale per meglio adattarsi alla percezione umana del volume.

Obiettivi di questa lezione

  1. Comprendere il funzionamento del potenziometro come partitore di tensione variabile.
  2. Collegare correttamente il modulo Potentiometer Grove allo shield Arduino Sensor Kit.
  3. Misurare la posizione del cursore con analogRead() e convertire in un valore all’interno di un range fissato.
  4. Utilizzare l’istruzione di controllo di flusso IF-THEN-ELSE.

Teoria di base

  • Il microcontrollore ATmega328 è dotato si 6 ADC (Analog to Digital Converter – Convertitori Analogici Digitali)
  • Gli ingressi analogici leggono valori compresi tra 0 e 5 volt
  • La risoluzione dei valori convertiti in digitale è di 10 bit (1024 valori)
  • Ogni bit equivale a valori di tensione pari a 5/1024 = 4,8 mV che è la più piccola misura di tensione che si può rilevare

Le grandezze fisiche del mondo reale sono di tipo analogico ed Arduino dispone di una serie di ingressi adibiti alla lettura di grandezze di tipo analogico, che come dettagliato nella lezione 1, vengono poi convertire dal microcontrollore in grandezze di tipo digitale.

Le variazioni di grandezze di tipo analogico vengono lette da Arduino come variazioni di tensione sugli ingressi analogici.

Un sensore generico quindi, connesso sui pin analogici fornirà una tensione che sarà funzione della grandezza fisica misurata.

Per poter simulare la variazione di tensione e quindi studiare il comportamento di un generico sensore e capire come leggere valori analogici, utilizzeremo in questa fase un potenziometro o un trimmer, componente elettronico che consente di variare la tensione presente ai suoi capi.

Il Grove Rotary Potentiometer

Continua a leggere

Lezione 3 – Corso di Elettronica Creativa con Arduino Sensor Kit

A distanza di qualche mese riprendo le mie brevi lezioni sull’uso dell’Arduino Sensor Kit, mi dispiace non stato celere nel produrre altre lezioni, ma gli impegni lavorativi mi hanno parecchio coinvolto.

Come già avevo avuto modo di segnalare nelle precedenti lezioni, per la realizzazione di queste guide prendo come riferimento l’indice presente sul sito Arduino e su quella traccia realizzo lezioni un po’ più approfondite che mi permettono poi di strutturare una lezione di laboratorio di circa due ore di attività.

Giusto per non far “arrabbiare” nessuno — mi riferisco a chi potrebbe critica le modalità con cui vengono presentati alcuni argomenti di elettronica — ricordo che queste lezioni sono dedicate a chi non ha mai affrontato lo studio dell’elettronica (neofiti o studenti della secondaria di primo grado e studenti dei primi due anni della scuola superiore), pertanto alcuni concetti richiedono chiarimenti e inevitabili semplificazioni, che consentiranno di riprendere gli stessi argomenti con maggiore facilità quando le competenze teoriche saranno più solide.

Gli obiettivi di questa terza lezione sono:

  • comprendere come funziona un pulsante a livello elettrico e meccanico.
  • sviluppare sketch via via più complessi:
    • accensione di un LED alla pressione del pulsante;
    • Indicazione dello stato del LED sulla SerialMonitor;
    • cicli di blink avviati da pulsante;
    • cicli di blink avviati da pulsante e segnalazione del numero di cicli.

Per lo svolgimento di questa esercitazione abbiamo necessità solamente dell’Arduino Sensor Kit ed utilizzeremo:

Il pulsante:

Il LED:

Continua a leggere

Lezione 2 – Corso di Elettronica Creativa con Arduino Sensor Kit

Come ormai tutti sappiamo un LED si presenta come un piccolo componente elettronico che emette luce quando attraversato da corrente elettrica. I LED sono molto usati nella vita di tutti i giorni in vari dispositivi come lampadine, schermi di telefoni e computer, telecomandi, e molto altro.

Immaginate il LED come una lampadina molto piccola, ma molto più efficiente ed ecologica. A differenza delle lampadine tradizionali, che producono luce riscaldando un filamento metallico, i LED producono luce attraverso un processo chiamato “elettroluminescenza”. Questo processo avviene quando la corrente elettrica passa attraverso un semiconduttore (il materiale di cui è costituito il LED) e lo stimola a emettere luce.

Un po’ di storia

Nel corso del primo Novecento, l’ingegnere inglese Henry Joseph Round fece una scoperta rivoluzionaria: l’elettroluminescenza, ovvero la proprietà di certi materiali di emettere luce quando attraversati da corrente elettrica. Da questa scoperta, nascono i LED acronimo di Light Emitting Diode (Diodo a Emissione di Luce), diodi specializzati nell’utilizzare tale fenomeno. Il primo LED, operante nell’infrarosso, venne introdotto nel 1961 e ancora oggi è ampiamente utilizzato in dispositivi come telecomandi e fotocellule.

L’anno successivo alla creazione del primo LED infrarosso, nel 1962, Nick Holonyak Jr. fece un ulteriore passo avanti sviluppando il primo LED rosso, capace di emettere luce visibile direttamente all’occhio umano. Gli studi su questi nuovi diodi proseguirono, focalizzandosi sulle varie applicazioni pratiche, come nell’ambito dei laser, e sull’esplorazione dei materiali necessari per produrre diverse tonalità di luce, combinando più fonti luminose per ottenere una vasta gamma di colori.

Durante gli anni cruciali della ricerca sui LED, un importante contributo venne dall’ingegnere americano M. George Craford, ex studente di Holonyak all’Università dell’Illinois. Nel 1972, Craford realizzò un significativo avanzamento creando i primi LED gialli che furono commercializzati dalla Monsanto, l’azienda per cui lavorava. Dedicate interamente al settore dei LED, le ricerche di Craford furono fondamentali per la loro prima larga diffusione, come dimostra il loro impiego in applicazioni quali semafori e segnalazioni luminose stradali.

Vantaggi nell’uso dei diodi LED

  • Consumano meno energia: sono molto più efficienti delle lampadine tradizionali, il che significa che usano meno elettricità per produrre la stessa quantità di luce.
  • Durano più a lungo: possono funzionare per migliaia di ore prima di dover essere sostituiti.
  • Sono robusti: non contengono filamenti o parti fragili che si possono rompere facilmente.
  • Offrono diverse colorazioni: i LED possono emettere luce di vari colori senza l’uso di filtri colorati.

Un esempio pratico molto semplice che potete realizzare a scuola è collegare un LED a una batteria con un piccolo resistore (di seguito sono fornite le indicazioni per il calcolo del valore del resistore) per limitare la corrente e proteggere il LED: noterete come si illumina, dimostrando in modo semplice ed efficace come funziona.

Struttura Fisica del LED

Un LED è composto principalmente da un chip di materiale semiconduttore in cui sono presenti impurità per creare una giunzione P-N. La giunzione è dove avviene l’elettroluminescenza (emissione di luce). Il chip è incapsulato in un guscio di plastica o vetro, che può essere modellato per focalizzare o diffondere la luce. I LED hanno due terminali: un anodo (+) e un catodo (-). La corrente elettrica fluisce dall’anodo al catodo, e questo flusso di corrente permette al LED di emettere luce.

Modalità di Polarizzazione

Per funzionare correttamente, un LED deve essere polarizzato in modo diretto, il che significa che l’anodo deve essere collegato al polo positivo della fonte di alimentazione e il catodo al polo negativo. Se il LED è collegato al contrario (polarizzazione inversa), non si accenderà perché la corrente non può fluire attraverso di esso nel modo giusto.

Calcolo della Resistenza Serie

Per proteggere il LED da correnti eccessive, si usa una resistore connesso in serie. Il calcolo di questa della resistenza (R) dipende dalla tensione di alimentazione (VS), dalla tensione del LED (VI​) e dalla corrente desiderata attraverso il LED (ILED​):

Dove:

  • VS​ è la tensione di alimentazione
  • VLED​ è la tensione di funzionamento del LED, tipicamente tra 1.8V e 3.3V a seconda del colore
  • ILED​ è la corrente di funzionamento desiderata per il LED, solitamente intorno a 20mA per la maggior parte dei LED, ma può variare.

Corrente di Funzionamento e Colore

La corrente di funzionamento del LED influisce sulla luminosità, ma anche il colore del LED ha un ruolo nella determinazione della tensione di funzionamento. Ecco alcune tensioni di funzionamento approssimative in base al colore:

  • Rosso: 1.8V – 2.2V
  • Verde: 2.0V – 3.0V
  • Blu, Bianco, UV: 3.0V – 3.5V

Questi valori possono variare a seconda del tipo specifico di LED. Per un funzionamento sicuro, è essenziale controllare le specifiche del produttore del LED che si sta utilizzando.

Ricordate, utilizzare un resistore di valore adeguato è cruciale per prevenire il danneggiamento del LED a causa di una corrente troppo elevata. Il calcolo della resistenza in serie aiuta a garantire che il LED riceva la corrente corretta per il suo ottimale funzionamento e durata.

Di seguito un esempio di collegamenti per controllare l’accensione di un diodo LED rosso:

Materiali Necessari

  • 1 LED rosso
  • 1 resistenza (calcoleremo il valore)
  • 1 batteria (per esempio, una batteria da 9V)
  •  Cavi di collegamento

Calcolo della Resistenza

Prima di collegare il circuito, dobbiamo calcolare il valore della resistenza necessaria per proteggere il LED. Supponendo che il LED rosso abbia una tensione di funzionamento di circa 2V e che la corrente ideale per il LED sia di 20mA (0,02A), usiamo una batteria da 9V come alimentazione. Il calcolo della resistenza (R) si basa sulla formula precedentemente indicata dove:

  • Vs, tensione di alimentazione vale 9V
  • VLED​, tensione di funzionamento del LED vale 2V per un LED rosso
  • ILED, corrente di funzionamento desiderata per il LED, vale 0,02A (2 mA)

Sostituendo i valori nella formula otteniamo:

Il valore 350 Ohm è quello calcolato, bisognerà quindi ora scegliere il valore commerciale prossimo al valore calcolato, si potrà scegliere quindi tra 330 Ohm o 360 Ohm.

Collegamento del Circuito

  1. Collega un’estremità della resistenza a uno dei terminali della batteria (il polo positivo, se state usando un portabatterie con i cavi già attaccati).
  2. Collega l’altra estremità della resistenza al terminale più lungo (anodo) del LED. L’anodo è il lato positivo del LED.
  3. Collega il terminale più corto (catodo) del LED al polo negativo della batteria. Puoi fare questo direttamente o usando un cavo.
  4. Una volta completato il collegamento, il LED dovrebbe accendersi. Se non si accende, verifica i collegamenti e assicurati che la batteria sia carica.

Ricordate come detto sopra, è importante non invertire la polarità del LED, perché non si illuminerà se collegato al contrario.

Nel modulo Grove LED incluso nell’Arduino Sensor Kit, la resistenza di limitazione della corrente è già integrata sul PCB (circuito stampato), quindi, non c’è bisogno di preoccuparsi di aggiungere manualmente una resistenza esterna quando lo usate; questa parte del lavoro è già stata fatta per voi. Questo tipo di collegamento verrà approfondito in un corso successivo.

Ricordate, state partecipando a un corso introduttivo il cui scopo è guidarvi, passo dopo passo, nel mondo della programmazione e nella realizzazione di sistemi elettronici. Questo approccio semplificato vi permette di concentrarvi sull’apprendimento delle basi, evitando inizialmente di soffermarvi troppo sui dettagli tecnici.

Utilizzare l’Arduino Sensor Kit

Le funzioni che verranno usate nei programmi che seguono saranno le seguenti:

pinMode()
La funzione pinMode() in Arduino è essenziale per impostare la modalità di funzionamento di uno specifico pin della scheda Arduino. Questa funzione permette di definire se un pin deve comportarsi come un ingresso (input) ovvero riceve un segnale in ingresso o come un’uscita (output) ovvero fornisce un segnale in uscita.

digitalWrite()
La funzione digitalWrite() in Arduino è utilizzata per scrivere un valore HIGH (1 logico corrispondente a 5V) o LOW (0 logico, corrispondente a 0V) su un pin configurato come OUTPUT. Questo permette di controllare dispositivi elettronici come LED, motori e altri componenti elettronici.

delay()
La funzione delay() in Arduino è utilizzata per introdurre un ritardo nel programma per un determinato numero di millisecondi. Durante questo ritardo, il programma si ferma e non esegue altre istruzioni. Questo può essere utile per controllare il timing di varie operazioni, come il lampeggio di un LED, il ritardo tra due azioni. Vedremo in lezioni successive come utilizzare un’altra tecnica per la gestione dei ritardi che permette di non bloccare l’intera esecuzione del programma.

Sketch 1

// Prof. Maffucci Michele
// Blink del LED connesso al pin digitale 6

// #define permette di assegnare un none ad un valore costante prima che
// il programma venga compilato.
// Le costanti così definite non occupano spazio nella memoria del mirocontrollore

#define LED 6

void setup() {
// inserire quì il codice che deve essere eseguito una sola volta
// dal momento che colleghi all'alimentazione Arduino
pinMode(LED, OUTPUT); // con pinMode indichiamo come verrà usato il pin, in questo caso come output
}

void loop() {
// Inseriamo nel loop il codice che vogliamo
// venga ripetuto continuamente

digitalWrite(LED, HIGH); // Imposta ad HIGH (5V) la tensione sull'anodo del LED
delay(1000); // Attesa di 1000 millisecondi
digitalWrite(LED, LOW); // Imposta ad LOW (0V) la tensione sull'anodo del LED
delay(1000); // Attesa di 1000 millisecondi
}

Sketch 2

Continua a leggere