Fiducial Follow

top

Introduction

The Fiducial Follow system enables the robot to follow fiducial markers like this one:

Fiducial Markers

This is an aruco marker. Its a little square image, that like a QR code contains an identifier encoded in the pattern of the marker. We use this type of marker a lot on our robots and you’ll encounter them again when you get to the navigation system description. With fiducial follow running the robot continuously searches its field of view for a specific aruco marker (number 49 by default which is shown). Because the marker is a pre-set size and has a pre-set orientation the robot can figure out how far away it is and even which direction it is pointing!

With fiducial follow running the robot knows how far away the marker is, so as it moves away the robot will try to follow it. If it moves to the left the robot will turn to the left, if it moves to the right the robot will turn to the right. In general the robot will try to maintain approximately the same distance from the marker at all times and will try to keep it in the same orientation. This means you can get the robot to move just by placing a marker in front of it. In fact by placing a marker too close in front of the robot you are telling the robot to move to a location behind the marker as quickly as possible, the robot can move forward and back this way, and you can have a robot dance party!

Warning: Magni is a big powerful robot, be really careful about putting a marker in front of the robot. With fiducial follow running you should:

To make fiducial follow work:

Read the above warning and then download and print the following marker:

Marker 49

A paper marker works just fine, but for best results the marker should be kept square and perfectly flat. You can do this by mounting the marker on stiff cardboard or anything flat. We always mount our fiducials on foam core. Its available at most print shops.

Put the fiducial away and close all windows on your computer that have a fiducial on them before you do the next step.

Log in to the robot as per the instructions in the section on connecting.

Once you are logged in to the robot make sure the robot software is running by typing:

rosnode list

the result should look like this:

/controller_spawner /joint_state_publisher /joy_node /motor_node /robot_state_publisher /rosbridge_ws/rosapi /rosbridge_ws/rosbridge_websocket /rosbridge_wss/rosapi /rosbridge_wss/rosbridge_websocket /rosout /teleop_twist_joy /tf2_web_republisher

Then type the following command:

roslaunch magni_demos fiducial_follow.launch

This starts the processes that you need to make fiducial follow work.

Then you can take the fiducial that you printed and put it in front of the robot. Usually the robot will move as soon as it detects an image of the fiducial. The robot can move back and forward. As you move the fiducial around the robot should follow you.

If you move too fast or for some reason the robot loses sight of the fiducial it will attempt to find the fiducial again. It will rotate around the room in an attempt to locate the position of the fiducial until it finally stops.

Common problems are the camera not working. If this is the case check to see if the camera is working by running the command:

raspistill -o cam.jpg

If there are no errors the camera is working.