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);
|
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)) {
|
if (!(renorm_val < 2.0 && renorm_val > 0.5)) {
|
||||||
// this is larger than it should get - log it as a warning
|
// this is larger than it should get - log it as a warning
|
||||||
renorm_range_count++;
|
renorm_range_count++;
|
||||||
@ -360,6 +364,8 @@ AP_DCM::drift_correction(void)
|
|||||||
float accel_weight;
|
float accel_weight;
|
||||||
float integrator_magnitude;
|
float integrator_magnitude;
|
||||||
Vector3f error;
|
Vector3f error;
|
||||||
|
float error_norm;
|
||||||
|
|
||||||
//static float scaled_omega_P[3];
|
//static float scaled_omega_P[3];
|
||||||
//static float scaled_omega_I[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
|
// error_roll_pitch are in Accel m/s^2 units
|
||||||
// Limit max error_roll_pitch to limit max omega_P and omega_I
|
// Limit max error_roll_pitch to limit max omega_P and omega_I
|
||||||
float error_norm;
|
|
||||||
error_norm = error.length();
|
error_norm = error.length();
|
||||||
if (error_norm > 2) {
|
if (error_norm > 2) {
|
||||||
error *= (2 / error_norm);
|
error *= (2 / error_norm);
|
||||||
@ -389,6 +394,12 @@ AP_DCM::drift_correction(void)
|
|||||||
_omega_P = error * (_kp_roll_pitch * accel_weight);
|
_omega_P = error * (_kp_roll_pitch * accel_weight);
|
||||||
_omega_I += error * (_ki_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***************
|
//*****YAW***************
|
||||||
|
|
||||||
@ -463,6 +474,10 @@ AP_DCM::drift_correction(void)
|
|||||||
if (integrator_magnitude > radians(30)) {
|
if (integrator_magnitude > radians(30)) {
|
||||||
_omega_I *= (radians(30) / integrator_magnitude);
|
_omega_I *= (radians(30) / integrator_magnitude);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_error_yaw_sum += error_course;
|
||||||
|
_error_yaw_count++;
|
||||||
|
|
||||||
//Serial.print("*");
|
//Serial.print("*");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -507,3 +522,58 @@ AP_DCM::euler_yaw(void)
|
|||||||
if (yaw_sensor < 0)
|
if (yaw_sensor < 0)
|
||||||
yaw_sensor += 36000;
|
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;
|
static const float kDCM_kp_rp_low = 0.01;
|
||||||
int8_t _clamp;
|
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:
|
private:
|
||||||
float _kp_roll_pitch;
|
float _kp_roll_pitch;
|
||||||
@ -129,6 +134,17 @@ private:
|
|||||||
float _health;
|
float _health;
|
||||||
bool _centripetal;
|
bool _centripetal;
|
||||||
uint8_t _toggle;
|
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
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user