Rather than emailing questions directly to the teaching staff, we strongly encourage you to post your questions on Piazza.
If you have any problems or feedback for the Piazza site, please email team@piazza.com (and feel free to cc rrw).
Textbook:
Michael Sipser, Introduction to the Theory of Computation (3rd Edition), Thomson
Note: the 2nd edition of Sipser is also fine for this course, if you can find it cheaper!
Grading: Midterm exam: 25%, Final exam: 35%, Homework: 40%.
Homeworks/Problem Sets:
Homework/psets will come out on Wednesdays (except when an exam falls on the next week) and will be due the following Wednesday at 11.59 pm. Late assignments will not be accepted. To account for this, we will drop the lowest homework grade in computing your final grade. If you are unable to submit your homework because of extenuating circumstances such as a family/medical emergency, please contact Ryan or the TAs about it (ASAP).
We require that you write your homeworks using a word processor that can generate PDFs. If you can generate a readable typeset PDF of your pset (i.e., in a clean font that is not your handwriting), we are OK with whatever system you use. We strongly recommend that you write your homeworks in LaTeX; we will provide the LaTeX source code for every homework assignment! (Exception: Hand-drawn figures are allowed; you can scan them and merge them in your PDF.) Practically every paper published in computer science and mathematics nowadays is written in LaTeX, so the ability to write in LaTeX is a very useful skill. If you use Windows, MiKTeX is a good choice. Grading will be done by TAs and/or Graders, possibly using Gradescope.
Most of the work in this course will be mathematical proofs of various cool facts. Your proofs should be as clear as possible. Note, this does not mean your proofs should be long -- in fact, typically, good clear explanations are also short!
Policy on Collaboration:This is very important; please read carefully. We believe that the best learning often happens when you work with others, and we want to encourage that. But it is equally important that you try to learn on your own! So here are our rules for collaboration on homework:
You must think about all homework problems on your own and do your very best to find the solutions yourself, before discussing/collaborating with other students. After failing to find the answers yourself, you may discuss homework problems with other students, and work in groups on the remaining questions.
You must not look for solutions on the web. Instead, ask us questions if/when you get stuck.
Cite properly! If you work in a group, include the names of the other people in the group in your written solution. In general, if you do receive a significant idea from someone or somewhere, you must acknowledge that person/book/website in your solution.
You must write up your own solution to every problem; you may not copy answers from another student, or any other source. Also, you may not show your answers to another student. Failing to follow this rule may constitute plagiarism.
Deviating from the above rules may result in violation of MIT policies. If you have any questions about our policy, please don't hesitate to send a private note to the course staff on Piazza. We have these rules so that you can learn on your own, and also learn from your classmates. They're actually pretty lax compared to other courses, so please respect them!
How to write/submit homework: To be announced.
Regrade Policy: If you wish to request a regrade on a problem, you will need to prepare a written justification and come to office hours to talk about your solution in person. We require that you submit your request within one week after the homework/exam is returned.
For all homework questions (that do not give away solutions!), please post
to piazza.com/mit/spring2017/6045/home or come visit us at office hours. You can also send private questions (to TAs and instructors only) using Piazza.
02/07 Introduction and course summary; Finite automata, DFAs and NFAs
Readings: Sipser, Chapter 0, 1.1
Slides: [color pdf][grayscale pdf]
02/09 SNOW DAY -- NO CLASS
02/14 DFAs and NFAs, equivalence of DFAs and NFAs
Readings: Sipser 1.1, 1.2
Slides: [color pdf][grayscale pdf]
02/16 Regular expressions; Equivalence of automata and regular expressions
Readings: Sipser 1.3
Slides: [color pdf][grayscale pdf]
02/21 YOUR MONDAY CLASS GOES HERE -- NO 6.045
02/23 Proving languages are not regular; start Minimizing DFAs
Readings: Sipser 1.4, Sipser Problem 7.40 in 2nd ed (7.25 in 3rd ed) and its solution
Slides: [color pdf][grayscale pdf]
03/21 Diagonalization revisited, Proving Undecidability via Reductions
Readings: Sipser 6.1, another take on Rice's theorem
Slides: [color pdf][grayscale pdf]
03/23 Midterm (During class time! --- located at 50-340)
03/28 and 03/30 SPRING BREAK -- NO CLASS
Homework comes out on Wednesdays and is due the following Wednesday at 11:59pm. You are required to compose your homeworks in some word processor (LaTeX is preferred); we will provide source code to get you started.
Midterm: The midterm will be in-class, on Thursday, March 23 in room 50-340. For this exam, we allow one single-sided sheet of notes (on the usual 8.5x11 letter paper); otherwise, the exam is closed-book.
IMPORTANT: If you have a conflict with the midterm time, please email the entire course staff with the subject line "Midterm Conflict". We'll schedule a conflict midterm during the week after spring break.
Final Exam: Room 4-270, Friday, May 26
1:30PM - 4:30PM according to this webpage. For this exam, we will allow one double-sided sheet of notes; otherwise, the exam is closed-book.