Blackbox device type 'file' (SITL) considered working when file handler is available
[inav.git] / src / main / flight / kalman.h
blob620473be5e3a6034cd15664cadadf9f061d1e260
1 /*
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)
8 * any later version.
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/>.
21 #pragma once
23 #include "sensors/gyro.h"
24 #include "common/filter.h"
26 #define MAX_KALMAN_WINDOW_SIZE 64
28 #define VARIANCE_SCALE 0.67f
30 typedef struct kalman
32 float q; //process noise covariance
33 float r; //measurement noise covariance
34 float p; //estimation error covariance matrix
35 float k; //kalman gain
36 float x; //state
37 float lastX; //previous state
38 float e;
40 float setpoint;
42 float axisVar;
43 uint16_t windex;
44 float axisWindow[MAX_KALMAN_WINDOW_SIZE + 1];
45 float varianceWindow[MAX_KALMAN_WINDOW_SIZE + 1];
46 float axisSumMean;
47 float axisMean;
48 float axisSumVar;
49 float inverseN;
50 uint16_t w;
51 } kalman_t;
53 void gyroKalmanInitialize(uint16_t q);
54 float gyroKalmanUpdate(uint8_t axis, float input);
55 void gyroKalmanUpdateSetpoint(uint8_t axis, float setpoint);