mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-21 16:18:29 -04:00
Tools: autotest: add test for follow mode
This commit is contained in:
parent
929426abf8
commit
36ba3a6e4c
@ -2,6 +2,7 @@
|
||||
|
||||
# Fly ArduCopter in SITL
|
||||
from __future__ import print_function
|
||||
import copy
|
||||
import math
|
||||
import os
|
||||
import shutil
|
||||
@ -3339,6 +3340,64 @@ class AutoTestCopter(AutoTest):
|
||||
if ex is not None:
|
||||
raise ex
|
||||
|
||||
def global_position_int_for_location(self, loc, time, heading=0):
|
||||
return self.mav.mav.global_position_int_encode(
|
||||
int(time * 1000), # time_boot_ms
|
||||
int(loc.lat * 1e7),
|
||||
int(loc.lng * 1e7),
|
||||
int(loc.alt * 1000), # alt in mm
|
||||
20, # relative alt - urp.
|
||||
vx = 0,
|
||||
vy = 0,
|
||||
vz = 0,
|
||||
hdg = heading
|
||||
)
|
||||
|
||||
def fly_follow_mode(self):
|
||||
self.set_parameter("FOLL_ENABLE", 1)
|
||||
self.set_parameter("FOLL_SYSID", 255)
|
||||
foll_ofs_x = 30 # metres
|
||||
self.set_parameter("FOLL_OFS_X", -foll_ofs_x)
|
||||
self.set_parameter("FOLL_OFS_TYPE", 1) # relative to other vehicle heading
|
||||
self.takeoff(10, mode="LOITER")
|
||||
self.set_parameter("SIM_SPEEDUP", 1)
|
||||
self.change_mode("FOLLOW")
|
||||
ex = None
|
||||
tstart = self.get_sim_time_cached()
|
||||
new_loc = self.mav.location()
|
||||
new_loc_offset_n = 20
|
||||
new_loc_offset_e = 30
|
||||
self.location_offset_ne(new_loc, new_loc_offset_n, new_loc_offset_e)
|
||||
self.progress("new_loc: %s" % str(new_loc))
|
||||
heading = 0
|
||||
self.mavproxy.send("map icon %f %f greenplane %f\n" %
|
||||
(new_loc.lat, new_loc.lng, heading))
|
||||
|
||||
expected_loc = copy.copy(new_loc)
|
||||
self.location_offset_ne(expected_loc, -foll_ofs_x, 0)
|
||||
self.mavproxy.send("map icon %f %f hoop\n" %
|
||||
(expected_loc.lat, expected_loc.lng))
|
||||
self.progress("expected_loc: %s" % str(expected_loc))
|
||||
|
||||
last_sent = 0
|
||||
while True:
|
||||
now = self.get_sim_time_cached()
|
||||
if now - last_sent > 0.5:
|
||||
last_run = now
|
||||
gpi = self.global_position_int_for_location(new_loc,
|
||||
now,
|
||||
heading=heading)
|
||||
gpi.pack(self.mav.mav)
|
||||
self.mav.mav.send(gpi)
|
||||
m = self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True)
|
||||
pos = self.mav.location()
|
||||
delta = self.get_distance(expected_loc, pos)
|
||||
max_delta = 2
|
||||
self.progress("position delta=%f (want <%f)" % (delta, max_delta))
|
||||
if delta < max_delta:
|
||||
break
|
||||
self.do_RTL()
|
||||
|
||||
def fly_beacon_position(self):
|
||||
self.reboot_sitl()
|
||||
|
||||
@ -3670,6 +3729,10 @@ class AutoTestCopter(AutoTest):
|
||||
"Fly POSHOLD takeoff",
|
||||
self.fly_poshold_takeoff),
|
||||
|
||||
("FOLLOW",
|
||||
"Fly follow mode",
|
||||
self.fly_follow_mode),
|
||||
|
||||
("OnboardCompassCalibration",
|
||||
"Test onboard compass calibration",
|
||||
self.test_onboard_compass_calibration),
|
||||
|
@ -1104,14 +1104,6 @@ class AutoTestPlane(AutoTest):
|
||||
self.test_fence_breach_circle_at(self.home_position_as_mav_location(),
|
||||
disable_on_breach=True)
|
||||
|
||||
def location_offset_ne(self, location, north, east):
|
||||
'''move location in metres'''
|
||||
print("old: %f %f" % (location.lat, location.lng))
|
||||
(lat, lng) = mp_util.gps_offset(location.lat, location.lng, east, north)
|
||||
location.lat = lat
|
||||
location.lng = lng
|
||||
print("new: %f %f" % (location.lat, location.lng))
|
||||
|
||||
def test_fence_rtl_rally(self):
|
||||
ex = None
|
||||
target_system = 1
|
||||
|
@ -847,6 +847,14 @@ class AutoTest(ABC):
|
||||
return True
|
||||
raise SetRCTimeout("Failed to send RC commands to channel %s" % str(chan))
|
||||
|
||||
def location_offset_ne(self, location, north, east):
|
||||
'''move location in metres'''
|
||||
print("old: %f %f" % (location.lat, location.lng))
|
||||
(lat, lng) = mp_util.gps_offset(location.lat, location.lng, east, north)
|
||||
location.lat = lat
|
||||
location.lng = lng
|
||||
print("new: %f %f" % (location.lat, location.lng))
|
||||
|
||||
def zero_throttle(self):
|
||||
"""Set throttle to zero."""
|
||||
if self.is_rover():
|
||||
|
Loading…
Reference in New Issue
Block a user