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

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

Course Introduction [slides, Worksheet]

1. Optional Reading: K&R: 1.1

Sep 4

Lab Recording

Lab 1

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]

Sockets: Pre-Class Video

Sep 11

Lab Recording

Lab 1 Cntd.

Sep 12

The Application Layer: Socket Programming: Concurrency & Non-blocking I/O[slides recording]

1. Socket Programming up to Concurrent Servers

2. Beej 7.1: Blocking

3. Non-Blocking I/O upto select()

3

Sep 17

The Application Layer: HTTP and Performance Cntd.[slides, Worksheet, Class Recording]

K&R: 2.1 and 2.2

Sep 18

Lab Recording

Lab 2

Sep 19

The Application Layer: TCP Sockets: [No In-person Class: Class Deliverable, TCP Slides]

1. Review Persistent-vs-Non-Persistent Connections

2. Concurrent Web Servers

3. Addressing Sockets: Part 1, Part 2

4. Putting it all together: TCP Web Servers

4

Sep 24

The Application Layer: Distributed Systems and The DNS Protocol [Slides]

1. The CAP Theorem

Optional Reading:

1. Your Coffee Shop Does not use two-phase commit

2. Root Servers in the World

3. Benefits of hosting a Root server

Sep 25

Lab Recording

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

2. How DNS Works

Oct 02

Lab Recording

Lab 3

Oct 03

Email

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 Recording

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

Lab Recording

Lab 4

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:

2. The transport layer

3. UDP

4. TCP-Mux/Demux,

5. UDP-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

Lab 5

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

Lab 6

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

1. Transport Layer Security

3. Illustrated Guide to TLS

12

Nov 26

Network Security: Guest Lecture

Readings: TBA

Nov 27

Project

Nov 28

Thanksgiving Break

13

Dec 3

Midterm-2 In-Class

Dec 4

Project

Dec 5

Anonymity and Tor [slides, worksheet, recording]

1. Anonymity and Tor

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:

"Because plagiarism is considered to be so serious a transgression, it is the opinion of the faculty that for the first offense, failure in the course and, as appropriate, suspension for a semester or deprivation of the degree in that year is suitable; for a second offense, the penalty should normally be expulsion."

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