Zero overhead efficient flooding (ZOEF) oriented hybrid any-cast routing for mobile ad hoc networks (MANET)
11646962 · 2023-05-09
Assignee
Inventors
Cpc classification
Y02D30/70
GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
International classification
Abstract
A system and method for hybrid any-cast (unicast, multicast and anycast) routing in a mobile ad hoc communication network (MANET) is disclosed. In embodiments, each communication node of the MANET may implement on-demand routing functions whereby the node does not establish or maintain routes to destination nodes unless there is active communication, discovering routes via flooding of data packets in transit. Each communication node may select, or may transition from on-demand to, proactive routing functions. Proactive nodes first establish routes to clusters of other proactive nodes by flooding, and receiving acknowledgments from, the other proactive nodes. Each cluster of proactive nodes maintains routes within the cluster and establishes communication routes outside the cluster by flooding and relaying of routing status messages via clusterhead and gateway nodes. A single MANET can support clusters of proactive nodes within a network of on-demand nodes and dynamic transitions between proactive and on-demand status.
Claims
1. A communication node of a multi-node communication network, the communication node comprising: a communication interface; and at least one controller communicatively coupled to the communication interface, the controller configured to: receive, via the communication interface, at least one first data packet in transit from a source communication node to a destination communication node; designate the communication node as a proactive communication node by: identifying at least one proactive cluster of one or more additional communication nodes of the multi-node communication network, the proactive cluster including at least one gateway node having a gateway node status, by transmitting, via the communication interface, at least one hello message including a unique identifier of the communication node and a clustering status of the communication node; designating the clustering status of the communication node as a clusterhead status; adjusting the unique identifier of the communication node to include a cluster identifier corresponding to the proactive cluster; receiving at least one acknowledgement from the one or more additional communication nodes; adding the at least one acknowledgement to a list of node acknowledgements; and including the list of node acknowledgements in at least one retransmission of the hello message; determine a route from the source communication node to the destination communication node by relaying, via the communication interface, at least one routing status message to the destination communication node via the at least one gateway node; receive, via the communication interface, at least one first route response from the destination communication node along a proactive route via the at least one gateway node; update the routing information to include the proactive route; and transmit the at least one first data packet to the destination node along the proactive route via the at least one gateway node; or designate the communication node as an on-demand communication node by: transmitting the first data packet to at least one relay communication node via at least one packet flooding procedure; receiving at least one second route response in transit from the destination communication node to the source communication node along a discovered route via the at least one relay communication node; updating routing information of the communication node to include the discovered route; and relaying at least one additional data packet in transit from the source communication node to the destination communication node via the discovered route.
2. The communication node of claim 1, wherein the at least one hello message is an adaptive hello message not including a local neighbor list.
3. The communication node of claim 1, wherein the at least one routing status message is selected from a link status advertisement (LSA) or a distance vector distribution (DVD).
4. The communication node of claim 1, wherein the at least one routing status message includes a hop count restriction.
5. The communication node of claim 1, wherein the hello message is a first hello message, the routing status message is a first routing status message, and the controller is configured to maintain the at least one proactive route by: relaying, via the communication interface, at least one of a second hello message and a second routing status message to the destination communication node via the at least one gateway node; receiving, via the communication interface, at least one additional route response from the destination communication node along an updated proactive route via the at least one gateway node; and updating the routing information to include one or more of the updated proactive route and an updated link status of the one or more additional communication nodes.
6. The communication node of claim 1, wherein the destination communication node is a first destination communication node, and the on-demand communication node is configured to: receive, via the communication interface, at least one additional route response from a second destination communication node along an additional proactive route; and update the routing information to include the additional proactive route.
7. The communication node of claim 1, wherein the on-demand communication node is configured to: transmit, via the communication interface, at least one join request to a first proactive node associated with a proactive duster; acknowledge acceptance of the join request by designating, via the controller, the on-demand communication node as a second proactive node; select the clustering status of the second proactive node from a clusterhead node status, a gateway node status, and an ordinary node status; and identify at least one proactive route to a third proactive node of the proactive duster by transmitting, via the communication interface, at least one first hello message including a unique identifier of the second proactive node, a unique identifier of the proactive duster, and the selected clustering status of the second proactive node.
8. A method for hybrid any-cast routing in a multi-node communication network, the method comprising: receiving, via a communication interface of a communication node, at least one data packet in transit from a source communication node to a destination communication node; designating, via a controller of the communication node, the communication node as one of a proactive node and an on-demand node; when the communication node is a proactive node: identifying at least one proactive cluster of one or more additional communication nodes of the multi-node communication network, the proactive cluster including at least one gateway node having a gateway node status, by transmitting, via the communication interface, at least one hello message including a unique identifier of the communication node and a clustering status of the communication node; designating, via the controller, the clustering status of the communication node as a clusterhead node status; adjusting the unique identifier of the communication node to include a cluster identifier corresponding to the proactive cluster; receiving at least one acknowledgement from the one or more additional communication nodes; adding the at least one acknowledgement to a node acknowledgement list; including the list of node acknowledgements in at least one retransmission of the hello message; determining a route from the source communication node to the destination communication node by relaying, via the communication interface, at least one of the hello message and a first routing status message to the destination communication node via the at least one gateway node; receiving, via the communication interface, at least one first route response from the destination communication node along a proactive route via the at least one gateway node; updating the routing information to include the proactive route; and transmitting the at least one data packet to the destination node along the proactive route via the at least one gateway node; and when the communication node is an on-demand node: transmitting the data packet to at least one relay communication node via at least one packet flooding procedure; receiving at least one second route response in transit from the destination communication node to the source communication node along a discovered route via the at least one relay communication node; updating routing information of the communication node to include the discovered route; and relaying at least one additional data packet in transit from the source communication node to the destination communication node via the discovered route.
9. The method of claim 8, wherein the hello message is a first hello message and the routing status message is a first routing status message, further comprising: when the communication node is a proactive node, maintaining the at least one proactive route by: relaying, via the communication interface, at least one of a second hello message and a second routing status message to the destination communication node via the at least one gateway node; receiving, via the communication interface, at least one additional route response from the destination communication node along an updated proactive route via the at least one gateway node; and updating the routing information to include the updated proactive route.
10. The method of claim 8, further comprising: when the communication node is an on-demand node: receiving, via the communication interface, at least one additional route response from a second destination communication node along an additional proactive route; and updating the routing information to include the additional proactive route.
11. The method of claim 8, further comprising: when the communication node is an on-demand node: transmitting, via the communication interface, at least one join request to a first proactive node associated with a proactive cluster; acknowledging acceptance of the join request by designating, via the controller, the on-demand communication node as a second proactive node; selecting the clustering status of the second proactive node from a clusterhead node status, a gateway node status, and an ordinary node status; identifying at least one proactive route to a third proactive node of the proactive cluster by transmitting, via the communication interface, at least one first hello message including a unique identifier of the second proactive node, a unique identifier of the proactive duster, and the selected clustering status of the second proactive node; receiving at least one additional routing status message from the proactive duster; and updating the routing information based on the received additional routing status message.
12. The method of claim 8, wherein the at least one hello message is an adaptive hello message not including a local neighbor list.
13. The method of claim 8, wherein the at least one routing status message is selected from a link status advertisement (LSA) or a distance vector distribution (DVD).
14. The method of claim 8, wherein the at least one routing status message includes a hop count restriction.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1) The detailed description is described with reference to the accompanying figures. The use of the same reference numbers in different instances in the description and the figures may indicate similar or identical items. Various embodiments or examples (“examples”) of the present disclosure are disclosed in the following detailed description and the accompanying drawings. The drawings are not necessarily to scale. In general, operations of disclosed processes may be performed in an arbitrary order, unless otherwise provided in the claims. In the drawings:
(2)
(3)
(4)
(5)
(6) and
DETAILED DESCRIPTION
(7) Before explaining one or more embodiments of the disclosure in detail, it is to be understood that the embodiments are not limited in their application to the details of construction and the arrangement of the components or steps or methodologies set forth in the following description or illustrated in the drawings. In the following detailed description of embodiments, numerous specific details may be set forth in order to provide a more thorough understanding of the disclosure. However, it will be apparent to one of ordinary skill in the art having the benefit of the instant disclosure that the embodiments disclosed herein may be practiced without some of these specific details. In other instances, well-known features may not be described in detail to avoid unnecessarily complicating the instant disclosure.
(8) As used herein a letter following a reference numeral is intended to reference an embodiment of the feature or element that may be similar, but not necessarily identical, to a previously described element or feature bearing the same reference numeral (e.g., 1, 1a, 1b). Such shorthand notations are used for purposes of convenience only and should not be construed to limit the disclosure in any way unless expressly stated to the contrary.
(9) Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
(10) In addition, use of “a” or “an” may be employed to describe elements and components of embodiments disclosed herein. This is done merely for convenience and “a” and “an” are intended to include “one” or “at least one,” and the singular also includes the plural unless it is obvious that it is meant otherwise.
(11) Finally, as used herein any reference to “one embodiment” or “some embodiments” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment disclosed herein. The appearances of the phrase “in some embodiments” in various places in the specification are not necessarily all referring to the same embodiment, and embodiments may include one or more of the features expressly described or inherently present herein, or any combination or sub-combination of two or more such features, along with any other features which may not necessarily be expressly described or inherently present in the instant disclosure.
(12) Referring to
(13) In embodiments, the multi-node communication network 100 may include any multi-node communication network known in the art. For example, the multi-node communication network 100 may include a mobile ad-hoc network (MANET) in which each communication node 102 within the multi-node communication network is able to move freely and independently. Similarly, the one or more communication nodes 102 may include any communication node known in the art which may be communicatively coupled. In this regard, the one or more communication nodes 102 may include any communication node known in the art for transmitting/transceiving data packets. For example, the one or more communication nodes 102 may include, but are not limited to, radios, mobile phones, smart phones, tablets, smart watches, laptops, and the like. In embodiments, each communication node 102 of the multi-node communication network 100 may include, but is not limited to, a respective controller 104 (e.g., control processor), memory 106, and communication interface 108.
(14) The controller 104 provides processing functionality for at least the communication node 102 and can include any number of processors, micro-controllers, circuitry, field programmable gate array (FPGA) or other processing systems, and resident or external memory for storing data, executable code, and other information accessed or generated by the communication node 102. The controller 104 can execute one or more software programs embodied in a non-transitory computer readable medium (e.g., memory 106) that implement techniques described herein. The controller 104 is not limited by the materials from which it is formed or the processing mechanisms employed therein and, as such, can be implemented via semiconductor(s) and/or transistors (e.g., using electronic integrated circuit (IC) components), and so forth.
(15) The memory 106 can be an example of tangible, computer-readable storage medium that provides storage functionality to store various data and/or program code associated with operation of the communication node 102/controller 104, such as software programs and/or code segments, or other data to instruct the controller 104, and possibly other components of the communication node 102, to perform the functionality described herein. Thus, the memory 106 can store data, such as a program of instructions for operating the communication node 102, including its components (e.g., controller 104, communication interface 108, etc.), and so forth. It should be noted that while a single memory 106 is described, a wide variety of types and combinations of memory (e.g., tangible, non-transitory memory) can be employed. The memory 106 can be integral with the controller 104, can comprise stand-alone memory, or can be a combination of both. Some examples of the memory 106 can include removable and non-removable memory components, such as random-access memory (RAM), read-only memory (ROM), flash memory (e.g., a secure digital (SD) memory card, a mini-SD memory card, and/or a micro-SD memory card), solid-state drive (SSD) memory, magnetic memory, optical memory, universal serial bus (USB) memory devices, hard disk memory, external memory, and so forth.
(16) The communication interface 108 can be operatively configured to communicate with components of the communication node 102. For example, the communication interface 108 can be configured to retrieve data from the controller 104 or other devices (e.g., other nodes 102), transmit data for storage in the memory 106, retrieve data from storage in the memory 106, and so forth. The communication interface 108 can also be communicatively coupled with the controller 104 to facilitate data transfer between components of the communication node 102 and the controller 104. It should be noted that while the communication interface 108 is described as a component of the communication node 102, one or more components of the communication interface 108 can be implemented as external components communicatively coupled to the communication node 102 via a wired and/or wireless connection. The communication node 102 can also include and/or connect to one or more input/output (I/O) devices. In embodiments, the communication interface 108 includes or is coupled to a transmitter, receiver, transceiver, physical connection interface, or any combination thereof.
(17) It is contemplated herein that the communication interface 108 of a communication node 102 may be configured to communicatively couple to additional communication interfaces 108 of additional communication nodes 102 of the multi-node communication network 100 using any wireless communication techniques known in the art including, but not limited to, GSM, GPRS, CDMA, EV-DO, EDGE, WiMAX, 3G, 4G, 4G LTE, 5G, WiFi protocols, RF, LoRa, and the like.
(18) In embodiments, the multi-node communication network 100 may determine the shortest route for transmission of a data packet between a source node 102a and a destination node 102b. For example, each communication node 102 of the multi-node communication network 100 may default to opportunistic on-demand routing. The source node 102a may transmit (110) the data packet (e.g., or a portion thereof) to the destination node 102b according to one or more packet flooding schemes or techniques (e.g., flooding to routing (F2R), efficient flooding with passive clustering (EFPC), zero overhead efficient flooding (ZOEF), ad hoc on-demand distance vector (AODV) routing, as disclosed by U.S. patent application Ser. Nos. 16/369,398, 16/537,824, and 16/707,111 herein incorporated by reference in their entirety). In some embodiments, the source node 102a may transmit hello messages, route request packets, or other specialized topology learning packets instead of the data to be transmitted.
(19) In embodiments, any relay nodes 102c within sufficient transmission range of the source node 102a to receive or “hear” the data packet may relay (112) the data packet. For example, referring also to
(20) In embodiments, the communication nodes 102 of the multi-node communication network 100 may default to opportunistic on-demand routing in that other proximate or nearby nodes 102d may receive or “overhear” route requests transmitted by the destination node 102b and relayed by nearby relay nodes 102c along the discovered route 202. Accordingly, the nearby nodes 102d may also establish the discovered route 202 to the destination node 102b in their own local routing tables.
(21) Referring now to
(22) In embodiments, a cluster 300 of communication nodes may be formed by a group of proactive nodes 302 transitioning from the default opportunistic on-demand state (e.g., as shown by
(23) In embodiments, the cluster 300 of proactive nodes 302 may establish and maintain routes 304 among its member nodes. For example, the cluster 300 may establish (e.g., via an initiating clusterhead node 306 or other critical node) a group identifier common to all member proactive nodes 302, which group identifier may be used by all proactive nodes to control the scope of proactive routing functions (e.g., hello messaging and/or routing status messages (e.g., link status advertisements (LSA), distance vector distributions (DVD), and unique node/clustering status identifiers incorporated therein) in establishing and maintaining routes to communication nodes 102 outside the cluster. Hello messages and/or routing status messages may incorporate hop count restrictions to limit excess message traffic due to packet flooding within, or external to, the clusters 300a-b.
(24) In embodiments, the clusters 300a-b may be implemented and may function similarly to the cluster 300, except that the clusters 300a-b may organize as critical or non-critical nodes according to the applicable proactive routing structure. For example, the proactive nodes 302 of the clusters 300a-b may organize themselves into clusterhead nodes 306, gateway nodes 308, ordinary nodes 310, or according to other node clustering statuses. Each cluster 300a-b may include a single clusterhead node 306 responsible for initiating routing status message (LSA/DVD) flooding and for collecting and maintaining link statuses among other proactive nodes (e.g., gateway nodes 308, ordinary nodes 310) in its cluster. Similarly, the number and distribution of critical nodes (e.g., clusterhead nodes 306, gateway nodes 308) within each cluster 300a-b may vary depending on applicable clustering status transition rules associated with the applicable proactive routing structure.
(25) In embodiments, the gateway nodes 308 may relay data packets to and from the ordinary nodes 310 within each cluster 300a-b. Similarly, the gateway nodes 308 may relay data packets to and from the clusterhead nodes 306 (or, e.g., if the data packets originate from source nodes (102a,
(26) Referring to
(27) In embodiments, communication nodes (102,
(28) Referring now to
(29) At a step 502, a communication node of the multi-node communication network receives, via its communication interface, a data packet in transit from a source node to a destination node.
(30) At a step 504, the communication node designates itself as a proactive node (504a) or an on-demand node (504b). For example, if the communication node defaults to on-demand routing functions, the communications node may retain its on-demand status. Alternatively, the communications node may be one of a group of nodes organizing as a cluster of proactive nodes, or an on-demand node invited to join a pre-existing cluster.
(31) Referring now to
(32) At a step 508, the proactive node adjusts its unique node identifier to include a group identifier for the cluster.
(33) At a step 510, the proactive node receives acknowledgements from one or more proactive nodes of the cluster.
(34) At a step 512, the proactive node adds the received acknowledgements to its list of node acknowledgements.
(35) At the step 514, the proactive node includes the list of node acknowledgements in subsequent retransmissions of the hello message. In some embodiments, the proactive node may iteratively transmit multiple instances of the list of node acknowledgements, each instance updated to reflect the most recent acknowledgements, until no further acknowledgements are received for at least a predetermined time interval.
(36) Referring now to
(37) At a step 518, the proactive node receives a subsequent route response from the destination node, and relayed by the gateway nodes, indicating an updated proactive route.
(38) At the step 520, the proactive node updates its routing information to include the updated proactive route.
(39) Referring now to
(40) At a step 524, the on-demand node receives a route response from the destination node, and in transit to the source node, indicative of a discovered route from the source node to the destination node including one or more relay nodes.
(41) At a step 526, the on-demand node updates its routing information to include the discovered route.
(42) At the step 528, the on-demand node transmits additional data packets originating with the source node to the destination node along the discovered route.
(43) Referring now to
(44) At the step 532, the on-demand node updates its local routing information to include the new proactive route.
(45) Referring to
(46) At a step 536, the on-demand node acknowledges an accepted join request by designating the on-demand node as a proactive node and a member of the cluster.
(47) At a step 538, the newly proactive node designates a node clustering status (e.g., clusterhead, gateway, ordinary). For example, the newly proactive node may default to gateway node status.
(48) At a step 540, the newly proactive node discovers proactive route information for its cluster (e.g., identities of other proactive nodes within the cluster, and route information for the other proactive nodes) by transmitting hello messages to the existing proactive node (e.g., which may be relayed and/or flooded within the cluster by the existing proactive node to collect updated routing information).
(49) At a step 542, the newly proactive node receives a routing status message (e.g., a link status advertisement (LSA) or distance vector distribution (DVD) transmitted by the existing proactive node) including updated routing, node identity, and clustering status information for member nodes of the proactive cluster.
(50) At the step 544, the newly proactive node updates its local routing table based on the group routing information received from the cluster.
CONCLUSION
(51) It is to be understood that embodiments of the methods disclosed herein may include one or more of the steps described herein. Further, such steps may be carried out in any desired order and two or more of the steps may be carried out simultaneously with one another. Two or more of the steps disclosed herein may be combined in a single step, and in some embodiments, one or more of the steps may be carried out as two or more sub-steps. Further, other steps or sub-steps may be carried in addition to, or as substitutes to one or more of the steps disclosed herein.
(52) Although inventive concepts have been described with reference to the embodiments illustrated in the attached drawing figures, equivalents may be employed and substitutions made herein without departing from the scope of the claims. Components illustrated and described herein are merely examples of a system/device and components that may be used to implement embodiments of the inventive concepts and may be replaced with other devices and components without departing from the scope of the claims. Furthermore, any dimensions, degrees, and/or numerical ranges provided herein are to be understood as non-limiting examples unless otherwise specified in the claims.