From 49f4a007eebbf5bc1ac3a9c2c86d742963547875 Mon Sep 17 00:00:00 2001 From: Nicolas Schodet Date: Fri, 15 Mar 2013 20:03:51 +0100 Subject: digital/ai, digital/io-hub, host/simu/robots: add basic APBirthday simulation --- digital/ai/tools/apbirthday.py | 49 ++++++++++++++++++++++++++++++++++++++++++ digital/ai/tools/test_simu.py | 3 +++ 2 files changed, 52 insertions(+) create mode 100644 digital/ai/tools/apbirthday.py (limited to 'digital/ai') diff --git a/digital/ai/tools/apbirthday.py b/digital/ai/tools/apbirthday.py new file mode 100644 index 00000000..13f06959 --- /dev/null +++ b/digital/ai/tools/apbirthday.py @@ -0,0 +1,49 @@ +import asserv +import asserv.init +import io_hub +import io_hub.init + +from proto.popen_io import PopenIO +import math +import subprocess + +class Robot: + """APBirthday robot instance.""" + + import simu.model.table_eurobot2013 as table_model + import simu.view.table_eurobot2013 as table_view + + import simu.robots.apbirthday.link.bag as robot_link + import simu.robots.apbirthday.model.bag as robot_model + import simu.robots.apbirthday.view.bag as robot_view + + # TODO: use right position. + robot_start_pos = { + False: (250, 2000 - 250, math.radians (0)), + True: (3000 - 250, 2000 - 250, math.radians (180)) + } + + client_nb = 3 + + def __init__ (self, proto_time, instance = 'robot0'): + self.instance = instance + def proto (proto_class, cmd, init): + cmd = [ s.format (instance = instance) for s in cmd ] + return proto_class (PopenIO (cmd), proto_time, **init) + def prog (cmd): + cmd = [ s.format (instance = instance) for s in cmd ] + subprocess.Popen (cmd) + # TODO: use apbirthday model for asserv. + asserv_cmd = ('../../mimot/src/asserv/asserv.host', + '-i{instance}:asserv0', '-m9', 'guybrush') + io_hub_cmd = ('../../io-hub/src/apbirthday/apbirthday.host', + '-i{instance}:io0') + beacon_stub_cmd = ('../../beacon/src/stub/simu_stub.host', + '-i{instance}:beacon0') + self.asserv = proto (asserv.Proto, asserv_cmd, + asserv.init.host['guybrush']) + self.io = proto (io_hub.ProtoGuybrush, io_hub_cmd, + io_hub.init.host['apbirthday']) + self.beacon_stub = prog (beacon_stub_cmd) + self.protos = (self.asserv, self.io) + diff --git a/digital/ai/tools/test_simu.py b/digital/ai/tools/test_simu.py index 330541e2..acb89c5d 100644 --- a/digital/ai/tools/test_simu.py +++ b/digital/ai/tools/test_simu.py @@ -142,6 +142,9 @@ def run (default_robot, test_class = TestSimu): elif options.robot == 'guybrush': import guybrush robot = guybrush.Robot + elif options.robot == 'apbirthday': + import apbirthday + robot = apbirthday.Robot else: parser.error ("unknown robot") app = test_class (robot, options.robot_nb) -- cgit v1.2.3