MAV'RIC
qfilter.h
1 /*******************************************************************************
2  * Copyright (c) 2009-2014, MAV'RIC Development Team
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice,
9  * this list of conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  * this list of conditions and the following disclaimer in the documentation
13  * and/or other materials provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its contributors
16  * may be used to endorse or promote products derived from this software without
17  * specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  ******************************************************************************/
31 
32 /*******************************************************************************
33  * \file qfilter.h
34  *
35  * \author MAV'RIC Team
36  * \author Felix Schill
37  *
38  * \brief This file implements a complementary filter for the attitude estimation
39  *
40  ******************************************************************************/
41 
42 
43 #ifndef QFILTER_H_
44 #define QFILTER_H_
45 
46 #ifdef __cplusplus
47 extern "C" {
48 #endif
49 
50 #include <stdint.h>
51 #include "imu.h"
52 #include "ahrs.h"
53 
54 
58 typedef enum
59 {
60  OFF,
61  LEVELING,
62  LEVEL_PLUS_ACCEL
63 } calibration_mode_t;
64 
65 
69 typedef struct
70 {
71  float kp;
72  float ki;
73  float kp_mag;
74  float ki_mag;
76 
80 typedef struct
81 {
84 
85  float kp;
86  float ki;
87  float kp_mag;
88  float ki_mag;
89 } qfilter_t;
90 
91 
102 bool qfilter_init(qfilter_t* qf, const qfilter_conf_t* config, imu_t* imu, ahrs_t* ahrs);
103 
104 
110 void qfilter_update(qfilter_t *qf);
111 
112 
113 #ifdef __cplusplus
114 }
115 #endif
116 
117 #endif /* QFILTER_H_ */
imu_t * imu
Pointer to inertial sensors readout.
Definition: qfilter.h:82
Structure containing the Attitude and Heading Reference System.
Definition: ahrs.h:58
The structure for configuring the quaternion-based attitude estimation.
Definition: qfilter.h:69
The structure for the quaternion-based attitude estimation.
Definition: qfilter.h:80
float kp
The proportional gain for the acceleration correction of the angular rates.
Definition: qfilter.h:85
float kp_mag
The proportional gain for the magnetometer correction of the angular rates.
Definition: qfilter.h:87
float kp
The proportional gain for the acceleration correction of the angular rates.
Definition: qfilter.h:71
float ki
The integral gain for the acceleration correction of the biais.
Definition: qfilter.h:72
float ki_mag
The integral gain for the magnetometer correction of the angular rates.
Definition: qfilter.h:74
float ki
The integral gain for the acceleration correction of the biais.
Definition: qfilter.h:86
The IMU structure.
Definition: imu.h:108
float kp_mag
The proportional gain for the magnetometer correction of the angular rates.
Definition: qfilter.h:73
ahrs_t * ahrs
Pointer to estimated attiude.
Definition: qfilter.h:83
float ki_mag
The integral gain for the magnetometer correction of the angular rates.
Definition: qfilter.h:88