MAV'RIC
/home/travis/build/lis-epfl/MAVRIC_Library/sensing/ahrs_ekf_mocap.hpp
00001 /*******************************************************************************
00002  * Copyright (c) 2009-2014, 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 ahrs_ekf_mocap.hpp
00034  *
00035  * \author MAV'RIC Team
00036  * \author Matthew Douglas
00037  *
00038  * \brief Extended Kalman Filter attitude estimation, mixing accelerometer and magnetometer
00039  * x[0] : bias_x
00040  * x[1] : bias_y
00041  * x[2] : bias_z
00042  * x[3] : q0
00043  * x[4] : q1
00044  * x[5] : q2
00045  * x[6] : q3
00046  *
00047  *
00048  * Takes into account the motion capture ahrs quaternion
00049  *
00050  ******************************************************************************/
00051 
00052 #ifndef __AHRS_EKF_MOCAP_HPP__
00053 #define __AHRS_EKF_MOCAP_HPP__
00054 
00055 #include "sensing/ahrs_ekf.hpp"
00056 #include "util/matrix.hpp"
00057 #include "communication/mavlink_message_handler.hpp"
00058 
00059 
00063 class Ahrs_ekf_mocap
00064 {
00065 public:
00066 
00070     struct conf_t
00071     {
00072         float R_mocap;                                  
00073     };
00074 
00082     Ahrs_ekf_mocap(Mavlink_message_handler& message_handler, AHRS_ekf& ahrs_ekf, const conf_t config_ = Ahrs_ekf_mocap::default_config());
00083 
00089     bool init();
00090 
00094     static inline conf_t default_config();
00095 
00096 
00097 protected:
00098 
00106     static void callback(Ahrs_ekf_mocap* ahrs_ekf_mocap, uint32_t sysid, const mavlink_message_t* msg);
00107 
00108     AHRS_ekf& ahrs_ekf_;                        
00109     Mavlink_message_handler& message_handler_;  
00110     Mat<4,4> R_mocap_;                          
00111     Mat<4, 7> H_;                               
00112     Mat<4, 1> z_;                                
00113     bool is_init_;                              
00114 
00115     conf_t config_;                                     
00116 
00117     float last_update_us_;                              
00118 };
00119 
00120 Ahrs_ekf_mocap::conf_t Ahrs_ekf_mocap::default_config()
00121 {
00122     Ahrs_ekf_mocap::conf_t conf = {};
00123 
00124     conf.R_mocap = 0.000001f;
00125 
00126     return conf;
00127 };
00128 
00129 #endif // __AHRS_EKF_MOCAP_HPP__
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Defines