MAV'RIC
/home/travis/build/lis-epfl/MAVRIC_Library/sensing/ahrs_qfilter.hpp
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_ */
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Defines