Paparazzi UAS v7.0_unstable
Paparazzi is a free software Unmanned Aircraft System.
Loading...
Searching...
No Matches
nps_autopilot_fixedwing.c
Go to the documentation of this file.
1/*
2 * Copyright (C) 2009 Antoine Drouin <poinix@gmail.com>
3 * Copyright (C) 2013 The Paparazzi Team
4 *
5 * This file is part of paparazzi.
6 *
7 * paparazzi is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2, or (at your option)
10 * any later version.
11 *
12 * paparazzi is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with paparazzi; see the file COPYING. If not, write to
19 * the Free Software Foundation, 59 Temple Place - Suite 330,
20 * Boston, MA 02111-1307, USA.
21 */
22
23#include "nps_autopilot.h"
24
25#include "main_ap.h"
26
27#include "nps_sensors.h"
28#include "nps_radio_control.h"
29#include "nps_electrical.h"
30#include "nps_fdm.h"
31
32#include "generated/modules.h"
34#include "modules/imu/imu.h"
35#include "mcu_periph/sys_time.h"
36#include "state.h"
38
39#include "modules/core/abi.h"
40
41// for launch
42#include "autopilot.h"
43
44// for datalink_time hack
46
47#if USE_SONAR
48// for sonar/lidar agl
50#endif
51
55
56#ifndef NPS_BYPASS_AHRS
57#define NPS_BYPASS_AHRS FALSE
58#endif
59
60#ifndef NPS_BYPASS_INS
61#define NPS_BYPASS_INS FALSE
62#endif
63
64void sys_tick_handler(void);
65
66//#if !defined (FBW) || !defined (AP)
67//#error NPS does not currently support dual processor simulation for FBW and AP on fixedwing!
68//#endif
69
87
92
93#include <stdio.h>
94#include "modules/gps/gps.h"
95
96void nps_autopilot_run_step(double time)
97{
98
100
101#if RADIO_CONTROL && !RADIO_CONTROL_TYPE_DATALINK
105 }
106#endif
107
111 }
112
114 imu_feed_mag();
116 }
117
120 float pressure = (float) sensors.baro.value;
123 }
124
127 }
128
129#if USE_AIRSPEED || USE_NPS_AIRSPEED
131 AbiSendMsgAIRSPEED(AIRSPEED_NPS_ID, (float)sensors.airspeed.value);
133 }
134#endif
135
139 }
140
141#if USE_SONAR
144 float dist = (float) sensors.sonar.value;
146
147#ifdef SENSOR_SYNC_SEND_SONAR
148 uint16_t foo = 0;
150#endif
151
153 }
154#endif
155
156 // standalone angle of attack
157#if USE_NPS_AOA && !NPS_SYNC_INCIDENCE
159 AbiSendMsgINCIDENCE(INCIDENCE_NPS_ID, 1, (float)sensors.aoa.value, 0.f);
161 }
162#endif
163
164 // standalone sideslip
165#if USE_NPS_SIDESLIP && !NPS_SYNC_INCIDENCE
167 AbiSendMsgINCIDENCE(INCIDENCE_NPS_ID, 2, 0.f, (float)sensors.sideslip.value);
169 }
170#endif
171
172 // synchronized angle of attack and sideslip
173#if NPS_SYNC_INCIDENCE && USE_NPS_AOA && USE_NPS_SIDESLIP
174 static uint8_t flag = 0;
176 SetBit(flag, 0);
177 }
179 SetBit(flag, 1);
180 }
181 if (flag == 3) {
182 // both sensors are updated
183 AbiSendMsgINCIDENCE(INCIDENCE_NPS_ID, 3, (float)sensors.aoa.value, (float)sensors.sideslip.value);
185 flag = 0;
186 }
187#endif
188
189
190
191 if (nps_bypass_ahrs) {
193 }
194
195 if (nps_bypass_ins) {
197 }
198
200
201 /* scale final motor commands to 0-1 for feeding the fdm */
202#ifdef NPS_ACTUATOR_NAMES
203 PRINT_CONFIG_MSG("actuators for JSBSim explicitly set.")
205 //PRINT_CONFIG_VAR(NPS_ACTUATOR_NAMES)
206
207 for (uint8_t i = 0; i < NPS_COMMANDS_NB; i++) {
209 }
210 // hack: invert pitch to fit most JSBSim models
212#else
213 PRINT_CONFIG_MSG("Using throttle, roll, pitch, yaw commands instead of explicit actuators.")
217
220 // hack: invert pitch to fit most JSBSim models
222#ifdef COMMAND_YAW
225#endif /* COMMAND_YAW */
226#endif /* NPS_ACTUATOR_NAMES */
227
228 // do the launch when clicking launch in GCS
230 if (!autopilot.launch) {
232 }
233}
234
236{
237
238 struct FloatQuat quat_f;
241
242 struct FloatRates rates_f;
245
246}
247
249{
250
252 struct NedCoor_f ltp_pos;
253 VECT3_COPY(ltp_pos, fdm.ltpprz_pos);
255 }
256 else if (state.utm_initialized_f) {
257 struct LlaCoor_f lla;
258 LLA_COPY(lla, fdm.lla_pos);
259 struct UtmCoor_f utm;
260 utm.zone = (lla.lon / 1e7 + 180) / 6 + 1;
261 utm_of_lla_f(&utm, &lla);
263 }
264
265 struct NedCoor_f ltp_speed;
266 VECT3_COPY(ltp_speed, fdm.ltpprz_ecef_vel);
268
269 struct NedCoor_f ltp_accel;
270 VECT3_COPY(ltp_accel, fdm.ltpprz_ecef_accel);
272
273}
Main include for ABI (AirBorneInterface).
#define BARO_SIM_SENDER_ID
#define INCIDENCE_NPS_ID
#define AGL_SONAR_NPS_ID
#define AIRSPEED_NPS_ID
struct pprz_autopilot autopilot
Global autopilot structure.
Definition autopilot.c:49
Core autopilot interface common to all firmwares.
bool launch
request launch
Definition autopilot.h:71
bool kill_throttle
allow autopilot to use throttle
Definition autopilot.h:69
#define sensors(...)
uint32_t get_sys_time_usec(void)
Get the time in microseconds since startup.
Hardware independent code for commands handling.
Device independent GPS code (interface)
void gps_feed_value(void)
Definition gps_sim_nps.c:32
Roation quaternion.
angular rates
#define RATES_COPY(_a, _b)
#define QUAT_COPY(_qo, _qi)
#define VECT3_COPY(_a, _b)
#define LLA_COPY(_pos1, _pos2)
static void stateSetAccelNed_f(uint16_t id, struct NedCoor_f *ned_accel)
Set acceleration in NED coordinates (float).
Definition state.h:1155
static void stateSetNedToBodyQuat_f(uint16_t id, struct FloatQuat *ned_to_body_quat)
Set vehicle body attitude from quaternion (float).
Definition state.h:1261
struct State state
Definition state.c:36
static void stateSetPositionNed_f(uint16_t id, struct NedCoor_f *ned_pos)
Set position from local NED coordinates (float).
Definition state.h:718
bool ned_initialized_f
True if local float coordinate frame is initialsed.
Definition state.h:251
static void stateSetPositionUtm_f(uint16_t id, struct UtmCoor_f *utm_pos)
Set position from UTM coordinates (float).
Definition state.h:698
bool utm_initialized_f
True if utm origin (float) coordinate frame is initialsed.
Definition state.h:264
bool ned_initialized_i
true if local int coordinate frame is initialsed
Definition state.h:199
static void stateSetBodyRates_f(uint16_t id, struct FloatRates *body_rate)
Set vehicle body angular rate (float).
Definition state.h:1354
static void stateSetSpeedNed_f(uint16_t id, struct NedCoor_f *ned_speed)
Set ground speed in local NED coordinates (float).
Definition state.h:947
Inertial Measurement Unit interface.
void imu_feed_mag(void)
Definition imu_nps.c:61
void imu_feed_gyro_accel(void)
Definition imu_nps.c:50
PRINT_CONFIG_MSG("USE_INS_NAV_INIT defaulting to TRUE")
void main_ap_periodic(void)
Definition main_ap.c:119
void main_ap_event(void)
Definition main_ap.c:146
void main_ap_init(void)
Definition main_ap.c:79
Autopilot main loop.
uint16_t foo
Definition main_demo5.c:58
double commands[NPS_COMMANDS_NB]
#define NPS_COMMANDS_NB
Number of commands sent to the FDM of NPS.
struct NpsAutopilot nps_autopilot
void nps_autopilot_run_step(double time)
#define NPS_BYPASS_INS
void nps_autopilot_init(enum NpsRadioControlType type_rc, int num_rc_script, char *rc_dev)
bool nps_bypass_ahrs
bool nps_bypass_ins
void sim_overwrite_ins(void)
void nps_autopilot_run_systime_step(void)
void sim_overwrite_ahrs(void)
#define NPS_BYPASS_AHRS
void sys_tick_handler(void)
void nps_electrical_init(void)
void nps_electrical_run_step(double time)
Electrical status (bat voltage) for NPS.
struct NedCoor_d ltpprz_ecef_vel
velocity in ltppprz frame, wrt ECEF frame
Definition nps_fdm.h:79
struct NedCoor_d ltpprz_pos
Definition nps_fdm.h:54
struct NedCoor_d ltpprz_ecef_accel
accel in ltppprz frame, wrt ECEF frame
Definition nps_fdm.h:81
struct DoubleQuat ltp_to_body_quat
Definition nps_fdm.h:91
struct DoubleRates body_ecef_rotvel
Definition nps_fdm.h:97
struct LlaCoor_d lla_pos
Definition nps_fdm.h:55
struct NpsFdm fdm
Holds all necessary NPS FDM state information.
void nps_radio_control_init(enum NpsRadioControlType type, int num_script, char *js_dev)
bool nps_radio_control_available(double time)
NpsRadioControlType
bool nps_sensors_airspeed_available(void)
Definition nps_sensors.c:85
bool nps_sensors_sonar_available(void)
Definition nps_sensors.c:76
bool nps_sensors_mag_available(void)
Definition nps_sensors.c:49
bool nps_sensors_gps_available(void)
Definition nps_sensors.c:67
bool nps_sensors_sideslip_available(void)
bool nps_sensors_aoa_available(void)
bool nps_sensors_baro_available(void)
Definition nps_sensors.c:58
bool nps_sensors_gyro_available(void)
Definition nps_sensors.c:40
bool nps_sensors_temperature_available(void)
Definition nps_sensors.c:94
PRINT_CONFIG_VAR(ONELOOP_ANDI_FILT_CUTOFF)
#define MAX_PPRZ
Definition paparazzi.h:8
void utm_of_lla_f(struct UtmCoor_f *utm, struct LlaCoor_f *lla)
uint8_t zone
UTM zone number.
float lon
in radians
vector in Latitude, Longitude and Altitude
vector in North East Down coordinates Units: meters
position in UTM coordinates Units: meters
Generic interface for radio control modules.
static const ShellCommand commands[]
Definition shell_arch.c:78
void radio_control_feed(void)
Definition ppm_arch.c:42
API to get/set the generic vehicle states.
#define FALSE
Definition std.h:5
Architecture independent timing functions.
unsigned short uint16_t
Typedef defining 16 bit unsigned short type.
unsigned int uint32_t
Typedef defining 32 bit unsigned int type.
unsigned char uint8_t
Typedef defining 8 bit unsigned char type.