mirror of
https://github.com/paparazzi/paparazzi.git
synced 2026-05-23 04:45:37 +08:00
[guided] rewrite guided mode example with a separated lib (#3442)
Doxygen / build (push) Has been cancelled
Doxygen / build (push) Has been cancelled
* [guided] rewrite guided mode example with a separated lib * [Settings] Allows to set setting by name. --------- Co-authored-by: Fabien-B <Fabien-B@github.com>
This commit is contained in:
committed by
GitHub
parent
aa0863fd4f
commit
646a79795d
@@ -12,224 +12,51 @@ PPRZ_SRC = getenv("PAPARAZZI_SRC", path.normpath(path.join(path.dirname(path.abs
|
||||
sys.path.append(PPRZ_SRC + "/sw/lib/python")
|
||||
sys.path.append(PPRZ_HOME + "/var/lib/python") # pprzlink
|
||||
|
||||
from pprzlink.ivy import IvyMessagesInterface
|
||||
from pprzlink.message import PprzMessage
|
||||
from settings_xml_parse import PaparazziACSettings
|
||||
|
||||
from math import radians
|
||||
from time import sleep
|
||||
|
||||
|
||||
class Guidance(object):
|
||||
def __init__(self, ac_id, verbose=False, interface=None):
|
||||
self.ac_id = ac_id
|
||||
self.verbose = verbose
|
||||
self._interface = interface
|
||||
self.auto2_index = None
|
||||
try:
|
||||
settings = PaparazziACSettings(self.ac_id)
|
||||
except Exception as e:
|
||||
print(e)
|
||||
return
|
||||
try:
|
||||
self.auto2_index = settings.name_lookup['auto2'].index
|
||||
except Exception as e:
|
||||
print(e)
|
||||
print("auto2 setting not found, mode change not possible.")
|
||||
if self._interface is None:
|
||||
self._interface = IvyMessagesInterface("guided mode example")
|
||||
|
||||
def shutdown(self):
|
||||
if self._interface is not None:
|
||||
print("Shutting down ivy interface...")
|
||||
self._interface.shutdown()
|
||||
self._interface = None
|
||||
|
||||
def __del__(self):
|
||||
self.shutdown()
|
||||
|
||||
def set_guided_mode(self):
|
||||
"""
|
||||
change auto2 mode to GUIDED.
|
||||
"""
|
||||
if self.auto2_index is not None:
|
||||
msg = PprzMessage("ground", "DL_SETTING")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['index'] = self.auto2_index
|
||||
msg['value'] = 19 # AP_MODE_GUIDED
|
||||
print("Setting mode to GUIDED: %s" % msg)
|
||||
self._interface.send(msg)
|
||||
|
||||
def set_nav_mode(self):
|
||||
"""
|
||||
change auto2 mode to NAV.
|
||||
"""
|
||||
if self.auto2_index is not None:
|
||||
msg = PprzMessage("ground", "DL_SETTING")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['index'] = self.auto2_index
|
||||
msg['value'] = 13 # AP_MODE_NAV
|
||||
print("Setting mode to NAV: %s" % msg)
|
||||
self._interface.send(msg)
|
||||
|
||||
def goto_ned(self, north, east, down, heading=0.0):
|
||||
"""
|
||||
goto a local NorthEastDown position in meters (if already in GUIDED mode)
|
||||
"""
|
||||
msg = PprzMessage("datalink", "GUIDED_SETPOINT_NED")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['flags'] = 0x00
|
||||
msg['x'] = north
|
||||
msg['y'] = east
|
||||
msg['z'] = down
|
||||
msg['yaw'] = heading
|
||||
print("goto NED: %s" % msg)
|
||||
# embed the message in RAW_DATALINK so that the server can log it
|
||||
self._interface.send_raw_datalink(msg)
|
||||
|
||||
def goto_ned_relative(self, north, east, down, yaw=0.0):
|
||||
"""
|
||||
goto a local NorthEastDown position relative to current position in meters (if already in GUIDED mode)
|
||||
"""
|
||||
msg = PprzMessage("datalink", "GUIDED_SETPOINT_NED")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['flags'] = 0x0D
|
||||
msg['x'] = north
|
||||
msg['y'] = east
|
||||
msg['z'] = down
|
||||
msg['yaw'] = yaw
|
||||
print("goto NED relative: %s" % msg)
|
||||
self._interface.send_raw_datalink(msg)
|
||||
|
||||
def goto_body_relative(self, forward, right, down, yaw=0.0):
|
||||
"""
|
||||
goto to a position relative to current position and heading in meters (if already in GUIDED mode)
|
||||
"""
|
||||
msg = PprzMessage("datalink", "GUIDED_SETPOINT_NED")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['flags'] = 0x0E
|
||||
msg['x'] = forward
|
||||
msg['y'] = right
|
||||
msg['z'] = down
|
||||
msg['yaw'] = yaw
|
||||
print("goto body relative: %s" % msg)
|
||||
self._interface.send_raw_datalink(msg)
|
||||
|
||||
def move_at_ned_vel(self, north=0.0, east=0.0, down=0.0, yaw=0.0):
|
||||
"""
|
||||
move at specified velocity in meters/sec with absolute heading (if already in GUIDED mode)
|
||||
"""
|
||||
msg = PprzMessage("datalink", "GUIDED_SETPOINT_NED")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['flags'] = 0x60
|
||||
msg['x'] = north
|
||||
msg['y'] = east
|
||||
msg['z'] = down
|
||||
msg['yaw'] = yaw
|
||||
print("move at vel NED: %s" % msg)
|
||||
self._interface.send_raw_datalink(msg)
|
||||
|
||||
def move_at_body_vel(self, forward=0.0, right=0.0, down=0.0, yaw=0.0):
|
||||
"""
|
||||
move at specified velocity in meters/sec with absolute heading (if already in GUIDED mode)
|
||||
"""
|
||||
msg = PprzMessage("datalink", "GUIDED_SETPOINT_NED")
|
||||
msg['ac_id'] = self.ac_id
|
||||
msg['flags'] = 0x62
|
||||
msg['x'] = forward
|
||||
msg['y'] = right
|
||||
msg['z'] = down
|
||||
msg['yaw'] = yaw
|
||||
print("move at vel body: %s" % msg)
|
||||
self._interface.send_raw_datalink(msg)
|
||||
|
||||
|
||||
class IvyRequester(object):
|
||||
def __init__(self, interface=None):
|
||||
self._interface = interface
|
||||
if interface is None:
|
||||
self._interface = IvyMessagesInterface("ivy requester")
|
||||
self.ac_list = []
|
||||
|
||||
def __del__(self):
|
||||
self.shutdown()
|
||||
|
||||
def shutdown(self):
|
||||
if self._interface is not None:
|
||||
print("Shutting down ivy interface...")
|
||||
self._interface.shutdown()
|
||||
self._interface = None
|
||||
|
||||
def get_aircrafts(self):
|
||||
wait_step = 0.1
|
||||
timeout = 30 / wait_step # 30 seconds
|
||||
new_answer = False
|
||||
|
||||
def aircrafts_cb(ac_id, msg):
|
||||
global new_answer
|
||||
self.ac_list = [int(a) for a in msg['ac_list'].split(',') if a]
|
||||
print("aircrafts: {}".format(self.ac_list))
|
||||
new_answer = True
|
||||
|
||||
self._interface.send_request('ground', "AIRCRAFTS", aircrafts_cb)
|
||||
# hack: sleep briefly to wait for answer
|
||||
while not new_answer and timeout > 0:
|
||||
sleep(wait_step)
|
||||
timeout -= 1
|
||||
|
||||
if not new_answer:
|
||||
print("WARNING: Getting the list of aircraft timed out. The results might be outdated.")
|
||||
# Didn't raise an exception or return None in order to not break the API
|
||||
|
||||
return self.ac_list
|
||||
|
||||
from pprz_connect import PprzConnect, PprzConfig
|
||||
from guided_mode import GuidedMode
|
||||
from settings import PprzSettingsManager
|
||||
|
||||
def main():
|
||||
from time import sleep
|
||||
from math import radians
|
||||
import argparse
|
||||
parser = argparse.ArgumentParser(description="Guided mode example")
|
||||
parser.add_argument("-i", "--ac_id", dest='ac_id', default=0, type=int, help="aircraft ID")
|
||||
parser.add_argument("-i", "--ac_id", dest='ac_id', default=1, type=int, help="aircraft ID")
|
||||
args = parser.parse_args()
|
||||
|
||||
interface = None
|
||||
if args.ac_id > 0:
|
||||
ac_id = args.ac_id
|
||||
else:
|
||||
print("No aircraft ID specified, checking available aircrafts...")
|
||||
interface = IvyMessagesInterface("guided mode example")
|
||||
req = IvyRequester(interface)
|
||||
# hack: sleep briefly so that connections can be established
|
||||
sleep(0.1)
|
||||
aircrafts = req.get_aircrafts()
|
||||
if not aircrafts:
|
||||
print("No active aircrafts found, aborting...")
|
||||
sys.exit(1)
|
||||
elif len(aircrafts) == 1:
|
||||
ac_id = aircrafts[0]
|
||||
else:
|
||||
print("multiple aircrafts found: {}".format(aircrafts))
|
||||
print("please specify one on the commandline...")
|
||||
sys.exit(1)
|
||||
|
||||
try:
|
||||
g = Guidance(ac_id, interface=interface)
|
||||
connect = PprzConnect()
|
||||
sleep(2)
|
||||
print(connect._conf_list_by_id)
|
||||
conf = connect.conf_by_id(str(args.ac_id))
|
||||
settings = PprzSettingsManager(conf.settings, conf.id, connect.ivy)
|
||||
guided = GuidedMode(connect.ivy)
|
||||
|
||||
settings['auto2'] = 'Guided'
|
||||
|
||||
sleep(0.1)
|
||||
g.set_guided_mode()
|
||||
sleep(0.2)
|
||||
g.goto_ned(north=2.0, east=2.0, down=-3.0, heading=radians(90))
|
||||
sleep(10)
|
||||
g.goto_ned_relative(north=-2.0, east=-2.0, down=1.0, yaw=-radians(45))
|
||||
sleep(10)
|
||||
g.goto_body_relative(forward=0.0, right=1.0, down=0.0)
|
||||
sleep(10)
|
||||
g.move_at_ned_vel(north=0.5)
|
||||
sleep(3)
|
||||
g.move_at_body_vel(forward=-0.5)
|
||||
sleep(3)
|
||||
g.set_nav_mode()
|
||||
sleep(0.2)
|
||||
print("Goto NED 2, 2, -3, 90°")
|
||||
guided.goto_ned(conf.id, north=2.0, east=2.0, down=-3.0, heading=radians(90))
|
||||
sleep(5)
|
||||
print("Goto NED relative -2, -2, 1, -45°")
|
||||
guided.goto_ned_relative(conf.id, north=-2.0, east=-2.0, down=1.0, yaw=-radians(45))
|
||||
sleep(5)
|
||||
print("Goto body 0, 1, 0")
|
||||
guided.goto_body_relative(conf.id, forward=0.0, right=1.0, down=0.0)
|
||||
sleep(5)
|
||||
print("Move NED 0.5m/s north")
|
||||
guided.move_at_ned_vel(conf.id, north=0.5)
|
||||
sleep(5)
|
||||
print("Move body -0.5m/s forward")
|
||||
guided.move_at_body_vel(conf.id, forward=-0.5)
|
||||
sleep(2)
|
||||
|
||||
settings['auto2'] = 'Nav'
|
||||
|
||||
except KeyboardInterrupt:
|
||||
print("Stopping on request")
|
||||
g.shutdown()
|
||||
finally:
|
||||
connect.shutdown()
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
||||
Reference in New Issue
Block a user