CIS 3800 (Fall 2023) Home Schedule Assignments Tools & Refs Syllabus

Disclaimer

Table of Contents

Overview

Prerequisites

This course is currently only open to undergraduate students and assumes prior C knowledge (specifically, what is covered in CIS 2400). This includes:

Students in other degree programs may add themselves to the CIS course waitlist. Note that students who have not taken CIS 2400, CIT 5930 or an equivalent course have very little, if any, chance of being admitted.

Course Description

In CIS 2400, you learned some fundamentals of how computers work, starting with transistors, going through assembly, briefly discussion the idea of the Operating System and then ending with the low level programming language of C. In this course, we plan to further develop the model of a computer introduced in CIS 2400 to a model that includes handling multiple programs (and multiple operating systems) running at the same time. A big component of this is seeing how shared resources are allocated and protected across programs.

More directly speaking, we plan to go over the following topics:

Course Materials

Website

The website acts as the central place for organizing material for the course. All essential material for the course is delivered through or linked through the course website. As an example, the website contains the course schedule, lecture materials, recitation materials, homework specifications, and this syllabus. We highly encourage you to explore, try some of the resources that are available, and become familiar with the site early on in the course.

Github

All programming projects will use github for version control. This is increasingly important for the later projects as they will be done with teammates. We will create repositories for you and distribute some provided code through them.

Gradescope

Gradescope is where both programming projects and exams are submitted and graded. You should be able to initially access the gradescope for the course via the canvas sidebar. After the initial access, you should be able to log into gradescope directly and see CIS 3800 on it.

Docker & Speclab

Docker and speclab are the two development enviroments supported by the course. We will not give advice on how to support alternatives unless one cannot get docker or speclab to work.

Docker is the recommended place for developing and testing your programming projects. The environment you will use in Docker will be the same as the environment we grade projects in. Instructions will be posted on Ed shortly into the semester directing you how to setup the docker environment.

If docker does not work, this is what we recommend to use for developing and testing your programming projects. Instructions for using speclab can be found here: https://cets.seas.upenn.edu/answers/speclab.html. Note that you do not need to install Docker on speclab, speclab is already a linux session that you can develop in.

Canvas

The canvas site contains the gradebook, surveys, and class recordings. You are free to use the canvas if you want, but if there is anything that is needed on canvas, it will be directly linked on the course website.

Ed Discussion Board

The Ed Discussion board provides a place for students to get support from course staff. Ed is also the primary mechanism for announcements, though we will try to repeat announcements at the beginning of lecture for convenience.

OHQ

The course has an OHQ that we will be using for virtual office hours. Please write at least a somewhat detailed explanation of your question/problem and what you have tried so far to fix it.

Textbook

There are no strictly required texts for this course, however, some find it helpful to read the course material from a textbook. Note that none of the textbooks listed will have everything used in this course. As a result, we are suggesting the following texts:

If you are looking for a more traditional textbook, past version of the course have required or highly recommended:

Course Components

Lectures

There are approximately 27 lectures throughout the semester, which occur from 1:45 PM to 3:15 PM on Tuesdays and Thursdays. Lectures will introduce Operating Systems concepts and reinforce those concepts with problem solving and small coding exercises. These in-class exercises are designed to prepare people for the exams and projects.

Attendance is not mandatory, but highly encouraged since it is easier to ask questions and participate in activities beneficial for learning. Attending class and engaging in activities may also help you find food teammates for the second and third programming project. It will be possible to join lecture via Zoom, and lecture recordings will be available on Canvas. We will also post videos to supplement lecture, but you are not required to watch these.

A few of the lectures will contain TA demos of the programming projects. We highly suggest you attend and look over the assignment before class. This is a great opportunity to ask clarifying questions to course staff to understand what you are supposed to implement.

Programming Projects

Projects will be distributed through the course website, but will be graded and submitted through the course gradescope. There will be 3 programming projects spread out through the semester:

Some of the projects will have optional extra credit that can be done to help your grade in the course. These will also provide interesting learning opportunities for you to get familiar with the OS concepts. We highly recommend that you at least read them and then consider doing them.

Late submissions will be possible. More information can be found in the assignment policies section here.

Check-in Quizzes

These will be “open-book quizzes” on gradescope that will be due before the first lecture of the week. These assignments will have unlimited submissions, so you can resubmit as many times as you wish. Some weeks will not have such an assignment, details can be found on the course calendar. The lowest two quiz scores will be dropped.

These assignments will be designed based off of exam questions from previous versions of this course and should help prepare you for the exams.

The lowest two check-in quizzes will be graded (this includes quizzes that were missed).

Exams

Exams will be graded by the course staff and will be posted to gradescope. As of now, these are planned to be cumulative, in-person and you can bring your own notes. The second exam will be a second midterm as opposed to a final exam. More information concerning how the exam is conducted will come as the exam approaches.

