mirror of
https://gitee.com/mirrors_PX4/PX4-Autopilot.git
synced 2026-04-14 10:07:39 +08:00
BlockParam: remove _extern_address and create a new class BlockParamExt for this
In most cases, _extern_address was unused, thus wasting cycles & RAM. This adds a separate class BlockParamExt with the field and uses it in ekf2_main Frees roughly 0.5KB of RAM on Pixracer
This commit is contained in:
parent
09d8e4fd8c
commit
7c6d99d30f
@ -82,10 +82,9 @@ BlockParamBase::BlockParamBase(Block *parent, const char *name, bool parent_pref
|
||||
|
||||
template <class T>
|
||||
BlockParam<T>::BlockParam(Block *block, const char *name,
|
||||
bool parent_prefix, T *extern_address) :
|
||||
bool parent_prefix) :
|
||||
BlockParamBase(block, name, parent_prefix),
|
||||
_val(),
|
||||
_extern_address(extern_address)
|
||||
_val()
|
||||
{
|
||||
update();
|
||||
}
|
||||
@ -97,10 +96,6 @@ template <class T>
|
||||
void BlockParam<T>::set(T val)
|
||||
{
|
||||
_val = val;
|
||||
|
||||
if (_extern_address != NULL) {
|
||||
*_extern_address = val;
|
||||
}
|
||||
}
|
||||
|
||||
template <class T>
|
||||
@ -108,10 +103,6 @@ void BlockParam<T>::update()
|
||||
{
|
||||
if (_handle != PARAM_INVALID) {
|
||||
param_get(_handle, &_val);
|
||||
|
||||
if (_extern_address != NULL) {
|
||||
*_extern_address = _val;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -127,4 +118,36 @@ BlockParam<T>::~BlockParam() {};
|
||||
template class __EXPORT BlockParam<float>;
|
||||
template class __EXPORT BlockParam<int>;
|
||||
|
||||
|
||||
template <class T>
|
||||
BlockParamExt<T>::BlockParamExt(Block *block, const char *name,
|
||||
bool parent_prefix, T &extern_val) :
|
||||
BlockParam<T>(block, name, parent_prefix),
|
||||
_extern_val(extern_val)
|
||||
{
|
||||
update();
|
||||
}
|
||||
|
||||
template <class T>
|
||||
void BlockParamExt<T>::set(T val)
|
||||
{
|
||||
this->_val = val;
|
||||
_extern_val = val;
|
||||
}
|
||||
|
||||
template <class T>
|
||||
void BlockParamExt<T>::update()
|
||||
{
|
||||
if (this->_handle != PARAM_INVALID) {
|
||||
param_get(this->_handle, &this->_val);
|
||||
_extern_val = this->_val;
|
||||
}
|
||||
}
|
||||
|
||||
template <class T>
|
||||
BlockParamExt<T>::~BlockParamExt() {};
|
||||
|
||||
template class __EXPORT BlockParamExt<float>;
|
||||
template class __EXPORT BlockParamExt<int>;
|
||||
|
||||
} // namespace control
|
||||
|
||||
@ -77,21 +77,45 @@ class BlockParam : public BlockParamBase
|
||||
{
|
||||
public:
|
||||
BlockParam(Block *block, const char *name,
|
||||
bool parent_prefix = true, T *extern_address = NULL);
|
||||
bool parent_prefix = true);
|
||||
BlockParam(const BlockParam &) = delete;
|
||||
BlockParam &operator=(const BlockParam &) = delete;
|
||||
|
||||
T get();
|
||||
void commit();
|
||||
void set(T val);
|
||||
void update();
|
||||
void update() override;
|
||||
virtual ~BlockParam();
|
||||
protected:
|
||||
T _val;
|
||||
T *_extern_address;
|
||||
};
|
||||
|
||||
typedef BlockParam<float> BlockParamFloat;
|
||||
typedef BlockParam<int> BlockParamInt;
|
||||
|
||||
|
||||
/**
|
||||
* Same as BlockParam, but in addition with a pointer to an external field that will be
|
||||
* set to the value of the parameter.
|
||||
* (BlockParam should be prefered over this)
|
||||
*/
|
||||
template <class T>
|
||||
class BlockParamExt : public BlockParam<T>
|
||||
{
|
||||
public:
|
||||
BlockParamExt(Block *block, const char *name,
|
||||
bool parent_prefix, T &extern_val);
|
||||
BlockParamExt(const BlockParamExt &) = delete;
|
||||
BlockParamExt &operator=(const BlockParamExt &) = delete;
|
||||
|
||||
void set(T val);
|
||||
void update() override;
|
||||
virtual ~BlockParamExt();
|
||||
protected:
|
||||
T &_extern_val;
|
||||
};
|
||||
|
||||
typedef BlockParamExt<float> BlockParamExtFloat;
|
||||
typedef BlockParamExt<int> BlockParamExtInt;
|
||||
|
||||
} // namespace control
|
||||
|
||||
@ -168,108 +168,109 @@ private:
|
||||
|
||||
parameters *_params; // pointer to ekf parameter struct (located in _ekf class instance)
|
||||
|
||||
control::BlockParamFloat _mag_delay_ms;
|
||||
control::BlockParamFloat _baro_delay_ms;
|
||||
control::BlockParamFloat _gps_delay_ms;
|
||||
control::BlockParamFloat _flow_delay_ms;
|
||||
control::BlockParamFloat _rng_delay_ms;
|
||||
control::BlockParamFloat _airspeed_delay_ms;
|
||||
control::BlockParamFloat _ev_delay_ms;
|
||||
control::BlockParamExtFloat _mag_delay_ms;
|
||||
control::BlockParamExtFloat _baro_delay_ms;
|
||||
control::BlockParamExtFloat _gps_delay_ms;
|
||||
control::BlockParamExtFloat _flow_delay_ms;
|
||||
control::BlockParamExtFloat _rng_delay_ms;
|
||||
control::BlockParamExtFloat _airspeed_delay_ms;
|
||||
control::BlockParamExtFloat _ev_delay_ms;
|
||||
|
||||
control::BlockParamFloat _gyro_noise;
|
||||
control::BlockParamFloat _accel_noise;
|
||||
control::BlockParamExtFloat _gyro_noise;
|
||||
control::BlockParamExtFloat _accel_noise;
|
||||
|
||||
// process noise
|
||||
control::BlockParamFloat _gyro_bias_p_noise;
|
||||
control::BlockParamFloat _accel_bias_p_noise;
|
||||
control::BlockParamFloat _mage_p_noise;
|
||||
control::BlockParamFloat _magb_p_noise;
|
||||
control::BlockParamFloat _wind_vel_p_noise;
|
||||
control::BlockParamFloat _terrain_p_noise; // terrain offset state random walk (m/s)
|
||||
control::BlockParamFloat _terrain_gradient; // magnitude of terrain gradient (m/m)
|
||||
control::BlockParamExtFloat _gyro_bias_p_noise;
|
||||
control::BlockParamExtFloat _accel_bias_p_noise;
|
||||
control::BlockParamExtFloat _mage_p_noise;
|
||||
control::BlockParamExtFloat _magb_p_noise;
|
||||
control::BlockParamExtFloat _wind_vel_p_noise;
|
||||
control::BlockParamExtFloat _terrain_p_noise; // terrain offset state random walk (m/s)
|
||||
control::BlockParamExtFloat _terrain_gradient; // magnitude of terrain gradient (m/m)
|
||||
|
||||
control::BlockParamFloat _gps_vel_noise;
|
||||
control::BlockParamFloat _gps_pos_noise;
|
||||
control::BlockParamFloat _pos_noaid_noise;
|
||||
control::BlockParamFloat _baro_noise;
|
||||
control::BlockParamFloat _baro_innov_gate; // innovation gate for barometric height innovation test (std dev)
|
||||
control::BlockParamFloat _posNE_innov_gate; // innovation gate for GPS horizontal position innovation test (std dev)
|
||||
control::BlockParamFloat _vel_innov_gate; // innovation gate for GPS velocity innovation test (std dev)
|
||||
control::BlockParamFloat _tas_innov_gate; // innovation gate for tas innovation test (std dev)
|
||||
control::BlockParamExtFloat _gps_vel_noise;
|
||||
control::BlockParamExtFloat _gps_pos_noise;
|
||||
control::BlockParamExtFloat _pos_noaid_noise;
|
||||
control::BlockParamExtFloat _baro_noise;
|
||||
control::BlockParamExtFloat _baro_innov_gate; // innovation gate for barometric height innovation test (std dev)
|
||||
control::BlockParamExtFloat
|
||||
_posNE_innov_gate; // innovation gate for GPS horizontal position innovation test (std dev)
|
||||
control::BlockParamExtFloat _vel_innov_gate; // innovation gate for GPS velocity innovation test (std dev)
|
||||
control::BlockParamExtFloat _tas_innov_gate; // innovation gate for tas innovation test (std dev)
|
||||
|
||||
control::BlockParamFloat _mag_heading_noise; // measurement noise used for simple heading fusion
|
||||
control::BlockParamFloat _mag_noise; // measurement noise used for 3-axis magnetoemter fusion (Gauss)
|
||||
control::BlockParamFloat _eas_noise; // measurement noise used for airspeed fusion (std m/s)
|
||||
control::BlockParamFloat _mag_declination_deg; // magnetic declination in degrees
|
||||
control::BlockParamFloat _heading_innov_gate; // innovation gate for heading innovation test
|
||||
control::BlockParamFloat _mag_innov_gate; // innovation gate for magnetometer innovation test
|
||||
control::BlockParamInt
|
||||
control::BlockParamExtFloat _mag_heading_noise; // measurement noise used for simple heading fusion
|
||||
control::BlockParamExtFloat _mag_noise; // measurement noise used for 3-axis magnetoemter fusion (Gauss)
|
||||
control::BlockParamExtFloat _eas_noise; // measurement noise used for airspeed fusion (std m/s)
|
||||
control::BlockParamExtFloat _mag_declination_deg; // magnetic declination in degrees
|
||||
control::BlockParamExtFloat _heading_innov_gate; // innovation gate for heading innovation test
|
||||
control::BlockParamExtFloat _mag_innov_gate; // innovation gate for magnetometer innovation test
|
||||
control::BlockParamExtInt
|
||||
_mag_decl_source; // bitmasked integer used to control the handling of magnetic declination
|
||||
control::BlockParamInt _mag_fuse_type; // integer ued to control the type of magnetometer fusion used
|
||||
control::BlockParamExtInt _mag_fuse_type; // integer ued to control the type of magnetometer fusion used
|
||||
|
||||
control::BlockParamInt _gps_check_mask; // bitmasked integer used to activate the different GPS quality checks
|
||||
control::BlockParamFloat _requiredEph; // maximum acceptable horiz position error (m)
|
||||
control::BlockParamFloat _requiredEpv; // maximum acceptable vert position error (m)
|
||||
control::BlockParamFloat _requiredSacc; // maximum acceptable speed error (m/s)
|
||||
control::BlockParamInt _requiredNsats; // minimum acceptable satellite count
|
||||
control::BlockParamFloat _requiredGDoP; // maximum acceptable geometric dilution of precision
|
||||
control::BlockParamFloat _requiredHdrift; // maximum acceptable horizontal drift speed (m/s)
|
||||
control::BlockParamFloat _requiredVdrift; // maximum acceptable vertical drift speed (m/s)
|
||||
control::BlockParamInt _param_record_replay_msg; // indicates if we want to record ekf2 replay messages
|
||||
control::BlockParamExtInt _gps_check_mask; // bitmasked integer used to activate the different GPS quality checks
|
||||
control::BlockParamExtFloat _requiredEph; // maximum acceptable horiz position error (m)
|
||||
control::BlockParamExtFloat _requiredEpv; // maximum acceptable vert position error (m)
|
||||
control::BlockParamExtFloat _requiredSacc; // maximum acceptable speed error (m/s)
|
||||
control::BlockParamExtInt _requiredNsats; // minimum acceptable satellite count
|
||||
control::BlockParamExtFloat _requiredGDoP; // maximum acceptable geometric dilution of precision
|
||||
control::BlockParamExtFloat _requiredHdrift; // maximum acceptable horizontal drift speed (m/s)
|
||||
control::BlockParamExtFloat _requiredVdrift; // maximum acceptable vertical drift speed (m/s)
|
||||
control::BlockParamExtInt _param_record_replay_msg; // indicates if we want to record ekf2 replay messages
|
||||
|
||||
// measurement source control
|
||||
control::BlockParamInt
|
||||
control::BlockParamExtInt
|
||||
_fusion_mode; // bitmasked integer that selects which of the GPS and optical flow aiding sources will be used
|
||||
control::BlockParamInt _vdist_sensor_type; // selects the primary source for height data
|
||||
control::BlockParamExtInt _vdist_sensor_type; // selects the primary source for height data
|
||||
|
||||
// range finder fusion
|
||||
control::BlockParamFloat _range_noise; // observation noise for range finder measurements (m)
|
||||
control::BlockParamFloat _range_innov_gate; // range finder fusion innovation consistency gate size (STD)
|
||||
control::BlockParamFloat _rng_gnd_clearance; // minimum valid value for range when on ground (m)
|
||||
control::BlockParamExtFloat _range_noise; // observation noise for range finder measurements (m)
|
||||
control::BlockParamExtFloat _range_innov_gate; // range finder fusion innovation consistency gate size (STD)
|
||||
control::BlockParamExtFloat _rng_gnd_clearance; // minimum valid value for range when on ground (m)
|
||||
|
||||
// vision estimate fusion
|
||||
control::BlockParamFloat _ev_pos_noise; // default position observation noise for exernal vision measurements (m)
|
||||
control::BlockParamFloat _ev_ang_noise; // default angular observation noise for exernal vision measurements (rad)
|
||||
control::BlockParamFloat _ev_innov_gate; // external vision position innovation consistency gate size (STD)
|
||||
control::BlockParamExtFloat _ev_pos_noise; // default position observation noise for exernal vision measurements (m)
|
||||
control::BlockParamExtFloat _ev_ang_noise; // default angular observation noise for exernal vision measurements (rad)
|
||||
control::BlockParamExtFloat _ev_innov_gate; // external vision position innovation consistency gate size (STD)
|
||||
|
||||
// optical flow fusion
|
||||
control::BlockParamFloat
|
||||
control::BlockParamExtFloat
|
||||
_flow_noise; // best quality observation noise for optical flow LOS rate measurements (rad/sec)
|
||||
control::BlockParamFloat
|
||||
control::BlockParamExtFloat
|
||||
_flow_noise_qual_min; // worst quality observation noise for optical flow LOS rate measurements (rad/sec)
|
||||
control::BlockParamInt _flow_qual_min; // minimum acceptable quality integer from the flow sensor
|
||||
control::BlockParamFloat _flow_innov_gate; // optical flow fusion innovation consistency gate size (STD)
|
||||
control::BlockParamFloat _flow_rate_max; // maximum valid optical flow rate (rad/sec)
|
||||
control::BlockParamExtInt _flow_qual_min; // minimum acceptable quality integer from the flow sensor
|
||||
control::BlockParamExtFloat _flow_innov_gate; // optical flow fusion innovation consistency gate size (STD)
|
||||
control::BlockParamExtFloat _flow_rate_max; // maximum valid optical flow rate (rad/sec)
|
||||
|
||||
// sensor positions in body frame
|
||||
control::BlockParamFloat _imu_pos_x; // X position of IMU in body frame (m)
|
||||
control::BlockParamFloat _imu_pos_y; // Y position of IMU in body frame (m)
|
||||
control::BlockParamFloat _imu_pos_z; // Z position of IMU in body frame (m)
|
||||
control::BlockParamFloat _gps_pos_x; // X position of GPS antenna in body frame (m)
|
||||
control::BlockParamFloat _gps_pos_y; // Y position of GPS antenna in body frame (m)
|
||||
control::BlockParamFloat _gps_pos_z; // Z position of GPS antenna in body frame (m)
|
||||
control::BlockParamFloat _rng_pos_x; // X position of range finder in body frame (m)
|
||||
control::BlockParamFloat _rng_pos_y; // Y position of range finder in body frame (m)
|
||||
control::BlockParamFloat _rng_pos_z; // Z position of range finder in body frame (m)
|
||||
control::BlockParamFloat _flow_pos_x; // X position of optical flow sensor focal point in body frame (m)
|
||||
control::BlockParamFloat _flow_pos_y; // Y position of optical flow sensor focal point in body frame (m)
|
||||
control::BlockParamFloat _flow_pos_z; // Z position of optical flow sensor focal point in body frame (m)
|
||||
control::BlockParamFloat _ev_pos_x; // X position of VI sensor focal point in body frame (m)
|
||||
control::BlockParamFloat _ev_pos_y; // Y position of VI sensor focal point in body frame (m)
|
||||
control::BlockParamFloat _ev_pos_z; // Z position of VI sensor focal point in body frame (m)
|
||||
control::BlockParamExtFloat _imu_pos_x; // X position of IMU in body frame (m)
|
||||
control::BlockParamExtFloat _imu_pos_y; // Y position of IMU in body frame (m)
|
||||
control::BlockParamExtFloat _imu_pos_z; // Z position of IMU in body frame (m)
|
||||
control::BlockParamExtFloat _gps_pos_x; // X position of GPS antenna in body frame (m)
|
||||
control::BlockParamExtFloat _gps_pos_y; // Y position of GPS antenna in body frame (m)
|
||||
control::BlockParamExtFloat _gps_pos_z; // Z position of GPS antenna in body frame (m)
|
||||
control::BlockParamExtFloat _rng_pos_x; // X position of range finder in body frame (m)
|
||||
control::BlockParamExtFloat _rng_pos_y; // Y position of range finder in body frame (m)
|
||||
control::BlockParamExtFloat _rng_pos_z; // Z position of range finder in body frame (m)
|
||||
control::BlockParamExtFloat _flow_pos_x; // X position of optical flow sensor focal point in body frame (m)
|
||||
control::BlockParamExtFloat _flow_pos_y; // Y position of optical flow sensor focal point in body frame (m)
|
||||
control::BlockParamExtFloat _flow_pos_z; // Z position of optical flow sensor focal point in body frame (m)
|
||||
control::BlockParamExtFloat _ev_pos_x; // X position of VI sensor focal point in body frame (m)
|
||||
control::BlockParamExtFloat _ev_pos_y; // Y position of VI sensor focal point in body frame (m)
|
||||
control::BlockParamExtFloat _ev_pos_z; // Z position of VI sensor focal point in body frame (m)
|
||||
// control of airspeed and sideslip fusion
|
||||
control::BlockParamFloat
|
||||
_arspFusionThreshold; // a value of zero will disabled airspeed fusion. Any another positive value will determine
|
||||
// the minimum airspeed which will still be fused
|
||||
|
||||
// output predictor filter time constants
|
||||
control::BlockParamFloat _tau_vel; // time constant used by the output velocity complementary filter (s)
|
||||
control::BlockParamFloat _tau_pos; // time constant used by the output position complementary filter (s)
|
||||
control::BlockParamExtFloat _tau_vel; // time constant used by the output velocity complementary filter (s)
|
||||
control::BlockParamExtFloat _tau_pos; // time constant used by the output position complementary filter (s)
|
||||
|
||||
// IMU switch on bias paameters
|
||||
control::BlockParamFloat _gyr_bias_init; // 1-sigma gyro bias uncertainty at switch-on (rad/sec)
|
||||
control::BlockParamFloat _acc_bias_init; // 1-sigma accelerometer bias uncertainty at switch-on (m/s**2)
|
||||
control::BlockParamFloat _ang_err_init; // 1-sigma uncertainty in tilt angle after gravity vector alignment (rad)
|
||||
control::BlockParamExtFloat _gyr_bias_init; // 1-sigma gyro bias uncertainty at switch-on (rad/sec)
|
||||
control::BlockParamExtFloat _acc_bias_init; // 1-sigma accelerometer bias uncertainty at switch-on (m/s**2)
|
||||
control::BlockParamExtFloat _ang_err_init; // 1-sigma uncertainty in tilt angle after gravity vector alignment (rad)
|
||||
|
||||
// airspeed mode parameter
|
||||
control::BlockParamInt _airspeed_mode;
|
||||
@ -295,81 +296,81 @@ Ekf2::Ekf2():
|
||||
_lp_yaw_rate(250.0f, 20.0f),
|
||||
_ekf(),
|
||||
_params(_ekf.getParamHandle()),
|
||||
_mag_delay_ms(this, "EKF2_MAG_DELAY", false, &_params->mag_delay_ms),
|
||||
_baro_delay_ms(this, "EKF2_BARO_DELAY", false, &_params->baro_delay_ms),
|
||||
_gps_delay_ms(this, "EKF2_GPS_DELAY", false, &_params->gps_delay_ms),
|
||||
_flow_delay_ms(this, "EKF2_OF_DELAY", false, &_params->flow_delay_ms),
|
||||
_rng_delay_ms(this, "EKF2_RNG_DELAY", false, &_params->range_delay_ms),
|
||||
_airspeed_delay_ms(this, "EKF2_ASP_DELAY", false, &_params->airspeed_delay_ms),
|
||||
_ev_delay_ms(this, "EKF2_EV_DELAY", false, &_params->ev_delay_ms),
|
||||
_gyro_noise(this, "EKF2_GYR_NOISE", false, &_params->gyro_noise),
|
||||
_accel_noise(this, "EKF2_ACC_NOISE", false, &_params->accel_noise),
|
||||
_gyro_bias_p_noise(this, "EKF2_GYR_B_NOISE", false, &_params->gyro_bias_p_noise),
|
||||
_accel_bias_p_noise(this, "EKF2_ACC_B_NOISE", false, &_params->accel_bias_p_noise),
|
||||
_mage_p_noise(this, "EKF2_MAG_E_NOISE", false, &_params->mage_p_noise),
|
||||
_magb_p_noise(this, "EKF2_MAG_B_NOISE", false, &_params->magb_p_noise),
|
||||
_wind_vel_p_noise(this, "EKF2_WIND_NOISE", false, &_params->wind_vel_p_noise),
|
||||
_terrain_p_noise(this, "EKF2_TERR_NOISE", false, &_params->terrain_p_noise),
|
||||
_terrain_gradient(this, "EKF2_TERR_GRAD", false, &_params->terrain_gradient),
|
||||
_gps_vel_noise(this, "EKF2_GPS_V_NOISE", false, &_params->gps_vel_noise),
|
||||
_gps_pos_noise(this, "EKF2_GPS_P_NOISE", false, &_params->gps_pos_noise),
|
||||
_pos_noaid_noise(this, "EKF2_NOAID_NOISE", false, &_params->pos_noaid_noise),
|
||||
_baro_noise(this, "EKF2_BARO_NOISE", false, &_params->baro_noise),
|
||||
_baro_innov_gate(this, "EKF2_BARO_GATE", false, &_params->baro_innov_gate),
|
||||
_posNE_innov_gate(this, "EKF2_GPS_P_GATE", false, &_params->posNE_innov_gate),
|
||||
_vel_innov_gate(this, "EKF2_GPS_V_GATE", false, &_params->vel_innov_gate),
|
||||
_tas_innov_gate(this, "EKF2_TAS_GATE", false, &_params->tas_innov_gate),
|
||||
_mag_heading_noise(this, "EKF2_HEAD_NOISE", false, &_params->mag_heading_noise),
|
||||
_mag_noise(this, "EKF2_MAG_NOISE", false, &_params->mag_noise),
|
||||
_eas_noise(this, "EKF2_EAS_NOISE", false, &_params->eas_noise),
|
||||
_mag_declination_deg(this, "EKF2_MAG_DECL", false, &_params->mag_declination_deg),
|
||||
_heading_innov_gate(this, "EKF2_HDG_GATE", false, &_params->heading_innov_gate),
|
||||
_mag_innov_gate(this, "EKF2_MAG_GATE", false, &_params->mag_innov_gate),
|
||||
_mag_decl_source(this, "EKF2_DECL_TYPE", false, &_params->mag_declination_source),
|
||||
_mag_fuse_type(this, "EKF2_MAG_TYPE", false, &_params->mag_fusion_type),
|
||||
_gps_check_mask(this, "EKF2_GPS_CHECK", false, &_params->gps_check_mask),
|
||||
_requiredEph(this, "EKF2_REQ_EPH", false, &_params->req_hacc),
|
||||
_requiredEpv(this, "EKF2_REQ_EPV", false, &_params->req_vacc),
|
||||
_requiredSacc(this, "EKF2_REQ_SACC", false, &_params->req_sacc),
|
||||
_requiredNsats(this, "EKF2_REQ_NSATS", false, &_params->req_nsats),
|
||||
_requiredGDoP(this, "EKF2_REQ_GDOP", false, &_params->req_gdop),
|
||||
_requiredHdrift(this, "EKF2_REQ_HDRIFT", false, &_params->req_hdrift),
|
||||
_requiredVdrift(this, "EKF2_REQ_VDRIFT", false, &_params->req_vdrift),
|
||||
_param_record_replay_msg(this, "EKF2_REC_RPL", false, &_publish_replay_mode),
|
||||
_fusion_mode(this, "EKF2_AID_MASK", false, &_params->fusion_mode),
|
||||
_vdist_sensor_type(this, "EKF2_HGT_MODE", false, &_params->vdist_sensor_type),
|
||||
_range_noise(this, "EKF2_RNG_NOISE", false, &_params->range_noise),
|
||||
_range_innov_gate(this, "EKF2_RNG_GATE", false, &_params->range_innov_gate),
|
||||
_rng_gnd_clearance(this, "EKF2_MIN_RNG", false, &_params->rng_gnd_clearance),
|
||||
_ev_pos_noise(this, "EKF2_EVP_NOISE", false, &_default_ev_pos_noise),
|
||||
_ev_ang_noise(this, "EKF2_EVA_NOISE", false, &_default_ev_ang_noise),
|
||||
_ev_innov_gate(this, "EKF2_EV_GATE", false, &_params->ev_innov_gate),
|
||||
_flow_noise(this, "EKF2_OF_N_MIN", false, &_params->flow_noise),
|
||||
_flow_noise_qual_min(this, "EKF2_OF_N_MAX", false, &_params->flow_noise_qual_min),
|
||||
_flow_qual_min(this, "EKF2_OF_QMIN", false, &_params->flow_qual_min),
|
||||
_flow_innov_gate(this, "EKF2_OF_GATE", false, &_params->flow_innov_gate),
|
||||
_flow_rate_max(this, "EKF2_OF_RMAX", false, &_params->flow_rate_max),
|
||||
_imu_pos_x(this, "EKF2_IMU_POS_X", false, &_params->imu_pos_body(0)),
|
||||
_imu_pos_y(this, "EKF2_IMU_POS_Y", false, &_params->imu_pos_body(1)),
|
||||
_imu_pos_z(this, "EKF2_IMU_POS_Z", false, &_params->imu_pos_body(2)),
|
||||
_gps_pos_x(this, "EKF2_GPS_POS_X", false, &_params->gps_pos_body(0)),
|
||||
_gps_pos_y(this, "EKF2_GPS_POS_Y", false, &_params->gps_pos_body(1)),
|
||||
_gps_pos_z(this, "EKF2_GPS_POS_Z", false, &_params->gps_pos_body(2)),
|
||||
_rng_pos_x(this, "EKF2_RNG_POS_X", false, &_params->rng_pos_body(0)),
|
||||
_rng_pos_y(this, "EKF2_RNG_POS_Y", false, &_params->rng_pos_body(1)),
|
||||
_rng_pos_z(this, "EKF2_RNG_POS_Z", false, &_params->rng_pos_body(2)),
|
||||
_flow_pos_x(this, "EKF2_OF_POS_X", false, &_params->flow_pos_body(0)),
|
||||
_flow_pos_y(this, "EKF2_OF_POS_Y", false, &_params->flow_pos_body(1)),
|
||||
_flow_pos_z(this, "EKF2_OF_POS_Z", false, &_params->flow_pos_body(2)),
|
||||
_ev_pos_x(this, "EKF2_EV_POS_X", false, &_params->ev_pos_body(0)),
|
||||
_ev_pos_y(this, "EKF2_EV_POS_Y", false, &_params->ev_pos_body(1)),
|
||||
_ev_pos_z(this, "EKF2_EV_POS_Z", false, &_params->ev_pos_body(2)),
|
||||
_mag_delay_ms(this, "EKF2_MAG_DELAY", false, _params->mag_delay_ms),
|
||||
_baro_delay_ms(this, "EKF2_BARO_DELAY", false, _params->baro_delay_ms),
|
||||
_gps_delay_ms(this, "EKF2_GPS_DELAY", false, _params->gps_delay_ms),
|
||||
_flow_delay_ms(this, "EKF2_OF_DELAY", false, _params->flow_delay_ms),
|
||||
_rng_delay_ms(this, "EKF2_RNG_DELAY", false, _params->range_delay_ms),
|
||||
_airspeed_delay_ms(this, "EKF2_ASP_DELAY", false, _params->airspeed_delay_ms),
|
||||
_ev_delay_ms(this, "EKF2_EV_DELAY", false, _params->ev_delay_ms),
|
||||
_gyro_noise(this, "EKF2_GYR_NOISE", false, _params->gyro_noise),
|
||||
_accel_noise(this, "EKF2_ACC_NOISE", false, _params->accel_noise),
|
||||
_gyro_bias_p_noise(this, "EKF2_GYR_B_NOISE", false, _params->gyro_bias_p_noise),
|
||||
_accel_bias_p_noise(this, "EKF2_ACC_B_NOISE", false, _params->accel_bias_p_noise),
|
||||
_mage_p_noise(this, "EKF2_MAG_E_NOISE", false, _params->mage_p_noise),
|
||||
_magb_p_noise(this, "EKF2_MAG_B_NOISE", false, _params->magb_p_noise),
|
||||
_wind_vel_p_noise(this, "EKF2_WIND_NOISE", false, _params->wind_vel_p_noise),
|
||||
_terrain_p_noise(this, "EKF2_TERR_NOISE", false, _params->terrain_p_noise),
|
||||
_terrain_gradient(this, "EKF2_TERR_GRAD", false, _params->terrain_gradient),
|
||||
_gps_vel_noise(this, "EKF2_GPS_V_NOISE", false, _params->gps_vel_noise),
|
||||
_gps_pos_noise(this, "EKF2_GPS_P_NOISE", false, _params->gps_pos_noise),
|
||||
_pos_noaid_noise(this, "EKF2_NOAID_NOISE", false, _params->pos_noaid_noise),
|
||||
_baro_noise(this, "EKF2_BARO_NOISE", false, _params->baro_noise),
|
||||
_baro_innov_gate(this, "EKF2_BARO_GATE", false, _params->baro_innov_gate),
|
||||
_posNE_innov_gate(this, "EKF2_GPS_P_GATE", false, _params->posNE_innov_gate),
|
||||
_vel_innov_gate(this, "EKF2_GPS_V_GATE", false, _params->vel_innov_gate),
|
||||
_tas_innov_gate(this, "EKF2_TAS_GATE", false, _params->tas_innov_gate),
|
||||
_mag_heading_noise(this, "EKF2_HEAD_NOISE", false, _params->mag_heading_noise),
|
||||
_mag_noise(this, "EKF2_MAG_NOISE", false, _params->mag_noise),
|
||||
_eas_noise(this, "EKF2_EAS_NOISE", false, _params->eas_noise),
|
||||
_mag_declination_deg(this, "EKF2_MAG_DECL", false, _params->mag_declination_deg),
|
||||
_heading_innov_gate(this, "EKF2_HDG_GATE", false, _params->heading_innov_gate),
|
||||
_mag_innov_gate(this, "EKF2_MAG_GATE", false, _params->mag_innov_gate),
|
||||
_mag_decl_source(this, "EKF2_DECL_TYPE", false, _params->mag_declination_source),
|
||||
_mag_fuse_type(this, "EKF2_MAG_TYPE", false, _params->mag_fusion_type),
|
||||
_gps_check_mask(this, "EKF2_GPS_CHECK", false, _params->gps_check_mask),
|
||||
_requiredEph(this, "EKF2_REQ_EPH", false, _params->req_hacc),
|
||||
_requiredEpv(this, "EKF2_REQ_EPV", false, _params->req_vacc),
|
||||
_requiredSacc(this, "EKF2_REQ_SACC", false, _params->req_sacc),
|
||||
_requiredNsats(this, "EKF2_REQ_NSATS", false, _params->req_nsats),
|
||||
_requiredGDoP(this, "EKF2_REQ_GDOP", false, _params->req_gdop),
|
||||
_requiredHdrift(this, "EKF2_REQ_HDRIFT", false, _params->req_hdrift),
|
||||
_requiredVdrift(this, "EKF2_REQ_VDRIFT", false, _params->req_vdrift),
|
||||
_param_record_replay_msg(this, "EKF2_REC_RPL", false, _publish_replay_mode),
|
||||
_fusion_mode(this, "EKF2_AID_MASK", false, _params->fusion_mode),
|
||||
_vdist_sensor_type(this, "EKF2_HGT_MODE", false, _params->vdist_sensor_type),
|
||||
_range_noise(this, "EKF2_RNG_NOISE", false, _params->range_noise),
|
||||
_range_innov_gate(this, "EKF2_RNG_GATE", false, _params->range_innov_gate),
|
||||
_rng_gnd_clearance(this, "EKF2_MIN_RNG", false, _params->rng_gnd_clearance),
|
||||
_ev_pos_noise(this, "EKF2_EVP_NOISE", false, _default_ev_pos_noise),
|
||||
_ev_ang_noise(this, "EKF2_EVA_NOISE", false, _default_ev_ang_noise),
|
||||
_ev_innov_gate(this, "EKF2_EV_GATE", false, _params->ev_innov_gate),
|
||||
_flow_noise(this, "EKF2_OF_N_MIN", false, _params->flow_noise),
|
||||
_flow_noise_qual_min(this, "EKF2_OF_N_MAX", false, _params->flow_noise_qual_min),
|
||||
_flow_qual_min(this, "EKF2_OF_QMIN", false, _params->flow_qual_min),
|
||||
_flow_innov_gate(this, "EKF2_OF_GATE", false, _params->flow_innov_gate),
|
||||
_flow_rate_max(this, "EKF2_OF_RMAX", false, _params->flow_rate_max),
|
||||
_imu_pos_x(this, "EKF2_IMU_POS_X", false, _params->imu_pos_body(0)),
|
||||
_imu_pos_y(this, "EKF2_IMU_POS_Y", false, _params->imu_pos_body(1)),
|
||||
_imu_pos_z(this, "EKF2_IMU_POS_Z", false, _params->imu_pos_body(2)),
|
||||
_gps_pos_x(this, "EKF2_GPS_POS_X", false, _params->gps_pos_body(0)),
|
||||
_gps_pos_y(this, "EKF2_GPS_POS_Y", false, _params->gps_pos_body(1)),
|
||||
_gps_pos_z(this, "EKF2_GPS_POS_Z", false, _params->gps_pos_body(2)),
|
||||
_rng_pos_x(this, "EKF2_RNG_POS_X", false, _params->rng_pos_body(0)),
|
||||
_rng_pos_y(this, "EKF2_RNG_POS_Y", false, _params->rng_pos_body(1)),
|
||||
_rng_pos_z(this, "EKF2_RNG_POS_Z", false, _params->rng_pos_body(2)),
|
||||
_flow_pos_x(this, "EKF2_OF_POS_X", false, _params->flow_pos_body(0)),
|
||||
_flow_pos_y(this, "EKF2_OF_POS_Y", false, _params->flow_pos_body(1)),
|
||||
_flow_pos_z(this, "EKF2_OF_POS_Z", false, _params->flow_pos_body(2)),
|
||||
_ev_pos_x(this, "EKF2_EV_POS_X", false, _params->ev_pos_body(0)),
|
||||
_ev_pos_y(this, "EKF2_EV_POS_Y", false, _params->ev_pos_body(1)),
|
||||
_ev_pos_z(this, "EKF2_EV_POS_Z", false, _params->ev_pos_body(2)),
|
||||
_arspFusionThreshold(this, "EKF2_ARSP_THR", false),
|
||||
_tau_vel(this, "EKF2_TAU_VEL", false, &_params->vel_Tau),
|
||||
_tau_pos(this, "EKF2_TAU_POS", false, &_params->pos_Tau),
|
||||
_gyr_bias_init(this, "EKF2_GBIAS_INIT", false, &_params->switch_on_gyro_bias),
|
||||
_acc_bias_init(this, "EKF2_ABIAS_INIT", false, &_params->switch_on_accel_bias),
|
||||
_ang_err_init(this, "EKF2_ANGERR_INIT", false, &_params->initial_tilt_err),
|
||||
_tau_vel(this, "EKF2_TAU_VEL", false, _params->vel_Tau),
|
||||
_tau_pos(this, "EKF2_TAU_POS", false, _params->pos_Tau),
|
||||
_gyr_bias_init(this, "EKF2_GBIAS_INIT", false, _params->switch_on_gyro_bias),
|
||||
_acc_bias_init(this, "EKF2_ABIAS_INIT", false, _params->switch_on_accel_bias),
|
||||
_ang_err_init(this, "EKF2_ANGERR_INIT", false, _params->initial_tilt_err),
|
||||
_airspeed_mode(this, "FW_ARSP_MODE", false)
|
||||
{
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user