Sadržaj:
2025 Autor: John Day | [email protected]. Zadnja promjena: 2025-01-13 06:57
ADXL345 je mali, tanki, troosni akcelerometar ultra male snage s mjerenjima visoke razlučivosti (13 bita) do ± 16 g. Digitalni izlazni podaci oblikovani su kao 16-bitne dvojke nadopunjeni i dostupni su putem I2 C digitalnog sučelja. Mjeri statičko ubrzanje gravitacije u aplikacijama osjetljivog nagiba, kao i dinamičko ubrzanje koje je posljedica kretanja ili udara. Njegova visoka razlučivost (3,9 mg/LSB) omogućuje mjerenje promjena nagiba manjih od 1,0 °.
U ovom vodiču prikazano je povezivanje senzorskog modula ADXL345 s fotonom čestica. Za očitavanje vrijednosti ubrzanja koristili smo čestice s I2c adapterom. Ovaj I2C adapter čini povezivanje s senzorskim modulom lakim i pouzdanijim.
Korak 1: Potreban hardver:
Materijali koji su nam potrebni za postizanje našeg cilja uključuju sljedeće hardverske komponente:
1. ADXL345
2. Foton čestica
3. I2C kabel
4. I2C štit za foton čestica
2. korak: Spajanje hardvera:
Odjeljak hardverskog spajanja u osnovi objašnjava potrebne ožičenje između senzora i fotona čestica. Osiguravanje ispravnih veza osnovna je potreba tijekom rada na bilo kojem sustavu za željeni izlaz. Dakle, potrebne veze su sljedeće:
ADXL345 će raditi preko I2C. Evo primjera dijagrama ožičenja koji pokazuje kako spojiti svako sučelje senzora.
Out-of-box, ploča je konfigurirana za I2C sučelje, pa kao takvu preporučujemo korištenje ove veze ako ste inače agnostični.
Sve što trebate su četiri žice! Potrebna su samo četiri priključka Vcc, Gnd, SCL i SDA pinovi koji se povezuju pomoću I2C kabela.
Ove veze su prikazane na gornjim slikama.
Korak 3: Kôd za mjerenje ubrzanja:
Počnimo sada s kodom čestica.
Dok koristimo senzorski modul s česticom, uključujemo knjižnicu application.h i spark_wiring_i2c.h. Knjižnica "application.h" i spark_wiring_i2c.h sadrži funkcije koje olakšavaju i2c komunikaciju između senzora i čestice.
Cijeli kod čestica dat je u nastavku radi praktičnosti korisnika:
#uključi
#uključi
// ADXL345 I2C adresa je 0x53 (83)
#define Addr 0x53
int xAccl = 0, yAccl = 0, zAccl = 0;
void setup ()
{
// Postavi varijablu
Particle.variable ("i2cdevice", "ADXL345");
Čestica.varijabilna ("xAccl", xAccl);
Čestica.varijabilna ("yAccl", yAccl);
Čestica.varijabilna ("zAccl", zAccl);
// Inicializirajte I2C komunikaciju kao MASTER
Wire.begin ();
// Pokretanje serijske komunikacije, postavljena brzina prijenosa = 9600
Serial.begin (9600);
// Pokretanje I2C prijenosa
Wire.beginTransmission (Addr);
// Odaberite registar stope propusnosti
Wire.write (0x2C);
// Odaberite brzinu izlaznih podataka = 100 Hz
Wire.write (0x0A);
// Zaustavljanje I2C prijenosa
Wire.endTransmission ();
// Pokretanje I2C prijenosa
Wire.beginTransmission (Addr);
// Odaberite registar za kontrolu snage
Wire.write (0x2D);
// Odaberite automatsko onemogućivanje mirovanja
Wire.write (0x08);
// Zaustavljanje I2C prijenosa
Wire.endTransmission ();
// Pokretanje I2C prijenosa
Wire.beginTransmission (Addr);
// Odabir registra formata podataka
Wire.write (0x31);
// Odaberite punu razlučivost, +/- 2g
Wire.write (0x08);
// Završetak I2C prijenosa
Wire.endTransmission ();
kašnjenje (300);
}
void loop ()
{
nepotpisani int podaci [6];
za (int i = 0; i <6; i ++)
{
// Pokretanje I2C prijenosa
Wire.beginTransmission (Addr);
// Odabir registra podataka
Wire.write ((50+i));
// Zaustavljanje I2C prijenosa
Wire.endTransmission ();
// Zatražite 1 bajt podataka s uređaja
Wire.requestFrom (Addr, 1);
// Očitavanje 6 bajtova podataka
// xAccl lsb, xAccl msb, yAccl lsb, yAccl msb, zAccl lsb, zAccl msb
if (Wire.available () == 1)
{
podaci = Wire.read ();
}
kašnjenje (300);
}
// Pretvorimo podatke u 10-bitne
int xAccl = (((podaci [1] & 0x03) * 256) + podaci [0]);
ako (xAccl> 511)
{
xAccl -= 1024;
}
int yAccl = (((podaci [3] & 0x03) * 256) + podaci [2]);
ako (yAccl> 511)
{
yAccl -= 1024;
}
int zAccl = (((podaci [5] & 0x03) * 256) + podaci [4]);
ako (zAccl> 511)
{
zAccl -= 1024;
}
// Izlaženje podataka na nadzornu ploču
Particle.publish ("Ubrzanje u osi X je:", niz (xAccl));
Particle.publish ("Ubrzanje u osi Y je:", niz (yAccl));
Particle.publish ("Ubrzanje u Z-osi je:", String (zAccl));
}
Funkcija Particle.variable () stvara varijable za spremanje rezultata senzora, a funkcija Particle.publish () prikazuje izlaz na nadzornoj ploči web mjesta.
Izlaz senzora prikazan je na gornjoj slici za vašu referencu.
Korak 4: Aplikacije:
ADXL345 je mali, tanki, troosni akcelerometar ultra male snage koji se može koristiti u mobilnim slušalicama, medicinskim instrumentima itd. Njegova primjena također uključuje igraće i pokazivačke uređaje, industrijske instrumente, osobne navigacijske uređaje i zaštitu tvrdog diska (HDD).