Sadržaj:
2025 Autor: John Day | [email protected]. Zadnja izmjena: 2025-01-13 06:57
ADXL345 je mali, tanak, troosni akcelerometar ultra male snage sa mjerenjima visoke rezolucije (13 bita) do ± 16 g. Digitalni izlazni podaci formatirani su kao 16-bitne dvojke i dopunjeni su i dostupni su preko I2 C digitalnog sučelja. Mjeri statičko ubrzanje gravitacije u aplikacijama osjetljivog nagiba, kao i dinamičko ubrzanje koje je rezultat kretanja ili udara. Njegova visoka rezolucija (3,9 mg/LSB) omogućuje mjerenje promjena nagiba manjih od 1,0 °.
U ovom vodiču prikazano je povezivanje senzorskog modula ADXL345 sa fotonom čestica. Za očitavanje vrijednosti ubrzanja koristili smo čestice s I2c adapterom. Ovaj I2C adapter čini povezivanje sa 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
Korak 2: Povezivanje hardvera:
Odeljak za priključivanje hardvera u osnovi objašnjava potrebne ožičenje između senzora i fotona čestica. Osiguravanje ispravnih veza osnovna je potreba pri radu na bilo kojem sistemu 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 biblioteku application.h i spark_wiring_i2c.h. Biblioteka "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:
#include
#include
// ADXL345 I2C adresa je 0x53 (83)
#define Addr 0x53
int xAccl = 0, yAccl = 0, zAccl = 0;
void setup ()
{
// Postavi varijablu
Particle.variable ("i2cdevice", "ADXL345");
Particle.variable ("xAccl", xAccl);
Particle.variable ("yAccl", yAccl);
Particle.variable ("zAccl", zAccl);
// Inicializirajte I2C komunikaciju kao MASTER
Wire.begin ();
// Pokrećemo serijsku komunikaciju, postavljena brzina prijenosa = 9600
Serial.begin (9600);
// Pokretanje I2C prijenosa
Wire.beginTransmission (Addr);
// Odabir registra 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);
// Odabir registra kontrole snage
Wire.write (0x2D);
// Odaberite automatsko onemogućavanje spavanja
Wire.write (0x08);
// Zaustavljanje I2C prijenosa
Wire.endTransmission ();
// Pokretanje I2C prijenosa
Wire.beginTransmission (Addr);
// Odabir registra formata podataka
Wire.write (0x31);
// Odaberite punu rezoluciju, +/- 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 od 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:", String (xAccl));
Particle.publish ("Ubrzanje u osi Y je:", String (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 stranice.
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čke i pokazivačke uređaje, industrijske instrumente, lične navigacijske uređaje i zaštitu tvrdog diska (HDD).