mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-12 02:48:28 -04:00
75 lines
2.3 KiB
C
75 lines
2.3 KiB
C
|
#pragma once
|
||
|
|
||
|
/*
|
||
|
This program is free software: you can redistribute it and/or modify
|
||
|
it under the terms of the GNU General Public License as published by
|
||
|
the Free Software Foundation, either version 3 of the License, or
|
||
|
(at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License
|
||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
|
||
|
#pragma once
|
||
|
|
||
|
#include "AP_GPS_config.h"
|
||
|
|
||
|
#if AP_GPS_BLENDED_ENABLED
|
||
|
|
||
|
#include "AP_GPS.h"
|
||
|
#include "GPS_Backend.h"
|
||
|
|
||
|
class AP_GPS_Blended : public AP_GPS_Backend
|
||
|
{
|
||
|
public:
|
||
|
|
||
|
AP_GPS_Blended(AP_GPS &_gps, AP_GPS::Params &_params, AP_GPS::GPS_State &_state, class AP_GPS::GPS_timing &_timing) :
|
||
|
AP_GPS_Backend(_gps, _params, _state, nullptr),
|
||
|
timing{_timing}
|
||
|
{ }
|
||
|
|
||
|
// pre-arm check of GPS blending. False if blending is unhealthy,
|
||
|
// True if healthy or blending is not being used
|
||
|
bool is_healthy() const override {
|
||
|
return (_blend_health_counter < 50);
|
||
|
}
|
||
|
|
||
|
bool read() override { return true; }
|
||
|
|
||
|
const char *name() const override { return "Blended"; }
|
||
|
|
||
|
bool get_lag(float &lag_sec) const override;
|
||
|
const Vector3f &get_antenna_offset() const {
|
||
|
return _blended_antenna_offset;
|
||
|
}
|
||
|
|
||
|
// calculate the blend weight. Returns true if blend could be
|
||
|
// calculated, false if not
|
||
|
bool calc_weights(void);
|
||
|
// calculate the blended state
|
||
|
void calc_state(void);
|
||
|
|
||
|
void zero_health_counter() {
|
||
|
_blend_health_counter = 0;
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
|
||
|
// GPS blending and switching
|
||
|
Vector3f _blended_antenna_offset; // blended antenna offset
|
||
|
float _blended_lag_sec; // blended receiver lag in seconds
|
||
|
float _blend_weights[GPS_MAX_RECEIVERS]; // blend weight for each GPS. The blend weights must sum to 1.0 across all instances.
|
||
|
bool _output_is_blended; // true when a blended GPS solution being output
|
||
|
uint8_t _blend_health_counter; // 0 = perfectly health, 100 = very unhealthy
|
||
|
|
||
|
AP_GPS::GPS_timing &timing;
|
||
|
bool _calc_weights(void);
|
||
|
};
|
||
|
|
||
|
#endif // AP_GPS_BLENDED_ENABLED
|