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 ins_ahrs_groundtruth.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * \author Basil Huber 00037 00038 * \brief Mockup Inertial Navigation System (INS) and Attitude Heading Reference System (AHRS) providing groundtruth 00039 * for position and velocity, attitude, acceleration and rates, obtained from the dynamic model 00040 * 00041 ******************************************************************************/ 00042 00043 00044 00045 #ifndef INS_AHRS_GROUNDTRUTH_HPP_ 00046 #define INS_AHRS_GROUNDTRUTH_HPP_ 00047 00048 #include "sensing/ins.hpp" 00049 #include "sensing/ahrs.hpp" 00050 #include "simulation/dynamic_model.hpp" 00051 00052 class INS_AHRS_groundtruth : public INS, public AHRS 00053 { 00054 public: 00055 00059 struct conf_t 00060 { 00061 global_position_t origin; 00062 }; 00063 00067 INS_AHRS_groundtruth(Dynamic_model& model, const conf_t& config = default_config()); 00068 00075 virtual bool update(void); 00076 00077 00084 virtual inline float last_update_s(void) const; 00085 00086 00093 virtual inline local_position_t position_lf(void) const {return position_lf_;}; 00094 00095 00102 virtual inline std::array<float,3> velocity_lf(void) const {return velocity_lf_;}; 00103 00104 00111 virtual inline float absolute_altitude(void) const {return absolute_altitude_;}; 00112 00113 00121 virtual inline bool is_healthy(INS::healthy_t type) const 00122 { 00123 (void) type; // unused 00124 return true; 00125 }; 00126 00127 00133 virtual inline bool is_healthy(void) const 00134 { 00135 return true; 00136 }; 00137 00138 00144 quat_t attitude(void) const; 00145 00146 00152 std::array<float,3> angular_speed(void) const; 00153 00154 00160 std::array<float,3> linear_acceleration(void) const; 00161 00162 00169 static inline conf_t default_config(); 00170 00171 protected: 00172 Dynamic_model& model_; 00173 00174 local_position_t position_lf_; 00175 std::array<float,3> velocity_lf_; 00176 float absolute_altitude_; 00177 00178 quat_t attitude_; 00179 std::array<float,3> angular_speed_; 00180 std::array<float,3> linear_acc_; 00181 float last_update_s_; 00182 }; 00183 00184 00185 00186 INS_AHRS_groundtruth::conf_t INS_AHRS_groundtruth::default_config() 00187 { 00188 conf_t conf; 00189 conf.origin = ORIGIN_EPFL; 00190 return conf; 00191 } 00192 00193 #endif /* INS_AHRS_GROUNDTRUTH_HPP_ */