2 * This file is part of Cleanflight and Betaflight.
4 * Cleanflight and Betaflight are free software. You can redistribute
5 * this software and/or modify this software under the terms of the
6 * GNU General Public License as published by the Free Software
7 * Foundation, either version 3 of the License, or (at your option)
10 * Cleanflight and Betaflight are distributed in the hope that they
11 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
12 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * See the GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this software.
18 * If not, see <http://www.gnu.org/licenses/>.
23 #include "sensors/gyro.h"
24 #include "common/filter.h"
26 #define MAX_KALMAN_WINDOW_SIZE 64
28 #define VARIANCE_SCALE 0.67f
32 float q
; //process noise covariance
33 float r
; //measurement noise covariance
34 float p
; //estimation error covariance matrix
35 float k
; //kalman gain
37 float lastX
; //previous state
44 float axisWindow
[MAX_KALMAN_WINDOW_SIZE
+ 1];
45 float varianceWindow
[MAX_KALMAN_WINDOW_SIZE
+ 1];
53 void gyroKalmanInitialize(uint16_t q
);
54 float gyroKalmanUpdate(uint8_t axis
, float input
);
55 void gyroKalmanUpdateSetpoint(uint8_t axis
, float setpoint
);