In this lab you will use a real robot in the physical world. You
will directly program the robot to do specific tasks, such as finding
its way out of a maze. This lab my be done alone or with a partner of
your choice.
We will be using git as a repository for your code for the class. If this is your first time using git, you may want to read a little more about git and its commands. Go through the following steps to setup your directory for this lab.
setup81
to create a git
repository for the lab.
If you want to work alone do:
setup81 labs/01 noneIf you want to work with a partner, then one of you needs to run the following while the other one waits until it finishes.
setup81 labs/01 partnerUsernameOnce the script finishes, the other partner should run it on their account.
cd ~/cs81/labs/01 cp -r ~meeden/public/cs81/labs/01/* ./This will copy over two files called draw.py and escape.py.
git add * git commit -m "lab1 start" git push
cd ~/cs81/labs/01 git pull
The Scribbler robot base has the following capabilities:
The robot has an attachment called the Fluke which provides additional capabilities:
In order to use your robot you'll need to do the following:
python >>> from myro import * >>> init("/dev/rfcommNUM")
The init command attempts to establish a bluetooth connection between the computer you are logged into and your particular robot. You may need to repeat this command several times before a successful connection is made. You can press the UpArrow key to re-enter previous commands within the Python interpreter.
If you are unable to connect, then check for the following problems:
After a successful connection you will see a message like this (the name may be different) and your robot will emit a series of beeps:
You are using fluke firmware 2.9.1 You are using scribbler firmware 1.0.2 Hello, I'm Scribby!
The Scribbler robot uses 6 AA batteries, and only works well when it has enough power. The first command you should run each time you begin using the robot is to check its current battery level:
>>> getBattery()If the battery level is below 6.2, replace the batteries. Put the old batteries into the small green battery recycling bin.
The Scribbler is controlled through a python library called Myro. Read through the Myro reference manual trying the commands interactively in the python interpreter as you go. Not all of the commands will work as described.
For example, the speak command turns a string into spoken words that will be output through the computer's speakers, not from the robot. Some computers do not have speakers so you will not hear anything. Some computers do have speakers, but the volume control is set very low.
Focus your attention on the commands that move the robot and read
the sensors.
After you've tried all of the Myro commands interactively in python, explore the obstacle detection sensors available to you in more detail. You'll need these sensors in order to program the robot to escape from a maze. There are IR sensors on both the scribbler and the fluke. Which ones work more reliably to detect obstacles? Feel free to grab an extra wooden block and bring it back to your desk to more easily test the robot. Read about the setIRPower command in the Myro reference manual. You may need to tweak the power setting of the Fluke's IR sensors in order to get reasonable values for obstacle detection.
Edit the program escape.py in your current lab directory. Using Myro commands, write a program that will cause the robot to find its way out of a maze like the one that is set up at the front of the lab. You have a number of options of how to accomplish this:
Once your robot can successfully escape, move on to the next section. Remember to use git to add, commit, and push the file you have changed.
git add escape.py git commit -m "put some message here" git push
One of the challenging aspects of using physical robots in the real world is that their movements are not always reliable. We will test the reliability of the Scribbler by drawing geometric figures.
Get a big piece of white paper. Insert a pen into the Scribbler's pen port and put it on top of the paper. As the Scribbler moves it will draw a line.
Once you have gotten some good drawings made by your robot, use git to add, commit, and push the file you have changed.
git add draw.py git commit -m "put some message here" git push
When you are completely done, be sure that you have pushed all of your changes to the repo. Use the status command as shown below, to verify this. If there are uncommitted changes, be sure to do another add, commit, and push cycle.
git statusAlso write your name(s) on the saved drawings made by your robot, and turn them into me.