AMoD - City Rescue
This readme file serves as an operation manual for running the entire city rescue demo. The documentation (explanation + how-to's) for each of the four submodules is within their own repository readme.
Link to the demo video, the full demo starts at 01:42
In the demo video, the Duckiebot with following 4 distress situations was rescued:
- out of straight lane
- stuck/crashed (with infrastructure)
- wrong heading (possibly not on correct side of lane)
- out of curve lane
The Duckietown should be setup as an Autolab, with following requirement:
- A map
- A fleet of Autobots
- A localization system
- Ground AprilTags
- Watchtowers
- The localization software on lab server(s)
After building a Duckietown, the map should be recorded following this procedure
This part is mentioned below in Duckiebot setup notes.
Ground AprilTags are essential and should be added to the Autolab following the instructions here. As also mentioned in the link, the tags should be added to the map created
- Build, initialize and calibrate the watchtowers following instructions here
- Place watchtowers in the Autolab with this guideline
- Prepare the docker images on watchtowers. For each watchtower, run following commands on lab server:
- 💻
docker -H <HOSTNAME>.local rm -f dt18_03_roscore_duckiebot-interface_1
- 💻
docker -H <HOSTNAME>.local pull duckietown/dt-duckiebot-interface:daffy-arm32v7
- 💻
docker -H <HOSTNAME>.local pull duckietown/acquisition-bridge:daffy-arm32v7
- 💻
- In terms of network connection, the watchtower should be connected to the lab server machine through cabled Ethernet LAN.
- Pull existing docker images needed
- 💻
docker pull duckietown/dt-ros-commons:daffy-amd64
- 💻
docker pull duckietown/dt-autolab-rviz
- 💻
docker pull duckietown/apriltag-processor:daffy-amd64
- 💻
docker pull duckietown/wheel-odometry-processor:daffy-amd64
- 💻
docker pull duckietown/cslam-graphoptimizer:daffy-amd64
- 💻
- In addition to the localization software, one should also clone the developed repositories onto the lab server
- 💻
git clone
all 4 submodule repositories
- 💻
- And among the developed repositories, build 2 of the server side images
- In terminal, navigate to the duckie-rescue-center repository. Then run 💻
dts devel build -f --arch amd64
- In terminal, navigate to the simple-localization repository. In
packages/localization/src
directory, modify the filebot_tag_mapping
by adding the (Autobot tag ID):(Autobot number) in the file. This files is responsible for mapping a recognized AprilTag to an Autobot, so make sure the demo Autobots are added. Then run 💻dts devel build -f --arch amd64
- In terminal, navigate to the duckie-rescue-center repository. Then run 💻
The Duckiebot should be modified according to the Autobot specification, without the autocharging part.
Among the developed repositories cloned to the lab server, build 2 of the Duckiebot side images:
- In lab server terminal, navigate to the dt-core-cityrescue repository. Then run 💻
dts devel build -f --arch arm32v7 -H <HOSTNAME>.local
- In lab server terminal, navigate to the rescue-acquisition-bridge repository. Then run 💻
dts devel build -f --arch arm32v7 -H <HOSTNAME>.local
- The Autolab map yaml file is created on your GitHub fork of duckietown-world, with ground AprilTags.
- The watchtowers are placed to properly cover the city.
- The watchtowers have the required dt-duckiebot-interface and acquisition-bridge images.
- The lab server has the required images, either pulled or built from the developed repositories.
- The Autobots have the required dt-core-cityrescue and rescue-acquisition-bridge built from the developed repositories.
All commands are run from the lab server terminal, and the 💻 mark will be omitted. For the placeholders in the following commands, a list of clarifications/examples is provided after the command.
docker run --name roscore --rm --net=host -dit duckietown/dt-ros-commons:daffy-amd64 roscore
If this container stopped, all ros nodes that communicate on this master node should be restarted.
First run: xhost +
Then run:
docker run -it --rm --net=host --env="DISPLAY" \
-e ROS_MASTER=<LAB_SERVER_HOSTNAME> \
-e ROS_MASTER_IP=<LAB_SERVER_IP> \
-e DUCKIETOWN_WORLD_FORK=<YOUR_FORK> \
-e MAP_NAME=<YOUR_MAP> \
duckietown/dt-autolab-rviz
- LAB_SERVER_HOSTNAME: e.g.
duckietown9
- LAB_SERVER_IP: e.g.
192.168.1.187
- YOUR_FORK: your GitHub duckietown-world fork (where the Autolab map is created). For ETHZ AMoD Lab, the fork is
jasonhu5
- YOUR_MAP: the map file name, without ".yaml" suffix. For ETHZ AMoD Lab, the map name is
ethz_amod_lab_k31
Expected outcome: Now a rviz window will pop up. It loads and displays the map one specified in above command. On left side bar, the path names should be modified to match the actual autobot names.
First start the required version of dt-duckiebot-interface. For each watchtower, run:
docker -H <HOSTNAME>.local run --name duckiebot-interface \ --privileged -e ROBOT_TYPE=watchtower \
--restart unless-stopped -v /data:/data \
-dit --network=host \
duckietown/dt-duckiebot-interface:daffy-arm32v7
- HOSTNAME: e.g.
watchtower101
Then start the acquisition bridge. For each watchtower, run:
docker -H <HOSTNAME>.local run --name acquisition-bridge \
--network=host -e ROBOT_TYPE=watchtower \
-e LAB_ROS_MASTER_IP=<LAB_SERVER_IP> \
-dit duckietown/acquisition-bridge:daffy-arm32v7
- HOSTNAME: e.g.
watchtower101
- LAB_SERVER_IP: e.g.
192.168.1.187
This is our version acquisition bridge. For each Autobot, run:
docker -H <HOSTNAME>.local run \
--name rescue-acquisition-bridge \
--rm --network=host -v /data:/data \
-e LAB_ROS_MASTER_IP=<LAB_SERVER_IP> \
-dit duckietown/rescue-acquisition-bridge:daffy-arm32v7
- HOSTNAME: e.g.
autobot27
- LAB_SERVER_IP: e.g.
192.168.1.187
It is suggested here to split up the apriltag processors on multiple lab machines. For each watchtower, run
docker run --name apriltag_processor_<WATCHTOWER_NUMBER> \
--network=host -dit --rm \
-e ROS_MASTER_URI=http://<LAB_SERVER_IP>:11311 -e ACQ_DEVICE_NAME=<WATCHTOWER_NAME> \
duckietown/apriltag-processor:daffy-amd64
- WATCHTOWER_NUMBER: for watchtower101, it's
101
- LAB_SERVER_IP: the IP of the lab server that is running ros master, e.g.
192.168.1.187
- WATCHTOWER_NAME: watchtower hostname, e.g.
watchtower101
For each Autobot, run
docker run --name odometry_processor_<AUTOBOT_NUMBER> \
--network=host -dit --rm \
-e ACQ_ROS_MASTER_URI_SERVER_IP=<LAB_SERVER_IP> \
-e ACQ_DEVICE_NAME=<AUTOBOT_NAME> \
duckietown/wheel-odometry-processor:daffy-amd64
- AUTOBOT_NUMBER: for autobot27, it's
27
- LAB_SERVER_IP: the IP of the lab server that is running ros master, e.g.
192.168.1.187
- AUTOBOT_NAME: bot hostname, e.g.
autobot27
docker run --rm \
-e OUTPUT_DIR=/data \
-e ROS_MASTER=<LAB_SERVER_HOSTNAME> \
-e ROS_MASTER_IP=<LAB_SERVER_IP> \
--net=host --name graph_optimizer \
-v <PATH_TO_RESULT_FOLDER>:/data \
-e DUCKIETOWN_WORLD_FORK=<YOUR_FORK> \
-e MAP_NAME=<YOUR_MAP> \
duckietown/cslam-graphoptimizer:daffy-amd64
- LAB_SERVER_HOSTNAME: e.g.
duckietown9
- LAB_SERVER_IP: e.g.
192.168.1.187
- PATH_TO_RESULT_FOLDER: the local path where result files should be created (this does not really matter for city rescue) e.g. ~/ProjectCityRescue
- YOUR_FORK: your GitHub duckietown-world fork (where the Autolab map is created). For ETHZ AMoD Lab, the fork is
jasonhu5
- YOUR_MAP: the map file name, without ".yaml" suffix. For ETHZ AMoD Lab, the map name is
ethz_amod_lab_k31
In the rviz window, add by topic the /cslam_markers
topic.
Expected outcome: after above steps, if one drives the Autobot through the Autolab, in the rviz visualization window, the watchtowers it went past, and a path of the bot will be displayed.
Start the container: docker run --name localization --network=host -it --rm duckietown/simple-localization:v1-amd64
As described here, an offset measurement step is needed. Please follow the steps described here to compensate the offset for the watchtowers that one intend to use.
After the offset measurement procedure is performed for some watchtowers, in the rviz visualization window, add by topic the /simple_loc
markers.
Expected outcome: when one moves the autobot near a offset compensated watchtower, rviz should reflect a faster localization of the bot. The bot appears as a red arrow in the visualization. Verify the position and orientation in rviz match the actual bot.
For each Autobot, run
dts duckiebot demo --duckiebot_name <HOSTNAME> \
--demo_name indefinite_navigation \
--package_name duckietown_demos \
--image duckietown/dt-core-cityrescue:v1-arm32v7
- HOSTNAME, e.g.
autobot27
docker run --name rescue_center \
--network=host -it --rm \
-e ROS_MASTER_IP=http://<LAB_SERVER_IP>:11311 \
-e MAP_FORK=<YOUR_FORK> \
-e MAP_NAME=<YOUR_MAP> \
duckietown/duckie-rescue-center:v1-amd64
- LAB_SERVER_IP: e.g.
192.168.1.187
- YOUR_FORK: your GitHub duckietown-world fork (where the Autolab map is created). For ETHZ AMoD Lab, the fork is
jasonhu5
- YOUR_MAP: the map file name, without ".yaml" suffix. For ETHZ AMoD Lab, the map name is
ethz_amod_lab_k31
Expected Outcome: Information should now be printed from the terminal window, showing e.g. which bots are now being monitored, or are they in distress? If so, what kind of distress situation they are in?
By default, no Autobot is being monitored. Place the demo bot near an offset compensated watchtower. And in a dt-ros-commons container (e.g. started with docker run -it --rm --net host duckietown/dt-ros-commons:daffy-amd64 /bin/bash
), run rosparam set /rescue/rescue_center/add_duckiebot <AUTOBOT_NUMBER>
- AUTOBOT_NUMBER: for autobot27, it's
27
In case one needs to stop a bot from being monitored for distress, run rosparam set /rescue/rescue_center/remove_duckiebot <AUTOBOT_NUMBER>
Expected outcome: Now the autobots are being monitored for distress. Try driving, with keyboard_control demo or dashboard, the autobot out of lane. Verify in rviz that the simple localization marker shows the bot is out of lane very fast, and the bot should begin a rescue operation immediately. The bot will first not respond to joystick commands anymore, and will move backwards, maybe with an angular velocity. Until the bot is at a position that is good for lane following, it's released from rescue nodes and starts to do lane following. This is the same for other distress situations as shown in the demo video.
- Why the rviz visualization does not show the autobot moving?
- Make sure the topic
/cslam_markers
and/simple_loc
are added - If you do not see online localization results, check with
dts start_gui_tools <LAB_SERVER_HOSTNAME>
andrqt_image_view
on the images from watchtowers. - If you see online localizaiton results, but not simple localization results, make sure
- The tag_id:bot_number mapping has been added in the build developed image step.
- The watchtower that sees the bot is offset compensated
- Make sure the topic
- Why is rescue not triggered when the bot is in distress?
- Verify on rviz that the distress situation is reflected with localization. It is possible that the bot is not visible by watchtowers anymore. In that case, adjust watchtowers' heading for better coverage of the map.
- Check the docker processes on the autobot for rescue-acquisition-bridge. It has to be the required image and running.
- Make sure that the bot is added to the monitor list of rescue-center