120 likes | 136 Views
Design and implement a "k out of m" multicast routing protocol that selects the best k destinations to send packets to and the best multicast path. Max value of m is 3, and direct links between end-nodes are not allowed. Loss probability on each link is p. Proposal includes addressing network elements, protocol structure, and ARQ scheme. Project involves proposing a protocol, implementing algorithms, and inter-working between groups for a final demonstration.
E N D
ECE 544 Software Project 3:Description and Timeline Akash Baid
Objective • Design and implement a specialized "k out of m" multicast routing protocol: • Each packet will have up to mdestination addr. • Required to send packet to any k m destination • Routing protocol chooses the ‘best’ k destinations to send to and the ‘best’ multicast path • Project Format: Like an industry standards committee • Each group proposes a solution to the class • Class as a whole combines proposals for final draft • All groups implements code based on this draft
Problem Details • Max value of m =3 thus k can be 1,2 or 3. • No direct links between end-nodes • Loss probability on each link = p a R3 b R4 k = 2 Dest = a,b,c R2 Data R5 R6 R1 c
Proposal Requirements • Proposal consists of a protocol and related algorithms • Protocol includes: • How to address different network elements? • Fixed static address vs. Dynamic address allocation • Bit structure of address and how it is used • How do nodes/routers discover each other? • Periodic hello messages vs. hello with ACK • Provisioning or not for router/node failure? • What is the baseline routing protocol? • Link State vs. Distance Vector vs. Other variations of these • What ARQ scheme to use?
Proposal Requirements • Algorithmic component includes: • How to select best k out of m? • Depends on what info you have at each router • Based on unicast hop count vs. multicast hop count • How to multicast once you know the final nodes? • Whether to follow one of known multicast schemes? • Determining where to split the packet ? • What requirements from baseline routing protocol?
Project Requirements • Each group submits a proposal with specific details on both protocol and algorithms • Class reaches a consensus on each item after 2-3 rounds of discussions • Each group individually implements the agreed upon protocol through codes for nodes and routers • Final Demonstration involves inter-working between groups, e.g. node of group 1 with router of group 2 • Final Report mentions implementation specific details from each group
Software Design Issues • Try to reuse relevant aspects of port-handling, ARQ, header processing from Projects 1 and 2 • However do not be constrained by the code snippets provided to you, e.g. modify common.cpp • For routing protocol, aim to minimize total hops/ path costs but keep implementation complexity in mind • Credits for constructive participation in the standards meetings
Timeline • April 4th : Draft Proposal due by each group • April 6th : 1st Standards Meeting – presentations by each group followed by discussion • April 8th : 2nd Standards Meeting – discussion on remaining topics, voting for finalization • April 13th : Circulation of Formal Standard Document • April 29th : Final Code Submission and Demo • May 2nd : Project Report due
1st Deadline: Draft Proposal • PPT with details of your proposed solution covering all the requirements • Follow the skeleton PPT provided on course site • Add any aspects that you feel is interesting to the design of the system • Slides from all group will be uploaded by March 31st • April 1st: Each group presents their slides (10-15 min) • Discuss what’s the best way to do each task • Vote if can’t reach a consensus
Demo • Demo network will have at least 4 nodes and 3 routers • Different nodes/routers can be initialized on different consoles on the same machine • The code should explicitly show (print out) how the routing table gets populated-no static table • Action taken by each entity on receipt of a packet should be shown • Network topology will be provided at the time of the demo
Final Submission • Router program ( Source code + Makefile) • Sender and receiver program (Source code + Makefile) • Guide: How to run your program • Document for Protocol implementation and Performance Evaluation. It could contain, but not limited to, following topics: • Signalling definition • Routing/Discovery procedure • Interfaces of router-router and router-terminal (end-node) • Performance estimation/evaluation
Grades • Participation in Standards Meetings – 4% • Final Demo – 12% • Final Report – 4%