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.
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.
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 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.
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.
We will be using the following software in this course.
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 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 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.
By default we will use the following grading cutoffs:
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.
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:
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:
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.
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.
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:
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:
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...
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.
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:
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.
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.
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.
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.
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: