mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-07 00:18:29 -04:00
527e621a57
currently we set drift based on current boot time. If you want to introduce it at some stage in a flight the baro alt will suddenly jump based on how long you've been up. Instead, accumulate a delta
55 lines
1.3 KiB
C++
55 lines
1.3 KiB
C++
#pragma once
|
|
|
|
#include "AP_Baro_Backend.h"
|
|
|
|
#if AP_SIM_BARO_ENABLED
|
|
|
|
#include <AP_Math/vectorN.h>
|
|
|
|
#include <SITL/SITL.h>
|
|
|
|
class AP_Baro_SITL : public AP_Baro_Backend {
|
|
public:
|
|
AP_Baro_SITL(AP_Baro &);
|
|
|
|
void update() override;
|
|
|
|
// adjust for simulated board temperature
|
|
static void temperature_adjustment(float &p, float &T);
|
|
|
|
// adjust for wind effects
|
|
static float wind_pressure_correction(uint8_t instance);
|
|
|
|
protected:
|
|
|
|
void update_healthy_flag(uint8_t instance) override { _frontend.sensors[instance].healthy = healthy(instance); };
|
|
|
|
private:
|
|
uint8_t _instance;
|
|
SITL::SIM *_sitl;
|
|
|
|
// barometer delay buffer variables
|
|
struct readings_baro {
|
|
uint32_t time;
|
|
float data;
|
|
};
|
|
uint8_t _store_index;
|
|
uint32_t _last_store_time;
|
|
static const uint8_t _buffer_length = 50;
|
|
VectorN<readings_baro, _buffer_length> _buffer;
|
|
|
|
// is the barometer usable for flight
|
|
bool healthy(uint8_t instance);
|
|
|
|
void _timer();
|
|
bool _has_sample;
|
|
uint32_t _last_sample_time;
|
|
float _recent_temp;
|
|
float _recent_press;
|
|
float _last_altitude;
|
|
|
|
uint32_t last_drift_delta_t_ms; // allows for integration of drift over time
|
|
float total_alt_drift; // integrated altitude drift in metres
|
|
};
|
|
#endif // AP_SIM_BARO_ENABLED
|