|Publication number||US8300551 B2|
|Application number||US 12/696,044|
|Publication date||30 Oct 2012|
|Filing date||28 Jan 2010|
|Priority date||28 Jan 2009|
|Also published as||US8699381, US20100238940, US20130070676|
|Publication number||12696044, 696044, US 8300551 B2, US 8300551B2, US-B2-8300551, US8300551 B2, US8300551B2|
|Inventors||LaMonte Peter KOOP, Edward Allen PAYNE|
|Original Assignee||Google Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (212), Non-Patent Citations (29), Referenced by (4), Classifications (16), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The present application is a U.S. nonprovisional patent application of, and claims priority under 35 U.S.C. §119(e) to, U.S. provisional patent application Ser. No. 61/147,917, filed Jan. 28, 2009, which provisional patent application is incorporated by reference herein. A copy of this provisional patent application is attached hereto as Appendix A, which Appendix is incorporated herein by reference.
U.S. Patent Application Publication No. 2007/0002792, U.S. Patent Application Publication No. 2007/0002793, U.S. patent application No. 12/608,837, and any publications thereof, including U.S. Patent Application Publication No. 2010/0150026, and any patents issuing from any of the foregoing, are hereby incorporated herein by reference.
Additionally, the present application hereby incorporates herein by reference each of the following identified U.S. patent applications—as well as any publications thereof and any patents issuing therefrom; the following identified U.S. patent application publications; and the following identified U.S. patent application Ser. Nos. 12/607,040; 12/609,009; 12/609,008; 12/608,837; 12/468,047; 12/367,544 (US 2009-0135000 A1); Ser. No. 12/367,543 (US 2009-0161642 A1); Ser. No. 12/367,542 (US 2009-0181623 A1); Ser. No. 12/353,197 (US 2009-0129306 A1); Ser. No. 12/352,992 (US 2009-0122737 A1); Ser. No. 12/343,865 (US 2009-0104902 A1); Ser. No. 12/343,822 (US 2009-0103462 A1); Ser. No. 12/271,850 (US 2009-0092082 A1); Ser. No. 12/140,253 (US 2008-0303897 A1); Ser. No. 11/930,797 (US 2008-0151850 A1); Ser. No. 11/930,793 (US 2008-0112378 A1); Ser. No. 11/930,788 (US 2008-0165749 A1); Ser. No. 11/930,785 (US 2008-0143484 A1); Ser. No. 11/930,782 (US 2008-0212544 A1); Ser. No. 11/930,779 (US 2008-0129458 A1); Ser. No. 11/930,777 (US 2008-0111692 A1); Ser. No. 11/930,770 (US 2008-0144554 A1); Ser. No. 11/930,761 (US 2008-0112377 A1); Ser. No. 11/930,753 (US 2008-0142592 A1) now U.S. Pat. No. 7,535,339; Ser. No. 11/930,749 (US 2008-0130536 A1) now U. S. Pat. No. 7,538,658; Ser. No. 11/930,740 (US 2008-0150723 A1) now U.S. Pat. No. 7,538,657; Ser. No. 11/930,736 (US 2008-0143483 A1) now U.S. Pat. No. 7,538,656; Ser. No. 11/847,309 (US 2007-0291724 A1); Ser. No. 11/847,295 (US 2007-0291690 A1); Ser. No. 11/832,998 (US 2007-0273503 A1) now U.S. Pat. No. 7,378,959; Ser. No. 11/832,991 (US 2007-0268134 A1) now U.S. Pat. No. 7,378,958; Ser. No. 11/832,979 (US 2007-0268126 A1) now U.S. Pat. No. 7,378,957; Ser. No. 11/610,427 (US 2007-0159999 A1); Ser. No. 11/618,931 (US 2007-0155327 A1); Ser. No. 11/555,173 (US 2007-0099629 A1); Ser. No. 11/555,164 (US 2007-0099628 A1); Ser. No. 11/465,466 (US 2007-0043807 A1); Ser. No. 11/465,796 (US 2007-0041333 A1); Ser. No. 11/460,976 (US 2008-0315596 A1); Ser. No. 11/428,536 (US 2007-0002793 A1); Ser. No. 11/428,535 (US 2007-0002792 A1); Ser. No. 11/425,047 (US 2007-0069885 A1) now U.S. Pat. No. 7,554,442; Ser. No. 11/425,040 (US 2006-0287008 A1) now U.S. Pat. No. 7,539,520; Ser. No. 11/424,850 (US 2007-0004331 A1); Ser. No. 11/424,849 (US 2007-0004330 A1) now U.S. Pat. No. 7,574,168; Ser. No. 11/424,847 (US 2007-0001898 A1) now U.S. Pat. No. 7,583,769; Ser. No. 11/424,845 (US 2006-0287822 A1) now U.S. Pat. No. 7,574,300; Ser. No. 11/423,127 (US 2006-0289204 A1) now Pat. No. 7,563,991; Ser. No. 11/422,306 (US 2006-0282217 A1) Now Pat. No. 7,542,849; Ser. No. 11/422,304 (US 2006-0276963 A1) now U.S. Pat No. 7,526,381; Ser. No. 11/422,321 (US 2006-0276161 A1); Ser. No. 11/422,329 (US 2006-0274698 A1) now U.S. Pat. No. 7,529,547; Ser. No. 11/306,765 (US 2008-0136624 A1) now U.S. Pat. No. 7,394,361; Ser. No. 11/306,764 (US 2006-0237490 A1) now U.S. Pat. No. 7,391,321; Ser. No. 11/193,300 (US 2007-0024066 A1) now U.S. Pat. No. 7,438,334; Ser. No. 11/161,550 (US 2007-0002808 A1) now U.S. Pat. No. 7,430,437; Ser. No. 11/161,545 (US 2006-0018274 A1) now U.S. Pat. No. 7,221,668; Ser. No. 11/161,542 (US 2006-0023679 A1) now U.S. Pat. No. 7,522,568; Ser. No. 11/161,540 (US 2007-0004431 A1) now U.S. Pat. No. 7,200,132; Ser. No. 11/161,539 (US 2006-0023678 A1) now U.S. Pat. No. 7,209,468; Ser. No. 10/987,964 (US 2005-0093703 A1) now U.S. Pat. No. 7,155,264; Ser. No. 10/987,884 (US 2005-0093702 A1) now U.S. Pat. No. 7,133,704; Ser. No. 10/604,032 (US 2004-0082296 A1) now U.S. Pat. No. 6,934,540; Ser. No. 10/514,336 (US 2005-0215280 A1) now U.S. Pat. No. 7,209,771; and 09/681,282 (US 2002-0119770 A1) now U.S. Pat. No. 6,745,027.
Each of the foregoing patent application publications and patents is hereby incorporated herein by reference for purposes of disclosure of class-based network (CBN) technology, wake-up (WU) technology, and class-based networks that utilize such technologies (such as those of TeraHop Networks, Inc. of Alpharetta, Ga.), and systems employing such technologies including, inter alia: (1) implementations in the first responder context; (2) implementations in container tracking and monitoring context; and (3) implementations in equipment tracking and monitoring, especially rental construction equipment. It is intended that the CBN and WU technologies, and related features, improvements, and enhancements, as disclosed in these incorporated references may be utilized in combination with various embodiments and implementations of the present invention.
All of the material in this patent document is subject to copyright protection under the copyright laws of the United States and other countries. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in official governmental records but, otherwise, all other copyright rights whatsoever are reserved.
The present invention generally relates to ascertaining presence in wireless networks.
A need exists for improvement in such presence ascertainment. This, and other needs, are addressed by one or more aspects of the present invention.
The present invention includes many aspects and features. Moreover, while many aspects and features relate to, and are described in, the context of wireless radio networks, the present invention is not limited to use only in such context, as will become apparent from the following summaries and detailed descriptions of aspects, features, and one or more embodiments of the present invention.
Accordingly, one aspect of the present invention relates to a method, in an ad hoc network in which inbound messages are communicated from an originating node to a gateway node via a plurality of intermediate nodes, performed by an intermediate node in communicating the inbound message to the gateway node. The method includes the steps of maintaining a routing table including a set of one or more rows, wherein each row of the set comprises fields including, a next hop address, representing a unique address of a node, a next hop hopcount, representing a hop count to the gateway, and a next hop qualifier, representing a preference to using a node as a next hop towards a gateway node relative to other nodes that may be used as a next hop towards a gateway node, all fields of the row being pertaining to a known intermediate node for use as a next hop towards the gateway node; selecting a node for use as the next hop towards the gateway node for communicating the inbound message to the gateway node by, determining whether a sum of the next hop hopcount from a row and a current hopcount of the inbound message exceeds a maximum number of allowable hops for an inbound message, and comparing a next hop qualifier of a row to a next hop qualifier of another row, wherein, for both rows, the maximum number of allowable hops for an inbound message is not exceeded, and communicating the inbound message to the node identified by the next hop address for which the next hop qualifier is determined to be preferred based on said comparison.
In a feature of this aspect of the invention, the step of comparing a next hop qualifier of a row to a next hop qualifier of another row comprises determining whether numeric values representing the next hop qualifiers are equal.
In a feature of this aspect of the invention, the gateway node maintains pathways among the nodes based on the messages received from each of the other nodes.
In a feature of this aspect of the invention, the next hop hopcount in a row represents a hop count to the gateway node from the node corresponding to the next hop address of that row.
In a feature of this aspect of the invention, the step of comparing a next hop qualifier of a row to a next hop qualifier of another row comprises determining which of two numeric values representing the next hop qualifiers is greater than the other.
In a feature of this aspect of the invention, the step of comparing a next hop qualifier of a row to a next hop qualifier of another row comprises determining which of two numeric values representing the next hop qualifiers is less than the other.
In a feature of this aspect of the invention, said step of determining whether a sum of the next hop hopcount from a row and a current hopcount of the inbound message exceeds a maximum number of allowable hops for an inbound message is performed before said step of comparing a next hop qualifier of a row to a next hop qualifier of another row, wherein, for both rows, the maximum number of allowable hops for an inbound message is not exceeded.
In a feature of this aspect of the invention, said step of comparing a next hop qualifier of a row to a next hop qualifier of another row, wherein, for both rows, the maximum number of allowable hops for an inbound message is not exceeded is performed before said step of determining whether a sum of the next hop hopcount from a row and a current hopcount of the inbound message exceeds a maximum number of allowable hops for an inbound message.
In a feature of this aspect of the invention, said step of determining whether a sum of the next hop hopcount from a row and a current hopcount of the inbound message exceeds a maximum number of allowable hops for an inbound message and said step of comparing a next hop qualifier of a row to a next hop qualifier of another row, wherein, for both rows, the maximum number of allowable hops for an inbound message is not exceeded are performed a plurality of times corresponding to the number of rows currently in the routing table being maintained.
In a feature of this aspect of the invention, the next hop qualifier is determined, at least in part, based on a general traffic load of the node to which the next hop qualifier pertains.
In a feature of this aspect of the invention, the next hop qualifier is determined, at least in part, based on transmission failure counts of the node to which the next hop qualifier pertains.
In a feature of this aspect of the invention, the next hop qualifier is determined, at least in part, based on signal strength of the node to which the next hop qualifier pertains.
In a feature of this aspect of the invention, the next hop qualifier represents both efficiency and success probability associated with using the node to which the next hop qualifier pertains as the next hop towards the gateway node for communicating the inbound message.
In a feature of this aspect of the invention, the method further includes updating a next hop qualifier pertaining to a node upon a communication with such node.
In a feature of this aspect of the invention, the method further includes updating a next hop qualifier pertaining to a node upon each communication with such node.
In a feature of this aspect of the invention, the method further includes updating a next hop qualifier pertaining to a node upon receiving a communication from such node.
In a feature of this aspect of the invention, the method further includes updating a next hop qualifier pertaining to a node upon receiving an acknowledgment associated with such node.
In a feature of this aspect of the invention, wherein an intermediate node does not maintain a routing table of entire pathways from the originating node to the gateway node.
In a feature of this aspect of the invention, the method further includes transmitting a message for receipt by each hop address in the table when the intermediate node leaves the ad hoc network.
In a feature of this aspect of the invention, the method further includes transmitting a leaving message for receipt by nodes corresponding to each next hop address in the table when the intermediate node leaves the ad hoc network.
In a feature of this aspect of the invention, each intermediate node is a captured node.
In a feature of this aspect of the invention, the intermediate node sends a message to the gateway node for each new node that is added to the routing table, the message identifying the new node.
In a feature of this aspect of the invention, the gateway node maintains pathways among the nodes based on messages received from the nodes.
In a feature of this aspect of the invention, the ad hoc network comprises a class-based network.
In a feature of this aspect of the invention, each set of one or more rows is associated with a class.
In a feature of this aspect of the invention, each row of the routing table is associated with a class.
In a feature of this aspect of the invention, the routing table is a first routing table associated with a first class, and further comprising the step of maintaining a second routing table including a set of one or more rows, wherein each row of the set comprises fields including, a next hop address, representing a unique address of a node, a next hop hopcount, representing a hop count to the gateway, and a next hop qualifier, representing a preference to using a node as a next hop towards a gateway node relative to other nodes that may be used as a next hop towards a gateway node, all fields of the row being pertaining to a known intermediate node for use as a next hop towards the gateway node; wherein the second routing table is associated with a second class.
In a feature of this aspect of the invention, the step of selecting a node for use as the next hop towards the gateway node comprises determining, based on a class of an incoming message, whether to select a node corresponding to a row of the first routing table or the second routing table.
Another aspect of the present invention relates to a computer-readable medium containing computer-executable instructions for performing a method in accordance with one or more aspects of the present invention.
Another aspect of the present invention relates to a communications device serving as the intermediate node performing a method in accordance with one or more aspects of the present invention and including a computer-readable medium in accordance with one or more aspects of the present invention.
Another aspect of the present invention relates to a method performed, in an ad hoc network in which inbound messages are communicated from an originating node to a gateway node via a plurality of intermediate nodes and a root primary node, by each intermediate node in communicating the inbound message to the gateway node via the root primary node. The method includes the steps of maintaining a routing table including a set of one or more rows, wherein each row of the set comprises fields including, a next hop address, representing a unique address of another node, a next hop hopcount, representing the hop count to the gateway from the other node, and a next hop qualifier, representing a preference to using the other node as a next hop towards a gateway node relative to yet other nodes that may be used as a next hop towards a gateway node, all fields of the row being pertaining to a known node for use as a next hop of the inbound message; selecting one of the known nodes for use as the next hop of the inbound message by, determining whether a sum of the next hop hopcount from a row and a current hopcount of the inbound message exceeds a maximum number of allowable hops for an inbound message, and comparing a next hop qualifier of a row to a next hop qualifier of another row both rows for which the maximum number of allowable hops for an inbound message is not exceeded; and communicating the inbound message to the node identified by the next hop address for which the next hop qualifier is determined to be preferred based on said comparison.
In addition to the aforementioned aspects and features of the present invention, it should be noted that the present invention further encompasses the various possible combinations and subcombinations of such aspects and features.
One or more preferred embodiments of the present invention now will be described in detail with reference to the accompanying drawings, wherein the same elements are referred to with the same reference numerals, and wherein,
As a preliminary matter, it will readily be understood by one having ordinary skill in the relevant art (“Ordinary Artisan”) that the present invention has broad utility and application. Furthermore, any embodiment discussed and identified as being “preferred” is considered to be part of a best mode contemplated for carrying out the present invention. Other embodiments also may be discussed for additional illustrative purposes in providing a full and enabling disclosure of the present invention. As should be understood, any embodiment may incorporate only one or a plurality of the above-disclosed aspects of the invention and may further incorporate only one or a plurality of the above-disclosed features. Moreover, many embodiments, such as adaptations, variations, modifications, and equivalent arrangements, will be implicitly disclosed by the embodiments described herein and fall within the scope of the present invention.
Accordingly, while the present invention is described herein in detail in relation to one or more embodiments, it is to be understood that this disclosure is illustrative and exemplary of the present invention, and is made merely for the purposes of providing a full and enabling disclosure of the present invention. The detailed disclosure herein of one or more embodiments is not intended, nor is to be construed, to limit the scope of patent protection afforded the present invention, which scope is to be defined by the claims and the equivalents thereof. It is not intended that the scope of patent protection afforded the present invention be defined by reading into any claim a limitation found herein that does not explicitly appear in the claim itself.
Thus, for example, any sequence(s) and/or temporal order of steps of various processes or methods that are described herein are illustrative and not restrictive. Accordingly, it should be understood that, although steps of various processes or methods may be shown and described as being in a sequence or temporal order, the steps of any such processes or methods are not limited to being carried out in any particular sequence or order, absent an indication otherwise. Indeed, the steps in such processes or methods generally may be carried out in various different sequences and orders while still falling within the scope of the present invention. Accordingly, it is intended that the scope of patent protection afforded the present invention is to be defined by the appended claims rather than the description set forth herein. Additionally, it is important to note that each term used herein refers to that which the Ordinary Artisan would understand such term to mean based on the contextual use of such term herein. To the extent that the meaning of a term used herein—as understood by the Ordinary Artisan based on the contextual use of such term—differs in any way from any particular dictionary definition of such term, it is intended that the meaning of the term as understood by the Ordinary Artisan should prevail.
Regarding applicability of 35 U.S.C. §112, 916, no claim element is intended to be read in accordance with this statutory provision unless the explicit phrase “means for” or “step for” is actually used in such claim element, whereupon this statutory provision is intended to apply in the interpretation of such claim element.
Furthermore, it is important to note that, as used herein, “a” and “an” each generally denotes “at least one”, but does not exclude a plurality unless the contextual use dictates otherwise. Thus, reference to “a picnic basket having an apple” describes “a picnic basket having at least one apple” as well as “a picnic basket having apples”. In contrast, reference to “a picnic basket having a single apple” describes “a picnic basket having only one apple”.
When used herein to join a list of items, “or” denotes “at least one of the items”, but does not exclude a plurality of items of the list. Thus, reference to “a picnic basket having cheese or crackers” describes “a picnic basket having cheese without crackers”, “a picnic basket having crackers without cheese”, and “a picnic basket having both cheese and crackers”. Finally, when used herein to join a list of items, “and” denotes “all of the items of the list”. Thus, reference to “a picnic basket having cheese and crackers” describes “a picnic basket having cheese, wherein the picnic basket further has crackers”, as well as describes “a picnic basket having crackers, wherein the picnic basket further has cheese”.
Referring now to the drawings, one or more preferred embodiments of the present invention are next described. The following description of one or more preferred embodiments is merely exemplary in nature and is in no way intended to limit the invention, its implementations, or uses.
A radio network in accordance with one or more preferred embodiments comprises a gateway server, one or more gateways (or gateway routers), and a plurality of remote sensor nodes (RSNs). Each RSN preferably includes CBN and RCR technology as described hereinbelow. Each gateway is preferably connected to the gateway server, which comprises software and a computing device on which that software runs. A gateway that is connected to a gateway server is characterized as captured, while a gateway that is not connected to a gateway server is characterized as free. Similarly, an RSN that is connected to a radio network is characterized as captured, while an RSN that is not connected to a radio network is characterized as free.
When an RSN is captured by a radio network, the RSN can be characterized as a node of the radio network, and can function as both an end point and a routing device. Further, each gateway includes a gateway RSN, which functions as a communication interface with other RSNs. Thus, in a radio network, each gateway, just like each RSN, can be characterized as a node.
A gateway and gateway server together collectively comprise a gateway controller (GC). Such a gateway controller can switch between functioning solely as a gateway, and functioning as a gateway controller. A gateway and gateway server that are integrated together can be characterized as an integrated gateway controller, while a gateway and gateway server that are physically separate, and preferably connected by a high-capacity, high-reliability data link, can be characterized as a logical gateway controller.
An overview of wake-up and class based networking technology preferably utilized in preferred radio networks will now be provided.
Although transmissions from a wireless node consume battery power, it is a node's receiver that usually limits battery life. Typically, a node's receiver is always on so that transmissions from other nodes can be received at any time. Since this receiver is usually similar in complexity and capability to the transmitter from which data is received, the receiver drains significant current from the node's battery. Even when this receiver is cycled on and off, thus reducing its average current drain, battery life is still limited to days or weeks without re-charging.
Receiver current consumption can be dramatically improved by using a wake-up transceiver to turn on a complex transceiver. This wake-up transceiver technology is patented by TeraHop Networks, Inc. (see U.S. Pat. No. 7,209,771, incorporated above by reference, and the patents related thereto). Using this wake-up technology, a complex transceiver is turned on generally only when needed to transfer data.
A wake-up transceiver achieves low current drain by virtue of its simplicity, thus the term reduced complexity radio. In addition to the exceptionally long battery life (measured in years) that results from the use of wake-up transceivers, the conserved battery and minimal required operating time of a complex transceiver allows a high-power complex transceiver to be utilized for transferring data. Thus, the use of RCRs provides both long battery life and long range.
Class-based networking (CBN) technology is patented by TeraHop Networks, Inc. (see U.S. Pat. No. 6,745,027, incorporated above, and the related patents thereto). In accordance with CBN technology, each node in a class-based network has at least one network class identifier, or more generally, one common designation, assigned to it. Wireless ad hoc hierarchical networks form using transceivers of these nodes. Preferably, the transceiver is a standards-based radio, and the node also includes a second low-power wake-up radio and a controller. The controller operates per class-based networking protocols and per self-configuration protocols that are optimized for class-based networking. This combination enables autonomous reconfiguration and behavioral changes of the node in response to changes in the node's location, the presence of other nodes, changes in a battery level of the node, environmental changes, or other changes.
Conventional wireless ad hoc networks form based on physical proximity and/or based on an effective radio range of nodes of the network. Only those nodes that are in radio range of one another (which typically means that they are physically close to one another) can communicate with each other and form a network.
In contrast, a class-based network forms among those nodes that have at least one network class identifier in common. The nodes still must be within radio range of at least one other node of the same class, but other nodes that may be in close proximity but are not of the same class are ignored (and those other nodes ignore all nodes not in their classes).
The long battery life and long range of RSNs, provided by the use of class-based networking and wake-up transceivers, makes true monitoring and tracking of mobile and/or movable assets practical. This practicality opens up many inventive implementations having benefits the desires for which have long been felt, but the means for which have heretofore been unobtainable.
In a first-responder application, RSNs are worn by firefighters and/or other first responders, and gateway controllers are mounted to trucks and engines. As firefighters get into a truck to respond to a fire, a gateway controller on that truck automatically notes the presence of those on board via their RSNs.
On scene, a gateway controller on an incident commander's vehicle automatically notes the arrival of the truck, and the truck's gateway controller communicates to the incident commander's gateway controller the identities of those present in the truck. The incident commander's gateway controller then communicates this data associated with the arrival to an application on the incident commander's laptop. This information (and information pertaining to other trucks) is displayed on the incident commander's laptop. A cellular link from the incident commander's gateway controller to dispatch conveys GPS data of the incident and the identity of all units present, preferably for graphical display.
As the incident progresses, the incident commander makes assignments using his laptop. Based on these assignments, commands are sent to the RSNs at the scene, such as, for example to change classes and corresponding behavior. These changes could include having an RSN detect the absence of motion, thereby allowing the RSN to function as an alarm indicating that a firefighter is in distress, thus supplementing traditional PASS (personal alert safety system) devices. As trucks and firefighters depart (either at the conclusion of the incident or otherwise), the incident commander's laptop automatically informs the incident commander that these departing trucks and firefighters are no longer present, thus supplementing other accountability measures.
Once firefighters and trucks have arrived back at their stations, gateway controllers located at each station automatically report their return to dispatch and upload incident records to an archive for later analysis.
The long battery life facilitated by wake-up transceivers and class-based networking obviates the need to recharge (and to remember to recharge) an RSN, or even to have to remember to turn it on. The RSN is always on, and can even be worn off-duty. Class designations on RSNs and gateways can also help keep different services (fire, police, EMS) and different jurisdictions from becoming confused.
The RSNs' long range afforded by their high-power data radios and the capabilities of autonomous network configuration facilitate good coverage at the incident scene, as firefighters move around, including in buildings. Further, due to the area-coverage capability of the radio network, the presence of firefighters and their vehicles can be known without the incident commander ever laying eyes on them. Special tag readers and “passports” are similarly not required.
In a shipping container application, an RSN is integrated with a security bolt, which is applied as a security seal through the container door hasp. Gateway controllers are located at origin and destination sites, and at various intermediate locations along a shipping route (e.g., ports, truck stops, weigh stations).
At the shipper's location, sealing of the door is automatically reported to a gateway controller at the shipping dock and, via a user application, associated with a shipment number. After leaving the shipper's location, a lack of presence would automatically be reported.
Arrival of the RSN at a port would automatically be detected and reported by gateways at the port. Even from inside a stack of containers, messages from the RSN could reach a gateway, and vice-versa, due to the high-powered data radios and the hopping that is facilitated by autonomous network configuration, which is enabled by class-based networking. If a container is moved when it should not be (indicating theft), or if a container is jarred enough to damage its contents, the event is reported immediately and automatically. Similarly, an RSN preferably reports dangerous fluctuations in a container's temperature or the presence of dangerous vapors, if connected to appropriate external sensors.
Aboard ship, the presence of the container is known to a gateway controller on the ship, which reports via satellite link. Similarly, sensor inputs are known. The location of the container is also known, from the GPS capability of the shipboard gateway controller.
Once the container reaches its destination, or at any location subsequent to the original sealing, every opening or closing of the seal is recorded. If the opening or closing occurs at a location covered by a radio network, the event is reported immediately. If the opening or closing occurs at a non-covered location, the event is stored and reported immediately upon encountering a radio network.
In such an application, class-based networking provides more than enough battery life to complete multiple door-to-door transoceanic shipments. It also enables different shippers or different shipping companies to share a radio network infrastructure at ports and other shared locations without interfering with each other's traffic, while still allowing for hopping of others' messages when needed.
For example, XYZ Shipping may configure its RSNs to communicate, under normal circumstances, with only other XYZ Shipping RSNs, but to assist hopping for RSNs of other companies when needed. Under those ordinary circumstances, wake-up and data traffic from other companies' RSNs would be ignored by XYZ Shipping's RSNs. However, if ABC Shipping has a container deep in a stack, and its RSN needs a hop-assist to reach a gateway controller, the RSNs of XYZ Shipping could make the assist. Preferably, the ABC Shipping RSN automatically makes a request for an assist after failing to reach a gateway controller using only its own class of RSNs. In this manner, class-based networking facilitates handling thousands of containers at a single location.
The area-coverage capability of the radio network means, for example, that an entire port facility may be covered. Consequently, the presence of an RSN (and thus its associated container) can be known at any time (via a query), and special detection lanes or choke points are not needed.
In a construction equipment application, an RSN is attached to a backhoe, dozer, crane, or other piece of equipment. In this application, gateway controllers are located at equipment rental yards and construction sites. A rental company then uses presence data generated by the RSN network to know in real-time which of multiple yards specific equipment is located to meet customer needs, in real-time. Preferably, improper movement data triggers a theft alarm. Such a theft alarm could be associated with gates and perimeter fencing as well as rental assets.
At a renter's construction site, a gateway receives engine-hours data from RSNs associated with equipment at that site and reports back to the rental company. The rental company uses the data to determine whether the renter is exceeding his contract and/or whether the equipment is being abused. Preferably, for sites that do not have a gateway controller, the rental company uses a truck-mounted gateway controller to periodically visit all such sites to collect data from the RSNs at each such site. The data is collected quickly and automatically, and is immediately uploaded via cellular link to the rental company's headquarters.
A construction company can similarly use the system to keep track of and monitor its own equipment, both in storage yards and on construction sites. For construction sites that have both rental and owned equipment, classes are set such that a rental company can “see” its equipment via the site's gateway, but see nothing of the equipment owned by the construction company.
Although some applications of radio networks utilizing CBN and WU technology have been described, it will be appreciated that many other applications are possible. In general, appropriate applications have high-utility, high-value assets that change operational location, are bigger than a breadbox but smaller than a house, are not powered for long periods or at all, dwell temporarily, and/or that, are remotely located or spend long periods unattended. These assets may be in regular use, stored, and/or pre-positioned/configured for emergency use.
In a radio network, communication from one end point to another end point, such as from an originating RSN to a gateway, or from a gateway to a destination RSN, is hopped along intermediate nodes. Generally, communication between nodes along a path, i.e. communication associated with a node's routing functionality, is provided by the MAC layer or the network layer, while communication between the end points is provided by the application layer.
In a preferred implementation, each RSN is implemented using RCR technology. An RCR of each RSN provides low power consumption, reasonably low network bandwidth utilization, and flexible ad-hoc message routing, but is not intended for large payloads or streaming data. The RCR protocol is broken down into 2 distinct sub-protocols representing two distinct layers, i.e. the MAC layer and the network layer. Further, the network layer is subdivided into a reassembly and fragmentation (FAR) layer, and a data control layer.
All node to node communications are implemented via node transactions at the MAC layer. A node initiates a transaction by transmitting a series of wakeup/attention (WU_ATTN) frames in repeated succession. The number of transmissions in the series is selected to ensure that the receiving device will “see” one of these frames within the total transmission sequence. These WU_ATTN frames differ from normal payload carrying frames. More specifically, they are differentiated by a different TYPE field within a frame control (CTRL) byte.
Each node is associated with a unique identifier (UID). Upon receiving a WU_ATTN frame, a node verifies that the frame contains either its UID, or a general broadcast address, which may comprise, for example, all is. As can be seen in
The node additionally verifies that the WU_ATTN frame includes a proper Area ID. As described more fully hereinbelow, an Area ID corresponds to a particular gateway server. If an Area ID contained in the WU_ATTN frame differs from an Area ID stored at the node upon joining the network as described hereinbelow, then the node will not respond to the WU_ATTN frame.
Similarly, the node verifies that the frame contains an allowable network class identifier. If a network class identifier of the frame does not correspond to a network class identifier stored at the node, the node will not respond to the WU_ATTN frame. This network class identifier may comprise all or part of a Class ID, or may comprise a wholly different network class identifier. A node may contain multiple network class identifiers, for example, a node may be configured to contain up to six network class identifiers.
The node further verifies appropriate sequencing. The CTRL byte includes frame sequence information, as well as including an indication of whether a message is an acknowledgment (ACK) and an indication of whether an acknowledgment is required. A frame sequence of all ones denotes the special WU_ATTN frame.
Further, the receiving node will not respond to any WU_ATTN frame if it is in the free state, unless the WU_ATTN frame is part of the process of becoming joined to, or “captured” by, a network.
Assuming successful reception by a receiving node of a WU_ATTN frame which corresponds to the receiving node's UID and verifies as allowed based on the sequencing, Area ID, and Class ID of the frame, the receiving node will then wait until the transmitting node completes its entire sequence of WU_ATTN frames. This time to wait is calculated using a counter contained in TX count information of the TX CTRL field of the WU_ATTN frame. After waiting for an amount of time calculated based on this counter, the receiving node will acknowledge a successful wakeup to the transmitting node and change its receive channel to the data channel specified in TX data channel information of the TX CTRL field of the WU_ATTN frame. A disallowed transmission may be negatively acknowledged utilizing the same sequence, with a reason code set within an acknowledgment frame. A transmitting node that receives such a negative acknowledgment ceases its attempts to continue the transaction.
After switching to a specified channel for an allowed transaction, a transmitting node transmits a plurality of data packets on the specified channel. This plurality of data packets collectively form a sequenced and potentially fragmented datagram. If all data packets are received at the receiving node and the full datagram is reassembled in its entirety, then the receiving node will acknowledge to the transmitting node that the transaction is complete. If one or more data packets are corrupted or otherwise in error, the receiving node will provide a negative acknowledgment to the transmitting node, and the transmitting node will repeat the transmission up to a maximum of three times.
Notably, the above sequence describes unicast node transactions, i.e. transmissions to a receiving node that specifies the UID of that receiving node. Broadcast transactions, i.e. transmissions that specify a general broadcast address, follow a similar sequence except in that no acknowledgments of any type are provided by a receiving node.
With both broadcast and unicast transactions, a successfully received transaction will be forwarded up to the network layer of the protocol stack for further processing. The network layer resides on top of the MAC layer and includes the FAR layer and the data control layer.
Communication routing within the network is characterized as asymmetrical. This is because routing of data from an RSN inbound to a gateway, i.e. inbound data, is handled differently than routing of data outbound from a gateway to an RSN, i.e. outbound data. Both inbound and outbound routing will now be described.
Inbound data routing utilizes a next hop approach, i.e. each node is unaware of an entire path needed to deliver a datagram to a gateway, and is instead only aware of specific nodes which are potential “next hops”, i.e. potential next destinations for an inbound datagram.
Each captured node of the network contains a next hop table with three entries corresponding to three potential next hop nodes. Each entry includes an address, i.e. the UID of that next hop node, a hop count, representing a number of hops required to reach the gateway node using that next hop node, and a qualifier, as illustrated in
When selecting a next hop node to forward a datagram to, both efficiency, i.e. hop counts of potential next hop nodes, and a probability of success, i.e. the chance that a transmission will fail to reach its destination, are taken into account. Inbound datagrams contain a current hop count which starts at zero and is incremented with each node traversed, i.e. with each hop. A node preferably utilizes this current hop count in conjunction with the hop count corresponding to each potential next hop node in its next hop table to select a next hop node such that the datagram will not exceed a maximum system hop count.
A node acquires its next hops, i.e. populates its next hop table, either when it first joins a network by listening for broadcast traffic, or by requesting that available nodes around it signal their status as potential next hops. A node makes such a request by broadcasting a NEXTHOP_REQUEST datagram. When a node receives such a request, it utilizes a random back-off timer, and then responds in kind to signal that it is a potential next hop. Use of the random back-off timer helps ensure that responses from a plurality of nodes are spread out, rather than being received all at once, thus likely allowing more to propagate through.
A node issues a NEXTHOP_REQUEST when there are no valid next hop entries in its next hop table. A next hop entry corresponding to another node is invalidated when an attempt to communicate with the other node fails, or if the hop count of the entry indicates that routing communications through the other node would cause the soon-to-be-requesting node to have a hop count greater than the maximum system hop count.
A node also issues a NEXTHOP_REQUEST when two next hop entries in its next hop table are invalid or empty, and the qualifier associated with each entry is a high value. In this case, a NEXTHOP_REQUEST is sent to attempt to find new next hop nodes with better qualifiers. Notably, however, such a request is only sent when network traffic is at a minimum and is only sent at a very low rate. An exponential back-off timer is utilized to prevent a node with poor next hop qualifiers from continually and rapidly sending out NEXTHOP_REQUESTs.
A NEXTHOP_REQUEST broadcast by a requesting node includes a hop count of the requesting node. In order to minimize possible path loop issues and maintain network efficiency, any node which receives the NEXTHOP_REQUEST does not respond to the request if its hop count is greater than the hop count of the requesting node. Additionally, upon receiving responses to its NEXTHOP_REQUEST, the requesting node validates the hop count of each responding node against its own perceived hop count. Similarly, no node will respond to a NEXTHOP_REQUEST if its hop count is greater than or equal to the maximum system hop count, and no requesting node will validate a response from a node whose hop count is greater than or equal to the maximum system hop count.
It will frequently be the case that a requesting node does not have any valid entries in its next hop table, and thus essentially has no hop count. A requesting node which does not have any valid entries in its next hop table sets its hop count to negative one (4) to indicate that all nodes receiving its NEXTHOP_REQUEST should respond, and validates a response from any node whose hop count is less than the maximum system hop count.
If a node broadcasts a NEXTHOP_REQUEST and receives no replies, the node retries this request three times, utilizing an exponential back-off timer between each retry. If, following the third retry, the node has still not received a reply and no next hop has been acquired, the node will transition to a free state, i.e. consider itself removed from the network. (It is noteworthy that each of these three retries may be retried utilizing a different network class identifier, which may comprise a different Class ID. Further, each of these retries may be retried utilizing soft-preferential class based networking.)
On the other hand, any node which does acquire a new next hop, either via a NEXTHOP_REQUEST or from listening to network traffic, sends a NEXTHOP_UPDATE datagram containing the current entries in its next hop table to the gateway for forwarding to a gateway server. NEXTHOP_UPDATE is the only network layer datagram which requires a gateway response. After beginning a transaction by sending a NEXTHOP_UPDATE, a node queues the transaction as pending awaiting acknowledgment by the gateway. The node uses its current known hop count to determine a time frame, such as 3 seconds per hop, within which an acknowledgment response should be received. If no acknowledgment is received during this time frame and the current information in its next hop table is still valid, the node retries sending the NEXTHOP_UPDATE. If, during this process, the node determines that information (i.e. one or more entries) in its next hop table is not valid, then it updates this information, possibly using NEXTHOP_REQUEST as described hereinabove. The node continues to retry sending a NEXTHOP_UPDATE datagram until either an acknowledgment is received or the node determines that it is no longer part of the network and is in a free state.
When a node receives an inbound datagram from another node, assuming the node includes one or more valid next hop entries in its next hop table, the node will forward the datagram to a selected most desirable next hop in its next hop table, the selection being guided by various factors as described hereinabove. Before forwarding the datagram, however, the forwarding node inserts its own UID. As a datagram travels along a path and traverses a plurality of nodes, each node insert its own UID, thus generating path information for the path the datagram has taken.
After selection by a forwarding node of a next node to hop to from its next hop table, transmission of the datagram to that next node may fail. In this event, the forwarding node selects a different next node to hop to from its next hop table. If transmission to each potential next hop node in its next hop table fails, the forwarding node broadcasts a NEXTHOP_REQUEST to attempt to obtain valid next hop entries. During this time, the datagram to be routed is kept queued and ready for transmission. Thus, even if a transmission fails, if the forwarding node is able to acquire a valid next hop, then the datagram continues on a path to the destination gateway.
If, on the other hand, the attempt to acquire a valid next hop is unsuccessful, the forwarding node generates a FAILED_ROUTE datagram, which is a copy of the original datagram to be forwarded with its type set to a FAILED_ROUTE enumerator. The forwarding node utilizes the path information within the original datagram to forward the FAILED_ROUTE datagram back to the originating node of the original datagram. This message may or may not propagate back to the originating node. Nodes receiving a FAILED_ROUTE datagram along a path back to the originating node can retry forwarding the message along a different path to the destination gateway by selecting a different next hop node from their next hop table if routing conditions permit, e.g. if the next hop table includes other valid entries. FAILED_ROUTE datagrams utilize outbound routing mechanisms as described hereinbelow.
A FAILED_ROUTE datagram will also be generated if the hop count corresponding to each potential next hop in a next hop table of a forwarding node is such that the maximum system hop count would be exceeded utilizing any of the potential next hops. This case is potentially a common occurrence. To more rapidly propagate hop count changes, all network datagram node to node acknowledgments contain the current hop count of the receiving node.
In contrast to inbound routing, outbound routing preferably utilizes a simple “known route” approach. As described hereinabove, path information is appended to a datagram as it travels inbound towards a gateway. This inbound path information is used to generate an outbound full path and store the UID of each node along this full path within a network header. An outbound datagram can thus be identified by the use of a FULL PATH option within a network header, and a final destination which is not a known gateway. When a node receives an outbound datagram, the node removes its own UID from the full path and then forwards the datagram to the node corresponding to the next UID in the full path. If this forwarding fails, the node retries three times, unless a negative acknowledgment is received that informs the forwarding node that the datagram cannot be received.
If each of these three retries is also unsuccessful, the forwarding node converts the datagram to a broadcast message that is set, with DG_ECHO, to cause nodes receiving the broadcast to repeat the broadcast. If such a broadcast datagram is received by the final destination node, the final destination node updates the path information of the gateway/gateway server. If the datagram is destined for the application layer, then this update can be accomplished via a reply generated by an application at the node. If, however, the datagram is not destined for the application layer, this update can be accomplished via a NEXTHOP_UPDATE.
Network communication is completed at the application layer. Where the MAC and network layers can be characterized as providing node to node communication and path discovery, the application layer can be characterized as providing end to end communication.
With the notable exception of NEXTHOP_UPDATE, network layer communication does not typically include end to end acknowledgment capability. This is essentially because it is not required at a base level. The utilization of FAILED_ROUTE network datagrams provides meaningful levels of reverse communication in the event of a routing breakdown.
However, most application layer communication will desire acknowledgment that communication with a final destination occurred successfully. Therefore the application layer utilizes a protocol of its own which provides end to end acknowledgment capability. As the network layers view data sent from an overlying application as simply raw data, this application protocol is thus fully encapsulated and acted upon by the application alone.
Preferably, an application within an RSN is ultimately be in control of the networking layers, regardless of the fact that these layers can act autonomously in terms of routing network datagrams and seeking out networks and routing paths. Thus, since this application is ultimately responsible for network system activities such as registration and authentication, the application can shut down the network layers in the event that such activities are unsuccessful.
Radio network formation between a captured gateway and an RSN, i.e. a node, is now described with reference to an exemplary radio network.
It is a characteristic of the system that RSNs arrive and depart from coverage areas at any time, in any order, and even randomly change position relatively within a coverage area. A free RSN that becomes aware of a radio network, attempts, if appropriate, to connect wirelessly to that radio network.
In order to make a free RSN aware of a nearby radio network, a process known as beaconing is used. More specifically, a beacon is a radio signal that is periodically broadcast by a node, e.g. a gateway, that contains identification information (as well as a check-in period, as described hereinbelow). The beacon effectively announces the presence of a gateway and identifies it. The identification information includes an address of a node that broadcast the beacon, an Area ID corresponding to a gateway server the node that broadcast the beacon is associated with, and a network class identifier. This network class identifier may comprise all or part of a Class ID (as described hereinbelow), or may comprise a wholly different network class identifier.
When a free RSN receives such a beacon, the network class identifier contained in the beacon is compared to one or more network class identifiers contained in the RSN, at the MAC layer of the RSN. If the network class identifier of the beacon matches any network class identifier contained in the RSN, information contained in the beacon is passed to the network layer of the RSN, which informs the application layer of the RSN of a detected radio network as well as information associated therewith, including the Area ID and node address. The RSN, at the application level, decides whether or not to activate the network layer of the RSN, i.e. attempt to join the radio network and transition the RSN to a captured state. If the RSN decides to join the radio network, the network layer will utilize the node address as a next hop and transmit a communication (which preferably contains a network class identifier of the RSN, and if the RSN contains multiple network class identifiers then preferably includes a primary network class identifier, e.g. a primary Class ID, as described hereinbelow), to the node, for communication to the gateway server corresponding to the Area ID, to attempt to register with the gateway server. Upon attempting to register, the RSN enters a tentative capture state. During this tentative capture state, the tentatively captured RSN can communicate over the radio network, but no other RSN can hop messages through the tentatively captured RSN.
Registration is dependent upon the application layer, as described more fully hereinbelow, and the RSN remains in the tentative capture state until an affirmative acknowledgment of registration is received, at which time the node transitions to being fully captured by the radio network. Each RSN stores the Area ID of the gateway server it is currently associated with. Notably, a negative acknowledgment (NACK) could be received instead, thus indicating that the RSN is not allowed to join the network. Each RSN stores a list of Area IDs that it is not allowed to attach to. If a node receives a negative acknowledgment upon an attempt to join a radio network corresponding to a particular Area ID, it places that Area ID within this list of Area IDs that it is not allowed to attach to. Notably, it is possible for registration to be dependent upon a human decision utilizing a customer application, and it is possible for an RSN to move directly into a full captured state if desired.
Once in a captured state, an RSN ignores messages associated with other gateway servers, i.e. messages including other Area IDs (as described hereinabove and described more fully hereinbelow). After being captured by a radio network, an RSN serves to expand the coverage area of the radio network. This is because RSNs are configured to retransmit, or pass, messages from other RSNs, as described more fully hereinbelow, such that the coverage area of the radio network is greater than just the coverage area of the gateway itself.
Simply expanding the coverage area of the radio network, however, does not necessarily expand the range at which RSNs become aware of the radio network if beacons are only received by RSNs within range of the gateway. Thus, it is advantageous to expand the area in which beacons of a radio network can be “heard”. An expanded area of beaconing increases the probability that RSNs will hear a beacon and join the radio network, as well as the probability that they will do so sooner and farther away than they would otherwise.
In order to effect this expansion of the beaconing area, RSNs connected to a gateway via the radio network are used to “repeat”, i.e. retransmit, the gateway's beacon. In conventional systems, this is sometimes accomplished by requiring every node in a network to broadcast a beacon during a beacon interval, or alternatively by synchronizing the entire network.
In a radio network, however, the following methodology, described in the context of a radio network which includes a captured gateway and a plurality of RSNs, is preferably used.
Beacons are transmitted by the gateway at regular intervals, i.e. a beacon interval “Tb”. When an RSN receives a beacon, the RSN selects a random variable between (Tb−X) and (Tb), where 0<X<Tb. The value of X is selected for each radio network and is tweaked appropriately for the radio network. If a time corresponding to the randomly selected variable passes before another beacon is received, then that RSN broadcasts its own beacon and resets its timer to the maximum value, i.e. Tb, such that it will not broadcast another beacon at least for a period corresponding to this maximum value. However, each RSN keeps track of an amount of time since it has broadcast a beacon of its own, and if this amount of time exceeds a “must beacon” interval, and the RSN still sees beacons of a lesser hop count, then the RSN will broadcast a beacon regardless of whether it has recently received a beacon. This allows distant RSNs to remain a part of a radio network even if statistics have worked out such that the RSN has a significantly reduced beacon rate. If an RSN does not receive a beacon after M*Tb, where M is an integer and M*Tb is greater than the “must beacon” interval, then the RSN decides that it has lost connection with the radio network and takes appropriate action to find it, or else goes free.
As can be seen in the table, at time T=0, the gateway broadcasts a beacon. This beacon is received by RSNs 1 and 2, each of which sets its timer to a random interval between Tb−X (in this example, 2045, i.e. 5 seconds) and Tb (in this example, 20 seconds). Here, RSN 1 sets its timer to expire in 19 seconds, i.e. at time T=19, and RSN 2 sets its timer to expire in 15 seconds, i.e. at time T=15. It will be appreciated that both of these values fall between 15 and 20, as specified. Note that RSNs 3, 4, and 5 do not receive the beacon broadcast by the gateway, and thus do not reset their timers. After broadcasting this beacon, the gateway resets its timer to 20 seconds such that it will broadcast another beacon at time T=20.
At time T=15, RSN 2's timer expires, thus causing RSN 2 to broadcast a beacon. This beacon is received by RSNs 1 and 3. In response, RSNs 1 and 3 each reset their timers to a random period between 15 and 20 seconds. RSN 1 resets its timer t1 to expire in 15 seconds, i.e. at time T=30, and RSN 3 resets its timer to expire in 16 seconds, i.e. at time T=31. RSNs 4 and 5, being out of broadcast range of RSN 2, do not receive the beacon broadcast by RSN 2 and thus do not reset their timers. RSN 2, after broadcasting the beacon, resets its timer to the maximum period, i.e. Tb, or 20, such that its timer will expire at time T=35.
At time T=18, RSN 4's timer expires, thus causing RSN 4 to broadcast a beacon. This beacon is received by RSNs 3 and 5, which, in response, each reset their timer to a random period between 15 and 20 seconds. RSN 3 resets its timer to expire at time T=34, and RSN 5 resets its timer to expire at time T=33. RSNs 1 and 2 are out of broadcast range of RSN 4, and thus do not reset their timers. RSN 4, after broadcasting the beacon, resets its timer to expire at time T=38.
At time T=20, the gateway broadcasts a beacon, which is received by RSNs 1 and 2, causing each of them to reset their timer to a random period between 15 and 20 seconds. RSN 1 resets its timer to expire at time T=37, and RSN 2 resets its timer to expire at time
T=36. RSNs 3, 4, and 5, being out of broadcast range, do not receive the beacon broadcast by the gateway and thus do not reset their timers. After broadcasting this beacon, the gateway resets its timer to expire at time T=40.
At time T=33, RSN 5's timer expires, thus causing RSN 5 to broadcast a beacon. This beacon is received by RSNs 3 and 4, which, in response, each reset their timer to a random period between 15 and 20 seconds. RSN 3 resets its timer to expire at time T=50, and RSN 4 resets its timer to expire at time T=49. RSNs 1 and 2 are out of broadcast range of RSN 5, and thus do not reset their timers. RSN 5, after broadcasting the beacon, resets its timer to expire at time T=53.
At time T=36, RSN 2's timer expires, thus causing RSN 2 to broadcast a beacon. This beacon is received by RSNs 1 and 3, which, in response, each reset their timer to a random period between 15 and 20 seconds. RSN 1 resets its timer to expire at time T=52, and RSN 3 resets its timer to expire at time T=48. Notably, RSN 3 actually resets its timer to expire sooner than it was previously set to expire. RSNs 4 and 5 are out of broadcast range of RSN 2, and thus do not reset their timers. RSN 2, after broadcasting the beacon, resets its timer to expire at time T=56.
It will be appreciated that this method allows for an organized use of a channel when many RSNs are gathered together. Further, it helps to extend the range of a radio network when RSNs are much farther apart, while minimizing the amount of power required to maintain the network. In accordance with the above-described methodology, RSNs will beacon less often on average than under a conventional pattern of beaconing every Tb. Notably, this method can be utilized with non-radio networks as well, and in fact can be utilized with both synchronous and asynchronous networks, although works best with an asynchronous network.
A gateway is responsible for maintaining connectivity with a gateway server in order to remain operational. A free gateway, i.e. one that is not connected to a gateway server, is not operational and will not broadcast a beacon, and will refuse communications of any kind from RSNs. When free, a gateway continuously attempts to connect to its known gateway server.
Notably, multiple gateways can be connected to a single gateway server, and in fact multiple gateways can exist in close physical proximity to each other, all being connected back to a single gateway server. (Moreover, multiple gateways in close physical proximity could also be connected to different gateway servers, in which case each would be associated with a distinct Area ID, and thus belong to a distinct coverage island, as described more fully hereinbelow. In some situations, two such islands could in fact merge together, as described more fully further hereinbelow.)
As described above, each gateway preferably includes a gateway RSN, although does not necessarily have to. Each gateway RSN is functionally equivalent to a standard RSN with a few exceptions. A receiver of each gateway RSN is always active, and therefore a repeated WU_ATTN frame is not required prior to data transmission. This can be changed, however, i.e. nodes can select and indicate whether they maintain a receiver that is always active.
Additionally, gateway RSNs do not perform any application layer protocol parsing. Rather, gateway RSNs pass application layer datagrams, as well as all non-acknowledgment network datagrams to a gateway processing element. It will be understood, as described hereinabove, that the gateway provides auto-acknowledgment capability that a datagram reached the gateway. Notably, this acknowledgment is provided irrespective of the gateway's ability to communicate with a gateway server.
The processing element of a gateway provides a very limited set of processing functions, generally comprising two way protocol conversion between a node network and a gateway server. Inbound datagrams are converted to an XML style format for transmission to the gateway server, and outbound XML formatted datagrams are converted to appropriate node-network level datagrams for communication via the gateway RSN.
When captured, a gateway is preferably in continuous communication with its gateway server, thus ensuring normal node communications. However, a gateway also allows for intermittent communication with a gateway server and does not immediately become free upon losing connectivity with its gateway server. Instead, a timeout period is utilized. During the timeout period, a gateway stores communications received from nodes that are intended for the gateway server. If communication with the gateway server is re-established, the gateway forwards these stored communications on to the gateway server. If, however, communication with the gateway server is not re-established, the gateway transitions to a free state and shuts down network operations. In this even, the gateway broadcasts an application level message across the node network indicating that the gateway is offline. Each node receiving this broadcast enters its own free state, and must then attempt to join a new network. Although some nodes may not receive this broadcast, routing mechanisms described hereinabove will cause all nodes to eventually transition to their free state and attempt to join a new network.
A gateway server's primary role is to provide network resolution, although the gateway server further provides all system application interfaces to external client applications. As noted hereinabove, a gateway server is associated with an Area ID. Preferably, each gateway server is assigned a unique Area ID by the managing entity.
As alluded to hereinabove, a gateway server maintains a database of known network members, e.g. nodes, a status of each, and known outbound path information for each, including the gateway each node is communicating through. This database is maintained in several ways.
First, as described hereinabove, path information of each inbound message, including a UID associated with each node traversed by the inbound message, is appended to that inbound message and is thus available to the gateway server. Additionally, as also described hereinabove, information is provided to the gateway server via NEXTHOP_UPDATE messages.
Utilizing this database, the gateway server is likely able to maintain a variety of possible return paths to each node. Outbound traffic which does not successfully make its way to a destination node can be retried utilizing a different path. Typically, an unsuccessful attempt is retried three times utilizing alternate paths. If each of these retries is unsuccessful, the gateway server can direct the message to be sent as a cascaded broadcast, which is sent to all nodes via all known, connected gateways. It will be appreciated that such a cascaded broadcast is network intensive and is avoided unless it is determined to be essential.
When all retries and communication mechanisms outbound to a node have been tried unsuccessfully, the node, rather than being immediately removed from the gateway server's database, is notated therein as being inactive. If communication is re-established with the node before a system-determined timeout period, which can be specified by a user, then the node is considered active once again. If, on the other hand, the time-out period expires before communication with the node is re-established, the node is removed from the database.
Transmission of an outbound messages to an inactive node is attempted one time, and then the message is either queued or discarded, and an appropriate indication is provided to any connected client application. A message is only queued for delivery to an inactive node if the message is marked as persistent. A mechanism allowing a client application to specify that a message is persistent will be enforced.
It will be appreciated that for some client applications, the regular determination of the presence of a node within a network, such as by use of a check-in message, is desirable in order to allow the client application to monitor and confirm the location of the node. To accomplish this, each node is configured to communicate a check-in message to its gateway at predefined intervals of time. This predefined interval of time, or check-in period, is communicated to each node via beacon, as noted hereinabove. Thus, “presence information” on each node can be gathered. The gateway communicates this presence information to the gateway server, which can then communicate it to one or more client applications.
A client application which keeps track of presence information of a plurality of nodes can be characterized as a presence server. A client application may serve as a presence server for all nodes of a network, or alternatively for a subset thereof. The gateway server also may function as a presence server for one or more of the nodes.
After the message has been communicated to the gateway 241, the gateway 241 returns an acknowledgment (hereinafter, “ACK”) of the check-in message to the initiating node 219. The pathway by which the ACK is communicated is the reverse of the pathway by which the check-in message is communicated, and includes transmission 228 with hops 230, 232, and 234.
In total, communication of a check-in message from node 219 to the gateway 241 requires four total node transmissions (the initial transmission and three hops), and communication of an acknowledgment from the gateway 241 to the node 219 requires three node transmissions (each a hop) with the initial transmission being by the gateway 241.
It will be appreciated from the above description and
The respective number of node transmissions for each of these sets of nodes is set forth in the table of
It will be appreciated that having a large number of nodes with a pathway to the gateway router 241 including a large number of hops greatly increases the total number of node retransmissions required for check-in messages. As can be seen in the table of
This number can be reduced, however, by taking advantage of path information stored in inbound communications. Specifically, each communication of a check-in message preferably includes the UID of each node along the path the check-in message has actually been communicated along, as described hereinabove.
When the gateway 241 receives the check-in message from node 219, the gateway 241 identifies from the pathway the nodes along which the message has hopped, i.e., through intermediate nodes 225, 233, 237. In particular, the gateway 241 analyzes the message to determine the UID of each node along the pathway. Then, rather than only considering the check-in message of node 219, the gateway 241 further utilizes the UIDs of nodes along the path to determine the presence of these additional nodes. The presence information for each of these nodes consequently is updated.
Importantly, and as outlined hereinabove, the ACK that is sent to node 219 is sent along the reverse pathway by which the check-in message was sent to the gateway 241. This insures that each intermediate node receives and retransmits the ACK for delivery to node 219. In doing so, each intermediate node thereby receives its own acknowledgement that its presence, as indicated by the pathway information, has been acknowledged by the gateway 241.
In this respect, each intermediate node 225, 233, 237 remembers that it passed (hopped) an inbound check-in message from the initiating node 219 and, when it passes (hops) the ACK back to the initiating node 219, the intermediate node 225, 233, and 237 uses the ACK as a positive indication that the inbound check-in message was delivered. Based on this, each of the intermediate nodes 225, 233, and 237 causes its check-in timer to be reset to zero as if the respective node had sent a check-in message itself and received back an ACK. As such, none of the intermediate nodes will send its own check-in message until its respective time interval for doing so (starting at the time of retransmitting the ACK for delivery to node 219) has passed.
This methodology is utilized by a node not just when hopping check-in messages, but when hopping any inbound message. Thus, the intermediate nodes 225,233,237 benefit from hopping inbound messages, as each resets its chronometer (clock or timer) for counting down its check-in interval, none need to send a check-in message as quickly as it otherwise would have done if there had been no message hopping. As an example, the outside nodes 211,213,215 may send check-in messages every 15 minutes, with each of all of the other nodes serving as intermediate nodes for the outside nodes 211,213,215, whereby check-in messages for such intermediate nodes would not be required to be sent. In this scenario, only twenty-four retransmissions or hops thus are required, instead of 60 hops as set forth in the table of
Preferably, if a node must leave a network, such as, for example, due to a connection loss or a path loop, the node will broadcast a “leave” message, which alerts other nodes (and/or, in at least some preferred implementations, a gateway), especially those previously utilizing that node in a path, that that node can no longer be used in a path. This minimizes the chances of needing retries for subsequent transmissions, as nodes will not attempt to transmit messages to nodes which have broadcast that they have left the network, and thus reduces power requirements.
It is believed that above described implementations are advantageous in allowing presence information to be obtained not only for sensors and event types, but for people and assets as well, and even for data itself, i.e. information can be provided on whether manifests are present or queued events are present, and on previous locations it has been present (by virtue of state and status information).
Based on the foregoing description, it will be readily understood by those persons skilled in the art that the present invention is susceptible of broad utility and application. Many embodiments and adaptations of the present invention other than those specifically described herein, as well as many variations, modifications, and equivalent arrangements, will be apparent from or reasonably suggested by the present invention and the foregoing descriptions thereof, without departing from the substance or scope of the present invention. Accordingly, while the present invention has been described herein in detail in relation to one or more preferred embodiments, it is to be understood that this disclosure is only illustrative and exemplary of the present invention and is made merely for the purpose of providing a full and enabling disclosure of the invention. The foregoing disclosure is not intended to be construed to limit the present invention or otherwise exclude any such other embodiments, adaptations, variations, modifications or equivalent arrangements, the present invention being limited only by the claims appended hereto and the equivalents thereof.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US3805265||6 Oct 1971||16 Apr 1974||Rcds Enterprises Inc||Radiant wave locating system|
|US4165024||9 Sep 1977||21 Aug 1979||Cato Oil And Grease Co.||Bulk shipping container|
|US4613990||25 Jun 1984||23 Sep 1986||At&T Bell Laboratories||Radiotelephone transmission power control|
|US4680583||1 Feb 1985||14 Jul 1987||Northern Telecom Limited||Terminal address assignment in a broadcast transmission system|
|US4688244||10 Nov 1986||18 Aug 1987||Marwan Hannon||Integrated cargo security system|
|US4750197||2 Jul 1987||7 Jun 1988||Denekamp Mark L||Integrated cargo security system|
|US4817537||16 Mar 1987||4 Apr 1989||Cripe Alan R||Container carrying convertible rail-highway vehicle|
|US5040238||29 Jun 1990||13 Aug 1991||Motorola, Inc.||Trunking system communication resource reuse method|
|US5054052||6 Jul 1989||1 Oct 1991||Mitsubishi Denki Kabushiki Kaisha||Mobile telephone device with low power consumption|
|US5117501||8 Aug 1988||26 May 1992||General Electric Company||Dynamic regrouping in a trunked radio communications system|
|US5129096||4 May 1990||7 Jul 1992||Tunstall Telecom Limited||System which routes radio transmissions to selected repeaters for retransmission|
|US5210540||12 Jun 1992||11 May 1993||Pioneer Electronic Corporation||Global positioning system|
|US5265025||5 Jul 1991||23 Nov 1993||Mitsubishi Denki Kabushiki Kaisha||Navigation system using satellite signals|
|US5295154||3 May 1993||15 Mar 1994||Norand Corporation||Radio frequency local area network|
|US5331637||30 Jul 1993||19 Jul 1994||Bell Communications Research, Inc.||Multicast routing using core based trees|
|US5369784||30 Jul 1992||29 Nov 1994||City Communications Limited||Radio communications system using multiple simultaneously transmitting transceivers|
|US5400254||18 Jun 1993||21 Mar 1995||Sharp Kabushiki Kaisha||Trace display apparatus for a navigation system|
|US5425051||30 Jun 1994||13 Jun 1995||Norand Corporation||Radio frequency communication network having adaptive parameters|
|US5442758||19 Jul 1993||15 Aug 1995||Sequent Computer Systems, Inc.||Apparatus and method for achieving reduced overhead mutual exclusion and maintaining coherency in a multiprocessor system utilizing execution history and thread monitoring|
|US5511232||2 Dec 1994||23 Apr 1996||Motorola, Inc.||Method for providing autonomous radio talk group configuration|
|US5565858||14 Sep 1994||15 Oct 1996||Northrop Grumman Corporation||Electronic inventory system for stacked containers|
|US5579306||1 Sep 1994||26 Nov 1996||Ericsson Inc.||Time and frequency slot allocation system and method|
|US5590409||11 May 1995||31 Dec 1996||Ntt Mobile Communications Network Inc.||Transmission power control method and a transmission power control apparatus|
|US5596652||23 Mar 1995||21 Jan 1997||Portable Data Technologies, Inc.||System and method for accounting for personnel at a site and system and method for providing personnel with information about an emergency site|
|US5604892||19 Dec 1994||18 Feb 1997||Nuttall; David J. H.||Method for modeling a physical system of elements using a relational database|
|US5606313||14 Nov 1995||25 Feb 1997||Motorola, Inc.||Low power addressable data communication device and method|
|US5640151||8 Nov 1993||17 Jun 1997||Texas Instruments Incorporated||Communication system for communicating with tags|
|US5652751||26 Mar 1996||29 Jul 1997||Hazeltine Corporation||Architecture for mobile radio networks with dynamically changing topology using virtual subnets|
|US5682379||23 Dec 1993||28 Oct 1997||Norand Corporation||Wireless personal local area network|
|US5686902||23 Apr 1996||11 Nov 1997||Texas Instruments Incorporated||Communication system for communicating with tags|
|US5732007||1 Jun 1995||24 Mar 1998||Sun Microsystems, Inc.||Computer methods and apparatus for eliminating leading non-significant digits in floating point computations|
|US5761195||30 Aug 1996||2 Jun 1998||Interwave Communications International, Ltd.||Methods and apparatus for connecting calls in a hierarchical cellular network|
|US5790946||19 Apr 1995||4 Aug 1998||Rotzoll; Robert R.||Wake up device for a communications system|
|US5793882||21 Jan 1997||11 Aug 1998||Portable Data Technologies, Inc.||System and method for accounting for personnel at a site and system and method for providing personnel with information about an emergency site|
|US5833910||3 Oct 1995||10 Nov 1998||Mecanismos Auxiliares Industiales S.A.||Mold and method for manufacturing conduit grommet elements|
|US5862803||2 Sep 1994||26 Jan 1999||Besson; Marcus||Wireless medical diagnosis and monitoring equipment|
|US5890054||14 Nov 1996||30 Mar 1999||Telxon Corporation||Emergency mobile routing protocol|
|US5892441||26 Jun 1996||6 Apr 1999||Par Government Systems Corporation||Sensing with active electronic tags|
|US5907491||4 Apr 1997||25 May 1999||Csi Technology, Inc.||Wireless machine monitoring and communication system|
|US5917423||12 Jun 1997||29 Jun 1999||Lojack Corporation||Vehicles tracking transponder system and transponding method|
|US5939982||8 Jun 1998||17 Aug 1999||Auratek Security Inc.||Apparatus for monitoring opening of sealed containers|
|US5943610||4 Apr 1997||24 Aug 1999||Nec Corporation||Transmission power control with dynamic step values|
|US5950124||4 Dec 1995||7 Sep 1999||Telxon Corporation||Cellular communication system with dynamically modified data transmission parameters|
|US5974236||17 Aug 1995||26 Oct 1999||Aes Corporation||Dynamically reconfigurable communications network and method|
|US5977913||5 Feb 1998||2 Nov 1999||Dominion Wireless||Method and apparatus for tracking and locating personnel|
|US6005884||6 Nov 1995||21 Dec 1999||Ems Technologies, Inc.||Distributed architecture for a wireless data communications system|
|US6006100||6 May 1994||21 Dec 1999||Norand Corporation||Multi-level, hierarchical radio-frequency communication system|
|US6072784||25 Jul 1997||6 Jun 2000||At&T Corp.||CDMA mobile station wireless transmission power management with adaptive scheduling priorities based on battery power level|
|US6078789||8 Mar 1999||20 Jun 2000||Bodenmann; Olivier||Wireless peripheral interface|
|US6091724||20 Nov 1997||18 Jul 2000||International Business Machines Corporation||Routing messages within a network using the data content of the message|
|US6097707||19 May 1995||1 Aug 2000||Hodzic; Migdat I.||Adaptive digital wireless communications network apparatus and process|
|US6104512||23 Jan 1998||15 Aug 2000||Motorola, Inc.||Method for adjusting the power level of an infrared signal|
|US6118988||31 Jul 1998||12 Sep 2000||Hyundai Electronics Industries Co., Ltd.||Transmission power control system and method for a mobile station|
|US6125306||13 Nov 1998||26 Sep 2000||Matsushita Electric Industrial Co., Ltd.||System for controlling physical distribution pallets|
|US6127928||26 Jul 1999||3 Oct 2000||E-Tag Systems, Inc.||Method and apparatus for locating and tracking documents and other objects|
|US6127976||2 Sep 1999||3 Oct 2000||Wherenet, Inc.||Distributed network for multi-lateration with circularly polarized antenna for hemispherical coverage|
|US6134587||18 Dec 1997||17 Oct 2000||Nec Corporation||Method of setting up ad hoc local area network, method of communicating using said network, and terminal for use with said network|
|US6134589||6 May 1998||17 Oct 2000||Telefonaktiebolaget Lm Ericsson||Dynamic quality control network routing|
|US6192400||8 Sep 1998||20 Feb 2001||Intermec Ip Corp.||Multilevel data communication system including local and host systems|
|US6198913||24 Aug 1998||6 Mar 2001||Samsung Electronics Co., Ltd.||Automatic wake-up device for radio automatic recognition terminal and communication method using the terminal|
|US6201974||20 Aug 1997||13 Mar 2001||Nokia Mobile Phones Limited||Mobile station and network having hierarchical index for cell broadcast service|
|US6256303||15 Oct 1999||3 Jul 2001||Akoo, Inc.||Wireless broadcast link to remote receiver|
|US6313745||6 Jan 2000||6 Nov 2001||Fujitsu Limited||System and method for fitting room merchandise item recognition using wireless tag|
|US6354493||23 Dec 1999||12 Mar 2002||Sensormatic Electronics Corporation||System and method for finding a specific RFID tagged article located in a plurality of RFID tagged articles|
|US6360169||7 Sep 2000||19 Mar 2002||Umesh Dudabey||System for determining and tracking changes in location|
|US6381467||22 Jun 2000||30 Apr 2002||Motorola, Inc.||Method and apparatus for managing an ad hoc wireless network|
|US6404082||24 Sep 1999||11 Jun 2002||Siemens Westinghouse Power Corporation||Exciter having thermally isolated diode wheel and method of removing diode wheel for same|
|US6405102||11 Aug 2000||11 Jun 2002||Symbol Technologies, Inc.||RF-interrogatable processing system|
|US6409082||22 Jul 1998||25 Jun 2002||Perseu Administration (Proprietary) Limited||Tracking of products|
|US6418299||9 Sep 1998||9 Jul 2002||Bbn Corporation||Self-organizing mobile wireless station network|
|US6424260||9 Oct 2001||23 Jul 2002||Key-Trak, Inc.||Mobile object tracking system|
|US6424264||12 Oct 2000||23 Jul 2002||Safetzone Technologies Corporation||System for real-time location of people in a fixed environment|
|US6427913||9 Sep 1999||6 Aug 2002||Key-Trak, Inc.||Object control and tracking system with zonal transition detection|
|US6437692||12 Nov 1999||20 Aug 2002||Statsignal Systems, Inc.||System and method for monitoring and controlling remote devices|
|US6473607||30 Apr 1999||29 Oct 2002||Broadcom Corporation||Communication device with a self-calibrating sleep timer|
|US6476708||20 Mar 1998||5 Nov 2002||Hid Corporation||Detection of an RFID device by an RF reader unit operating in a reduced power state|
|US6512478||26 Feb 2000||28 Jan 2003||Rockwell Technologies, Llc||Location position system for relay assisted tracking|
|US6529142||24 Jul 2001||4 Mar 2003||Shipong Norman Yeh||Parked vehicle location finder|
|US6542114||24 Apr 2001||1 Apr 2003||Savi Technology, Inc.||Method and apparatus for tracking items using dual frequency tags|
|US6547137||28 Nov 2000||15 Apr 2003||Larry J. Begelfer||System for distribution and control of merchandise|
|US6559620||21 Mar 2001||6 May 2003||Digital Angel Corporation||System and method for remote monitoring utilizing a rechargeable battery|
|US6587755||12 Jul 2000||1 Jul 2003||International Business Machines Corporation||Virtual signs for improving information communicated to the automotive driver|
|US6600418||12 Dec 2000||29 Jul 2003||3M Innovative Properties Company||Object tracking and management system and method using radio-frequency identification tags|
|US6611556||17 May 2000||26 Aug 2003||Steve J. Koerner||Identification system for monitoring the presence/absence of members of a defined set|
|US6614349||2 Oct 2000||2 Sep 2003||Airbiquity Inc.||Facility and method for tracking physical assets|
|US6617962||6 Jan 2000||9 Sep 2003||Samsys Technologies Inc.||System for multi-standard RFID tags|
|US6665585||30 Jan 2001||16 Dec 2003||Ishikarajima-Harima Jukogyo Kabushiki Kaisha||Method and apparatus for container management|
|US6700533||4 May 2000||2 Mar 2004||Rf Technologies, Inc.||Asset and personnel tagging system utilizing GPS|
|US6720888||24 Apr 2001||13 Apr 2004||Savi Technology, Inc.||Method and apparatus for tracking mobile devices using tags|
|US6737974||18 Sep 2001||18 May 2004||Kent H. Dickinson||Shipping container and system along with shipping method employing the same|
|US6744740||21 Dec 2001||1 Jun 2004||Motorola, Inc.||Network protocol for wireless devices utilizing location information|
|US6747562||13 Nov 2001||8 Jun 2004||Safetzone Technologies Corporation||Identification tag for real-time location of people|
|US6753775||27 Aug 2002||22 Jun 2004||Hi-G-Tek Ltd.||Smart container monitoring system|
|US6760578||2 Jul 2001||6 Jul 2004||Micron Technology, Inc.||Wake up device for a communications system|
|US6761312||12 Jun 2002||13 Jul 2004||Salamander Technologies, Inc.||System and method for tracking victims of a mass casualty incident|
|US6765484||24 Apr 2001||20 Jul 2004||Savi Technology, Inc.||Method and apparatus for supplying commands to a tag|
|US6816063||30 Jan 2003||9 Nov 2004||Intermec Ip Corp||Radio frequency identification systems and methods for waking up data storage devices for wireless communication|
|US6847892||29 Oct 2001||25 Jan 2005||Digital Angel Corporation||System for localizing and sensing objects and providing alerts|
|US6919803||9 Jun 2003||19 Jul 2005||Intelligent Technologies International Inc.||Low power remote asset monitoring|
|US6927688||16 May 2003||9 Aug 2005||Caci International Inc.||Method for enabling communication and condition monitoring from inside of a sealed shipping container using impulse radio wireless techniques|
|US6940392||24 Apr 2001||6 Sep 2005||Savi Technology, Inc.||Method and apparatus for varying signals transmitted by a tag|
|US6975614||4 Sep 2002||13 Dec 2005||Harris Corporation||Intelligent communication node object beacon framework in a mobile ad hoc network|
|US7012529||17 Jun 2004||14 Mar 2006||United Security Applications Id, Inc.||Electronic security system for monitoring and recording activity and data relating to cargo|
|US7027773||24 May 2000||11 Apr 2006||Afx Technology Group International, Inc.||On/off keying node-to-node messaging transceiver network with dynamic routing and configuring|
|US7088229||14 Jun 2004||8 Aug 2006||Oracle International Corporation||Methods and systems for verifying the position and status of hierarchically arranged objects|
|US7098784||3 Sep 2004||29 Aug 2006||System Planning Corporation||System and method for providing container security|
|US7103344||1 Nov 2002||5 Sep 2006||Menard Raymond J||Device with passive receiver|
|US7126470||31 Mar 2004||24 Oct 2006||Harris Corporation||Wireless ad-hoc RFID tracking system|
|US7142121||4 Jun 2004||28 Nov 2006||Endicott Interconnect Technologies, Inc.||Radio frequency device for tracking goods|
|US7191934||16 Jul 2004||20 Mar 2007||Salamander Technologies, Inc.||Technique for creating incident-specific credentials at the scene of a large-scale incident or WMD event|
|US7196622||6 May 2004||27 Mar 2007||Savi Technology, Inc.||State monitoring of a container|
|US7212122||29 Dec 2004||1 May 2007||G2 Microsystems Pty. Ltd.||Methods and apparatus of meshing and hierarchy establishment for tracking devices|
|US7230933||17 Apr 2002||12 Jun 2007||Microsoft Corporation||Reducing idle power consumption in a networked battery operated device|
|US7282944||6 Feb 2004||16 Oct 2007||Power Measurement, Ltd.||Body capacitance electric field powered device for high voltage lines|
|US7348875||4 May 2004||25 Mar 2008||Battelle Memorial Institute||Semi-passive radio frequency identification (RFID) tag with active beacon|
|US7349803||15 Apr 2005||25 Mar 2008||Trex Enterprises Corp.||Daytime stellar imager|
|US7349804||31 May 2005||25 Mar 2008||Trex Enterprises Corp.||Daytime stellar imager|
|US7376507||27 May 2004||20 May 2008||Sandia Corporation||Geophysics-based method of locating a stationary earth object|
|US7440781||7 Oct 2005||21 Oct 2008||Symbol Technologies, Inc.||System and method for power conservation in a wireless device|
|US7940716||3 Jul 2006||10 May 2011||Terahop Networks, Inc.||Maintaining information facilitating deterministic network routing|
|US8111651||15 Nov 2008||7 Feb 2012||Terahop Networks, Inc.||Systems, methods and apparatus for facilitating deterministic network routing|
|US8144671||3 Jul 2006||27 Mar 2012||Twitchell Jr Robert W||Communicating via nondeterministic and deterministic network routing|
|US20010000019||29 Nov 2000||15 Mar 2001||Bowers John H.||Inventory system using articles with RFID tags|
|US20010050550||28 Feb 2001||13 Dec 2001||Norio Yoshida||High frequency component, communication apparatus, and method for measuring characteristics of high frequency component|
|US20020039896||3 Oct 2001||4 Apr 2002||Brown Barry Allen Thomas||Method and apparatus for disabling mobile telephones|
|US20020050932||30 Oct 2001||2 May 2002||Ocean Systems Engineering Corporation||Environment and hazard condition monitoring system|
|US20020089434||5 Dec 2001||11 Jul 2002||Ohanes Ghazarian||Electronic vehicle product and personnel monitoring|
|US20020098861||19 Jan 2001||25 Jul 2002||International Business Machines Corporation||Method and system for preventing wireless devices from interfering with other equipment in a sensitive area|
|US20020146985||31 Jan 2001||10 Oct 2002||Axonn Corporation||Battery operated remote transceiver (BORT) system and method|
|US20030008692||3 Jul 2002||9 Jan 2003||Phelan John Roux||Energy conservation in battery powered tag|
|US20030037167 *||25 Sep 2002||20 Feb 2003||Nokia Wireless Routers Inc.||Unified routing scheme for ad-hoc internetworking|
|US20030045295 *||18 May 2001||6 Mar 2003||Peter Stanforth||Prioritized-routing for an Ad-Hoc, peer-to-peer, mobile radio access system|
|US20030083064||30 Oct 2001||1 May 2003||Rotem Cooper||Scheduling acquisition attempts of service providing systems|
|US20030117966||21 Dec 2001||26 Jun 2003||Priscilla Chen||Network protocol for wireless devices utilizing location information|
|US20030141973||6 Jan 2003||31 Jul 2003||Hen-Geul Yeh||Smart object locator|
|US20030144020||26 Jul 2002||31 Jul 2003||Raghu Challa||Intermediate wake mode to track sleep clock frequency in a wireless communication device|
|US20030179073||19 Mar 2003||25 Sep 2003||Ohanes Ghazarian||Electronic secure locking system|
|US20030182077||25 Mar 2003||25 Sep 2003||Emord Nicholas Jon||Seamless sensory system|
|US20030209601||7 Apr 2003||13 Nov 2003||Chung Kevin Kwong-Tai||Article tracking system and method|
|US20030236077||7 Apr 2003||25 Dec 2003||Zarlink Semiconductor Ab||Method of saving power in communication devices|
|US20040021572||5 Aug 2002||5 Feb 2004||Schoen Marc L.||Electronic baggage tracking and identification|
|US20040025018||23 Jan 2003||5 Feb 2004||Haas Zygmunt J.||Secure end-to-end communication in mobile ad hoc networks|
|US20040041731||29 Aug 2002||4 Mar 2004||Omron Corporation||Wireless node that uses a circular polarized antenna and a mechanism for preventing corner reflections of an inside of a metal box space|
|US20040100394||24 Oct 2003||27 May 2004||Hitt Dale K.||Distributed environmental control in a wireless sensor system|
|US20040100415||2 May 2001||27 May 2004||Veitch Jeffrey Douglas||Sample container with radiofrequency identifier tag|
|US20040119588||24 Oct 2003||24 Jun 2004||Marks Roger Julian||Door mountable alarm system|
|US20040121793||30 Apr 2003||24 Jun 2004||Weigele Ingo W.||Methods and apparatus for controlling power to electrical circuitry of a wireless communication device having a subscriber identity module (SIM) interface|
|US20040135691||13 Jan 2003||15 Jul 2004||Mark Duron||Package-integrated RF relay|
|US20040142716||21 Jan 2003||22 Jul 2004||Philip Orlik||System and method for reducing power consumption in a wireless communications network|
|US20040147267||28 Mar 2002||29 Jul 2004||Stephen Hill||Wireless communications network|
|US20040183673||30 Jan 2004||23 Sep 2004||Nageli Hans Peter||Portable detachable self-contained tracking unit for two-way satellite communication with a central server|
|US20040198467||21 Jan 2003||7 Oct 2004||Philip Orlik||System and method for reducing power consumption in a wireless communications network|
|US20040232924||22 Jun 2004||25 Nov 2004||Hilleary Thomas N.||Methods and systems for automated pipeline testing|
|US20040233041||12 Mar 2002||25 Nov 2004||Karl Bohman||Container surveillance system and related method|
|US20040233054||29 Mar 2004||25 Nov 2004||Neff Raymond Lynn||Wireless monitoring device|
|US20040233855 *||19 May 2003||25 Nov 2004||Gutierrez Jose A.||Ad-hoc network and method of routing communications in a communication network|
|US20040246463||29 Jan 2004||9 Dec 2004||Milinusic Tomislav F.||Method and apparatus for optical inertial measurement|
|US20040246903||4 Jun 2003||9 Dec 2004||Jian Huang||Distributed mac protocol facilitating collaborative ranging in communications networks|
|US20050043068||14 Sep 2004||24 Feb 2005||Aki Shohara||Communication device with a self-calibrating sleep timer|
|US20050073406||3 Sep 2004||7 Apr 2005||Easley Linda G.||System and method for providing container security|
|US20050078672||27 Jul 2004||14 Apr 2005||Alaattin Caliskan||Ad Hoc wireless node and network|
|US20050087235||22 Oct 2003||28 Apr 2005||Skorpik James R.||Sensor assembly, system including RFID sensor assemblies, and method|
|US20050088299||22 Jan 2004||28 Apr 2005||Bandy William R.||Radio frequency identification (RFID) based sensor networks|
|US20050090211||28 Oct 2003||28 Apr 2005||Antti Lilja||Method and radio terminal equipment arrangement for power control, radio terminal equipment and secondary terminal unit|
|US20050111428||25 Nov 2003||26 May 2005||Philip Orlik||Power and delay sensitive ad-hoc communication networks|
|US20050128080||23 Feb 2004||16 Jun 2005||Hall Larry L.||Cargo lock and monitoring apparatus and process|
|US20050145018||6 Jan 2005||7 Jul 2005||Ashok Sabata||Remote Monitoring of Pipelines using Wireless Sensor Network|
|US20050146445||31 Dec 2003||7 Jul 2005||Sleboda Pawel W.||Vehicle information display and communication system having an antenna array|
|US20050152318||13 Jan 2004||14 Jul 2005||General Motors Corporation.||Efficient lightweight information dissemination algorithm for mobile wireless Ad Hoc networks|
|US20050190759||5 Oct 2004||1 Sep 2005||Samsung Electronics Co., Ltd.||Method for transmitting a hello packet and a medium access control protocol layer module of a mobile station in a mobile ad hoc network|
|US20050199716||10 Mar 2004||15 Sep 2005||Microsoft Corporation||Method and system for communicating with identification tags|
|US20050226201||3 Jun 2005||13 Oct 2005||Afx Technology Group International, Inc.||Node-to node messaging transceiver network with dynamec routing and configuring|
|US20050261037||18 May 2004||24 Nov 2005||Raghunath Mandayam T||Conservation of battery power in mobile devices having communication capabilities|
|US20050270160||4 Jun 2004||8 Dec 2005||Maines Paper And Food Service, Inc.||Radio frequency device for tracking goods|
|US20060007863||11 Aug 2003||12 Jan 2006||Siamak Naghian||Signal propagation delay routing|
|US20060109106||22 Nov 2004||25 May 2006||Maersk Logistics Usa, Inc.||Shipping container monitoring and tracking system|
|US20060114102||18 Mar 2005||1 Jun 2006||Industrial Technology Research Institute||High performance RFID system and operating method thereof|
|US20060133408||14 Nov 2005||22 Jun 2006||Juan Nogueira-Nine||Beaconless communication system|
|US20060135145||10 Mar 2005||22 Jun 2006||Bbnt Solutions Llc||Methods and apparatus for reduced energy communication in an ad hoc network|
|US20060146717||5 Jan 2005||6 Jul 2006||Intel Corporation||Methods and apparatus for identifying a distance-vector route associated with a wireless mesh network|
|US20060163422||26 Jan 2005||27 Jul 2006||Raytheon Company||Pseudo GPS aided multiple projectile bistatic guidance|
|US20060164232||3 Dec 2005||27 Jul 2006||Visible Assets, Inc.||Auditable security for cargo containers and other repositories|
|US20060164239||14 Jan 2004||27 Jul 2006||Loda David C||Shipping container and method of using same|
|US20060268727||6 May 2005||30 Nov 2006||Anand Rangarajan||Methods and apparatus for providing a dynamic on-demand routing protocol|
|US20060270382||24 May 2006||30 Nov 2006||Antti Lappetelainen||Method and device for transponder aided wake-up of a low power radio device|
|US20060286988||2 Jun 2006||21 Dec 2006||Alcatel||Method for providing data to a mobile terminal which is moving|
|US20070002792||3 Jul 2006||4 Jan 2007||Terahop Networks, Inc.||Communicating via nondeterministic and deterministic network routing|
|US20070002793||3 Jul 2006||4 Jan 2007||Terahop Networks, Inc.||Maintaining information facilitating deterministic network routing|
|US20070008408||22 Jun 2005||11 Jan 2007||Ron Zehavi||Wide area security system and method|
|US20070032951||13 Apr 2006||8 Feb 2007||Jaymart Sensors, Llc||Miniaturized Inertial Measurement Unit and Associated Methods|
|US20070041345||17 Aug 2005||22 Feb 2007||Yarvis Mark D||Methods and apparatus for providing an integrated multi-hop routing and cooperative diversity system|
|US20070115827||17 Dec 2004||24 May 2007||Sony Deutschland Gmbh||Wireless communication network architecture|
|US20070135179||29 Nov 2006||14 Jun 2007||Hardman Gordon E||System for conserving battery life in a battery operated device|
|US20070147255||23 Dec 2005||28 Jun 2007||Ozgur Oyman||Routing in wireless mesh networks|
|US20070155327||1 Jan 2007||5 Jul 2007||Terahop Networks, Inc.||Determining presence of radio frequency communication device|
|US20070189191 *||19 Apr 2007||16 Aug 2007||Stephen Ades||Communications Meshes|
|US20070274232||14 Jun 2004||29 Nov 2007||Telefonaktiebolaget Lm Ericsson (Pub)||Method, Communication Device and System for Detecting Neighboring Nodes in a Wireless Multihop Network Using Ndp|
|US20080186984 *||27 Nov 2007||7 Aug 2008||Fujitsu Limited||Apparatus and method of controlling ad hoc network route|
|US20090092082||15 Nov 2008||9 Apr 2009||Terahop Networks, Inc.||Maintaining information facilitating deterministic network routing|
|US20090154345 *||23 Feb 2009||18 Jun 2009||Nokie Siemens Networks Gmbh & Co Kg||Method and network nodes for reporting at least one dropped-out connection path within a communication network|
|US20100014444 *||12 Oct 2006||21 Jan 2010||Reza Ghanadan||Adaptive message routing for mobile ad hoc networks|
|US20100150026||29 Oct 2009||17 Jun 2010||Robins David S||Updating node presence based on communication pathway|
|EP0467036B1||15 May 1991||7 Feb 1996||Savi Technology, Inc.||Method and apparatus for radio identification and tracking|
|EP0748083B1||29 May 1996||15 Jun 2005||General Electric Company||Use of mutter mode in asset tracking for gathering data from cargo sensors|
|EP0748085B1||29 May 1996||11 Feb 2004||General Electric Company||Local communication network for power reduction and enhanced reliability in a multiple node tracking system|
|EP0829995B1||16 Sep 1997||23 May 2007||Sphere Communications Inc.||Lan telephone system|
|EP0944014B1||11 Mar 1999||28 Dec 2005||HID Corporation||Transponder system and method|
|EP1317733B1||6 Sep 2001||14 Apr 2010||Savi Technology, Inc.||Method and apparatus for tracking devices using tags|
|EP1692599B1||8 Dec 2004||17 Jul 2013||Savi Technology, Inc.||Efficient aggregate summary views of massive numbers of items in highly concurrent update environments|
|EP1692668A2||9 Dec 2004||23 Aug 2006||Savi Technology, Inc.||Item-level visibility of nested and adjacent containers|
|GB2308947A||Title not available|
|KR20070005515A||Title not available|
|1||"Cluster Based Routing Protocol", Internet-Draft, Mingliang, Jiang et al., National University of Singapore, Jul. 1999.|
|2||"Written Opinion of the International Search Authority" in TERAHOP Networks, Inc. et al. International Patent Application Serial No. PCT/US06/26158, dated Nov. 21, 2006, 7 pages.|
|3||Atsushi Iwata et al., Scalable Routing Strategies foe Ad Hoc Wireless Networks, IEEE Journal on Selected Areas in Communications, vol. 17, No. 8, Aug. 1999, pp. 1369-1379.|
|4||Ben Sommer et al., Group 4, Passive RF Tags.|
|5||Charles E. Perkins, AD HOC Networks, Jan. 2001, Table of Contents, Chapters 1,4, and 11.|
|6||Daniel Lihui Gu et al., C-ICAMA, ACentralized Intelligent Channel Assigned Multiple Access for Multi-Layer Ad-Hoc Wireless Networks with UAVs, 2000, 6 pages.|
|7||Daniel Lihui Gu et al., Hierarchical Routing for Multi-Layer Ad-Hoc Wireless Networks with UAVs, 2000, 5 pages.|
|8||Ezio Valdevit, Cascading in Fibre Channel: How to Build a Multi-Switch Fabric, pp. 1-12.|
|9||Gary Morgan, Miniature Tags Provide Visibility & Cohesion for an LIA Battalion Level ‘Proof of Principle’, Pacific NW National Laboratory, Apr. 2001, Gary.firstname.lastname@example.org.|
|10||Gary Morgan, Miniature Tags Provide Visibility & Cohesion for an LIA Battalion Level 'Proof of Principle', Pacific NW National Laboratory, Apr. 2001, Gary.email@example.com.|
|11||Guangyu Pei et al., A Wireless Hierarchical Routing Protocol with Group Mobility, 1998 IEEE, 5 pages.|
|12||Guangyu Pei et al., Mobility Management in Hierarchical Multi-hop Mobile Wireless Networks, 1999, 6 pages.|
|13||http://www.cs.ucla.edu/NRL/wireless/PAPER/draft-ietf-manet-admrp-02.txt, Sung-Ju Lee et al., On-Demand Multicast Routing Protocol (ODMRP) for Ad Hoc Networks, Jan. 2000, visited Nov. 13, 2000.|
|14||http:/www/iprg/nokia.com/charliep/txt/manet/term.txt, Mobile Ad Hoc Networking Terminology, C. Perkins, Nov. 17, 1998, visited Nov. 13, 2000.|
|15||Information Disclosure Statement (IDS) Letter Regarding Common Patent Application(s), dated Nov. 30, 2011.|
|16||Information Disclosure Statement (IDS) Letter Regarding Common Patent Application(s), dated Oct. 6, 2010.|
|17||J.J. Gardia-Luna-Aceves et al., Source-Tree Routing in Wireless Networks, 1999, 10 pages.|
|18||Jaap Haartsen et al., Bluetooth: Vision, Goals, and Architecture, Mobile Computing & Communications Review, vol. 1, No. 2, 1998, 8 pages.|
|19||Jaap Haartsen, Bluetooth-The Universal Radio Interface for Ad Hoc, Wireless Connectivity, Ericsson Review No. 3, pp. 110-117, 1998.|
|20||Jaap Haartsen, Bluetooth—The Universal Radio Interface for Ad Hoc, Wireless Connectivity, Ericsson Review No. 3, pp. 110-117, 1998.|
|21||Jean-Pierre Hubaux et al., Toward Self-Organized Mobile Ad Hoc Networks: The Teminodes Project, IEEE Communications Magazine, Jan. 2001, pp. 118-124.|
|22||Keshavarzian et al., Energy-Efficient Link Assessment in Wireless Sensor Networks, INFOCOM 2004. 23rd Annual Joint Conference of the IEEE Computer and Communications Societies, vol. 3, 2004, pp. 1751-1761.|
|23||Kevin Sharp, Physical Reality: A Second Look, Supply Chain Systems, http://www.idsystems.com/reader/1999-03/phys0399-pt2/index.htm, Helmers Publishing, Inc., Mar. 1999.|
|24||Kevin Sharp, Physical Reality: A Second Look, Supply Chain Systems, http://www.idsystems.com/reader/1999—03/phys0399—pt2/index.htm, Helmers Publishing, Inc., Mar. 1999.|
|25||Melodia et al., On the Interdependence of Distributed Topology Control and Geographical Routing in Ad Hoc and Sensor Networks, Selected Areas in Communications, IEEE Journal, vol. 23, Issue 3, Mar. 2005, pp. 101-106.|
|26||Ram Ramanathan et al., Hierarchically-Organized, Multihop Mobile Wireless Networks for Quality-of-Service Support, 1998, pp. 1-35.|
|27||Stojmenovic et al., Design Guidelines for Routing Protocols in Ad Hoc and Sensor Networks with a Realistic Physical Layer, Communications Magazine, IEEE, vol. 43, Issue 3, Mar. 2005, pp. 101-106.|
|28||U.S. Appl. No. 60/444,029, of Nageli, filed Jan. 31, 2003.|
|29||U.S. Appl. No. 60/499,338, of Easley et al., filed Sep. 3, 2003.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US8717887 *||8 Aug 2011||6 May 2014||Telefonaktiebolaget Lm Ericsson (Publ)||Scrambling code planning device and method for using same in wireless communication network|
|US9571986||7 May 2014||14 Feb 2017||Johnson Controls Technology Company||Systems and methods for detecting and using equipment location in a building management system|
|US20070021981 *||23 Jun 2006||25 Jan 2007||James Cox||System for managing emergency personnel and their information|
|US20130039281 *||8 Aug 2011||14 Feb 2013||Debasish Sarkar||Scrambling code planning device and method for using same in wireless communication network|
|U.S. Classification||370/254, 370/252, 370/229|
|Cooperative Classification||H04L45/124, H04L45/122, H04L45/54, H04W40/32, H04W40/248, H04W40/246, H04L45/20|
|European Classification||H04L45/124, H04L45/54, H04L45/122, H04W40/24D, H04L45/20|
|16 Nov 2011||AS||Assignment|
Owner name: TERAHOP NETWORKS, INC., GEORGIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:PAYNE, EDWARD ALLEN;REEL/FRAME:027239/0374
Effective date: 20100505
Owner name: TERAHOP NETWORKS, INC., GEORGIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KOOP, LAMONTE PETER;ROBINS, DAVID S.;SIGNING DATES FROM 20100505 TO 20100512;REEL/FRAME:027239/0334
|20 Dec 2011||AS||Assignment|
Owner name: KLJ CONSULTING LLC, WASHINGTON
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TERAHOP NETWORKS, INC.;REEL/FRAME:027422/0740
Effective date: 20110916
|24 Apr 2012||AS||Assignment|
Owner name: GOOGLE INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:KLJ CONSULTING LLC;REEL/FRAME:028100/0701
Effective date: 20120323
|2 May 2016||FPAY||Fee payment|
Year of fee payment: 4