Accessing Accelerometer Data on Nano 33 BLE Rev2
Learn how to measure the relative position of the Nano 33 BLE Rev2 through the BMi270 and BMM150 IMU system.
This tutorial will focus on the IMU system with the BMI270 and BMM150 modules on the Arduino Nano 33 BLE Rev2, to measure the relative position of the board. This will be achieved by utilizing the values of the accelerometer's axes and later printing the return values through the Arduino IDE Serial Monitor.
Goals
The goals of this project are:
- Understand how the IMU system on the Nano 33 BLE Rev2 works.
- Use the BMI270_BMM150 library.
- Read the raw data of the accelerometer sensor.
- Convert the raw data into board positions.
- Print out live data through the Serial Monitor.
Hardware & Software Needed
- This project uses no external sensors or components apart from the Arduino Nano 33 BLE Rev2.
- In this tutorial, we will use the Arduino Cloud Editor to program the board.
The IMU System on Nano 33 BLE Rev2
IMU (Inertial Measurement Unit) is an electronic device that measures and reports a body's specific force, angular rate and the orientation of the body, using a combination of accelerometers, gyroscopes, and oftentimes magnetometers. In this tutorial, we will learn about the IMU system that is included in the Nano 33 BLE Rev2 Board.
The IMU system on the Nano 33 BLE Rev2 is a combination of two modules, the 6-axis BMI270, and the 3-axis BMM150, that together add up to a combined 9-axis IMU system that can measure acceleration, as well as rotation and magnetic fields all in 3D space.
The BMI270_BMM150 Library
The Arduino BMI270_BMM150 library allows us to use the Nano 33 BLE Rev2 IMU system without having to go into complicated programming. The library takes care of the sensor initialization and sets its values as follows:
- Accelerometer range is set at [-4, +4]g -/+0.122 mg.
- Gyroscope range is set at [-2000, +2000] dps +/-70 mdps.
- Magnetometer range is set at [-400, +400] uT +/-0.014 uT.
- Accelerometer Output data rate is fixed at 104 Hz.
- Gyroscope Output data rate is fixed at 104 Hz.
- Magnetometer Output data rate is fixed at 20 Hz.
If you want to read more about the sensor modules that make up the IMU system, find the datasheet for the BMI270 and the BMM150 here.
Accelerometer
An accelerometer is an electromechanical device used to measure acceleration forces. Such forces may be static, like the continuous force of gravity or, as is the case with many mobile devices, dynamic to movement or vibrations.
In this example, we will use the accelerometer as a "level" that will provide information about the position of the board. With this application, we will be able to read the relative position of the board as well as the degrees, by tilting the board up, down, left or right.
Creating the Program
1. Setting up
Let's start by opening the Arduino Cloud Editor, clicking on the Libraries tab and searching for the BMI270_BMM150 library. Then in > Examples, open the SimpleAccelerometer sketch and once it opens, rename it as Accelerometer.
2. Connecting the board
Now, connect the Arduino Nano 33 BLE Rev2 to the computer and make sure that the Cloud Editor recognizes it, if so, the board and port should appear as shown in the image below. If they don't appear, follow the instructions to install the plugin that will allow the editor to recognize your board.
3. Printing the relative position
Now we will need to modify the code on the example, to print the relative position of the board as we move it in different angles.
Let's start by initializing the x, y, and z axes as
float
data types, and the int degreesX = 0;
and int degreesY = 0;
variables before the setup()
.In the
setup()
we should remove the following lines of code:1Serial.println();2Serial.println("Acceleration in G's");3Serial.println("X\tY\tZ");
Since the raw values of the three axes will not be required, we can remove the lines that will print these. Similarly, we should remove the following lines from the
loop()
:1Serial.print(x);2Serial.print('\t');3Serial.print(y);4Serial.print('\t');5Serial.println(z);
Instead, in the
loop()
we tell the sensor to begin reading the values for the three axes. In this example we will not be using the readings from the Z axis as it is not required for this application to function, therefore you could remove it.After the
IMU.readAcceleration
initialization, we add four if
statements for the board's different positions. The statements will calculate the direction in which the board will be tilting, as well as provide the axe's degree values.1if(x > 0.1){2 x = 100*x;3 degreesX = map(x, 0, 97, 0, 90);4 Serial.print("Tilting up ");5 Serial.print(degreesX);6 Serial.println(" degrees");7 }8 if(x < -0.1){9 x = 100*x;10 degreesX = map(x, 0, -100, 0, 90);11 Serial.print("Tilting down ");12 Serial.print(degreesX);13 Serial.println(" degrees");14 }15 if(y > 0.1){16 y = 100*y;17 degreesY = map(y, 0, 97, 0, 90);18 Serial.print("Tilting left ");19 Serial.print(degreesY);20 Serial.println(" degrees");21 }22 if(y < -0.1){23 y = 100*y;24 degreesY = map(y, 0, -100, 0, 90);25 Serial.print("Tilting right ");26 Serial.print(degreesY);27 Serial.println(" degrees");28 }
Lastly, we print the values in the serial monitor add a
delay(1000);
.Note: For the following code to properly work, the board's facing direction and inclination during the initialization of the code, need to be specific. More information will be shared on the "testing it out" section.
4. Complete code
If you choose to skip the code-building section, the complete code can be found below:
1/*2 Arduino BMI270_BMM150 - Simple Accelerometer3
4 This example reads the acceleration values from the BMI270_BMM1505 sensor and continuously prints them to the Serial Monitor6 or Serial Plotter.7
8 The circuit:9 - Arduino Nano 33 BLE Rev210
11 created 10 Jul 201912 by Riccardo Rizzo13
14 This example code is in the public domain.15*/16
17#include "Arduino_BMI270_BMM150.h"18
19float x, y, z;20int degreesX = 0;21int degreesY = 0;22
23void setup() {24 Serial.begin(9600);25 while (!Serial);26 Serial.println("Started");27
28 if (!IMU.begin()) {29 Serial.println("Failed to initialize IMU!");30 while (1);31 }32
33 Serial.print("Accelerometer sample rate = ");34 Serial.print(IMU.accelerationSampleRate());35 Serial.println(" Hz");36}37
38void loop() {39 float x, y, z;40
41 if (IMU.accelerationAvailable()) {42 IMU.readAcceleration(x, y, z);43
44if(x > 0.1){45 x = 100*x;46 degreesX = map(x, 0, 97, 0, 90);47 Serial.print("Tilting up ");48 Serial.print(degreesX);49 Serial.println(" degrees");50 }51 if(x < -0.1){52 x = 100*x;53 degreesX = map(x, 0, -100, 0, 90);54 Serial.print("Tilting down ");55 Serial.print(degreesX);56 Serial.println(" degrees");57 }58 if(y > 0.1){59 y = 100*y;60 degreesY = map(y, 0, 97, 0, 90);61 Serial.print("Tilting left ");62 Serial.print(degreesY);63 Serial.println(" degrees");64 }65 if(y < -0.1){66 y = 100*y;67 degreesY = map(y, 0, -100, 0, 90);68 Serial.print("Tilting right ");69 Serial.print(degreesY);70 Serial.println(" degrees");71 }72 }73}74
75}
Testing It Out
To get a correct reading of the board data, before uploading the sketch to the board hold the board in your hand, from the side of the USB port. The board should be facing up and "pointing" away from you. The image below illustrates the board's position and how it works:
Now, you can verify and upload the sketch to the board and open the Monitor from the menu on the left.
If you tilt the board upwards, downwards, right or left, you will see the results printing every second according to the direction of your movement!
Here is a screenshot of the sketch returning these values:
Troubleshoot
Sometimes errors occur, if the code is not working there are some common issues we can troubleshoot:
- Missing a bracket or a semicolon.
- The Arduino board is connected to the wrong port.
- Accidental interruption of cable connection.
- The initial position of the board is not as instructed. In this case, you can refresh the page and try again.
Conclusion
In this simple tutorial, we learned what an IMU sensor module is, how to use the BMI270_BMM150 library, and how to use an Arduino Nano 33 BLE Rev2 to get data. Furthermore, we utilized the 3-axis accelerometer sensor, in order to measure and print out the degrees and relative position of the board.
Suggest changes
The content on docs.arduino.cc is facilitated through a public GitHub repository. If you see anything wrong, you can edit this page here.
License
The Arduino documentation is licensed under the Creative Commons Attribution-Share Alike 4.0 license.