mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-15 13:18:28 -04:00
152edf7189
Using a global .dir-locals.el file is a better alternative than reincluding the same emacs header in every file of the project.
109 lines
3.3 KiB
C++
109 lines
3.3 KiB
C++
#include "AC_AttitudeControl.h"
|
|
#include <AP_HAL/AP_HAL.h>
|
|
#include <AP_Math/AP_Math.h>
|
|
|
|
/*
|
|
code to monitor and report on the rate controllers, allowing for
|
|
notification of controller oscillation
|
|
*/
|
|
|
|
|
|
/*
|
|
update a RMS estimate of controller state
|
|
*/
|
|
void AC_AttitudeControl::control_monitor_filter_pid(float value, float &rms)
|
|
{
|
|
const float filter_constant = 0.99f;
|
|
// we don't do the sqrt() here as it is quite expensive. That is
|
|
// done when reporting a result
|
|
rms = filter_constant * rms + (1.0f - filter_constant) * sq(value);
|
|
}
|
|
|
|
/*
|
|
update state in _control_monitor
|
|
*/
|
|
void AC_AttitudeControl::control_monitor_update(void)
|
|
{
|
|
const DataFlash_Class::PID_Info &iroll = get_rate_roll_pid().get_pid_info();
|
|
control_monitor_filter_pid(iroll.P + iroll.FF, _control_monitor.rms_roll_P);
|
|
control_monitor_filter_pid(iroll.D, _control_monitor.rms_roll_D);
|
|
|
|
const DataFlash_Class::PID_Info &ipitch = get_rate_pitch_pid().get_pid_info();
|
|
control_monitor_filter_pid(ipitch.P + iroll.FF, _control_monitor.rms_pitch_P);
|
|
control_monitor_filter_pid(ipitch.D, _control_monitor.rms_pitch_D);
|
|
|
|
const DataFlash_Class::PID_Info &iyaw = get_rate_yaw_pid().get_pid_info();
|
|
control_monitor_filter_pid(iyaw.P + iyaw.D + iyaw.FF, _control_monitor.rms_yaw);
|
|
}
|
|
|
|
/*
|
|
log a CRTL message
|
|
*/
|
|
void AC_AttitudeControl::control_monitor_log(void)
|
|
{
|
|
DataFlash_Class::instance()->Log_Write("CTRL", "TimeUS,RMSRollP,RMSRollD,RMSPitchP,RMSPitchD,RMSYaw", "Qfffff",
|
|
AP_HAL::micros64(),
|
|
(double)sqrtf(_control_monitor.rms_roll_P),
|
|
(double)sqrtf(_control_monitor.rms_roll_D),
|
|
(double)sqrtf(_control_monitor.rms_pitch_P),
|
|
(double)sqrtf(_control_monitor.rms_pitch_D),
|
|
(double)sqrtf(_control_monitor.rms_yaw));
|
|
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for roll
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_roll(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_roll_P + _control_monitor.rms_roll_D);
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for roll_P
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_roll_P(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_roll_P);
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for roll_D
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_roll_D(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_roll_D);
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for pitch
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_pitch(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_pitch_P + _control_monitor.rms_pitch_D);
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for pitch_P
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_pitch_P(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_pitch_P);
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for pitch_D
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_pitch_D(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_pitch_D);
|
|
}
|
|
|
|
/*
|
|
return current controller RMS filter value for yaw
|
|
*/
|
|
float AC_AttitudeControl::control_monitor_rms_output_yaw(void) const
|
|
{
|
|
return sqrtf(_control_monitor.rms_yaw);
|
|
}
|