mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
AP_NavEKF3: avoid using struct Location
clang reports this could be a problem when compiling under some EABIs. Remove it from most places as it is just noise, replace with class where we want to avoid including Location.h
This commit is contained in:
parent
38c6eb24cd
commit
35a5a73f52
@ -1356,7 +1356,7 @@ bool NavEKF3::getMagOffsets(uint8_t mag_idx, Vector3f &magOffsets) const
|
|||||||
// If a calculated location isn't available, return a raw GPS measurement
|
// If a calculated location isn't available, return a raw GPS measurement
|
||||||
// The status will return true if a calculation or raw measurement is available
|
// The status will return true if a calculation or raw measurement is available
|
||||||
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
||||||
bool NavEKF3::getLLH(struct Location &loc) const
|
bool NavEKF3::getLLH(Location &loc) const
|
||||||
{
|
{
|
||||||
if (!core) {
|
if (!core) {
|
||||||
return false;
|
return false;
|
||||||
@ -1367,7 +1367,7 @@ bool NavEKF3::getLLH(struct Location &loc) const
|
|||||||
// Return the latitude and longitude and height used to set the NED origin
|
// Return the latitude and longitude and height used to set the NED origin
|
||||||
// All NED positions calculated by the filter are relative to this location
|
// All NED positions calculated by the filter are relative to this location
|
||||||
// Returns false if the origin has not been set
|
// Returns false if the origin has not been set
|
||||||
bool NavEKF3::getOriginLLH(struct Location &loc) const
|
bool NavEKF3::getOriginLLH(Location &loc) const
|
||||||
{
|
{
|
||||||
if (!core) {
|
if (!core) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -139,12 +139,12 @@ public:
|
|||||||
// If a calculated location isn't available, return a raw GPS measurement
|
// If a calculated location isn't available, return a raw GPS measurement
|
||||||
// The status will return true if a calculation or raw measurement is available
|
// The status will return true if a calculation or raw measurement is available
|
||||||
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
||||||
bool getLLH(struct Location &loc) const;
|
bool getLLH(Location &loc) const;
|
||||||
|
|
||||||
// Return the latitude and longitude and height used to set the NED origin
|
// Return the latitude and longitude and height used to set the NED origin
|
||||||
// All NED positions calculated by the filter are relative to this location
|
// All NED positions calculated by the filter are relative to this location
|
||||||
// Returns false if the origin has not been set
|
// Returns false if the origin has not been set
|
||||||
bool getOriginLLH(struct Location &loc) const;
|
bool getOriginLLH(Location &loc) const;
|
||||||
|
|
||||||
// set the latitude and longitude and height used to set the NED origin
|
// set the latitude and longitude and height used to set the NED origin
|
||||||
// All NED positions calculated by the filter will be relative to this location
|
// All NED positions calculated by the filter will be relative to this location
|
||||||
@ -525,7 +525,7 @@ private:
|
|||||||
uint64_t coreLastTimePrimary_us[MAX_EKF_CORES]; // last time we were using this core as primary
|
uint64_t coreLastTimePrimary_us[MAX_EKF_CORES]; // last time we were using this core as primary
|
||||||
|
|
||||||
// origin set by one of the cores
|
// origin set by one of the cores
|
||||||
struct Location common_EKF_origin;
|
Location common_EKF_origin;
|
||||||
bool common_origin_valid;
|
bool common_origin_valid;
|
||||||
|
|
||||||
// update the yaw reset data to capture changes due to a lane switch
|
// update the yaw reset data to capture changes due to a lane switch
|
||||||
|
@ -645,7 +645,7 @@ void NavEKF3_core::readGpsData()
|
|||||||
calcGpsGoodForFlight();
|
calcGpsGoodForFlight();
|
||||||
|
|
||||||
// Read the GPS location in WGS-84 lat,long,height coordinates
|
// Read the GPS location in WGS-84 lat,long,height coordinates
|
||||||
const struct Location &gpsloc = gps.location(selected_gps);
|
const Location &gpsloc = gps.location(selected_gps);
|
||||||
|
|
||||||
// Set the EKF origin and magnetic field declination if not previously set and GPS checks have passed
|
// Set the EKF origin and magnetic field declination if not previously set and GPS checks have passed
|
||||||
if (gpsGoodToAlign && !validOrigin) {
|
if (gpsGoodToAlign && !validOrigin) {
|
||||||
|
@ -232,7 +232,7 @@ bool NavEKF3_core::getPosNE(Vector2f &posNE) const
|
|||||||
auto &gps = dal.gps();
|
auto &gps = dal.gps();
|
||||||
if ((gps.status(selected_gps) >= AP_DAL_GPS::GPS_OK_FIX_2D)) {
|
if ((gps.status(selected_gps) >= AP_DAL_GPS::GPS_OK_FIX_2D)) {
|
||||||
// If the origin has been set and we have GPS, then return the GPS position relative to the origin
|
// If the origin has been set and we have GPS, then return the GPS position relative to the origin
|
||||||
const struct Location &gpsloc = gps.location(selected_gps);
|
const Location &gpsloc = gps.location(selected_gps);
|
||||||
posNE = public_origin.get_distance_NE_ftype(gpsloc).tofloat();
|
posNE = public_origin.get_distance_NE_ftype(gpsloc).tofloat();
|
||||||
return false;
|
return false;
|
||||||
#if EK3_FEATURE_BEACON_FUSION
|
#if EK3_FEATURE_BEACON_FUSION
|
||||||
@ -304,7 +304,7 @@ bool NavEKF3_core::getHAGL(float &HAGL) const
|
|||||||
// If a calculated location isn't available, return a raw GPS measurement
|
// If a calculated location isn't available, return a raw GPS measurement
|
||||||
// The status will return true if a calculation or raw measurement is available
|
// The status will return true if a calculation or raw measurement is available
|
||||||
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
||||||
bool NavEKF3_core::getLLH(struct Location &loc) const
|
bool NavEKF3_core::getLLH(Location &loc) const
|
||||||
{
|
{
|
||||||
Location origin;
|
Location origin;
|
||||||
if (getOriginLLH(origin)) {
|
if (getOriginLLH(origin)) {
|
||||||
@ -351,7 +351,7 @@ bool NavEKF3_core::getLLH(struct Location &loc) const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NavEKF3_core::getGPSLLH(struct Location &loc) const
|
bool NavEKF3_core::getGPSLLH(Location &loc) const
|
||||||
{
|
{
|
||||||
const auto &gps = dal.gps();
|
const auto &gps = dal.gps();
|
||||||
if ((gps.status(selected_gps) >= AP_DAL_GPS::GPS_OK_FIX_3D)) {
|
if ((gps.status(selected_gps) >= AP_DAL_GPS::GPS_OK_FIX_3D)) {
|
||||||
@ -384,7 +384,7 @@ void NavEKF3_core::getEkfControlLimits(float &ekfGndSpdLimit, float &ekfNavVelGa
|
|||||||
|
|
||||||
|
|
||||||
// return the LLH location of the filters NED origin
|
// return the LLH location of the filters NED origin
|
||||||
bool NavEKF3_core::getOriginLLH(struct Location &loc) const
|
bool NavEKF3_core::getOriginLLH(Location &loc) const
|
||||||
{
|
{
|
||||||
if (validOrigin) {
|
if (validOrigin) {
|
||||||
loc = public_origin;
|
loc = public_origin;
|
||||||
|
@ -48,7 +48,7 @@ void NavEKF3_core::calcGpsGoodToAlign(void)
|
|||||||
// This check can only be used when the vehicle is stationary
|
// This check can only be used when the vehicle is stationary
|
||||||
const auto &gps = dal.gps();
|
const auto &gps = dal.gps();
|
||||||
|
|
||||||
const struct Location &gpsloc = gps.location(preferred_gps); // Current location
|
const Location &gpsloc = gps.location(preferred_gps); // Current location
|
||||||
const ftype posFiltTimeConst = 10.0; // time constant used to decay position drift
|
const ftype posFiltTimeConst = 10.0; // time constant used to decay position drift
|
||||||
// calculate time lapsed since last update and limit to prevent numerical errors
|
// calculate time lapsed since last update and limit to prevent numerical errors
|
||||||
ftype deltaTime = constrain_ftype(ftype(imuDataDelayed.time_ms - lastPreAlignGpsCheckTime_ms)*0.001f,0.01f,posFiltTimeConst);
|
ftype deltaTime = constrain_ftype(ftype(imuDataDelayed.time_ms - lastPreAlignGpsCheckTime_ms)*0.001f,0.01f,posFiltTimeConst);
|
||||||
|
@ -209,12 +209,12 @@ public:
|
|||||||
// If a calculated location isn't available, return a raw GPS measurement
|
// If a calculated location isn't available, return a raw GPS measurement
|
||||||
// The status will return true if a calculation or raw measurement is available
|
// The status will return true if a calculation or raw measurement is available
|
||||||
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
// The getFilterStatus() function provides a more detailed description of data health and must be checked if data is to be used for flight control
|
||||||
bool getLLH(struct Location &loc) const;
|
bool getLLH(Location &loc) const;
|
||||||
|
|
||||||
// return the latitude and longitude and height used to set the NED origin
|
// return the latitude and longitude and height used to set the NED origin
|
||||||
// All NED positions calculated by the filter are relative to this location
|
// All NED positions calculated by the filter are relative to this location
|
||||||
// Returns false if the origin has not been set
|
// Returns false if the origin has not been set
|
||||||
bool getOriginLLH(struct Location &loc) const;
|
bool getOriginLLH(Location &loc) const;
|
||||||
|
|
||||||
// set the latitude and longitude and height used to set the NED origin
|
// set the latitude and longitude and height used to set the NED origin
|
||||||
// All NED positions calculated by the filter will be relative to this location
|
// All NED positions calculated by the filter will be relative to this location
|
||||||
@ -1011,7 +1011,7 @@ private:
|
|||||||
void SelectDragFusion();
|
void SelectDragFusion();
|
||||||
void SampleDragData(const imu_elements &imu);
|
void SampleDragData(const imu_elements &imu);
|
||||||
|
|
||||||
bool getGPSLLH(struct Location &loc) const;
|
bool getGPSLLH(Location &loc) const;
|
||||||
|
|
||||||
// Variables
|
// Variables
|
||||||
bool statesInitialised; // boolean true when filter states have been initialised
|
bool statesInitialised; // boolean true when filter states have been initialised
|
||||||
@ -1101,8 +1101,8 @@ private:
|
|||||||
bool needEarthBodyVarReset; // we need to reset mag earth variances at next CovariancePrediction
|
bool needEarthBodyVarReset; // we need to reset mag earth variances at next CovariancePrediction
|
||||||
bool inhibitDelAngBiasStates; // true when IMU delta angle bias states are inactive
|
bool inhibitDelAngBiasStates; // true when IMU delta angle bias states are inactive
|
||||||
bool gpsIsInUse; // bool true when GPS data is being used to correct states estimates
|
bool gpsIsInUse; // bool true when GPS data is being used to correct states estimates
|
||||||
struct Location EKF_origin; // LLH origin of the NED axis system, internal only
|
Location EKF_origin; // LLH origin of the NED axis system, internal only
|
||||||
struct Location &public_origin; // LLH origin of the NED axis system, public functions
|
Location &public_origin; // LLH origin of the NED axis system, public functions
|
||||||
bool validOrigin; // true when the EKF origin is valid
|
bool validOrigin; // true when the EKF origin is valid
|
||||||
ftype gpsSpdAccuracy; // estimated speed accuracy in m/s returned by the GPS receiver
|
ftype gpsSpdAccuracy; // estimated speed accuracy in m/s returned by the GPS receiver
|
||||||
ftype gpsPosAccuracy; // estimated position accuracy in m returned by the GPS receiver
|
ftype gpsPosAccuracy; // estimated position accuracy in m returned by the GPS receiver
|
||||||
@ -1194,7 +1194,7 @@ private:
|
|||||||
} vertCompFiltState;
|
} vertCompFiltState;
|
||||||
|
|
||||||
// variables used by the pre-initialisation GPS checks
|
// variables used by the pre-initialisation GPS checks
|
||||||
struct Location gpsloc_prev; // LLH location of previous GPS measurement
|
Location gpsloc_prev; // LLH location of previous GPS measurement
|
||||||
uint32_t lastPreAlignGpsCheckTime_ms; // last time in msec the GPS quality was checked during pre alignment checks
|
uint32_t lastPreAlignGpsCheckTime_ms; // last time in msec the GPS quality was checked during pre alignment checks
|
||||||
ftype gpsDriftNE; // amount of drift detected in the GPS position during pre-flight GPs checks
|
ftype gpsDriftNE; // amount of drift detected in the GPS position during pre-flight GPs checks
|
||||||
ftype gpsVertVelFilt; // amount of filtered vertical GPS velocity detected during pre-flight GPS checks
|
ftype gpsVertVelFilt; // amount of filtered vertical GPS velocity detected during pre-flight GPS checks
|
||||||
|
Loading…
Reference in New Issue
Block a user