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