mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-20 07:38:28 -04:00
Blimp: Support changing update period
This commit is contained in:
parent
55e19bbf5b
commit
5491d5bf2d
@ -226,13 +226,13 @@ private:
|
|||||||
AP_InertialNav inertial_nav;
|
AP_InertialNav inertial_nav;
|
||||||
|
|
||||||
// Vel & pos PIDs
|
// Vel & pos PIDs
|
||||||
AC_PID_2D pid_vel_xy{3, 0.2, 0, 0, 0.2, 3, 3, 0.02}; //These are the defaults - P I D FF IMAX FiltHz FiltDHz DT
|
AC_PID_2D pid_vel_xy{3, 0.2, 0, 0, 0.2, 3, 3}; //These are the defaults - P I D FF IMAX FiltHz FiltDHz DT
|
||||||
AC_PID_Basic pid_vel_z{7, 1.5, 0, 0, 1, 3, 3, 0.02};
|
AC_PID_Basic pid_vel_z{7, 1.5, 0, 0, 1, 3, 3};
|
||||||
AC_PID_Basic pid_vel_yaw{3, 0.4, 0, 0, 0.2, 3, 3, 0.02};
|
AC_PID_Basic pid_vel_yaw{3, 0.4, 0, 0, 0.2, 3, 3};
|
||||||
|
|
||||||
AC_PID_2D pid_pos_xy{1, 0.05, 0, 0, 0.1, 3, 3, 0.02};
|
AC_PID_2D pid_pos_xy{1, 0.05, 0, 0, 0.1, 3, 3};
|
||||||
AC_PID_Basic pid_pos_z{0.7, 0, 0, 0, 0, 3, 3, 0.02};
|
AC_PID_Basic pid_pos_z{0.7, 0, 0, 0, 0, 3, 3};
|
||||||
AC_PID pid_pos_yaw{1.2, 0.5, 0, 0, 2, 3, 3, 3, 0.02}; //p, i, d, ff, imax, filt_t, filt_e, filt_d, dt, opt srmax, opt srtau
|
AC_PID pid_pos_yaw{1.2, 0.5, 0, 0, 2, 3, 3, 3}; //p, i, d, ff, imax, filt_t, filt_e, filt_d, dt, opt srmax, opt srtau
|
||||||
|
|
||||||
// System Timers
|
// System Timers
|
||||||
// --------------
|
// --------------
|
||||||
|
@ -14,11 +14,13 @@
|
|||||||
//Runs the main loiter controller
|
//Runs the main loiter controller
|
||||||
void ModeLoiter::run()
|
void ModeLoiter::run()
|
||||||
{
|
{
|
||||||
|
const float dt = blimp.scheduler.get_last_loop_time_s();
|
||||||
|
|
||||||
Vector3f pilot;
|
Vector3f pilot;
|
||||||
pilot.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_pos_xy * blimp.scheduler.get_loop_period_s();
|
pilot.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_pos_xy * dt;
|
||||||
pilot.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_pos_xy * blimp.scheduler.get_loop_period_s();
|
pilot.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_pos_xy * dt;
|
||||||
pilot.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_pos_z * blimp.scheduler.get_loop_period_s();
|
pilot.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_pos_z * dt;
|
||||||
float pilot_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_pos_yaw * blimp.scheduler.get_loop_period_s();
|
float pilot_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_pos_yaw * dt;
|
||||||
|
|
||||||
if (g.simple_mode == 0){
|
if (g.simple_mode == 0){
|
||||||
//If simple mode is disabled, input is in body-frame, thus needs to be rotated.
|
//If simple mode is disabled, input is in body-frame, thus needs to be rotated.
|
||||||
@ -30,10 +32,10 @@ void ModeLoiter::run()
|
|||||||
target_yaw = wrap_PI(target_yaw + pilot_yaw);
|
target_yaw = wrap_PI(target_yaw + pilot_yaw);
|
||||||
|
|
||||||
//Pos controller's output becomes target for velocity controller
|
//Pos controller's output becomes target for velocity controller
|
||||||
Vector3f target_vel_ef{blimp.pid_pos_xy.update_all(target_pos, blimp.pos_ned, {0,0,0}), 0};
|
Vector3f target_vel_ef{blimp.pid_pos_xy.update_all(target_pos, blimp.pos_ned, dt, {0,0,0}), 0};
|
||||||
target_vel_ef.z = blimp.pid_pos_z.update_all(target_pos.z, blimp.pos_ned.z);
|
target_vel_ef.z = blimp.pid_pos_z.update_all(target_pos.z, blimp.pos_ned.z, dt);
|
||||||
float yaw_ef = blimp.ahrs.get_yaw();
|
float yaw_ef = blimp.ahrs.get_yaw();
|
||||||
float target_vel_yaw = blimp.pid_pos_yaw.update_error(wrap_PI(target_yaw - yaw_ef));
|
float target_vel_yaw = blimp.pid_pos_yaw.update_error(wrap_PI(target_yaw - yaw_ef), dt);
|
||||||
blimp.pid_pos_yaw.set_target_rate(target_yaw);
|
blimp.pid_pos_yaw.set_target_rate(target_yaw);
|
||||||
blimp.pid_pos_yaw.set_actual_rate(yaw_ef);
|
blimp.pid_pos_yaw.set_actual_rate(yaw_ef);
|
||||||
|
|
||||||
@ -42,10 +44,10 @@ void ModeLoiter::run()
|
|||||||
constrain_float(target_vel_ef.z, -g.max_vel_z, g.max_vel_z)};
|
constrain_float(target_vel_ef.z, -g.max_vel_z, g.max_vel_z)};
|
||||||
float target_vel_yaw_c = constrain_float(target_vel_yaw, -g.max_vel_yaw, g.max_vel_yaw);
|
float target_vel_yaw_c = constrain_float(target_vel_yaw, -g.max_vel_yaw, g.max_vel_yaw);
|
||||||
|
|
||||||
Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel_ef_c, blimp.vel_ned_filtd, {0,0,0});
|
Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel_ef_c, blimp.vel_ned_filtd, dt, {0,0,0});
|
||||||
float act_down = blimp.pid_vel_z.update_all(target_vel_ef_c.z, blimp.vel_ned_filtd.z);
|
float act_down = blimp.pid_vel_z.update_all(target_vel_ef_c.z, blimp.vel_ned_filtd.z, dt);
|
||||||
blimp.rotate_NE_to_BF(actuator);
|
blimp.rotate_NE_to_BF(actuator);
|
||||||
float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw_c, blimp.vel_yaw_filtd);
|
float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw_c, blimp.vel_yaw_filtd, dt);
|
||||||
|
|
||||||
if(!(blimp.g.dis_mask & (1<<(2-1)))){
|
if(!(blimp.g.dis_mask & (1<<(2-1)))){
|
||||||
motors->front_out = actuator.x;
|
motors->front_out = actuator.x;
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
// Runs the main velocity controller
|
// Runs the main velocity controller
|
||||||
void ModeVelocity::run()
|
void ModeVelocity::run()
|
||||||
{
|
{
|
||||||
|
const float dt = blimp.scheduler.get_last_loop_time_s();
|
||||||
|
|
||||||
Vector3f target_vel;
|
Vector3f target_vel;
|
||||||
target_vel.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_vel_xy;
|
target_vel.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_vel_xy;
|
||||||
target_vel.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_vel_xy;
|
target_vel.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_vel_xy;
|
||||||
@ -15,10 +17,10 @@ void ModeVelocity::run()
|
|||||||
target_vel.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_vel_z;
|
target_vel.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_vel_z;
|
||||||
float target_vel_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_vel_yaw;
|
float target_vel_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_vel_yaw;
|
||||||
|
|
||||||
Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel, blimp.vel_ned_filtd, {0,0,0});
|
Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel, blimp.vel_ned_filtd, dt, {0,0,0});
|
||||||
blimp.rotate_NE_to_BF(actuator);
|
blimp.rotate_NE_to_BF(actuator);
|
||||||
float act_down = blimp.pid_vel_z.update_all(target_vel.z, blimp.vel_ned_filtd.z);
|
float act_down = blimp.pid_vel_z.update_all(target_vel.z, blimp.vel_ned_filtd.z, dt);
|
||||||
float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw, blimp.vel_yaw_filtd);
|
float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw, blimp.vel_yaw_filtd, dt);
|
||||||
|
|
||||||
if(!(blimp.g.dis_mask & (1<<(2-1)))){
|
if(!(blimp.g.dis_mask & (1<<(2-1)))){
|
||||||
motors->front_out = actuator.x;
|
motors->front_out = actuator.x;
|
||||||
|
Loading…
Reference in New Issue
Block a user