1 / 29

Routing in Mobile Ad-Hoc Networks

Routing in Mobile Ad-Hoc Networks. An M.Tech. Project by Srinath Perur Guide: Prof. Sridhar Iyer. Organization. Introduction to Mobile Ad hoc networks (MANETs) Routing in MANETs Virtual Backbone Routing Kelpi: Algorithm and implementation Conclusions. Towards MANETs.

parson
Download Presentation

Routing in Mobile Ad-Hoc Networks

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Routing in Mobile Ad-Hoc Networks An M.Tech. Project by Srinath Perur Guide: Prof. Sridhar Iyer

  2. Organization • Introduction to Mobile Ad hoc networks (MANETs) • Routing in MANETs • Virtual Backbone Routing • Kelpi: Algorithm and implementation • Conclusions

  3. Towards MANETs Networking wireless hosts: • Cellular Networks • Infrastructure dependent • High setup costs • Large setup time • Reliable

  4. Towards MANETs Some motivating applications: • Casual conferencing • low set-up time, cost preferred • Battlefield operations/disaster relief • infrastructure unavailable • Personal area networking • devices around the home/office Cellular networks are not preferred.

  5. Mobile Ad hoc Networks • mobile hosts • multi-hop routes between nodes • may not use infrastructure Source: it644 course material Prof. Sridhar Iyer

  6. B A A B Characteristics of MANETs • Dynamic topology • links formed and broken with mobility • Possibly uni-directional links • Constrained resources • battery power • wireless transmitter range • Network partitions Source: it644 course material Prof. Sridhar Iyer

  7. Routing in MANETs To find and maintain routes between nodes in a dynamic topology with possibly uni-directional links, using minimum resources.

  8. Dynamic Source Routing (DSR) • Routing is through source routing • complete path with each packet • Route discovery • flooding RREQ till a node replies • Route maintainance • explicit link breakage notification Mobility of a node can break routes passing through it.

  9. Destination Sequenced Distance Vector (DSDV) • Modified Distance Vector protocol • periodic DV updates • High frequency of DV updates • topology is dynamic • Does not scale well • size of DV updates increase • high routing overheads

  10. Observations • Most ad hoc routing protocols are combinations/variations of DSR/DSDV • Mobility in DSR causes short-lived routes • DSDV is not scalable

  11. The Dynamic Virtual Backbone The dynamic virtual backbone is a concept wherein a set of relatively stable routes are formed despite nodes being mobile. • a possible way is to abstract mobility through aggregation • a dynamic group of nodes by preventing some information from moving out of the group, keeps mobility transparent to the rest of the network.

  12. Virtual Backbone in Kelpi (xl, yl) 36 37 38 39 40 41 42 43 44 27 28 29 30 31 32 33 34 35 D S 18 19 20 21 22 23 24 25 26 9 10 11 12 13 14 15 16 17 0 1 2 3 4 5 6 7 8 (x0, y0) Cell Node Operational Area Router

  13. Kelpi • Kelpi: a MANET routing algorithm based on the concept of Virtual Backbone Routing (VBR). • Assumptions: • nodes equipped with positioning system, say a GPS receiver • nodes capable of multi-level transmission • mobility scenario • upto vehicular speeds of mobility • area of a few kilometres • fairly dense network • typical battlefield/disaster relief scenario

  14. Routing in Kelpi • Area of operation divided into square geographical cells • In each cell one node is a router • Inter-cell communication is through routers • Routers transmit at a higher transmission power • Nodes communicate through their cell routers

  15. Routing in Kelpi (xl, yl) 36 37 38 39 40 41 42 43 44 27 28 29 30 31 32 33 34 35 D S 18 19 20 21 22 23 24 25 26 9 10 11 12 13 14 15 16 17 0 1 2 3 4 5 6 7 8 (x0, y0) Cell Node Operational Area Router

  16. VBR in Kelpi • Nodes aggregated by position • geographically defined cells • Each group has a router • any node can be a router • router responds to a Cell Router Address (CRA) • before moving cells a router hands off routing information

  17. Use of Cell Router Address and cells to implement VBR in Kelpi CRA(1) CRA(2) 0 1 2

  18. (xl, yl) 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 (x0, y0) 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 0 0 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 Initialization: Node comes on: Another node comes on: 1.Node calculates grid 1.Node sends HI 1.Area of operation is known 2 Receives reply from router 2.Node sends HI 2..Initialization parameters: bounding co-ordinates and maxTxPower. 3. Does not receive reply and declares itself router of cell 21

  19. Kelpi: Router • Data structures at router: • node_list, routing_table, forwarding_pointers • The new router sends a RH (Router Here) message • prevents multiple routers in a cell • starts listening on the CRA • starts sending/receiving DV updates to/from neighbouring routers • <cell, distance, sequence_no> • receives HI messages and enters sending node into node_list

  20. Kelpi: Route Discovery • node S wants to send to node D • S must know D’s cell • S discovers D’s cell by sending a FIND_CELL packet to its router • Routers flood FIND_CELL among themselves • A router with the node in its node_list replies directly to S

  21. Routing in Kelpi (xl, yl) 36 37 38 39 40 41 42 43 44 27 28 29 30 31 32 33 34 35 D S 18 19 20 21 22 23 24 25 26 9 10 11 12 13 14 15 16 17 0 1 2 3 4 5 6 7 8 (x0, y0) Cell Node Operational Area Router

  22. Kelpi: Handling node mobility • Node detects it is in a new cell • sends BYE to previous cell’s router • sends HI to new cell’s router • sends MOVED_CELL to nodes communicating with it • Router detects it is approaching a new cell • initiates router handoff • appoints new router • messages: RTR_MOVE, RTR_MOVE_ACK, RTR_HANDOFF • sends routing_table, sequence numbers, node_list to new router • becomes a node

  23. Implementation • ns-2 network simulator used for implementing Kelpi • open source, used widely in MANET research • critical modifications to ns-2 • packet headers • physical layer code for multi-powered transmitter • introduction of new routing agent: Kelpi

  24. Excerpt from events.cc void KelpiAgent::node_receives_packet(Packet* p){ struct hdr_cmn* ch = HDR_CMN(p); struct hdr_ip* iph = HDR_IP(p); int src_ip = iph->saddr(); int dst_ip = iph->daddr(); double now = Scheduler::instance().clock(); // if this node originates the packet if(src_ip == node_address && ch->num_forwards() == 0) { printf("ch size: %d ", ch->size()); ch->size() += IP_HDR_LEN; printf("%d \n", ch->size()); iph->ttl_ = 32; // change to num. cells in diagonal? } . . . if ((node_cache[dst_ip] != NULL) && (node_cache[dst_ip]->time_last_accessed > 0.1) && ((now - node_cache[dst_ip]->time_last_accessed) < CACHE_STALE)) { if (node_cache[dst_ip]->cell != current_cell) forward_to_router(p, node_cache[dst_ip]->cell); else { // send packet directly to node ch->next_hop_ = dst_ip; ch->addr_type_ = NS_AF_INET; ch->txPower = nodeTxPower; ch->src_cell = current_cell; ch->dst_cell = current_cell; Scheduler &s = Scheduler::instance(); printf (" Direct send to %d from %d at %lf\n",dst_ip,src_ip, s.clock()); target_->recv(p,(Handler*)0); } //update cache node_cache[dst_ip]->time_last_accessed = now; } else { // buffer the packet rtQ.enque(p);

  25. Excerpts from tst.tcl set val(chan) Channel/WirelessChannel ;# channel typeset val(prop) Propagation/TwoRayGround ;# radio-propagation modelset val(ant) Antenna/OmniAntenna ;# Antenna typeset val(ll) LL ;# Link layer typeset val(ifq) Queue/DropTail/PriQueue ;# Interface queue typeset val(ifqlen) 50 ;# max packet in ifqset val(netif) Phy/WirelessPhy ;# network interface typeset val(mac) Mac/802_11 ;# MAC typeset val(rp) Kelpi ;# ad-hoc routing protocol set val(nn) 3 ;# number of mobilenodesset val(txPower) 0.002w ;# txPowerset ns_ [new Simulator]. . . # Provide initial (X,Y, for now Z=0) co-ordinates for node_(0) and node_(1)#$node_(0) set X_ 5.0$node_(0) set Y_ 5.0$node_(0) set Z_ 0.0. .## Move$ns_ at 1.0 "$node_(0) setdest 30.0 5.0 10.0"$ns_ at 6.0 "$node_(1) setdest 25.0 25.0 1.0"# TCP connections between node_(0) and node_(1)set tcp [new Agent/TCP]#$tcp set class_ 2set sink [new Agent/TCPSink]$ns_ attach-agent $node_(2) $sink$ns_ attach-agent $node_(1) $tcp$ns_ connect $tcp $sinkset ftp [new Application/FTP]$ftp attach-agent $tcp$ns_ at 2.0 "$ftp start" $ns_ at 3.0 "$ftp stop"

  26. Excerpt from wireless.tr s 2.003625883 _2_ MAC --- 7 tcp 1052 [a3 1 2 800] ------- [2:0 1:0 32 0] [0 0] 0 0r 2.007833936 _1_ MAC --- 7 tcp 1000 [a3 1 2 800] ------- [2:0 1:0 32 0] [0 0] 1 0s 2.007843936 _1_ MAC --- 0 MAC 38 [0 2 0 0] r 2.007858936 _1_ AGT --- 7 tcp 1000 [a3 1 2 800] ------- [2:0 1:0 32 0] [0 0] 1 0s 2.007858936 _1_ AGT --- 10 ack 40 [0 0 0 0] ------- [1:0 2:0 32 0] [0 0] 0 0r 2.007858936 _1_ RTR --- 10 ack 40 [0 0 0 0] ------- [1:0 2:0 32 0] [0 0] 0 0s 2.007858936 _1_ RTR --- 11 message 48 [0 0 0 0] ------- [1:255 0:255 32 0] r 2.007995988 _2_ MAC --- 0 MAC 38 [0 2 0 0] s 2.008505936 _1_ MAC --- 0 MAC 44 [2df 0 1 0] r 2.008681983 _0_ MAC --- 0 MAC 44 [2df 0 1 0] s 2.008691983 _0_ MAC --- 0 MAC 38 [23d 1 0 0] r 2.008844030 _1_ MAC --- 0 MAC 38 [23d 1 0 0] s 2.008894030 _1_ MAC --- 11 message 100 [a3 0 1 800] ------- [1:255 0:255 32 0] r 2.009294077 _0_ MAC --- 11 message 48 [a3 0 1 800] ------- [1:255 0:255 32 0] s 2.009304077 _0_ MAC --- 0 MAC 38 [0 1 0 0] r 2.009319077 _0_ RTR --- 11 message 48 [a3 0 1 800] ------- [1:255 0:255 32 0] s 2.009319077 _0_ RTR --- 11 message 48 [a3 0 1 800] ------- [0:255 -1:255 31 0]

  27. Kelpi: Implementation • following functionality has been successfully implemented • topology related functions • cell discovery • destination cell caching • packet buffering • packet forwarding • router hand-offs • these have been validated for small test cases

  28. Kelpi vs. other algorithms • Advantages • designed to provide stable routes • increased throughput due to two levels of transmission • reduced flooding overhead • Disadvantages • positioning system required • muliple levels of transmission preferred • routers may be overloaded in a dense network

  29. Future Directions • Remove requirement of GPS from Kelpi • Generalize concept of Virtual Backbone Routing to other existing routing algorithms

More Related