System and method for multiple range estimation location

Information

  • Patent Grant
  • 8380222
  • Patent Number
    8,380,222
  • Date Filed
    Tuesday, February 14, 2012
    12 years ago
  • Date Issued
    Tuesday, February 19, 2013
    11 years ago
Abstract
A system and method of determining the location of a mobile station by determining the time of transmission of a signal by a mobile station and determining range rings at a plurality of reference stations receiving the transmitted signal, where the range rings represent the distance of the mobile station from the plurality of reference stations.
Description

The present disclosure is directed to an accurate location estimation of a mobile device. More specifically the present disclosure is directed at estimating the location of a mobile device using multiple range estimates.


BACKGROUND

It is well known to determine the location of a mobile device based on signals that are transmitted by the mobile device received at a plurality of reference stations. When a location estimation technique is dependent on signal arrival time or signal transit time measurements, it is well recognized that signal multipath is often highly deleterious to the accuracy of the location estimate. Multipath refers to the reflection of a signal, or component of a signal off an object between the transmitter and the receiver.


In the context of a wireless network, a mobile device or mobile station (MS) transmits uplink signals to an access point or base station (BS) that may have a certain functional relationship (in terms of signal timing) with respect to downlink signals transmitted by a serving access point. This functional relationship permits an extraneous system to observe the transmissions between the mobile devices and the access point, and by doing so, determine the time of transmission for a given signal from the mobile device.


Knowing the time of transmission of a signal from a mobile device, and the time at which this same signal is received at a set of other observing stations (termed Wireless Location Sensors or WLSs), it is possible to obtain a set of Range Rings (RRs) representing the distance of the mobile device to each WLS. The intersection of the RRs represents the estimated geographic location of the mobile device.


However, in most location systems, the WLSs do not know the time of transmission of the signals from the mobile device. This is especially so when the mobile device is not synchronized with the access point. Because of this problem, a common location technology uses the time difference of arrival (TDOA) of the signal transmitted by the mobile device at a plurality of WLSs. Each pair of WLSs produces a hyperbola of points representing the possible location of the mobile device. The intersection of the hyperbolae between at least three WLSs provides an estimate of the location of the mobile device. Thus the TDOA technique is useful when the time of transmission of the signal is not known or cannot be determined.


The present application is directed to the novel use of RRs to estimate location referred to as Multiple Range Estimation Location (MREL). Additional embodiments include adjusting the Range Rings to account for errors and mitigate multipath interference.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a simplified pictorial representation of one embodiment of the present disclosure.



FIG. 2 is a simplified pictorial representation illustrating the differences between one embodiment of the present disclosure and the use of a time difference of arrival (TDOA) method to determine the location of a mobile transmitter.



FIG. 3 is a simplified pictorial representation of one embodiment of the present disclosure where the serving base station does not include a WLS.



FIG. 4 is a simplified pictorial representation of one embodiment of the present disclosure where the serving base station does include a WLS.



FIG. 5 is a graphical representation of the g(.) function which can be used in one embodiment of the present disclosure to mitigate multipath propagation.





DETAILED DESCRIPTION

In the present disclosure, a system and method of MS location based on generating Range Rings that represent the propagation time of signals from the MS location to a set of receivers having a known location is disclosed. A functional relationship between the timing on the forward channel and the reverse channel, represented mathematically as ƒ(P) may be exploited to determine the time of transmit at the MS and this functional relationship can thus be used to determine the Range Rings. The Range Rings determined in this embodiment may potentially be degraded resulting from a common error due to any errors in estimating the time of transmit at the MS. In addition one or more of the Range Rings could be further distorted by non-line of sight (NLOS) or multipath propagation which, if not addressed, could seriously degrade the accuracy of any location estimate. This embodiment avoids differencing operations on the timing measurements since the method exploits the distinct propagation properties on each path; this also eliminates the ambiguity problems that can occur in TDOA location. The common error and the NLOS problem are jointly addressed in the present disclosure directed to a multipath mitigating method to generate location estimates that are far superior to standard TDOA location estimation.


With reference to FIG. 1, the communication link between a Mobile Station (MS) 100 and a serving Base Station (BS) 110 is illustrated. A marker M1 on the downlink channel (BS to MS) and a marker M2 on the uplink channel (MS to BS) may appear in some predefined manner. For example, the markers could occur in some regular periodic fashion.


An example of such a marker could be the start of a particular frame or the start of a particular slot. A marker could also be the start or end of a particular piece or sequence of data. In one embodiment, the communication protocol may force the MS to align its marker M2 in some prescribed manner, defined by a parameter P, and communicated within the network, with respect to the receive time (at the MS) of downlink marker M1. The uplink marker M2, when viewed at the MS, is aligned such that it is separated in time with respect to the downlink marker M1 by some time interval ƒ(P). The GSM cellular protocol is an example of one such configuration. In this case, the markers of interest are the start times of corresponding slots. The parameter P is the Timing Advance (TA) parameter and the function ƒ(P) is given by ƒ(TA)=3.6928*TA−3*Ts where Ts is the symbol duration in microseconds.


In such a configuration, location of the MS can be determined with reference to FIG. 1. An observer at some location Lobs 120 is capable of monitoring the downlink transmissions from the serving BS 110. The location of the serving BS 110 is Lbs and the observer knows both Lbs and Lobs. The observer 120 can then determine the exact transmission time of a marker M1 by determining when the marker M1 was observed at Lobs and subtracting the transmission time for the signal from Lbs to Lobs, denoted by tF. A known technique may be used to derive the time estimates, where the specific technique used to obtain these estimates is well known and not described herein. If the locations Lobs and Lbs are coincident or very close to each other, the time of transmission of M2 from the MS to the serving BS can be computed as follows:

tM=tFp−ƒ(P)  [1]

where


tM is the transmission of a marker M2 at the MS,


tF is the transmission time of a marker M1 at the BS,


τp is the one way propagation time and, may include the effects of noise and multipath,


P is the timing parameter; and


ƒ(P) is a function of the parameter P


The time of receipt of the marker M2 at Lobs is given by

tR=tMp  [2]

Solving for τp gives the propagation time from the MS to the serving BS as

τp=½(tR−tF+ƒ(P))  [3]

and gives the time of transmission at the MS as

tM=tR−½(tR−tF+ƒ(P))=½(tR+tF−ƒ(P))  [4]


Thus, knowing the transmission time tF, the receive time tR the parameter P and the functional relationship ƒ(P), the time of transmission of the signal M2 at the MS can be determined.


In the case of the GSM protocol

τp=½(tR−tF+3.6928*TA−3*Ts),  [5]
and
tM=½(tR+tF−3.6928*TA+3*Ts)  [6]

where all time measurements in this case are in microseconds.


Knowing the time of transmission of a marker M2 at the MS, Range Rings can be calculated with respect to any other observing station or WLS. For example, the time of transmission of Marker 2 can be transmitted to all observing stations. Or the time of transmission can be transmitted to a remote central site which collects the time of receipt of M2 from each of the WLSs. For each WLS, if the marker M2 was received at time tR,WLS, then the propagation time from the MS to that WLS is

τp,WLS=tR,WLS−tM=tR,WLS−½(tR+tF−ƒ(P))  [7]

And, given a set of WLSs, WLS1, WLS2, . . . WLSn, a set of Range Rings can be produced:

τp,WLSi=tR,WLSi−tM=tR,WLSi−½(tR+tF−ƒ(P)), i=1,2, . . . n  [8]


Thus, a set of Range Rings R, defining the propagation times from the MS to a set of WLSs, one of which could be co-located at the serving BS, can be determined. An intersection of the Range rings provides the location of the MS. The Range Rings need not be determined at each WLS. Instead all WLSs can transmit their respective timing information to one of the WLSs, e.g., the WLS co-located at the serving BS, which performs Range Ring and location determination. Likewise, the Range Ring calculations and location determination can be made at a remote central site discussed above. A beneficial aspect of this method is that multipath on the serving link can extend the Range Rings between the WLS at the serving BS and the MS, but will not affect the computed Range Rings from the MS to other WLSs.


In one embodiment, the covariance matrix C of the Range Rings captures important statistical properties that can be used in a location technique. Given equations [5]-[7], it is possible to express all of the elements of this matrix in terms of (a) the variance of the transmission time tF given by σF2, (b) the variance of the arrival time at the serving WLS tR given by σR2, and (c) the variance of the arrival time at non-serving WLSs, tR,WLSi given by σRi2. The calculations assume that the signals are disturbed by additive noise that is independent from sensor to sensor.


The diagonal terms of the covariance matrix C are given by the serving Range Ring variance ¼σR2+¼σF2 in the (1, 1) position and the individual non-serving Range Ring variances σRi2+¼σR2+¼σF2 in the (k, k) positions, where k=2, 3, . . . n. The terms along the first row and column, the terms in the (1, k) and (k, 1) positions, are given by −¼σR2+¼σF2. The mutual covariance terms between distinct non-serving Range Rings, the terms in the positions (k, j) where k 6=j; k, j 6=1, are given by ¼σF2+¼σR2.


It may be observed that this defines a matrix with a lack of symmetry between the serving Range Ring and other non-serving Range Rings. This is to be expected from the form of the equations, particularly noting how the MS transmission time, tM is generated. The serving Range Ring properties are therefore dominant in this matrix.


It is important to note that the variance for each Range Ring may be different in the MREL method. That is, there may be a different variance for each individual timing measurement. In the TDOA method the calculated variance is associated with the TDOA pairs, not with the individual timing measurement, since such individual measurements are not computable in such schemes.


When clear Line Of Sight (LOS) signal paths exist between a transmitter and a set of receivers, it is expected that the multipath component in the signal propagation is quite small. In a situation where multiple instances of Range Rings can be obtained over a short time interval within which the MS cannot move an appreciable distance, the best estimate of any particular Range Ring can be obtained by some means. For example, the median Range Ring for a given MS-WLS pair may be taken as the representative Range Ring for that pair. Alternatively, the representative Range Ring may be taken by clustering the available set of Range Rings for this MS-WLS pair and using the cluster with smallest distance. Note that if two or more tight clusters occur, it is possible to provide multiple Range Rings for a given MS-WLS pair.


The set of Range Rings may be given by R where










R
=

[




R
1






R
2











R
k




]


,




[
9
]








where k is the number of geographically separated WLSs observing the MS. The WLS at the serving BS is included as a member in this set.


Let S denote the region over which the MS maybe located. This region could, for example, be the region enclosed by the set of WLSs or some expansion of this basic region. Now, for each point (x,y) in the region let Di(x,y) denote the distance from the point (x,y) to the ith WLS. Now let us define the vector









D
=


[





D
1



(

x
,
y

)








D
2



(

x
,
y

)













D
k



(

x
,
y

)





]

.





[
10
]







Let α be a real number. Then assuming Gaussian noise as the disturbance on the Range Rings measurements, it can be shown that the optimum location for the MS can be written as the location ({circumflex over (x)}, ŷ) such that the quantity

[R−A−D]H*C−1*[R−A−D]  [11]

is minimized, and in which the vector A is a vector of equal values in each position is written as,









A
=

[



α




α









α



]





[
12
]








and where the minimization is over all points (x,y) in the region S and over all real α.


A highly simplified version of this, where we only consider the diagonal elements of the covariance matrix is considered in this disclosure. The understanding is that in actual application one should consider both the optimal solution and the simplified presentations, shown here primarily for the ease of exposition of the principles involved. With this simplification, let Δ be a real number. Then the optimal location for the mobile can be determined as the location ({circumflex over (x)}, ŷ) such that the vector norm given by

R−A−D∥  [13]

is minimized.


An understanding of the process applied here can be obtained by considering some fundamental issues associated with LOS propagation and Range Ring accuracy. First, it is important to note that the Range Rings obtained as described in the previous section could have some uncertainty associated with them due to even a small error in estimating the transmission time at the MS. The parameter α is used to permit correction of this effect and also to possibly correct any error in the MSs implementation of the functional relationship ƒ(P) as well as compensating for multipath in the serving BS to MS path.


Secondly, once these measurement inaccuracies have been addressed, the remaining error on the Range Rings is assumed to be Gaussian noise for the ideal case of LOS signals. This noise is statistically limited by other quantities such as the power level of the signal, and is generally small. For example in the GSM protocol the associated error is of the order of a few tens of meters.


This minimization in equation [11] can also be expressed as

min Σi=1n(Ri−α−Di)2  [14]

where i indexes the particular Range Ring (or the WLS associated with that Range Ring) and the sum is over all i, with the index i running from 1 to n, where n is the number of rings. In addition if each Range Ring is assigned a weight wi, the minimization can be written as

min Σi=1nwi(Ri−α−Di)2  [15]

An example of such a weight is the inverse of the variance of the Range Ring measurements that were used to generate that particular Range Ring. Another example of a weighting may be a measure of the overall quality of the measurements that generated this Range Ring.


In addition, the range of α may be limited. In one case α is unrestricted; that is it is allowed to take any real value. In another case, α is limited in a manner defined by several factors including the wireless protocol being used, the type of terrain being considered, etc. In addition, one can also consider the case where α is limited by specifying its value to lie on a specific probability distribution.


In another case, the range of α can be limited by suitably applying a weighting function to a such that locations with small values for α are weighted more heavily—thus solutions with smaller values of α are picked in preference to solutions with large values of alpha. In such a case; equation [15] can be rewritten as:

min Σi=1nwi(Ri−α−Di)2π(α)  [15-a]

where the function π(α) is a weighting function. One example of such a weighting function would be shaped such that it is smallest where α is most likely, and largest where α is least likely. This forces the location to preferentially pick locations where α is smaller. By applying such a constraint on α, the location solution is constrained in a manner that reflects the expected accuracy of the range rings and the nature of the environment in which the location attempt is made.


In yet another method of constraining α, depending on the value of α, the location estimate can be guided towards a default location. A typical default location used in cellular geolocation is the location at 1 km on bore-sight from the serving site. Let this location be denoted by L. As the magnitude of alpha increases or the value of alpha that attempts to minimize equation [15] approaches an unlikely number, the location estimator can be driven towards point L. One method of forcing such a constraint within MREL is expressed in the following location determining function:

min[w0(α)R02i=1nwi(R−α−Di)2]  [15-b]

Here, the weight w0 is a function of α and R0 is the distance from the location estimate to the default location L. Since w0 is a function of a that has larger weight with increasing α, the resulting location is driven towards the default location L as either α increases in magnitude, or as a moves out of its most likely region.


It is not necessary that the observer location be collocated with the base station location. In one embodiment illustrated in FIG. 1, the observer LOBS 120 can be located at a known distance from the base station LBS 110. In this case, the Range Rings created are in the shape of ellipses rather than circles. One application of this embodiment is where the locations of the WLSs and the BTSs are not coincident as illustrated in FIG. 3. With reference to FIG. 3, there is no WLS (observer location) at the serving site BTS1300. There are WLSs at the sites BTS2310, BTS3320, and BTS4330. More generally there may be some observer locations with known coordinates and they may or may not be collocated with one or more BTSs.


For example, if the serving base station does 300 not have a co-located WLS, using the WLS at BTS2310, we can, in a manner completely analogous to equations [1] and [2], write the following equation:

tR2=tF+d1−f(P)+d2  [a1]


where,


tR2 is the arrival time of the signal (the observed time of receipt of a marker) transmitted from the mobile 340 and received at the observer location WLS coincident with BTS2310;


tF is the time of transmission of a marker on the downlink received at WLS at BTS2310, as described previously in association with equations [1] and [2];


d1 is the signal propagation time from the serving site 300 to the mobile 340; and


d2 is the signal propagation time from the mobile 340 to the WLS coincident with BTS2310.


It is important to note that tF can be measured even if one does not have an WLS collocated with the serving BTS: one simply observes the marker at some different WLS (WLS at BTS2310 in this example) and adjusts the time for the known distance between the serving BTS and the observing WLS. Alternately one observes the marker at multiple WLSs and takes an average of the observation times after adjusting for the known distances from each WLS to the serving site.


Note also that the observing WLS does not need to be coincident with BTS2310 and is only shown as an example in FIG. 3. The only requirement is that the observing WLS has known coordinates (a known location). Equation [a1] is the equation of an ellipse with foci located at the serving base station BTS1300 and the WLS located at BTS2310. This can be seen by re-writing equation [a1] as

d1+d2=tR2−tF+f(P)  [a2]


where the right hand side is a constant determined from the measurements and the determined value of f(P); d1 and d2 are the distances from two fixed points (the serving site location 300 and the WLS location 310) to the mobile 340. Similarly one can construct equations identical in form to [a2] with respect to the signal path from the serving site BTS1300 to all other observer locations (WLSs). For each such WLS one then obtains an ellipse as a locus (range ring) on which the mobile must be located. Thus the intersection of these elliptical loci defines the location of the mobile 340. That is, elliptical range rings can be constructed and their common intersection point or points will be the most likely location of the mobile.


With reference to FIG. 4, it can also be observed that the elliptical range rings offer a viable mobile location solution even when there is an WLS coincident with the location of the serving site BTS1400. In this case one of the ellipses 410, the ellipse corresponding to the signal path starting at the serving BTS1400 and ending at the WLS collocated with the serving BTS, collapses into a circle: a special case of an ellipse with equal minor and major axes. Thus the mobile 440 can be located at the intersection of one circle 410 centered at the serving BTS 400 and several ellipses 420, 430 and 450. Each of these ellipses has the serving site as one of its foci and an observing WLS 425, 435 and 445 respectively, as the other focus.


