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

H3LIS331DL, troosni linearni akcelerometar male snage, visokih performansi, male porodice, koji pripada „nano“porodici, sa digitalnim I²C serijskim interfejsom. H3LIS331DL ima pune skale koje korisnik može odabrati od ± 100g/± 200g/± 400g i sposoban je mjeriti ubrzanja sa izlaznim brzinama podataka od 0,5 Hz do 1 kHz. Zajamčeno je da će H3LIS331DL raditi u proširenom temperaturnom rasponu od -40 ° C do +85 ° C.

U ovom vodiču pokazat ćemo povezivanje H3LIS331DL s fotonom čestica.

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

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:

H3LIS331DL ć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 arduinom, 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

// H3LIS331DL I2C adresa je 0x18 (24)

#define Addr 0x18

int xAccl = 0, yAccl = 0, zAccl = 0;

void setup ()

{

// Postavi varijablu

Particle.variable ("i2cdevice", "H3LIS331DL");

Particle.variable ("xAccl", xAccl);

Particle.variable ("yAccl", yAccl);

Particle.variable ("zAccl", zAccl);

// Inicializirajte I2C komunikaciju kao MASTER

Wire.begin ();

// Pokretanje serijske komunikacije, postavljanje brzine prijenosa = 9600

Serial.begin (9600);

// Pokretanje I2C prijenosa

Wire.beginTransmission (Addr);

// Odabir kontrolnog registra 1

Wire.write (0x20);

// Omogući X, Y, Z os, način uključivanja, izlazna brzina podataka 50Hz

Wire.write (0x27);

// Zaustavljanje I2C prijenosa

Wire.endTransmission ();

// Pokretanje I2C prijenosa

Wire.beginTransmission (Addr);

// Odaberite kontrolni registar 4

Wire.write (0x23);

// Postavljanje pune skale, +/- 100g, kontinuirano ažuriranje

Wire.write (0x00);

// Zaustavljanje 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 ((40 + i));

// Zaustavljanje I2C prijenosa

Wire.endTransmission ();

// Zatražite 1 bajt podataka

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

int xAccl = ((podaci [1] * 256) + podaci [0]);

ako (xAccl> 32767)

{

xAccl -= 65536;

}

int yAccl = ((podaci [3] * 256) + podaci [2]);

ako (yAccl> 32767)

{

yAccl -= 65536;

}

int zAccl = ((podaci [5] * 256) + podaci [4]);

ako (zAccl> 32767)

{

zAccl -= 65536;

}

// 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));

kašnjenje (300);

}

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

Akcelerometri poput H3LIS331DL uglavnom nalaze svoju primjenu u igrama i prebacivanju profila prikaza. Ovaj senzorski modul se takođe koristi u naprednom sistemu upravljanja napajanjem za mobilne aplikacije. H3LIS331DL je troosni digitalni senzor ubrzanja koji je ugrađen u inteligentni kontroler prekida pokretan pokretom na čipu.