From a8ecc2386e4ed008f69a80a5a6f26f8465457533 Mon Sep 17 00:00:00 2001 From: Andy Piper Date: Tue, 24 Sep 2024 11:14:52 +0100 Subject: [PATCH] autotest: GainBackoffTakeoff test --- Tools/autotest/arducopter.py | 121 +++++++++++++++++++++++++++++++++++ 1 file changed, 121 insertions(+) diff --git a/Tools/autotest/arducopter.py b/Tools/autotest/arducopter.py index 3c8e82278c..1747c72fc9 100644 --- a/Tools/autotest/arducopter.py +++ b/Tools/autotest/arducopter.py @@ -10630,6 +10630,7 @@ class AutoTestCopter(vehicle_test_suite.TestSuite): self.SetpointBadVel, self.SplineTerrain, self.TakeoffCheck, + self.GainBackoffTakeoff, ]) return ret @@ -10769,6 +10770,126 @@ class AutoTestCopter(vehicle_test_suite.TestSuite): self.context_pop() self.reboot_sitl() + def GainBackoffTakeoff(self): + '''test gain backoff on takeoff''' + self.context_push() + self.progress("Test gains are fully backed off") + self.set_parameters({ + "ATC_LAND_R_MULT": 0.0, + "ATC_LAND_P_MULT": 0.0, + "ATC_LAND_Y_MULT": 0.0, + "GCS_PID_MASK" : 7, + "LOG_BITMASK": 180222, + }) + self.reboot_sitl() + self.wait_ready_to_arm() + self.change_mode('ALT_HOLD') + + class ValidatePDZero(vehicle_test_suite.TestSuite.MessageHook): + '''asserts correct values in PID_TUNING''' + + def __init__(self, suite, axis): + super(ValidatePDZero, self).__init__(suite) + self.pid_tuning_count = 0 + self.p_sum = 0 + self.d_sum = 0 + self.i_sum = 0 + self.axis = axis + + def hook_removed(self): + if self.pid_tuning_count == 0: + raise NotAchievedException("Did not get PID_TUNING") + if self.i_sum == 0: + raise ValueError("I sum is zero") + print(f"ValidatePDZero: PID_TUNING count: {self.pid_tuning_count}") + + def process(self, mav, m): + if m.get_type() != 'PID_TUNING' or m.axis != self.axis: + return + self.pid_tuning_count += 1 + self.p_sum += m.P + self.d_sum += m.D + self.i_sum += m.I + if self.p_sum > 0: + raise ValueError("P sum is not zero") + if self.d_sum > 0: + raise ValueError("D sum is not zero") + + self.progress("Check that PD values are zero") + self.install_message_hook_context(ValidatePDZero(self, mavutil.mavlink.PID_TUNING_ROLL)) + self.install_message_hook_context(ValidatePDZero(self, mavutil.mavlink.PID_TUNING_PITCH)) + self.install_message_hook_context(ValidatePDZero(self, mavutil.mavlink.PID_TUNING_YAW)) + # until the context pop happens, all received PID_TUNINGS will be verified as good + self.arm_vehicle() + self.set_rc(3, 1500) + self.delay_sim_time(2) + self.set_rc(2, 1250) + self.delay_sim_time(5) + self.assert_receive_message('PID_TUNING', timeout=5) + self.set_rc_default() + self.zero_throttle() + self.disarm_vehicle() + self.context_pop() + + self.context_push() + self.progress("Test gains are not backed off") + self.set_parameters({ + "ATC_LAND_R_MULT": 1.0, + "ATC_LAND_P_MULT": 1.0, + "ATC_LAND_Y_MULT": 1.0, + "GCS_PID_MASK" : 7, + "LOG_BITMASK": 180222, + }) + self.reboot_sitl() + self.wait_ready_to_arm() + self.change_mode('ALT_HOLD') + + class ValidatePDNonZero(vehicle_test_suite.TestSuite.MessageHook): + '''asserts correct values in PID_TUNING''' + + def __init__(self, suite, axis): + super(ValidatePDNonZero, self).__init__(suite) + self.pid_tuning_count = 0 + self.p_sum = 0 + self.d_sum = 0 + self.i_sum = 0 + self.axis = axis + + def hook_removed(self): + if self.pid_tuning_count == 0: + raise NotAchievedException("Did not get PID_TUNING") + if self.p_sum == 0: + raise ValueError("P sum is zero") + if self.i_sum == 0: + raise ValueError("I sum is zero") + print(f"ValidatePDNonZero: PID_TUNING count: {self.pid_tuning_count}") + + def process(self, mav, m): + if m.get_type() != 'PID_TUNING' or m.axis != self.axis: + return + self.pid_tuning_count += 1 + self.p_sum += m.P + self.d_sum += m.D + self.i_sum += m.I + + self.progress("Check that PD values are non-zero") + self.install_message_hook_context(ValidatePDNonZero(self, mavutil.mavlink.PID_TUNING_ROLL)) + self.install_message_hook_context(ValidatePDNonZero(self, mavutil.mavlink.PID_TUNING_PITCH)) + self.install_message_hook_context(ValidatePDNonZero(self, mavutil.mavlink.PID_TUNING_YAW)) + # until the context pop happens, all received PID_TUNINGS will be verified as good + self.arm_vehicle() + self.set_rc(3, 1500) + self.delay_sim_time(2) + self.set_rc(2, 1250) + self.delay_sim_time(5) + self.assert_receive_message('PID_TUNING', timeout=5) + self.set_rc_default() + self.zero_throttle() + self.disarm_vehicle() + + self.context_pop() + self.reboot_sitl() + def turn_safety_x(self, value): self.mav.mav.set_mode_send( self.mav.target_system,