mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
Tools: autotest for OpticalFlowCalibration
This commit is contained in:
parent
7a35fa2214
commit
d1bf4f1c1e
@ -1999,6 +1999,89 @@ class AutoTestCopter(AutoTest):
|
|||||||
if ex is not None:
|
if ex is not None:
|
||||||
raise ex
|
raise ex
|
||||||
|
|
||||||
|
# fly_optical_flow_calibration - test optical flow calibration
|
||||||
|
def fly_optical_flow_calibration(self):
|
||||||
|
ex = None
|
||||||
|
self.context_push()
|
||||||
|
try:
|
||||||
|
|
||||||
|
self.set_parameter("SIM_FLOW_ENABLE", 1)
|
||||||
|
self.set_parameter("FLOW_TYPE", 10)
|
||||||
|
self.set_analog_rangefinder_parameters()
|
||||||
|
|
||||||
|
# RC9 starts/stops calibration
|
||||||
|
self.set_parameter("RC9_OPTION", 158)
|
||||||
|
|
||||||
|
# initialise flow scaling parameters to incorrect values
|
||||||
|
self.set_parameter("FLOW_FXSCALER", -200)
|
||||||
|
self.set_parameter("FLOW_FYSCALER", 200)
|
||||||
|
|
||||||
|
self.reboot_sitl()
|
||||||
|
|
||||||
|
# ensure calibration is off
|
||||||
|
self.set_rc(9, 1000)
|
||||||
|
|
||||||
|
# takeoff to 10m in loiter
|
||||||
|
self.takeoff(10, mode="LOITER", require_absolute=True, timeout=720)
|
||||||
|
|
||||||
|
# start calibration
|
||||||
|
self.set_rc(9, 2000)
|
||||||
|
|
||||||
|
tstart = self.get_sim_time()
|
||||||
|
timeout = 90
|
||||||
|
veh_dir_tstart = self.get_sim_time()
|
||||||
|
veh_dir = 0
|
||||||
|
while self.get_sim_time_cached() - tstart < timeout:
|
||||||
|
# roll and pitch vehicle until samples collected
|
||||||
|
# change direction of movement every 2 seconds
|
||||||
|
if self.get_sim_time_cached() - veh_dir_tstart > 2:
|
||||||
|
veh_dir_tstart = self.get_sim_time()
|
||||||
|
veh_dir = veh_dir + 1
|
||||||
|
if veh_dir > 3:
|
||||||
|
veh_dir = 0
|
||||||
|
if veh_dir == 0:
|
||||||
|
# move right
|
||||||
|
self.set_rc(1, 1800)
|
||||||
|
self.set_rc(2, 1500)
|
||||||
|
if veh_dir == 1:
|
||||||
|
# move left
|
||||||
|
self.set_rc(1, 1200)
|
||||||
|
self.set_rc(2, 1500)
|
||||||
|
if veh_dir == 2:
|
||||||
|
# move forward
|
||||||
|
self.set_rc(1, 1500)
|
||||||
|
self.set_rc(2, 1200)
|
||||||
|
if veh_dir == 3:
|
||||||
|
# move back
|
||||||
|
self.set_rc(1, 1500)
|
||||||
|
self.set_rc(2, 1800)
|
||||||
|
|
||||||
|
# return sticks to center
|
||||||
|
self.set_rc(1, 1500)
|
||||||
|
self.set_rc(2, 1500)
|
||||||
|
|
||||||
|
# stop calibration (not actually necessary)
|
||||||
|
self.set_rc(9, 1000)
|
||||||
|
|
||||||
|
# check scaling parameters have been restored to values near zero
|
||||||
|
flow_scalar_x = self.get_parameter("FLOW_FXSCALER")
|
||||||
|
flow_scalar_y = self.get_parameter("FLOW_FYSCALER")
|
||||||
|
if ((flow_scalar_x > 30) or (flow_scalar_x < -30)):
|
||||||
|
raise NotAchievedException("FlowCal failed to set FLOW_FXSCALER correctly")
|
||||||
|
if ((flow_scalar_y > 30) or (flow_scalar_y < -30)):
|
||||||
|
raise NotAchievedException("FlowCal failed to set FLOW_FYSCALER correctly")
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
self.print_exception_caught(e)
|
||||||
|
ex = e
|
||||||
|
|
||||||
|
self.context_pop()
|
||||||
|
self.disarm_vehicle(force=True)
|
||||||
|
self.reboot_sitl()
|
||||||
|
|
||||||
|
if ex is not None:
|
||||||
|
raise ex
|
||||||
|
|
||||||
def fly_autotune(self):
|
def fly_autotune(self):
|
||||||
"""Test autotune mode"""
|
"""Test autotune mode"""
|
||||||
|
|
||||||
@ -8019,6 +8102,10 @@ class AutoTestCopter(AutoTest):
|
|||||||
"Fly Optical Flow limits",
|
"Fly Optical Flow limits",
|
||||||
self.fly_optical_flow_limits), # 27s
|
self.fly_optical_flow_limits), # 27s
|
||||||
|
|
||||||
|
("OpticalFlowCalibration",
|
||||||
|
"Fly Optical Flow calibration",
|
||||||
|
self.fly_optical_flow_calibration),
|
||||||
|
|
||||||
("MotorFail",
|
("MotorFail",
|
||||||
"Fly motor failure test",
|
"Fly motor failure test",
|
||||||
self.fly_motor_fail),
|
self.fly_motor_fail),
|
||||||
|
Loading…
Reference in New Issue
Block a user