Close Menu
  • Articles
    • Learn Electronics
    • Product Review
    • Tech Articles
  • Electronics Circuits
    • 555 Timer Projects
    • Op-Amp Circuits
    • Power Electronics
  • Microcontrollers
    • Arduino Projects
    • STM32 Projects
    • AMB82-Mini IoT AI Camera
    • BLE Projects
  • IoT Projects
    • ESP8266 Projects
    • ESP32 Projects
    • ESP32 MicroPython
    • ESP32-CAM Projects
    • LoRa/LoRaWAN Projects
  • Raspberry Pi
    • Raspberry Pi Projects
    • Raspberry Pi Pico Projects
    • Raspberry Pi Pico W Projects
  • Electronics Calculator
Facebook X (Twitter) Instagram
  • About Us
  • Disclaimer
  • Privacy Policy
  • Contact Us
  • Advertise With Us
Facebook X (Twitter) Instagram Pinterest YouTube LinkedIn
How To Electronics
  • Articles
    • Learn Electronics
    • Product Review
    • Tech Articles
  • Electronics Circuits
    • 555 Timer Projects
    • Op-Amp Circuits
    • Power Electronics
  • Microcontrollers
    • Arduino Projects
    • STM32 Projects
    • AMB82-Mini IoT AI Camera
    • BLE Projects
  • IoT Projects
    • ESP8266 Projects
    • ESP32 Projects
    • ESP32 MicroPython
    • ESP32-CAM Projects
    • LoRa/LoRaWAN Projects
  • Raspberry Pi
    • Raspberry Pi Projects
    • Raspberry Pi Pico Projects
    • Raspberry Pi Pico W Projects
  • Electronics Calculator
How To Electronics
Home » Acceleration Measurement with ADXL375 Accelerometer & ESP32
ESP32 Projects

Acceleration Measurement with ADXL375 Accelerometer & ESP32

Mamtaz AlamBy Mamtaz AlamUpdated:June 28, 20255 Mins Read
Share Facebook Twitter LinkedIn Telegram Reddit WhatsApp
Share
Facebook Twitter LinkedIn Pinterest Email Reddit Telegram WhatsApp

Overview

This tutorial explains how to interface the ADXL375 Accelerometer module with the ESP32 Microcontroller to measure acceleration in the X, Y, and Z axes.

Today, we will introduce you to a very powerful and highly advanced accelerometer called ADXL375, which can measure acceleration up to ±200 g. You might be familiar with accelerometer modules like ADXL335 or ADXL345, as well as MPU6050. Well, these modules are good for simpler projects but fail miserably when working on applications that require high precision, high resolution, and extreme ranges.

ADXL375 Accelerometer
Fig: ADXL375 Accelerometer Module

This is the ADXL375 module, which is a digital MEMS accelerometer from Analog Devices. The sensor is small and thin, with ultra-low power consumption as low as 35 µA in measurement mode.  The best thing about this sensor is that it can measure acceleration up to ±200 g. Imagine reading such a high gravitational pull of the Earth or measuring the acceleration of a very fast-moving object—here, the ADXL375 is perfect.

In this tutorial, we will first go through the ADXL375 features, capabilities, pinout, and other details. Then, we will show you how you can use this sensor with ESP32o using C++ code. You may follow the ADXL375 Arduino guide as well as ADXL375 Raspberry Pi Pico guide.

Components Required

The following are the components required for this tutorial.

S.N.Components NameQuantityPurchase Link
1ESP32 Board1Amazon | AliExpress
2ADXL375 Accelerometer1Amazon | AliExpress
3Connecting Wires10Amazon | AliExpress
4Breadboard1Amazon | AliExpress




ADXL375 Accelerometer

The ADXL375 is a small, thin, 3-axis accelerometer that provides low power consumption and high resolution measurement up to ±200 g.

ADXL375
Fig: ADXL375 Accelerometer Module

The digital output data is formatted as 16-bit, two’s complement data and is accessible through a SPI or I2C digital interface. It supports a bandwidth of up to 1 Kilo Hertz. The bandwidth is selectable via Serial Command. An integrated memory management system with a 32-level FIFO buffer can be used to store data to minimize host processor activity and lower overall system power consumption.