The present disclosure addresses the additional considerations when multipath is present by utilizing the same basic principles described above, bounded by additional constraints discussed below.


As discussed above, when clear line of sight signal paths exist between a transmitter and a set of receivers, the multipath component in the signal propagation is expected to be small. However in the majority of the situations that require location estimation, the more typical situation is that the environment is Non Line Of Sight (NLOS). This is particularly true in cities and other built-up environments. Transmitted signals arrive at a receiver along multiple paths and hence the determined propagation time is almost always in excess of the applicable LOS transmission time. In M. Silventionen and T. Rantalainen, Mobile Station Emergency Locating in GSM, Proc. IEEE Int. Conf Personal Wireless Communications, Vol. 1 (1996), 232-238, the authors consider the effect of NLOS error in measurements and concludes that the errors dramatically effect accuracy of standard location algorithms. Other prior art methods of dealing with NLOS signals are considered in and discussed in P.-C. Chen. A non-line-of-sight error mitigation algorithm in location estimation, Proc. IEEE Conf on Wireless Communications Networking, vol. 1 (1999), 316-320, and Xin Wang, Zongxin Wang and Bob O'Dea. A TOA-based Location Algorithm Reducing the Errors due to Non-Line-Of-Sight (NLOS) Propagation, IEEE Trans. Vehicular Technology., Vol. 52, no. 1 (January 2003), 112-116.


For the NLOS situation where multiple instances of Range Rings can be obtained over a short time interval, and within which the MS cannot move an appreciable distance, the best estimate of any particular Range Ring can be obtained by some means. For example, the median Range Ring for a given MS-WLS pair may be taken as the representative Range Ring for that pair. Alternatively, the representative Range Ring may be taken by clustering the available set of Range Rings for this MS-WLS pair and using the cluster with smallest distance. In any case, the final set of Range Rings has a single Range Ring for each MS-WLS pair. Note that if two or more tight clusters occur, the present disclosure can be used as follows to develop multiple Range Rings for a given MS-WLS pair.


Let this set of Range Rings be given by R where










R
=

[




R
1






R
2











R
k




]


,




[
16
]








where k is the number of geographically separated WLSs observing the MS. The WLS at the serving BS is included as a member in this set.


Let S denote the region over which the MS may be located. This region could, for example be the region enclosed by the set of WLSs or some expansion of this basic region. Now, for each point (x, y) in the region let Di(x, y) denote the distance from the point (x, y) to the ith WLS. Now let









D
=


[





D
1



(

x
,
y

)








D
2



(

x
,
y

)













D
k



(

x
,
y

)





]

.





[
17
]








Let α be a real number and βi a set of fixed non-positive real numbers. Then an optimal location for the mobile is determined as the location (x′, y′) such that the vector norm given by

R−A−D∥  [18]

is minimized, subject to the set of constraints that

{Ri−α−Di}≧βi,∀i,  [19]

in which the vector A is a vector of equal values in each position written as









A
=

[



α




α









α



]





[
20
]








and where the minimization is over all points (x, y) in the region S and over all real α or where α is constrained in some manner to a range of real numbers. In what follows we refer to the constraints of equation [19] as the “β constraints”.


Similar to the discussion above with respect to LOS, in the NLOS scenario, the Range Rings could have some uncertainty associated with them due to even a small error in estimating the transmission time at the MS. The parameter α, once again may be used to permit correction of this effect and also to possibly correct any error in the MSs implementation of the functional relationship ƒ(P) as well as compensating for multipath in the serving BS to MS path. Once these measurement inaccuracies have been addressed, the remaining error on the Range Rings is assumed to be Gaussian noise for the ideal case of LOS signals. As discussed previously, this noise is statistically limited by other quantities such as the power level of the signal, and is generally small. For example in the GSM protocol the associated error is of the order of a few tens of meters. Thus, for those Range Rings disturbed only by noise, the negative excursion on the measurement can vary from the correct value by at most a few tens of meters.


The positive excursion is unconstrained since multipath or NLOS propagation can extend the measurement, at least up to some high limit. This explains the use of the constraints applied by βi. It follows that applying this constraint is then equivalent to biasing the final solution for the estimated location in a manner that favors location estimates where the Range Rings with NLOS components are de-emphasized. The final estimated location is thus biased in such a manner that the corrected Range Rings, {Ri−α}, at any candidate solution, exhibit either the effect of Gaussian noise or a positive measurement excursion due to multipath (or NLOS signals) but no large negative excursion.


A simplified constraint may also be applied in general by using a single real non positive number β for each βi. In such a case, the assumption is that the variation in the measurements on the signals forming the Range Rings are approximately identical. In the general case though, it is better to apply different values of βi, which, in addition to being defined by varying power levels, can also be related to the particular WLS and its adjoining terrain. Note that it is also conceivable that there may be situations in a wireless environment where some signals are known to always have some minimal multipath such that it is statistically larger than the noise component. In such cases, it may be accurate to have some βi as small positive real numbers.


If a set of weights wi as used in the previous LOS section are available for use with each Range Ring, one could specify the method of location as determining

min Σi=1nwi(Ri−α−Di)2  [21]

subject to the requirement that

{Ri−α−Di}≧βi,∀i,  [22]

In addition, like in the LOS scenario, the range of α can be limited in the multipath scenario. In one case, α is unrestricted; that is it is allowed to take any real value. In another case, it is limited in a manner defined by several factors including the wireless protocol being used, the type of terrain being considered, etc. For example, in the GSM protocol and in a rural environment a could be limited to a maximum of 500 meters.


A further method of implementing the multipath mitigating constraints of equations [19] or [22] is by means of directly modifying the measurements within the objective function. In this method, measurements that exhibit a positive offset are unaffected but measurements that exhibit a negative offset are expanded. Thus the earlier mentioned β constraints of equations [19] and [22] can be implemented by applying such expansions of negative offsets. One such implementation is achieved by requiring the function to be minimized to have the following characterization:

min Σi=1nwi[g(Ri−α−Di)]2  [22-b]

A possible role for the function g(.) in equation [22-b] is to examine its argument, namely (Ri−α−Di), and if this argument is positive, not modify it. If the argument is negative, and depending how large the negative value is, the g(.) function will increase the negativity (i.e. make the negative number even more negative). The effect of such measurement adjustments is to force the function to pick a final selected location such that it has a multipath profile where most, if not all, measurements have positive bias.


In such cases as well, it is also possible to combine this with a weighting on the value of alpha, applying a weighting function as follows:

min Σi=1nwi[g(Ri−α−Di)]2π(α)  [22-c]

In [22-c] the function g(.) operates on its argument by examining the sign of (Ri−α−Di) and depending on the sign, operate as described in the previous paragraph. However, the function π(α) will further modify the expression by weighting it depending on the value of α. Typically large values of α will be made less likely in a solution by making π(α) large for such values. One example of such a weighting function would be shaped such that it is smallest where α is most likely, and largest where α is least likely. This forces the location to preferentially pick locations where α is smaller.


Alternately a dependency on the value of α can be achieved by using a function of the following form to determine the location:

min[w0(α)R02i=1nwi[g(Ri−α−Di)]2]  [22-d]

Here, the weight w0 is a function of α and R0 is the distance from the location estimate to a default location L. Since w0 is a function of a that has larger weight with increasing α, the resulting location is driven towards the default location L as either α increases in magnitude, or as α moves out of its most likely region. Thus in [22-d] the location now depends on the multipath profile, as captured by the operation of the function g(.), and also on α, the value of the adjustment.


Additionally, in all of the above methods of location estimation, and in all of the variety of location solutions which we have expressed as functions, it is also possible to apply different values of α to each measurement. For example, while minimizing any of the abovementioned functions, one can select the adjustment for a particular measurement, say the first measurement, as α1 and then depending on some other observation or calculation, choose the adjustments for the other measurements as α2, α3, . . . , αn. One possible method for deciding how to set such adjustments is to use the measurement variance as a guide. Then the sequence of adjustments α1, α2, . . . αn, can be taken in order of increasing variance where the adjustment is larger with larger variance. It should be clear to the informed reader that many such variations of how these adjustments are mutually related can be considered.


In all of these cases, it is also possible to make the function g(.) affect positive offsets or biases. For example, it can be made to treat all positive biases in excess of some number as equivalent. Then, in a typical example, a positive bias of 1 km or 5 km may result in the same function value. Intuitively what this does is to treat all multipath in excess of 1 km the same; there is no need to penalize such a measurement any more than it is already being penalized—the selected location becomes defined by the other measurements, not the one with large multipath. Thus the use of the g(.) function permits a flexible architecture for picking particular signal measurement profiles. These choices result in much improved location accuracy when multipath is present.


