Paparazzi UAS  v5.2.2_stable-0-gd6b9f29
Paparazzi is a free software Unmanned Aircraft System.
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
common_nav.c
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2007-2009 ENAC, Pascal Brisset, Antoine Drouin
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, write to
18  * the Free Software Foundation, 59 Temple Place - Suite 330,
19  * Boston, MA 02111-1307, USA.
20  */
21 
28 #include "generated/flight_plan.h"
29 #include "subsystems/ins.h"
31 
34 
36 
37 const uint8_t nb_waypoint = NB_WAYPOINT;
38 struct point waypoints[NB_WAYPOINT] = WAYPOINTS;
39 
40 float ground_alt;
41 
42 int32_t nav_utm_east0 = NAV_UTM_EAST0;
43 int32_t nav_utm_north0 = NAV_UTM_NORTH0;
44 uint8_t nav_utm_zone0 = NAV_UTM_ZONE0;
45 float max_dist_from_home = MAX_DIST_FROM_HOME;
46 
51  struct EnuCoor_f* pos = stateGetPositionEnu_f();
52  float ph_x = waypoints[WP_HOME].x - pos->x;
53  float ph_y = waypoints[WP_HOME].y - pos->y;
54  dist2_to_home = ph_x*ph_x + ph_y *ph_y;
55  too_far_from_home = dist2_to_home > (MAX_DIST_FROM_HOME*MAX_DIST_FROM_HOME);
56 #if defined InAirspace
57  too_far_from_home = too_far_from_home || !(InAirspace(pos_x, pos_y));
58 #endif
59 }
60 
61 
62 static float previous_ground_alt;
63 
65 unit_t nav_reset_utm_zone(void) {
66 
67  struct UtmCoor_f utm0;
68  utm0.zone = nav_utm_zone0;
69  utm0.north = nav_utm_north0;
70  utm0.east = nav_utm_east0;
71  utm0.alt = ground_alt;
72  ins_reset_utm_zone(&utm0);
73 
74  /* Set the real UTM ref */
75  nav_utm_zone0 = utm0.zone;
76  nav_utm_east0 = utm0.east;
77  nav_utm_north0 = utm0.north;
78 
79  return 0;
80 }
81 
83 unit_t nav_reset_reference(void) {
84  /* realign INS */
86 
87  /* Set nav UTM ref */
91 
92  /* Ground alt */
95 
96  return 0;
97 }
98 
100 unit_t nav_reset_alt(void) {
102 
103  /* Ground alt */
106 
107  return 0;
108 }
109 
112  uint8_t i;
113  for(i = 0; i < NB_WAYPOINT; i++) {
114  waypoints[i].a += ground_alt - previous_ground_alt;
115  }
116  return 0;
117 }
118 
120  RunOnceEvery(4, { stage_time++; block_time++; });
121 }
122 
129 void nav_move_waypoint(uint8_t wp_id, float ux, float uy, float alt) {
130  if (wp_id < nb_waypoint) {
131  float dx, dy;
132  dx = ux - nav_utm_east0 - waypoints[WP_HOME].x;
133  dy = uy - nav_utm_north0 - waypoints[WP_HOME].y;
134  BoundAbs(dx, max_dist_from_home);
135  BoundAbs(dy, max_dist_from_home);
136  waypoints[wp_id].x = waypoints[WP_HOME].x + dx;
137  waypoints[wp_id].y = waypoints[WP_HOME].y + dy;
138  waypoints[wp_id].a = alt;
139  }
140 }
unit_t nav_update_waypoints_alt(void)
Shift altitude of the waypoint according to a new ground altitude.
Definition: common_nav.c:111
uint16_t block_time
void ins_reset_local_origin(void)
Reset the geographic reference to the current GPS fix.
void WEAK ins_reset_utm_zone(struct UtmCoor_f *utm)
INS utm zone reset.
Definition: ins.c:49
float ground_alt
size == nb_waypoint, waypoint 0 is a dummy waypoint
Definition: common_nav.c:40
void compute_dist2_to_home(void)
Computes squared distance to the HOME waypoint.
Definition: common_nav.c:50
float a
Definition: common_nav.h:42
uint8_t nav_utm_zone0
Definition: common_nav.c:44
Integrated Navigation System interface.
static float previous_ground_alt
Definition: common_nav.c:62
void nav_move_waypoint(uint8_t wp_id, float ux, float uy, float alt)
Move a waypoint to given UTM coordinates.
Definition: common_nav.c:129
float dist2_to_home
squared distance to home waypoint
Definition: common_nav.c:32
static struct EnuCoor_f * stateGetPositionEnu_f(void)
Get position in local ENU coordinates (float).
Definition: state.h:672
float y
in meters
Paparazzi floating point math for geodetic calculations.
uint8_t zone
UTM zone number.
void common_nav_periodic_task_4Hz()
Definition: common_nav.c:119
int32_t nav_utm_north0
Definition: common_nav.c:43
float north
in meters
unit_t nav_reset_alt(void)
Reset the altitude reference to the current GPS alt.
Definition: common_nav.c:100
position in UTM coordinates Units: meters
unit_t nav_reset_reference(void)
Reset the geographic reference to the current GPS fix.
Definition: common_nav.c:83
float x
in meters
float max_dist_from_home
Definition: common_nav.c:45
struct UtmCoor_f utm_origin_f
Definition of the origin of Utm coordinate system.
Definition: state.h:228
uint16_t stage_time
In s.
const uint8_t nb_waypoint
Definition: common_nav.c:37
signed long int32_t
Definition: types.h:19
unit_t nav_reset_utm_zone(void)
Reset the UTM zone to current GPS fix.
Definition: common_nav.c:65
unsigned char uint8_t
Definition: types.h:14
bool_t too_far_from_home
Definition: common_nav.c:35
int32_t nav_utm_east0
Definition: common_nav.c:42
struct point waypoints[NB_WAYPOINT]
Definition: common_nav.c:38
float y
Definition: common_nav.h:41
float dist2_to_wp
squared distance to next waypoint
Definition: common_nav.c:33
vector in East North Up coordinates Units: meters
float east
in meters
float alt
in meters above WGS84 reference ellipsoid
void ins_reset_altitude_ref(void)
INS altitude reference reset.
float x
Definition: common_nav.h:40
struct State state
Definition: state.c:36