ADXL375 Functional Diagram
Fig: ADXL375 Functional Diagram

The sensor has the ability to determine shock, even, or could be used in an activity or inactivity monitoring system. One shocking thing to notice about this module is, it has a 10,000g shock survival, which is amazing. According to the datasheet, it could be used for concussion and head trauma detection, and also for high-force event detection. To learn more about the ADXL375 Module, you may go through the ADXL375 Datasheet.

ADXL375 Features & Specifications

  • Measurement Range: ±200 g (fixed) with 13-bit two ’s-complement output
  • Sensitivity: 49 mg/LSB (0.049 g/LSB) → ~0.4805 mg resolution when converted to m/s²
  • Power Consumption:
    • Measurement mode: 35 µA typical
    • Standby mode: 0.1 µA typical (VS = 2.5 V)
    • Note: Supply current varies with output data rate/bandwidth setting
  • Output Data Rate / Bandwidth:
    • User-selectable via serial registers
    • Bandwidth up to 1 kHz (ODR up to 1 kHz)
  • FIFO Buffer: 32-sample watermark FIFO reduces host-processor load
  • Event Detection:
    • Single-tap / double-tap (impulse) detection
    • Activity/inactivity monitoring with programmable thresholds & durations
  • Digital Interfaces:
    • I²C (7-bit address = 0x53 when ALT_ADDRESS = LOW)
    • SPI (3- or 4-wire)
  • Supply Voltage: 2.0 V to 3.6 V
  • I/O Voltage Range: 1.7 V to VS
  • Operating Temperature: –40 °C to +85 °C
  • Shock Survivability: 10,000 g (non-operating)
  • Package / RoHS: 3 × 5 × 1 mm LGA, RoHS-compliant




Hardware Connection between ESP32 & ADXL375 Accelerometer

First, let’s perform basic testing of ADXL375 with the ESP32 Microcontroller Board. Here is the simple schematic

ESP32 ADXL375

We can connect the ADXL375 to the ESP32 via the I²C interface. In most of the ESP32 board, the SDA and SCL pins are D21 and D22 respectively.

ADXL375 ESP32 Interfacing

We can simplify the breadboard wiring with jumper cables and ensure the ADXL375 is oriented as shown on the breakout board.

Source Code/Program: Getting ADXL325 ESP32 Acceleration Readings

To develop firmware, we can use the well-written ADXL375 Adafruit library/a>. You can download the repository from GitHub and add it to the Arduino IDE via the Library Manager.

Next, the following code is the modified example sketch for I²C mode.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include <Wire.h>
#include <Adafruit_Sensor.h>
#include <Adafruit_ADXL375.h>
 
// ——— I²C SETUP ———
// Use the “default Wire” constructor (just the sensor ID)
Adafruit_ADXL375 accel = Adafruit_ADXL375(12345);
 
// If you ever need to override the address, you can call begin(0x53) below.
// ALT_ADDRESS pin tied to GND → 0x53.
 
void displayDataRate(void) {
  Serial.print("Data Rate:    ");
  switch (accel.getDataRate()) {
    case ADXL343_DATARATE_3200_HZ: Serial.print("3200 "); break;
    case ADXL343_DATARATE_1600_HZ: Serial.print("1600 "); break;
    case ADXL343_DATARATE_800_HZ:  Serial.print("800 ");  break;
    case ADXL343_DATARATE_400_HZ:  Serial.print("400 ");  break;
    case ADXL343_DATARATE_200_HZ:  Serial.print("200 ");  break;
    case ADXL343_DATARATE_100_HZ:  Serial.print("100 ");  break;
    case ADXL343_DATARATE_50_HZ:   Serial.print("50 ");   break;
    case ADXL343_DATARATE_25_HZ:   Serial.print("25 ");   break;
    case ADXL343_DATARATE_12_5_HZ: Serial.print("12.5 "); break;
    case ADXL343_DATARATE_6_25HZ:  Serial.print("6.25 "); break;
    case ADXL343_DATARATE_3_13_HZ: Serial.print("3.13 "); break;
    case ADXL343_DATARATE_1_56_HZ: Serial.print("1.56 "); break;
    case ADXL343_DATARATE_0_78_HZ: Serial.print("0.78 "); break;
    case ADXL343_DATARATE_0_39_HZ: Serial.print("0.39 "); break;
    case ADXL343_DATARATE_0_20_HZ: Serial.print("0.20 "); break;
    case ADXL343_DATARATE_0_10_HZ: Serial.print("0.10 "); break;
    default:                       Serial.print("???? "); break;
  }
  Serial.println("Hz");
}
 
