Mjerenje ubrzanja pomoću ADXL345 i fotona čestica: 4 koraka
Mjerenje ubrzanja pomoću ADXL345 i fotona čestica: 4 koraka
Anonim
Image
Image

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:

Potreban hardver
Potreban hardver
Potreban hardver
Potreban hardver
Potreban hardver
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:

Povezivanje hardvera
Povezivanje hardvera
Povezivanje hardvera
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:

Kôd za mjerenje ubrzanja
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:

Prijave
Prijave

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).