Paparazzi UAS v7.0_unstable
Paparazzi is a free software Unmanned Aircraft System.
Loading...
Searching...
No Matches
nav_parametric_3d_lissajous.c
Go to the documentation of this file.
1/*
2 * Copyright (C) 2020 Hector Garcia de Marina <hgarciad@ucm.es>
3 *
4 * This file is part of paparazzi.
5 *
6 * paparazzi is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2, or (at your option)
9 * any later version.
10 *
11 * paparazzi is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with paparazzi; see the file COPYING. If not, see
18 * <http://www.gnu.org/licenses/>.
19 */
20
29
31#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_KX
32 #if GVF_PARAMETRIC_CONTROL_STEP_ADAPTATION > 0
33 #define GVF_PARAMETRIC_3D_LISSAJOUS_KX 0.1
34 #else
35 #define GVF_PARAMETRIC_3D_LISSAJOUS_KX 0.001
36 #endif
37#endif
38
40#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_KY
41 #if GVF_PARAMETRIC_CONTROL_STEP_ADAPTATION > 0
42 #define GVF_PARAMETRIC_3D_LISSAJOUS_KY 0.1
43 #else
44 #define GVF_PARAMETRIC_3D_LISSAJOUS_KY 0.001
45 #endif
46#endif
47
49#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_KZ
50 #if GVF_PARAMETRIC_CONTROL_STEP_ADAPTATION > 0
51 #define GVF_PARAMETRIC_3D_LISSAJOUS_KZ 0.1
52 #else
53 #define GVF_PARAMETRIC_3D_LISSAJOUS_KZ 0.001
54 #endif
55#endif
56
58#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_CX
59 #define GVF_PARAMETRIC_3D_LISSAJOUS_CX 80
60#endif
61
63#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_CY
64 #define GVF_PARAMETRIC_3D_LISSAJOUS_CY 80
65#endif
66
68#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_CZ
69 #define GVF_PARAMETRIC_3D_LISSAJOUS_CZ 10
70#endif
71
73#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_WX
74 #define GVF_PARAMETRIC_3D_LISSAJOUS_WX 1
75#endif
76
78#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_WY
79 #define GVF_PARAMETRIC_3D_LISSAJOUS_WY 1
80#endif
81
83#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_WZ
84 #define GVF_PARAMETRIC_3D_LISSAJOUS_WZ 1
85#endif
86
88#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_DX
89 #define GVF_PARAMETRIC_3D_LISSAJOUS_DX 0
90#endif
91
93#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_DY
94 #define GVF_PARAMETRIC_3D_LISSAJOUS_DY 0
95#endif
96
98#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_DZ
99 #define GVF_PARAMETRIC_3D_LISSAJOUS_DZ 0
100#endif
101
103#ifndef GVF_PARAMETRIC_3D_LISSAJOUS_ALPHA
104 #define GVF_PARAMETRIC_3D_LISSAJOUS_ALPHA 0
105#endif
106
114
115#ifdef FIXEDWING_FIRMWARE
116
117static int gvf_parametric_p_len_wps = 0;
118
121// 3D Lissajous
122
123bool nav_gvf_parametric_3D_lissajous_XYZ(float xo, float yo, float zo, float cx, float cy, float cz, float wx, float wy,
124 float wz, float dx, float dy, float dz, float alpha)
125{
126 // Safety first! If the asked altitude is low
127 if ((zo - cz) < 1) {
128 zo = 10;
129 cz = 0;
130 }
131
148
149 float f1, f2, f3, f1d, f2d, f3d, f1dd, f2dd, f3dd;
151
155
156 return true;
157}
158
159bool nav_gvf_parametric_3D_lissajous_wp_center(uint8_t wp, float zo, float cx, float cy, float cz, float wx, float wy,
160 float wz, float dx, float dy, float dz, float alpha)
161{
164
165 nav_gvf_parametric_3D_lissajous_XYZ(waypoints[wp].x, waypoints[wp].y, zo, cx, cy, cz, wx, wy, wz, dx, dy, dz, alpha);
166 return true;
167}
168
169#endif
struct point waypoints[NB_WAYPOINT]
size == nb_waypoint, waypoint 0 is a dummy waypoint
Definition common_nav.c:44
void gvf_parametric_3d_lissajous_info(float *f1, float *f2, float *f3, float *f1d, float *f2d, float *f3d, float *f1dd, float *f2dd, float *f3dd, float wb)
gvf_parametric_tra gvf_parametric_trajectory
@ LISSAJOUS_3D
enum trajectories_parametric type
gvf_parametric_con gvf_parametric_control
Guiding vector field algorithm for 2D and 3D parametric trajectories.
void gvf_parametric_control_3D(float, float, float, float, float, float, float, float, float, float, float, float)
uint16_t foo
Definition main_demo5.c:58
static int gvf_parametric_p_len_wps
#define GVF_PARAMETRIC_3D_LISSAJOUS_CX
#define GVF_PARAMETRIC_3D_LISSAJOUS_ALPHA
gvf_par_3d_lis_par gvf_parametric_3d_lissajous_par
#define GVF_PARAMETRIC_3D_LISSAJOUS_KX
Guiding vector field algorithm for 2D and 3D complex trajectories.
#define GVF_PARAMETRIC_3D_LISSAJOUS_WZ
#define GVF_PARAMETRIC_3D_LISSAJOUS_WY
#define GVF_PARAMETRIC_3D_LISSAJOUS_KY
#define GVF_PARAMETRIC_3D_LISSAJOUS_DX
#define GVF_PARAMETRIC_3D_LISSAJOUS_DZ
#define GVF_PARAMETRIC_3D_LISSAJOUS_CY
#define GVF_PARAMETRIC_3D_LISSAJOUS_CZ
#define GVF_PARAMETRIC_3D_LISSAJOUS_DY
#define GVF_PARAMETRIC_3D_LISSAJOUS_KZ
#define GVF_PARAMETRIC_3D_LISSAJOUS_WX
bool nav_gvf_parametric_3D_lissajous_wp_center(uint8_t wp, float zo, float cx, float cy, float cz, float wx, float wy, float wz, float dx, float dy, float dz, float alpha)
bool nav_gvf_parametric_3D_lissajous_XYZ(float xo, float yo, float zo, float cx, float cy, float cz, float wx, float wy, float wz, float dx, float dy, float dz, float alpha)
float alpha
Definition textons.c:133
unsigned char uint8_t
Typedef defining 8 bit unsigned char type.