void setup(void) {
  Serial.begin(115200);
  while (!Serial) delay(10);
  Serial.println("ADXL375 I²C Accelerometer Test");
 
  // Initialize I2C
  Wire.begin();
 
  // Try to start the sensor on address 0x53
  if (!accel.begin(0x53)) {
    Serial.println("Ooops, no ADXL375 detected ... Check your wiring!");
    while (1) delay(10);
  }
 
  // (Optional) change data rate — default is 100 Hz
  accel.setDataRate(ADXL343_DATARATE_100_HZ);
 
  // Note: range is fixed at ±200 g on the ADXL375
 
  Serial.println();
  accel.printSensorDetails();
  displayDataRate();
  Serial.println();
}
 
void loop(void) {
  sensors_event_t event;
  accel.getEvent(&event);
 
  Serial.print("X: "); Serial.print(event.acceleration.x);  Serial.print("  ");
  Serial.print("Y: "); Serial.print(event.acceleration.y);  Serial.print("  ");
  Serial.print("Z: "); Serial.print(event.acceleration.z);  Serial.println(" m/s^2");
  delay(500);
}

Upload this code to the ESP32 Board and then open the Serial monitor. You will see the Acceleration data on the serial monitor for all the x, y, and z axes.

Fig: ADXL375 ESP32 Readings

The x and y data should be almost zero as the sensor is placed on a flat surface. The z-axis data should be almost 9.8 m/s2 due to the gravitational pull of the Earth. But it’s showing some offset readings. That’s why you modified the code for auto calibration.




Source Code/Program: Read ADXL375 Acceleration with Auto Calibration

Here is another code for reading the correct values of acceleration in the x, y, and z axis using the ESP32 and ADXL375

We first average 100 readings with the board held flat to compute x_offset, y_offset, and z_offset = avg_z – 9.80665 m/s². Then, on each loop, we subtract those offsets from the raw readings so that X/Y read ~0 and Z reads ~9.8 m/s² when the sensor is level.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <Wire.h>
#include <Adafruit_Sensor.h>
#include <Adafruit_ADXL375.h>
 
// I²C constructor; we’ll call begin(0x53) below.
Adafruit_ADXL375 accel = Adafruit_ADXL375(12345);
 
// Offsets computed at startup:
float x_offset = 0, y_offset = 0, z_offset = 0;
 
// Helper to print current data rate
void displayDataRate() {
  Serial.print("Data Rate: ");
  switch (accel.getDataRate()) {
    case ADXL343_DATARATE_3200_HZ: Serial.print("3200"); break;
    case ADXL343_DATARATE_1600_HZ: Serial.print("1600"); break;
    case ADXL343_DATARATE_800_HZ:  Serial.print("800");  break;
    case ADXL343_DATARATE_400_HZ:  Serial.print("400");  break;
    case ADXL343_DATARATE_200_HZ:  Serial.print("200");  break;
    case ADXL343_DATARATE_100_HZ:  Serial.print("100");  break;
    case ADXL343_DATARATE_50_HZ:   Serial.print("50");   break;<span data-mce-type="bookmark" style="display: inline-block; width: 0px; overflow: hidden; line-height: 0;" class="mce_SELRES_start"></span>
    case ADXL343_DATARATE_25_HZ:   Serial.print("25");   break;
    case ADXL343_DATARATE_12_5_HZ: Serial.print("12.5"); break;
    default:                       Serial.print("?");    break;
  }
  Serial.println(" Hz");
}
 
