MAV'RIC
|
00001 /******************************************************************************* 00002 * Copyright (c) 2009-2016, MAV'RIC Development Team 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright notice, 00009 * this list of conditions and the following disclaimer. 00010 * 00011 * 2. Redistributions in binary form must reproduce the above copyright notice, 00012 * this list of conditions and the following disclaimer in the documentation 00013 * and/or other materials provided with the distribution. 00014 * 00015 * 3. Neither the name of the copyright holder nor the names of its contributors 00016 * may be used to endorse or promote products derived from this software without 00017 * specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 ******************************************************************************/ 00031 00032 /******************************************************************************* 00033 * \file qfilter.h 00034 * 00035 * \author MAV'RIC Team 00036 * \author Felix Schill 00037 * 00038 * \brief This file implements a complementary filter for the attitude estimation 00039 * 00040 ******************************************************************************/ 00041 00042 00043 #ifndef QFILTER_HPP_ 00044 #define QFILTER_HPP_ 00045 00046 #include <cstdint> 00047 00048 #include "sensing/ahrs.hpp" 00049 #include "sensing/imu.hpp" 00050 00051 00055 class AHRS_qfilter: public AHRS 00056 { 00057 public: 00061 struct conf_t 00062 { 00063 float kp; 00064 float ki; 00065 float kp_mag; 00066 float ki_mag; 00067 }; 00068 00069 00070 static inline conf_t default_config() 00071 { 00072 conf_t conf = {}; 00073 00074 conf.kp = 0.07f; 00075 conf.ki = 0.0f; 00076 conf.kp_mag = 0.1f; 00077 conf.ki_mag = 0.0f; 00078 00079 return conf; 00080 }; 00081 00082 00089 AHRS_qfilter(const Imu& imu, const conf_t& config = default_config()); 00090 00091 00095 bool update(void); 00096 00097 00103 float last_update_s(void) const; 00104 00105 00113 bool is_healthy(void) const; 00114 00115 00121 quat_t attitude(void) const; 00122 00123 00129 std::array<float,3> angular_speed(void) const; 00130 00131 00137 std::array<float,3> linear_acceleration(void) const; 00138 00139 00140 protected: 00141 const Imu& imu_; 00142 00143 quat_t attitude_; 00144 std::array<float,3> angular_speed_; 00145 std::array<float,3> linear_acc_; 00146 float last_update_s_; 00147 00148 private: 00149 ahrs_state_t internal_state_; 00150 00151 float kp_; 00152 float ki_; 00153 float kp_mag_; 00154 float ki_mag_; 00155 00156 float time_s_; 00157 00158 std::array<float, 3> gyro_bias_; 00159 }; 00160 00161 #endif /* QFILTER_HPP_ */