Paparazzi UAS v7.0_unstable
Paparazzi is a free software Unmanned Aircraft System.
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
ins_ext_pose.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2023 MAVLab
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
27/*
28Extened kalman filter based on https://en.wikipedia.org/wiki/Extended_Kalman_filter
29Section 5.3: Non-additive noise formulation and equations
30*/
31
32#ifndef INS_EXT_POSE_H
33#define INS_EXT_POSE_H
34
35#include "std.h"
36#include "generated/airframe.h"
37#include <stdio.h>
38
57
67
77
78extern float ekf_X[EKF_NUM_STATES];
79
80extern void ins_ext_pose_init(void);
81extern void ins_ext_pose_run(void);
82
83extern void ins_ext_pose_msg_update(uint8_t *buf);
84
85#ifdef INS_EXT_VISION_ROTATION
86extern struct FloatQuat ins_ext_vision_rot;
87#endif
88
89// Logging
90extern void ins_ext_pose_log_header(FILE *file);
91extern void ins_ext_pose_log_data(FILE *file);
92
93#endif
Roation quaternion.
void ins_ext_pose_msg_update(uint8_t *buf)
Import External Pose Message.
void ins_ext_pose_log_data(FILE *file)
void ins_ext_pose_init(void)
Module.
ins_ext_pose_state
@ EKF_X_VEL_Z
@ EKF_X_VEL_X
@ EKF_X_VEL_Y
@ EKF_X_A_BIAS_Z
@ EKF_X_PSI
@ EKF_X_A_BIAS_X
@ EKF_X_G_BIAS_R
@ EKF_X_G_BIAS_Q
@ EKF_X_G_BIAS_P
@ EKF_NUM_STATES
@ EKF_X_THETA
@ EKF_X_POS_Y
@ EKF_X_POS_X
@ EKF_X_A_BIAS_Y
@ EKF_X_POS_Z
@ EKF_X_PHI
void ins_ext_pose_log_header(FILE *file)
Logging.
ins_ext_pose_inputs
@ EKF_U_ACC_Z
@ EKF_NUM_INPUTS
@ EKF_U_GYRO_R
@ EKF_U_ACC_Y
@ EKF_U_GYRO_P
@ EKF_U_ACC_X
@ EKF_U_GYRO_Q
void ins_ext_pose_run(void)
ins_ext_pose_outputs
@ EKF_Z_POS_Z
@ EKF_Z_PHI
@ EKF_Z_POS_X
@ EKF_Z_PSI
@ EKF_NUM_OUTPUTS
@ EKF_Z_THETA
@ EKF_Z_POS_Y
float ekf_X[EKF_NUM_STATES]
uint16_t foo
Definition main_demo5.c:58
unsigned char uint8_t
Typedef defining 8 bit unsigned char type.