Files
J1B4-Fitbot/code/arduino/Movement-sensor-code/Movement-sensor-code.ino

34 lines
1.0 KiB
C++

#include "SensorManager.h"
SensorManager sensorManager;
void setup() {
Wire.setClockStretchLimit(150000L); // Default stretch limit 150mS
Serial.begin(9600);
Serial.println("startup");
delay(10000);
sensorManager.sensorSetup();
}
void loop() {
SensorManager::Rotation rotation = sensorManager.readLoop();
// Convert quaternion to Euler angles in radians
float roll = atan2(2.0f * (rotation.w * rotation.i + rotation.j * rotation.k), 1.0f - 2.0f * (rotation.i * rotation.i + rotation.j * rotation.j));
float pitch = asin(2.0f * (rotation.w * rotation.j - rotation.k * rotation.i));
float yaw = atan2(2.0f * (rotation.w * rotation.k + rotation.i * rotation.j), 1.0f - 2.0f * (rotation.j * rotation.j + rotation.k * rotation.k));
// Convert to degrees
float rollDegrees = roll * 180.0f / PI;
float pitchDegrees = pitch * 180.0f / PI;
float yawDegrees = yaw * 180.0f / PI;
Serial.print(roll);
Serial.print(" ");
Serial.print(pitch);
Serial.print(" ");
Serial.print(yaw);
Serial.println();
}