Diversity statement

At Southwestern, we are always striving to improve our commitment to diversity and inclusion, and that includes promoting the most inclusive learning environmennt possible. I view diversity as a resource and a strength of our community, and I want to make this course work for studeents of all identities. It is my intent to teach in a way that is as respectful and inclusive as possible with regard to: race, gender/gender identity, sexual orientation, socioeconomic status, age, cultural background, as well as any other identities that I have unintentionally missed. I am always open to your suggestions, comments, concerns, and constructive criticism on how I carry out this ethos.

At Southwestern we have stringent community standards for the treatment of others. I will not tolerate any hate speech, bullying, or harassment of any kind, and I will report any violations of our code of conduct to the Title IX office.

Please feel free to let me know what name and pronouns you prefer to go by, and/or how you want your name to be pronounced, and I will make sure to address you how you want to be addressed.

Religious Observances

Southwestern University recognizes that it has students from a variety of religious and cultural traditions that have special days of observance or celebration that may take students out of their regular activities on certain days during the school year. Since the academic calendar does not always coincide with these days, the following policy is to be followed in order to facilitate student absences due to cultural and religious observances: As far in advance as possible, the student is expected to notify the professor(s) or instructor(s) of the class(es) to be missed. The student is expected to learn what assignments or exams are due or will be assigned on those dates and negotiate with the professor(s) or instructor(s) alternate times for fulfilling those requirements. Students should be prepared to fulfill the requirements prior to the class(es) to be missed.

Students with Disabilities

The Center for Academic Success coordinates reasonable, individualized accommodations for students with documented disabilities (medical, learning and/or psychological). To receive formal accommodations, students must be registered with the Assistant Director of Academic Success, Prothro Suite 120, (512) 863-1536. If you have a disability for which you are or may be requesting an accommodation, the CAS will verify your disability and determine what reasonable accommodation(s) for this course are warranted, and then you should notify me of any required accommodations as soon as possible. Accommodations cannot be applied retroactively. It is the responsibility of any student seeking accommodation(s) for this course to present any necessary documentation to the instructor as early as possible.

Courses credit statement

Courses in the curriculum of the University are expressed in terms of credits. For courses that have a minimum class time of 150 minutes per week, students should expect to work outside of class a minimum of 2 and 1/2 hours per credit per week. For courses that have a minimum class time of 200 minutes per week, students should expect to work outside of class a minimum of 2 hours per credit per week. Class time and out-of-class work for courses yielding fewer than four credits will be expressed as some proportion of a four-credit course.

Prerequisites

The official prerequisite for this courses is CSC 54-284 (Computer Science II), or equivalent. What this means is that I am assuming that have experience with computer programming, basic and intermediate algorithms, and runtime analysis. These concepts will make it easier for you to develop intuitions about the models of computation and the computability that we will cover in this course. Additionally, this course will include some programming assignments, but I won't devote lecture time towards teaching you computer programming. It is also advisable (but not required) to have taken CSC 54-384 (Discrete Mathematics), or any other math course that provides some exposure to proofs (especially proof by contradiction and induction), first order logic, sets, and graphs. If you are unsure about whether you have enough mathematical or programming background for this course, please feel free to reach out to me.

Technology

We will be using the following software in this course.

Moodle

At Southwestern our learning management system is Moodle. You will submit all of your programming assignments on Moodle. I will use Moodle to keep track of grades, and you can use Moodle to see your current grade in the course. Finally, I will be using Moodle to make announcements. It is your responsibility to check your Southwestern email frequently and pay attention to announcements.

Top Hat