Policies

Getting Help

It is very important to us that you succeed in CIS 3800. As a result, we are providing many resources to help you succeed. These include:

Please do not be afraid to ask for help if you don’t understand something. We are here to help you succeed. Additionally, some of the course staff will get lonely and bored if no one shows up to their office hours.

It is also very important to us that you maintain your mental wellness throughout the course. A few points are not worth losing sleep over. Everyone on the course staff is available to chat, and you can always attend office hours for a non-academic conversation if necessary.

Additionally, if you are experiencing some unforeseen and extenuating circumstances, please feel free to reach out to course staff for help. Notably, we are still in a global pandemic! Hopefully the pandemic is winding down for everyone, but we know things can come up in the middle of the quarter (whether it is related to the pandemic or not), and we are here to help.

Inclusion

You have a right to a learning environment that feels safe, where you are treated with respect and feel that you can contribute ideas constructively. Put another way, you have the right to an inclusive learning environment.

We want every student to feel that they have a safe and healthy learning environment, and if at any point you feel like this is not the case in any way, please let course staff know and we will see what we can do to help.

You can contact staff by making a private post on Ed, reaching out to course staff via email, talking to course staff at office hours, or scheduling a 1-on-1 with the instructor here: https://www.cis.upenn.edu/~tqmcgaha/#meetings

Disability Services

The Student Disability Services (SDS) is a unit within the Weingarten Learning Resources Center (WLRC) dedicated to ensure equal access to all University programs, activities and services. They offer a wide range of services for students with disabilities that are individually designed and remove the need to reveal sensitive medical information to the course staff. Please submit a request if you will have a medical need for extensions of exam times or assignment deadlines.

Grading Breakdown

Final scores will be rounded to the nearest integer after adding extra credits. Previous versions of the course followed the following scale:

This semester will likely follow a similar grading scale.

Assessment Policies

Late Policy

For exams and weekly check-ins, no late submissions will be accepted, or extensions granted, except for particularly special circumstances.

For homework assignments, we are granting you a total of 5 late tokens.

Below is pseudo code that may help explain things. Apologies if it just makes things more confusing :X

fn handle_late_submission(assignment a, map<student, int> late_token_gradebook) {
  if (a.is_late) {
     double diff = a.submission_date - a.due_date;
     int tokens_used = round_up(diff / 48_hours);  // must be equal to 1 or 2
     for (student s : assignment.group_members) {
       late_token_gradebook[student] -= tokens_used;
       // if the value becomes negative, then that means late deduction 
       // will be applied when calculating final grades
     }
  }
}

Rescheduling Exams

If you know in advance that you will be unable to take an exam, please discuss it with the instructor as soon as possible, at least a day before the exam so that the reason can be verified and plans can be put in place. Make-up exams would likely take place after the initial exam.

For emergency absences, please reach out to the instructor when possible so that plans can be put in place.

Policies regarding absences for the Final Exam are covered by the University Provost; for Spring semester courses, a makeup Final Exam would be scheduled at the start of the following Fall semester. Requests for a makeup Final Exam due to reasons that could reasonably be anticipated (e.g. traveling for summer break) are unlikely to be approved.

Collaboration & Academic Misconduct

In general, we encourage collaboration, but there is a very fine line between collaboration and cheating. We can learn a lot from working with each other and it can make the course more fun, but we also want to ensure that every student can get the maximum benefit from the material this course has to offer. Keep in mind that the overall goal is for YOU to learn the material so you will be prepared for the exams and for job interviews etc. in the future. Cheating turns the assignments into an exercise that is a waste of both your time and ours; save us both by not doing it.

Cheating consists of sharing code or solutions to assignments by either copying, retyping, looking at, or supplying a copy of a file. Examples include:

Cheating is a very serious offense. If you are caught cheating, you can expect an initiation of a cheating case in the University system and a zero for the assignment. Depending on circumstances, you may receive a failing grade in the course. Cheating is an insult to the instructor and course staff, to the department and major program, and most importantly, to you and your fellow students. If you feel that you are having a problem with the material, or don’t have time to finish an assignment, or have any number of other reasons to cheat, then PLEASE talk with the instructor, we are more than happy to work with students as needed. **Just don’t cheat.**

If you are in doubt about what might constitute cheating, send the instructor an email describing the situation and we will be happy to clarify it for you.

See Penn’s Code of Academic Integrity for more information.

Policy on Generative A.I.

This isn’t as much a policy as it is advice. For this class, I recommend against using generative ai like ChatGPT or related technologies. I am not denying that ChatGPT can be a useful tool, I am just not convinced it is useful for your growth and learning of the material in this class.

I do not claim that ChatGPT is useless by these statements. There are many things it can do, I just doubt their usefulness in this class. We will not ban the usage of ChatGPT or similar tools except for during exams, but we expect you to be able to:

All in all, use your best judgement.