void setup() {
  Serial.begin(115200);
  while (!Serial) delay(10);
  Serial.println("ADXL375 I²C Auto-Cal Accelerometer");
 
  // --- I²C on custom ESP32 pins SDA=21, SCL=22 ---
  Wire.begin();
 
  // Start the sensor at address 0x53
  if (!accel.begin(0x53)) {
    Serial.println("ERROR: ADXL375 not found. Check wiring!");
    while (1) delay(10);
  }
 
  // Optional: change from default 100 Hz
  accel.setDataRate(ADXL343_DATARATE_100_HZ);
 
  Serial.println();
  accel.printSensorDetails();
  displayDataRate();
  Serial.println();
 
  // --- AUTO CALIBRATION ---
  Serial.println("Calibrating... keep sensor FLAT and STILL");
  const int SAMPLES = 100;
  float sum_x = 0, sum_y = 0, sum_z = 0;
  sensors_event_t evt;
  for (int i = 0; i < SAMPLES; i++) {
    accel.getEvent(&evt);
    sum_x += evt.acceleration.x;
    sum_y += evt.acceleration.y;
    sum_z += evt.acceleration.z;
    delay(20);
  }
  float avg_x = sum_x / SAMPLES;
  float avg_y = sum_y / SAMPLES;
  float avg_z = sum_z / SAMPLES;
 
  // X/Y → zero; Z → 1 g
  x_offset = avg_x;
  y_offset = avg_y;
  z_offset = avg_z - SENSORS_GRAVITY_STANDARD;
 
  Serial.print("X offset = "); Serial.println(x_offset, 4);
  Serial.print("Y offset = "); Serial.println(y_offset, 4);
  Serial.print("Z offset = "); Serial.println(z_offset, 4);
  Serial.println("Calibration done!\n");
}
 
void loop() {
  sensors_event_t evt;
  accel.getEvent(&evt);
 
  // apply offsets
  float x = evt.acceleration.x - x_offset;
  float y = evt.acceleration.y - y_offset;
  float z = evt.acceleration.z - z_offset;
 
  Serial.print("X: "); Serial.print(x, 2);
  Serial.print("  Y: "); Serial.print(y, 2);
  Serial.print("  Z: "); Serial.print(z, 2);
  Serial.println(" m/s^2");
 
  delay(500);
}




Upload this code again to the ESP32 Board. The reading will be correct now.

Fig: ADXL375 ESP32 Calibrated Readings

To observe the change in reading, shake the sensor or move the sensor, or jerk it. You will see a massive change in the reading.

Fig: ADXL375 ESP32 acceleration test readings
Share. Facebook Twitter Pinterest LinkedIn Tumblr Email Reddit Telegram WhatsApp
Previous ArticleInterfacing ADXL375 Accelerometer with Arduino (±200g)
Next Article Securing IoT Devices With Microchip ATECC608A

Related Posts

IoT Based PM & Air Quality Monitoring System using ESP32

IoT Based PM & Air Quality Monitoring System using ESP32

DIY ESP32 MLX90640 IR Thermal Camera with Live Web Display

DIY ESP32 MLX90640 IR Thermal Camera with Live Web Display

Updated:May 10, 20261K
IoT Activity Tracker with ESP32 & Accelerometer Gyroscope

IoT Activity Tracker with ESP32 & Accelerometer/Gyroscope

Updated:May 2, 2026

ESP32 IoT Vehicle Motion Analyzer with MPU6050 & LIS3MDL

Updated:April 27, 20261K
High-Accuracy Pitch, Roll, Yaw with ESP32 & BNO08x IMU

High-Accuracy Pitch, Roll, Yaw with ESP32 & BNO08x IMU

Updated:April 27, 20262K
DIY Colorimeter using AS7265x Spectroscopy Sensor & ESP32

DIY Colorimeter using AS7265x Spectroscopy Sensor & ESP32

Updated:February 1, 20261K
Add A Comment

CommentsCancel reply

