METHOD AND SYSTEM FOR MULTIPATH REDUCTION FOR WIRELESS SYNCHRONIZATION AND/OR LOCATING
20220011399 · 2022-01-13
Inventors
Cpc classification
G01S5/06
PHYSICS
International classification
G01S5/06
PHYSICS
G01S5/00
PHYSICS
Abstract
A method for determining an instantaneous phase difference between time bases of at least two location anchors for a desired point in time (t), each of the location anchors having transmitting and receiving access to a joint broadcast transmission medium and a respective time base for measuring time, wherein a first of the location anchors broadcasts a first broadcast message at least twice; the first location anchor and at least a second of the location anchors receive the first broadcast messages; the second location anchor broadcasting a second broadcast message at least twice; and the second location anchor and at least the first location anchor receive the second broadcast messages. The location server calculates the instantaneous phase difference from a determined first and second clock model functions and from a time elapsed between a reference point in time and the desired point in time t.
Claims
1. (canceled)
2. A tangible, non-transitory, machine-readable medium storing instructions that when executed by one or more computing devices effectuate operations comprising: receiving, with a computer system, a set of time-of-arrival (TOA) stamps, wherein the set of TOA stamps comprises: a first subset of TOA stamps indicative of a first time of reception of a first broadcast message broadcasted from a first location anchor and a second time of reception of a second broadcast message broadcasted from a second location anchor; and a second subset of TOA stamps based on a first self-reception time of the first broadcast message by the first location anchor and a second self-reception time of the second broadcast message by the second location anchor, wherein the second subset of TOA stamps have smaller multipath error than the first subset of TOA stamps, and wherein the TOA stamps are delivered in association with information indicative of the location anchor broadcasting each broadcast message having a TOA stamp among the set of TOA stamps; identifying the location anchor broadcasting each broadcast message having a TOA stamp among the set of TOA stamps based on the information; calculating, with the computer system, time-difference-of-arrival (TDOA) values based on the first subset of TOA stamps and the second subset of TOA stamps; determining, with the computer system, a first set of parameters that define a first clock model function using at least two of the TDOA values, wherein the first clock model function utilizes a time dependence factor of the TDOA values associated with the first broadcast message and the second broadcast message; and calculating, with the computer system, using the first clock model function, an phase difference from the first clock model function and from a time elapsed between a first reference point in time and a second reference point in time.
3. The medium of claim 2, wherein the operations further comprise: correcting, using the phase difference, at least one TDOA value.
4. The medium of claim 2, wherein the first subset of TOA stamps and the second subset of TOA stamps further include information indicative of a first source location anchor from which the first broadcast message and a second source location anchor from which the second broadcast message originate, and information indicating a first receiving location anchor that received the first broadcast message and a second receiving location anchor that received the second broadcast message.
5. The medium of claim 2, wherein calculating the phase difference further comprises using the first set of parameters of the first clock model function and a second set of parameters of a second clock model function, the first clock model function and the second clock model function being linear functions.
6. The medium of claim 2, wherein the first set of parameters further comprises a first parameter value of the first set of parameters that corresponds to an offset of a linear function of the first clock model function, and the operations further comprise: determining, for at least one of the first clock model function and second clock model function, a respective second parameter value corresponding to a slope of the linear function of each first clock model function and the second clock model function respectively.
7. The medium of claim 2, wherein the first location anchor determines a self-reception time by self-reception of the first broadcast message with a first location anchor antenna.
8. The medium of claim 2, wherein the operations further comprise: operating at least three location anchors, in respective pairs, that broadcast and receive broadcast messages, and each provide one or more TOA stamps among the first subset of TOA stamps and the second subset of TOA stamps.
9. The medium of claim 8, wherein the operations further comprise: determining respective phase differences of the time bases of the respective pairs of location anchors.
10. The medium of claim 2, wherein the set of TOA values are received via a wired connection.
11. The medium of claim 2, wherein the operations further comprise: generating a synchronization correction value; adjusting a TDOA value for a location tag; and determining a corrected distance to the location tag.
12. The medium of claim 2, wherein the first time of reception is determined by the second location anchor and the second time of reception is determined by the first location anchor.
13. The medium of claim 2, wherein the operations further comprise steps for determining a self-reception time.
14. The medium of claim 2, wherein the operations further comprise steps for calculating a phase difference.
15. A system, comprising: a first location anchor configured to broadcast a first broadcast message, self-receive the first broadcast message, and determine a first self-reception time of the self-received first broadcast message; and a second location anchor configured to broadcast a second broadcast message, self-receive the second broadcast message, and determine a second self-reception time of the self-received second broadcast message, wherein the second location anchor receives the first broadcast message, the first location anchor receives the second broadcast message, and the first location anchor and the second location anchor generate a first set of time-of-arrival (TOA) stamps indicative of respective times of reception of the first broadcast message and the second broadcast message and a second set TOA stamps indicative of the first self-reception time and the second self-reception time; and a server configured to: receive the first set of TOA stamps and the second set of TOA stamps; identify, based on a first identifier of the first location anchor sent to the server with a first TOA stamp of the first set of TOA stamps, the first location anchor broadcasting a broadcast message corresponding to the first TOA stamp; calculate time-difference-of-arrival (TDOA) values based on the first set of TOA stamps and the second set of TOA stamps; and calculate a phase difference, according to a first clock model function, between time bases of the first location anchor and the second location anchor.
16. The system of claim 15, wherein the TOA stamps further include information indicative of a receiving location anchor that received the first broadcast message and the second broadcast message.
17. The system of claim 15, wherein the server is configured to: calculate the phase difference by: determining a first set of parameters of the first clock model function for the first location anchor and a second set of parameters of a second clock model function for the second location anchor, wherein the first clock model function and the second clock model function are linear functions and a respective first parameter value of the first set of parameters corresponding to an offset of each respective linear function; and determining, for at least one of the first clock model function and the second clock model function, a respective second parameter value corresponding to a slope of each respective linear function.
18. A method, comprising: receiving, by a computing device, a set of time-of-arrival (TOA) stamps, wherein the set of time stamps comprises: a first subset of TOA stamps indicative of a first time of reception of a first broadcast message broadcasted from a first location anchor and a second time of reception of a second broadcast message broadcasted from a second location anchor, and a second subset of TOA stamps based on a first self-reception time of the first broadcast message by the first location anchor and a second self-reception time of the second broadcast message by the second location anchor, wherein the second subset of TOA stamps have smaller multipath error than the first subset of TOA stamps, and wherein the TOA stamps are delivered in association with information indicative of the location anchor broadcasting each broadcast message having a TOA stamp among the set of TOA stamps; identifying, by the computing device, the location anchor broadcasting each broadcast message having a TOA stamp among the set of TOA stamps based on the information; calculating, by the computing device, time-difference-of-arrival (TDOA) values based on the first subset of TOA stamps and the second subset of TOA stamps; determining, by the computing device, a first set of parameters that define a first clock model function using at least two of the TDOA values, wherein the first clock model function-utilizes-a time dependence factor of the TDOA values associated with the first broadcast message and the second broadcast message; and calculating, by the computing device and using the first clock model function, an phase difference from the clock model function and from a time elapsed between a first reference point in time and a second reference point in time.
19. The method of claim 18, further comprising: correcting, by the computing device and using the phase difference, at least one TDOA value based on the calculated phase difference.
20. The method of claim 18, wherein the first subset of TOA stamps and the second subset of TOA stamps further include information indicative of a source location anchor from which the first broadcast message and the second broadcast message originate, and information indicating a receiving location anchor that received the first broadcast message and the second broadcast message.
21. The method of claim 18, wherein the first set of parameters further comprises a first parameter value of the first set of parameters that corresponds to an offset of a linear function of the first clock model function, and the operations further comprise: determining, by the computing device and for at least one of the first clock model function and second clock model function, a respective second parameter value corresponding to a slope of the linear function of each first clock model function and the second clock model function respectively.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0114]
[0115]
[0116]
[0117]
[0118]
[0119]
[0120]
[0121]
DETAILED DESCRIPTION OF EMBODIMENTS
[0122] A first embodiment of the invention is depicted in
[0123] The location anchors 200 are capable of wirelessly transmitting signals. Each or at least some of the location anchors 200 are also capable of receiving wirelessly transmitted signals or messages from other location anchors 200, and they are capable of receiving wirelessly transmitted signals or messages from location tags 102, the position of which is initially unknown and which are thus to be located.
[0124] Furthermore the location anchors 200 are capable of transmitting messages. However, this capability is used completely different from prior-art systems described in the introductory part of the present specification as background art.
[0125] The location anchors 200 generate time of arrival stamps (TOAs) for messages they receive, and they also generate additional TOAs for messages they transmit. This is indicated by a self reception arrow 205. It is important to note that those additional TOAs have little or no multipath error, because the transmission path from the transmission antenna to the reception antenna (which may even be implemented by only one antenna) is not subject to significant multipath effects.
[0126] Each location anchor 200 is equipped with some kind of time base. Typically a crystal oscillator is used.
[0127] In order to fully and precisely describe the invention, a time base model will be defined in the following. The commonly used, simple model which describes a time base based on two parameters, start offset and frequency error, is sufficient here. Of course, a time base model of higher complexity would result in more complex calculations, but would in the end yield similar or same results in the context of the present invention.
[0128] We define:
C.sub.A.sub.
[0129] where
[0130] t is the true reference time;
[0131] C.sub.A.sub.
[0132] An at time t;
[0133] In other words, the instantaneous phase of the time base of a location anchor is a time value that the time base of the location anchor provides at a given time value of the true reference time.
[0134] T.sub.A.sub.
[0135] e.sub.A.sub.
[0136] Typically the absolute value of the frequency error is below a known limit, e.g., a tolerance of a crystal. Due to changes in temperature, supply voltage etc. it will vary randomly but slowly.
[0137] Although the number of location anchors usable by the invention is not limited, for explanatory purposes the calculation involved will be derived for a minimum embodiment with two location anchors A1 and A2 as depicted in
[0138] With (1) and
T.sub.A.sub.
e.sub.A.sub.
[0139] where
[0140] T.sub.A.sub.
[0141] e.sub.A.sub.
[0142] the instantaneous phase difference between the time bases of the two location anchors at time t can be expressed as
C.sub.A.sub.
[0143] Every once in a while each location anchor wirelessly transmits a message which can be received by one or more location anchors. It is irrelevant how the transmission is triggered (random, deterministic, synchronized or other). Each of the N location anchors, which receive the message, generates a TOA stamp, with respect to its individual time base.
[0144] It is important to note that the transmitting location anchor also generates a TOA stamp for the message transmitted by this very location anchor itself. Several possibilities for generating this special TOA stamp exist. For example, this TOA stamp can be derived from the time of transmission. As an alternative, it can be generated by a receiver, to which the propagation delay and multipath delay are either zero, for instance because it is colocated with the transmitting part of the location anchor, or to which the propagation delay and multipath delay are exactly known. The receiver must be active during transmission of the message.
[0145] It is assumed in the following, that location anchor A1 has transmitted a broadcast message at t=t1 and that it has generated the TOA stamp TOA.sub.A.sub.
[0146] Without loss of generality and only for reasons of clarity, we can assume that the time base of anchor A1 is absolutely correct, which means that the location anchor A1 has the ‘true’ time. Hence we can write:
T.sub.A.sub.
e.sub.A.sub.
[0147] Using (1) and (4) we get for a transmission of a message from location anchor A1 at t=t1 for the TOA stamp at location anchor A1:
TOA.sub.A.sub.
[0148] Using (1), (2) and (4) we get for a transmission of the same message from location anchor A1 at t=t1 for the TOA stamp at location anchor A2:
TOA.sub.A.sub.
[0149] wherein
[0150] T.sub.A.sub.
[0151] T.sub.A.sub.
[0152] For most wireless media it is reasonable to assume reciprocal propagation of signals. Thus we can write:
T.sub.A.sub.
T.sub.A.sub.
[0153] Using (5), (6) and (7) the Time Difference Of Arrival between location anchors A1 and A2 for the message transmitted by the location anchor A1 at time t1 can be calculated as follows:
TDOA.sub.A.sub.
This yields
TDOA.sub.A.sub.
[0154] It should be noted that, since the terms T.sub.A.sub.
TDOA.sub.A.sub.
[0155] This means that from at least two measurements of TDO.sub.A.sub.
{circumflex over (k)}.sub.A.sub.
ŝ.sub.A.sub.
[0156] The symbol “{circumflex over ( )}” is used here for indicating that the respective value is an estimate. In other words, the estimate {circumflex over (k)}.sub.A.sub.
[0157] Similarly as above, for the transmission of the broadcast message from location anchor A2 at t=t.sub.2:
TOA.sub.A.sub.
TOA.sub.A.sub.
[0158] and the corresponding TDOA for the message transmitted by the location anchor A2 at the time t.sub.2 is:
TDOA.sub.A.sub.
[0159] Estimating the parameters yields
{circumflex over (k)}.sub.A.sub.
ŝ.sub.A.sub.
[0160] Since T.sub.A.sub.
{circumflex over (T)}.sub.A.sub.
[0161] Equation (15) yields an estimate for the initial offset between the time bases of the two location anchors A1 and A2. It is to be pointed out that the estimate is not affected by multipath error T.sub.A.sub.
[0162] If T.sub.A.sub.
{circumflex over (T)}.sub.A.sub.
[0163] Regarding the slope of the lines it is possible to utilize the fact that both lines should have the same slope and thus two independent estimates for one parameter are available and can for example be averaged in order to further reduce the estimation error as indicated in equation (17)
ê.sub.A.sub.
[0164] With the estimates obtained up to equation (15) it is now possible to calculate an estimate for the instantaneous phase difference between the time bases of the two location anchors A1 and A2 at any time t. For example either equation (18) or (19) could be used
Ĉ.sub.A.sub.
Ĉ.sub.A.sub.
[0165] A potentially even better estimate is obtained when the result from equation (17) is used. This yields equation (20):
Ĉ.sub.A.sub.
[0166] Of course the same result would be obtained if the values at time t of the functions defined in equations (9) and (13) were estimated first and then averaged. This shown in equation (21)
Ĉ.sub.A.sub.
[0167] It should be emphasized that the above equations, which were derived for one location anchor pair, can be applied to any location anchor pair in which the location anchors receive messages from each other in a system with an arbitrary number N of location anchors. Thus, information on timebase differences and multipath error between many or all location-anchor pairs is available.
[0168] In the use case of a real-time locating system additionally comprising a location tag, wherein the location of the location tag is unknown and the respective positions of the first and second location anchors are known to a location server, if a message from a location tag is received by a location anchor pair at time t—wherein any of the location anchors may serve as a time reference for t, irrespective of its correctness in terms of true time, because what matters in the present context is only the difference in respective times of the respective time bases of the location anchors —, the multipath-error free synchronization correction value between the two location anchors can be estimated and subtracted from the TDOA measured for the location tag. This yields a TDOA estimate or, after multiplying with the propagation speed, distance difference for the location tag with none or minimum synchronization error. For further processing of the TDOA values of location tags and/or for improvement of the location estimate of location tags the multipath information from equation (16) will be useful.
DETAILED DESCRIPTION OF FIG. 4
[0169]
[0170] From time to time each location anchor 200 transmits a message, which is received by other (not necessarily all) location anchors 200. The timing for transmitting may be independent or coordinated between the location anchors. Location anchors 200 generate a TOA stamp 402 for each message which they receive. For messages which they transmit they also generate TOA stamps 401 which match the TOA stamp they would have generated if they had received the message over their reception antenna without any or with negligible multipath delay.
[0171] After two location anchors have received at least two messages from each other and the respective TOA stamps have been gathered in one place, typically the location server, the method disclosed in this invention can be applied. Further messages can be processed similarly in order to update and improve results.
[0172] Location anchors typically report the TOA stamps (TOAs) they generate to the location server together with information on the originating source of the message and other information like message ids. In the example here messages send out from a location anchor are enumerated with a counter which is given in brackets in order to identify a TOA stamp. E.g. TOA.sub.An,A1(2) denotes the time of arrival at location anchor A1, of the second message sent by location anchor An.
DETAILED DESCRIPTION OF FIG. 5
[0173]
[0174] In the next step some or all possible TDOAs in-between location anchor pairs are calculated from the TOAs 503.
[0175] Further processing depends on the type of source of the originating message for which the TOAs were generated.
[0176] If the message for which the TOAs have been generated, was transmitted by a location anchor, the resulting TDOAs are used for estimating the parameters of time base differences in-between the location anchor pairs like indicated in equations (11) and (14). At this point these parameter estimates are still subject to multipath error 504. Such estimation can be achieved by state of the art techniques like Kalman filtering or others. It is also possible to collect time series of TDOAs for location anchor pairs and update the estimation once in a while using all or some of the collected TDOAs.
[0177] If on the other hand the message was transmitted by a location tag, the instantaneous multipath error free phase differences for some or all location anchor pairs are calculated 505 using the method indicated by equation (18) or (19) or (20) or (21).
[0178] By applying (e.g. subtracting) the synchronisation correction values from the TDOAs of the location tag obtained in 503 synchronization error free TDOA values for the location tag are obtained 507.
[0179] In an enhanced embodiment further steps are taken:
[0180] Using the estimates obtained in 504 and applying equation (16) the multipath errors in-between anchor pairs are explicitly found 510. The multipath information found in 510 can either be passed up or it can be used immediately. Since the TDOA values of the location tags are still subject to multipath error between location tag and location anchors, there is a potential to reduce this multipath error. For example by utilizing the statistical correlation of multipath errors between different locations in one environment the TDOA values of the location tags can be reduced by a certain amount based on the multipath error determined between location anchors 511.
DETAILED DESCRIPTION OF FIG. 6
[0181] As indicated in
DETAILED DESCRIPTION OF FIG. 7
[0182] As has been shown in equation (3) the time base difference between two location anchors changes over time but it can be modelled in a as a simple function e.g. as a straight line at least within a certain time interval of observation.
[0183] In case A1 is the originator the TDOA.sub.A.sub.
[0184] A location server, according to an embodiment of the present invention, is shown in
[0185] The location server 204 is configured to determine a difference of distances of a location tag from at least two location anchors, the location of the location tag being unknown and the respective locations of the location anchors being known to a location server, wherein the transmitting/receiving part 210 is configured to receive, from the first and second location anchors, tag TOA stamps, which are indicative of a first and second time of reception of the tag message broadcast by the location tag at the first and second location anchor, respectively, in terms of the time base of the first and second location anchor, respectively. The phase-difference determination unit 240 is also configured to determine an instantaneous phase difference between time bases of the first and second location anchors for the time at which the tag message has been received by one of the anchors. The TDOA unit 220 is configured to determine a TDOA value for the tag message from the first and second TOA stamps and to correct the determined TDOA value by the determined instantaneous phase difference, thus obtaining a corrected TDOA value. The location server 204 also comprises a locating unit 250 configured to determine a difference in distance of the location tag from the first and second location anchor, using the corrected TDOA value and a known speed of signal propagation within a broadcast medium used by the first and second location anchors and by the location tag.