66 lines
1.7 KiB
C++
66 lines
1.7 KiB
C++
|
#include "Plane.h"
|
||
|
#include "qautotune.h"
|
||
|
|
||
|
#if QAUTOTUNE_ENABLED
|
||
|
|
||
|
/*
|
||
|
initialise QAUTOTUNE mode
|
||
|
*/
|
||
|
bool QAutoTune::init()
|
||
|
{
|
||
|
if (!plane.quadplane.available()) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// use position hold while tuning if we were in QLOITER
|
||
|
bool position_hold = (plane.previous_mode == QLOITER);
|
||
|
|
||
|
return init_internals(position_hold,
|
||
|
plane.quadplane.attitude_control,
|
||
|
plane.quadplane.pos_control,
|
||
|
plane.quadplane.ahrs_view,
|
||
|
&plane.quadplane.inertial_nav);
|
||
|
}
|
||
|
|
||
|
float QAutoTune::get_pilot_desired_climb_rate_cms(void) const
|
||
|
{
|
||
|
return plane.quadplane.get_pilot_desired_climb_rate_cms();
|
||
|
}
|
||
|
|
||
|
void QAutoTune::get_pilot_desired_rp_yrate_cd(int32_t &des_roll_cd, int32_t &des_pitch_cd, int32_t &yaw_rate_cds)
|
||
|
{
|
||
|
if (plane.channel_roll->get_control_in() == 0 && plane.channel_pitch->get_control_in() == 0) {
|
||
|
des_roll_cd = 0;
|
||
|
des_pitch_cd = 0;
|
||
|
} else {
|
||
|
des_roll_cd = plane.nav_roll_cd;
|
||
|
des_pitch_cd = plane.nav_pitch_cd;
|
||
|
}
|
||
|
yaw_rate_cds = plane.quadplane.get_desired_yaw_rate_cds();
|
||
|
}
|
||
|
|
||
|
void QAutoTune::init_z_limits()
|
||
|
{
|
||
|
plane.quadplane.pos_control->set_max_speed_z(-plane.quadplane.pilot_velocity_z_max, plane.quadplane.pilot_velocity_z_max);
|
||
|
plane.quadplane.pos_control->set_max_accel_z(plane.quadplane.pilot_accel_z);
|
||
|
}
|
||
|
|
||
|
|
||
|
// Wrote an event packet
|
||
|
void QAutoTune::Log_Write_Event(enum at_event id)
|
||
|
{
|
||
|
// offset of 30 aligned with ArduCopter autotune events
|
||
|
uint8_t ev_id = 30 + (uint8_t)id;
|
||
|
DataFlash_Class::instance()->Log_Write(
|
||
|
"EVT",
|
||
|
"TimeUS,Id",
|
||
|
"s-",
|
||
|
"F-",
|
||
|
"QB",
|
||
|
AP_HAL::micros64(),
|
||
|
ev_id);
|
||
|
}
|
||
|
|
||
|
#endif // QAUTOTUNE_ENABLED
|
||
|
|