mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
autotest: send position targets once
This commit is contained in:
parent
d13f6acc66
commit
750f1d4032
@ -3056,28 +3056,28 @@ class AutoTestCopter(AutoTest):
|
||||
"""stop the vehicle moving in guided mode"""
|
||||
self.progress("Stopping vehicle")
|
||||
tstart = self.get_sim_time()
|
||||
# send a position-control command
|
||||
self.mav.mav.set_position_target_local_ned_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_BODY_NED,
|
||||
0b1111111111111000, # mask specifying use-only-x-y-z
|
||||
0, # x
|
||||
0, # y
|
||||
0, # z
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
while True:
|
||||
if self.get_sim_time_cached() - tstart > timeout:
|
||||
raise NotAchievedException("Vehicle did not stop")
|
||||
# send a position-control command
|
||||
self.mav.mav.set_position_target_local_ned_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_BODY_NED,
|
||||
0b1111111111111000, # mask specifying use-only-x-y-z
|
||||
0, # x
|
||||
0, # y
|
||||
0, # z
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("%s" % str(m))
|
||||
if (m.groundspeed < groundspeed_tolerance and
|
||||
@ -3088,29 +3088,30 @@ class AutoTestCopter(AutoTest):
|
||||
startpos = self.mav.recv_match(type='GLOBAL_POSITION_INT',
|
||||
blocking=True)
|
||||
|
||||
self.mav.mav.set_position_target_global_int_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_GLOBAL_RELATIVE_ALT_INT,
|
||||
0b1111111111111000, # mask specifying use-only-lat-lon-alt
|
||||
lat, # lat
|
||||
lon, # lon
|
||||
alt, # alt
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
|
||||
tstart = self.get_sim_time()
|
||||
while True:
|
||||
if self.get_sim_time_cached() - tstart > 200:
|
||||
raise NotAchievedException("Did not move far enough")
|
||||
# send a position-control command
|
||||
self.mav.mav.set_position_target_global_int_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_GLOBAL_RELATIVE_ALT_INT,
|
||||
0b1111111111111000, # mask specifying use-only-lat-lon-alt
|
||||
lat, # lat
|
||||
lon, # lon
|
||||
alt, # alt
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
pos = self.mav.recv_match(type='GLOBAL_POSITION_INT',
|
||||
blocking=True)
|
||||
delta = self.get_distance_int(startpos, pos)
|
||||
@ -3124,28 +3125,28 @@ class AutoTestCopter(AutoTest):
|
||||
self.progress("startpos=%s" % str(startpos))
|
||||
|
||||
tstart = self.get_sim_time()
|
||||
# send a position-control command
|
||||
self.mav.mav.set_position_target_local_ned_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_LOCAL_NED,
|
||||
0b1111111111111000, # mask specifying use-only-x-y-z
|
||||
x, # x
|
||||
y, # y
|
||||
-z_up,# z
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
while True:
|
||||
if self.get_sim_time_cached() - tstart > timeout:
|
||||
raise NotAchievedException("Did not start to move")
|
||||
# send a position-control command
|
||||
self.mav.mav.set_position_target_local_ned_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_LOCAL_NED,
|
||||
0b1111111111111000, # mask specifying use-only-x-y-z
|
||||
x, # x
|
||||
y, # y
|
||||
-z_up,# z
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("%s" % m)
|
||||
if m.groundspeed > 0.5:
|
||||
@ -4410,27 +4411,27 @@ class AutoTestCopter(AutoTest):
|
||||
def fly_guided_move_to(self, destination, timeout=30):
|
||||
'''move to mavutil.location location; absolute altitude'''
|
||||
tstart = self.get_sim_time()
|
||||
self.mav.mav.set_position_target_global_int_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_GLOBAL_INT,
|
||||
0b1111111111111000, # mask specifying use-only-lat-lon-alt
|
||||
int(destination.lat *1e7), # lat
|
||||
int(destination.lng *1e7), # lon
|
||||
destination.alt, # alt
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
while True:
|
||||
if self.get_sim_time() - tstart > timeout:
|
||||
raise NotAchievedException()
|
||||
self.mav.mav.set_position_target_global_int_send(
|
||||
0, # timestamp
|
||||
1, # target system_id
|
||||
1, # target component id
|
||||
mavutil.mavlink.MAV_FRAME_GLOBAL_INT,
|
||||
0b1111111111111000, # mask specifying use-only-lat-lon-alt
|
||||
int(destination.lat *1e7), # lat
|
||||
int(destination.lng *1e7), # lon
|
||||
destination.alt, # alt
|
||||
0, # vx
|
||||
0, # vy
|
||||
0, # vz
|
||||
0, # afx
|
||||
0, # afy
|
||||
0, # afz
|
||||
0, # yaw
|
||||
0, # yawrate
|
||||
)
|
||||
delta = self.get_distance(self.mav.location(), destination)
|
||||
self.progress("delta=%f (want <1)" % delta)
|
||||
if delta < 1:
|
||||
|
Loading…
Reference in New Issue
Block a user