Top Hat is a platform that I will be using for for administering in-class practice questions. You should create an account on Top Hat and log into Top Hat at the start of every lecture. You may log in on a computer, on your phone (either in your phone's web browser, or using the Top Hat mobile app). When you create your Top Hat account, you may use any email of your choosing - either your Southwestern email or your personal email will work. Top Hat questions are not counted for a grade, meaning you can answer them freely without worrying about getting the question wrong.

Discord

Discord is an instant-messaging platform that we will be using for communication. I have created a Discord server dedicated to this class. You can use Discord to communicate and collaborate with your fellow classmates. If you ask a question on Discord, you may well get a response from one of your classmates faster than you would get a response if you were to email me. You can also message me privately on Discord if you like using Discord better than email. The Discord server can also serve as a space for informal communication and simply getting to know your classmates better. Note that there are some guidelines about asking for help through Discord - please review the academic integrity section carefully.

Textbook

This course will be self-contained. That said, I (strongly) suggest you obtain a copy of Michael Sipser's Introduction to the Theory of Computation (3rd Edition). This will provide much more thorough explanations of the material we cover. Furthermore, if you enjoy this course and choose to pursue the material further, you will probably need Sipser for future computability and complexity courses.

Grading Scheme

By default we will use the following grading cutoffs:

These cutoffs may be lowered if need be, but they will never be raised. Below we describe all of the components that we will use to calculate your score.

Attendance (0%)

Attending class is very important for many reaons. When I lecture I will add explanations and details that cannot be captured by slides alone. Much of class time will be dedicated to solving problems in groups, but this will not work well if there is not a critical mass of people. Even if you think you know the material well, you will benefit from comparing answers with others and explaining your thought process. That said, I understand that not everyone can attend every lecture, and not every student necessarily needs to attend lecture. Thus, I will track attendance and use it to help both me and you assess your effort and engagement, but I will not use it to calculate your grade.

I will use Moodle to track lecture attendance. At the start of every class, I will write an attendance code on the whiteboard. You will then to the attendance tab on Moodle, enter the code, and mark yourself present. I will also show a QR code on screen that you can use to go straight to the attendance block on Moodle and have the code filled in automatically. If you mark yourself present before start of class, you will earn one (1) attendance point for that day. If you come to class late, you will receive 0.5 points. Othwerwise, you will receive 0 points. I also reserve the right to give you 0 points if you leave class unexcused.

If you have 5 or more unexcused absences you may receive an involuntary withdrawal from the course. If you need to miss class for a University-sponsored event you should let me know as far in advance as possible so that I know not to count it as an unexcused absence.

Written Assignments (20%)

Every week you will complete an assignment based on material covered in the previous week's lecture. These assignments will involve designing different types of machines/expressions/grammars, describing algorithms, and writing proofs about what types of problems different machines can or can't solve. To succeed in this course, it will not be sufficient to simply get the correct answer on homeworks. You should aim to fully understand and digest the solution to each problem. A good rule of thumb is that you should aim to get to the point where you can reproduce the solution without referring to your writeup. All homework assignments should be handed in on paper at the started of class on the day they are due.

Each homework problem will be graded as follows:

Homeworks will be due on Tuesdays. They will be graded and returned on Thursday of that week (i.e. two days later). You will then have until the following Tuesday (i.e., one week after the original due date) to re-work the assignment for a higher grade. Whenever you re-work a problem, you can re-work a 0% grade to a 50% grade, and you can re-work a 50% grade to a 100% grade. What you cannot do is re-work a 0% grade to a 100% grade; in order to earn the chance to re-work your way to 100%, you must put adequate effort into your original submission.

You may write your solutions on paper. However, you are strongly encouraged to typeset your assignments for several reasons, including making it easier for me to read your work, grade it accurately, and give precise feedback. In order to incentivize you to typeset your assignments, I will give one (1) extra credit for submitting typed work. To do this, you can use Microsoft Word, Apple Pages or Google Docs (along with their built-in equation editors) to type your work. However, the best way to typeset mathematical documents is to use LaTeX, a markup language specifically designed for typing mathematical symbols. In my opionion, the easiest way to create documents in LaTeX is through Overleaf, which is basically "Google Docs for LaTeX". In addition to making it easy to write LaTeX code and compile it into a document, Overleaf provides tools such as real-time collaboration, track-changes/commenting, and a chat-box, that will make it easy for me to help you prepare/fix your document. You can look at this tutorial to learn more about what LaTeX is and how to create LaTeX documents on Overleaf. Initially you may experience some growing pains with LaTeX, but eventually you will see that it allows you to write complicated equations much more quickly than other typesetting software; furthermore, because this is not the last mathematically-oriented course you will have to take, learning LaTeX now will serve as an investment that will pay dividends in the future.

In this class you will have to draw several state diagrams. If you are typesetting your assignment, you have a few options for putting them into your document. You can draw them by hand, take a picture or scan it, and insert the picture/scan into your document. You can also use software such as Flap.js or JFlap for drawing state diagrams. If you feel comfortable with python, you can use Dr. David Chiang's Theory of Computing Toolkit (tock). If you use these tools, please cite or acknowledge them in your writeup. Finally, if you are typesetting your assignments in LaTeX, you can actually use LaTeX commands to draw diagrams. This may seem intimidating at first but if you persevere you will see that this is actually the fastest and most convenient way to get state diagrams into your writeup. Here is a tutorial by Dr. David Chiang and Dr. Satyaki Sikdar on drawing state diagrams in LaTeX.

Programming Project (15%)

You will have one programming project. You will write code to parse a text file describing a Chomsky Normal Form grammar, and you will implement an algorithm that tests whether that grammar will accept a particular string. This will give you the chance to connect the theory and practice of computation, and make the material feel more concrete. The project will also sharpen your skills with the kinds of data structures that you explored in your previous computer science courses.

The programming project may be completed individually or with a partner. If you are working with a partner, should use the pair programming technique to ensure that you are both contributing and learning.

In addition to writing code, the programming project includes writing a report. In the report you will answer questions to make sure that you understand the code that you wrote and the concepts that we are learning. You may NOT collaborate with ANYONE (including your programming partner) on the assignment report in ANY capacity. This would defeat the purpose of the report. If you complete the project with a partner, only one of you will need to submit the code on Moodle, but each of you will need to submit separate reports on Moodle.

The programming project has two deadlines: one for the initial submission, and one for the re-work. Here is how it works:

When you write your code, external libraries are explicitly prohibited. You may NOT use any libraries or packages that are not part of the base languages. You may import packages or libraries that are part of the base language, however you may not import packages or libraries that are designed specifically for these problems (i.e., you should not import a regular expression or grammar parser even if it is part of the base language). If you are unsure, please contact the professor to get explicit permission for which libraries you may import. If you use libraries that I do not find acceptable, I reserve the right to ask you to resubmit the assignment without using that library.

Midterm Exam (20%)
Final Exam (30%)

I need some way to evaluate how well you yourself can understand the course material without the help of your peers and/or the instructional staff. That said, I won't make you take a timed exam. Instead, I will administer two take-home exams: a midterm, which will be available in the middle of the semester, and a final exam, which will be available during finals week. The exams will be untimed, open book, and open note. I am trusting all of you to complete the exams with integrity.

The exams will test your conceptual understanding of the material. You should not expect to be able to simply regurgitate the solutions to problems we did class and on the homework. You will need to have a thorough understanding of the techniques we used to solve those problems.

Paideia Project (15%)

You will complete a project in which you explore an advanced topic in computability and complexity theory and draw connections with the other courses you take at Southwestern. The topic of the project is open-ended - I have provided some suggested directions, but you are ultimately free to pursue whatever direction you like. For the project, you will submit an initial proposal, and later a full report that details your explorations and the paideia connections that you made. Towards the end of the semester, you will give a presentation on the topic you chose and a summary of your findings.

Extra Engagement (1%)

Throughout the semester you will have opportunities to receive extra credit for active engagement that goes beyond coming to class and completing assignments. You can receive extra engagement points for the following activities: You may receive up to 25 "engagement points", 20 of which may come from activities other than the syllabus quiz.

Pass-fail grading policy

If you are taking the course for pass/fail credit instead of a grade, then you must meet the following criteria to earn a passing grade:

Academic Integrity

We want you to succeed in this course, but we also want you to succeed with integrity. We want to make sure that you actually learn the material, so that the impact of the course doesn't disappear once the semester ends. We also want to make sure that every student has a fair chance to succeed, and isn't being taken advantage of by his or her peers. You worked very hard to get into a prestigious school like Southwestern, and without enforcing academic integrity that very prestige would quickly crumble.

In this course we expect students to adhere to Southwestern University's honor code. This means that you will complete your work honestly, with integrity, and support and environment of integrity within the class. While you may collaborate on homework, all work that you submit should reflect your own effort and understanding. The following actions represent acceptable forms of collaboration:

  • Discussing approaches for solving a problem
  • Walking another student through the steps to solving a problem without actually telling them how to write it up
  • Comparing answers to see that you got the same results
  • Watching/listening to someone else walk through their solution to see if they've completed a problem correct and/or help them find errors
  • Sharing notes from class or student hours
  • You may use the internet to find and learn about techniques that you are able to apply towards completing programming assignments. However, you may not search the internet for direct solutions to the assignments themselves. You may not consult AI software under any circumstances.
  • You may post code output and error messages on Discord, and you may describe your general approach/code structure on Discord, but you may not post any code on Discord.
The following actions represent unacceptable forms of collaboration:
  • Dictating to another student exactly how they should write up the solution to a problem
  • Sharing your writeup with another student - in particular, providing them with any sort of document that would even make it possible to copy your work
  • Copying another student's work verbatim, or making small modifications to make it look different without having produced the main ideas independently
  • Accessing another student's work without their permission
  • Taking pictures of another student's writeup for you to reference
  • You may not dictate your programming assignment code to another student, to the point that they could reproduce your solution from your dictation.
  • You may not send your programming assignment code to other groups, and you may not use code that was sent to you from another group.
  • You may engage in whiteboard discussions on how to solve problems; however, you may not write any code on the board during whiteboarding sessions. You should restrict your whiteboarding to visual diagrams and instructions written in human language.
  • Programming project reports must be completed individually. No collaboration is allowed whatsoever (even with your partner). The point of the report is to demonstrate that you pulled your weight on the project that you you fully understand everything that you submitted. You may ask the instructor or tutors for help, but that's it.
A good rule of thumb is that you should be able to reproduce the solutions that you turn in without needing to refer to your writeup. If I suspect that you have not followed the honor code, I reserve the right to ask you to explain the solutions that you submitted, and I will be significantly more inclined to press charges if you cannot reproduce your own work. Additionally, when you are solving participation or homework problems, you should not consult with students who are not in this class, nor should you consult any online resources other than the textbook or posted class materials.

All honor code violations will be handled according to university guidelines. If it is your first violation, you and I will have the opportunity to come to a joint resolution. Otherwise, you will be referred to honor code hearing board for a hearing.

Note: When you are asking for help on Discord, you may ask general questions, and you can post partial solutions in order to get help finishing the problem. Just try not to post anything that fully gives away the answer to a problem. Posting a discord message that gives away too much info is not an honor code violation as long as it was an honest mistake and a good faith effort to give or get help, as opposed to a blatant attempt to help the rest of the class cheat; regardless, but I will delete messages that I judge to be too revealing.

Late Policy

Late Penalty

I will accept late work; however, I will impose a late penalty of 10% for each day that an assignment is late. This means that while it is in your best interest to submit the assignment on time, you won't be penalized harshly if you take a extra time to get the assignment right. Note that I will round up to the next full day, so if you are just 5 minutes late, this will be rounded up to 1 full day and you will still lose 10%. This late penalty applies to all assigned work. There is, however, a way to avoid late penalties...

Late Tokens

I understand that circumstances come up - family or medical situations, tough work in other classes, extracurricular commitments, your social life, etc. For this class, you have three (3) late tokens. A late token grants you the ability to turn in an assignment 24 hours late without incurring any penalties. Alternately, you may use a late token to reduce your late penalty - for example, if you turn in an assignment two days late, you may use a late token to reduce the penalty and lose 10% instead of 20%. You may use late tokens on any assignment (except for the paideia project or exams), and you may use multiple tokens on the same assignment. Late tokens are cannot be transferred from one student to another. Late tokens cannot be split into fractional tokens. When you want to use a late token, please send me an email - not a submission comment or a discord message; this helps me keep all of the late token requests in one place. In your email, tell me which assignment you want to use a late token on (and how many tokens you want to use). Note that I may not email you back, but you can verify that your late token request was accepted by going to Moodle and confirming that your due date for the assignment has been modified.

Mulligans

If you ever accidentally submit the wrong document, and you don't realize this until well after the deadline has passed, you can get a one-time "mulligan" to resubmit the assignment without penalty. However, you must use a late tokens to get a mulligan. Furthermore, you may only get one mulligan per semester. Please be careful and make sure you upload the right document when you submit an assignment! Some additional notes:

  • A mulligan is not a chance to re-work the assignment. This is for situations in which you submit the completely wrong document (such as the work for a different assignment), and it is clearly an accident.
  • If the assignment deadline hasn't passed you don't need to use a mulligan (or even a late token). You can re-upload files as many times as you like, and I will grade the most recent submission.

Extenuating Circumstances

If you have a family or a medical emergency (including a mental health emergency), or if we encounter the literal apocalypse, I can grant you an extension without using a late token. In most circumstances, however, I will probably ask you to simply use a late token or take the late penalty. I reserve the right to request some sort of doctors or parent's note should you make such a request.

Grade Appeals

Grades can be appealed up to two weeks after they have been posted; no appeals will be considered after that time. Please note that the entire assignment will be regraded upon appeal.

Audio/Video Recordings

To ensure the free and open discussion of ideas, students may not record classroom lectures, discussion and/or activities without the advance written permission of the instructor, and any such recording properly approved in advance can be used solely for the student's own private use.

Copyrighted Materials

All material provided through course websites is subject to copyright. This applies to class notes, slides, assignments, exams, solutions, project descriptions, etc. You are allowed (and expected!) to use all of the provided material for personal use. However, you are strictly prohibited from sharing the material with others in general and from posting the material on the web or other file sharing venues in particular.

Covid Statement

At Southwestern, we are committed to providing instruction in the safest and most responsible manner possible. Beginning July 22, 2022, we will no longer require the use of face coverings in indoor spaces on campus, with the following exceptions:

  • Faculty and staff may require the use of face coverings in their personal offices; please continue to carry a mask with you in order to meet the requirements in these spaces.
  • Masks may be required as normal Personal Protective Equipment (PPE) in lab courses.
  • Individuals who are unvaccinated and/or at high risk for serious illness are strongly advised to continue to wear a KN95 or N95 mask in indoor settings and large group events.
We should also recognize that each person comes to the community with their own sense of personal risk. Many will continue to choose to wear a mask, and we should extend our colleagues, peers and neighbors grace in recognition of their needs and preferences. Please consult Southwestern University's official covid policy for the most up-to-date information.