One of the primary purposes of the BETA algorithm as described above is to implement a specific technique for the mitigation of the effect of multipath in determining a location for the mobile device. As discussed above, BETA is implemented using a function g(.). The role of this function is to force the algorithm to preferentially select locations where the multipath profiles of the corrected measurements have positive rather than negative bias. The algorithm also corrects for other errors in the measurements using a parameter termed α. This parameter is ideally zero or a few meters. When α is non-zero, the algorithm guides the location estimate towards a default location. This default location, denoted PL may be picked in any arbitrary manner. For example the selected location PL could be at some prescribed distance along bore-sight from the serving site. The BETA algorithm may perform better than using the standard MREL algorithm without BETA, with the degree of improvement directly related to the prevalence of multipath in the operating environment.


A further enhancement of BETA is also described herein. In this case, different α values are used for different sites based on an indicator to the expected multipath on each signal. This case is denoted by using a vector of adjustments ζ in which each component applies to a specific site or signal. One possible indicator to the presence of multipath is the variance of the range measurements, and hence a particular implementation can use some function of the variance in making these adjustments.


In a specific embodiment of the present disclosure, let n denote the number of sites. Let the measured arrival times at the sites (sensors) be Ti, i=1, 2, . . . n . Let the determined time of transmission of the signal at the Mobile be tM (this determination being performed exactly as in the original MREL algorithm). We then compute a set of range rings corresponding to the sensors (LMU's or sites) as follows:

Ri=c(Ti−tM); i=1,2, . . . n  [23]

where c denotes the speed of light in free space.


Let (x, y) denote a current location for the mobile device, meaning that a sequence of estimates of the mobile location are made and (x, y) denotes an intermediary point in this process. The objective function of MREL BETA seeks to minimize the following function:











f


(

x
,
y
,
α

)


=



w
L



D
L
2


+




i
=
1

n





w
i



(

g


[


R
i

-
α
-

D
i


]


)


2




,




[
24
]








where Di is the distance from the point (x, y) to the site i,

Di=√{square root over ((x−xi)2+(y−yi)2))}{square root over ((x−xi)2+(y−yi)2))},  [25]

DL is the distance from the point (x, y) to the default location PL,

DL=√{square root over ((x−xL)2+(y−yL)2))}{square root over ((x−xL)2+(y−yL)2))},  [26]

the terms wi are some predetermined weights, and wL is a variable weight that is continually modified in the course of the location estimation process depending on the value of α at any instant of that process. For example,










w
L

=


(


1
C



(


[

α
F

]


2





N


)


)

.





[
27
]








In equation [27], F is a real number (for example 1.75), N is an integer (for example 4), C is a constant (for example 100). wL may be described more generally as a weight that has a shape inversely proportional to the probability that α takes a certain value. Such a probability distribution for α could have been obtained previously from examining the results when the MREL α algorithm was implemented in a particular environment. Alternatively wL can be selected based on laboratory experiments that determine the probability density function of α. The function g(.) has the general shape as illustrated in FIG. 5. The function g(.) has a slope equal to 1 in the first quadrant (with possibly some slightly higher or lower slope as the argument approaches zero). In the third quadrant g(.) has a slope that continues to increases as the argument decreases. The function g(.) is a particular method of implementing the β constraints described in this disclosure. The effect of g(.) is to change the measurements prior to the next iterative step of the iterative location search. Effectively, if the current (x, y, α) values correspond to certain biases in the measurements, it penalizes negative excursions by making them larger (negatively) while not penalizing positive excursions to the same extent. Thus, the candidate locations associated with the positive excursions can be weighted greater than the candidate locations associated with the negative excursions. The resultant effect is to then force the next location estimate to avoid such negative excursions in the measurements from appearing. This is how MREL BETA forces the final estimated location to exhibit positive bias measurements as would be apparent in any real-world environment.


The optimum location is obtained as










(


x
^

,

y
^

,

α
^


)

=

arg







min

x
,
y
,
α





[

f


(

x
,
y
,
α

)


]

.







[
28
]







On examining equation [24] it is found that the form of the minimization is ideally suited to the application of the Gauss-Newton non-linear least squares minimization technique. This technique can be implemented to find a solution to the problem. The technique requires the Jacobian matrix consisting of the partial derivatives of each sub-function of [24] with respect to x, y, and α. Let these sub-functions be denoted by

λi(x,y,α)=√{square root over (wi)}g(Ri−α−Di); i=1,2, . . . n,  [29]
λn+1(x,y,α)=√{square root over (wL)}DL  [30]


The terms in J are then obtained by taking the partial derivatives of λi with respect to x, y and α. Thus, for i=1, 2, . . . n ,











J


(

i
,
1

)


=



w
i





g
p



(


R
i

-
α
-

D
i


)




(



x
i

-
x


D
i


)



,




[
31
]








J


(

i
,
2

)


=



w
i





g
p



(


R
i

-
α
-

D
i


)




(



y
i

-
y


D
i


)



,




[
32
]









J(i,3)=−√{square root over (wi)}gp(Ri−α−Di),  [33]


where gp denotes the first derivative of the function g(.) with respect to its argument. That is, gp(.) is the slope of the function g(.) at the particular (x, y, α) point.


The final row of J (row n+1) is obtained by taking the partial derivatives of λn+1 with respect to x, y and α:











J


(


n
+
1

,
1

)


=



w
L




(



x
L

-
x


D
L


)



,




[
34
]








J


(


n
+
1

,
2

)


=



w
L




(



y
L

-
y


D
L


)



,




[
35
]







J


(


n
+
1

,
3

)


=


1

2



w
L






(




w
L




α


)




D
L

.






[
36
]







Vector Z can be defined as a vector containing the various function values at the current location. Then

Z=[√{square root over (w1)}g(R1−α−D1)
√{square root over (w2)}g(R2−α−D2)
√{square root over (w3)}g(R3−α−D3)
√{square root over (wn)}g(Rn−α−Dn)
√{square root over (wL)}DL]  [37]


The increment in the estimate of (x, y, α) can then be written as

Δ=[δxδyδα]  [38]
where
Δ=−(JTJ)−1JZ.  [39]


Thus if the current stage of the location process places at a current location (xk, yk, αk), the next location is then obtained iteratively as

xk+1yk+1αk+1=xkykαk−(JkTJk)−1JkZk,  [40]

where Jk, Zk are the evaluations of J and Z at the kth iterations. The iterations are continued until convergence occurs. The method described in the previous sections derives the presence of multipath indirectly. By observing the mismatch of the adjusted measurements in trying to find a candidate location for the mobile, the g(.) function adjusts the measurements within the algorithm to achieve a best solution where the multipath in the signals is removed or mitigated. While this technique has been shown to be efficacious in tests on real data, it is possible to further enhance this by removing multipath by the observation of certain characteristics of the signals. For example, by observing the arrival times of signals on multiple channels one can deduce that there is multipath in the channel. Whenever these arrival times have appreciable differences one can deduce the presence of multipath. In our investigation of real signals, another observation that has been found to point to multipath is signal timing variance. A majority of the time, when signals do exhibit large variance, an analysis of the data shows the presence of multipath. Hence it makes sense to include an adjustment to the measurements directly, in addition to the algorithmic adjustment made in the previously described BETA features.


This can be implemented by modifying equation [24] as follows:











f


(

x
,
y
,

ζ
_


)


=



w
L



D
L
2


+




i
=
1

n





w
i



(

g


[


R
i

-

ζ
_

-

D
i


]


)


2




,




[
41
]








where ζ is now a vector adjustment. A location solution is found where the function is minimized.


One possible implementation of this is to make the following setting:

ζ(j)=α,

where α is as described previously and j is the minimum variance measurement. Now with ζ(j) as a guide, all of the other elements in the vector ζ can be generated based on a determination of the multipath on every other signal. For example, one can use the variance ratio between the minimum variance site j and any other site k to appropriately determine the value of ζ(k) that should be applied. Likewise, any other technique of ascertaining the presence of multipath can also be used to create the mapping from the adjustment to a particular measurement, as given by α and the adjustments to the other measurements filling out the vector ζ. More generally, equation [41] can be implemented independent of any tie in to the description of the previous sections. Equation [41] can be interpreted as seeking the best set of different adjustments to the measured ranges R in conjunction with the further finer adjustment provided by the g(.) function, which can be considered as mutually constraining the values in the ζ vector. That is, the adjustment vector is constrained by a non-linear function h(.) such that

