Announcements
Most announcements will be on Edstem.
Class Info
Class: Tuesday/Thursday 11:20 - 12:35PM, Science Center 181
Professor: Vasanta Chaganti
Edstem: Q&A Forum
GitHub: Swarthmore GitHub Enterprise
Grades: Grades will be posted on Edstem
Textbook: Accessible via TAP+ on Moodle
Office hours:
Vasanta |
Monday 3.00 - 4.30 PM |
Tuesday 3.30 - 4.30 PM |
|
Marcus Wright |
Friday 2.00 - 4.00 PM |
Weekly Lab Sessions: SCI 240
Section A |
Wednesday 1.15 - 2.45PM |
Section B |
Wednesday 3.00 - 4.30PM |
Welcome to CS43, Computer Networks! This course will introduce fundamental ideas in computer networking. The structure of this course may be different from many other CS courses at Swarthmore. We will be using a teaching model called Peer Instruction, which places a strong emphasis on classroom discussion and student interaction.
The course is composed of the following:
-
Readings: The readings serve as a first exposure to new topics, where students learn the basics of the material.
-
Class meetings: The classroom material will cover the difficult concepts and facilitate student discussions.
-
Labs: There are several lab programming assignments (mostly in C) that will explore various aspects of network programming.
-
Midterms: There will be two midterms instead of a final for this course.
-
Project: There will be a significant end-of-year project culminating in a presentation during Finals Week.
All assessment submissions should follow the Swarthmore Academic Integrity guidelines.
iClickers: This course will use iClickers to facilitate feedback and discussion during class. For many upper level courses including CS43, clicker will commonly be used in class. Clickers may be purchased at the college bookstore or online. Please register your device as soon as you get it. Registering allows me to give you credit for quizzes and class participation. We will begin using clickers for credit at the start of week 2!
Textbook: Computer Networking: A Top-Down Approach by Kurose and Ross. ISBN-13: 978-9356061316 We will be using the Eigth Edition. The electronic version of the textbook is available via the course Moodle page.
Goals for the course
By the end of the course, we hope that you will have developed the skills to:
-
Classify network functionality into the appropriate abstraction layer.
-
Characterize the behavior of popular network applications and protocols (HTTP, SMTP, DNS, etc.).
-
Construct distributed applications using various concurrency models.
-
Design and analyze network application protocols.
-
Identify the role of transport protocols in providing reliability and high performance.
-
Implement routing algorithms and analyze routing protocols.
-
Compare and contrast switching and forwarding platforms.
-
Test and debug networked applications.
Networks Resources
Links that are related to the course may be posted here. If you have suggestions for links, let me know.
Class Schedule
This is a tentative schedule; it may change as we go. You should read the assigned sections before class to prepare for class discussion points. All readings refer to the Kurose and Ross textbook unless otherwise indicated (e.g., there’s a link to some other source).
Week | Date | Topic & In-class Worksheets | Readings & Videos | Labs |
---|---|---|---|---|
1 |
Sep 3 |
1. Optional Reading: K&R: 1.1 |
||
Sep 4 |
||||
Sep 5 |
Protocols, Layering and The Application Layer: HTTP[slides, Worksheet, Class Recording] |
1. K&R: 1.1, 1.5 2. Try Telnet! |
||
2 |
Sep 10 |
The Application Layer: HTTP Sockets[slides, Worksheet, Class Recording] |
||
Sep 11 |
Lab 1 Cntd. |
|||
Sep 12 |
The Application Layer: Socket Programming: Concurrency & Non-blocking I/O[slides recording] |
|||
3 |
Sep 17 |
The Application Layer: HTTP and Performance Cntd.[slides, Worksheet, Class Recording] |
K&R: 2.1 and 2.2 |
|
Sep 18 |
||||
Sep 19 |
The Application Layer: TCP Sockets: [No In-person Class: Class Deliverable, TCP Slides] |
1. Review Persistent-vs-Non-Persistent Connections |
||
4 |
Sep 24 |
The Application Layer: Distributed Systems and The DNS Protocol [Slides] |
Optional Reading: 1. Your Coffee Shop Does not use two-phase commit |
|
Sep 25 |
Lab 2 Cntd. |
|||
Sep 26 |
The Application Layer: Domain Name System [slides, Worksheet, Class Recording] |
|||
5 |
Oct 01 |
DNS and Email[slides, Worksheet, Class Recording] |
1. K&R: 2.4 |
|
Oct 02 |
||||
Oct 03 |
1. K&R 2.5 2. K&R 2.6 |
|||
6 |
Oct 08 |
P2P and BitTorrent[slides, Worksheet, Class Recording] |
K&R 2.3, 2.5, 2.6 |
|
Oct 09 |
Lab 3 Cntd. |
|||
Oct 10 |
BitTorrent Cntd. |
|||
Fall Break |
||||
7 |
Oct 21 |
Midterm-1, SCI 199 7.00 - 9.30 PM |
||
Oct 22 |
DHTs and CDNs[slides, Class Recording] |
K&R 2.6 |
||
Oct 23 |
||||
Oct 24 |
The Transport Layer: Transport Services and UDP[slides, Class-Quiz] |
1. K&R 3.1, 3.2, 3.3 and Pre-class videos: 3. UDP 4. TCP-Mux/Demux, |
||
8 |
Oct 29 |
The Transport Layer: Reliable Transport and TCP[slides, Worksheet, Class Recording] |
K&R 3.5.1 to 3.5.4 |
|
Oct 30 |
Lab 4 Ctnd. |
|||
Oct 31 |
The Transport Layer: Flow and Congestion Control[slides, Worksheet, Class Recording] |
K&R 3.4.3, 3.4.4, 3.6 |
||
9 |
Nov 5 |
The Transport Layer Contd. |
Same readings as above. |
|
Nov 6 |
||||
Nov 7 |
The Network Layer: Introduction[slides, Worksheet, Class Recording] |
K&R 4.1, 4.2.1, 4.3.1 |
||
10 |
Nov 12 |
The Network Layer Contd. |
Same readings as above |
|
Nov 13 |
||||
Nov 14 |
The Network Layer: IP Glue: DHCP, NATs, IPv6, ICMP[slides, Worksheet, Class Recording] |
K&R 4.3.2, 4.3.3, 4.3.4, 5.6 |
||
11 |
Nov 19 |
The Network Layer: IP Glue: DHCP, NATs, IPv6, ICMP[slides, Worksheet, Class Recording] |
||
Nov 20 |
Lab 6 Cntd. |
|||
Nov 21 |
Network Security |
|||
12 |
Nov 26 |
Network Security: Guest Lecture |
Readings: TBA |
|
Nov 27 |
||||
Nov 28 |
Thanksgiving Break |
|||
13 |
Dec 3 |
Midterm-2 In-Class |
||
Dec 4 |
Project |
|||
Dec 5 |
Anonymity and Tor [slides, worksheet, recording] |
|||
14 |
Dec 10 |
Guest Lecture: Quantum Networks |
||
Dec 11 |
Project |
|||
Dec 12 |
Classes End |
|||
About Course Work
Class Policy
This course will have pre-recorded class videos and readings that are required before class. There will be a short reading quiz based on that day’s required videos/readings. In-class we will break into smaller discussion groups and go over 10-15 minute discussion questions, that take a deeper look at the class material. You’re expected to actively participate in your smaller discussion groups. The homework quizzes will heavily be based on class discussions.
Class Attendance: Participation in class discussions accounts for your participation grade.
Lab Policy
This course features regular lab assignments that account for the largest component of your course grade. Lab attendance is required by all students, unless you have already completed and submitted the lab assignment for the week. While you must attend the lab session for which you are registered, you may optionally attend additional lab sessions,however, students registered for the lab will have priority.
Changing Lab Sections: Right now, we have an even number of folks in each lab section. If you would like to switch sections please send out a post on EdStem so someone can swap with you.
Lab Due Dates
Lab assignments will typically be assigned during the lab sections on Wednesday will generally be due by midnight on Tuesday 1-2 weeks later. The assignments for this course are designed to expose you to real-world systems. They are probably going to be more complex than most other course related work. You are strongly encouraged to start early! If you can get in the habit of starting early you will be much better off.
Lab Partnerships
For this course, there will be 1 individual lab, and 6 paired labs. You may choose your own lab partner for each lab, there will be a Edstem post to record your choice the week before the lab is out. If you have not chosen a lab partner by Friday the week before, I will assign a lab partner for you.
Working with Partners: For partnered lab assignments, you should follow these guidelines:
-
The expectation is that you and your partner are working together side by side, virtually, for most, if not all, of the time you work on partnered lab assignments. You and your partner should work on all aspects of the project together: initial top-down design, incremental testing and debugging, and final testing and code review.
-
If you are pair programming, where one of you types and one of you watches and assists, then you should swap roles periodically, taking turns doing each part. There may be short periods of time where you each go off and implement some small part independently. However, you should frequently come back together, talk through your changes, push and pull each other’s code from the git repository, and test your merged code together.
-
You should not delete or significantly alter code written by your partner when he or she is not present. If there is a problem in the code, then meet together to resolve it. If there is any issue with the partnership, please contact Vasanta.
Partnerships where partners work mostly independently rarely work out well and rarely result in complete, correct and robust solutions. Partnerships where partners work side-by-side for all or most of the time tend to work out very well.
You and your partner are both equally responsible for initiating scheduling times when you can meet to work together, and for making time available in your schedule for working together.
Absence / Assignment Extension Policy
To help with cases of minor illnesses, or other short-term time limitations, we will drop your three lowest reading and participation grades. You are still responsible for the material, and you should review any missed materials via the class recordings as soon as you can.
Each student may use up to 2 late days for the semester, no questions asked. Late days do not apply to reading quizzes, participation grades. A late day is a considered a full 24-hours (i.e., 15 minutes late is the same as 23 hours late). In the case of labs, late days are counted against all lab partners.
In the rare case in which only one partner has unused late days, the partnership can use the late days, barring a consistent pattern. If you continuously find yourself needing late days on the assignment, please reach out to your Professor to discuss this.
To use your extra time, you must email your professor after you have completed the lab and pushed to your repository. You do not need to inform anyone ahead of time. When you use late time, you should still expect to work on the newly-released lab during the following lab section meeting. The professor will always prioritize answering questions related to the current lab assignment.
If you feel that you need an extension on an assignment or that you are unable to attend class for two or more meetings due to a medical condition (e.g., extended illness, concussion, hospitalization) or other emergency, you must contact the dean’s office and your instructors. Faculty will coordinate with the deans to determine and provide the appropriate accommodations.
Grading
Grades will be weighted as follows:
35% |
Lab assignments (3%, 8%, 8%, 8%, 8%) |
40% |
Midterm-1 (20%) and Midterm-2 (20%) |
15% |
Final project |
10% |
Class & Lab Attendance (5%), Reading Quizzes (5%) |
How to Succeed in CS 88
-
Attend class.
Class attendance is mandatory. In class, we will do a deep dive into the more challenging details of the material. Example case-studies in class will directly contribute to your ability to complete homeworks and midterms. -
Do the required readings/listen to videos before you come to class.
In-class group participation will carry grades, so please come prepared with your readings and videos. This will make for an interesting and lively debate in class. -
Ask questions if you don’t understand.
-
This means both during class and while doing lab assignments.
-
This class continually builds on previous material, so if you don’t understand something one week, it will continue to be a problem the next week, and the week after that, and so on.
-
If you need help, ask your classmates (make sure you have read the "Academic Integrity" section below first), post on EdStem, or come talk with me during my office hours.
-
-
Start the lab assignments early.
-
The assignments for this course are designed to expose you to real-world systems. They are probably going to be more complex than most other assignments from earlier courses.
-
Get in the habit of starting early you will be much better off. If you get stuck on a lab issue early (i.e., not two hours before it is due), there will be time to look for help.
-
In addition, if you start early enough, you can take a break, go do something else, and come back later. I find I always have at least a few new ideas when I come back to a problem after a break. If you wait until the last minute, you can’t do this.
-
-
Completing your labs.
The only effective way to learn the material and consistently do well in the labs is to get into the regular habit of: Discussing the top-down design of your code with your lab partner, before you start coding. Writing descriptive function comments as you go along. ** Incrementally coding and testing with GDB and Valgrind.
+ This process, will make you a sought after computer scientist once you graduate.
-
Attend CS88 Labs.
Lab Attendance is mandatory, and the labs constitute the largest portion of your grade. You should be there! -
Seek help early and often.
Because course material builds on previous material, it is essential to your success in this class that you keep up with the course material. If you are having difficulty with a programming assignment, if you didn’t follow something covered in class, if you feel you need some extra help understanding or practicing some of the course material, or if you just want to discuss something from a class, an assignment, or the text, please come to my office hours.
Policies
Academic Integrity
Academic honesty is required in all your work. Under no circumstances may you hand in work done with (or by) someone else under your own name. Your code should never be shared with anyone; you may not examine or use code belonging to someone else, nor may you let anyone else look at or make a copy of your code. This includes, but is not limited to, obtaining solutions from students who previously took the course or code that can be found online. You may not share solutions after the due date of the assignment or make them publicly available anywhere (e.g. public GitHub repository).
Discussing ideas and approaches to problems with others on a general level is fine (in fact, we encourage you to discuss general strategies with each other), but you should never read anyone else’s code or let anyone else read your code. All code and written homeworks you submit must be your own with the following permissible exceptions: code distributed in class, code found in the course text book, and code worked on with an assigned partner. In these cases, you should always include detailed comments that indicates on which parts of the assignment you received help, and what your sources were.
Use of or consultation with generative AI (e.g., chatGPT or GitHub CoPilot or other variants) is considered to be unauthorized collaboration with another source and is a violation of our academic integrity policy.
Failure to abide by these rules constitutes academic dishonesty and will lead to a hearing of the College Judiciary Committee. According to the Faculty Handbook:
The spirit of this policy applies to all course work, including code, homework solutions (e.g., proofs, analysis, written reports), and exams. Please contact me if you have any questions about what is permissible in this course.
Exam Integrity
Students must strictly adhere to the following policy, which applies to all exams taken in a Computer Science course at Swarthmore:
Exam takers must place all non-essential items at the front of the room (or other designated area). Unless otherwise permitted, students may not have any electronic devices or course materials in their possession during the entirety of the exam. This includes cell phones, tablets, laptops, smart watches, course notes, articles and books, among others. These items should be placed at the front of the room near the proctor. If you need to leave the room during the exam, you must obtain permission from an instructor first. Any non-permitted discussion or aide in regards to exam material will result in immediate forfeiture of the exam and a report to the College Judiciary Committee. Please discuss any concerns or accommodations with your instructor prior to starting the exam.
Academic Accommodations
If you believe you need accommodations for a disability or a chronic medical condition, please visit the Student Disability Services website for details about the accommodations process. Since accommodations require early planning and are not retroactive, contact Student Disability Services as soon as possible. You are also welcome to contact me, Vasanta, privately to discuss your academic needs. However, all disability-related accommodations must be arranged, in advance, through Student Disability Services.
To receive an accommodation for a course activity you must have an official Accommodations Letter and you need to meet with me to work out the details of your accommodation at least two weeks prior to any activity requiring accommodations.
You are also welcome to contact me, privately to discuss your academic needs. However, all disability-related accommodations must be arranged, in advance, through Student Disability Services