Per prima cosa si deve scaricare la libreria Time da qui da inserire poi nella directory libraries del software di programmazione dell'Arduino (vengono aggiunte Time TimeAlarms e DS1307RTC)
dopo si puo' provare con il seguente sketch che riporta il valore in millisecondi dall'accensione della scheda
---------------------
unsigned long time;
void setup()
{
Serial.begin(9600);
}
void loop()
{
Serial.print("tempo : ");
time = millis();
Serial.println(time);
delay(1000);
}
--------------------
giovedì 17 maggio 2012
Arduino Ethernet
L'alimentazione alla scheda viene data dal convertitore, in caso di assenza si deve alimentare mediante una batteria da 9 V in quanto il voltaggio di ingresso consentito e' tra 7 e 12 V. Altrimenti si puo' usare un alimentatore AC/DC da muro con 9 V ed il + sul pin centrale
Per la programmazione e' necessario anche modifica il file boards.txt che si trova nella directory /hardware/arduino del software di programmazione (fatto cio' nell'interfaccia e' possibile selezionare la scheda)
Nella foto soprastante si puo' vedere l'Arduino collegata direttamente al PC mediante un cavo di rete incrociato
mercoledì 16 maggio 2012
Sensore Umidita' e temperatura
Per questa prova e' stato usato un sensore Phidgets 1125 che monta sia un sensore di temperatura che di umidita' relativa; il sensore e' nato per essere collegato alla PhidgetInterfaceKit 8/8/8 ma in realta' puo' essere collegato tranquillamente ad una Arduino visto che in uscita si ha un segnala analogico
La pedinatura dei cavi e'
Nero = Ground
Rosso = Power (+5v)
Bianco = segnale analogic0
I collegamenti sulla bread board sono piuttosto banali
Lo sketch per leggere i dati e' nettamente piu' semplice rispetto all'intefaccia I2C
(Le formule di conversione tra segnale e temperatura/umidita' sono state riprese dalle specifiche tecniche del sensore)
------------------------
// legge temperatura e umidita'
int temp = 0;
int umi = 0;
float temp2 = 0.0;
float rh = 0.0;
void setup() {
Serial.begin(9600);
}
void loop() {
temp = analogRead(A0); // legge il primo
umi = analogRead(A1);
temp2 = (temp * 0.2222) -61.11;
rh = (umi*0.1906)-40.2;
Serial.print("Temp (C): ");
Serial.println(temp2);
Serial.print("Umidita' rel.%: ");
Serial.println(rh);
delay(1000);
}
------------------------
I valori di temperatura sono coerenti .... non ho ancora capito bene i risultati dell'umidita' :<<<<
La pedinatura dei cavi e'
Nero = Ground
Rosso = Power (+5v)
Bianco = segnale analogic0
I collegamenti sulla bread board sono piuttosto banali
Lo sketch per leggere i dati e' nettamente piu' semplice rispetto all'intefaccia I2C
(Le formule di conversione tra segnale e temperatura/umidita' sono state riprese dalle specifiche tecniche del sensore)
------------------------
// legge temperatura e umidita'
int temp = 0;
int umi = 0;
float temp2 = 0.0;
float rh = 0.0;
void setup() {
Serial.begin(9600);
}
void loop() {
temp = analogRead(A0); // legge il primo
umi = analogRead(A1);
temp2 = (temp * 0.2222) -61.11;
rh = (umi*0.1906)-40.2;
Serial.print("Temp (C): ");
Serial.println(temp2);
Serial.print("Umidita' rel.%: ");
Serial.println(rh);
delay(1000);
}
------------------------
I valori di temperatura sono coerenti .... non ho ancora capito bene i risultati dell'umidita' :<<<<
martedì 15 maggio 2012
Arduino Bluetooth v 06
Connessione di alimentazione della Arduino BT ... di fatto non ha una connessione USB quindi ha solo alimentazione esterna che deve essere inferiore a 5.5 Volts ed assolutamente della giusta polarita' pena la compromissione dell'elettronica .
La versione 06 monta il processore ATMEGA 168 (importante da settare nel software di programmazione)
Programmare la scheda Bluetooth e' un po' piu' difficile rispetto alla versione USB
la procedura prevede
hcitool scan per verificare l'address della scheda
dopo di cio' si crea la porta seriale virtuale per la programmazione
sudo rfcomm bind rfcomm0 00:07:80:90:51:17 1
dando il comando rfcomm si puo' verificare la connessione avvenuta
in seguito si deve andare nella directory /lib/ ed editare il file preferences.txt
modificando alla fine del file
serial.port=/dev/rfcomm0
serial.databits=8
serial.stopbits=1
serial.parity=N
serial.debug._rate=115200
serial.burn_rate=115200
board=bt
(per usare piu' schede uso due installazione del software, una per la versione USB ed una per la BT)
ed infine la parte difficile
una volta compilato lo sketch per fare l'upload sulla scheda si deve premere il tasto RESET sulla scheda BT (e' l'unico pulsante presente) e subito dopo premere il pulsante di upload sul software Arduino. La giusta scelta di tempo e' fondamentale per l'upload
Il tasto di upload e' il secondo da destra nella barra in alto |
Puo' essere comodo montare un LED sul pin digitale 13 perche' da qui si puo' vedere quando viene fatto il reboot
Accelerometro LIS3LV02DQ su Arduino
La prova reale dell'accelerometro LIS3LVV02DQ collegato come I2C ad una Arduino
Le resistenze di Pull-Off sono da 1.5 KOhm
Lo sketch caricato e' il seguente (ripreso da qui)
-----------------
#include <Wire.h>
// TWI (I2C) sketch to communicate with the LIS3LV02DQ accelerometer
//Modified code from http://research.techkwondo.com/blog/julian/279
//Thanks Julian.
void setup()
{
Wire.begin(); // join i2c bus (address optional for master)
Serial.begin(9600);
Serial.println("Wire.begin");
Wire.beginTransmission(0x1D); Wire.send(0x20); // CTRL_REG1 (20h)
Wire.send(0x87); // Device on, 40hz, normal mode, all axis's enabled
Wire.endTransmission();
}
void loop()
{
#define i2cID 0x1D#define outXhigh 0x29
#define outYhigh 0x2B
#define outZhigh 0x2D
#define outXlow 0x28
#define outYlow 0x2A
#define outZlow 0x2C
byte z_val_l, z_val_h, y_val_l, y_val_h, x_val_l, x_val_h;
//----------X Values-----------------------
int x_val;
//------------------------------- Wire.beginTransmission(i2cID);
Wire.send(outXlow);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1); while(Wire.available())
{
x_val_l = Wire.receive();
}
//-------------------------------
Wire.beginTransmission(i2cID);
Wire.send(outXhigh);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1);if(Wire.available())
{
x_val_h = Wire.receive();
}
//-------------------------------
x_val = x_val_h; x_val <<= 8;
x_val += x_val_l;
//----------Y Values-----------------------
int y_val;
//------------------------------- Wire.beginTransmission(i2cID);
Wire.send(outYlow);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1); while(Wire.available())
{
y_val_l = Wire.receive();
}
//-------------------------------
Wire.beginTransmission(i2cID);
Wire.send(outYhigh);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1);
if(Wire.available())
{
y_val_h = Wire.receive();
}
//-------------------------------
y_val = y_val_h; y_val <<= 8;
y_val += y_val_l;
//----------Z Values-----------------------
int z_val;
//------------------------------- Wire.beginTransmission(i2cID);
Wire.send(outZlow);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1); while(Wire.available())
{
z_val_l = Wire.receive();
}
//-------------------------------
Wire.beginTransmission(i2cID);
Wire.send(outZhigh);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1);
if(Wire.available())
{
z_val_h = Wire.receive();
}
//-------------------------------
z_val = z_val_h; z_val <<= 8;
z_val += z_val_l;
Serial.print("x_val= "); Serial.println(x_val, DEC);
Serial.print("y_val= "); Serial.println(y_val, DEC);
Serial.print("z_val= "); Serial.println(z_val, DEC);
delay(250);
}
-----------------
I risultati a video (ogni tanto sollevo e faccio ricadere la board sul tavolo per vedere l'effetto)
Le resistenze di Pull-Off sono da 1.5 KOhm
Lo sketch caricato e' il seguente (ripreso da qui)
-----------------
#include <Wire.h>
// TWI (I2C) sketch to communicate with the LIS3LV02DQ accelerometer
//Modified code from http://research.techkwondo.com/blog/julian/279
//Thanks Julian.
void setup()
{
Wire.begin(); // join i2c bus (address optional for master)
Serial.begin(9600);
Serial.println("Wire.begin");
Wire.beginTransmission(0x1D); Wire.send(0x20); // CTRL_REG1 (20h)
Wire.send(0x87); // Device on, 40hz, normal mode, all axis's enabled
Wire.endTransmission();
}
void loop()
{
#define i2cID 0x1D#define outXhigh 0x29
#define outYhigh 0x2B
#define outZhigh 0x2D
#define outXlow 0x28
#define outYlow 0x2A
#define outZlow 0x2C
byte z_val_l, z_val_h, y_val_l, y_val_h, x_val_l, x_val_h;
//----------X Values-----------------------
int x_val;
//------------------------------- Wire.beginTransmission(i2cID);
Wire.send(outXlow);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1); while(Wire.available())
{
x_val_l = Wire.receive();
}
//-------------------------------
Wire.beginTransmission(i2cID);
Wire.send(outXhigh);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1);if(Wire.available())
{
x_val_h = Wire.receive();
}
//-------------------------------
x_val = x_val_h; x_val <<= 8;
x_val += x_val_l;
//----------Y Values-----------------------
int y_val;
//------------------------------- Wire.beginTransmission(i2cID);
Wire.send(outYlow);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1); while(Wire.available())
{
y_val_l = Wire.receive();
}
//-------------------------------
Wire.beginTransmission(i2cID);
Wire.send(outYhigh);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1);
if(Wire.available())
{
y_val_h = Wire.receive();
}
//-------------------------------
y_val = y_val_h; y_val <<= 8;
y_val += y_val_l;
//----------Z Values-----------------------
int z_val;
//------------------------------- Wire.beginTransmission(i2cID);
Wire.send(outZlow);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1); while(Wire.available())
{
z_val_l = Wire.receive();
}
//-------------------------------
Wire.beginTransmission(i2cID);
Wire.send(outZhigh);
Wire.endTransmission();
Wire.requestFrom(i2cID, 1);
if(Wire.available())
{
z_val_h = Wire.receive();
}
//-------------------------------
z_val = z_val_h; z_val <<= 8;
z_val += z_val_l;
Serial.print("x_val= "); Serial.println(x_val, DEC);
Serial.print("y_val= "); Serial.println(y_val, DEC);
Serial.print("z_val= "); Serial.println(z_val, DEC);
delay(250);
}
-----------------
I risultati a video (ogni tanto sollevo e faccio ricadere la board sul tavolo per vedere l'effetto)
lunedì 14 maggio 2012
Connessione I2C su Arduino
Il protocollo I2C e' un sistema seriale a 2 cavi con i quali e' possibile interagire con una serie di sensori
Le resistenze devono essere da almeno 1K ohm (alcuni usano da 1.5-2 K Ohm mentre altri esempi riportano anche 10 K Ohm)
Il Pin 4 analogico dell'Arduino deve essere collegato a SDA (dati) del sensore
Il Pin 5 analogico dell'Arduino deve essere collegato a SCL (clock) del sensore
GND del sensore deve essere collegato ovviamente al GND di Arduino cosi' come VDD al 5 Volts di Arduino
E' possibile usare il BUS I2C per mettere insieme piu' sensori, l'importante e' che ogni sensore abbia il proprio ID univoco
Immagine ripresa da qui anche se la mia attrezzatura e' sostanzialmente identica |
Le resistenze devono essere da almeno 1K ohm (alcuni usano da 1.5-2 K Ohm mentre altri esempi riportano anche 10 K Ohm)
Il Pin 4 analogico dell'Arduino deve essere collegato a SDA (dati) del sensore
Il Pin 5 analogico dell'Arduino deve essere collegato a SCL (clock) del sensore
GND del sensore deve essere collegato ovviamente al GND di Arduino cosi' come VDD al 5 Volts di Arduino
E' possibile usare il BUS I2C per mettere insieme piu' sensori, l'importante e' che ogni sensore abbia il proprio ID univoco
Ripreso da qui |
Iscriviti a:
Post (Atom)
Change Detection with structural similarity
L'idea di base e' quella di cercare le differenze tra le due immagini sottostanti Non e' immediatamente visibile ma ci sono dei ...
-
In questo post viene indicato come creare uno scatterplot dinamico basato da dati ripresi da un file csv (nel dettaglio il file csv e' c...
-
La scheda ESP32-2432S028R monta un Esp Dev Module con uno schermo TFT a driver ILI9341 di 320x240 pixels 16 bit colore.Il sito di riferiment...
-
Questo post e' a seguito di quanto gia' visto nella precedente prova Lo scopo e' sempre il solito: creare un sistema che permet...