mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-12 02:48:28 -04:00
DCM: added reporting interfaces for DCM state
This commit is contained in:
parent
ae6a94a933
commit
82032b17a9
@ -328,6 +328,10 @@ AP_DCM::renorm(Vector3f const &a, int &problem)
|
||||
|
||||
renorm_val = 1.0 / sqrt(a * a);
|
||||
|
||||
// keep the average for reporting
|
||||
_renorm_val_sum += renorm_val;
|
||||
_renorm_val_count++;
|
||||
|
||||
if (!(renorm_val < 2.0 && renorm_val > 0.5)) {
|
||||
// this is larger than it should get - log it as a warning
|
||||
renorm_range_count++;
|
||||
@ -360,6 +364,8 @@ AP_DCM::drift_correction(void)
|
||||
float accel_weight;
|
||||
float integrator_magnitude;
|
||||
Vector3f error;
|
||||
float error_norm;
|
||||
|
||||
//static float scaled_omega_P[3];
|
||||
//static float scaled_omega_I[3];
|
||||
|
||||
@ -380,7 +386,6 @@ AP_DCM::drift_correction(void)
|
||||
|
||||
// error_roll_pitch are in Accel m/s^2 units
|
||||
// Limit max error_roll_pitch to limit max omega_P and omega_I
|
||||
float error_norm;
|
||||
error_norm = error.length();
|
||||
if (error_norm > 2) {
|
||||
error *= (2 / error_norm);
|
||||
@ -389,6 +394,12 @@ AP_DCM::drift_correction(void)
|
||||
_omega_P = error * (_kp_roll_pitch * accel_weight);
|
||||
_omega_I += error * (_ki_roll_pitch * accel_weight);
|
||||
|
||||
// these sums support the reporting of the DCM state via MAVLink
|
||||
_accel_weight_sum += accel_weight;
|
||||
_accel_weight_count++;
|
||||
_error_rp_sum += error_norm;
|
||||
_error_rp_count++;
|
||||
|
||||
|
||||
//*****YAW***************
|
||||
|
||||
@ -463,6 +474,10 @@ AP_DCM::drift_correction(void)
|
||||
if (integrator_magnitude > radians(30)) {
|
||||
_omega_I *= (radians(30) / integrator_magnitude);
|
||||
}
|
||||
|
||||
_error_yaw_sum += error_course;
|
||||
_error_yaw_count++;
|
||||
|
||||
//Serial.print("*");
|
||||
}
|
||||
|
||||
@ -507,3 +522,58 @@ AP_DCM::euler_yaw(void)
|
||||
if (yaw_sensor < 0)
|
||||
yaw_sensor += 36000;
|
||||
}
|
||||
|
||||
|
||||
/* reporting of DCM state for MAVLink */
|
||||
|
||||
// average accel_weight since last call
|
||||
float AP_DCM::get_accel_weight(void)
|
||||
{
|
||||
float ret;
|
||||
if (_accel_weight_count == 0) {
|
||||
return 0;
|
||||
}
|
||||
ret = _accel_weight_sum / _accel_weight_count;
|
||||
_accel_weight_sum = 0;
|
||||
_accel_weight_count = 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// average renorm_val since last call
|
||||
float AP_DCM::get_renorm_val(void)
|
||||
{
|
||||
float ret;
|
||||
if (_renorm_val_count == 0) {
|
||||
return 0;
|
||||
}
|
||||
ret = _renorm_val_sum / _renorm_val_count;
|
||||
_renorm_val_sum = 0;
|
||||
_renorm_val_count = 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// average error_roll_pitch since last call
|
||||
float AP_DCM::get_error_rp(void)
|
||||
{
|
||||
float ret;
|
||||
if (_error_rp_count == 0) {
|
||||
return 0;
|
||||
}
|
||||
ret = _error_rp_sum / _error_rp_count;
|
||||
_error_rp_sum = 0;
|
||||
_error_rp_count = 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// average error_yaw since last call
|
||||
float AP_DCM::get_error_yaw(void)
|
||||
{
|
||||
float ret;
|
||||
if (_error_yaw_count == 0) {
|
||||
return 0;
|
||||
}
|
||||
ret = _error_yaw_sum / _error_yaw_count;
|
||||
_error_yaw_sum = 0;
|
||||
_error_yaw_count = 0;
|
||||
return ret;
|
||||
}
|
||||
|
@ -86,6 +86,11 @@ public:
|
||||
static const float kDCM_kp_rp_low = 0.01;
|
||||
int8_t _clamp;
|
||||
|
||||
// status reporting
|
||||
float get_accel_weight(void);
|
||||
float get_renorm_val(void);
|
||||
float get_error_rp(void);
|
||||
float get_error_yaw(void);
|
||||
|
||||
private:
|
||||
float _kp_roll_pitch;
|
||||
@ -129,6 +134,17 @@ private:
|
||||
float _health;
|
||||
bool _centripetal;
|
||||
uint8_t _toggle;
|
||||
|
||||
// state to support status reporting
|
||||
float _accel_weight_sum;
|
||||
uint16_t _accel_weight_count;
|
||||
float _renorm_val_sum;
|
||||
uint16_t _renorm_val_count;
|
||||
float _error_rp_sum;
|
||||
uint16_t _error_rp_count;
|
||||
float _error_yaw_sum;
|
||||
uint16_t _error_yaw_count;
|
||||
|
||||
};
|
||||
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user