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.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * \author Julien Lecoeur 00037 * 00038 * \brief Inertial Navigation System (estimates position and velocity) 00039 * 00040 ******************************************************************************/ 00041 00042 00043 #ifndef INS_HPP_ 00044 #define INS_HPP_ 00045 00046 #include <array> 00047 #include "communication/mavlink_stream.hpp" 00048 #include "hal/common/time_keeper.hpp" 00049 #include "util/coord_conventions.hpp" 00050 #include "util/constants.hpp" 00051 00052 class INS 00053 { 00054 public: 00058 INS(global_position_t origin = ORIGIN_EPFL); 00059 00065 virtual bool update(void) = 0; 00066 00067 00073 virtual float last_update_s(void) const = 0; 00074 00075 00081 virtual local_position_t position_lf(void) const = 0; 00082 00083 00089 virtual std::array<float,3> velocity_lf(void) const = 0; 00090 00091 00097 virtual float absolute_altitude(void) const = 0; 00098 00099 00103 enum healthy_t 00104 { 00105 XY_VELOCITY, 00106 Z_VELOCITY, 00107 XYZ_VELOCITY, 00108 XY_REL_POSITION, 00109 Z_REL_POSITION, 00110 XYZ_REL_POSITION, 00111 XY_ABS_POSITION, 00112 Z_ABS_POSITION, 00113 XYZ_ABS_POSITION 00114 }; 00115 00116 00124 virtual bool is_healthy(INS::healthy_t type) const = 0; 00125 00126 00132 static inline const global_position_t& origin(void) {return origin_;}; 00133 00134 00140 virtual global_position_t position_gf(void) const 00141 { 00142 global_position_t position_gf; 00143 coord_conventions_local_to_global_position(position_lf(), origin(), position_gf); 00144 return position_gf; 00145 }; 00146 00147 protected: 00148 00156 static bool set_origin(global_position_t origin); 00157 00158 private: 00159 static global_position_t origin_; 00160 00161 /* declare callback for setting the origin as friend to give access to set_origin */ 00162 friend void ins_telemetry_set_gps_global_origin_callback(INS* ins, uint32_t sysid, const mavlink_message_t* msg); 00163 }; 00164 00165 #endif /* INS_HPP_ */