Library containing Crazyflie 2.0 controller classes: - Attitude estimator - Horizontal estimator - Vertical estimator - Attitude controller - Horizontal controller - Vertical controller - Mixer
AttitudeEstimator/AttitudeEstimator.cpp
- Committer:
- fbob
- Date:
- 2018-08-31
- Revision:
- 0:b1f2c9e88e32
- Child:
- 1:24effec9e9aa
File content as of revision 0:b1f2c9e88e32:
#include "mbed.h" #include "AttitudeEstimator.h" // Class constructor AttitudeEstimator::AttitudeEstimator() : imu(PC_9,PA_8) { } // Initialize class void AttitudeEstimator::init() { // Initialize IMU sensor object imu.init(); // Calibrate gyroscope calibrate_gyro(); } // Estimate euler angles (rad) and angular velocity (rad/s) void AttitudeEstimator::estimate() { // Read IMU sensor data imu.read(); // Estimate Euler angles (rad) and angular velocities (rad/s) from accelerometer and gyroscope data estimate_accel(); estimate_gyro(); // phi = phi_accel*rho + phi_gyro*(1.0f-rho); theta = theta_accel*rho + theta_gyro*(1.0f-rho); } // Estimate Euler angles (rad) from accelerometer data void AttitudeEstimator::estimate_accel() { // Estimate Euler angles (rad) phi_accel = atan2(-imu.ay,-imu.az); theta_accel = atan2(imu.ax,-imu.az); } // Estimate Euler angles (rad) and angular velocities (rad/s) from gyroscope data void AttitudeEstimator::estimate_gyro() { // Estimate angular velocities (rad/s) p = imu.gx - p_bias; q = imu.gy - q_bias; r = imu.gz - r_bias; // Estimate Euler angles (rad) phi_gyro = phi + p*dt; theta_gyro = theta + q*dt; psi = psi + r*dt; } // Calibrates gyroscope by calculating angular velocity bias (rad/s) void AttitudeEstimator::calibrate_gyro() { // Reser angular velocites bias (rad/s) p_bias = 0.0f; q_bias = 0.0f; r_bias = 0.0f; // Calculate angular velocities bias (rad/s) by averaging 200 samples in 1 second for(int i = 0; i<200;i++) { imu.read(); p_bias += imu.gx/200.0f; q_bias += imu.gy/200.0f; r_bias += imu.gz/200.0f; wait(0.005); } }