CS7260: Internetworking Architectures and Protocols

(Design and Analysis of Network/Router Algorithms and Hardware)

  Spring 2021, College of Computing, Georgia Tech
class webpage:  https://www.cc.gatech.edu/classes/AY2020/cs7260a_spring/


Class time: TTh 2:00 to 3:15
Mode: Fully remote

Instructor: Prof. Jun (Jim) Xu

Office hours by appointment:  TBD, Bluejeans link to be posted soon in Canvas
Email:  jx@cc.gatech.edu


TA:Huayi Wang ( huayiwang@gatech.edu )
TA Office hours: Friday afternoons 3:00 pm- 4:00 pm by email appointment via https://bluejeans.com/561849767


Table of Contents


Course Information and Objectives


Textbook and additional references

Approximately half of the course material will come from the following textbook:

Network Algorithmics

by George Varghese, Morgan Kaufmann, 2005 (available at Engineer's Bookstore).

The other half will come from exerpts of the secone edition of the above book and from research papers (many by myself). We will also cover parts of the following book (you don't need to purchase it):


Syllabus - Tentative schedule (subject to adjustments)

The reading list will be updated every week, before we cover the corresponding topic.  The schedule is approximate and subject to changes.


P. Valente, “Exact GPS simulation with logarithmic complexity, and its application to an optimally fair scheduler“, IEEE/ACM Transactions on Networking (ToN), February 2008.
We just talked about the example presented in its Figure 1 in class.

Zhao, Q., Xu, J. ``On the Computational Complexity of Maintaining GPS Clock in Packet Scheduling'', in Proc. of IEEE Infocom 2004.

The ``standard" GPS simulator code, the caveats of which are explained in the above paper.

Xu, J., and Lipton, R. 2002. ``On Fundamental Tradeoffs between Delay Bounds and Computational Complexity in Packet Scheduling Algorithms'' , ACM SIGCOMM'2002, Pittsburgh, PA, August 2002.  


A paper of mine about re-use distance and caching:

Jun Xu, Mukesh Singhal, and Joanne Degroat, "A Novel Cache Architecture to Support Layer-Four Packet Classification at Memory Access Speeds," Proceedings of the IEEE INFOCOM 2000, Tel-Aviv, Israel, March 2000.

Chapter 14 of  this book is devoted to the topic of augmented data structures.

 
Streaming Algorithms for Counting Distinct Elements (Slides)

I could not find the "Walmart example" I covered in class.  This one is close enough or even better.

"A sketch algorithm for estimating two-way and multi-way associations"
Ping Li and Kenneth W. Church, Computational Linguistics 33(3), 305-354, 2007




Project

Each student shall carry out an individual project. Every project MUST be focused on a Network Algorithmics topic. Project reports on unrelated or marginally related topics (e.g., TCP congestion control mechanisms or BGP routing protocols) will receive little or no credit.  An individual project can take any of the following three different forms.

1. A research project that produces new network algorithmics solutions, e.g., new packet classfication techniques for SDN applications or new switching algorithms.

2. An in-depth survey of a core or emerging network algorithmics topic, e.g., how single root I/O virtuation technology can be used for building future network algorithmics solutions.

3. A set of 3 to 4 nontrivial exercise problems -- focused on a single core algorithmics topic and balanced across the subtopics -- that have the same level of sophistication as the example problems I are going to show you in class.  Since a student has almost a whole semester to do it, I expect this set to be of very high quality.  Solutions need to be produced and submitted along with the exercise problems.


Homeworks

A few regular homework assignments and possibly a programming assignment will be distributed during the semester.


Grading 


Course Policies