GSOC2014Bufferbloat
		
		
		
		Jump to navigation
		Jump to search
		
Main Page - Roadmap - Summer Projects - Project Ideas - Developer FAQ - Tools - Related Projects
HOWTOs - Installation - Troubleshooting - User FAQ - Samples - Models - Education - Contributed Code - Papers
Return to GSoC 2014 Accepted Projects page.
Understanding bufferbloat through simulations in ns-3
- Student: Truc Anh Nguyen
- Mentors: Tom Henderson and Dave Täht
- Abstract: The goal of the project is to study and visualize the bufferbloat problem by developing models and examples in ns-3 and analyze the performance of different queue types that are developed as solutions to bufferbloat, including CoDel, FQ_CoDel, and SFQRED
- Code:
- About me: I am currently a PhD student in Computer Science at The University of Kansas. My focus area is networking with the emphasis on studying and understanding the different reliable transport layer mechanisms and protocols, including the various connection management, error control, and congestion control approaches. More information is available on my website
Readings
Approach
I plan to accomplish the project's goal through the following 3 phases:
- Phase 1: Bufferbloat problem demonstration and simulation
- Phase 2: Codel, FQ Codel, SFQRED code fix and cross-validation
- Codel: address the comments on ns-3 code review for Codel, add documentation, write test suite, validate against ns-2 and OpenWrt Linux implementations
- FQ Codel: address the comments on ns-3 code review for FQ Codel, add documentation, write test suite, validate against ns-2 and OpenWrt Linux implementations
- SFQRED: address the comments on ns-3 code review for SFQRED, add documentation, write test suite, validate against ns-2 and OpenWrt Linux implementations
 
- Phase 3: Simulations and performance analysis
Deliverables
- Delverable 1: Scripts to demonstrate and visualize bufferbloat problem
- Deliverable 2: Codel code with documentation, test suite, and scripts to validate against ns-2 and OpenWrt implementations
- Deliverable 3: FQ Codel code with documentation, test suite , and scripts to validate against ns-2 and OpenWrt implementations
- Deliverable 4: SFQRED code with documentation, test suite, and scripts to validate against ns-2 and OpenWrt implementations
- Deliverable 5: Scripts to perform simulation analysis under different scenarios
Plan
After our weekly meeting on Friday, we update this section noting down our plan for the upcoming week(s).
- Friday, May 16, 2014:
- Review ns-3 AQM code reviewers' comments, make a list of all the issues to be attacked, test Dave's git repo, and run the programs in the scratch/ dir
- Develop a 3-node test script with FIFO queue for initial visualization of bufferbloat. One router sits in between a sender and a receiver, and the link connects the router and the receiver is the bottleneck link with a 10 Mb/s bandwidth and a 5 ms delay. The sender node sends multiple small TCP flows and 1 large flow. We may want a diversity of receivers with different RTTs to avoid synchronization effects. Initial set of performance metrics we want to capture include:
- queue sojourn time
- cwnd evolution for "elephant" TCP connection
- completion time or PLT (Page Load Time) for "mice" TCP connections
- other TCP statistics
 
 
Weekly progress
- Week 1 (May 19, 2014 -- May 23, 2014):