WO2002015614A1 - Method, system, and computer program product for positioning and synchronizing wireless communications nodes - Google Patents

Method, system, and computer program product for positioning and synchronizing wireless communications nodes Download PDF

Info

Publication number
WO2002015614A1
WO2002015614A1 PCT/US2001/025381 US0125381W WO0215614A1 WO 2002015614 A1 WO2002015614 A1 WO 2002015614A1 US 0125381 W US0125381 W US 0125381W WO 0215614 A1 WO0215614 A1 WO 0215614A1
Authority
WO
WIPO (PCT)
Prior art keywords
node
measurement
nodes
communications
message
Prior art date
Application number
PCT/US2001/025381
Other languages
French (fr)
Inventor
Ashok Kumar Agrawala
Ronald L. Larsen
A. Udaya Shankar
Douglas C. Szajda
Original Assignee
University Of Maryland, College Park
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by University Of Maryland, College Park filed Critical University Of Maryland, College Park
Priority to AU2001284877A priority Critical patent/AU2001284877A1/en
Priority to US10/344,857 priority patent/US7224984B2/en
Publication of WO2002015614A1 publication Critical patent/WO2002015614A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W64/00Locating users or terminals or network equipment for network management purposes, e.g. mobility management
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0205Details
    • G01S5/0244Accuracy or reliability of position solution or of measurements contributing thereto
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0284Relative positioning
    • G01S5/0289Relative positioning of multiple transceivers, e.g. in ad hoc networks
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S11/00Systems for determining distance or velocity not using reflection or reradiation
    • G01S11/02Systems for determining distance or velocity not using reflection or reradiation using radio waves
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0205Details
    • G01S5/021Calibration, monitoring or correction
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W84/00Network topologies
    • H04W84/18Self-organising networks, e.g. ad-hoc networks or sensor networks
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Definitions

  • the present invention relates generally to asset tracking. More specifically, the present invention pertains to determining the location of objects in a distributed communications network.
  • Table 1 Positioning Technologies
  • GPS global satellite positioning
  • GPS can also provide an absolute timing reference.
  • GPS receivers are not sensors and the accuracy measurements fall within the range of meters.
  • An ultrasonic system provides improved accuracy measurements, but is effective over limited ranges. As the information in Table 1 shows, there is a need for a method and system that overcome the above limitations of conventional positioning technology.
  • the present invention solves the above problems by providing methodologies and techniques for determining the precise location (e.g., within a few centimeters) of a collection of nodes within three-dimensional space.
  • the present invention also determines the clock attributes
  • the present invention can be divided into three distinct phases with each phase having one or more communication cycles. Each cycle communication carries out the exchange of information among the nodes according to the protocol defined in this invention.
  • the three phases include a measurement phase, information exchange phase, and computation phase.
  • the measurement phase consists of one or more measurement cycles. In each cycle, each node transmits a measurement message containing its identifier and a transmit timestamp for the message. Upon receipt of a measurement message from another node, each node also records the receive timestamp of the measurement messages transmitted by other nodes.
  • the information exchange phase consists of one or more information exchange cycles.
  • each node transmits a measurement message containing its receive timestamp for messages transmitted by the other nodes during the measurement phase.
  • each node computes the spatial location and clock attributes of the other nodes relative to itself.
  • the present invention also includes protocols that govern the exchange of measurement messages, the generation of send and receive timestamps, the dissemination of the timestamps to all neighboring nodes, and the calculation of their spatial locations and clock attributes.
  • FIG. 1 illustrates a wireless multinodal communications system according to an embodiment of the present invention.
  • FIG. 2 illustrates a communications node according to an embodiment of the present invention.
  • FIG. 3 illustrates a communication module according to an embodiment of the present invention.
  • FIG. 4 illustrates a clock module according to an embodiment of the present invention.
  • FIG. 5 illustrates a clock module according to another embodiment of the present invention.
  • FIG. 6 illustrates a computation module according to an embodiment of the present invention.
  • FIG. 7 illustrates an operational flow diagram for positioning wireless communications nodes according to an embodiment of the present invention.
  • FIG. 8 illustrates an operational flow diagram for positioning wireless communications nodes according to a second embodiment of the present invention.
  • FIG. 9 illustrates a timing diagram for positioning wireless communications nodes according to an embodiment of the present invention.
  • FIG. 10 illustrates an operational flow diagram for positioning wireless communications nodes according to a third embodiment of the present invention.
  • FIG. 11 illustrates an operational flow diagram for computing the spatial coordinates of wireless communications nodes according to an embodiment of the present invention.
  • FIG. 12 illustrates a coordinate diagram for positioning wireless communications nodes according to an embodiment of the present invention.
  • FIG. 13 illustrates an operational flow diagram for determining clock characteristics of wireless communications nodes according to an embodiment of the present invention.
  • FIG. 14 illustrates a block diagram of an example computer system useful for implementing the present invention.
  • the present invention includes a method, system, and computer program product for enabling a wireless communications node to determine accurately and precisely the spatial locations of neighboring communications nodes distributed in three-dimensional space. Additionally, the present invention includes methodologies and techniques for determining the clock characteristics, including the relative offset and drift of the neighboring nodes. As a result, each node is permitted to execute precise synchronized actions.
  • the present invention has significant implications for a broad range of wireless networking infrastructure and applications.
  • the rapid availability of accurate location information can greatly simplify and optimize the implementation of ad-hoc networks and/or sensor-based applications.
  • One exemplary application domain benefiting from the present invention includes vehicle position sensors (e.g., for "smart" highways or for collision detection in adverse conditions).
  • vehicle position sensors e.g., for "smart" highways or for collision detection in adverse conditions.
  • Another example is a tourist information system in which a tourist is given relevant information for the location of the tourist.
  • the expected level of accuracy of the distance measurement obtained by the present invention in combination with its lightweight distributed clock synchronization algorithm allow the creation of entirely new applications.
  • Such new applications include phase locked arrays, in which several low power transmitters create a powerful group transmission through careful control of the superposition of several low power signals.
  • the present invention is configured to rapidly locate nodes with positional accuracy in the range of a few centimeters, the present invention can be used to track mobile nodes while they are moving. Moreover, the present invention is highly scalable to position and/or synchronize thousands of wireless nodes.
  • FIG. 1 illustrates an embodiment of a wireless multinodal communications system 100 of the present invention.
  • System 100 includes a widely distributed network of wireless communications nodes 102a-102n (collectively referred to herein as "communications nodes 102").
  • communications nodes 102 are positioned in three-dimensional space.
  • the present invention can be implemented in a system having a centralized communications node 102. However, in the preferred embodiment, no centralized node or node with any special privileges is required. Accordingly, the present invention operates in any environment consisting of a collection of communications nodes 102. As such, the positioning and/or synchronization methodologies and techniques of the present invention can be initiated or executed by any one of the communication nodes 102.
  • the initiating or executing node is referred to as the base node.
  • the base node is communications node 102a (referred to herein as "base node 102a").
  • the nodes located within the listening range of base node 102a are referred to as the neighboring nodes.
  • the neighboring nodes in FIG. 1 are denoted as communications nodes 102b-102p.
  • Communications nodes 102q-102r lie outside of the range of base node 102a.
  • FIG. 2 shows the architecture of communications node 102 according to an embodiment of the present invention.
  • Communications node 102 includes a clock module 204, communication module 208, antenna 216, and computation module 210.
  • the components of communications node 102 are connected by a bus 214.
  • Bus 214 is a conventional, bidirectional bus.
  • Clock module 204 includes a time-of-day clock, as described in detail below.
  • Clock module 204 is linked to communication module 208 which receives and transmits signals through antenna 216.
  • communication module 208 consists of several send and receive buffers for storing the signals.
  • Clock module 204 and communication module 208 are linked to permit the receive and/or transmit times of the signals to be timestamped and/or recorded.
  • the transmit time of a signal is the value of the time-of-day clock of the transmitting communications node 102 when a specified bit (e.g., the last bit of the message sync header) is transmitted.
  • the specified bit is referred to herein as the "sync bit" of the signal.
  • Computation module 210 consists of a general-purpose computation and storage engine. Computation module 210 manages clock module 204 and communication module 208, and executes other operations as described in detailed below. Computation module 210 constructs the information (e.g., send messages) residing in the send buffers of communication module 208.
  • Computation module 210 also instructs clock module 204 to send a timing signal to communication module 208 to initiate the sending operations. Computation module 210 also collects the information residing in the receive buffers of communication module 208.
  • Antenna 216 sends and receives signals (including electronic, electromagnetic, optical, or the like).
  • antenna 216 is a UHF antenna operating in half-duplex mode at, for example, 10 Mbs data rate, 2.4 GHz carrier, and turnaround time of a microsecond.
  • the present invention operates in other regions of the frequency spectrum, including without limitation in the radio, microwave, and infrared spectrum, as would be apparent to one skilled in the relevant art(s).
  • FIG. 3 shows the components of communication module 208 according to an embodiment of the present invention.
  • Sync detector 308 receives signals from antenna 216 and forwards the signals to decoder 312. Upon recognizing the synch bit of the received signal, sync detector 308 sends a timestamp trigger pulse to clock module 204 (shown in FIG. 2). Thus, in an embodiment, the timestamp trigger pulse corresponds to the last edge of the last bit of the sync header of the received signal.
  • Decoder 312 decodes the rest of the received signal and stores the signal in received message queue 316. Received message queue 316 is one of two receive buffers located in communication module 208. The second receive buffer is received message bypass 304.
  • Antenna 216 delivers signals destined for received message bypass 304 directly to the buffer.
  • Measurement recorder 320 receives and stores signals from received message queue 316 and received message bypass 304.
  • Communication module 208 also includes a send message encoder 328 and an information exchange encoder 332 that send signals to antenna 216 for broadcast to other communications nodes 102.
  • a control signal i.e., timing signal from clock module 204
  • the contents of send message encoder 328 and information exchange encoder 332 are sent out at the prescribed rate of 10 Mbps using a 2.4 GHz carrier.
  • the components of communication module 208 are interconnected to each other by an internal universal bus 324.
  • An input/output (I/O) arbitrator 336 is also connected to bus 324. I/O arbitrator 336 manages the flow of signals to and from bus 214.
  • FIG. 4 shows the components of clock module 204 according to an embodiment of the present invention.
  • Clock module 204 includes a timestamp generator 404, a clock 408, and a control signal generator 416.
  • Clock 408 is a time-of-day clock of nanosecond resolution. The offset and drift of clock 408 are assumed to be essentially constant over a few seconds. High clock drifts, of the order of 100 parts-per-million (pp ), are acceptable. Thus, the present invention can be implemented with a crystal oscillator clock.
  • Clock 408 provides signals to timestamp generator 404 and control signal generator 416.
  • Timestamp generator 404 provides receive and transmit timestamps to communication module 208 (shown in FIG. 2).
  • Control signal generator 416 provides signals to instruct send message encoder 328 and information exchange encoder 332 (both shown in FIG. 3) to transmit their respective contents.
  • FIG. 5 illustrates an alternative embodiment of clock module 204.
  • timestamp generator 404 includes a time-of-day (TOD) register 504 and a timestamp register 508.
  • control signal generator 416 includes a countdown register 512 and a reset register 516.
  • registers 504, 508, 512 and 516 are 64 bit registers.
  • TOD register 504 captures the time of day from clock 408, and continuously records time since the last initialization of the register. Upon receiving an initialization signal, the value of TOD register 504 is reset to zero.
  • TOD register 504 receives a timestamp trigger pulse from communication module 208 (shown in FIG. 2), as discussed below. Upon receipt of the timestamp trigger pulse, the current time value recorded in TOD register 504 is transfeixed to timestamp register 508. The time value serves as the timestamp for the timestamp trigger pulse. Timestamp register
  • bus 214 to transfer out a timestamp signal representing the time value.
  • Clock 408 also drives countdown register 512.
  • Countdown register 512 receives nanosecond pulses from clock 408 and counts down to generate a timing signal when the count reaches zero. The timing signal is sent to communication module 208 (shown in FIG. 2) to support operations requiring transmit and receive times. After releasing the timing signal, countdown register 512 refreshes its contents with the contents of reset register 516. Accordingly, reset register 516 contains the refresh value for countdown register 512. The refresh value it provided by computation module 210 (shown in FIG. 2).
  • FIG. 6 shows the components of computation module 210 according to an embodiment of the present invention.
  • Computation module 210 includes a coordinate processor 604 and a clock attribute processor 608, both of which are connected to an internal universal bus 620.
  • a memory 612 and 110 arbitrator 616 are also connected to bus 620.
  • I/O arbitrator manages the exchange of signals between computation module 210 and bus 214.
  • flowchart 700 represents the general operational flow of an embodiment of the present invention. More specifically, flowchart 700 shows an example of a control flow for determining the spatial locations of multiple communications nodes 102 described in reference to FIG. 1-6.
  • the control flow of flowchart 700 begins at step 701 and passes immediately to step 704.
  • base node 102a (shown in FIG. 1) initiates the positioning and synchronization process by exchanging measurement messages with neighboring nodes 102b-102p.
  • each communications node 102 asynchronously transmits and/or receives a measurement message with its neighboring nodes.
  • computation module 210 (shown in FIG. 2) constructs two types of send messages that are transmitted from communication module 208.
  • One type of send message is a measurement message.
  • a measurement message contains an identifier for the transmitting communications node 102 and a transmit timestamp.
  • the measurement message also includes a header and trailer for synchronization and frame delimiting.
  • Computation module 210 interacts with clock module 204 and communication module 208 to construct the measurement message. Once generated, the measurement message is stored in send message encoder 328 (shown in FIG. 3).
  • communications node 102 operates in half duplex mode to exchange measurement messages in TDM A slots. As such from the perspective of base node 102a, each neighboring node 102b-102p is assigned a designated time slot for exchanging signals with base node 102a.
  • countdown register 512 (shown in FIG. 5) counts down and sends a timing signal pulse to send message encoder 328 (shown in FIG. 3). The timing signal instructs send message encoder 328 to forward the measurement message stored therein to antenna 216. The timing signal is set to enable antenna 216 to transmit the measurement message in the time slot for the designated neighboring node 102b-102p.
  • Computation module 210 (shown in
  • FIG. 2 provides the refresh values to reset register 516 (shown in FIG. 5) so that it can load countdown register 512 to trigger the next transmission in the designated time slot for the next neighboring node 102b-102p.
  • send message encoder 328 Prior to forwarding the measurement message to antenna 216, send message encoder 328 (shown in FIG. 3) sends a timestamp trigger pulse to
  • send message encoder 328 pulses TOD register 504 when the sync bit (e.g., the last bit of the message sync header) is transmitted to antenna 216.
  • sync bit e.g., the last bit of the message sync header
  • TOD register 504 Upon receipt of the timestamp trigger pulse, TOD register 504 pulses timestamp register 508 to generate and forward a timestamp signal to send message encoder 328 (shown in FIG. 3). Send message encoder 328 postpends the timestamp to the measurement message which is forwarded to antenna 216. Antenna 216 transmits the measurement message to the neighboring node 102b-102p for the designated time slot.
  • antenna 216 When base node 102a is operating in receive mode, antenna 216 (shown in FIG. 2) receives measurement messages transmitted from neighboring nodes 102b-102p from their designated TDMA slot. Referring back to FIG. 7 at step 708, base node 102a timestamps the received measurement messages.
  • Sync detector 308 (shown as FIG. 3) receives the measurement message from antenna 216. As sync detector 308 detects the sync bit, sync detector 308 pulses TOD register 504 (shown in FIG. 5) and, in response, timestamp register 508 returns a timestamp signal indicating the receive timestamp to decoder 312 (shown in FIG. 3).
  • Decoder 312 decodes the rest of the received measurement message which contains the transmitting node 102 identifier and transmit timestamp. Decoder 312 also receives the timestamp signal from timestamp register 508, and postpends the receive timestamp to the measurement message.
  • Measurement recorder 320 produces a table of measurement messages containing the transmitting node 102 identifier, transmit timestamp and receive timestamp.
  • the measurement messages from the neighboring nodes 102b-102p are forwarded from measurement recorder 320 (shown in FIG. 3) to information exchange encoder 332.
  • Computation module 210 (shown in FIG. 2) sends a signal to reset register 516 (FIG. 5) to refresh countdown register 512.
  • countdown register 512 counts down to zero
  • countdown register 512 sends a timing signal to information exchange encoder 332.
  • information exchange encoder 332 interacts with antenna 216 to broadcast the measurement messages to the designated neighboring nodes 102b-102p.
  • the recipient communications nodes 102 receives and processes the measurement messages transmitted in step 712 Referring back to FIG.
  • received message bypass 304 collects the measurement messages from antenna 216 and stores them in measurement recorder 320.
  • Computation module 210 processes the measurement messages to determine the spatial coordinates of the neighboring nodes.
  • each communications node 102 serving as base node 102a, is able to determine the topology of the widely distributed communications nodes 102 within its network.
  • the control flow of flowchart 700 ends as indicated by step 795.
  • the present invention includes methodologies and techniques that govern the exchange of measurement messages, the generation of send and receive timestamps, the dissemination of the timestamps to all neighboring nodes, and the calculation of their spatial locations.
  • the present invention can be divided into three phases with each phase having one or more communication cycles. A cycle is divided into time slots which are allocated among communications nodes 102.
  • the three phases include a measurement phase, information exchange phase and computation phase.
  • the measurement phase (described in reference to steps 704-708 in FIG. 7) consists of one or more measurement cycles. In each cycle, each communications node 102 transmits in a designated time slot a measurement message containing its identifier and the transmit timestamp of the message. The communications node 102 also records the receive timestamp of the measurement messages sent by other communications nodes 102.
  • the information exchange phase (described in reference to step 712 in
  • FIG. 7 consists of one or more information exchange cycles.
  • each communications node 102 transmits a measurement message containing its receive timestamp for messages transmitted by other communications nodes 102 during the measurement phase.
  • each communications node 102 computes the spatial coordinates of the other communications nodes 102.
  • each communication node 102 has, for every ordered pair of nodes, two pairs of transmit and receive timestamps. This information is used to determine the topology. In an embodiment, no communication takes place during this phase.
  • flowchart 800 represents the general operational flow of an embodiment of the present invention having multiple measurement cycles. More specifically, flowchart 800 shows an example of a control flow for determining the spatial locations of multiple communications nodes 102 using multiple measurement cycles.
  • the control flow of flowchart 800 begins at step 801 and passes immediately to step 804.
  • an initialization parameter is set to specify the cycle count as one.
  • the measurement phase is executed as described in reference to FIG. 7.
  • the cycle count is incremented by one count.
  • computation module 210 shown in FIG. 2 compares the cycle count to the maximum count parameter.
  • the maximum count parameter determines the number of measurement cycles for the measurement phase.
  • the maximum count parameter is set to optimize the accuracy of the spatial calculations.
  • the measurement cycle is set for two.
  • FIG. 9 illustrates a timing diagram for transmitting measurement messages over two measurement cycles. Each cycle is divided into 1,024 slots to support asynchronous communications with as many as 1,024 communications nodes 102. Each communications node 102 is allocated a designate slot(s) for transmitting and/or receiving measurement messages.
  • computation module 210 determines that the designated maximum number of cycles has not been reached, the control flow returns to step 804 and another measurement cycle is executed as shown in FIG. 9. If, however, it is determined that the maximum number of cycles has been executed, the control flow passes to step 712. As described above, at step 712, the information exchange phase is executed as shown in FIG. 9. It should be noted that the time slots should be large enough to accommodate the message size and clock drifts.
  • each measurement cycle slot is ten microseconds and each information exchange slot is ten milliseconds.
  • step 716 the computation phase is executed to determine the positions of the communications nodes 102 with respect to each other.
  • the control flow of flowchart 800 ends as indicated by step 895.
  • each communications node 102 should have sufficient information to compute the spatial coordinates of every other communications node 102.
  • Each communications node 102 should also have sufficient information to reduce errors.
  • flowchart 1000 represents the general operational flow of an embodiment of the present invention for mitigating computation errors. More specifically, flowchart 1000 shows another example of a control flow for determining the spatial locations of multiple communications nodes 102.
  • control flow of flowchart 1000 begins at step 1001 and passes immediately to steps 704-708 as described in reference to FIG. 7. At step
  • computation module 210 determines whether sufficient information has been collected to confirm the accuracy of the measurements. If network conditions (e.g., noise, collision, invalid checksum, etc.) adversely affects the quality of communications among communications nodes 102, the entire measurement phase is repeated, or another measurement cycle is executed.
  • network conditions e.g., noise, collision, invalid checksum, etc.
  • computation module 210 starts another measurement cycle until, for example, two successive uncorrupted measurement cycles occur. Computation module 210 could also decide to not execute another measurement cycle if it determines that enough information is available. In an embodiment, computation module 210 determines that it has enough information if there are two successive corrupted cycles that contain enough measurements to compute topology within desired accuracy. In an embodiment, computation module 210 determines that it has enough information if there are two measurement cycles that are not successive but are close enough for the clock constant drift assumption.
  • control flow passes to steps 712-716 to execute the information exchange and computation phases as described in reference to FIG. 7. Afterwards, the control flow of flowchart 1000 ends as indicated by step 1095.
  • the accuracy determinations are also evaluated at the end of the information exchange phase in addition to, or in lieu of, the measurement phase determinations.
  • the information exchange phase whenever computation module 210 detects a corrupted cycle it starts another information exchange cycle until it determines that enough information has been conveyed to compute the topology within desired accuracy.
  • flowchart 1100 represents the general operational flow of an embodiment of the present invention for executing the computation phase. More specifically, flowchart 1100 shows another example of a control flow for determining the spatial locations of multiple communications nodes 102. In particular, flowchart 1100 shows an alternative embodiment of step
  • the control flow of flowchart 1100 begins at step 1101 and passes immediately to steps 704-712 to execute the measurement and information exchange phases as described in reference to FIG. 7.
  • the computation phase is initiated when coordinate processor 604 (shown in FIG. 6) selects the measurement messages stored in measurement recorder 320
  • coordinate processor 604 computes the ratio — , where
  • ⁇ a (also referred to herein as " ⁇ base”) lS tne d ⁇ ft rate for base node 102a and ⁇ b
  • ⁇ n0 nbase (also referred to herein as " ⁇ n0 nbase”)i s the drift rate for neighboring node 102b- 102p.
  • system 100 includes only two communications nodes 102, A and B, both operating in each other's respective listening range.
  • their local clocks 408 which may have some drift and offset, have clock readings, respectively, of:
  • the present invention uses the time equivalent of the internodal distance "d" between the communications nodes 102.
  • the internodal distance d is represented in nanoseconds to indicate the time it will take light to travel that distance. It is presumed that for the environments for which the present invention is implemented, the speed of light does not vary significantly making this measure of distance stable.
  • Time generated from local clock 408 is denoted with the ⁇ notation, while global clock time is denoted with a "t" type notation.
  • the letter contained in the subscript on ⁇ indicates the clock which records the time, so for example z- fll is a time recorded by local clock 408 at communications node A (i.e., base node 102a).
  • communications node A broadcasts a measurement message in the form of a tuple giving its identifier and a transmit timestamp, the latter denoted by ⁇ aX . That is, the timestamp reads:
  • Communications node B receives the tuple and records the time of receipt as ⁇ bi . Denoting the time distance between communications node A and communications node B as d , the global time at which communications node B should receive the broadcast from communications node A is t x + d , so that
  • communications nodes A and B both, send a second measurement cycle, with communications node A sending its second message at time t 3 , and communications node B sending its message at time t 4 .
  • ⁇ a3 ⁇ a ⁇ a a +t 3
  • ⁇ b3 ⁇ b ( b +t 3 +d) ⁇ a ⁇ a ⁇ (X a +t ⁇ d)
  • ⁇ b4 ⁇ b (a b +t 4 )
  • communications node A sends the values ⁇ ⁇ 2 and ⁇ ⁇ 4 to communications node B, and communications node B sends the values ⁇ bl and ⁇ b3 to communications node A.
  • both of communications nodes A and B have all eight values ⁇ a > T a2 ' T a3 ' ⁇ a ⁇ ' T bl > T b2 T b3 » 3I1 " T fi 4 •
  • both communications nodes A and B use these eight values to compute the ratios — from the following equation:
  • coordinate processor 604 computes the quantity ⁇ b d from the equation:
  • Equation 8 every quantity on the right side of Equation 8 is computable by every communications node 102, as long as the communications nodes 102 have the eight quantities on the left sides of the reference equations.
  • Equation 8 is derived by averaging these two quantities A x and ⁇ 2 , or:
  • Equation 11 Substituting Equation 11 into Equation 9 gives:
  • coordinate processor 604 computes the quantity ⁇ a d
  • coordinate processor 604 determines the internodal distance "d" between communications nodes A and B. It is presumed that both ⁇ a and ⁇ b are close to one, so that the quantities ⁇ a d and ⁇ b d are both good estimates of d . Therefore, in an embodiment either quantity ⁇ a d or ⁇ b d is selected by coordinate processor 604 as the distance "d. "
  • the communications node 102 selects the expression having the drift rate for its respective clock 408. For instance, communications node A would select ⁇ a d and communications node B would select ⁇ b d .
  • each communications node A and B computes the average of the quantities ⁇ a d or ⁇ b d .
  • step 604 determines whether the internodal distance to all neighboring nodes 102b- 102p have been computed. If not, steps 1104-1124 are repeated. Otherwise, the control flow passes to step 1132.
  • coordinate processor 604 produces a pointset to determine the topology for communications nodes 102.
  • the present invention is premised on the assumption that base node 102a is positioned at the coordinate point (0,0) in a x-y coordinate system. In other words, all communications nodes 102 believe they are located at the origin of system 100. If there is at least one other communications node 102, the neighboring node 102b-102p with the minimum node identifier (as determined by the node identification number) is considered to be the first reference node, and is positioned on the positive x-axis.
  • the neighboring node 102b-102p with the minimum node identifier among those neighborhood nodes 102b-102p that are neither base node 102a, the first reference node, nor collinear with base 102a and the first reference node is denoted the second reference node and is positioned in the upper half-plane.
  • the placement of the first reference node has the effect of fixing a particular rotational orientation, while the placement of the second reference node locks in a particular reflective orientation.
  • FIG. 12 shows the internodal distances among base node 102a and the first and second reference nodes 102b-102c.
  • coordinate processor 604 computes the lengths of segments BP and R 2 P , which give respectively the x and y coordinates of second reference node 102c, since base node 102a is positioned at point (0,0), first reference node 102b on the positive x-axis, and second reference node 102c in the upper half-plane.
  • Coordinate processor 604 then proceeds to compute the rest of the pointset. For each remaining non-base or reference node 102, coordinate processor 604 determines two candidate positions using distances between the remaining node, base node 102a, and first reference node 102b, as above. Next, coordinate processor 604 uses the distance between the node in question and second reference node 102c in order to choose between the two candidate positions. Thus, once coordinate processor 604 has determined the positions of the two reference nodes, the position of each additional node is determined using only the distances from it to the base and reference nodes. In an embodiment, coordinate processor 604 uses more of the internodal distance information to obtain better estimates on point positions.
  • the present invention After determining the topology, the control flow of flowchart 1100 ends as indicated by step 1195.
  • the present invention also allows each communications node 102 to evaluate overlapping neighborhoods to generate consistent pictures of the network topology. Additionally, the present invention enables each communications node 102 to combine local topology information generated by neighboring nodes to derive a global network topology. Since the present invention does not requires a central authority or node, each communications node 102 is considered to be homogeneous. Each communications node 102 enters and leaves system 100 at any time.
  • the present invention permits groups of cooperating sensor nodes 102 to detect and position certain classes of objects that do not, themselves, contain sensor nodes 102. Among the non-sensor objects that are detectable include vehicles, such as automobiles, aircrafts, submarines, ships, and the like. As such, the present invention offers the added, advantage of collision detection and avoidance even when other vehicles are not equipped with sensor units.
  • flowchart 1300 represents the general operational flow of another embodiment of the present invention. More specifically, flowchart
  • 1300 shows an example of a control flow for determining the clock attributes of multiple communications nodes 102.
  • step 1301 The control flow of flowchart 1300 begins at step 1301 and passes immediately to steps 704-716 to execute the measurement, information exchange, and computation phases. However, the computation phase continues into step 1304.
  • clock attribute processor 608 processes the information computed at step 716, to determine the clock attributes of neighboring nodes 102b-102p. As described in reference to FIG. 11, upon completion of step 1128, coordinate processor 604 will have computed, for each communications
  • clock attribute processor 608 of base node 102a determines the reading of clock 408 on a neighboring node 102 (e.g., communications node B) by computing the value
  • each communications node 102 utilizes the reference equations to determine both a very good estimate for the internodal distance " d ", and the values of the respective clocks 408 of neighboring nodes 102b-102p based on readings of its local clock 408.
  • the clock attributes as describe above, are used by each communications node 102 to synchronize its local clock 408 for subsequent operations. After determining the clock attributes, the control flow of flowchart 1300 ends as indicated by step 1395.
  • base node 102a transmits and receives measurement messages
  • base node 102a is operable to function in passive mode to only receive measurement messages from each neighboring node 102b-102p.
  • the computation phase is adjusted to calculate the position and synchronization data from received tuples accordingly.
  • FIGs. 1-13 are conceptual illustrations that allow an easy explanation of the present invention. That is, the same piece of hardware or module of software can perform one or more of the blocks. It should also be understood that embodiments of the present invention can be implemented in hardware, software, or a combination thereof. In such an embodiment, the various components and steps would be implemented in hardware and/or software to perform the functions of the present invention. Additionally, the present invention (e.g., system 100 and/or any part thereof) can be implemented in one or more computer systems or other processing systems. In fact, in an embodiment, the invention is directed toward one or more computer systems capable of carrying out the functionality described herein.
  • the computer system 1400 includes one or more processors, such as processor 1404.
  • the processor 1404 is connected to a communication infrastructure 1406 (e.g., communications bus, crossover bar, or network).
  • a communication infrastructure 1406 e.g., communications bus, crossover bar, or network.
  • Computer system 1400 can include a display interface 1402 that forwards graphics, text, and other data from the communication infrastructure 1406 (or from a frame buffer not shown) for display on the display unit 1430.
  • Computer system 1400 also includes a main memory 1408, preferably random access memory (RAM), and can also include a secondary memory 1410.
  • the secondary memory 1410 can include, for example, a hard disk drive
  • removable storage drive 1414 representing a floppy disk drive, a magnetic tape drive, an optical disk drive, etc.
  • the removable storage drive 1414 reads from and/or writes to a removable storage unit 1418 in a well- known manner.
  • Removable storage unit 1418 represents a floppy disk, magnetic tape, optical disk, etc. which is read by and written to removable storage drive 1414.
  • the removable storage unit 1418 includes a computer usable storage medium having stored therein computer software and/or data.
  • secondary memory 1410 can include other similar means for allowing computer programs or other instructions to be loaded into computer system 1400.
  • Such means can include, for example, a removable storage unit 1422 and an interface 1420. Examples of such can include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 1422 and interfaces 1420 which allow software and data to be transferred from the removable storage unit 1422 to computer system 1400.
  • Computer system 1400 can also include a communications interface 1424.
  • Communications interface 1424 allows software and data to be transferred between computer system 1400 and external devices. Examples of communications interface 1424 can include a modem, a network interface
  • communications interface 1424 (such as an Ethernet card), a communications port, a PCMCIA slot and card, etc.
  • Software and data transferred via communications interface 1424 are in the form of signals 1428 which can be electronic, electromagnetic, optical or other signals capable of being received by communications interface 1424. These signals 1428 are provided to communications interface 1424 via a communications path (i.e., channel) 1426.
  • This channel 1426 carries signals 1428 and can be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link and other communications channels.
  • computer program medium and “computer usable medium” are used to generally refer to media such as removable storage drive 1414, a hard disk installed in hard disk drive 1412, and signals 1428.
  • These computer program products are means for providing software to computer system 1400.
  • the invention is directed to such computer program products.
  • Computer programs also called computer control logic
  • Computer programs are stored in main memory 1408 and/or secondary memory 1410.
  • Computer programs can also be received via communications interface 1424.
  • Such computer programs when executed, enable the computer system 1400 to perform the features of the present invention as discussed herein.
  • the computer programs when executed, enable the processor 1404 to perform the features of the present invention. Accordingly, such computer programs represent controllers of the computer system 1400.
  • the software can be stored in a computer program product and loaded into computer system 1400 using removable storage drive 1414, hard drive 1412 or communications interface 1424.
  • the control logic when executed by the processor 1404, causes the processor 1404 to perform the functions of the invention as described herein.
  • the invention is implemented primarily in hardware using, for example, hardware components such as application specific integrated circuits (ASICs).
  • ASICs application specific integrated circuits
  • the invention is implemented using a combination of both hardware and software.

Abstract

An asset positioning method and system (700) rapidly and accurately determine the special location of wireless nodes distributed in three-dimensional space. Furthermore, as a by-product, every node also determines the relative offset and drift of every other node's clock, so that it is possible for all nodes to carry out a precise synchronized action (708). The positioning and synchronization protocol has significant implications for a broad range of wireless networking infrastructure and applications. For instance, the rapid availability of accurate location information greatly simplifies and optimises the implementation of ad-hoc networks and sensor-based applications (716). Additionally, the synchronized node operations facilitate the development of new applications, such as phase-locked arrays, in which several low power transmitters coordinate to form a powerful group transmitter. Since the positioning protocol yields rapid responses and positional accuracy in the range of a few centimeters, the positioning protocol permits mobile nodes to be tracked while they are moving.

Description

METHOD, SYSTEM, AND COMPUTER PROGRAM PRODUCT FOR
POSITIONING AND SYNCHRONIZING WIRELESS
COMMUNICATIONS NODES
BACKGROUND OF THE INVENTION
Field of the Invention
The present invention relates generally to asset tracking. More specifically, the present invention pertains to determining the location of objects in a distributed communications network.
Related Art
The development of an efficient lightweight protocol to determine the topology of a wireless network of mobile hosts has proven to be elusive.
Several conventional solutions have been explored, but each has serious limitations. Table 1 below provides a summary of these conventional approaches.
Figure imgf000004_0001
Table 1: Positioning Technologies For example, global satellite positioning (GPS) can be used to determine covert absolute positions. GPS can also provide an absolute timing reference. However, GPS receivers are not sensors and the accuracy measurements fall within the range of meters. An ultrasonic system provides improved accuracy measurements, but is effective over limited ranges. As the information in Table 1 shows, there is a need for a method and system that overcome the above limitations of conventional positioning technology.
SUMMARY OF THE INVENTION
The present invention solves the above problems by providing methodologies and techniques for determining the precise location (e.g., within a few centimeters) of a collection of nodes within three-dimensional space. In addition, the present invention also determines the clock attributes
(including drift and offset) relative to neighboring nodes. The present invention can be divided into three distinct phases with each phase having one or more communication cycles. Each cycle communication carries out the exchange of information among the nodes according to the protocol defined in this invention.
The three phases include a measurement phase, information exchange phase, and computation phase. The measurement phase consists of one or more measurement cycles. In each cycle, each node transmits a measurement message containing its identifier and a transmit timestamp for the message. Upon receipt of a measurement message from another node, each node also records the receive timestamp of the measurement messages transmitted by other nodes.
The information exchange phase consists of one or more information exchange cycles. In each cycle, each node transmits a measurement message containing its receive timestamp for messages transmitted by the other nodes during the measurement phase.
Finally, during the computation phase, each node computes the spatial location and clock attributes of the other nodes relative to itself. The present invention also includes protocols that govern the exchange of measurement messages, the generation of send and receive timestamps, the dissemination of the timestamps to all neighboring nodes, and the calculation of their spatial locations and clock attributes.
BRIEF DESCRIPTION OF THE DRAWINGS FIGURES
The accompanying drawings, which are incorporated herein and form part of the specification, illustrate the present invention and, together with the description, further serve to explain the principles of the invention and to enable a person skilled in the pertinent art to make and use the invention, hi the drawings, like reference numbers indicate identical or functionally similar elements. Additionally, the leftmost digit(s) of a reference number identifies the drawing in which the reference number first appears.
FIG. 1 illustrates a wireless multinodal communications system according to an embodiment of the present invention. FIG. 2 illustrates a communications node according to an embodiment of the present invention.
FIG. 3 illustrates a communication module according to an embodiment of the present invention.
FIG. 4 illustrates a clock module according to an embodiment of the present invention.
FIG. 5 illustrates a clock module according to another embodiment of the present invention.
FIG. 6 illustrates a computation module according to an embodiment of the present invention. FIG. 7 illustrates an operational flow diagram for positioning wireless communications nodes according to an embodiment of the present invention.
FIG. 8 illustrates an operational flow diagram for positioning wireless communications nodes according to a second embodiment of the present invention.
FIG. 9 illustrates a timing diagram for positioning wireless communications nodes according to an embodiment of the present invention.
FIG. 10 illustrates an operational flow diagram for positioning wireless communications nodes according to a third embodiment of the present invention.
FIG. 11 illustrates an operational flow diagram for computing the spatial coordinates of wireless communications nodes according to an embodiment of the present invention.
FIG. 12 illustrates a coordinate diagram for positioning wireless communications nodes according to an embodiment of the present invention.
FIG. 13 illustrates an operational flow diagram for determining clock characteristics of wireless communications nodes according to an embodiment of the present invention.
FIG. 14 illustrates a block diagram of an example computer system useful for implementing the present invention.
DETAILED DESCRIPTION OF THE INVENTION
I. Introduction The present invention includes a method, system, and computer program product for enabling a wireless communications node to determine accurately and precisely the spatial locations of neighboring communications nodes distributed in three-dimensional space. Additionally, the present invention includes methodologies and techniques for determining the clock characteristics, including the relative offset and drift of the neighboring nodes. As a result, each node is permitted to execute precise synchronized actions.
The present invention has significant implications for a broad range of wireless networking infrastructure and applications. The rapid availability of accurate location information can greatly simplify and optimize the implementation of ad-hoc networks and/or sensor-based applications. One exemplary application domain benefiting from the present invention includes vehicle position sensors (e.g., for "smart" highways or for collision detection in adverse conditions). Another example is a tourist information system in which a tourist is given relevant information for the location of the tourist.
In addition, the expected level of accuracy of the distance measurement obtained by the present invention in combination with its lightweight distributed clock synchronization algorithm allow the creation of entirely new applications. Such new applications include phase locked arrays, in which several low power transmitters create a powerful group transmission through careful control of the superposition of several low power signals.
Since the present invention is configured to rapidly locate nodes with positional accuracy in the range of a few centimeters, the present invention can be used to track mobile nodes while they are moving. Moreover, the present invention is highly scalable to position and/or synchronize thousands of wireless nodes.
II. System Overview
FIG. 1 illustrates an embodiment of a wireless multinodal communications system 100 of the present invention. System 100 includes a widely distributed network of wireless communications nodes 102a-102n (collectively referred to herein as "communications nodes 102"). As discussed above, system 100 can be implemented in a variety of mobile and/or non- mobile wireless networks, including sensor-based applications. Additionally, communications nodes 102 are positioned in three-dimensional space. The present invention can be implemented in a system having a centralized communications node 102. However, in the preferred embodiment, no centralized node or node with any special privileges is required. Accordingly, the present invention operates in any environment consisting of a collection of communications nodes 102. As such, the positioning and/or synchronization methodologies and techniques of the present invention can be initiated or executed by any one of the communication nodes 102.
The initiating or executing node is referred to as the base node. Referring to FIG. 1, the base node is communications node 102a (referred to herein as "base node 102a"). The nodes located within the listening range of base node 102a are referred to as the neighboring nodes. The neighboring nodes in FIG. 1 are denoted as communications nodes 102b-102p.
Communications nodes 102q-102r lie outside of the range of base node 102a.
FIG. 2 shows the architecture of communications node 102 according to an embodiment of the present invention. Communications node 102 includes a clock module 204, communication module 208, antenna 216, and computation module 210. The components of communications node 102 are connected by a bus 214. Bus 214 is a conventional, bidirectional bus.
Clock module 204 includes a time-of-day clock, as described in detail below. Clock module 204 is linked to communication module 208 which receives and transmits signals through antenna 216. As discussed below, communication module 208 consists of several send and receive buffers for storing the signals. Clock module 204 and communication module 208 are linked to permit the receive and/or transmit times of the signals to be timestamped and/or recorded. The transmit time of a signal is the value of the time-of-day clock of the transmitting communications node 102 when a specified bit (e.g., the last bit of the message sync header) is transmitted. The specified bit is referred to herein as the "sync bit" of the signal. The receive time of a signal is the value of the time-of-day clock of the receiving communications node 102 at the arrival of the sync bit. Computation module 210 consists of a general-purpose computation and storage engine. Computation module 210 manages clock module 204 and communication module 208, and executes other operations as described in detailed below. Computation module 210 constructs the information (e.g., send messages) residing in the send buffers of communication module 208.
Computation module 210 also instructs clock module 204 to send a timing signal to communication module 208 to initiate the sending operations. Computation module 210 also collects the information residing in the receive buffers of communication module 208. Antenna 216 sends and receives signals (including electronic, electromagnetic, optical, or the like). In an embodiment, antenna 216 is a UHF antenna operating in half-duplex mode at, for example, 10 Mbs data rate, 2.4 GHz carrier, and turnaround time of a microsecond. However, it should be understood that the present invention operates in other regions of the frequency spectrum, including without limitation in the radio, microwave, and infrared spectrum, as would be apparent to one skilled in the relevant art(s).
FIG. 3 shows the components of communication module 208 according to an embodiment of the present invention. Sync detector 308 receives signals from antenna 216 and forwards the signals to decoder 312. Upon recognizing the synch bit of the received signal, sync detector 308 sends a timestamp trigger pulse to clock module 204 (shown in FIG. 2). Thus, in an embodiment, the timestamp trigger pulse corresponds to the last edge of the last bit of the sync header of the received signal. Decoder 312 decodes the rest of the received signal and stores the signal in received message queue 316. Received message queue 316 is one of two receive buffers located in communication module 208. The second receive buffer is received message bypass 304. Antenna 216 delivers signals destined for received message bypass 304 directly to the buffer. Measurement recorder 320 receives and stores signals from received message queue 316 and received message bypass 304. Communication module 208 also includes a send message encoder 328 and an information exchange encoder 332 that send signals to antenna 216 for broadcast to other communications nodes 102. On receiving a control signal (i.e., timing signal from clock module 204), the contents of send message encoder 328 and information exchange encoder 332 are sent out at the prescribed rate of 10 Mbps using a 2.4 GHz carrier.
The components of communication module 208 are interconnected to each other by an internal universal bus 324. An input/output (I/O) arbitrator 336 is also connected to bus 324. I/O arbitrator 336 manages the flow of signals to and from bus 214.
FIG. 4 shows the components of clock module 204 according to an embodiment of the present invention. Clock module 204 includes a timestamp generator 404, a clock 408, and a control signal generator 416. Clock 408 is a time-of-day clock of nanosecond resolution. The offset and drift of clock 408 are assumed to be essentially constant over a few seconds. High clock drifts, of the order of 100 parts-per-million (pp ), are acceptable. Thus, the present invention can be implemented with a crystal oscillator clock.
Clock 408 provides signals to timestamp generator 404 and control signal generator 416. Timestamp generator 404 provides receive and transmit timestamps to communication module 208 (shown in FIG. 2). Control signal generator 416 provides signals to instruct send message encoder 328 and information exchange encoder 332 (both shown in FIG. 3) to transmit their respective contents.
FIG. 5 illustrates an alternative embodiment of clock module 204. In this embodiment, timestamp generator 404 includes a time-of-day (TOD) register 504 and a timestamp register 508. Additionally, control signal generator 416 includes a countdown register 512 and a reset register 516. In an embodiment, registers 504, 508, 512 and 516 are 64 bit registers.
With nanosecond resolution, TOD register 504 captures the time of day from clock 408, and continuously records time since the last initialization of the register. Upon receiving an initialization signal, the value of TOD register 504 is reset to zero. TOD register 504 receives a timestamp trigger pulse from communication module 208 (shown in FIG. 2), as discussed below. Upon receipt of the timestamp trigger pulse, the current time value recorded in TOD register 504 is transfeixed to timestamp register 508. The time value serves as the timestamp for the timestamp trigger pulse. Timestamp register
508 interacts with bus 214 to transfer out a timestamp signal representing the time value.
Clock 408 also drives countdown register 512. Countdown register 512 receives nanosecond pulses from clock 408 and counts down to generate a timing signal when the count reaches zero. The timing signal is sent to communication module 208 (shown in FIG. 2) to support operations requiring transmit and receive times. After releasing the timing signal, countdown register 512 refreshes its contents with the contents of reset register 516. Accordingly, reset register 516 contains the refresh value for countdown register 512. The refresh value it provided by computation module 210 (shown in FIG. 2).
FIG. 6 shows the components of computation module 210 according to an embodiment of the present invention. Computation module 210 includes a coordinate processor 604 and a clock attribute processor 608, both of which are connected to an internal universal bus 620. A memory 612 and 110 arbitrator 616 are also connected to bus 620. I/O arbitrator manages the exchange of signals between computation module 210 and bus 214.
III. Operational Flow for Positioning Communications Nodes The present invention provides a lightweight, inexpensive and scaleable solution for determining the location and clock attributes of a collection of spatially distributed communications nodes 102. Referring to FIG. 7, flowchart 700 represents the general operational flow of an embodiment of the present invention. More specifically, flowchart 700 shows an example of a control flow for determining the spatial locations of multiple communications nodes 102 described in reference to FIG. 1-6. The control flow of flowchart 700 begins at step 701 and passes immediately to step 704. At step 704, base node 102a (shown in FIG. 1) initiates the positioning and synchronization process by exchanging measurement messages with neighboring nodes 102b-102p. In turn, each communications node 102 asynchronously transmits and/or receives a measurement message with its neighboring nodes. As intimated above, computation module 210 (shown in FIG. 2) constructs two types of send messages that are transmitted from communication module 208. One type of send message is a measurement message. A measurement message contains an identifier for the transmitting communications node 102 and a transmit timestamp. The measurement message also includes a header and trailer for synchronization and frame delimiting. Computation module 210 interacts with clock module 204 and communication module 208 to construct the measurement message. Once generated, the measurement message is stored in send message encoder 328 (shown in FIG. 3).
In an embodiment, communications node 102 operates in half duplex mode to exchange measurement messages in TDM A slots. As such from the perspective of base node 102a, each neighboring node 102b-102p is assigned a designated time slot for exchanging signals with base node 102a. In send mode, countdown register 512 (shown in FIG. 5) counts down and sends a timing signal pulse to send message encoder 328 (shown in FIG. 3). The timing signal instructs send message encoder 328 to forward the measurement message stored therein to antenna 216. The timing signal is set to enable antenna 216 to transmit the measurement message in the time slot for the designated neighboring node 102b-102p. Computation module 210 (shown in
FIG. 2) provides the refresh values to reset register 516 (shown in FIG. 5) so that it can load countdown register 512 to trigger the next transmission in the designated time slot for the next neighboring node 102b-102p.
Prior to forwarding the measurement message to antenna 216, send message encoder 328 (shown in FIG. 3) sends a timestamp trigger pulse to
TOD register 504 (shown in FIG. 5). In an embodiment, send message encoder 328 pulses TOD register 504 when the sync bit (e.g., the last bit of the message sync header) is transmitted to antenna 216.
Upon receipt of the timestamp trigger pulse, TOD register 504 pulses timestamp register 508 to generate and forward a timestamp signal to send message encoder 328 (shown in FIG. 3). Send message encoder 328 postpends the timestamp to the measurement message which is forwarded to antenna 216. Antenna 216 transmits the measurement message to the neighboring node 102b-102p for the designated time slot.
When base node 102a is operating in receive mode, antenna 216 (shown in FIG. 2) receives measurement messages transmitted from neighboring nodes 102b-102p from their designated TDMA slot. Referring back to FIG. 7 at step 708, base node 102a timestamps the received measurement messages. Sync detector 308 (shown as FIG. 3) receives the measurement message from antenna 216. As sync detector 308 detects the sync bit, sync detector 308 pulses TOD register 504 (shown in FIG. 5) and, in response, timestamp register 508 returns a timestamp signal indicating the receive timestamp to decoder 312 (shown in FIG. 3). Decoder 312 decodes the rest of the received measurement message which contains the transmitting node 102 identifier and transmit timestamp. Decoder 312 also receives the timestamp signal from timestamp register 508, and postpends the receive timestamp to the measurement message.
Afterwards, the measurement message is stored in measurement recorder 320. All measurement messages received from the neighboring nodes 102b-102p are stored in measurement recorder 320. Measurement recorder 320 produces a table of measurement messages containing the transmitting node 102 identifier, transmit timestamp and receive timestamp.
Referring again to FIG. 7 at step 712, the measurement messages from the neighboring nodes 102b-102p are forwarded from measurement recorder 320 (shown in FIG. 3) to information exchange encoder 332. Computation module 210 (shown in FIG. 2) sends a signal to reset register 516 (FIG. 5) to refresh countdown register 512. When countdown register 512 counts down to zero, countdown register 512 sends a timing signal to information exchange encoder 332. Upon receipt of the timing signal, information exchange encoder 332 interacts with antenna 216 to broadcast the measurement messages to the designated neighboring nodes 102b-102p. At step 716 in FIG. 7, the recipient communications nodes 102 receives and processes the measurement messages transmitted in step 712 Referring back to FIG. 3, received message bypass 304 collects the measurement messages from antenna 216 and stores them in measurement recorder 320. Computation module 210 processes the measurement messages to determine the spatial coordinates of the neighboring nodes. As a result, each communications node 102, serving as base node 102a, is able to determine the topology of the widely distributed communications nodes 102 within its network. After the topology has been determined, the control flow of flowchart 700 ends as indicated by step 795. Hence, the present invention includes methodologies and techniques that govern the exchange of measurement messages, the generation of send and receive timestamps, the dissemination of the timestamps to all neighboring nodes, and the calculation of their spatial locations. The present invention can be divided into three phases with each phase having one or more communication cycles. A cycle is divided into time slots which are allocated among communications nodes 102.
The three phases include a measurement phase, information exchange phase and computation phase. The measurement phase (described in reference to steps 704-708 in FIG. 7) consists of one or more measurement cycles. In each cycle, each communications node 102 transmits in a designated time slot a measurement message containing its identifier and the transmit timestamp of the message. The communications node 102 also records the receive timestamp of the measurement messages sent by other communications nodes 102. The information exchange phase (described in reference to step 712 in
FIG. 7) consists of one or more information exchange cycles. In each cycle, each communications node 102 transmits a measurement message containing its receive timestamp for messages transmitted by other communications nodes 102 during the measurement phase.
Finally, during the computation phase (described in reference to step 716 in FIG. 7), each communications node 102 computes the spatial coordinates of the other communications nodes 102. After the information exchange phase, each communication node 102 has, for every ordered pair of nodes, two pairs of transmit and receive timestamps. This information is used to determine the topology. In an embodiment, no communication takes place during this phase.
As described, the measurement phase consists of multiple cycles in an embodiment. Referring to FIG. 8, flowchart 800 represents the general operational flow of an embodiment of the present invention having multiple measurement cycles. More specifically, flowchart 800 shows an example of a control flow for determining the spatial locations of multiple communications nodes 102 using multiple measurement cycles.
The control flow of flowchart 800 begins at step 801 and passes immediately to step 804. At step 804, an initialization parameter is set to specify the cycle count as one. At steps 704-708, the measurement phase is executed as described in reference to FIG. 7. At step 808, the cycle count is incremented by one count. At step 812, computation module 210 (shown in FIG. 2) compares the cycle count to the maximum count parameter. The maximum count parameter determines the number of measurement cycles for the measurement phase. The maximum count parameter is set to optimize the accuracy of the spatial calculations.
In an embodiment, the measurement cycle is set for two. FIG. 9 illustrates a timing diagram for transmitting measurement messages over two measurement cycles. Each cycle is divided into 1,024 slots to support asynchronous communications with as many as 1,024 communications nodes 102. Each communications node 102 is allocated a designate slot(s) for transmitting and/or receiving measurement messages. Referring back to FIG. 8, if at step 812 computation module 210 determines that the designated maximum number of cycles has not been reached, the control flow returns to step 804 and another measurement cycle is executed as shown in FIG. 9. If, however, it is determined that the maximum number of cycles has been executed, the control flow passes to step 712. As described above, at step 712, the information exchange phase is executed as shown in FIG. 9. It should be noted that the time slots should be large enough to accommodate the message size and clock drifts. In an embodiment, each measurement cycle slot is ten microseconds and each information exchange slot is ten milliseconds.
Referring again to FIG. 8, at step 716, the computation phase is executed to determine the positions of the communications nodes 102 with respect to each other. After the topology has been determined, the control flow of flowchart 800 ends as indicated by step 895. As discussed, upon completion of the information exchange phase, each communications node 102 should have sufficient information to compute the spatial coordinates of every other communications node 102. Each communications node 102 should also have sufficient information to reduce errors. Referring to FIG. 10, flowchart 1000 represents the general operational flow of an embodiment of the present invention for mitigating computation errors. More specifically, flowchart 1000 shows another example of a control flow for determining the spatial locations of multiple communications nodes 102.
The control flow of flowchart 1000 begins at step 1001 and passes immediately to steps 704-708 as described in reference to FIG. 7. At step
1004, computation module 210 determines whether sufficient information has been collected to confirm the accuracy of the measurements. If network conditions (e.g., noise, collision, invalid checksum, etc.) adversely affects the quality of communications among communications nodes 102, the entire measurement phase is repeated, or another measurement cycle is executed.
Specifically, during the measurement phase, whenever computation module 210 detects a corrupted cycle, computation module 210 starts another measurement cycle until, for example, two successive uncorrupted measurement cycles occur. Computation module 210 could also decide to not execute another measurement cycle if it determines that enough information is available. In an embodiment, computation module 210 determines that it has enough information if there are two successive corrupted cycles that contain enough measurements to compute topology within desired accuracy. In an embodiment, computation module 210 determines that it has enough information if there are two measurement cycles that are not successive but are close enough for the clock constant drift assumption.
If computation module 210 determines the measurements provide acceptable levels of confidence, the control flow passes to steps 712-716 to execute the information exchange and computation phases as described in reference to FIG. 7. Afterwards, the control flow of flowchart 1000 ends as indicated by step 1095.
In an embodiment, the accuracy determinations are also evaluated at the end of the information exchange phase in addition to, or in lieu of, the measurement phase determinations. As such, in the information exchange phase, whenever computation module 210 detects a corrupted cycle it starts another information exchange cycle until it determines that enough information has been conveyed to compute the topology within desired accuracy.
The present invention can be used to rapidly compute the precise location of communications nodes 102 within the listening range of base node 102b. Referring to FIG. 11, flowchart 1100 represents the general operational flow of an embodiment of the present invention for executing the computation phase. More specifically, flowchart 1100 shows another example of a control flow for determining the spatial locations of multiple communications nodes 102. In particular, flowchart 1100 shows an alternative embodiment of step The control flow of flowchart 1100 begins at step 1101 and passes immediately to steps 704-712 to execute the measurement and information exchange phases as described in reference to FIG. 7. At step 1104, the computation phase is initiated when coordinate processor 604 (shown in FIG. 6) selects the measurement messages stored in measurement recorder 320
(shown in FIG. 3) from neighboring nodes 102b- 102b.
At step 1108, coordinate processor 604 computes the ratio — , where
βa (also referred to herein as "βbase")lS tne dήft rate for base node 102a and βb
(also referred to herein as "βn0nbase")is the drift rate for neighboring node 102b- 102p.
For example, assume that system 100 includes only two communications nodes 102, A and B, both operating in each other's respective listening range. For global time t, their local clocks 408, which may have some drift and offset, have clock readings, respectively, of:
Equation 1 ** (*) = & («* +')
The present invention uses the time equivalent of the internodal distance "d" between the communications nodes 102. In other words, the internodal distance d is represented in nanoseconds to indicate the time it will take light to travel that distance. It is presumed that for the environments for which the present invention is implemented, the speed of light does not vary significantly making this measure of distance stable.
Time generated from local clock 408 is denoted with the τ notation, while global clock time is denoted with a "t" type notation. Also, when discussing local clock times, the letter contained in the subscript on τ indicates the clock which records the time, so for example z-fll is a time recorded by local clock 408 at communications node A (i.e., base node 102a). Accordingly, at time t\, communications node A broadcasts a measurement message in the form of a tuple giving its identifier and a transmit timestamp, the latter denoted by τaX . That is, the timestamp reads:
τΛ s τa (f, ) = βa (aa + tx ) Equation 2
and the tuple broadcast is (A,τaX) . Communications node B receives the tuple and records the time of receipt as τbi . Denoting the time distance between communications node A and communications node B as d , the global time at which communications node B should receive the broadcast from communications node A is tx + d , so that
τ b\ = b { b +tχd) Equation 3 Since each node is running the same decentralized protocol, communication node B also sends a two-tuple at global time t2 . In steps similar to above, communications node B broadcasts the tuple (B,τb2) , where
τbi = τ {f2 ) = β (ab + 12 ) Equation 4 and communications node A receives this broadcast at global time t2 + d . which communications node A marks as time
τa2 = τa (t2 + d) = βa (aa +t2 +d) Equation 5
In an embodiment, once the first cycle of messages has been completed, communications nodes A and B, both, send a second measurement cycle, with communications node A sending its second message at time t3 , and communications node B sending its message at time t4. Using notation similar to above, the timestamps generated by communications nodes A and B is represented by:
Figure imgf000020_0001
Figure imgf000021_0001
τ a4a( a+t4+d),md τb,=βb{ab+t4).
Upon completion of the measurement phase, all eight of the measurement messages timestamps can be expressed as:
X = βa{aa+tι) τblb( b+t1+d)
Figure imgf000021_0002
^a3a{aa+t3) τb3b( b+t3+d) τaχβa{(Xa+tχd) τb4b(ab+t4)
The above eight expressions are referred to herein as "reference equations." During the information exchange phase, communications node A sends the values τα2and τα4to communications node B, and communications node B sends the values τbl and τb3 to communications node A. At this point, both of communications nodes A and B have all eight values τa > Ta2 ' Ta3 ' τ a\ ' Tbl > Tb2 Tb3 » 3I1" Tfi4
Accordingly at step 1104, both communications nodes A and B use these eight values to compute the ratios — from the following equation:
Equation6
Figure imgf000021_0003
Next at step 1112, coordinate processor 604 computes the quantities Δ, and Δ2 from: Δ, s τbx - τΛb( b+tl+d)-βa ( a + tx ) Equation 6
and
Δ2 s „2 - τi
Figure imgf000021_0004
+ d)-βb { b + f2 ) Equation 7 At step 1116, coordinate processor 604 computes the quantity βbd from the equation:
-X) Equation 8
Figure imgf000022_0001
As can be noted, every quantity on the right side of Equation 8 is computable by every communications node 102, as long as the communications nodes 102 have the eight quantities on the left sides of the reference equations.
Equation 8 is derived by averaging these two quantities Ax and Δ2 , or:
^ ^[Ah+^ή-A(α.+ +A(β.^2+(/)-AK+ϋ]
= βad + ∑±L(βab) Equation 9
The first and second lines of the reference equations provide: r„2 - X = βa {t2 -tx) + βad Equation 10
or equivalently:
-h τa2 τa -d Equation 11
Figure imgf000022_0002
Substituting Equation 11 into Equation 9 gives:
Ax +A2 _ βab d ] βab τa2 τa\ d 2 2 2 βa
Figure imgf000022_0003
or equivalently the expression shown in Equation 8.
At step 1120, coordinate processor 604 computes the quantity βad
which is determined from βbd . Note that βad =—βbd , and communications βb nodes 102 know both right hand side quantities. At step 1124, coordinate processor 604 determines the internodal distance "d" between communications nodes A and B. It is presumed that both βa and βb are close to one, so that the quantities βad and βbd are both good estimates of d . Therefore, in an embodiment either quantity βad or βb d is selected by coordinate processor 604 as the distance "d. " In another embodiment, the communications node 102 selects the expression having the drift rate for its respective clock 408. For instance, communications node A would select βad and communications node B would select βbd . In another embodiment, each communications node A and B computes the average of the quantities βad or βbd .
The above steps have been described with reference to only two communications nodes 102. However the present invention is scaleable to determine the positions of more than two communications nodes. As such, base node 102a uses the above steps to calculate the distance "d" to each of its neighboring nodes 102b-102p. Therefore, at step 1128, coordinate processor
604 determines whether the internodal distance to all neighboring nodes 102b- 102p have been computed. If not, steps 1104-1124 are repeated. Otherwise, the control flow passes to step 1132.
At step 1132, coordinate processor 604 produces a pointset to determine the topology for communications nodes 102. The present invention is premised on the assumption that base node 102a is positioned at the coordinate point (0,0) in a x-y coordinate system. In other words, all communications nodes 102 believe they are located at the origin of system 100. If there is at least one other communications node 102, the neighboring node 102b-102p with the minimum node identifier (as determined by the node identification number) is considered to be the first reference node, and is positioned on the positive x-axis. If there are three or more non-coUinear neighboring nodes 102b-102p, the neighboring node 102b-102p with the minimum node identifier among those neighborhood nodes 102b-102p that are neither base node 102a, the first reference node, nor collinear with base 102a and the first reference node, is denoted the second reference node and is positioned in the upper half-plane. Thus, the placement of the first reference node has the effect of fixing a particular rotational orientation, while the placement of the second reference node locks in a particular reflective orientation.
It is also presumed that the computation phase is executed only once.
That is, once a given pointset is determined, communications nodes 102 entering or leaving are added or removed incrementally. Therefore, it is conceivable that the actual first reference node is, after some time, not the non-base local node with the minimum node identifier.
Upon determining the base node 102a and the first two reference nodes 102b-102p, the pointset is constructed by coordinate processor 604. FIG. 12 shows the internodal distances among base node 102a and the first and second reference nodes 102b-102c. The law of cosines provide: dx +d3 — d2 cos(α) =
2dxd3
Once cos(α)is computed, coordinate processor 604 computes the lengths of segments BP and R2P , which give respectively the x and y coordinates of second reference node 102c, since base node 102a is positioned at point (0,0), first reference node 102b on the positive x-axis, and second reference node 102c in the upper half-plane.
Coordinate processor 604 then proceeds to compute the rest of the pointset. For each remaining non-base or reference node 102, coordinate processor 604 determines two candidate positions using distances between the remaining node, base node 102a, and first reference node 102b, as above. Next, coordinate processor 604 uses the distance between the node in question and second reference node 102c in order to choose between the two candidate positions. Thus, once coordinate processor 604 has determined the positions of the two reference nodes, the position of each additional node is determined using only the distances from it to the base and reference nodes. In an embodiment, coordinate processor 604 uses more of the internodal distance information to obtain better estimates on point positions.
Thus somewhere in between using a linear amount of data and an n2 amount of data (where n is the total number of communications nodes 102) lies an amount that will efficiently provide the desired accuracy.
After determining the topology, the control flow of flowchart 1100 ends as indicated by step 1195. Although above steps lead to the determination of local topology, the present invention also allows each communications node 102 to evaluate overlapping neighborhoods to generate consistent pictures of the network topology. Additionally, the present invention enables each communications node 102 to combine local topology information generated by neighboring nodes to derive a global network topology. Since the present invention does not requires a central authority or node, each communications node 102 is considered to be homogeneous. Each communications node 102 enters and leaves system 100 at any time. In addition, in an embodiment, the present invention permits groups of cooperating sensor nodes 102 to detect and position certain classes of objects that do not, themselves, contain sensor nodes 102. Among the non-sensor objects that are detectable include vehicles, such as automobiles, aircrafts, submarines, ships, and the like. As such, the present invention offers the added, advantage of collision detection and avoidance even when other vehicles are not equipped with sensor units.
In addition to determining the spatial locations, the present invention also determines the clock attributes of each communications nodes 102. Referring to FIG. 13, flowchart 1300 represents the general operational flow of another embodiment of the present invention. More specifically, flowchart
1300 shows an example of a control flow for determining the clock attributes of multiple communications nodes 102.
The control flow of flowchart 1300 begins at step 1301 and passes immediately to steps 704-716 to execute the measurement, information exchange, and computation phases. However, the computation phase continues into step 1304. At step 1304, clock attribute processor 608 processes the information computed at step 716, to determine the clock attributes of neighboring nodes 102b-102p. As described in reference to FIG. 11, upon completion of step 1128, coordinate processor 604 will have computed, for each communications
node 102, all of the τ values in addition to — ,βad and βbd . Moreover, βb assuming communications node A is base node 102a and communications node B is neighboring node 102b, the value of global time "t" can be determined from: τα (0 = βαβ + = βααα + βJ Equation 12 where "β" is the drift rate and "βα" is the offset for the local clock of the designated communications node 102. Therefore, for a reading of the local clock at communications node A, the global time "t" can be determined by:
Equation 13
Figure imgf000026_0001
Using the above value for t, the reading of local clock 408 from communications node B is determined by:
Figure imgf000026_0002
= βb (cb -cα)+^τα (t) Equation 14
Therefore, clock attribute processor 608 of base node 102a (e.g., communications node A) determines the reading of clock 408 on a neighboring node 102 (e.g., communications node B) by computing the value
of βbbα) , computing the ratio — , and taking a reading from local βb clock 408 of base node 102a.
The value βbb - α) is determined by solving both of the equations in the first line of the reference equations for the α term, as follows: c . = —t Equation 14
A
«, _ Ή Equation 15
A so that,
Figure imgf000027_0001
= X -βbd-^-τa Equation 16
Pa
Thus, each communications node 102 utilizes the reference equations to determine both a very good estimate for the internodal distance " d ", and the values of the respective clocks 408 of neighboring nodes 102b-102p based on readings of its local clock 408. The clock attributes, as describe above, are used by each communications node 102 to synchronize its local clock 408 for subsequent operations. After determining the clock attributes, the control flow of flowchart 1300 ends as indicated by step 1395.
Although in the preferred embodiment base node 102a transmits and receives measurement messages, base node 102a is operable to function in passive mode to only receive measurement messages from each neighboring node 102b-102p. The computation phase is adjusted to calculate the position and synchronization data from received tuples accordingly.
IV. Conclusion
FIGs. 1-13 are conceptual illustrations that allow an easy explanation of the present invention. That is, the same piece of hardware or module of software can perform one or more of the blocks. It should also be understood that embodiments of the present invention can be implemented in hardware, software, or a combination thereof. In such an embodiment, the various components and steps would be implemented in hardware and/or software to perform the functions of the present invention. Additionally, the present invention (e.g., system 100 and/or any part thereof) can be implemented in one or more computer systems or other processing systems. In fact, in an embodiment, the invention is directed toward one or more computer systems capable of carrying out the functionality described herein.
Referring to FIG. 14, an example computer system 1400 useful in implementing the present invention is shown. The computer system 1400 includes one or more processors, such as processor 1404. The processor 1404 is connected to a communication infrastructure 1406 (e.g., communications bus, crossover bar, or network). Various software embodiments are described in terms of this exemplary computer system. After reading this description, it will become apparent to a person skilled in the relevant art(s) how to implement the invention using other computer systems and or computer architectures. Computer system 1400 can include a display interface 1402 that forwards graphics, text, and other data from the communication infrastructure 1406 (or from a frame buffer not shown) for display on the display unit 1430.
Computer system 1400 also includes a main memory 1408, preferably random access memory (RAM), and can also include a secondary memory 1410. The secondary memory 1410 can include, for example, a hard disk drive
1412 and/or a removable storage drive 1414, representing a floppy disk drive, a magnetic tape drive, an optical disk drive, etc. The removable storage drive 1414 reads from and/or writes to a removable storage unit 1418 in a well- known manner. Removable storage unit 1418, represents a floppy disk, magnetic tape, optical disk, etc. which is read by and written to removable storage drive 1414. As will be appreciated, the removable storage unit 1418 includes a computer usable storage medium having stored therein computer software and/or data.
In alternative embodiments, secondary memory 1410 can include other similar means for allowing computer programs or other instructions to be loaded into computer system 1400. Such means can include, for example, a removable storage unit 1422 and an interface 1420. Examples of such can include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 1422 and interfaces 1420 which allow software and data to be transferred from the removable storage unit 1422 to computer system 1400.
Computer system 1400 can also include a communications interface 1424. Communications interface 1424 allows software and data to be transferred between computer system 1400 and external devices. Examples of communications interface 1424 can include a modem, a network interface
(such as an Ethernet card), a communications port, a PCMCIA slot and card, etc. Software and data transferred via communications interface 1424 are in the form of signals 1428 which can be electronic, electromagnetic, optical or other signals capable of being received by communications interface 1424. These signals 1428 are provided to communications interface 1424 via a communications path (i.e., channel) 1426. This channel 1426 carries signals 1428 and can be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link and other communications channels.
In this document, the terms "computer program medium" and "computer usable medium" are used to generally refer to media such as removable storage drive 1414, a hard disk installed in hard disk drive 1412, and signals 1428. These computer program products are means for providing software to computer system 1400. The invention is directed to such computer program products. Computer programs (also called computer control logic) are stored in main memory 1408 and/or secondary memory 1410. Computer programs can also be received via communications interface 1424. Such computer programs, when executed, enable the computer system 1400 to perform the features of the present invention as discussed herein. In particular, the computer programs, when executed, enable the processor 1404 to perform the features of the present invention. Accordingly, such computer programs represent controllers of the computer system 1400.
In an embodiment where the invention is implemented using software, the software can be stored in a computer program product and loaded into computer system 1400 using removable storage drive 1414, hard drive 1412 or communications interface 1424. The control logic (software), when executed by the processor 1404, causes the processor 1404 to perform the functions of the invention as described herein.
In another embodiment, the invention is implemented primarily in hardware using, for example, hardware components such as application specific integrated circuits (ASICs). Implementation of the hardware state machine so as to perform the functions described herein will be apparent to persons skilled in the relevant art(s).
In yet another embodiment, the invention is implemented using a combination of both hardware and software.
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example, and not limitation. It will be apparent to persons skilled in the relevant art(s) that various changes in form and detail can be made therein without departing from the spirit and scope of the invention. Thus, the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.

Claims

WHAT IS CLAIMED IS:
1. A method of determining the location of communications nodes in a distributed network, comprising the steps of: creating, at a first node, a transmit timestamp for a message as said message is transmitted by said first node to a second node; creating, at said second node, a receive timestamp as said message is received by said second node; storing, at said second node, a measurement tuple corresponding to said message, wherein said storing includes recording an identifier for said first node, said transmit timestamp from said first node and said receive timestamp from said second node; exchanging, by said second node, said measurement tuple with said first node, so that said first node and said second node each have a record of all measurement tuples stored therein; and analyzing said record of measurement tuples to determine the location of said first node and said second node with respect to each other.
2. A method of claim 1, wherein said storing step is repeated at least once prior to said exchanging step.
3. A method of claim 1, wherein said analyzing step comprises determining a distance between said first node and said second node.
4. A method of claim 1, wherein said analyzing step comprises determining spatial coordinates for said first node and said second node.
5. A method of claim 1, wherein said exchanging step comprises exchanging, by said second node, said measurement tuple with multiple nodes, so that said second node and said multiple nodes each have a record of all measurement tuples stored therein; whereby said analyzing step determines the location of said second node and said multiple nodes with respect to each other.
6. A method of claim 1, further comprising the step of determining clock attributes for at least one of said first node and said second node.
7. A method of claim 6, further comprising the step of determining clock attributes as a measure of relative offset and/or drift for at least one of said first node and said second node.
8. A method of claim 6, further comprising the step of synchronizing said first node and said second node with respect to each other based on one of said clock attributes.
9. A method of claim 1, further comprising the step of determining the location of a mobile sensor node while said mobile sensor node is in motion, wherein said mobile sensor node is one of said first node and said second node.
10. A method of claim 1, further comprising the step of determining the location of a sensor node in a wireless network, wherein said sensor node is one of said first node and said second node.
11. A method of claim 1, further comprising the step of transmitting said message and/or exchanging said measurement tuple at a UHF frequency.
12. A method of claim 1, wherein at least one of said first node and said second node is selected from a group consisting of an automobile, aircraft, submarine, and ship.
13. A method of claim 1, further comprising the step of determining the location of an object that is not a sensor node.
14. A method of claim 1, further comprising the steps of: creating, at said second node, a transmit timestamp for a second message as said second message is transmitted by said second node to said first node; creating, at said first node, a receive timestamp as said second message is received by said first node; storing, at said first node, a second measurement tuple corresponding to said second message, wherein said storing includes recording an identifier for said second node, said transmit timestamp from said second node and said receive timestamp from said first node; and exchanging, by said first node, said second measurement tuple with said second node, so that said second node and said first node each have a record of all second measurement tuples stored therein, wherein said analyzing step processes both sets of measurement tuples to determine the location of said first node and said second node with respect to each other.
PCT/US2001/025381 2000-08-15 2001-08-15 Method, system, and computer program product for positioning and synchronizing wireless communications nodes WO2002015614A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
AU2001284877A AU2001284877A1 (en) 2000-08-15 2001-08-15 Method, system, and computer program product for positioning and synchronizing wireless communications nodes
US10/344,857 US7224984B2 (en) 2000-08-15 2001-08-15 Method, system and computer program product for positioning and synchronizing wireless communications nodes

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US22559200P 2000-08-15 2000-08-15
US60/225,592 2000-08-15

Publications (1)

Publication Number Publication Date
WO2002015614A1 true WO2002015614A1 (en) 2002-02-21

Family

ID=22845478

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2001/025381 WO2002015614A1 (en) 2000-08-15 2001-08-15 Method, system, and computer program product for positioning and synchronizing wireless communications nodes

Country Status (3)

Country Link
US (1) US7224984B2 (en)
AU (1) AU2001284877A1 (en)
WO (1) WO2002015614A1 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1631832A1 (en) * 2003-05-26 2006-03-08 Commonwealth Scientific And Industrial Research Organisation Self surveying radio location method
US7401334B2 (en) 2002-12-20 2008-07-15 International Business Machines Corporation Method, apparatus and computer program product for managing message flow in a multithreaded, message flow environment
GB2446847A (en) * 2007-02-02 2008-08-27 Ubiquisys Ltd Locating a mobile basestation
GB2513211A (en) * 2013-01-03 2014-10-22 Csr Technology Inc Method for determining location of wireless devices
CN1870492B (en) * 2005-05-25 2016-04-20 游天童 The synchronous method of time frame fine is realized in WLAN (wireless local area network) or free net
WO2016186752A1 (en) * 2015-05-15 2016-11-24 Motorola Mobility Llc Method and apparatus for indoor location estimation among peer-to-peer devices
US9907047B1 (en) 2016-08-30 2018-02-27 Qualcomm Incorporated Passive positioning procedure and use of single burst ASAP FTM sessions
US10182413B2 (en) 2014-07-30 2019-01-15 Qualcomm Incorporated Wireless positioning using scheduled transmissions

Families Citing this family (51)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6678510B2 (en) * 2001-02-05 2004-01-13 Nokia Mobile Phones Ltd. Method, apparatus and system for GPS time synchronization using cellular signal bursts
US20030153338A1 (en) * 2001-07-24 2003-08-14 Herz Frederick S. M. Autoband
US7463890B2 (en) * 2002-07-24 2008-12-09 Herz Frederick S M Method and apparatus for establishing ad hoc communications pathways between source and destination nodes in a communications network
AU2002225377A1 (en) * 2001-12-28 2003-07-30 Nokia Corporation Node selecting method
WO2004072888A2 (en) * 2002-10-09 2004-08-26 California Institute Of Technology Sensor web
US8432942B1 (en) * 2003-05-16 2013-04-30 Apple Inc. Providing a timing source for multiple nodes coupled to a circuit-switched network
US7023814B2 (en) * 2003-05-30 2006-04-04 Motorola, Inc. Method and apparatus for distributing information
US7716585B2 (en) * 2003-08-28 2010-05-11 Microsoft Corporation Multi-dimensional graphical display of discovered wireless devices
US20050058081A1 (en) * 2003-09-16 2005-03-17 Elliott Brig Barnum Systems and methods for measuring the distance between devices
KR100494847B1 (en) * 2003-11-21 2005-06-14 한국전자통신연구원 Apparatus and Method for bidirectional and high-accurate position determination for ubiquitous computing environment
KR100654433B1 (en) * 2004-05-18 2006-12-06 삼성전자주식회사 Information processing device and method for wireless network
GB0415219D0 (en) * 2004-07-07 2004-08-11 Koninkl Philips Electronics Nv Improvements in or relating to time-of-flight ranging systems
US8930579B2 (en) * 2004-09-13 2015-01-06 Keysight Technologies, Inc. System and method for synchronizing operations of a plurality of devices via messages over a communication network
US7610015B2 (en) * 2004-09-30 2009-10-27 Alcatel-Lucent Usa Inc. System and method for coherent communication in a network
US20060106840A1 (en) * 2004-11-04 2006-05-18 International Business Machines Corporation System and method for tracking notifications in a publish subscribe system
EP1894337A1 (en) * 2005-06-13 2008-03-05 Koninklijke Philips Electronics N.V. Methods and receives of data transmission using clock domains
US20070025272A1 (en) * 2005-07-29 2007-02-01 Feng Niu Reduced order model node location method for multi-hop networks
US7812718B1 (en) * 2005-11-21 2010-10-12 The Hong Kong University Of Science And Technology Distributed position estimation for wireless sensor networks
US7899894B2 (en) 2006-08-30 2011-03-01 International Business Machines Corporation Coordinated timing network configuration parameter update procedure
US8451763B2 (en) * 2006-12-07 2013-05-28 Digimarc Corporation Wireless local area network-based position locating systems and methods
US8421675B2 (en) * 2006-12-07 2013-04-16 Digimarc Corporation Systems and methods for locating a mobile device within a cellular system
WO2008073347A1 (en) * 2006-12-07 2008-06-19 Venture Ad Astra, Llc Space-time calibration system and method
US9112626B2 (en) * 2007-01-31 2015-08-18 International Business Machines Corporation Employing configuration information to determine the role of a server in a coordinated timing network
US8738792B2 (en) * 2007-01-31 2014-05-27 International Business Machines Corporation Server time protocol messages and methods
US7797414B2 (en) * 2007-01-31 2010-09-14 International Business Machines Corporation Establishing a logical path between servers in a coordinated timing network
US7783736B2 (en) * 2007-01-31 2010-08-24 International Business Machines Corporation Definition of an active stratum-1 server in a coordinated timing network
US7689718B2 (en) * 2007-01-31 2010-03-30 International Business Machines Corporation Channel subsystem server time protocol commands and system therefor
US7783913B2 (en) * 2007-01-31 2010-08-24 International Business Machines Corporation Facilitating recovery in a coordinated timing network
US8249616B2 (en) * 2007-08-23 2012-08-21 Texas Instruments Incorporated Satellite (GPS) assisted clock apparatus, circuits, systems and processes for cellular terminals on asynchronous networks
DE102008010536A1 (en) * 2008-02-22 2009-08-27 Symeo Gmbh Circuit arrangement and method for synchronizing clocks in a network
US8416811B2 (en) * 2008-04-10 2013-04-09 International Business Machines Corporation Coordinated timing network having servers of different capabilities
US7925916B2 (en) 2008-04-10 2011-04-12 International Business Machines Corporation Failsafe recovery facility in a coordinated timing network
US8223744B2 (en) * 2008-04-24 2012-07-17 Avaak, Inc. Communication protocol for low-power network applications and a network of sensors using the same
US7873862B2 (en) * 2008-10-21 2011-01-18 International Business Machines Corporation Maintaining a primary time server as the current time server in response to failure of time code receivers of the primary time server
CN101435867B (en) * 2008-12-17 2011-07-27 西安交通大学 Wireless sensor network node positioning method based on phase measurement
US8315278B2 (en) * 2008-12-23 2012-11-20 Nokia Corporation Network synchronization method
US8457013B2 (en) 2009-01-13 2013-06-04 Metrologic Instruments, Inc. Wireless dual-function network device dynamically switching and reconfiguring from a wireless network router state of operation into a wireless network coordinator state of operation in a wireless communication network
US7983185B2 (en) 2009-02-12 2011-07-19 Zulutime, Llc Systems and methods for space-time determinations with reduced network traffic
US8463290B2 (en) 2010-07-09 2013-06-11 Digimarc Corporation Mobile device positioning in dynamic groupings of communication devices
WO2012082471A1 (en) * 2010-12-14 2012-06-21 Conocophillips Company Autonomous electrical methods node
US8744487B2 (en) * 2011-01-19 2014-06-03 Qualcomm Incorporated Methods and apparatus for determining mobile device location in a communications system
US8548493B2 (en) 2011-04-14 2013-10-01 Navteq B.V. Location tracking
US8787944B2 (en) * 2011-08-18 2014-07-22 Rivada Research, Llc Method and system for providing enhanced location based information for wireless handsets
US10237688B2 (en) 2011-08-18 2019-03-19 Rivada Research, Llc Method and system for improving the location of fixed wireless CBSD nodes
US20130107802A1 (en) * 2011-10-26 2013-05-02 Qualcomm Incorporated Downlink time difference determination in frame asynchronous systems
US9282471B2 (en) 2012-03-21 2016-03-08 Digimarc Corporation Positioning systems for wireless networks
US9007231B2 (en) 2013-01-17 2015-04-14 Baker Hughes Incorporated Synchronization of distributed measurements in a borehole
US9295016B2 (en) 2013-06-12 2016-03-22 Microsoft Technology Licensing, Llc Cooperative phase tracking in distributed multiple-input multiple-output system
US9107043B2 (en) 2013-09-30 2015-08-11 Qualcomm Incorporated Determining coordinates of access points in an indoor position location system
US9645553B1 (en) * 2016-01-28 2017-05-09 Raytheon Bbn Technologies Corp. Secure time reference using multiple time sources
WO2018113997A1 (en) * 2016-12-23 2018-06-28 Huawei Technologies Co., Ltd. Method for obtaining relatively accurate timings for location measurement

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5600706A (en) * 1992-04-08 1997-02-04 U S West, Inc. Method and system for determining the position of a mobile receiver
US6011974A (en) * 1997-09-23 2000-01-04 Telefonaktiebolaget L M Ericsson (Publ) Method and system for determining position of a cellular mobile terminal

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2670345B1 (en) * 1990-12-11 1994-09-30 Alcatel Business Systems METHOD FOR ENSURING THE PERMANENCE OF THE SYNCHRONIZATION OF THE NODES OF A PRIVATE TELECOMMUNICATIONS NETWORK ON THE BEST AVAILABLE CLOCKS AND CORRESPONDING NETWORK.
AU6279794A (en) * 1993-04-01 1994-10-24 Bruno Robert System for selectively positioning and tracking a movable object or individual
US6125368A (en) * 1997-02-28 2000-09-26 Oracle Corporation Fault-tolerant timestamp generation for multi-node parallel databases
US6157957A (en) * 1998-01-22 2000-12-05 Cisco Technology, Inc. Clock synchronization system and method using a continuous conversion function for a communication network
US6184829B1 (en) * 1999-01-08 2001-02-06 Trueposition, Inc. Calibration for wireless location system
US6957075B1 (en) * 1999-02-01 2005-10-18 Intel Corporation Method and apparatus for providing a location based appliance personality
SE9900710L (en) * 1999-02-25 2000-08-26 Ericsson Telefon Ab L M Method and device relating to communication networks for mobile phones
US6539393B1 (en) * 1999-09-30 2003-03-25 Hill-Rom Services, Inc. Portable locator system

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5600706A (en) * 1992-04-08 1997-02-04 U S West, Inc. Method and system for determining the position of a mobile receiver
US6011974A (en) * 1997-09-23 2000-01-04 Telefonaktiebolaget L M Ericsson (Publ) Method and system for determining position of a cellular mobile terminal

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7401334B2 (en) 2002-12-20 2008-07-15 International Business Machines Corporation Method, apparatus and computer program product for managing message flow in a multithreaded, message flow environment
US8108860B2 (en) 2002-12-20 2012-01-31 International Business Machines Corporation Method for managing message flow in a multithreaded, message flow environment
EP1631832A4 (en) * 2003-05-26 2007-01-17 Commw Scient Ind Res Org Self surveying radio location method
EP1631832A1 (en) * 2003-05-26 2006-03-08 Commonwealth Scientific And Industrial Research Organisation Self surveying radio location method
CN1870492B (en) * 2005-05-25 2016-04-20 游天童 The synchronous method of time frame fine is realized in WLAN (wireless local area network) or free net
GB2446847A (en) * 2007-02-02 2008-08-27 Ubiquisys Ltd Locating a mobile basestation
GB2446847B (en) * 2007-02-02 2012-02-22 Ubiquisys Ltd Location of Basestation
US8626240B2 (en) 2007-02-02 2014-01-07 Ubiquisys Limited Location of basestation
US8738033B2 (en) 2007-02-02 2014-05-27 Ubiquisys Limited Location of basestation
GB2513211A (en) * 2013-01-03 2014-10-22 Csr Technology Inc Method for determining location of wireless devices
US10039073B2 (en) 2013-01-03 2018-07-31 Qualcomm Incorporated Method for determining location of wireless devices
US10219241B2 (en) 2013-01-03 2019-02-26 Csr Technology Inc. Method for determining location of wireless devices
GB2513211B (en) * 2013-01-03 2019-10-30 Csr Tech Inc Method for determining location of wireless devices
US10624055B2 (en) 2013-01-03 2020-04-14 Csr Technology Inc. Method for determining location of wireless devices
US10182413B2 (en) 2014-07-30 2019-01-15 Qualcomm Incorporated Wireless positioning using scheduled transmissions
WO2016186752A1 (en) * 2015-05-15 2016-11-24 Motorola Mobility Llc Method and apparatus for indoor location estimation among peer-to-peer devices
US9980097B2 (en) 2015-05-15 2018-05-22 Motorola Mobility Llc Method and apparatus for indoor location estimation among peer-to-peer devices
US9907047B1 (en) 2016-08-30 2018-02-27 Qualcomm Incorporated Passive positioning procedure and use of single burst ASAP FTM sessions

Also Published As

Publication number Publication date
AU2001284877A1 (en) 2002-02-25
US20050020275A1 (en) 2005-01-27
US7224984B2 (en) 2007-05-29

Similar Documents

Publication Publication Date Title
US7224984B2 (en) Method, system and computer program product for positioning and synchronizing wireless communications nodes
US10462762B2 (en) Methods for synchronizing multiple devices and determining location based on the synchronized devices
US10408917B2 (en) Method and apparatus for determining location of an object
US7302269B1 (en) Radiolocation in a wireless network using time difference of arrival
US9060342B2 (en) System and method for passively determining own position listening to wireless time synchronization communications
CN103344942B (en) Controlling vertex, asynchronous tracking method and system
CN110167135B (en) TDOA wireless positioning method and system free of clock synchronization
CN112073903A (en) Single-base-station high-precision UWB indoor positioning system and method
CN111308514B (en) Satellite navigation spoofing detection method in wireless synchronous communication network
US8150378B2 (en) Determining position of a node based on aged position data
Pelka et al. S-TDoA—Sequential time difference of arrival—A scalable and synchronization free approach forl positioning
Banin et al. High-accuracy indoor geolocation using collaborative time of arrival
JP5884170B2 (en) Relative positioning device, relative positioning method, and program
Fokin Vehicles Tracking in 5G-V2X UDN Using Range and Bearing Measurements
Yu et al. An improved DV-hop localization algorithm in wireless sensor networks
CN111366960A (en) Navigation positioning method based on communication time service
EP3264132A1 (en) Pulsed radio timing and propagation correction in spatial measurement
JPH09133747A (en) Method for localizing transceiver of data packet
CN114222362B (en) Positioning method and positioning device
Bar-Shalom et al. Accurate time synchronization for automotive cooperative radar (CoRD) applications
Cho et al. Real time locating system for wireless networks using IEEE 802.15. 4 radio
Mah Time-based location techniques using inexpensive, unsynchronized clocks in wireless networks
Cho et al. Precise location tracking system based on time difference of arrival over LR-WPAN
Boukerche et al. Localization in time and space for wireless sensor networks: A Mobile Beacon approach
CN117098225A (en) Indoor positioning system and method

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
WWE Wipo information: entry into national phase

Ref document number: 10344857

Country of ref document: US

NENP Non-entry into the national phase

Ref country code: JP