GSOC2017TBFAndHHF: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| No edit summary | |||
| Line 85: | Line 85: | ||
| #Buffer time for any incomplete work from past weeks. | #Buffer time for any incomplete work from past weeks. | ||
| #Do a full on integrated testing of TBF with ns-3. | #Do a full on integrated testing of TBF with ns-3. | ||
| #Web page documentation for the added parts of the traffic-control model library. | |||
| #Complete API documentation for TBF using Doxygen. | |||
| #Produce mergeable patch for TBF and submit it for review. | #Produce mergeable patch for TBF and submit it for review. | ||
| *Execution | *Execution | ||
Revision as of 21:16, 11 May 2017
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 2017 Accepted Projects page.
Project Overview
- Project Title: Implementation of Token Bucket Filter (TBF) and Heavy-Hitter Filter (HHF) in ns-3.
- Student: Surya Seetharaman
- Mentor: Stefano Avallone
- Abstract: In PSNs, sometimes it is not possible to distinguish and manipulate different kinds of network flows. For example, we may want to give priority to some flows while limiting bandwidth of other flows or even perform packet classification. To solve such problems, we have a traffic control layer in ns-3 which intercepts the packets flowing between the L2 Net devices and any IP protocol. It uses several qdiscs like pfifo, HBT, RED, CoDel etc., in order to process these packets and perform scheduling or shaping. Currently the ns-3 traffic layer only contains traffic scheduling qdisc models (AQMs) and lacks realistic traffic shaping algorithms. This project aims to introduce the TBF and HHF algorithms into the ns-3 traffic control layer. TBF is a classless traffic shaper, that is used to control the flow rate or bandwidth of the throughput. HHF is a size-based qdisc that attempts to differentiate small and heavy flows. The goal is to catch the heavy flows and move them to a separate queue with less priority so that bulk traffic does not affect the latency of critical traffic.
- Code: Coming Soon...
- About me: A FOSS enthusiast, pursuing the final year of my Master’s degree in Network Services and Systems, from KTH Royal Institute of Technology, Stockholm. My areas of interests include designing/analysing Networked Systems and problem solving using Algorithms and Data Structures.
Deliverables
By the end of this project, the following would be delivered to the ns-3 traffic-layer component :
- A realistic classless traffic shaping algorithm - Token Bucket Filter (TBF).
- Validation tests, User example and Documentation of TBF.
- A size based classless qdisc - Heavy-Hitter Filter (HHF).
- Validation tests, User example and Documentation of HHF.
Approach
A detailed description of the technical approach can be found in my original proposal [link].
Project Timeline
Community Bonding Phase [May 4th - May 29th]
- Continue studying about the traffic-control component but now more specific to the project at hand (TBF and HHF).
- Submit quality patches to traffic-control component (could be open issues or some other minor tasks) or do some required solid documentation work for this component.
- Communicate regularly with mentors and discuss about weekly plans. Also finalize on the project plan with respect to the submitted proposal. In case any changes need to be made, now is the time. Put the approved plan on the ns-3 Wiki page.
- Study the references provided by mentors in order to start with the project.
Coding Phase [May 30th - Aug 21st]
Phase 1
Week 1 [May 30th - Jun 6th] : TBF implementation phase 1.
- Plan
- Go through TBF documentation and Linux kernel source code for TBF.
- Make clarifications and discuss the TBF implementation approach with mentors and make sure of the method before jumping to code.
- Declare the TbfQueueDisc class and other necessary functions in it.
- Finish the tbf.h file completely and write proper comments in the file.
- Execution
Week 2 [Jun 6th - Jun 13th] : TBF implementation phase 2.
- Plan
- Create the structure of the tokens, bucket and transmission queue (fifo).
- Define the function DoEnqueue()and test it.
- Define the other functions like BurstChange() and DoPeek().
- Finally define DoDequeue() and test it.
- Finish tbf.c file and comment it.
- Execution
Week 3 [Jun 13th - Jun 20th] : TBF user example.
- Plan
- Do a stand alone testing and ensure it works properly.
- Create the user example network topology.
- Use the example simulation to test the overall integrated working of TBF.
- Complete tbf-example.cc and write proper comments in the file.
- Execution
Week 4 [Jun 20th - 27th] : TBF testing.
- Plan
- Create the simple test network topology.
- Finish implementation of all the test cases in tbf-disc-test-suite.cc and validate each one of them individually before moving to next test case.
- Get code written till date, ready for PHASE 1 evaluation.
- Execution
Deliverables at the end of Phase 1 : TBF algorithm, user example and test case suite will be ready.
Phase 2 :
Week 5 [Jun 27th - Jul 4th] : TBF patch submission for code review.
- Plan
- Buffer time for any incomplete work from past weeks.
- Do a full on integrated testing of TBF with ns-3.
- Web page documentation for the added parts of the traffic-control model library.
- Complete API documentation for TBF using Doxygen.
- Produce mergeable patch for TBF and submit it for review.
- Execution
Week 6 [Jul 4th - Jul 11th] : HHF implementation phase 1.
- Plan
- Go through HHF documentation and Linux kernel source code for HHF.
- Make clarifications and discuss the HHF implementation approach with mentors and make sure of the method before jumping to code.
- Declare the HhfQueueDisc class and other necessary functions in it.
- Finish the hhf.h file completely and write proper comments in the file.
- Execution
Week 7 [Jul 11th - Jul 18th] : HHF implementation phase 2.
- Plan
- Create the flow (hash) table.
- Define the function DoEnqueue()and test it.
- Define the other functions like Classify().
- Finally define DoDequeue() and test it.
- Finish hhf.c file and do a stand alone testing ensuring it works properly.
- Execution
Week 8 [Jul 18th - Jul 25th] : HHF user example
- Plan
- Improvise by taking comments from the mentors and others in the organization about the submitted code review for TBF. Complete TBF and keep it ready for merge.
- Create the HHF user example network topology.
- Use the example simulation to test the integrated working of HHF.
- Complete hhf-example.cc and write proper comments in the file.
- Get code written till date, ready for PHASE 2 evaluation.
- Execution
Deliverables at the end of Phase 2 : HHF algorithm, user example will be ready along with TBF patch for merge into ns-3.
Phase 3 :
Week 9 [Jul 25th - Aug 1st] : HHF testing.
- Plan
- Create the simple test network topology (take if from TBF).
- Finish implementation of all the test cases in hhf-disc-test-suite.cc and validate each one of them individually before moving to next test case.
- Complete integrated testing of HHF.
- Execution
Week 10 [Aug 1st - Aug 8th] : HHF patch submission for code review.
- Plan
- Buffer time for any incomplete work from past weeks.
- Produce mergeable patch for HHF and submit it for review.
- Execution
Week 11 [Aug 8th - Aug 15th] : Documentation and Improvising
- Plan
- Web page documentation for the added parts of the traffic-control model library.
- Complete API documentation for TBF and HHF using Doxygen.
- Improvise by taking comments from the mentors and others in the organization about the submitted code review for HHF. Complete HHF and keep it ready for merge.
- Execution
Week 12 [Aug 15th - Aug 21st] : Fix the Project
- Plan
- All code should be ready after cleanup and comments write up.
- Integrating, testing and fixing the complete project.
- Execution
Code Submission Week [Aug 21st - Aug 29th] : Submission
- Plan
- Buffer time for final touches and incomplete documentation work.
- Merge the code to ns-3.
- Submit the code for the final GSoC evaluations.
- Execution