Inhoudsopgave:
2025 Auteur: John Day | [email protected]. Laatst gewijzigd: 2025-01-13 06:57
De ADXL345 is een kleine, dunne, ultralaag vermogen, 3-assige accelerometer met hoge resolutie (13-bits) meting tot ±16 g. Digitale uitvoergegevens zijn geformatteerd als 16-bits tweetallen en zijn toegankelijk via de digitale I2 C-interface. Het meet de statische versnelling van de zwaartekracht in toepassingen met kanteldetectie, evenals dynamische versnelling als gevolg van beweging of schokken. De hoge resolutie (3,9 mg/LSB) maakt het mogelijk om hellingsveranderingen van minder dan 1,0° te meten.
In deze tutorial is de interface van de ADXL345 sensormodule met deeltjesfoton geïllustreerd. Om de versnellingswaarden uit te lezen hebben we deeltje met een I2c-adapter gebruikt. Deze I2C-adapter maakt de aansluiting op de sensormodule eenvoudig en betrouwbaarder.
Stap 1: Benodigde hardware:
De materialen die we nodig hebben om ons doel te bereiken, omvatten de volgende hardwarecomponenten:
1. ADXL345
2. Deeltjesfoton
3. I2C-kabel
4. I2C Shield voor deeltjesfoton
Stap 2: Hardware-aansluiting:
De hardware-aansluitingssectie legt in feite de bedradingsverbindingen uit die nodig zijn tussen de sensor en het deeltjesfoton. Zorgen voor correcte verbindingen is de basisbehoefte bij het werken aan elk systeem voor de gewenste output. De vereiste verbindingen zijn dus als volgt:
De ADXL345 werkt via I2C. Hier is het voorbeeldbedradingsschema, dat laat zien hoe elke interface van de sensor moet worden aangesloten.
Out-of-the-box, het bord is geconfigureerd voor een I2C-interface, daarom raden we aan om deze aansluiting te gebruiken als je verder agnostisch bent.
Alles wat je nodig hebt zijn vier draden! Er zijn slechts vier aansluitingen nodig Vcc, Gnd, SCL en SDA-pinnen en deze worden verbonden met behulp van I2C-kabel.
Deze verbindingen worden gedemonstreerd in de bovenstaande afbeeldingen.
Stap 3: Code voor het meten van versnelling:
Laten we nu beginnen met de deeltjescode.
Terwijl we de sensormodule met het deeltje gebruiken, nemen we de bibliotheek application.h en spark_wiring_i2c.h op. "application.h" en spark_wiring_i2c.h bibliotheek bevat de functies die de i2c-communicatie tussen de sensor en het deeltje vergemakkelijken.
De volledige deeltjescode wordt hieronder gegeven voor het gemak van de gebruiker:
#erbij betrekken
#erbij betrekken
// ADXL345 I2C-adres is 0x53(83)
#define Addr 0x53
int xAccl = 0, yAccl = 0, zAccl = 0;
ongeldige setup()
{
// Variabele instellen
Particle.variable ("i2cdevice", "ADXL345");
Particle.variable("xAccl", xAccl);
Particle.variable("yAccl", yAccl);
Particle.variable("zAccl", zAccl);
// Initialiseer I2C-communicatie als MASTER
Draad.begin();
// Initialiseer seriële communicatie, stel baudrate in = 9600
Serieel.begin(9600);
// Start I2C-transmissie
Wire.beginTransmission (Addr);
// Selecteer bandbreedte tariefregister
Draad.schrijven (0x2C);
// Selecteer uitvoer datasnelheid = 100 Hz
Draad.schrijven (0x0A);
// Stop I2C-verzending
Wire.endTransmission();
// Start I2C-transmissie
Wire.beginTransmission (Addr);
// Selecteer vermogensbeheerregister
Draad.schrijven (0x2D);
// Selecteer automatische slaapuitschakeling
Draad.schrijven (0x08);
// Stop I2C-transmissie
Wire.endTransmission();
// Start I2C-transmissie
Wire.beginTransmission (Addr);
// Selecteer dataformaat register
Draad.schrijven (0x31);
// Selecteer volledige resolutie, +/- 2g
Draad.schrijven (0x08);
// Einde I2C-transmissie
Wire.endTransmission();
vertraging (300);
}
lege lus()
{
niet-ondertekende int-gegevens[6];
for(int i = 0; i < 6; i++)
{
// Start I2C-transmissie
Wire.beginTransmission (Addr);
// Selecteer dataregister
Wire.write((50+i));
// Stop I2C-transmissie
Wire.endTransmission();
// Vraag 1 byte aan gegevens van het apparaat aan
Wire.requestFrom(Addr, 1);
// Lees 6 bytes aan gegevens
// xAccl lsb, xAccl msb, yAccl lsb, yAccl msb, zAccl lsb, zAccl msb
if(Draad.beschikbaar()==1)
{
data = Wire.read();
}
vertraging (300);
}
// Converteer de gegevens naar 10-bits
int xAccl = (((data[1] & 0x03) * 256) + data[0]);
if(xAccl > 511)
{
xAccl -= 1024;
}
int yAccl = (((data[3] & 0x03) * 256) + data[2]);
if(yAccl > 511)
{
yAccl -= 1024;
}
int zAccl = (((gegevens[5] & 0x03) * 256) + gegevens[4]);
if(zAccl > 511)
{
zAccl -= 1024;
}
// Gegevens uitvoeren naar dashboard
Particle.publish("Versnelling in X-as is:", String(xAccl));
Particle.publish("Versnelling in de Y-as is:", String(yAccl));
Particle.publish("Versnelling in de Z-as is:", String(zAccl));
}
De functie Particle.variable() maakt de variabelen om de uitvoer van de sensor op te slaan en de functie Particle.publish() geeft de uitvoer weer op het dashboard van de site.
De sensoruitgang wordt ter referentie in de afbeelding hierboven weergegeven.
Stap 4: Toepassingen:
ADXL345 is een kleine, dunne 3-assige accelerometer met ultralaag vermogen die kan worden gebruikt in handsets, medische instrumenten enz. De toepassing ervan omvat ook gaming- en aanwijsapparaten, industriële instrumenten, persoonlijke navigatieapparatuur en bescherming van de harde schijf (HDD).