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 coord_conventions.h 00034 * 00035 * \author MAV'RIC Team 00036 * \author Julien Lecoeur 00037 * 00038 * \brief Coordinate conventions 00039 * 00040 ******************************************************************************/ 00041 00042 00043 #ifndef COORD_CONVENTIONS_HPP_ 00044 #define COORD_CONVENTIONS_HPP_ 00045 00046 #include <cstdint> 00047 #include <array> 00048 00049 extern "C" 00050 { 00051 #include "util/quaternions.h" 00052 } 00053 00054 00055 #define EARTH_RADIUS 6378137.0f ///< radius of the earth in meters 00056 00057 00061 typedef struct 00062 { 00063 double longitude; 00064 double latitude; 00065 float altitude; 00066 } global_position_t; 00067 00068 typedef std::array<float,3> local_position_t; 00069 00070 typedef std::array<float,3> local_velocity_t; 00071 00072 /* 00073 * \brief Attitude with aeronautics convention 00074 * 00075 * \details Expressed with the NED frame: X front, Y right, Z down. 00076 * The rotations are done in the following order: 00077 * - first around the local yaw axis, 00078 * - then around new local pitch axis, 00079 * - and finally around the new roll axis 00080 */ 00081 typedef struct 00082 { 00083 float rpy[3]; 00084 } aero_attitude_t; 00085 00086 00097 void coord_conventions_local_to_global_position(const local_position_t& input, const global_position_t& origin, global_position_t& output); 00098 00099 00107 void coord_conventions_global_to_local_position(const global_position_t& input, const global_position_t& origin, local_position_t& output); 00108 00109 00117 aero_attitude_t coord_conventions_quat_to_aero(quat_t qe); 00118 00119 00127 quat_t coord_conventions_quaternion_from_aero(aero_attitude_t aero); 00128 00136 quat_t coord_conventions_quaternion_from_rpy(const float rpy[3]); 00137 quat_t coord_conventions_quaternion_from_rpy(float roll, float pitch, float yaw); 00138 00139 00146 void coord_conventions_rpy_from_quaternion(const quat_t& quat, float rpy[3]); 00147 00148 00156 float coord_conventions_get_yaw(quat_t qe); 00157 00158 00167 quat_t coord_conventions_quaternion_from_angle_axis(float angle, const float axis[3]); 00168 00169 00170 #endif /* STABILISATION_HPP_ */