h(ζ)=0.  [42]

In this formulation, one searches the space of ζ adjustments with mutual constraints on the values in ζ seeking a minimizing value of [41]. If one were to interpret the variance based technique described earlier using this formulation, the specific measurement variances constrain how much difference exists between the different values in ζ, and this establishes the mutual constraint on the ζ values. An implementation of this algorithm would then have a much larger number of variables than equation [41]: two variables for the location and as many other variables as there are ranges in R


The use of MREL to determine location of the MS is significantly different than the use of TDOA to determine location. For example, in TDOA location, there is no attempt made to determine the time of transmission from the MS. MREL on the other hand requires a determination of the MS transmit time so that it can function appropriately. In addition, because the MS transmit time is unknown in TDOA, there is no option but to subtract individual arrival times at WLSs so that the unknown MS transmit time is eliminated. For example, if the set of measured arrival times of a signal at a given set of WLSs is T, then the first operation on T is to eliminate the unknown MS transmit time by multiplying T by a differencing matrix H to generate

Tdiff=H*T  [23]

in which










H
=

[



1



-
1



0


0





0


0




0


1



-
1



0





0


0





























0


0


0


0





1



-
1




]


,




[
24
]








is the differencing matrix that generates pair-wise difference terms. Permutations of the matrix H may also be used where each row has a single +1 term, a single −1 term and all other terms are zero. In contrast MREL has no differencing stage since the propagation time information is vital and thus requires retaining the MS's transmission time. If for example TDOA was applied to the Range Ring estimates, the first stage would have been to generate H*R. Clearly this is not the case in MREL where if this were done the MS transmission time information is lost.


Another significant difference is that if the location problem involves n WLSs, the MREL technique generates n surfaces. In one embodiment, each of these surfaces is a circle defined by

{[Ri−α=Di]}; i=1, 2, . . . n.  [25]

TDOA location on the other hand generates n−1 surfaces

Tdiff,i=hi; i=1, 2, . . . (n−1)  [26]

where each surface is a hyperbola defined by a constant h.


Another difference is that the MREL surfaces being circles or ellipses are much better constrained geometrically than TDOA location which uses hyperbolae (which extend to infinity at their tails). The MREL surfaces, being one more in number than the TDOA surfaces have reduced ambiguity. This can clearly be seen with reference to FIG. 2. In this case, there is a collocated WLS at the serving base station. Three WLSs 200, 210, 220 produce the three circles constituting MREL surfaces 205, 215, 225 intersect in a single point 230 which is the correct location of the MS. In contrast, the hyperbolae generated as TDOA surfaces 240, 250, 260 have two points of intersection 230 and 270. Also note that with three WLSs there are only two independent hyperbolic surfaces, whereas all three hyperbolic surfaces have been plotted to show that the intersections common to the first two independent hyperbolae are unaltered when the third dependent hyperbola is introduced. The main observation is that there is no ambiguity when MREL surfaces are used, whereas there is ambiguity (i.e. is the solution 230 or 270?) when TDOA location is applied.


Another significant difference is that the TDOA location method is weak in its ability to functionally address the problem of multipath because it starts by considering the difference of two arrival times. Once the difference of two arrival times is generated, a constraint βi such as applied in MREL, is inapplicable since the differenced terms show no multipath bias in either a positive or negative direction. That is, the TDOA surfaces could be equally extended in the positive or negative direction. In addition, the TDOA location scheme offers no equivalent to the limitation on the range of α as specified for MREL. The effect of such a limitation is to constrain the solution further by the available measurements. In a TDOA implementation, such a limitation on the Range Rings would be masked by the fact that time differences of arrival times are obtained, and where such differencing effectively negates the possibility of excluding certain arrival times measurements.


Another significant difference is that if ƒ(P) is implemented differently from what is assumed, that is the MS implements either an incorrect value of P or applies ƒ(P) in some manner divergent from the expected value, then tM will be incorrect, potentially affecting all Range Rings, but doing so equally in a manner that can be mitigated using α. On the other hand, NLOS behavior on the serving link can cause tM to be different from what it would be if the link were LOS. It will however be computed properly in that the computed value matches the actual value. In this case, if the other links from the MS to other WLSs were LOS, such Range Rings would be computed correctly. That is, the serving Range Ring will be magnified but other Range Rings will be unaffected. This should be contrasted with TDOA location where NLOS behavior on the serving link, assuming this is the link with respect to which the TDOA hyperbolas are constructed, will affect all hyperbolas.


The previous sections considered the general case of generating a representative Range Ring for each MS-WLS pair over a period of time referred to as a collect. Each such collect involves a sequence of estimates for each Range Ring, and the sequence of Range Rings is finally reduced to a representative Range Ring. The individual estimation periods are referred to as time slots. For example if Rij is the Range Ring associated with WLS i within time slot j, the final Range Ring Ri associated with WLS i and the MS over the entire collect is given by

Ri=g(Rij),  [27]

where g(.) is the function that reduces this set of values Rij to a single Range Ring Ri. For example g(.) could be the median of the set, the mean of the set, or in general any specified function of the set Rij. Once a particular Ri is determined for each WLS, the location determination follows as described in previous sections.


However, several other embodiments of this sequence of processing can be implemented. For example, in one embodiment, an estimated location for the MS can be determined in each slot. A final location can them be determined over all slots by suitably combining the individual estimates in some manner. For example the individual estimates can be clustered and the cluster centroid can be defined as the final location. In another embodiment, a quality measure associated with each such estimate can be used to weight and sum the individual location estimates. In yet another embodiment, a method can be used to extract the location estimates associated with smaller values of the final α, given by {circumflex over (α)}, and combine these estimates to produce the final location. A final low value of α serves as an indicator that the set of Range Rings used in this location are in agreement and also that the Range Rings themselves are good estimates. This combination of qualities makes such a selection highly likely to result in an accurate location estimate.


In another embodiment, the location estimation techniques of the previous sections can be combined to directly generate a location estimate. One method for doing so can be written as











min


α
_

,
x
,
y






j





i



{



w
ij



(


R
ij

-

α
j

-

D
ij


)


2

}




,




[
28
]








where wij is the applied weighting on the ith Range Ring of the jth slot, and subject to the requirement that

{Rij−αj−Dij}≧βij,∀i,j  [29]

and where







α
_

=


[




α
1






α
2











α
j











α
k




]

.





In another embodiment, any of the methods described here for using a set of Range Rings to generate a location estimate may be enhanced by examining properties of the location process. When a location estimate is generated, the set of ({circumflex over (α)}, {circumflex over (x)}, ŷ) minimizes the function of interest (Eqns: 11, 13, 14, 17, 20, 23). Various measures of the estimated location ({circumflex over (x)}, ŷ) can be defined:


For example, the set

{Ri−{circumflex over (α)}−Di}

can be examined. Each element of this set is indicative of the agreement of the location estimate with the original measurements. This set, viewed as a vector is thus called a mismatch vector. If the magnitude of some of these elements is significantly larger than some of the other elements, subsets of the original set of Range Rings can be used to generate new location estimates. The first case corresponds to where there is a large mismatch. If such secondary estimates result in a smaller mismatch, such a secondary estimate with low mismatch may be used to define a revised location estimate.


By way of another example, the locations generated by all the different subsets of the original set of Range Rings can be clustered. Doing so, it can be determined which subset of Range Rings define the best cluster. This best cluster can be defined by various measures such as the tightness of the cluster, the number of members, a function of the Circular Error Probable (CEP) for the locations in the cluster, a function of the values of {circumflex over (α)} for the locations in the cluster, etc. Once the appropriate cluster is selected, the centroid of this cluster can be defined as the final estimated location.


In one embodiment, a method for improving the transmission time estimate can be used. The estimation of the transmission time, tF at the serving BS can be obtained by observing the transmitted signal at a single observer location Lobs as described previously. Often, Lobs is co-located at the serving BS location. However, even if it is not, provided the distance between Lobs and the serving BS is known, tF can be estimated as the time at which a marker on the downlink is observed at Lobs and subtracting the propagation time required for the signal to traverse the distance from the serving BS to Lobs.


Because this estimate can be corrupted by multipath or NLOS behavior of the path between the serving BS and Lobs, the present disclosure can attempt to mitigate the corruption caused by the multipath. One method of achieving this is to observe the downlink at more than one WLS. If the downlink is observed at WLS1, WLS2, WLSm, the known (computed since the distances are known) propagation times from the serving BS to each of these WLSs is tp1, tp2, . . . , tpm and the observed times at which the marker is observed on the downlink at each of these WLSs be tO1, tO2, . . . , tOm. Then the actual transmission time, as observed by these observers is given by the vector










t
F

=


[





t

O





1


-

t

p





1









t

O





2


-

t

p





2














t

O





m


-

t
pm





]

