The present invention relates generally to communication systems and in particular, to a method and apparatus for flooding within such communication systems.
Message flooding within a communication system is well known. In particular, the message flooding procedure is often the basis of on-demand route discovery and network initialization. Message flooding is basically defined as a broadcast procedure covering a complete network. It operates as follows: When a node, or remote unit, in a network wishes to discover a route to another node in the network a message is broadcasted to all of its neighbors without specifying the destination address. Upon receiving the message, all of the neighboring nodes will rebroadcast the message to their neighbors. When a node receives the same message again, it discards it. The procedure repeats itself until all of the nodes in the network are reached. As discussed, the purpose to flood the network in a routing algorithm is essentially to find a path to send data to destinations or draw data from the sources. The message content is usually a request of route discovery.
Although message flooding is a dependable way to find a path within the network, flooding is proven to be the most expensive type of communication in wireless networks due to its broadcasting nature. The redundant broadcast caused by overlapping coverage amongst neighboring nodes wastes system resources, energy, and contributes to the excessive collisions. The redundant broadcast is more critical when executing flooding in a low-duty cycle mode because of the short communication windows and the use of coordination devices to schedule communications. In addition, a densely-deployed topology is another key factor to motivate the search for a new solution to address the redundant rebroadcast. Therefore, a need exists for a method and apparatus for message flooding within a communication system that minimizes redundant broadcasts caused by overlapping coverage.
To address the need for flooding within a communication system, a method and apparatus for flooding is provided herein. In accordance with the preferred embodiment of the present invention message flooding is provided that takes advantage of the availability of the node locations. The transmission of a flood message by a node is based on location information/coverage areas of neighboring nodes. In particular, each node within the communication system will delay retransmission of flood messages by a predetermined amount of time. If, during this delay, a node hears the flood message from another node, it then cancels or reschedules the transmission of the flood message.
During a home flooding scenario the delay, or back off period, is inversely proportional to a first area under the coordinator that a node can broadcast to, excluding a second area under the coordinator that the sender of the flood message can also broadcast to. Similarly, during a neighborhood flooding scenario the back off period is inversely proportional to a first area under the neighbor coordinator that a node can broadcast to, excluding a second area under both the home and neighbor coordinator that the node can broadcast to.
The above-described technique will allow as few as possible nodes that hear a flood message to rebroadcast the message, but still allows the full coverage of the network by the flood message. By reducing the number of nodes that rebroadcast, redundant flood messages are reduced, competitions in reservation windows that result in collisions are reduced, and traffic overhead is reduced.
The present invention encompasses a method for message flooding within a communication system. The method comprises the steps of receiving, by a remote unit, a message that potentially needs to be broadcast and determining a delay time for broadcasting the message, wherein the delay time is based on a coverage area of the remote unit.
The present invention additionally encompasses a method comprising the steps of receiving by a receiving node (B), a message transmitted from a transmitting node (A) and calculating a delay time for broadcasting the message. In the preferred embodiment of the present invention the delay time is based on a coverage area of the receiving node. The message is broadcast after the delay time if the message has not been broadcast by another node.
Finally, the present invention encompasses a receiving node for message flooding within a communication system. The receiving node comprises a receiver having as an input, a message that potentially needs to be broadcast, wherein the message was transmitted by a transmitting node, logic circuitry determining a delay time for broadcasting the message, wherein the delay time is based on a coverage area, and a transmitter outputting the message after the delay time has expired.
Prior to describing flooding in accordance with the preferred embodiment of the present invention the following definitions are provided to set the necessary background.
Turning now to the drawings, wherein like numerals designate like components,
As shown, communication system 100 comprises a plurality of nodes 101 and devices 102. During the network initialization, an infrastructure is formed with a subset of nodes 101 (10 are shown in
During typical transmission, a device (or node) 102 will schedule a time period to transmit through a given coordinator 101, and to receive through the given coordinator 101. This is illustrated in
An example of broadcasting a message within communication system 100 is illustrated in
As discussed above, message flooding is a dependable way to find a path within communication system 100, however, the redundant broadcast caused by overlapping coverage amongst neighboring nodes 102 wastes system resources, energy, and contribute to the excessive collisions. In order to address this issue, each node 102 within communication system 100 will delay retransmission of flood messages by a predetermined amount of time. If, during this delay, or back off period, a node hears the flood message from a neighboring node (home flooding) or another node (neighborhood flooding), then it cancels transmission of the flood message. In the preferred embodiment of the present invention, for home flooding the back off period is inversely proportional to a first area under the coordinator that a node can broadcast to, excluding a second area under the coordinator that the sender of the flood message can also broadcast to. Similarly, for neighborhood flooding the back off period is inversely proportional to a first area under the neighbor coordinator that a node can broadcast to, excluding a second area under both the home and neighbor coordinator that the node can broadcast to.
The above-described technique allows for broadcasting by largely reduced number of nodes 102 that hear a flood message while still allowing the full coverage of the network 100 by the flood message. By reducing the number of nodes 102 that rebroadcast, redundant flood messages are reduced along with competitions in reservation windows that result in collisions, and traffic overhead.
Home Flooding
As discussed above, all nodes 102 back off the rebroadcast of a received flood message, until they decide the time that they should rebroadcast or that there is no need to rebroadcast. In the preferred embodiment of the present invention the back off period for a particular node is inversely proportional to a first area under the coordinator that the node can broadcast to, excluding a second area under the coordinator that the sender of the flood message can also broadcast to. For example, for a coordinator (M) and a node that broadcasts the original message (A), a given node (B) will back off re-broadcasting the flood message for a period of time inversely proportional to:
Area=Area(M∩B)−Area(M∩B∩A). (1)
Thus, the larger the area, the shorter the back off period for the node. The back off time always ends at the beginning of a reservation window that node M can receive broadcast requests.
In the preferred embodiment of the present invention a unique identification (ID) is assigned to each flood message. This unique ID comprises a unique address of the originator of a flood message plus some sequence number generated by the originator as the unique ID. Additionally, each coordinator 101 will also record the number of rounds a specific message has been broadcasted using its own coordination. Therefore, for a specific flood message scheduled by a particular coordinator, the message can be identified as (coordinator ID, flood message ID, round ID). Additionally, when a node hears a flood message for the first time, the node will memorize this message as (sender ID, (coordinator ID, flood message ID, round ID)).
Flooding then takes place as follows:
Note that after receiving a flood message, a node will not wake up and listen to any future broadcasting of this message from other nodes in its range even if the schedule appears in any of its neighboring coordinators' beacon windows.
The process described above continues until there is no more rebroadcast attempts for the same message in the range of coordinator M. There will be no more attempts if any node in the range of M that has received this flood message meets either of the following conditions:
Condition 1 is the basic way to prevent any node from broadcasting the same message more than once in any flooding method. Condition 2 can easily be applied but it does not help if any node rebroadcasts a received flood message immediately. Therefore, the back off scheme is used to utilize these two conditions more efficiently to reduce the number of nodes that rebroadcast messages.
The new coverage area size is utilized as the back off criteria such that the node that can forward the message to the most new nodes (assuming uniform distribution of nodes) under a coordinator is always chosen to flood the message for the next round. Note that the optimal way is to calculate the new area by excluding any previous covered area under the coordinator. But in order to reduce the complexity at calculating this area at a given node B, Formula (1) is utilized considering only coverage of three nodes: the coordinator M, node A where the flood message comes from to B, and the node B itself.
Any next round broadcasting will cause some nodes to be covered more than once, which triggers Condition 2 and stop some nodes' attempt. Because these nodes have been covered more than once, they are likely to overlap more with the previous senders' coverage area. Therefore, for the node that has not been covered more than once, it is likely that it will cover more new area if it is chosen next round. The area that has never been covered or covered only once should decrease quickly by always choosing such a node to rebroadcast. The total number of nodes that actually rebroadcast should be greatly reduced compared with letting all nodes rebroadcast once, because many nodes' rebroadcast can be avoided due to the overlapping of covered areas.
As shown in
Because C covers a larger new area 601, it schedules next round of broadcast before B's back off finishes. Therefore, it rebroadcasts the message and B quits any further attempt to rebroadcast the message because it is also a neighbor of C. Area 701 (
Node D and E belong to area 701 and only hear the flood message once. Therefore, they decide how long to back off based on the areas 801 and 901 (
Referring to
Finally, referring to
Thus in accordance with the preferred embodiment of the present invention a total of four nodes have been used to rebroadcast the message within node's M's range in the above example. When compared to prior-art flooding where the same message are broadcast by all neighbors of node M at least once, the situations caused by the problems described earlier can be greatly improved.
Neighborhood Flooding
In the preferred embodiment of the present invention neighborhood flooding optimization works similarly to the above-described home flooding procedure. As discussed above, neighborhood flooding occurs when a node rebroadcasts a flood message through a different coordinator to reach neighbors under the different coordinator. In this scenario, when node A receives a flood message through the coordination of node M, and node A is in the range of another coordinator N, node A will try to send a request to node N in order to rebroadcast this message to its neighbors that are also in the range of N. Instead of sending the request immediately, node A will also back off for a period of time decided by the following formula:
Area(N∩A)−Area(N∩A∩M) (2)
If node A does not hear any other node's schedule of rebroadcast the same message through node N before its back off is over, it will send request to node N to rebroadcast this message. If it hears any broadcast schedule of the same message through N (no mater whether the sender is a neighboring node or not), node A will stop rebroadcast this message. Hereafter, the algorithm used by all nodes under coordinator N is the same as the algorithms used in home flooding.
As an example, in
Home Flooding Back Off Time
The algorithm may choose to use Formula (3) to decide the back off time for home flooding. In the formula, M is the coordinator, A is the flood message sender, and B is the node that calculates the back off time.
In Formula (3), Area (M-M∩A) refers to the maximal new covered area under M's range by any node that is in M∩A, which receives a flood message from A. Furthermore, Density×Area (M∩A) estimates the total number of nodes under M that receive the flood message from A. These two values are constant for all nodes in M∩A. As described earlier, Area (M∩B)—Area (M∩B∩A) refers to the new covered area under M's range by node B. This formula will estimates to an integer number from 0 to the number of nodes in M∩A. The smaller is the new coverage area, the larger is the value of Formula (3). If a node's new coverage area equals the maximal new coverage, Formula (3) will have a value of 0.
The calculated value decides how many more beacon windows to wait before sending node B's rebroadcast request to M. If no other node's rebroadcast through the coordination of node M covers node B when all these beacon windows past, node B sends its own rebroadcast request to M in the next available reservation window of node M.
H. Neighborhood Flooding Back Off Time
The algorithm may choose to use Formula (4) to decide the back off time for neighborhood flooding. In the formula, N is the new coordinator, M is the previous coordinator, and A is the node that calculates the back off time.
In Formula (4), Area (N-N∩M) refers to the maximal new covered area under N's range by any node that is in N∩M, which receives a flood message through the coordination of node M and then tries to rebroadcast the same message to other neighbors through the coordination of node N. Furthermore, Density×Area (N∩M) estimates the total number of nodes under M that will try to rebroadcast through the coordination of node N. These two values are constant for all nodes in N∩M. Similar to home flooding, Area (N∩A)—Area (N∩A∩M) refers to the new covered area under N's range by node A other than the area covered by node M. This formula will estimates to a number from 0 to the number of nodes in N∩M. The smaller is the new coverage area, the larger is the value of Formula (4). If a node's new coverage area under N equals the maximal new coverage, Formula (4) will have a value of 0.
The calculated value decides how many more beacon windows to wait before sending node A's rebroadcast request to N. If no other node rebroadcasts through the coordination of node N when all these beacon windows past, node A sends its own rebroadcast request to N in the next available reservation window of node N.
Area Calculation
As is evident, physical locations and radio transmission range of all nodes 101 and 102 within network 100 are essential information for the area calculations. In the preferred embodiment of the present invention location is accomplished as described in U.S. Pat. No. 6,473,038 “Method and Apparatus for Location Estimation” and pending U.S. patent application Ser. No. 10/040,610 “Method for Determining Location Information”.
Assume each node knows their own two dimensional physical location and the radio transmission range is known and fixed, each node is required to attach its own location information when it broadcasts or rebroadcasts a flood message. Each node also knows the locations of its coordinators. Therefore, a node can always apply the location information of itself, the coordinator, and the node that sends it the flood message in area calculations.
The area calculation used in Formulas (1) to (4) involves calculating the size of overlapped areas of two and three circles.
Area(M∩B∩A)=2×(Area(Sector AOP)−Area(Triangle AOP)); (5)
Area(M∩B∩A)=Area(Sector AOQ)−Area(Triangle AOQ)+Area(Sector BQR)−Area(Triangle BQR)+Area (Sector MOR)−Area(Triangle MOR)+Area(Triangle OQR). (6)
The areas of the sectors and triangles shown in Formulas (5) and (6) can be easily derived from nodes M, A and B's physical locations, the radius of the circles (transmission range), and the distances between nodes.
The logic flow begins at step 2001 where receiver 1902 receives a message that potentially needs to be rebroadcast. In the preferred embodiment of the present invention the message comprises a flood message transmitted from a transmitting node, however in alternate embodiments of the present invention the message may comprise any message type that requires units to retransmit the message.
At step 2003 logic unit 1901 calculates a delay, or back off time, to retransmit the message. As discussed above, the delay time is based on a coverage area of the receiving node (remote unit 102), and for home flooding, is inversely proportional to a first area under the coordinator that remote unit 102 can broadcast to, excluding a second area under the coordinator that the sender of the flood message can also broadcast to. For neighborhood flooding the delay time is inversely proportional to a first area under the neighbor coordinator that a node can broadcast to, excluding a second area under both the home and neighbor coordinator that the node can broadcast to. At step 2005, and prior to the back off time being over, logic unit 1901 determines if the flood message has been heard from another node, and if not the logic flow continues to step 2007, otherwise the logic flow continues to step 2009. It should be noted that for neighborhood flooding, the logic flow skips step 2009 and simply ends at step 2011.
At step 2009 logic unit 1901 determines if the message was from a neighbor, and if so, the logic flow ends at step 2011 (flood message is not rebroadcast), otherwise the logic flow continues to step 2013 where the back off period is restarted and the round number is changed. The logic flow then returns to step 2005.
At step 2007 it is determined if the back off time has expired, and if not the logic flow returns to step 2005. If, at step 2007 the back off time has expired, then the logic flow continues to step 2013 where a request to rebroadcast the message is sent. At step 2015 it is determined if the message has been scheduled, and if so, the message is broadcast (step 2017) and the logic flow ends at step 2011. If, however, at step 2015 it is determined that the message has not been scheduled, then the logic flow continues to step 2019 where it is determined if the message has been scheduled by another node. If, at step 2019 it is determined the message has been scheduled by another node, the logic flow returns to step 2009, otherwise the logic flow continues to step 2021. At step 2021 the back off timer is reset to the beginning of next reservation window and the logic flow returns to step 2005.
While the invention has been particularly shown and described with reference to a particular embodiment, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention. It is intended that such changes come within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5038403 | Leitch | Aug 1991 | A |
5172396 | Rose et al. | Dec 1992 | A |
5423059 | LoGalbo et al. | Jun 1995 | A |
5815814 | Dennison et al. | Sep 1998 | A |
5924042 | Sakamoto et al. | Jul 1999 | A |
5930248 | Langlet et al. | Jul 1999 | A |
5963868 | Baek | Oct 1999 | A |
6011977 | Brown et al. | Jan 2000 | A |
6097930 | Hill et al. | Aug 2000 | A |
6161022 | Hwang et al. | Dec 2000 | A |
6266536 | Janky | Jul 2001 | B1 |
6438376 | Elliott et al. | Aug 2002 | B1 |
6909706 | Wilmer et al. | Jun 2005 | B2 |
7002934 | Dolgonos et al. | Feb 2006 | B2 |
7002949 | Garcia-Luna-Aceves et al. | Feb 2006 | B2 |
7016336 | Sorensen | Mar 2006 | B2 |
20010005368 | Rune | Jun 2001 | A1 |
Number | Date | Country |
---|---|---|
1037484 | Sep 2000 | EP |
Number | Date | Country | |
---|---|---|---|
20040100957 A1 | May 2004 | US |