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 dubin.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * \author Nicolas Dousse 00037 * 00038 * \brief Vector field navigation using Dubin's path 00039 * 00040 ******************************************************************************/ 00041 00042 #ifndef DUBIN_HPP_ 00043 #define DUBIN_HPP_ 00044 00045 #include <cstdint> 00046 #include <cstdbool> 00047 #include "util/constants.hpp" 00048 00049 extern "C" 00050 { 00051 #include "util/vectors.h" 00052 #include "util/maths.h" 00053 } 00054 00055 typedef enum 00056 { 00057 DUBIN_INIT = 0, 00058 DUBIN_CIRCLE1 = 1, 00059 DUBIN_STRAIGHT = 2, 00060 DUBIN_CIRCLE2 = 3, 00061 } dubin_state_t; 00062 00063 /* 00064 * \brief The Dubin's path structure 00065 */ 00066 typedef struct 00067 { 00068 float circle_center_1[3]; 00069 float tangent_point_1[3]; 00070 int8_t sense_1; 00071 int8_t radius_1; 00072 float circle_center_2[3]; 00073 float tangent_point_2[3]; 00074 float line_direction[3]; 00075 float length; 00076 }dubin_t; 00077 00078 //void dubin_test_code(void); 00079 00092 void dubin_line(float tvel[3], const float line_dir[3], const float line_origin[3], const float pos[3], const float speed, const float one_over_scaling); 00093 00104 void dubin_circle(float tvel[3], const float circle[3], float radius_mavlink, const float pos[3], float speed, float one_over_scaling, float look_ahead_angle=0.0f); 00105 00117 dubin_t dubin_2d(const float wp1[3], const float wp2[3], const float d1[3], const float d2[3], float sense_mavlink); 00118 00119 #endif /* DUBIN_HPP_ */