.





[
30
]








A final estimate of the transmission time tF can be obtained as a function of the vector tF. One possibility is to use the mean of the vector. Another method would be to use the median. Since multipath can only extend the propagation times, another option would be to set tF as the minimum of the vector, provided that all measurements in the vector have high quality.


It was previously described how the MREL method could be implemented in a GSM protocol. However, the disclosure is equally applicable to other protocols as well. For example, the generation of Range Rings for the Universal Mobile Telecommunication System (UMTS) fits the general framework described above. The relevant marker M1 in this case can be taken as the Downlink Dedicated Physical Channel (F-DPCH) frame marker and the marker M2 can be taken as the Uplink Dedicated Physical Channel (DPCH) frame marker. P is the Timing Window Parameter. With this interpretation, the function ƒ(P) is given by

ƒ(P)=−(1024+P)*Tc  [31]

where


P is the Timing Window Parameter in the range [0-148] and


Tc is 26.042 microseconds.


The value of ƒ(P) referred to in the standards as the UE Rx-Tx time difference is reported by the MS. Unlike the case of GSM, where the TA parameter is transmitted by the BS with the understanding that the Mobile should implement the corresponding ƒ(P), in the case of UMTS the MS's objective is to always aim for a value of P=0 and thus ƒ(P)=−1024. This is not readily achieved at all times, such as during a handover, where the MS is adjusting from one serving BS to another. The actual ƒ(P), where P is non-zero, is thus reported back to the BS. With the knowledge of ƒ(P), the calculation of the Range Rings can proceed as described above.


In the WiMAX wireless protocol, the MS reports the Round Trip Delay (TRTD) and the Relative Delay (TRD) where the first parameter is with respect to the anchor BS, and the second is with respect to other neighboring BSs. Let the values of Relative Delay with respect to neighbor BSs 2, 3, . . . k be given by TRDj. Then the Range Ring with respect to the anchor BS can be written as R1=0.5*TRTD while the Range Ring with respect to neighbor BS j can be written as

Rj=TRDj+R1; {j=2, 3, . . . k}  [32]

With the Range Rings determined in this manner the methods for determining location as described above can be applied.


In the case of the CDMA protocol, the downlink transmissions are synchronous to Global Positioning System (GPS) time. Additionally, this time reference is conveyed to the MS via the downlink of the serving BS. The Mobile time reference is thus a delayed version of the BS time reference with this delay being exactly the propagation delay from the BS to the MS. When the MS transmits, it uses its own delayed time reference to adjust the Pseudo-Noise (PN) code phases. A WLS collocated with the serving BS can thus determine the BS-MS propagation time R1 as one half of the overall time difference between the downlink PN code phase and the received uplink PN code phase. This is then the applicable Range Ring for the Mobile Serving BS path. Additionally, WLSs located elsewhere can observe the uplink PN code phase. If WLSj receives this uplink code phase at time tj, and the WLS at the serving BS observes the Downlink code phase at time tF, then one can write the Range Ring Rj as

Rj=tj−tF−R1; {j=2, 3, . . . k}  [33]

With the Range Rings determined in this manner the methods for determining location as described above can be applied.


It may be emphasized that the above-described embodiments, particularly any “preferred” embodiments, are merely possible examples of implementations, merely set forth for a clear understanding of the principles of the disclosure. Many variations and modifications may be made to the above-described embodiments of the disclosure without departing substantially from the spirit and principles of the disclosure. All such modifications and variations are intended to be included herein within the scope of this disclosure and the present disclosure and protected by the following claims Embodiments of the subject matter and the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Embodiments of the subject matter described in this specification can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a tangible program carrier for execution by, or to control the operation of, data processing apparatus. The tangible program carrier can be a propagated signal or a computer readable medium. The propagated signal is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal that is generated to encode information for transmission to suitable receiver apparatus for execution by a computer. The computer readable medium can be a machine-readable storage device, a machine-readable storage substrate, a memory device, a composition of matter affecting a machine-readable propagated signal, or a combination of one or more of them.


The term “data processing apparatus” encompasses all apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, or multiple processors or computers. The apparatus can include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them.


A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, or declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.


The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit).


Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read only memory or a random access memory or both. The essential elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto optical disks, or optical disks. However, a computer need not have such devices. Moreover, a computer can be embedded in another device, e.g., a mobile telephone, a personal digital assistant (PDA), a mobile audio or video player, a game console, a Global Positioning System (GPS) receiver, to name just a few.


Computer readable media suitable for storing computer program instructions and data include all forms of non volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto optical disks; and CD ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.


To provide for interaction with a user, embodiments of the subject matter described in this specification can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, input from the user can be received in any form, including acoustic, speech, or tactile input.


Embodiments of the subject matter described in this specification can be implemented in a computing system that includes a back end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described is this specification, or any combination of one or more such back end, middleware, or front end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.


The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.


While this specification contains many specifics, these should not be construed as limitations on the scope of any invention or of what may be claimed, but rather as descriptions of features that may be specific to particular embodiments of particular inventions. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.


Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.


Although a few embodiments have been described in detail above, other modifications are possible. Other embodiments may be within the scope of the following claims.

Claims
  • 1. A method of determining the location of a mobile device in a network having a plurality of bases stations, in which a base station communicates with the mobile device in a downlink transmission and the mobile device communicates with a base station in uplink transmission, comprising the steps of: (a) receiving signals transmitted by the mobile device at a plurality of sensors;(b) for each sensor: (i) estimating a range between the mobile device and the sensor as a function of the received signal;(ii) estimating an error associated with the received signal at the sensor;(iii) determining a distance between the sensor and a candidate location of the mobile device;(iv) comparing the estimated range adjusted by the estimated error to the determined distance to the candidate location; and(v) weighting the candidate location as a function of the comparison, wherein the weighting is greater for the case when the estimated range adjusted by the estimated error is greater than the determined distance to the candidate location than for the case when the estimated range adjusted by the estimated error is less than the determined distance to the candidate location;and(c) estimating the location of the mobile as a function of the weighted candidate solutions.
  • 2. The method of claim 1 further comprising the step of weighting the estimated range as a function of the magnitude of the difference between the estimated range adjusted by the estimated error and the determined distance to the candidate location.
  • 3. The method of claim 1 wherein the estimated error is determined as a function of at least one of timing errors, wireless protocol, type of terrain, and presence of multipath.
  • 4. The method of claim 1 wherein the estimated error is weighted.
  • 5. The method of claim 1 wherein the estimated error is constrained.
  • 6. The method of claim 1 wherein the estimated error for each estimated range is the same.
  • 7. The method of claim 1 wherein the candidate location of the mobile device is based on downlink signals received by the mobile device.
  • 8. The method of claim 1 wherein the candidate location of the mobile device is based on uplink signals received by the mobile device.
  • 9. The method of claim 1 wherein the candidate location of the mobile device is based on GPS signals.
Parent Case Info

The present application is a divisional application of U.S. patent application Ser. No. 13/051,911 titled “System and Method for Multiple Range Estimation Location” filed on 18 Mar. 2011 which is itself a continuation-in-part of U.S. patent application Ser. No. 12/292,821 filed 26 Nov. 2008 titled “System and Method for Multiple Range Estimation Location”. Each of the foregoing applications is hereby incorporated herein by reference.

