[4.4.2] Remove 15 m/s limit on estimated vario (#12788)
[betaflight.git] / src / main / sensors / rangefinder.h
blobcf3d49739d8c8913973c02663a88403ef6377a01
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 <stdint.h>
25 #include "drivers/rangefinder/rangefinder.h"
27 #include "pg/pg.h"
29 typedef enum {
30 RANGEFINDER_NONE = 0,
31 RANGEFINDER_HCSR04 = 1,
32 RANGEFINDER_TFMINI = 2,
33 RANGEFINDER_TF02 = 3,
34 } rangefinderType_e;
36 typedef struct rangefinderConfig_s {
37 uint8_t rangefinder_hardware;
38 } rangefinderConfig_t;
40 PG_DECLARE(rangefinderConfig_t, rangefinderConfig);
42 typedef struct rangefinder_s {
43 rangefinderDev_t dev;
44 float maxTiltCos;
45 int32_t rawAltitude;
46 int32_t calculatedAltitude;
47 timeMs_t lastValidResponseTimeMs;
49 bool snrThresholdReached;
50 int32_t dynamicDistanceThreshold;
51 int16_t snr;
52 } rangefinder_t;
54 void rangefinderResetDynamicThreshold(void);
55 bool rangefinderInit(void);
57 int32_t rangefinderGetLatestAltitude(void);
58 int32_t rangefinderGetLatestRawAltitude(void);
60 void rangefinderUpdate(void);
61 bool rangefinderProcess(float cosTiltAngle);
62 bool rangefinderIsHealthy(void);