mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AutoTest: add copter stability patch test
This commit is contained in:
parent
b914f9ba06
commit
7bbee36e89
@ -263,6 +263,57 @@ def fly_throttle_failsafe(mavproxy, mav, side=60, timeout=180):
|
|||||||
mavproxy.send('switch 6\n')
|
mavproxy.send('switch 6\n')
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
# fly_stability_patch - fly south, then hold loiter within 5m position and altitude and reduce 1 motor to 60% efficiency
|
||||||
|
def fly_stability_patch(mavproxy, mav, holdtime=30, maxaltchange=5, maxdistchange=5):
|
||||||
|
'''hold loiter position'''
|
||||||
|
mavproxy.send('switch 5\n') # loiter mode
|
||||||
|
wait_mode(mav, 'LOITER')
|
||||||
|
|
||||||
|
# first south
|
||||||
|
print("turn south")
|
||||||
|
mavproxy.send('rc 4 1580\n')
|
||||||
|
if not wait_heading(mav, 180):
|
||||||
|
return False
|
||||||
|
mavproxy.send('rc 4 1500\n')
|
||||||
|
|
||||||
|
#fly west 80m
|
||||||
|
mavproxy.send('rc 2 1100\n')
|
||||||
|
if not wait_distance(mav, 80):
|
||||||
|
return False
|
||||||
|
mavproxy.send('rc 2 1500\n')
|
||||||
|
|
||||||
|
# wait for copter to slow moving
|
||||||
|
if not wait_groundspeed(mav, 0, 2):
|
||||||
|
return False
|
||||||
|
|
||||||
|
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
start_altitude = m.alt
|
||||||
|
start = mav.location()
|
||||||
|
tstart = time.time()
|
||||||
|
tholdstart = time.time()
|
||||||
|
print("Holding loiter at %u meters for %u seconds" % (start_altitude, holdtime))
|
||||||
|
|
||||||
|
# cut motor 1 to 55% efficiency
|
||||||
|
print("Cutting motor 1 to 55% efficiency")
|
||||||
|
mavproxy.send('param set SIM_ENGINE_MUL 0.55\n')
|
||||||
|
|
||||||
|
while time.time() < tstart + holdtime:
|
||||||
|
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
pos = mav.location()
|
||||||
|
delta = get_distance(start, pos)
|
||||||
|
print("Loiter Dist: %.2fm, alt:%u" % (delta, m.alt))
|
||||||
|
if math.fabs(m.alt - start_altitude) > maxaltchange:
|
||||||
|
tholdstart = time.time() # this will cause this test to timeout and fails
|
||||||
|
if delta > maxdistchange:
|
||||||
|
tholdstart = time.time() # this will cause this test to timeout and fails
|
||||||
|
if time.time() - tholdstart > holdtime:
|
||||||
|
print("Stability patch and Loiter OK for %u seconds" % holdtime)
|
||||||
|
# restore motor 1 to 100% efficiency
|
||||||
|
mavproxy.send('param set SIM_ENGINE_MUL 1.0\n')
|
||||||
|
return True
|
||||||
|
print("Stability Patch FAILED")
|
||||||
|
return False
|
||||||
|
|
||||||
#fly_simple - assumes the simple bearing is initialised to be directly north
|
#fly_simple - assumes the simple bearing is initialised to be directly north
|
||||||
# flies a box with 100m west, 15 seconds north, 50 seconds east, 15 seconds south
|
# flies a box with 100m west, 15 seconds north, 50 seconds east, 15 seconds south
|
||||||
def fly_simple(mavproxy, mav, side=100, timeout=120):
|
def fly_simple(mavproxy, mav, side=100, timeout=120):
|
||||||
@ -543,7 +594,7 @@ def fly_ArduCopter(viewerip=None, map=False):
|
|||||||
|
|
||||||
# Loiter for 30 seconds
|
# Loiter for 30 seconds
|
||||||
print("#")
|
print("#")
|
||||||
print("########## Test Loiter for 40 seconds ##########")
|
print("########## Test Loiter for 30 seconds ##########")
|
||||||
print("#")
|
print("#")
|
||||||
if not loiter(mavproxy, mav, 30):
|
if not loiter(mavproxy, mav, 30):
|
||||||
print("loiter failed")
|
print("loiter failed")
|
||||||
@ -583,6 +634,26 @@ def fly_ArduCopter(viewerip=None, map=False):
|
|||||||
print("takeoff failed")
|
print("takeoff failed")
|
||||||
failed = True
|
failed = True
|
||||||
|
|
||||||
|
### Stability patch ###
|
||||||
|
print("#")
|
||||||
|
print("########## Test Stability Patch ##########")
|
||||||
|
print("#")
|
||||||
|
if not fly_stability_patch(mavproxy, mav, 30):
|
||||||
|
print("Stability Patch failed")
|
||||||
|
failed = True
|
||||||
|
|
||||||
|
# RTL
|
||||||
|
print("# RTL #")
|
||||||
|
if not fly_RTL(mavproxy, mav):
|
||||||
|
print("RTL failed")
|
||||||
|
failed = True
|
||||||
|
|
||||||
|
# Takeoff
|
||||||
|
print("# Takeoff")
|
||||||
|
if not takeoff(mavproxy, mav, 10):
|
||||||
|
print("takeoff failed")
|
||||||
|
failed = True
|
||||||
|
|
||||||
# Simple mode
|
# Simple mode
|
||||||
print("# Fly in SIMPLE mode")
|
print("# Fly in SIMPLE mode")
|
||||||
if not fly_simple(mavproxy, mav):
|
if not fly_simple(mavproxy, mav):
|
||||||
|
Loading…
Reference in New Issue
Block a user