This disclosure generally concerns wireless positioning, and in particular, a method, system and computer program for estimating the location of a transmitter using multiple pairs of locator nodes. This disclosure also provides a method, system and computer program for measuring time of arrival of a signal received from a transmitter.
Wireless positioning systems generally refer to systems that track or locate a transmitter using wireless technologies, including the transmission and measurement of electromagnetic signals. Tracking is beneficial for many applications, such as to enhance safety, security or productivity. Knowing the location of people and mobile equipment may be used to enhance the safety of people on a work site. Knowing the location of patients may enable assistance to rapidly reach them if they fall or press a panic button. Tracking the location of people in a building may allow security staff to be alerted if a person enters an area to which they are not authorised. Determining the location of access points in a building allows a rogue access point to be rapidly found and dealt with. Tracking the movement of staff and materials at a work site allows the operational efficiency to be analysed and possibly improved.
Mobile networks track mobile handsets so that their location for an emergency call can be estimated (e.g. E911 in the USA). This technique has low accuracy, with a typical accuracy many tens to hundreds of metres. The location of handsets with WiFi (e.g. Apple iPhone) can be determined in some areas using the signal strength of multiple access points. However, this only works in areas where there is a sufficient density of access points and a database of their signal strength as a function of location is available.
According to a first aspect, there is provided a method for estimating the location of a transmitter using multiple pairs of locator nodes with known locations, the method being implemented by a processor of a location estimation node and comprising:
According to the method of the first aspect, the likelihood information represents a “likelihood, map” of the location of the transmitter. The method is Bayesian in nature and considers the error distribution of the time difference of arrival values, rather than restricting the transmitter to lie on a particular hyperbola defined by absolute time difference of arrival values. Advantageously, the location estimation according to the method is more robust to outlier measurements. Further, using the error distribution of the time difference of arrival values results in better location accuracy, compared with just assuming a general distribution.
Determining the likelihood information may further comprise:
The estimated location may be a candidate location associated with a maximum value derived from the likelihood information. Alternatively, the estimated location may be a candidate location associated with a mean value derived from the likelihood information.
The error distribution may follow a predetermined model of error distribution and is a function of difference between the time difference of arrival values, and expected time difference of arrival values calculated based on known locations of a pair of locator nodes when time of arrival values are measured.
One or more locator nodes may be mobile locator node devices having a means to determine their location when the time of arrival values are measured. In this example, mobile locator nodes facilitate rapid deployment and tracking of the transmitter. This is especially useful in applications where fixed infrastructure is not available, including devices at fixed and known location and connected to a cable to a location processor.
Mobile locator nodes also facilitate more accurate location of the transmitter, particularly when there are a limited number of locator nodes.
The time of arrival values may be synchronised among the locator nodes using one of the following:
The location estimation node may be one of the locator nodes, a central processing node in wireless communication with the locator nodes, or a node associated with the transmitter.
According to a second aspect, there is provided computer program comprising executable instructions which, when executed by a processor of a location estimation node device, cause the processor to perform the method according to the first aspect.
According to a third aspect, there is provided a location estimation node device for estimating the location of a transmitter using multiple pairs of locator nodes with known locations, the device comprises:
According to a fourth aspect, there is provided a method for measuring time of arrival of a signal received by a locator node from a transmitter, the method being performed by a processor of a locator node and comprising:
The method according to the fourth aspect takes into account multipath propagation environment in which radio signals travel from the transmitter to the locator node. By determining the time correction from the first and second values of the channel impulse response, a more accurate time of arrival value is obtained. Improving the time of arrival estimation not only allows more accurate localisation and tracking of the transmitter, but also facilitates a more accurate time synchronisation among locator nodes in the system.
The time correction may be a time delay from the second value, and determining the time correction comprises:
The first value may be a first peak of the channel impulse response with a magnitude that exceeds or equals a first threshold multiplied by the largest peak of the channel impulse response; and the second value may lie on the leading edge of the first value and corresponds to either a minimum or a second threshold multiplied by the first value.
The signal received from the transmitter may be a direct sequence spread spectrum (DSSS) signal, in which case the method further comprises:
The signal received from the transmitter may be an orthogonal frequency division multiplexing (OFDM) signal, in which case the method further comprises:
The method may further comprise performing time synchronisation on the improved time of arrival value using one of the following:
The locator node may be a mobile device having a means to determine its location when the signal is received from the transmitter.
The method may further comprise sending the improved time of arrival value to a location estimation node device to estimate the location of the transmitter according to the method of the first aspect.
According to a fifth aspect, there is provided computer program comprising executable instructions which, when executed by a processor of a locator node device, cause the processor to perform the method measuring time of arrival of a signal received by the locator node from a transmitter according to the fourth aspect.
According to a sixth aspect, there is provided a locator node device for measuring time of arrival of a signal received by a locator node from a transmitter, the device comprises:
Cooperation with the target transmitter may not be required for the system to locate the transmitter.
Each locator node may measure time of arrival of wireless signals received from the transmitter.
Each locator node may have an independent clock.
A method is provided to regularly measure the difference in local clock times between locator nodes, hence the time difference of arrival values are measured between pairs of locator nodes.
Locator nodes may be mobile, and a method is provided to determine the location of each locator node near the time that the time of arrival of a signal is received.
The method may, based on the time difference of arrival values and an error distribution of the time difference of arrival values, determine likelihood information for multiple candidate locations of the transmitter; and estimate the location of the transmitter from the likelihood information.
Reference transmissions from known locations may be received by locator nodes.
Non-limiting example(s) will now be described with reference to the accompanying drawings, in which:
a) is an example structure of DSSS (direct-sequence spread spectrum) signal;
b) is an example channel impulse response of the DSSS signal.
a) is plot of individual likelihood information of locator nodes N1 and N2;
b) is plot of individual likelihood information of locator nodes N1 and N3;
a) is plot of individual likelihood information of locator nodes N2 and N3;
b) is plot of the individual likelihood information in
Each locator node 110 is able to receive radio signals 140 transmitted by the transmitter 120 over a radio channel between them, and the unknown location xT can be estimated using time difference of arrival (TDOA) values of the received signals. The location of the locator nodes 110 (N1, N2 and N3) are known (x1, x2 and x3 respectively) at the time the signals are received. Locations xT, x1, x2 and x3 may be two-dimensional (2D) in which case at least two pairs of locator nodes 110 are required; or three-dimensional (3D) which requires at least three pairs of locator nodes 110.
The transmitter 120 to be tracked may be part of a mobile node or a tag attached to an object. The transmitter 120 does not need to be cooperative with the tracking process, either because they are unwilling (e.g. wireless intruder) or unable (e.g. resource constrained or locked architecture). Any suitable wireless communication protocols may be used by the transmitter 120 to transmit the signals 140, including but not limited to IEEE 802.11 OFDM (orthogonal frequency division multiplexing) and IEEE 802.11 DSSS (direct sequence spread spectrum).
The locator nodes 110 may be any suitable device with a receiver to receive the signals 140 transmitted by the transmitter 120, and computational resources to perform necessary processing. The locator nodes 110 may be mobile devices having a means to determine their own location, fixed devices, or a combination of both. Example mobile devices include mobile phones, tablet computers and laptop computers that are connected to a cellular mobile communications network (e.g. one of the 3GPP or 4G standards) or local area network (e.g. one of the 802.11 standards), or both. The locator nodes 110 may also be access points and printers that are typically fixed, and others such as transponders and wireless modems may be attached to fixed or mobile equipment.
Referring also to
Step 210 is performed by each locator node 110 when signals are received from the transmitter. Time synchronisation according to step 220 may be performed by each locator node 110 or by a “location estimation node”. Using the synchronised TOA values, the location estimation node estimates the location of the transmitter 120 according to steps 230 and 240.
The TOA values may be sent from the locator nodes 110 to the location estimation node wirelessly, or using any suitable wired means. For example, the TOA values may be transported via a physical link between each locator node 110 and transmitter 120, such as Universal Serial Bus (USB) or Ethernet local area network (LAN).
The location estimation node may be (i) one of the locator nodes 110, (ii) the central processing node 130, or (iii) the transmitter 120. For cases (i) and (ii), the system 100 does not require cooperation of the transmitter 120, and therefore can be rapidly setup to accurately track the transmitter 120 in a wireless network. As such, the system 100 would be beneficial for security services, network security, safety (e.g. tracking workers and unauthorised personnel on work sites), tracking passengers at airports, and a range of similar applications. Furthermore, the tracking may be covert in that the transmitter 120 does not know that it is being tracked.
Although the steps in
The example method in
In step 210, the locator nodes 110 measure the TOA of signals received from the transmitter 120. The signals may be carrying data, and any other information such a medium access control (MAC) address to identify the transmitter 120, and packet type or sequence number to facilitate matching packets between locator nodes 110.
For each received signal, the locator nodes 110 also have the means to determine their own location relative to the other location devices or in global coordinates. Each locator node 110 (e.g. N1, N2 and N3) may be provided with a means of determining its location (e.g. x1, x2 and x3) when TOA measurements are taken. For example, the locator nodes 110 may include a global positioning system (GPS), or a personal dead reckoning system to determine their location, starting from a known location. The locator nodes 110 may also be static at known locations.
The locator nodes 110 are not assumed to be stationary, although it may be beneficial to move the nodes 110 about while taking measurements. This is because an increase in the diversity of baselines (i.e. locations of node pairs at which a TDOA measurement is made) increases the accuracy of the subsequent steps in
Referring now to
The output of step 210 in
In the examples below, the transmitter 120 uses the IEEE 802.11 protocol, with transmissions using either (a) OFDM (orthogonal frequency division multiplexed) or (b) DSSS (direct sequence spread spectrum) physical layer signalling. DSSS transmissions are typically used in 802.11 beacons while OFDM transmissions are used in 802.11a/g/n packets. Note that an access point will usually transmit beacons in the 2.4 GHz band using DSSS, even when data packets are transmitted using OFDM.
To determine an initial TOA value according to step 212 in
An example an 802.11 OFDM transmission is shown in
The “long training sequence” 420 provides two known symbols to estimate the frequency response of the channel. The measured complex value at each of the 52 non-zero subcarriers after frequency offset correction is divided by the known transmitted value to obtain a channel frequency response at these subcarriers. This channel frequency response is averaged over the two long training symbols and data symbols. For improved signal to noise ratio (SNR), this channel frequency response may be determined over the entire packet.
To obtain a channel impulse response for a radio channel between the transmitter 120 and locator node 110, the channel frequency response is then transformed to the time domain using an inverse Fourier transform; see step 214 in
A time correction is then calculated based on the channel impulse response; see step 216 in
To determine a time correction for the TOA value, the following values are considered:
The time correction is calculated based on the first value v1 and second value v2. In one example, the ratio of the second value v2 to the first value v1 is determined and the delay from the/second value v2 to the peak value 510 or expected time of arrival value for the case with no multipath interference (see
In more detail, in the ideal case with no multipath in
To obtain the result 530 shown in
For example, windowing may be used in some scenarios to reduce the side lobes of the channel impulse response. For example, this is indicated by the channel impulse response having less wiggles for the case with Hamming windowing; see 515 in
Similarly, symbol timing recovery of the decoding process of the DSSS packet provides a coarse TOA estimate; see also step 212 in
Standard DSSS processing does not required frequency offset correction, however for the method in
An example format of an 802.11 DSSS packet is shown in
Using the decoded data, the original DSSS transmission can be reconstructed. In one example, only the last 32 bits of the SYNC field, the 16 bits of the SFD field and the 48 bits of the PLCP header are generated (total duration 96 μs as these use the base data rate). This reconstructed section of the transmitted signal is correlated against the frequency-corrected received data to obtain a channel impulse response; see also step 214 in
The same process as described for OFDM transmissions is then used to calculate a time correction value which is the time offset of the DSSS signal; see also step 216 in
Similar to process used for OFDM transmissions, a ratio of the second value v2 to the first value v1 is first determined. Next, a location, which corresponds to the ratio, on a leading edge of a largest peak of an ideal channel impulse response with no multipath present is determined. The time correction is determined as a time delay from the location to the largest peak of the ideal channel impulse response.
The improved TOA is then estimated from the coarse TOA estimate and the time correction; see step 218 in
While the TOA may be measured using a time that is synchronised between all locator nodes 110, the measurements may also be recorded using an unsynchronised local clock in each locator node 110. In the latter case, time synchronisation is required.
At the time synchronisation step 220 in
It will be appreciated that the above are non-limiting examples, and other suitable time synchronisation techniques may be also used, depending on the configuration of the locator nodes 110, transmitter 120 and central processing node 130. Step 220 may be performed locally by each locator node 110 or by the location estimation node.
Next, the TDOA of packets at one or more pairs of locator nodes 110 is calculated based on the TOA values; see step 230
When a signal transmission from transmitter 120 is received by more than one locator node 110, the difference in the time synchronised TOA values measured by a pair of locator nodes 110 is a TDOA value. The TDOA of two TOA values can be used to determine the likelihood values for the location of the transmitter 120 in step 240 in
In the example in
τ1,2=t1−t2,
τ1,3=t1−t3,
τ2,3=t2−t3.
In the above, τ1,2 is the difference between the TOA values measured by locator nodes N1 and N2; τ1,3 is the difference between the TOA values measured by locator nodes N1 and N3; and τ2,3 is the difference between the TOA values measured by locator nodes N2 and N3.
The output of step 230 may be, for each transmitter 120, a list of TDOA values and corresponding known location of the two locator nodes 110, as follows:
The TDOA values may be generated using all pairs of locator nodes 110 receiving a particular transmission or multiple transmissions by the transmitter 120. The TDOA values and location information of the relevant locator nodes 110 are then sent to a location estimation node that performs location estimation.
In step 240 in
One example implementation of step 240 is shown in
In the above equation, the speed of light given by c, and the two locator nodes Ni and Nj are at known locations xi and xj respectively. In the example in
In step 244 in
e(x,xi,xj)={circumflex over (τ)}i,j(x,xi,xj)−τi,j.
Let the function ƒ(e) define a likelihood that the error takes particular value e, then the likelihood that the transmitter 120 is located at x is represented as ƒ(e(x)). Function ƒ(e(x)) may follow any suitable probability distribution, such as a Normal distribution N(0, σr2) with zero mean and standard deviation σr, and a minimum value lmin. In this case, the likelihood of a candidate location x can be modelled as:
The function ƒ(e(x)) defines a set of likelihood values for the candidate location x, rather than restricting the transmitter 120 to lie on a particular hyperbola. Advantageously, this model of distribution of errors makes the location estimation step more robust to outlier TDOA values. The likelihood function may be empirically determined in representative environments, such as multi-storey office building, warehouse, indoor sports venue, shopping centre, residential area and airport.
Using multiple TDOA values, either between the same pair of locator nodes 110 for different transmissions, or between different pairs of locator nodes 110, multiple such likelihood maps can be generated. These can be combined to refine the location of the transmitter 120 to be tracked.
In step 246 in
l
i,j(x)=ƒ({circumflex over (τ)}i,j(x,xi,xj)−τi,j).
In the example in
b) shows a region 930 with various intersections among the individual likelihood maps in
In step 248 in
An example is shown in
In step 249 in
(a) Maximum Value:
(b) Mean Value:
The above estimators are known as the maximum a posterior (MAP) and minimum mean squared error (MMSE) estimates, respectively. In cases where the distribution of ƒ(e(x)) is unimodal, the MMSE estimate is preferred. An example of unimodal distribution is the Normal distribution which has a single peak.
The method and system in this disclosure can be implemented by hardware, software or firmware or a combination thereof.
The example device 1100 includes a processor 1110, a memory 1120 and a radio transmitter and receiver (or transceiver) 1130. The processor 1110 implements functional units in the form of a transmission unit 1112, a receiving unit 1114, and a processing unit 1116. Radio signals may be transmitted and received via the radio transmitter/receiver 1130.
In the case of the locator node 110, the method of measuring time of arrival of a signal transmitted by the transmitter 120 to be tracked to the locator node 110 may be performed as follows. The receiving unit 1114 receives the signal from the transmitter 120. The processing unit 1116 performs the following:
In the case of the location estimation node, the method of estimating the location of the transmitter may be performed as follows. The receiving unit 1114 receives, from the locator nodes, the time of arrival values of signals received by the locator nodes 110 from the transmitter 120. The time of arrival values may also be received by the location estimation node wirelessly via the receiver 1130, or any wired means such as over a cable such as Universal Serial Bus (USB) or Ethernet.
The processing unit 1116 performs the following:
Time synchronisation of the time of arrival values may be performed by the processing unit 1116 of the locator node 110 or location estimation node (which may be a locator node 110, transmitter 120 or central processing node 130).
For example, the various methods, processes and functional units described herein may be implemented by the processor 1110. The term ‘processor’ is to be interpreted broadly to include a CPU, processing unit, ASIC, logic unit, or programmable gate array etc. The processes, methods and functional units may all be performed by a single processor 1110 or split between several processors (not shown in
Although a radio transmitter/receiver 1130 is shown in
The processes, methods and functional units may be implemented as machine-readable instructions executable by one or more processors, hardware logic circuitry of the one or more processors or a combination thereof. In the example in
Further, the processes, methods and functional units described in this disclosure may be implemented in the form of a computer software product. The computer software product is stored in a storage medium and comprises a plurality of instructions for making a computer device (which can be a personal computer, a server or a network device such as a router, switch, bridge, host, access point etc.) implement the methods recited in the examples of the present disclosure.
The figures are only illustrations of an example, wherein the units or procedure shown in the figures are not necessarily essential for implementing the present disclosure. Those skilled in the art will understand that the units in the device in the example can be arranged in the device in the examples as described, or can be alternatively located in one or more devices different from that in the examples. The units in the examples described can be combined into one module or further divided into a plurality of sub-units.
Although the flowcharts in
It will be appreciated by persons skilled in the art that numerous variations and/or modifications may be made to the above-described examples, without departing from the broad general scope of the present disclosure. The examples in the present disclosure are, therefore, to be considered in all respects as illustrative and not restrictive.
Number | Date | Country | Kind |
---|---|---|---|
2012901862 | May 2012 | AU | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/AU2013/000468 | 5/7/2013 | WO | 00 |