The present invention is directed generally to proximity awareness in three dimensional space, and, more particularly, to systems and methods for estimating proximity in three dimensional space to a transponder based on interactions among a communication device and at least two short-range transponders.
Short-range beacons using technologies such as infrared, ultrasonics, near-field communications (NFC) and Bluetooth® have been used to determine proximity between a mobile listening device and a beacon. In an example system, a beacon transmitter broadcasts a signal containing its identifier (ID) and a mobile device, proximate to the beacon receives the signal and determines the proximity of the mobile device to the beacon based on characteristics of the received signal. The beacon ID may be a Bluetooth® beacon ID transmitted by a first device, for example a mobile telephone, that desirably maintains a close proximate relationship with a second device, for example a Bluetooth headset even when not in use. When these devices are separated, for example because the user has inadvertently left the phone on a restaurant table, the headset may emit an alarm.
The present invention is embodied in devices and methods of determining a proximity of a receiver to a tag in a predetermined region. At the receiver, at least one signal characteristic is sensed from each of the tag and an assisting tag proximate to the tag. One or more zones are defined for each of the tag and the assisting tag in the predetermined region, where each zone represents a respective proximity of the receiver to the tag and the assisting tag. For each of the tag and the assisting tag, a presence probability vector is estimated for the receiver and each zone of the corresponding tag, based on the sensed at least one signal characteristic. For the assisting tag, a further presence probability vector is estimated for the receiver and each zone of the tag given the presence probability vector estimated for the assisting tag, based on a predetermined spatial relationship between the tag and the assisting tag. A combined presence probability vector for the receiver and the corresponding zones of the tag is calculated, from the presence probability vector estimated for the tag and the further presence probability vector via a Bayesian network. The proximity of the receiver to the tag is determined based on the combined presence probability vector.
The invention may be understood from the following detailed description when read in connection with the accompanying drawing. It is emphasized, according to common practice, that various features of the drawing may not be to scale. On the contrary, the dimensions of the various features may be arbitrarily expanded or reduced for clarity. Moreover, in the drawing, common numerical references are used to represent like features. Included in the drawing are the following figures:
With the proliferation of connected mobile devices and sensors, it may be possible to gather information from clients carrying mobile devices in a proximity aware indoor area and further provide the clients with relevant information related to the area. To date, presence of indoor proximity awareness is limited to, for example, store front door or check out stands. Furthermore, dense and expensive infrastructures may be required, for example, WiFi Access Points, video cameras, in order to establish proximity aware systems which may further need manual intervention by the client, such as, “check-ins”, in order to communicate with the system. Thus, indoor proximity awareness continues to be a challenge as current navigation and positioning systems are optimized for outdoors.
Embodiments of the invention overcome the limitations by defining proximity zones in a region (such as a three-dimensional (3D) volume, a two-dimensional (2D) area, etc.) associated with short range communication devices such as radio frequency (RF) transponders and mobile devices and by associating this space with definitions according to which actions may be taken by the client in possession of the mobile device or client device.
An example proximity system according to the subject invention employs a plurality of transponders (also referred to herein as tags). Each transponder may transmit or receive a signal to or from a client device. Each transponder may be associated with a region of interest. A region of interest may be a particular region of an area covered by the transponders, for example, a portion of a shelving unit in a retail store. The transponder associated with the region of interest may be used to define one or more zones. Zones are defined relative to one or more of the transponders, as described below. Signaling between the client device and the transponder(s) may establish at least a probability of the client device being in a particular zone relative to the transponder. Each of the zones may be considered to be a range of locations relative to each transponder indicating, for example, respectively different levels of proximity between the client device and the region of interest in the covered area.
The system may also associate one or more actions with each of the zones of each of the transponders and may also associate conditions that trigger the actions. For example, in order to allow the user sufficient time to consider a promotional offer, it may be desirable for a condition to trigger an action presenting the offer as the client device approaches the zone corresponding to the promoted product. This may be, for example, an adjacent or nearby zone. Such a condition may also include sensed data on the client's speed and direction.
The proximity of the client device to a particular zone may be determined independently for each transponder. However, there may be information available from other transponders in the vicinity of a transponder of interest that may be useful in estimating the proximity of the client device to a particular zone. In contrast, a single independent assessment of proximity on a transponder by transponder basis may not be aware of any inter-transponder relationships.
The embodiments described below relate to proximity systems and methods of determining a proximity of a receiver device to a transponder of interest. An example proximity system incorporates proximity information associated with multiple transponders in the vicinity of a transponder of interest in order to refine the proximity estimation for the transponder of interest. Additionally, in the presence of a positioning system, the proximity may be refined. To incorporate data associated with additional transponders into the process of inferring proximity of the receiver device to a particular transponder, spatial relationships between the zones for one or more “assisting” transponders (also referred to herein as assisting tags) and those of the transponder of interest (also referred to herein as a test tag) are used. The spatial relationships may be used to estimate a presence probability vector for the receiver device in zones of the test tag conditioned on presence probability vectors for the assisting tags.
This information, and the presence probability vectors for each of the individual tags may each contribute to a Bayesian data fusion process of a Bayesian network. The data fusion output may be the same in form as that from the presence probability vector associated with the test tag. However, the output from the fusion process may have an increased estimation accuracy, having been constructed with the additional supporting evidence that comes from assisting tags and their spatial relationships to the test tag.
Accordingly, by incorporating information from multiple tags, the zone estimation output from a single tag may be improved. Improved performance of the overall zoning system may be desirable in retail markets because false classifications may lead to an unsatisfying user experience and missed opportunities for the retailer.
In contrast to exemplary proximity systems described herein, existing methods either do not use the concept of zones or of geometric relationships among transmitters. Most existing methods output a position relative to local (or global) axes, based on a weighted average of transmitter positions; a set of ranges derived from received signal power or round trip time; or relative distances by measuring time difference of arrival measurements.
The example embodiments are described in terms of short-range transmitters (e.g., Bluetooth® transmitters) the signals from which are captured by mobile client devices, such as a mobile telephone including a Bluetooth transceiver. It is contemplated, however, that other types of transmitters and receivers may be used, for example, infrared (IR), ultrasonic, near-field communications (NFC), etc. In addition, as described further below, the transponders may be RF transceivers that do not broadcast signals but instead, sense signals broadcast by the portable mobile devices. Furthermore, although the transponders are described as being stationary, it is contemplated that they may be mobile devices as well and, thus that the zones defined for these transponders may move throughout the space.
Although the invention is described in terms of a retail environment, it is contemplated that the underlying technology has broader application including, without being limited to, security, enterprise workflow, gaming and social interactions. In short, it may be useful in any environment in which different actions may be triggered based on different levels of proximity among devices.
Referring to
In another embodiment, transponders 106 may be receiving devices that sense signals broadcast by client devices 102 and send identifying information about the respective client device 102 and, optionally, sensed signal strength measurements to server 104 so that server 104 may estimate the zone occupied by client device 102 relative to the transponder 106 (and hence the proximity of client device 102 to transponder 106) from which it received the client's information. The broadcast signals may be radio frequency (RF) or ultrasonic signals or they may be light signals having wavelengths within the infrared (IR), visible or ultra-violet (UV) ranges. Example client, server and transponder devices are described below with reference to
Although not shown in
It is contemplated that the determination of the zone proximity may be performed by client device 102, server 104 or a combination thereof. The zone proximity processing may be distributed among client device 102 and server 104. For example, single (individual) tag zonal presence probability vectors (described further below with respect to
In a server-centric example, the client device 102-1, after entering retail venue 100, transmits information about the sensed signal characteristics of transponders 106-1 and 106-2 to server 104, which may use the information to determine the zone of the client device. For example, client device 102-1 after moving to point B from point A, and communicating the signal characteristics of transponders 106-1 and 106-2 to server 104, may receive information about zone Z2. Client device 102-1 may also communicate with client device 102-2 in order to send and receive information about zone Z1. This operation may repeat as the client device moves from zone to zone. A similar exchange between client device 102-1 and the server 104 may occur when the client device 102-1 moves to point C in zone Z4, for example.
Server-centric systems reduce the computational load on the client device 102 but may greatly increase the communications load in the covered area and, thus, the latency of the zone determination. It is contemplated that the determination of the zones may be performed by client device 102 instead of by server 104. In this embodiment, client device 102 may send only transponder IDs to server 104. Server 104 may respond with definitions for zones associated with the transponder (e.g., transponder 106-1) and with other nearby transponders (e.g., transponder 106-2). These zones may be defined based on proximity to the transponder. Client device 102 may then analyze the sensed transponder signals (including one or more transponder signals for assisting transponders) according to these zone definitions to determine its proximity to the transponder of interest, and, thus, its proximity to a zone. In one embodiment, server 104 may send information on all zones in the covered area to client device 102 which may then store this data in an internal memory. This information may, for example, be conveyed when client device 102 encounters a first transponder, when client device 102 enters the covered area or even before client device 102 enters the area, responsive to a registration process.
The system may also take into account context information related to client device 102 such as, without limitation, its orientation, speed of movement and altitude. In one exemplary embodiment, the context of the client device may be determined using sensors such as, for example, an accelerometer, a pedometer, a compass and an altimeter. It is contemplated that these sensors may be micro-electromechanical sensor (MEMS) devices integral with client device 102.
The analysis may, for example, include comparing the signal characteristics of each of a transponder of interest and at least one assisting transponder to one or more probability distributions to determine, for each transponder, a presence probability vector between client device 102 and each corresponding tag. The analysis may also include incorporating the presence probability vector of the assisting transponder(s) into calculations that produce the presence probability vector of the transponder of interest, based on a predetermined spatial relationship between the transponder of interest and the assisting transponder, forming a combined presence probability vector. The zone (of the transponder of interest) having the highest probability (from the combined presence probability vector) is then selected as an estimate of the proximity of the client device 102 to the transponder of interest.
Referring to
For example, the signal characteristics may be further processed by processor 208 to determine the proximity of client device 102 to a transponder of interest. The signal characteristics may be sent to server 104 (
The example client device 102 further includes optional sensor module 202 that may include one or more of an accelerometer, a gyroscope, a compass, a pedometer and/or a barometer. As described above, sensor module 202 may be used to gather information on movement of client device 102. This information may be processed locally by processor 208 or it may be sent to server 104 (
In one example, transponder 106 includes only transmitter 234 and antenna 232. Although not shown, transponder 106 also includes a power source, for example, a lithium battery. Because it periodically broadcasts a low-power signal, the example transponder 106 may operate for several years using the battery.
In another example, transponder 106 may include antenna 232 and receiver 238, and may be configured to sense low-power signals (e.g., BLE) signals broadcast by client devices 102 (
In one embodiment (shown by line 302), transponders 106 are transmit-only devices that emit signals having signal characteristics and include a transponder label asynchronously and at regular intervals. These signals are sensed by one or more client devices 102 proximate to transponders 106. Each client device 102 senses signals from transponders 106 that are within range and can collect, none, one or more signal characteristics over a period of time. In addition, client device 102 may receive transponder signal(s) and decode the transponder label from the corresponding transponder signal. For example, with reference to
In another embodiment, as shown by the dashed line 304, transponders 106 may be configured to sense low-power signals (e.g. BLE) signals broadcast by client devices 102 and to send their identities and information on the detected client devices to server 104, for example, as shown by dashed line 306. The information sent may include a client device identifier and characteristics of the sensed signal. Server 104 may then determine the zone corresponding to the transponder ID and client device signal characteristics and also the definitions of the zones. Server 104 may then send the zone information to the identified client device 102, for example as shown by line 308.
Client device 102 may also be configured to have bi-directional communication with server 104 and further transmit signal characteristics, where determination of proximity of the client device to a transponder of interest for a predetermined time may be performed by server 104. During the communication, client device 102 may also receive definitions of the zones from server 104, for example. Alternatively, client device 102 may provide such information to server 104.
As indicated by dashed line 310, a cross client device communication may also take place. In such a scenario, the client devices 102 may communicate information among each other regarding their respective zones and definitions of the zones, for example.
Referring next to
The architecture of estimator 400 is described herein for the case of a deployment space consisting of two mutually cooperating tags (such as tags 106-1, 106-2 in
According to an exemplary embodiment, when a potentially large number of assisting tags are present, the assisting tags may be grouped into small (non-mutually) exclusive states, to reduce the occupational complexity of the spatial relationships. In this way, each individual (test) tag may be associated with a small number of assisting tags (e.g., its nearest few neighbors).
According to another example, estimator 400 may generate separate proximity estimates (also referred to herein as presence probability vectors) for a number of different sets of assisting tags that are proximate to a test tag. Estimator 400 may then perform an additional Bayesian data fusion of each estimate to obtain a final proximity estimate for the test tag. For example, if there are 9 assisting tags proximate to a test tag, the 9 assisting tags may be divided into 3 sets of assisting tags, with a separate proximity estimate being determined for each set. The three proximity estimates (one for each set) may be applied to Bayesian network 408 to generate a final fused proximity estimate for all of the sets.
In
Single tag proximity estimator 402-r receives at least one signal characteristic 410-r from tag r and may estimate a zonal presence probability vector 412-r for tag r. The signal characteristic may include, without limitation, at least one of a signal strength, a signal round-trip time, a signal arrival time, a signal quality or a signal phase. Estimator 402-r may also use context information regarding client device 102 (
Database 404 may store predetermined spatial relationships between zones associated with different tags. These spatial relationships may be supplied through precise geometrical statements of the areas or volume of intersection between all of the zones of both tags as well as the total area or volume associated with each zone of the assisting tag. Examples of spatial relationships between tags for various tag arrangements are described further below with respect to
In general, the probability of a location being in zone ‘a’ of the test tag (the first tag), given that it is present in zone ‘b’ of the assisting tag (the second tag) is (assuming uniform probability density within any particular zone), the area lying on both zones (the intersection) divided by the area of zone ‘b’ of the assisting tag. These ideal geometrical statements may take into consideration any regions excluded by the presence of impenetrable obstacles such as shelving. It may be appreciated that looser definitions may be provided for these relationships in some cases, and that the resulting calculation of conditional probabilities (based on zonal intersections between) are commensurately approximate.
Database 404 may also store predetermined temporal transition probability values that may define the probability of moving from any zone in the covered area to any other zone. The transition probability values may be dependent upon a definition of the zones, the duration between updates (from a previous state to a current state) and estimates of the probability distribution for the speed of the motion of the client device 102. The temporal transition probability values may be applied to zonal presence probability vectors 412 in transition matrices of spatio-temporal transition matrix module 406. For example, a transition matrix of a Markov chain may encapsulate estimates of conditional probabilities that client device 102 will move between every possible pair of zones (including no change in zone) from a previous state to a current state.
The problem of fusing the zonal presence probability vector estimates for a pair of tags, focuses first on just one of the pair (e.g., tag 1, i.e., the test tag). At a particular instant, suppose that a column vector of probabilities (whose elements are associated with the zones of tag 1) becomes available as the output of the Hidden Markov Model (HMM) for tag 1. A similar column vector corresponding to the zones of the assisting tag (tag 2) is available from the output of the HMM for tag 2.
One problem in using data from assisting tags is that it is asynchronous with data from the test tag. This may be resolved by the application of the temporal transition matrix. Another problem in using data from assisting tags (e.g., tag 2) is that the assisting tag output refers to probabilities of zonal proximity for tag 2. This may be resolved by the application of conditional probabilities based on the spatial relationships between the zones of the two tags as described herein.
Spatio-temporal transition matrix module 406-r receives a timestamp of the currently estimated zonal presence probability vector (timestamp of (412-r)) for the associated tag r as well as the most recently estimated timestamp and zonal proximity probabilities for the other tag (412, but not r) and applies a temporal transition matrix and spatial relationship matrix to the presence probability vector for the assisting tag (not r).
For example, module 406-1 receives a (previously estimated) time-stamped zonal presence probability vector 412-2 (for tag 2) and applies a temporal transition matrix to that probability vector in order to synchronize the time at which that estimate applies with the timestamp of 412-1. Module 406-1 also applies a spatial relationship matrix to the presence probability vector of 412-2 (via spatial relationship probability values in database 404). The output of 406-1 together with 412-1 then form a statistically independent pair of estimates for the zonal presence probability vector values for tag 1 at the timestamp of 412-1.
In this way, the data from the assisting tag (e.g., tag 2) may be used to infer zonal probabilities associated with tag 1 (via transitioned probabilities 414-1), and together with the output for tag 1 (zonal presence probability vector 412-1) there are now two independent estimates of the zonal presence probability vector associated with each test tag. These estimates 412-1 and 414-1 are provided as inputs to Bayesian network 408-1. The situation for tag 2 is entirely symmetric. Namely, the roles of the test tag and assisting tag are simply reversed.
Bayesian network 408 includes a Bayesian fusion algorithm. The Bayesian fusion algorithm for a pair of tags may be derived from Bayesian analysis. Suppose a system may be in any one of a discrete set of states at any given instant (in the present case, the state is the true zone of the test tag in which the receiver is present). Suppose also that at discrete times, two statistically independent measurements are available, whose values are random variables each drawn from one of a mutually distinct class of distributions, dependent only on the current state of the system (these measurements correspond in our particular case to signal strength measurements from the two different tags).
Statistical independence of the measurements derives from conditioning on the state of the system in the present case under weak assumptions. Let the state that the receiver is present in zone j of tag m at time k be denoted by xkjm, and denote a single measurement (e.g. signal characteristic) at time k from tag m by ykm.
Let the set of all measurements up to and including time k from tag m be Ykm={y1m, y2m, . . . ykm}. The probability that at time k the receiver is in zone j of tag 1 (the test tag) conditioned on having received all of the measurements from both tags up to time k is denoted as (xkj1|Yk1, Yk2).
Separating out the most recent measurements (time k), the probability may be written as:
(xkj1|Yk1,Yk2)=(xkj1|Yk1,Yk2,Yk-11,Yk-12). (1)
After application of Bayes' rule and under the assumption of statistical independence, eq. (1) may be expressed as:
In eq. (2), the 1st factor is the probability of the receiver being in zone j of tag 1 conditioned on all the measurements from tag 1. This is the output 412-1 of single tag proximity estimator 402-1 (for tag 1).
The 2nd factor is the probability of the receiver being in zone j of tag 1 conditioned on all the measurements from tag 2. This is obtained from the output 412-2 from single tag proximity estimator 402-2 (for tag 2) using predetermined spatial relationships (from database 404) applied via module 406-1.
The 3rd factor is the probability of being in zone j of tag 1 conditioned an all the previous measurements from both tags. This is the previous output of Bayesian network 408-1, but predicted forwarded to time k using the appropriate zone transition matrix. This process is shown in
Referring back to
The 5th factor is the probability of being in zone j of tag 1 conditioned on all the previous measurements from tag 2. It may be obtained from the previous (spatially corrected) output 402-2 for tag 2 (via the spatial relationships applied by module 406-1), but predicted forward to time k using the appropriate zone transition matrix (by module 406-1).
With these interpretations, it may be appreciated that estimator 400 applies a recursive procedure in which present measurements from both tags as well as the previous output 416 of estimator 400 are fused with previous measurements from both tags to provide the required current fused output 416-1 (for tag 1).
The two tag estimation may be extended to more than two tags (i.e., one test tag and two or more assisting tags). The inventors have determined that the probability estimation, for (n−1) assisting tags (numbered from 2 to n), where n is in integer, can be represented as:
if the spatial relationships between each of the assisting tags with the test tag are coupled. If the spatial relationships between the assisting tags and the test tag are de-coupled, eq. (3) may be represented by eq. (4) as:
In operation, it may be desirable to assume that the tags are mutually spatially decoupled, and to use eq. (4), for ease of scalability as the number of assisting tags increases.
Referring again to
The fusion process operates at times k. To further emphasis the dependence of estimator 400 on time, Each zonal presence probability vector 412 may be represented as (xτ(r,k),jr|Yτ(r,k)r). This output 412 represents the output available at time for tag τ at fusion epoch k. Fusion box 422 uses a temporal transition matrix (from module 406 of
Referring to
At step 500, the time index is initialized. At step 502, at least one signal characteristic is sensed from a tag (a test tag) by a receiver. For example, client device 102-1 (
For example, transponders 106-1, 106-2 may broadcast associated BLE signals. Client device 102-1 may receive the BLE signals, decode associated payload data, such as forward error correction (FEC) code, embedded in the BLE signals to obtain a measure of signal quality. As another example, signal strength and/or signal-to-noise ratio may be used as a measure of signal quality. Client device 102-1 then estimates signal characteristics from each sensed tag 106-1, 106-2.
At step 506, for each of the tag (e.g., tag 106-1) and the assisting tag(s) (e.g., tag 106-2), a current presence probability vector is estimated for the receiver and each of one or more zones of the corresponding tag, based on the signal characteristic(s), for example, by single tag proximity estimators 402-1, 402-2 (
At step 508, for each assisting tag (e.g., tag 106-2), a current further presence probability vector is estimated. The further presence probability vector is a proximity for the receiver and each zone of the tag given the presence probability vector estimated for the assisting tag. The further presence probability vector is determined from the presence probability vector of the assisting tag (e.g., zonal presence probability vector 412-2 of tag 2 as shown in
The predetermined relationship may be used to determine the terms in the ratio shown in eq. (4). The single tag output for tag r≠1 is of the form (xkjr|Ykr). For eq. (4) however, the form (xkj1|Ykr) is needed. To convert the tag output to the appropriate form, a spatial transition matrix is applied to the single tag output as:
At step 510, previously estimated quantities are propagated to current time k based on the temporal transition matrix, for example, via module 406 (
At step 512, a current combined presence probability vector is calculated from the propagated presence probability vectors (step 510), the current presence probability vector of the tag (step 506) and the current further presence probability vector of the assisting tag (step 508) via application to a Bayesian network (e.g., network 408-1 shown in
At step 514, the proximity of the receiver to the tag is determined based on the current combined presence probability vector, for example, by server 104 (
At step 516, the time index is updated and step 516 proceeds to step 502. Steps 502-516 may be repeated for each time index k.
Referring next to
Two example methods are described below for obtaining terms pertaining to spatial relationships between zones associated with different tags. In the first example method, several simplified spatial configurations are defined for the purpose of calculating these terms (which are of the form (xkmp|xkjq)). These spatial configurations include free-space (
The cases above in
Although
According to a second exemplary method for obtaining terms pertaining to spatial relationships between zones associated with different tags, a mapped environment may be used to determine terms in (eqs. (3) or (4)) representing the spatial relationships. The map may be considered as a set of Cartesian coordinates associated with its image pixels. Each point in the map lies in a single zone of any chosen tag, outside the range of the tag or in a region excluded from user penetration due to the presence of an obstacle. The quantity (xkmp|xkjq) may be determined from the number of pixels in the intersection of zone m of tag p with zone j of tag q divided by the total number of pixels in the latter.
Referring next to
In an exemplary embodiment, proximity data from the output of a positioning system (e.g., of a client device) in a mapped environment may be used. The system may be provided with an estimated map location together with a confidence value or region 704 or a mechanism to specify the probability of the position being at a given map coordinate. Using the map, an estimated position may be associated with a single zone of each of a number of tags. If a confidence region 704 (set of map coordinates) is available, that region may overlap one or more zones of multiple tags. Each point in the confidence region 704 may be associated with a probability, or it may be assumed that the probability is distributed uniformly among the confidence region 704.
In either case, a zonal presence probability vector for a tag 106 may be calculated by summing the probabilities that lie in both the confidence region 704 and the zone of interest of the tag of interest. If for example, a confidence region 704 is provided as a set of coordinates (pixels) with, for example, a 70% confidence, then the set of pixels within that confidence region would each be associated with a probability of 0.7 divided by the number of pixels in the region. The complement of the confidence region would have its coordinates (pixels) associated with 0.3 divided by its number of pixels.
The probability of each zone may be obtained by integrating the specified probability distribution for each position over the area with a selector function for each zone as:
P(xj1)=∫P(r)δ(Z1(r)−j)dr,
where P(R) is the probability distribution for position, r is the map position, Z1(R) is the zone for tag 1 at position r, the integral is over the 2D space covered by the map and
For example, to find the probability for proximity in zone Z3 for tag 1 (tag 106), the number of pixels in zone Z3 may be counted, and weighted with the probability density with which they are associated. The summation over the pixels (weighted by probability) may be expressed as:
Thus, the probability of proximity in zone 3 for tag 1 (i.e., the zonal presence probability vector) may be determined by taking into consideration the confidence region 704 associated with the client device's position.
Although the invention is illustrated and described herein with reference to specific embodiments, the invention is not intended to be limited to the details shown. Rather, various modifications may be made in the details within the scope and range of equivalents of the claims and without departing from the invention.