We will examine several key challenges of networking, such as application-level interoperability, transport-level congestion control, and network-level routing. For each of these challenges, we will examine the specific response embodied in the current Internet protocol suite and the systems implementing it. However, we will also keep an eye out for the broader possibilities for potential future protocols and systems.
I will be available in my office (OHS 303) 10:30-11:20 Mondays and Thursdays, and 9:00-9:50 Tuesdays and Fridays, as well as by appointment. Or try your luck: just stop by and see whether my door is open. You may send me electronic mail at max@gustavus.edu or call me at extension 7466. I'll try to put any updates to my office hours on my web page, so check there if in doubt.
All course materials will be available through my World Wide Web page. The URL for this course is http://www.gustavus.edu/+max/courses/F2004/MCS-377/. After this syllabus I will give hardcopy handouts only to those students who want them.
The primary text for the course will be Computer Networking: A Top-Down Approach Featuring the Internet, 3rd ed., by James F. Kurose and Keith W. Ross, Addison-Wesley, 2005. You will also read some of the professional literature as part of the homework.
There will be four lab assignments. The due dates for the labs are shown in the syllabus below. We'll meet in the OHS 326 lab as shown in the syllabus (subject to change).
Attendance is expected for all lab days. (If you turn in a lab report early, you are excused from the remaining days devoted to that lab.) I will excuse up to two absences per student, for any reason. Use yours wisely. If you exceed this allowance, I may reduce your course grade by one letter grade.
I will assign homework problems. You may turn in any individual homework problem whenever you think you have it solved. I will return it to you as quickly as I can, but normally with only an indication of whether it is acceptable or needs more work. (Sometimes I may give a brief indication of what area it needs more work in.) If a problem needs more work, and you aren't sure what sort of work it still needs, you should treat that as an invitation to come talk with me about it. Once you've done the additional work, you may turn the problem in again. In fact, you may turn in each problem in as many times as you like, until it is marked as acceptable. Your grade for the homework portion of the course will be based on the fraction of homework problems that you eventually did acceptably.
Normally homework problems may be turned in at any time up until the start of class on October 15th for chapters 1-3, November 16th for chapters 4-5, and December 14th for Chapters 6-8. However, if we would benefit from discussing a homework problem in class, I may issue a "last call" for solutions to that problem, at least a week in advance.
Unless I indicate that a particular problem must be done individually, you may work on any problem in a group of two or three students. One copy of the solution produced by the team should be turned in, with all team members names on it. Write "we all contributed fairly to this solution" and have all team members sign under that statement.
There will be two intra-term exams and a final exam. You will be given one and a half hours for each intra-term exam. Unless you tell me otherwise, I will assume that you are taking the first exam in OHS 317 from 7:30-9:00 pm on October 18th. The second exam will be taken on November 22 or 23; each student will be able to sign a test paper out for an hour and a half of his or her own choice on either of those dates. The final exam will be as scheduled by the registrar. For each test, you may use one 8.5x11 sheet of handwritten notes. (Both sides of the sheet are OK.)
On two occasions, we will examine how networking plays out in actual sites. The first one (a warm up) will be an examination of the Gustavus campus network, which we will do during a normal class period. The second one will involve a more extended time period, as we will be taking a bus to HickoryTech in Mankato. Based on the (relatively few) responses I got to my poll, I've scheduled that trip for Wednesday, December 8, 1pm-4pm.
You are expected to be familiar with the college academic honesty honor code policy, and to comply with that policy. If you have any questions about it, please ask. One specific requirement of that policy is that you write the following in full and sign it on every examination and graded paper:
On my honor, I pledge that I have not given, received, nor tolerated others' use of unauthorized aid in completing this work.
For the purposes of this policy, I am defining "graded papers" to be lab reports but not homework problems. (I still expect you to comply with the honor code on homework problems, just not to write the explicit pledge on them.) When lab reports are co-authored, each co-author should write and sign the pledge.
All lab reports are due at the beginning of class on the day indicated. Late reports will be penalized by one ``grade notch'' (such as A to A- or A- to B+) for each weekday late or fraction thereof.
If you are too sick to complete an assignment on time, you will not be penalized. Simply write ``late due to illness'' at the top of the assignment, sign your name and hand it in. Other circumstances will be evaluated on a case-by-case basis.
I will provide you with a letter grade on each lab assignment and test, in addition to the mid-term and final grades, so that you may keep track of your performance. As a guideline, the course components will contribute to your final grade in the proportions indicated below:
All homework and lab reports should be readily readable, and should not presuppose that I already know what you are trying to say. Use full English sentences where appropriate (namely almost everywhere) and clear diagrams, programs, etc. Remember that your goal is to communicate clearly, and that the appearance of these technical items plays a role in this communication process. Be sure your assignments are always stapled together and that your name is always on them.
If you have a learning, psychological, or physical disability for which a reasonable accommodation can be made, I would be happy to refer you to the college's disability services coordinator, and to cooperate in the accommodation process. It is generally best if this can be done as soon as possible.
This is my best guess as to the rate at which we will cover material. However, don't be shocked if I have to pass out one or more revised syllabi.
Date | Reading | Topic | Due |
---|---|---|---|
9/9 | Introduction | ||
9/10 | 1.0-1.5 | Introduction, part 2 | |
9/13 | 1.6-1.10 | Introduction, part 3 | |
9/14 | 2.0-2.2 | Application layer and HTTP | |
9/16 | 2.3-2.4 | FTP and email | |
9/17 | No class | ||
9/20 | 2.5 | DNS | |
9/21 | 2.6 | P2P filesharing | |
9/23 | 2.7-2.8 | Socket programming | |
9/24 | 2.9-2.10 | Programming example | |
9/27 | Lab 1 | ||
9/28 | 3.0-3.3 | Transport layer and UDP | |
9/30 | 3.4.0-3.4.2 | Reliable data transfer | |
10/1 | Lab 1 | ||
10/4 | 3.4.3-3.5.3 | TCP | |
10/5 | No class (Nobel Conference) | ||
10/7 | 3.5.4-3.5.6 | TCP, continued | |
10/8 | 3.6-3.7.0 | Congestion control | |
10/11 | Lab 2 | Lab 1 | |
10/12 | 3.7.1-3.8 | TCP congestion control | |
10/14 | Lab 2 | ||
10/15 | Review, catch-up | ||
10/18 | 5.0-5.2 | Error detection and correction | |
10/19 | 5.3-5.4 | LANs | |
10/21 | 5.5 | Ethernet | |
10/22 | 5.6-5.7 | Ethernet boxes and PPP | Lab 2 |
10/28 | 5.8-5.9 | Link virtualization | |
10/29 | Lab 3 | ||
11/1 | 4.0-4.3 | Network layer and routers | |
11/2 | No class: go vote! | ||
11/4 | 4.4.0-4.4.2 | IPv4 | |
11/5 | 4.4.3-4.4.4 | ICMP and IPv6 | |
11/8 | Lab 3 | ||
11/9 | 4.5.0-4.5.1 | Link-state routing | |
11/11 | 4.5.2-4.5.3 | Distance-vector routing | |
11/12 | 4.6 | Internet routing | Lab 3 |
11/15 | 4.7-4.8 | Multicast routing | |
11/16 | Review, catch-up | ||
11/18 | 6.0-6.3.1 | Wireless | |
11/19 | 6.3.2-6.3.5 | Wi-Fi | |
11/22 | No class: test schedulable | ||
11/23 | 6.4-6.5 | Cellular and mobility | |
11/29 | Gustavus networking tour | ||
11/30 | 6.6-6.9 | More on mobility | |
12/2 | 8.1-8.2 | Cryptography | |
12/3 | Lab 4 | ||
12/6 | Lab 4 | ||
12/7 | 8.3-8.4 | Authentication and integrity | |
12/8 | Trip to HickoryTech, 1pm-4pm | ||
12/9 | 8.5-8.6 | Key distribution and firewalls | |
12/10 | 8.7-8.8.1 | Attacks and secure email | Lab 4 |
12/13 | 8.8.2-8.9 | More on security | |
12/14 | Review, catch-up, and evaluation |