MAV'RIC
|
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__