ME CS 133 2018-19
This is a homepage for ME/CS 133(a) (Introduction to Robotics) for Fall/Winter 2018-19. We will also use the Caltech Moodle" system for submitting homeworks, lab assignments, and final project reports.
Course Staff, Hours, Location
|Position||Name||Office||Office Hours (changing weekly)||Phone|
|Instructor||Joel Burdick||245 Gates-Thomas||send mail for an appointment||jwb at robotics dot caltech dot edu||626-395-4139|
|Teach Asst.||Amanda Bouman||205 Gates-Thomas||TBD||me133tas at robotics dot caltech dot edu||626-395-4470|
|Teach Asst.||Anushri Dixit||205 Gates-Thomas||TBD||me133tas at robotics dot caltech dot edu||626-395-4470|
|Teach Asst.||Andrew Singletary||Gates-Thomas||TBD||me133tas at robotics dot caltech dot edu||626-395-????|
|Administrative||Sonya Lincoln||250 Gates-Thomas||7:30am-noon; 1:00pm-4:30pm||lincolns at caltech dot edu||626-395-3385|
Lecture Schedule: Monday, Wednesday, Friday, 3:00-3:55 pm, 135 Gates-Thomas
Announcements For ME/CS 133(a,b)
- 01/18/19: Lab 1b is due on MONDAY. The T.A.s should have emailed to your group the data from your lab scripts.
- Lab 1b, additional code:
- Run this file before sending any commands to check your trajectory. Open rviz in another terminal and add the marker from the published topic. The marker will follow the /bebop/cmd_vel commands.
- In case you are missing your files from Lab 1, they are missing some values or they are corrupted, you can do the analysis on the files in this zip directory. It includes the output file bebop.csv, python script that generated the file, the matlab script to read the output file lab_csv_analysis.m. Run this file to get a comparison between the commanded path, the path bebop though it was doing and the true path from Optitrack
- 12/07/2018: Please mail a copy of your lab 2 report to Andrew Singletary ( firstname.lastname@example.org )
- 11/30/2018: The Final Project Instructions were distributed in class.
Course Text and References
The main course text for ME/CS 133(a) is:
- R.M. Murray, Z. Li, and S. Sastry, A Mathematical Introduction to Robotic Manipulation, CR Press, 1994.
- The 1st edition of this book is available freely on-line at the link above, and is perfectly adequate for the course
We will refer to this text as MLS (the initials of the authors' last names). While the course topics will follow the text, additional material will often be presented in class. Additional course handouts covering this material will be posted on this website
A main text for the ME/CS 133(b) is: Planning Algorithms by Steve LaValle (UIUC).
- You can buy this book on-line at Amazon. A preprint of the text is available freely on-line, and is adequate for all course activities.
The following two books are recommended (but not required) for ME/CS 133(b):
- Principles of Robot Motion: Theory, Algorithms, and Implementations, by Howie Choset, Kevin Lynch, Seth Hutchinson, George Kantor, Wolfram Burgard, Lydia Kavraki, and Sebastian Thrun.
- Probabilistic Robotics, S. Thrun, W. Burgard, D. Fox, MIT Press, 2006.
For ME/CS 133(b), the final grade will be based on a few homework sets, laboratories, and a final project:
- Homework (20%): Homework sets are due at 5 pm on the due date (which will always coincide with a class meeting). Homeworks can be dropped off in class, or deposited in the box outside of 245 Gates-Thomas. Some homeworks will require computation. MATLAB or Mathematica should be sufficient to solve every homework posed in ME/CS 133(a), though students can choose their favorite programming language. Code is considered part of your solution and should be included in with the problem set when appropriate. ME/CS 133(b) will require a bit more knowledge of coding in C++ or python.
- Laboratory (40%): Lab reports are due at 5 pm on the due date (which will usually coincide with a class meeting). Labs can be dropped off in class, or deposited in the box outside of 245 Gates-Thomas. The first labs will familiarize students with the class robots. Subsequent labs will focus on how to translate the lecture material to the lab robots, and will often involve the use of software systems such as ROS and OOMPL.
- Final project (40%): The final project must incorporate some aspect of the course, and the topic and scope my be approved by the course instructor. The final exam will due at 5:00 pm the last day of finals. The final project is similarly due at 5:00 pm on the last day of finals.
- Late Homework Policy: Students may automatically take a 2-day extension on two homeworks or labs during each quarter.
Collaboration on homework assignments is encouraged. You may consult outside reference materials, other students, the TA, or the instructor, but you must cite any use of material from outside references. All solutions that are handed in should be written up individually and should reflect your own understanding of the subject matter. Computer code and graphical plots are considered part of your homework solution, and therefore should be done individually (you can share ideas, but not code).
Laboratory assignments will be performed in small teams. Collaboration on laboratory assignments is different. Each team need only submit one laboratory report.
Course Lecture Schedule for ME/CS 133(b)
Review of Quadcopters, Intro to Motion Planning
|7 Jan. (Mon.)|| ME 133(b) Class Overview,
Intro to Motion Planning
| Course Overview,
Brief Review of Quadcopter Mechanics/Control
| -Lab 1b - |
|9 Jan. (W)||Motion Planning Intro (continued)||Lavalle, Chapter 1|
|11 Jan. (F)||Motion Planning problems, and c-space intro|
Intro to Motion Planning
|14 Jan. (Mon.)||Configuration Space Obstacles||Lavalle Chapter 3.1, Visualization of C-obstacles||Wolfram 2R c-obstacle demo||- N/A-|
|16 Jan. (W)||Motion Planning Intro & Road Maps||Lavalle Chapter 3.1 on c-obstacles|
|17 Jan. (F)||Road Maps Continued||Lavalle Chapter 6.1, 6.2|
RoadMap Motion Planning Methods
|21 Jan. (Mon.)||No Class, Institute MLK Holiday||Homework #1b|
|23 Jan. (W)||Generalized Voronoi Graphs||Lavalle Chapters 6.1 and 6.2 on Roadmaps|
|25 Jan. (F)||Intro to Sample-Based Planners|
Sample-Based Planners, Cellular Decomposition
|28 Jan. (Mon.)||No Class, Burdick sick||-N/A-|
|30 Jan. (W)||Random Dense Trees||Lavalle Chapter 5|
|1 Feb. (F)||Cellular Decomposition||Lavalle Chapt. 6.3|
|4 Feb. (Mon.)||Inertial Navigation||Notes on the Kinematics of Inertial Navigation|| Lab 2 Instructions |
(Due Feb. 20, 2019)
|6 Feb. (W)|
|8 Feb. (F)|
Course Lecture Schedule for ME/CS 133(a)
Introduction and Review of Rigid Body Kinematics
|1 Oct. (Mon.)||Class Overview|| Course Overview,
Chapter 1 of MLS,
Introduction to the DARPA Subterranean Challenge
|History of Kinematics Through 1900 (Introductory chapter from Kinematic Synthesis of Linkages)||-No Homework-|
|3 Oct. (W)|| Planar Rigid Body Kinematics,
|MLS Ch 2.1, Pages 19-23||Wikipedia Page on the Peaucellier Mechanism|
|5 Oct. (F)|| Planar Rigid Body Displacements (continued),
| MLS Ch 2.1,
Change of Reference in Planar Displacements (PowerPoint)
From Planar Rigid Body Kinematics to Spherical Kinematics
|08 Oct. (M)|| poles, Centrodes, elliptic Trammel
||Notes on the Elliptical Trammel|| Archemides Trammel (Wikipedia)
Trammel, V 1, V 2, compliation,
Linkages Synthesized Using Cardan Motion Along Radial Lines
| Homework 1, |
(Due Wed. Oct. 17)
|10 Oct. (W)||Intro to Spherical Kinematics|| MLS Pages 22-26,
Notes on the Classical Matrix Groups
|12 Oct. (F)|| Spherical Kinematics (continued),
Classical Matrix Groups
| MLS Ch 2.2, 2.3,
Notes on Rotations
|Herman Weyl's book on the classical groups|
|15 Oct. (M)||Cayley's Theorem, Euler's Theorem||MLS 27-31||Wikipedia Page on Cayley Transform|| Homework 2 |
(Due Oct. 26)
|17 Oct. (W)||Angle-Axis Representation, Rodriguez Formula, Matrix Exponential,||-N/A-|
|19 Oct. (F)||Euler Angles||MLS 31-34||-N/A-|
|22 Oct. (M)||Quaternions||MLS 33-34||Notes On Algebras||-N/A-|
|24 Oct. (W)|| Quaternion Wrap-Up,
Intro to Spatial Kinematics,
|26 Oct. (F)|| Spatial Exponential Coordinates,
Intro to screws
| MLS 39-45
Spatial Kinematics and Velocities
|29 Oct. (M)||Motion Capture|| Using Rodriguez' Displacement Equation,
Quaternion-Based Displacement Estimation
|Horn paper on Quaternion-Based Displacement Estimation|| Lab 1 |
Zip File with lab1 data and MATLAB scripts
|31 Oct. (W)|| Rigid Body Velocities
|2 Nov. (F)||Rigid Body Velocities and Coordinate Transformations||MLS 51-56||-N/A-|
|5 Nov. (M)||Wrenches||MLS Chapter 2, Sections 5.1 and 5.2|
|7 Nov. (W)||Joints||-N/A-|
|10 NOV. (F)||Multi-Body Kinematics||MLS Chapter 3, Sections 1 and 2||-N/A-|
|12 Nov. (M)||ROS Tutorial||ROS Tutorial|| Python script for ROS Tutorial |
|14 Nov. (W)||In-class tutorial on Running ROS||-N/A-|
|16 NOV. (F)||NO CLASS||-N/A-|
|19 Nov. (M)||Denavit-Hartenberg Convention||Scan of Craig Book on D-H Parameters|
|21 Nov. (W)||More Forward Kinematics, Jacobians||-N/A-|
|23 NOV. (F)||NO CLASS, Thanksgiving Holiday||-N/A-|
Jacobian & Differential Drive Kinematics
|26 Nov. (M)||Jacobians, Differential Drive Kinematics|| MLS Chapter 3, Section 4, pages 115- 121
Kinematics of a Differential Drive Vehicle
| Lab 2 Instructions |
Lab 2 Modifiable Python Script
|28 Nov. (W)||Differential Drive Kinematics||-N/A-|
|30 Nov. (F)||Inverse Kinematics||MLS Chapter 3, pages 97-99||-N/A-|
Inverse Kinematics, Intro to Quadrotors
|3 Dec. (M)||Inverse Kinematics Continued||MLS Chapter 3, pages 108-114|
|5 Dec. (W)||Intro to Multi-Rotors: dynamics||-N/A-|
|7 Dec. (F)||Multi-Rotors: basics of control||-N/A-|