Latest Posts
IoT Based PM & Air Quality Monitoring System using ESP32

IoT Based PM & Air Quality Monitoring System using ESP32

May 31, 2026
DIY ESP32 MLX90640 IR Thermal Camera with Live Web Display

DIY ESP32 MLX90640 IR Thermal Camera with Live Web Display

May 10, 2026
IoT Activity Tracker with ESP32 & Accelerometer Gyroscope

IoT Activity Tracker with ESP32 & Accelerometer/Gyroscope

May 2, 2026
A Guide to Sourcing Obsolete ICs for Vintage Projects

Beyond AliExpress: A Guide to Sourcing Obsolete ICs for Vintage Projects

April 21, 2026

ESP32 IoT Vehicle Motion Analyzer with MPU6050 & LIS3MDL

April 27, 2026
Building a Smart Sensor Node with a BLE Microcontroller

Building a Smart Sensor Node with a BLE Microcontroller

February 26, 2026
High-Accuracy Pitch, Roll, Yaw with ESP32 & BNO08x IMU

High-Accuracy Pitch, Roll, Yaw with ESP32 & BNO08x IMU

April 27, 2026
DIY Colorimeter using AS7265x Spectroscopy Sensor & ESP32

DIY Colorimeter using AS7265x Spectroscopy Sensor & ESP32

February 1, 2026
Top Posts & Pages
  • How to use INA226 DC Current Sensor with Arduino
    How to use INA226 DC Current Sensor with Arduino
  • Buck Converter: Basics, Working, Design & Application
    Buck Converter: Basics, Working, Design & Application
  • How to use INA219 DC Current Sensor Module with Arduino
    How to use INA219 DC Current Sensor Module with Arduino
  • Designing of MPPT Solar Charge Controller using Arduino
    Designing of MPPT Solar Charge Controller using Arduino
  • 12V DC to 220V AC Inverter Circuit & PCB
    12V DC to 220V AC Inverter Circuit & PCB
  • How to use Modbus RTU with ESP32 to read Sensor Data
    How to use Modbus RTU with ESP32 to read Sensor Data
  • IoT AC Energy Meter with PZEM-004T & ESP32 WebServer
    IoT AC Energy Meter with PZEM-004T & ESP32 WebServer
  • ECG Graph Monitoring with AD8232 ECG Sensor & Arduino
    ECG Graph Monitoring with AD8232 ECG Sensor & Arduino
Categories
  • Arduino Projects (197)
  • Articles (60)
    • Learn Electronics (19)
    • Product Review (15)
    • Tech Articles (28)
  • Electronics Circuits (46)
    • 555 Timer Projects (21)
    • Op-Amp Circuits (7)
    • Power Electronics (13)
  • IoT Projects (204)
    • ESP32 MicroPython (7)
    • ESP32 Projects (81)
    • ESP32-CAM Projects (15)
    • ESP8266 Projects (76)
    • LoRa/LoRaWAN Projects (22)
  • Microcontrollers (38)
    • AMB82-Mini IoT AI Camera (4)
    • BLE Projects (18)
    • STM32 Projects (19)
  • Raspberry Pi (93)
    • Raspberry Pi Pico Projects (57)
    • Raspberry Pi Pico W Projects (12)
    • Raspberry Pi Projects (24)
Follow Us
  • Facebook
  • Twitter
  • Pinterest
  • Instagram
  • YouTube
About Us

“‘How to Electronics’ is a vibrant community for electronics enthusiasts and professionals. We deliver latest insights in areas such as Embedded Systems, Power Electronics, AI, IoT, and Robotics. Our goal is to stimulate innovation and provide practical solutions for students, organizations, and industries. Join us to transform learning into a joyful journey of discovery and innovation.

Copyright © How To Electronics. All rights reserved.
  • About Us
  • Disclaimer
  • Privacy Policy
  • Contact Us
  • Advertise With Us

Type above and press Enter to search. Press Esc to cancel.

Ad Blocker Enabled!
Ad Blocker Enabled!
Looks like you're using an ad blocker. Please allow ads on our site. We rely on advertising to help fund our site.