15-112 Fundamentals of Programming

Course Syllabus

Welcome to 15-112! This course introduces students to the fundamentals of programming with an emphasis on producing clear, robust, and reasonably efficient code using top-down design, informal analysis, and effective testing and debugging. It is intended for students with little or no background in programming. Even so, it is a fast-paced and rigorous preparation for 15-122. Students looking for a gentler introduction to computer science concepts should consider taking 15-110 first.

A computer program is simply a set of instructions that tells a computer to perform a task. However, finding the right set of instructions can be quite challenging. For this, one has to learn how to structure a larger problem into small subsets, and then find the solution to each of those subsets. A big part of this course is dedicated to teaching students a way of thinking that will enable them to build non-trivial programs.

Just like human-understanble instructions can be given in various human languages, computer-understandable instructions can be given in various programming languages. There can be important differences between programming languages, but many of them use the same building blocks that are fundamental to programming. Once you learn a programming language, it becomes much easier to learn another language. This course uses the Python programming language.

Learning Objectives

  • Develop computational problem-solving skills using Python as a tool to be applied to new problems, especially in the student's home academic discipline.
  • Produce clear, robust, and efficient code in Python by employing top-down design, informal analysis, and effective testing and debugging techniques.
  • Apply programming-style conventions to make the programs easy to understand, debug and modify.
  • Learn independently about new programming-language features and libraries/modules by reading documentation and by experimenting.
  • Develop and write a substantial (700-1500 line) program in Python to implement a solution to a term project of their choosing during the last week of classes.
  • Prerequisites

    None.

    Required Software

    Every required software package we use is available for free on the web. This includes:
  • Python version 3.x (3.4 or later) , which can be freely downloaded from python.org.
  • We may also use Brython, which is a version of Python that runs in web browsers.
  • We will also use one or more free IDE's (code editors) and other free software packages.
  • Resources

    There is no required text for the course. Lecture notes will be provided on the course website. We will frequently use notes from the Spring 2017 edition of the course, which contain very useful examples and videos!

    If you want to look at books which contain part of the course material, we recommend the following:

  • How to Think Like a Computer Scientist (interactive online textbook)
  • Python Programming: An Introduction to Computer Science (regular textbook)
  • If you have any Python specific questions, the first place you should look at is the official Python documentation:

  • Python 3.5.1 documentation
  • Information you find above is guaranteed to be correct. The same cannot be said of information you might find on, say, Stack Overflow. Be careful about googling concepts related to a homework question as this may violate academic integrity (see the section on academic integrity below). You are, however, always welcome to (and encouraged to (!)) use the official Python documentation.

    Communication with the Course Staff

    Every student is required to signup for the course's Piazza page! Course related announcements will be made using Piazza, so you must check Piazza every day.

    If you have a question regarding the lecture material or a homework question, please make use of the following resources:

  • Piazza: Piazza is best suited for questions with a short answer.
  • Office hours: Questions that require a back and forth conversation is much better suited for office hours.

    For personal matters, you can directly email the course instructor, Rudina (rmorina).

    If you have a grading related question, please contact the assistant head TA, Kyle (kdchin).

    Grading

    Your grade for the course will be calculated according to the following table.

    Course Component Weight
    Homework 25%
    Exam 1 20%
    Exam 2 25%
    Quizzes 10%
    Term Project 15%
    Participation 5%

    Alternate Minimum Grading (AMG) Policy

    This AMG policy is available to everybody, but is designed specifically for those students who struggle in the first part of the course and then through sustained hard work and dedication manage to elevate their performance in the latter part of the course to a level that merits passing with a C, even if their Standard Grade might be lower than that.

    In addition to Standard Grading as described above, we will separately compute your grade using an Alternate Minimum Grading (AMG). Students do not sign up for AMG. Every student will be considered both for Standard Grading and AMG, and their semester grade will be the higher of the two (where the highest grade via AMG is a C).

    To compute your Alternate Minimum Grade, compute your score as follows:

    Course Component Weight
    Homework (week 3 onwards) 25%
    Exam 2 40%
    Quizzes (3, 4, 5) 10%
    Term Project 20%
    Participation 5%

    Homework

    There will be multiple homework assignments every week for the first 5 weeks. There will be 2 (or possibly 3) small assignments due during the week, and 1 larger assignment due during the weekend. It is important that you complete all assignments, as this is the major way in which you will learn the material. By working hard on the assignments, you will gain essential experience needed to solve problems on the exams and create term projects that you can be proud of.

    Unless explicitly stated otherwise, all homework must be done by yourself without collaborating with anyone else. You are of course welcome to (and encouraged to (!)) ask questions to the course staff in office hours or Piazza.

    Submission: Assignment submissions will take place on Autolab. Every student is responsible for verifying that their submissions are successful. Misformatted homework in general cannot be graded by our autograder, and as such may receive 0 points. Thus, be sure to submit your homework early -- you can submit repeatedly, but we only grade the last submission.In recitation, we will walk you through how to submit your work on Autolab.

    Late Policy: You are allowed 2 free (no penalty) late days for the course. (These are also called grace days.) You can use at most 1 grace day for an assignment. The late days cannot be broken down further, i.e., even if you submit 5 minutes late, it will count as 1 late day. Once you submit a day late, one of your grace days will be automatically deducted by Autolab. You do not have to notify us. After you have used up all of your late days, late submissions will not be accepted and will result in 0% for that assignment. Exceptions to the lateness policy will not be granted without appropriate justification (e.g. medical or family emergency) submitted in writing and supported by documentary evidence.

    Exams

    We will have 2 exams during the semester (June 12th and June 26th). Both will be held in lecture and they will be cumulative. More information will be provided before the exams.

    Quizzes

    We will have 5 quizzes during the semester (May 26th, June 2nd, June 9th, June 16th, June 23rd). All will be held in Friday recitations. The quizzes will help you prepare for the homework and the exams.

    Term Project

    An important component of the course is the term project. The last week of the course will be entirely devoted to working on your term projects. You will have the freedom to create any program you want! This will be a great way to display all of the programming skills and knowledge you have learned in the course. We hope that you will work on a project that you really find interesting, that you'll have fun working on, and that you'll be proud of at the end.

    Participation

    You are expected to attend every lecture and recitation unless you have special permission from the instructor. Attendance will be taken and will be used to calculate your participation grade.

    Classroom

    Recording

    Students may not record lectures or recitations without explicit permission in writing from the instructor. Violations will result in your failing the course. Exceptions will be granted in accordance with university guidelines for accessibility concerns, but even then such recordings may not be shared publicly or privately and must be deleted at the end of the semester.

    Electronics

    Students may not use any electronic devices in lecture (no cell phones, laptops, iPads, iPods, iWhatevers, etc) without explicit permission in writing from the instructor. Students are expected to take notes, but to do so manually (pen and paper).

    Academic Integrity

    We understand that most of you would never consider cheating in any form. There is, however, a small minority of students for whom this is not the case. In the past, when we have caught students cheating they have often insisted that they did not understand the rules and penalties. As a part of the first homework, you will be required to acknowledge that you have read and understood the cheating policies. Please read Carnegie Mellon University Policy on Academic Integrity. The following are some clear examples of cheating:

  • Looking at another student's paper during an exam or a quiz.
  • Submitting code that does not belong to you without properly citing your sources.
  • Looking at a piece of code related to a homework problem that you have not written yourself or that is not published by the course staff. Specifically: do not look at other students' code or written answers, and do not show them your code or written answers, until after the assignment deadline has passed and the assignment has been submitted and graded.
  • Showing to someone else a piece of code related to a homework problem that is not published by the course. Specifically do not email or otherwise electronically or physically transfer your code to other students, and do not receive such transmissions from other students, until after the assignment deadline has passed and the assignment has been submitted and graded.
  • Googling for specific keywords that happen to appear in one of the homework questions.
  • Getting help from someone who is not part of the course staff.
  • Receiving exam related information from a student who has already taken the exam when you have not.
  • Attempting to hack any part of the 15-112 infrastructure.
  • Lying to the course staff.
  • Online "Help"

    There are many online 'help' resources, and while some may be legitimate, many are basically providing a homework outsourcing service, or otherwise violating the spirit (and often also the letter) of our course policies on cheating and collaboration. Importantly, we also cannot control the quality of 'help' students receive from such sources, and experience indicates many 'answers' from such sources are of very low quality (presumably in part as these are not always supplied by CMU Teaching Assistants or other similarly-qualified tutors). Finally, given the truly extensive support this course provides through daily office hours, private and small-group tutoring, email-based help, and so forth, not to mention the support of the broader CMU community of learners, there is no compelling reason students should need any external sources (except, presumably, to obtain assistance in violation of course policies). AND SO... Students may not post any course content, nor any questions related to any assigned material, to any online venue. Doing so may result in failing the course on the first offense.

    Retaking Course / Reusing Prior Material Policy

    If you are repeating 112, your prior work in this course is treated just as anyone else's work -- that is, you may not consult it. This is to promote the best possible learning, and using your prior answers will only hurt in that regard. So do not refer to your prior work, and solve everything from scratch. This will result in your best learning experience.

    Consequences

    The penalty for cheating can range from a 10% deduction on your overall course average (i.e. a letter grade drop) to directly failing the course. Furthermore, a letter to the Dean of Student Affairs is sent and further consequences are determined by them.

    Plagiarism Detection

    We will be using automated software similarity detection tools to compare your assignment submissions to that of all other students who are currently taking the course and who have taken the course in the past. These tools are very effective at what they have been designed for. For a demonstration, please watch how it works (avi or mp4). Note that the main use of these tools is to determine which submissions should be manually checked for similarity by the instructor; we will not accuse anyone of copying or working in groups based solely on the output of these tools.

    You may also be asked to present and explain your assignment submissions to the instructor at any time.

    Extended-Time and Make-Up Policy

    We are happy to accomodate students that require extended time approved by Larry Powell's office. Please contact the instructor if you are in this situation.

    There will be no make-up quizzes, exams, or homeworks, except in the case of documented medical or family emergencies, or other university approved absences. The common cold or your computer crashing do not qualify as an excused absence. Keep in mind that you have 2 free late days for the homework. You should save up your free late days for when you really need it, e.g., when your computer crashes.

    Well-being and Happiness

    We very much care about your well-being and happiness! Be aware that everyone on the course staff is always available to provide counsel or chat, and you should attend office hours as often as you want for academic and non-academic conversation.

    However, also know that the university provides services that you may want to take advantage of at some point during the semester. Over the summer some resources from the regular semester may be limited or non-existent. If you are ever unsure about them, run into a problem, or want more information, feel free to reach out to the instructor.

    CMU Police Department

    Do not hesitate to call CMU police when in an emergency or if you are interested in taking advantage of their services.
  • Website: http://www.cmu.edu/police/welcome.html
  • Emergency phone number: 412-268-2323
  • Non-Emergency phone number: 412-268-6232
  • Counseling and Psychological Services (CAPS)

    CAPS has a more limited staff during the summer but is still available for you to use. They offer therapy, crisis support, etc. and you should reach out to CAPS for counseling if you are struggling, no matter how small you may think your problems are. If CAPS can’t help you appropriately, they also do referrals and basic consultations to help you find what you need.
  • Website: http://www.cmu.edu/counseling/
  • Hours: Monday through Friday 8:30am-5:00pm
  • Phone number: 412-268-2922
  • Location: 2nd floor, Morewood Gardens, E-Tower
  • University Health Services

    Health services can help you in the same way a doctor does but they also offer comprehensive care management and health promotion services.
  • Website: http://www.cmu.edu/health-services/
  • Medical Emergencies: Call University Police at 412-268-2323 (off campus, call 911)
  • Urgent Medical Care: Visit UHS or call 412-268-2157, option 1.
  • After-Hours Care: Call 412-268-2157 for instructions.
  • To set up an appointment on HealthConnect, click here.
  • Comprehensive Care Manager: Diane Dawson, 412-268-9171
  • 15-112 Non-Technical OH, Wellness help

    If you find yourself struggling in any way or simply would like to discuss how you are feeling about 112 or just chat, reach out to the instructor (rmorina) or to your TA to set up a casual meeting. During office hours we will also offer non-technical help, that is help on approaching your work, managing stress, etc.


    Valid CSS! Valid XHTML 1.0 Strict