US Referenced Citations (191)
Number Name Date Kind
3150372 Groth, Jr. Sep 1964 A
3659085 Potter et al. Apr 1972 A
4728959 Maloney Mar 1988 A
4814751 Hawkins Mar 1989 A
4845504 Roberts et al. Jul 1989 A
4891650 Sheffer Jan 1990 A
5056106 Wang et al. Oct 1991 A
5218618 Sagey Jun 1993 A
5317323 Kennedy et al. May 1994 A
5327144 Stilp et al. Jul 1994 A
5365544 Schilling Nov 1994 A
5372144 Mortier et al. Dec 1994 A
5404376 Dent Apr 1995 A
5423067 Manabe Jun 1995 A
5465289 Kennedy Nov 1995 A
5506863 Meidan et al. Apr 1996 A
5506864 Schilling Apr 1996 A
5508708 Ghosh et al. Apr 1996 A
5512908 Herrick Apr 1996 A
5515419 Sheffer May 1996 A
5519760 Borkowski et al. May 1996 A
5559864 Kennedy Sep 1996 A
5592180 Yokev et al. Jan 1997 A
5608410 Stilp et al. Mar 1997 A
5614914 Bolgiano et al. Mar 1997 A
5675344 Tong et al. Oct 1997 A
5736964 Ghosh et al. Apr 1998 A
5815538 Grell et al. Sep 1998 A
5825887 Lennen Oct 1998 A
5870029 Otto et al. Feb 1999 A
5920278 Tyler et al. Jul 1999 A
5952969 Hagerman et al. Sep 1999 A
5959580 Maloney et al. Sep 1999 A
5960341 LeBlanc et al. Sep 1999 A
5973643 Hawkes et al. Oct 1999 A
5987329 Yost Nov 1999 A
6014102 Mitzlaff et al. Jan 2000 A
6047192 Maloney Apr 2000 A
6091362 Stilp Jul 2000 A
6097336 Stilp Aug 2000 A
6097709 Kuwabara Aug 2000 A
6097959 Yost Aug 2000 A
6101178 Beal Aug 2000 A
6108555 Maloney et al. Aug 2000 A
6108558 Vanderspool, II Aug 2000 A
6115599 Stilp Sep 2000 A
6115605 Siccardo et al. Sep 2000 A
6119013 Maloney et al. Sep 2000 A
6127975 Maloney Oct 2000 A
6144711 Raleigh et al. Nov 2000 A
6172644 Stilp Jan 2001 B1
6184829 Stilp Feb 2001 B1
6188351 Bloebaum Feb 2001 B1
6191738 Pfeil et al. Feb 2001 B1
6201499 Hawkes et al. Mar 2001 B1
6201803 Munday et al. Mar 2001 B1
6212319 Cayrefourcq Apr 2001 B1
6233459 Sullivan et al. May 2001 B1
6246884 Karmi et al. Jun 2001 B1
6266013 Stilp et al. Jul 2001 B1
6269246 Rao et al. Jul 2001 B1
6281834 Stilp Aug 2001 B1
6285321 Stilp et al. Sep 2001 B1
6288675 Maloney Sep 2001 B1
6288676 Maloney Sep 2001 B1
6295455 Fischer et al. Sep 2001 B1
6311043 Haardt et al. Oct 2001 B1
6317081 Stilp Nov 2001 B1
6317604 Kovach, Jr. et al. Nov 2001 B1
6334059 Stilp et al. Dec 2001 B1
6351235 Stilp Feb 2002 B1
6366241 Pack Apr 2002 B2
6388618 Stilp et al. May 2002 B1
6393294 Perez-Breva et al. May 2002 B1
6400320 Stilp et al. Jun 2002 B1
6407703 Minter et al. Jun 2002 B1
6449486 Rao Sep 2002 B1
6463290 Stilp et al. Oct 2002 B1
6470195 Meyer Oct 2002 B1
6477161 Hudson Nov 2002 B1
6483460 Stilp et al. Nov 2002 B2
6492944 Stilp Dec 2002 B1
6501955 Durrant et al. Dec 2002 B1
6519465 Stilp et al. Feb 2003 B2
6546256 Maloney Apr 2003 B1
6553322 Ignagni Apr 2003 B1
6563460 Stilp et al. May 2003 B2
6571082 Rahman May 2003 B1
6591112 Siccardo et al. Jul 2003 B1
6603428 Stilp Aug 2003 B2
6603761 Wang Aug 2003 B1
6640106 Gutowski et al. Oct 2003 B2
6646604 Anderson Nov 2003 B2
6661379 Stilp et al. Dec 2003 B2
6765531 Anderson Jul 2004 B2
6771625 Beal Aug 2004 B1
6771969 Chinoy Aug 2004 B1
6782264 Anderson Aug 2004 B2
6782265 Perez-Breva et al. Aug 2004 B2
6834234 Scherzinger et al. Dec 2004 B2
6839539 Durrant et al. Jan 2005 B2
6845240 Carlson et al. Jan 2005 B2
6859172 Powers et al. Feb 2005 B2
6871077 Kennedy, Jr. Mar 2005 B2
6873290 Anderson et al. Mar 2005 B2
6876859 Anderson et al. Apr 2005 B2
6920329 Kennedy, Jr. et al. Jul 2005 B2
6922170 Alexander, Jr. Jul 2005 B2
6944465 Spain et al. Sep 2005 B2
6952158 Kennedy, Jr. Oct 2005 B2
6987979 Carlsson Jan 2006 B2
6996392 Anderson Feb 2006 B2
7023383 Stilp et al. Apr 2006 B2
7116987 Spain, Jr. et al. Oct 2006 B2
7167713 Anderson Jan 2007 B2
7167714 Dressler et al. Jan 2007 B2
7233799 Spain, Jr. Jun 2007 B2
7250907 Krumm et al. Jul 2007 B2
7257414 Spain, Jr. et al. Aug 2007 B2
7271765 Stilp et al. Sep 2007 B2
7340259 Maloney Mar 2008 B2
7383051 Spain, Jr. et al. Jun 2008 B2
7427952 Bull et al. Sep 2008 B2
7433652 Durgin Oct 2008 B2
7433695 Gordon et al. Oct 2008 B2
7440762 Maloney et al. Oct 2008 B2
7460505 Spain Dec 2008 B2
7593738 Anderson Sep 2009 B2
7725111 Dressler et al. May 2010 B2
7734298 Bhattacharya et al. Jun 2010 B2
7753278 Spain, Jr. et al. Jul 2010 B2
7796966 Bhattacharya et al. Sep 2010 B2
7848762 Gordon et al. Dec 2010 B2
7899467 Feuerstein et al. Mar 2011 B2
8013785 Bhattacharya et al. Sep 2011 B2
8068802 Bhattacharya et al. Nov 2011 B2
8068855 Dressler et al. Nov 2011 B2
8106817 Bhattacharya et al. Jan 2012 B2
8106818 Bhattacharya et al. Jan 2012 B2
8155394 Allegra et al. Apr 2012 B2
20010046870 Stilp et al. Nov 2001 A1
20020132624 Watanabe et al. Sep 2002 A1
20020172223 Stilp et al. Nov 2002 A1
20030064734 Stilp et al. Apr 2003 A1
20030129993 Overy et al. Jul 2003 A1
20030139188 Chen et al. Jul 2003 A1
20030181163 Ofuji et al. Sep 2003 A1
20030190919 Niemenmaa Oct 2003 A1
20030203738 Brown et al. Oct 2003 A1
20040002344 Moeglein et al. Jan 2004 A1
20040043775 Kennedy, Jr. et al. Mar 2004 A1
20040132466 Kennedy, Jr. et al. Jul 2004 A1
20040203380 Hamdi et al. Oct 2004 A1
20040203539 Benes et al. Oct 2004 A1
20040203921 Bromhead et al. Oct 2004 A1
20040218664 Kennedy, Jr. et al. Nov 2004 A1
20040252752 Kennedy, Jr. et al. Dec 2004 A1
20050003831 Anderson Jan 2005 A1
20050058182 Kennedy, Jr. et al. Mar 2005 A1
20050136945 Kennedy, Jr. et al. Jun 2005 A1
20050164712 Kennedy, Jr. et al. Jul 2005 A1
20050192026 Carlson et al. Sep 2005 A1
20050255865 Sillasto et al. Nov 2005 A1
20060003695 Kennedy, Jr. et al. Jan 2006 A1
20060003775 Bull et al. Jan 2006 A1
20060030333 Ward et al. Feb 2006 A1
20060116130 Kennedy, Jr. et al. Jun 2006 A1
20060125695 Kennedy, Jr. et al. Jun 2006 A1
20060141998 Kennedy, Jr. et al. Jun 2006 A1
20060154607 Kennedy, Jr. et al. Jul 2006 A1
20060240836 Kennedy, Jr. et al. Oct 2006 A1
20070087689 Kennedy, Jr. et al. Apr 2007 A1
20070111746 Anderson et al. May 2007 A1
20070155401 Ward et al. Jul 2007 A1
20070155489 Beckley et al. Jul 2007 A1
20070202885 Kennedy, Jr. et al. Aug 2007 A1
20080132244 Anderson et al. Jun 2008 A1
20080132247 Anderson et al. Jun 2008 A1
20080137524 Anderson et al. Jun 2008 A1
20080158059 Bull et al. Jul 2008 A1
20080160952 Bull et al. Jul 2008 A1
20080160953 Mia et al. Jul 2008 A1
20080161015 Maloney et al. Jul 2008 A1
20080248811 Maloney et al. Oct 2008 A1
20080261611 Mia et al. Oct 2008 A1
20080261612 Mia et al. Oct 2008 A1
20080261613 Anderson et al. Oct 2008 A1
20080261614 Mia et al. Oct 2008 A1
20090005061 Ward et al. Jan 2009 A1
20090310585 Alizadeh-Shabdiz Dec 2009 A1
20100136999 Kim et al. Jun 2010 A1
Foreign Referenced Citations (4)
Number Date Country
06-347529 Dec 1994 JP
2006088472 Aug 2006 WO
2008017034 Feb 2008 WO
2011016805 Feb 2011 WO
Non-Patent Literature Citations (39)
Entry
Rick Roberts, “Project: IEEE P802.15 Working Group for Wireless Personal Area Networks (WPANS),” Harris Corporation, Melbourne Florida, Oct. 4, 2004, pp. 1-11.
Stephanie Bell, A Beginners Guide to Uncertainty of Measurement, The National Physics Laboratory of the United Kingdom of Great Britain and Northern Ireland, Teddington, Middlesex, UK, 2001, pp. 1-41.
Y. Zhao, “Standardization of Mobile Phone Positioning for 3G Systems,” IEEE Communications Magazine, Jul. 2002, pp. 108-116.
C. Drane, M. MacNaughtan, and C. Scott, “Positioning GSM Telephones,” IEEE Communications Magazine, Apr. 1998, pp. 46-54, 59.
J. Caffery, Jr., and G. Stuber, “Overview of Radiolocation in CDMA Cellular Systems,” IEEE Communications Magazine, Apr. 1998, pp. 38-45.
T. Rappaport, J.H. Reed and B.D. Woerner, “Position Location Using Wireless Communications on Highways of the Future,” IEEE Communications Magazine, Oct. 1996, pp. 33-41.
I. Ziskind and M. Wax, “Maximum Likelihood Localization of Multiple Sources by Alternating Projection,” IEEE Transactions on Acoustics, Speech, and Signal Porcessing, vol. 36, No. 10, pp. 1553-1560, Oct. 1988.
G.W.K. Colman, “A Comparison of the Accuracy of TDOA and TOA Location Algorithms with Equivalent Receiver Geometry,” Defence R&D Canada Technical Memorandum (DREO TM 2001-063), Oct. 2001, pp. 1-53.
L. Mailaender, “On the Geolocation Bounds for Round-Trip Time-of-Arrival and All Non-Line-of-Sight Channels”, EURASIP Journal on Advances in Signal Processing, vol. 2008, pp. 1-10.
N. Agarwal, L. Chaudran-Wadi, and V. Apte, “Capacity Analysis of the GSM Short Message Service”, Indian Institute of Technology Bombay, www.cse.iitb.ac.in/˜varsha/allpapers/wireless/ncc03cam.pdf, 2004, pp. 1-5.
J.D. Bard, and P.M. Ham, “Time Difference of Arrival Dilution of Precision and Applications,” IEEE Transactions on Signal Processing, vol. 47, No. 2, pp. 521-523, Feb. 1999.
K.C. Ho, and W. Xu, “An Accurate Algebraic Solution for Moving Source Location Using TDOA and FDOA Measurements”, IEEE Transactions on Signal Processing, vol. 52, No. 9, Sep. 2004, pp. 2453-2463.
C.H. Knapp and G.C. Carter, “The Generalized Correlation Method for Estimation of Time Delay,” IEEE Transactions on Acoustics, Speech, and Signal Processing, vol. ASSP-24, No. 4, Aug. 1976, pp. 320-327.
M. Rahnema, “Overview of the GSM System and Protocol Architecture,” IEEE Communications Magazine, Apr. 1993, pp. 92-100.
S. Stein, “Algorithms for Ambiguity Function Processing,” IEEE Transactions on Acoustics, Speech, and Signal Processing, vol. ASSP-29, No. 3, Jun. 1981, pp. 588-599.
M. Vanderveen, C.B. Papadias, and A. Paulraj, “Joint Angle and Delay Estimation (JADE) for Multipath Signals Arriving at an Antenna Array”, IEEE Communications Letters, vol. 1, No. 1, Jan. 1997, pp. 12-14.
M. Wax and I. Ziskind, “On Unique Localization of Multiple Sources by Passive Sensor Arrays,” IEEE Transactions on Acoustics, Speech, and Signal Processing, vol. 37, No. 7, Jul. 1989, pp. 996-1000.
B. Yang, “Projection Approximation Subspace Tracking,” IEEE Transactions on Signal Processing, vol. 43, No. 1, Jan. 1995, pp. 95-107.
Amir Leshem, Mati Wax, “Array Calibration in the Presence of Multipath,” IEEE Transactions on Signal Processing, vol. 48, No. 1, pp. 53-59, Jan. 2000.
Xin Wang, Zongxin Wang and Bob O'Dea, “A TOA-Based Location Algorithm Reducing the Errors Due to Non-Line-of-Sight (NLOS) Propagation,” IEEE Trans. Vehicular Technology, vol. 52, No. 1, Jan. 2003, pp. 112-116.
M. Vanderveen, C. Papadias, A. Paulraj, “Joint Angle and Delay Estimation (JADE) for Multipath Signals Arriving at an Antenna Array,” IEEE Communications Letters, vol. 1, No. 1, Jan. 1997, pp. 12-14.
R. Schmidt, “Multiple Emitter Location and Signal Parameter Estimation,” IEEE Transactions on Antennas and Propagation, vol. AP-34, No. 3, Mar. 1986, pp. 276-280.
Y. Chen, M. Zoltowski, “Joint Angle and Delay Estimation for DS-CDMA with Application to Reduced Dimension Space-Time Rake Receivers,” Mar. 1999, pp. 2933-2936.
A.J. Paulraj, C.B. Papadias, “Space-Time Processing for Wireless Communications”, IEEE Signal Processing Magazine, vol. 11, Nov. 1997, pp. 49-83.
C.B. Papadias, A.J. Paulraj , “Space-Time Signal Processing for Wireless Communications: A Survey”, Information Systems Laboratory, Stanford University, Apr. 16-18, 1997, 4pages.
M. Haardt, C. Brunner, J. Nossek, “Joint Estimation of 2-D Arrival Angles, Propagation Delays, and Doppler Frequencies in Wireless Communications,” Proc. IEEE Digital Signal Processing Workshop, vol. 1, pp. 1-4, Bryce Canyon National Park, Utah, Aug. 1998.
Mati Wax, “Position Location from Sensors with Position Uncertainty,” IEEE Transactions Aerospace and Electronic Systems, vol. AES-19, No. 5, Sep. 1983, pp. 658-662.
D.J. Torrieri, “Statistical Theory of Passive Location Systems”, IEEE Transactions Aerospace and Electronic Systems, vol. AES-20, No. 2, Mar. 1984, pp. 183-198.
Y.T. Chan and K.C. Ho, “A Simple and Efficient Estimator for Hyperbolic Location”, IEEE Transactions Signal Processing, vol. 42, No. 8, Aug. 1994, pp. 1905-1915.
W.H. Foy, “Position-Location Solutions by Taylor-Series Estimation”, IEEE Transactions Aerospace and Electronic Systems, vol. AES-12, No. 2, Mar. 1976, pp. 187-194.
R.G. Stansfield, “Statistical Theory of DF Fixing”, Journal IEEE 94, Part III A, Oct. 1947, pp. 762-770.
M.P. Wylie and J. Holtzman, “The Non-Line of Sight Problem in Mobile Location Estimation”, Process IEEE 5th International Conference on Universal Personal Communications, vol. 2, Oct. 1996, pp. 827-831.
L.Cong and W. Zhuang, “Non-Line-of-Sight Error Mitigation in TDOA Mobile Location”, Process IEEE Global Telecommunications Conference, vol. 1, Sep. 2001, pp. 680-684.
P.C. Chen, “A Non-Line-of-Sight Error Mitigation Algorithm in Location Estimation”, Process IEEE Conference on Wireless Communications Networking, vol. 1, 1999, pp. 316-320.
N. J. Thomas, D.G.M. Cruickshank and D.I. Laurenson, “Performance of a TDOA-AOA Hybrid Mobile Location System”, 3G Mobile Communication Technologies, Conference Publication No. 477, Mar. 2001, pp. 216-220.
J. Caffery, Jr., and G. Stuber, “Subscriber Location in CDMA Cellular Networks,” IEEE Transactions on Vehicular Technology, vol. 47, No. 2, May 1998, pp. 406-416.
J. Caffery. Jr., “A New Approach to the Geometry of TOA Location,” IEEE, VTC 2000, pp. 1943-1949.
M.Silventoinen and T. Rantalainen, “Mobile Station Emergency Locating in GSM”, Process IEEE International Conference, Personal Wireless Communications, vol. 1, 1996, pp. 232-238.
International Searching Authority, International Search Report PCT Application No. PCT/US2011/035532 mailed Feb. 29, 2012, 2pgs.
Related Publications (1)
Number Date Country
20120142375 A1 Jun 2012 US
Divisions (1)
Number Date Country
Parent 13051911 Mar 2011 US
Child 13396281 US
Continuation in Parts (1)
Number Date Country
Parent 12292821 Nov 2008 US
Child 13051911 US