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