AP_Scripting: use actual_dt for ef rate update

this seems to work more consistently for now
This commit is contained in:
Andrew Tridgell 2022-11-06 17:53:20 +11:00
parent 48415de472
commit d7c0a1025e

View File

@ -111,7 +111,7 @@ local NAV_SCRIPT_TIME = 42702
local MODE_AUTO = 10 local MODE_AUTO = 10
local LOOP_RATE = 50 local LOOP_RATE = 20
local DO_JUMP = 177 local DO_JUMP = 177
local k_throttle = 70 local k_throttle = 70
local NAME_FLOAT_RATE = 2 local NAME_FLOAT_RATE = 2
@ -1795,7 +1795,6 @@ function do_path()
calculate positions and angles at previous, current and next time steps calculate positions and angles at previous, current and next time steps
--]] --]]
next_target_pos_ef = next_target_pos_ef
local p0 = path_var.pos:copy() local p0 = path_var.pos:copy()
local r0 = path_var.roll local r0 = path_var.roll
local s0 = path_var.speed local s0 = path_var.speed
@ -1931,7 +1930,8 @@ function do_path()
--]] --]]
local path_rate_ef_rads = Vector3f() local path_rate_ef_rads = Vector3f()
q_delta:to_axis_angle(path_rate_ef_rads) q_delta:to_axis_angle(path_rate_ef_rads)
path_rate_ef_rads = path_rate_ef_rads:scale(1.0/q_change_t) path_rate_ef_rads = path_rate_ef_rads:scale(1.0/actual_dt)
if Vec3IsNaN(path_rate_ef_rads) then if Vec3IsNaN(path_rate_ef_rads) then
gcs:send_text(0,string.format("path_rate_ef_rads: NaN")) gcs:send_text(0,string.format("path_rate_ef_rads: NaN"))
path_rate_ef_rads = makeVector3f(0,0,0) path_rate_ef_rads = makeVector3f(0,0,0)
@ -1944,15 +1944,19 @@ function do_path()
local path_rate_bf_dps = ahrs:earth_to_body(path_rate_ef_dps) local path_rate_bf_dps = ahrs:earth_to_body(path_rate_ef_dps)
-- set the path roll rate -- set the path roll rate
path_rate_bf_dps:x(math.deg(wrap_pi(r1 - r0)/q_change_t)) path_rate_bf_dps:x(math.deg(wrap_pi(r1 - r0)/actual_dt))
--[[ --[[
calculate body frame roll rate to achieved the desired roll calculate body frame roll rate to achieved the desired roll
angle relative to the maneuver path angle relative to the maneuver path
--]] --]]
path_var.accumulated_orientation_rel_ef = q_delta*path_var.accumulated_orientation_rel_ef local zero_roll_angle_delta = Quaternion()
zero_roll_angle_delta:from_angular_velocity(path_rate_ef_rads, actual_dt)
path_var.accumulated_orientation_rel_ef = zero_roll_angle_delta*path_var.accumulated_orientation_rel_ef
path_var.accumulated_orientation_rel_ef:normalize() path_var.accumulated_orientation_rel_ef:normalize()
local mf_axis = makeVector3f(1, 0, 0) local mf_axis = makeVector3f(1, 0, 0)
path_var.accumulated_orientation_rel_ef:earth_to_body(mf_axis) path_var.accumulated_orientation_rel_ef:earth_to_body(mf_axis)
@ -2010,7 +2014,7 @@ function do_path()
apply angular accel limit apply angular accel limit
--]] --]]
local ang_rate_diff_dps = tot_ang_vel_bf_dps - path_var.last_ang_rate_dps local ang_rate_diff_dps = tot_ang_vel_bf_dps - path_var.last_ang_rate_dps
local max_delta_dps = AEROM_ANG_ACCEL:get() * q_change_t local max_delta_dps = AEROM_ANG_ACCEL:get() * actual_dt
if max_delta_dps > 0 then if max_delta_dps > 0 then
ang_rate_diff_dps:x(constrain(ang_rate_diff_dps:x(), -max_delta_dps, max_delta_dps)) ang_rate_diff_dps:x(constrain(ang_rate_diff_dps:x(), -max_delta_dps, max_delta_dps))
ang_rate_diff_dps:y(constrain(ang_rate_diff_dps:y(), -max_delta_dps, max_delta_dps)) ang_rate_diff_dps:y(constrain(ang_rate_diff_dps:y(), -max_delta_dps, max_delta_dps))