CS 354 Autonomous Robotics
Fall 2020
Zeta Rescue!
Introduction
Once again, students in the Engineering Department have meddled with forces they do not understand. In the early morning hours of Dec. 15th 2020 members of an unauthorized capstone project accidentally released massive quantities of deadly zeta radiation into the first floor hallways of the EngGeo building on the campus of James Madison University.
An unknown number students and staff members were in the affected area at the time of the incident. It is assumed that these individuals have been incapacitated by the effects of the zeta radiation. Zeta radiation poisoning progresses through two stages: In the first stage, the victim loses consciousness and transforms into a pumpkin-headed monstrosity. (See Figure 1 below.) The second stage is death. Fortunately, most victims make a full recovery if they receive treatment in time.
Figure 1
A response team is on the way with the necessary equipment to decontaminate the affected areas and treat the victims. Unfortunately, the decontamination process is slow, and the victims don't have much time. It is crucially important that we determine the location and identity of all victims so that the response team can allocate their resources as efficiently as possible.
The high levels of zeta radiation in the contaminated areas will interfere with any wireless communications. The only hope is to send in fully autonomous robots to find the victims and report back on their positions.
Project Outline
Once your application has been launched, no interaction with the robot will be allowed. The robot will have a limited amount of time to search for victims within the area defined by the map. By the end of the time period the robot must return to its initial location.
Once the user requests a report by clicking on the appropriate button, the robot must provide location and identity information for as many victims as possible.
You are free to use any existing ROS Packages in your solution.
Provided Code
The following github repository contains submodules providing a number of ROS packages that will be necessary or helpful in developing your application:
You can clone all of the repositories at once as follows:
git clone --recurse-submodules https://github.com/JMU-ROBOTICS-VIVA/zeta_all.git
Refer to the individual READMEs for information about each package.
Competition Steps
A round of competition will proceed as follows:
The judge launches the competition:
ros2 launch zeta_competition competition.launch.py
This launch file has an optional
headless
argument that makes it possible start the Gazebo simulator with no GUI. This should significantly reduce computational overhead and, hopefully, make it possible to test on lower-powered computers:This launch file will starts the following:ros2 launch zeta_competition competition.launch.py headless:=true
- Gazebo simulator
- Navigation system (judge will initialize pose)
tb_fixer
node from thejmu_turtlebot3_bringup
package- The end-of-competition button node.
Judge starts the rescue application:
ros2 launch zeta_rescue rescue.launch.py
This launch file takes an optional
time_limit
argument indicating the time limit for the competition in seconds:ros2 launch zeta_rescue rescue.launch.py time_limit:=60
You are free to modify
rescue.launch.py
, but you should not add or remove any command line arguments.The judge waits until the time limit has elapsed. By this point, the robot should have returned to the starting area. The judge will then run the
victim_listener
node to receive the results:The final command line argument is a string that will be used to prefix the filenames for storing the results of this run. This node will store an an image for each victim and create a .csv file containing all reported victim locations.ros2 run zeta_competition victim_listener team1_run1
- The judge will click on the "CLICK FOR REPORT" button, indicating to the rescue application that it should publish victim information.
The judge will then inspect the saved files to evaluate the success of the rescue operation.
Competition API
- Subscribed topics:
/report_requested
(std_msgs/msg/Empty
) - When a message is received on this topic, victim information should be published. Any victim information published before the button is pressed will be ignored.
- Published topics:
/victim
(zeta_competition_interfaces/msg/Victim
) This message will contain the full information about a single victim including an image and a location. The image in this message should provide the clearest possible view of the victim, ideally with a legible view of the name tag.
Issues To Consider
Searching
The simplest search strategy is to select random navigation targets until time elapses. The time limit will be short enough that a random strategy will be unlikely to discover all victims. There are many other approaches ranging from simple greedy strategies to complex search algorithms. If you are interested in exploring the literature in this area, A survey on coverage path planning for robotics by Enric Galceran and Marc Carreras [1] would provide a reasonable starting point.
Identifying Victims
Fortunately, all of the victims were wearing name tags with ArUco
augmented reality markers [2] at the time of the accident. The
ros2_aruco
package provides a ROS2 wrapper for performing ArUco
marker identification. You can try out on the competition markers by
starting the competition launch file and then executing the following
launch file to start the aruco detector and an appropriate
visualization:
ros2 launch zeta_rescue aruco_demo.launch.py
The marker detection is not perfectly accurate or reliable, and it only works if the victim is observed from the correct direction. You are welcome to use additional strategies for identifying and locating victims.
Coordinate Transforms
It will be necessary to perform some coordinate transformations to map
sensor data into the map coordinate frame. The standard mechanism for
handling this in ROS is to use tf
. Unfortunately, the tf
Python
API is not available in ROS Dashing. Instead, you can use the
transform_service
package to request coordinate transforms. The
transform_service_demo
package includes some sample Python code illustrating how to the server. You can run the code be executing the following
launch file:
ros2 launch transform_service_demo transform_service_demo_launch.py
Testing and Debugging
RViz is one of the key features of the ROS ecosystem. It can be very
difficult to debug a robotics application without being able to
visualize intermediate results. For this application it will probably
be useful to visualize victim data as it is discovered. One approach
to this is to publish to the /victim
topic during testing while
running the victim_listener
node. This node publishes rviz markers
at reported victim locations as well as victim images on the the
/victim_marker
and /victim_image
topics respectively. Both topics
can be viewed in rviz.
Competition
The final project day will be organized as a friendly competition between the project teams. Results will be scored on the basis of the number of victims that each team locates and reports.
The exact scoring rubric will be released as competition date gets closer. The following factors will be considered:
- Incorrect reports: points will be deducted for reporting non-existent victims.
- Duplicate reports: points will be deducted for reporting the same victim multiple times.
- Image quality: points will be deducted if the name of the victim is not legible.
The scoring rubric will not explicitly reward smart search strategies, but random wandering will probably result in fewer detections than a systematic search.
Deadlines and Grading
Your grade for this project will be based on the quality of your final solution, as well as on making adequate progress on intermediate checkpoints.
For the fist two checkpoints you must:
- Create a release named with the appropriate checkpoint number: "checkpoint1", "checkpoint2", etc.
- Post a narrated YouTube video demonstrating the current functionality.
- Provide a short text document document including:
- A link to the YouTube demo.
- A description of the current state of the code: what works, what doesn't, etc.
- Any instructions I would need to test your current code.
- A development plan for the next checkpoint.
The text documents should be named README1.md, README2.md etc., and should be stored in a doc folder in your package.
There are no specific requirements for the functionality that should be finished for the first two checkpoints. However, for full credit, there must be clear progress in functionality from one checkpoint to the next. Also, the code submitted for each checkpoint must represent a complete, executable application. I should be able to run your code after each submission and evaluate the level of functionality. The following checkpoint schedule has an example of the kind of thing I have in mind:
- Checkpoint 1: The robot wanders randomly for a while, somehow recording or reporting where it sees victims. The robot returns to the start location after a fixed time interval.
- Checkpoint 2: All of the functionality for checkpoint 1, plus systematic search patterns. Careful navigation to enable close-up name tag images. Victim data is reported in response to button presses.
Overall final project grades will be calculated as follows:
Checkpoint 1 | 15% |
Checkpoint 2 | 20% |
Peer Evaluation* | 15% |
Final Functionality and Code Quality | 40% |
Competition Score | 10% |
References
[1]Galceran, Enric, and Marc Carreras. "A survey on coverage path planning for robotics." Robotics and Autonomous systems
[2] Garrido-Jurado, Sergio, et al. "Automatic generation and detection of highly reliable fiducial markers under occlusion." Pattern Recognition 47.6 (2014): 2280-2292.
* We reserve the right to increase the weight of this factor if there is strong evidence that a group member has not make a good-faith effort to contribute to the project.