260 likes | 342 Views
Explore Dijkstra's and Bellman-Ford algorithms for efficient routing in computer networks. Learn how nodes compute least-cost paths and update routing tables. Includes examples and algorithm complexities.
 
                
                E N D
Lecture 10 Computer Networking: A Top Down Approach 6th edition Jim Kurose, Keith RossAddison-WesleyMarch 2012 CS3516: These slides are generated from those made available by the authors of our text. Introduction
4.5 routing algorithms link state distance vector hierarchical routing 4.1 introduction 4.2 virtual circuit and datagram networks Lecture 10: outline Network Layer
Dijkstra’s algorithm net topology, link costs known to all nodes accomplished via “link state broadcast” all nodes have same info computes least cost paths from one node (‘source”) to all other nodes gives forwarding table for that node iterative: after k iterations, know least cost path to k dest.’s notation: c(x,y): link cost from node x to y; = ∞ if not direct neighbors D(v): current value of cost of path from source to dest. v p(v): predecessor node along path from source to v N': set of nodes whose least cost path definitively known A Link-State Routing Algorithm Network Layer
Dijsktra’s Algorithm 1 Initialization: 2 N' = {u} 3 for all nodes v 4 if v adjacent to u 5 then D(v) = c(u,v) 6 else D(v) = ∞ 7 8 Loop 9 find w not in N' such that D(w) is a minimum 10 add w to N' 11 update D(v) for all v adjacent to w and not in N' : 12 D(v) = min( D(v), D(w) + c(w,v) ) 13 /* new cost to v is either old cost to v or known 14 shortest path cost to w plus cost from w to v */ 15 until all nodes in N' Network Layer
Dijkstra’s algorithm: example 9 11,w 14,x 11,w ∞ ∞ ∞ 3,u 5,u 5,u 6,w 6,w 7,u 7 5 4 8 3 w u x v y z 2 3 4 7 10,v 14,x D(v) p(v) D(w) p(w) D(x) p(x) D(y) p(y) D(z) p(z) Step N' u 0 uw 1 uwx 2 uwxv 3 uwxvy 4 12,y uwxvyz 5 notes: • construct shortest path tree by tracing predecessor nodes • ties can exist (can be broken arbitrarily) Network Layer
5 3 5 2 2 1 3 1 2 1 z x w u v y Dijkstra’s algorithm: another example D(v),p(v) 2,u 2,u 2,u D(x),p(x) 1,u D(w),p(w) 5,u 4,x 3,y 3,y D(y),p(y) ∞ 2,x Step 0 1 2 3 4 5 N' u ux uxy uxyv uxyvw uxyvwz D(z),p(z) ∞ ∞ 4,y 4,y 4,y Network Layer
z x w u y v destination link (u,v) v (u,x) x y (u,x) (u,x) w z (u,x) Dijkstra’s algorithm: example (2) resulting shortest-path tree from u: resulting forwarding table in u: Network Layer
algorithm complexity:n nodes each iteration: need to check all nodes, w, not in N n(n+1)/2 comparisons: O(n2) more efficient implementations possible: O(nlogn) oscillations possible: e.g., support link cost equals amount of carried traffic: 2+e 0 0 0 1 1+e C C C C D D D D B B A B B A A A 2+e 2+e 0 0 1 1 1+e 1+e 0 0 0 0 given these costs, find new routing…. resulting in new costs given these costs, find new routing…. resulting in new costs given these costs, find new routing…. resulting in new costs Dijkstra’s algorithm, discussion 1 1+e 0 0 e 0 1 1 e initially Network Layer
4.5 routing algorithms link state distance vector hierarchical routing 4.1 introduction 4.2 virtual circuit and datagram networks Lecture 10: outline Network Layer
Distance vector algorithm Bellman-Ford equation (dynamic programming) let dx(y) := cost of least-cost path from x to y then dx(y) = min {c(x,v) + dv(y) } v cost from neighbor v to destination y cost to neighbor v min taken over all neighbors v of x Network Layer
5 3 5 2 2 1 3 1 2 1 z x w u v y Bellman-Ford example clearly, dv(z) = 5, dx(z) = 3, dw(z) = 3 B-F equation says: du(z) = min { c(u,v) + dv(z), c(u,x) + dx(z), c(u,w) + dw(z) } = min {2 + 5, 1 + 3, 5 + 3} = 4 node achieving minimum is next hop in shortest path, used inforwarding table Network Layer
Distance vector algorithm • Dx(y) = estimate of least cost from x to y • x maintains distance vector Dx = [Dx(y): y є N ] • node x: • knows cost to each neighbor v: c(x,v) • maintains its neighbors’ distance vectors. For each neighbor v, x maintains Dv = [Dv(y): y є N ] Network Layer
Distance vector algorithm key idea: • from time-to-time, each node sends its own distance vector estimate to neighbors • when x receives new DV estimate from neighbor, it updates its own DV using B-F equation: Dx(y) ← minv{c(x,v) + Dv(y)} for each node y ∊ N • under minor, natural conditions, the estimate Dx(y) converge to the actual least cost dx(y) Network Layer
iterative, asynchronous:each local iteration caused by: local link cost change DV update message from neighbor distributed: each node notifies neighbors only when its DV changes neighbors then notify their neighbors if necessary Distance vector algorithm each node: waitfor (change in local link cost or msg from neighbor) recompute estimates if DV to any dest has changed, notify neighbors Network Layer
2 1 7 z y x Dx(y) = min{c(x,y) + Dy(y), c(x,z) + Dz(y)} = min{2+0 , 7+1} = 2 Dx(z) = min{c(x,y) + Dy(z), c(x,z) + Dz(z)} = min{2+1 , 7+0} = 3 node x table cost to cost to x y z x y z x 0 2 7 x 0 3 2 y y 2 0 1 from ∞ ∞ ∞ from z z 7 1 0 ∞ ∞ ∞ node y table cost to x y z x ∞ ∞ ∞ 2 0 1 y from z ∞ ∞ ∞ node z table cost to x y z x ∞ ∞ ∞ y from ∞ ∞ ∞ z 7 1 0 time Network Layer
Dx(z) = min{c(x,y)+Dy(z), c(x,z) + Dz(z)} = min{2+1 , 7+0} = 3 2 1 7 z y x Dx(y) = min{c(x,y) + Dy(y), c(x,z) + Dz(y)} = min{2+0 , 7+1} = 2 node x table cost to cost to cost to x y z x y z x y z x 0 2 7 x 0 3 2 x 0 2 3 y y 2 0 1 from ∞ ∞ ∞ y from 2 0 1 from z z 7 1 0 ∞ ∞ ∞ z 3 1 0 node y table cost to cost to cost to x y z x y z x y z x ∞ ∞ x 0 2 7 ∞ 2 0 1 x 0 2 3 y y 2 0 1 y from from 2 0 1 from z z ∞ ∞ ∞ 7 1 0 z 3 1 0 cost to cost to node z table cost to x y z x y z x y z x 0 2 7 x 0 2 3 x ∞ ∞ ∞ y y 2 0 1 from y 2 0 1 from from ∞ ∞ ∞ z z z 3 1 0 3 1 0 7 1 0 time time Network Layer
1 4 1 50 x z y Distance vector: link cost changes link cost changes: • node detects local link cost change • updates routing info, recalculates distance vector • if DV changes, notify neighbors t0 : y detects link-cost change, updates its DV, informs its neighbors. “good news travels fast” t1 : z receives update from y, updates its table, computes new least cost to x , sends its neighbors its DV. t2 : y receives z’s update, updates its distance table. y’s least costs do not change, so y does not send a message to z. Network Layer
60 4 1 50 x z y Distance vector: link cost changes link cost changes: • node detects local link cost change • bad news travels slow - “count to infinity” problem! • 44 iterations before algorithm stabilizes: see text poisoned reverse: • If Z routes through Y to get to X : • Z tells Y its (Z’s) distance to X is infinite (so Y won’t route to X via Z) • will this completely solve count to infinity problem? Network Layer
A table cost to C table cost to A B C D E A B C D E A 0 5 2 3 ∞ A ∞ ∞ ∞ ∞ ∞ B ∞ ∞ B ∞ ∞ ∞ ∞ from ∞ ∞ ∞ ∞ from 5 C ∞ ∞ A B C 2 4 0 4 ∞ ∞ ∞ ∞ 2 4 D ∞ ∞ ∞ ∞ D ∞ ∞ ∞ ∞ ∞ C ∞ 3 3 E ∞ ∞ ∞ ∞ E ∞ ∞ ∞ ∞ ∞ ∞ 4 D E B table cost to E table D table cost to cost to A B C D E A B C D E A B C D E A ∞ ∞ ∞ ∞ ∞ A ∞ ∞ A ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ B 5 0 4 3 ∞ from B B ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ from from C ∞ ∞ ∞ ∞ ∞ C C ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ D ∞ ∞ ∞ ∞ ∞ D 3 0 D ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ E ∞ ∞ ∞ ∞ ∞ E E 3 4 0 ∞ ∞ ∞ ∞ ∞ ∞ ∞ Initial Step Network Layer
A table cost to C table cost to A B C D E A B C D E A 0 5 2 3 ∞ A ∞ ∞ ∞ ∞ ∞ B 5 0 4 3 B ∞ ∞ from ∞ ∞ ∞ ∞ from 5 C 2 4 0 4 ∞ A B C 2 4 0 4 ∞ 2 4 D 3 0 ∞ ∞ D ∞ ∞ ∞ ∞ ∞ C ∞ 3 3 E ∞ ∞ E ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ 4 D E Note: not a nearest neighbor B table cost to E table D table cost to cost to A B C D E A B C D E A B C D E A ∞ ∞ ∞ ∞ ∞ A ∞ ∞ A ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ B 5 0 4 3 ∞ from B B ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ from from C ∞ ∞ ∞ ∞ ∞ C C ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ D ∞ ∞ ∞ ∞ ∞ D 3 0 D ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ E ∞ ∞ ∞ ∞ ∞ E E 3 4 0 ∞ ∞ ∞ ∞ ∞ ∞ ∞ Step 2A – Messages from other nodes Network Layer
A table cost to A B C D E A 0 5 2 3 ∞ B 5 0 4 3 from ∞ 5 C 2 4 0 4 ∞ A B 2 4 D 3 0 ∞ ∞ ∞ C 3 3 ∞ ∞ E ∞ ∞ ∞ 4 D E A table cost to A B C D E A 0 5 2 3 6 B ∞ ∞ ∞ ∞ ∞ from C ∞ ∞ ∞ ∞ ∞ ∞ ∞ D ∞ ∞ ∞ ∞ ∞ E ∞ ∞ ∞ Step 2A – Updating Table A Network Layer
A table cost to C table cost to A B C D E A B C D E A 0 5 2 3 ∞ A ∞ ∞ ∞ ∞ ∞ B 5 0 4 3 B ∞ ∞ from ∞ ∞ ∞ ∞ from 5 C 2 4 0 4 ∞ A B C 2 4 0 4 ∞ 2 4 D 3 0 ∞ ∞ D ∞ ∞ ∞ ∞ ∞ C ∞ 3 3 E ∞ ∞ E ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ 4 D E Note: not a nearest neighbor B table cost to E table D table cost to cost to A B C D E A B C D E A B C D E A ∞ ∞ ∞ ∞ ∞ 0 5 2 3 A ∞ ∞ A ∞ ∞ ∞ ∞ B 5 0 4 3 ∞ from B B ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ from from C ∞ ∞ ∞ ∞ ∞ C C ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ D ∞ ∞ ∞ ∞ ∞ D 3 0 D ∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞ E ∞ ∞ ∞ ∞ ∞ E E 3 4 0 ∞ ∞ ∞ ∞ ∞ ∞ ∞ Step 2D – Messages from other nodes Network Layer
5 A B 2 4 C 3 3 4 D E D table cost to D table cost to A B C D E A B C D E 0 5 2 3 A ∞ A ∞ ∞ ∞ ∞ ∞ B ∞ ∞ ∞ ∞ ∞ from B ∞ ∞ ∞ ∞ ∞ from C ∞ ∞ ∞ ∞ ∞ C ∞ ∞ ∞ ∞ ∞ 3 0 D ∞ ∞ ∞ 3 8 5 0 D ∞ E ∞ ∞ ∞ ∞ ∞ E ∞ ∞ ∞ ∞ ∞ Step 2D – Updating Table D Network Layer
message complexity LS: with n nodes, E links, O(nE) msgs sent DV:exchange between neighbors only convergence time varies speed of convergence LS: O(n2) algorithm requires O(nE) msgs may have oscillations DV: convergence time varies may be routing loops count-to-infinity problem robustness: what happens if router malfunctions? LS: node can advertise incorrect link cost each node computes only its own table DV: DV node can advertise incorrect path cost each node’s table used by others error propagate thru network Comparison of LS and DV algorithms Network Layer
Frank Sweetser Manager of Network Operations Lecture 10: outline Network Layer