CA2725250A1 - System, method and computer program for anonymous localization - Google Patents

System, method and computer program for anonymous localization Download PDF

Info

Publication number
CA2725250A1
CA2725250A1 CA2725250A CA2725250A CA2725250A1 CA 2725250 A1 CA2725250 A1 CA 2725250A1 CA 2725250 A CA2725250 A CA 2725250A CA 2725250 A CA2725250 A CA 2725250A CA 2725250 A1 CA2725250 A1 CA 2725250A1
Authority
CA
Canada
Prior art keywords
mobile device
localization
location
radio map
rss
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
CA2725250A
Other languages
French (fr)
Inventor
Shahrokh Valaee
Chen Feng
Anthea Wain Sy Au
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
University of Toronto
Original Assignee
Shahrokh Valaee
Chen Feng
Anthea Wain Sy Au
The Governing Council Of The University Of Toronto
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shahrokh Valaee, Chen Feng, Anthea Wain Sy Au, The Governing Council Of The University Of Toronto filed Critical Shahrokh Valaee
Priority to CA2725250A priority Critical patent/CA2725250A1/en
Publication of CA2725250A1 publication Critical patent/CA2725250A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0294Trajectory determination or predictive filtering, e.g. target tracking or Kalman filtering
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0252Radio frequency fingerprinting
    • G01S5/02521Radio frequency fingerprinting using a radio-map
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information

Abstract

The present invention provides a system, method and computer program for anonymous localization. The location of a mobile device can be determined based on received signal strength (RSS) from one or more access points (APs) and a radio map. A radio map can be generated by measuring RSS at a set of fingerprints, which are a finite set of reference points within the area to be mapped.

Description

SYSTEM, METHOD AND COMPUTER PROGRAM FOR ANONYMOUS
LOCALIZATION
FIELD OF THE INVENTION

The present invention relates generally to determining a location of a network connected mobile device. The present invention relates more specifically to determining the location of the network connected mobile device based on received signal strength and a radio map.

BACKGROUND OF THE INVENTION

Recent advances in smart phones have made it feasible to provide indoor Location-Based Services (LBSs) including through low cost Wireless Local Area Network (WLAN) infrastructures, such as indoor positioning, tracking, navigation, and location-based security.
However, due to the complexity of the indoor environment, it is usually difficult to provide a satisfactory level of accuracy in most applications. Thus, one of the key challenges arises: how to design an accurate and real-time indoor positioning system that can be easily deployed on commercially available mobile devices without any hardware installation or modification.

Received Signal Strength (RSS)-based localization algorithms have been extensively studied as an inexpensive solution for indoor positioning in recent years. Compared with other measurement-based algorithms (e.g. time of-arrival (TOA) or angle-of-arrival (AOA) measurements of ultra-wideband (UWB) signal), RSS can be easily obtained by a WiFi-integrated mobile device, without any additional hardware. Several RSS-based indoor positioning and tracking algorithms have been proposed based on the position information of access points (APs), which may result in labor overheads for the installation of infrastructures in real applications.

The key challenge for accurate RSS-based positioning comes from the variations of RSS due to the dynamic and unpredictable nature of radio channels, such as shadowing, multipath, interference, the orientation of wireless device, etc.

Also, as is well'known GPS still does not provide optimal foundation for indoor LBSs because of signal outages, positional inaccuracies, and other technical problems prevent localization and tracing.

Certain mobile devices (such as those using the ANDROIDTM operating system) are configured to enable the localization of the device but generally based on communication with a central server with which the mobile device checks in intermittently, providing current location information for the mobile device. Many users however are concerned about the privacy implications of their movements being traced by a remote computer.
Furthermore, privacy breaches caused by dealings between individuals and web companies have become very public and have heightened concern around possible privacy implications of LBSs in particular. Certain information services, delivered to or using mobile devices may require some exposure of some location information associated with the user of the mobile device, however, this may be acceptable to the user if they were able to regulate this exposure, which prior art technologies do not permit.

Therefore, what is required is a system and method for localization of a mobile device and tracing of a mobile device, that provides effective support for LBSs including in indoor environments. There is a further need for a system and method for localization of a mobile device that enables LBSs, while maintaining privacy or enabling the user of the mobile device to control exposure of location information to remote computers.

SUMMARY OF THE INVENTION

The present invention provides a system for localization of a mobile device, the system comprising: (a) one or more network access points each emitting a signal; (b) a network accessible server; (c) a fingerprint database linked to the server, the fingerprint database providing a radio map based on received signal strength from the one or more network access points at one or more reference points; and (d) a mobile device, the mobile device linked to: (i) a network adaptor operable to receive the signal from the one or more access points; and (ii) a localization engine operable to obtain the radio map or a subset thereof from the server, and to determine the location of the mobile device based on the radio map and the received signal from the one or more access points.

The present invention also provides a method for localization of a mobile device, the method comprising: (a) providing a radio map based on received signal strength of one or more signals emitted from one or more network access points at one or more reference points; and (b) enabling a mobile device to: (i) receive, by means of a network adaptor linked to the mobile device, the signal from the one or more access points; (ii) obtain the radio map or a subset thereof; and (iii) determine, by means of a localization engine linked to the mobile device, the location of the mobile device based on the radio map and the received signal from the one or more access points.

Other features and advantages of the present invention will become apparent from the following detailed description and accompanying drawings. It should be understood, however, that the detailed description and specific examples are given by way of illustration and not limitation.
Many modifications and changes within the scope of the present invention may be made without departing from the spirit thereof, and the invention includes all such modifications.

DESCRIPTION OF THE DRAWINGS

The invention will be better understood and objects of the invention will become apparent when consideration is given to the following detailed description thereof. Such description makes reference to the annexed drawings wherein:

Fig. 1 illustrates a system in accordance with the present invention.

Fig.2 illustrates a block diagram of the radio mapping utility and localization engine.
Fig. 3 illustrates tracking update analysis.

Fig. 4 illustrates a point in close range to a line segment.

Fig. 5 illustrates an example of the clustering result on a PDA using affinity propagation on the radio map at the north orientation.

Fig. 6 illustrates the implementation result of the average localization error with respect to the number of access points used, under different number of clusters generated in all four orientations.

Fig. 7 illustrates the CDF of the localization error of the positioning system under different coarse localization schemes, when 10 APs are used.

Fig. 8 illustrates the implementation result of the average localization error under different AP
selection schemes.
Fig. 9 illustrates the cumulative error distribution for kernel-based method, kNN, and the proposed CS-based method.

Fig. 10 illustrates recovery of the radio map during the offline phase using the theory of compressive sensing.

Fig. 11 illustrates a comparison of the localization accuracy, using actual RSS measurements at 72 reference points, the recovered RSS radio map from samples on 36 reference points, and that using interpolated RSS radio map.

Fig. 12 illustrates a modular overview for implementing the computer program of the present invention.

Fig. 13 illustrates a comparison of localization accuracy of a mobile user for different positioning and tracking schemes.

Fig. 14 illustrates cumulative error probability using 10 APs.

Fig. 15 illustrates the connected graph defined in CNIB to be used for path routing.

Fig. 16 illustrates a screenshot of the computer program of the present invention showing the actual tracks that the user is walking. The line shows the routed path generated by the navigation module. The squares denote the user's locations and the circle denotes the destination.

In the drawings, embodiments of the invention are illustrated by way of example. It is to be expressly understood that the description and drawings are only for the purpose of illustration and as an aid to understanding, and are not intended as a definition of the limits of the invention.
DETAILED DESCRIPTION

The present invention provides a system, method and computer program for anonymous localization. The location of a mobile device can be determined based on received signal strength (RSS) from one or more access points (APs) and a radio map. A radio map can be generated by measuring RSS at a set of fingerprints, which are a finite set of reference points within the area to be mapped.
The present invention enables the mobile device to measure RSS and compare RSS
to the radio map in order to determine its location without providing the RSS measurements to a server or other third party, thus enabling anonymous localization. Furthermore, the location of the APs does not need to be known in order to generate the radio map or determine the location of a mobile device.

The present invention comprises two phases: an offline phase for generating or reconstructing a radio map, and an online phase for localization. A radio mapping utility linked to a mobile device may implement the offline phase, while a localization engine linked to the mobile device may implement the online phase.

The radio mapping utility may generate the radio map by implementing a clustering technique, such as affinity propagation, followed by an outlier adjustment to address the effects of RSS
variations. A compressive sensing algorithm may be used by the radio mapping utility to reconstruct the radio map based on RSS measurements at a subset of fingerprints, reducing the number of measurements significantly for updating the radio map.

The localization engine implements one or more algorithms to determine the location of the mobile device based on the measured RSS. One such algorithm is the k-nearest neighbor algorithm (kNN), which estimates the mobile device's location by computing the centroid of the k closest neighbors that have the smallest Euclidean distance with respect to the online RSS
readings. Another algorithm is a statistical method, in which the probability of each potential position is analyzed using the Bayesian theory and kernel functions, assuming that RSS readings from different APs are independent at every time instant. A less computationally complex algorithm, which therefore enables real-time or near real-time performance, is a compressive sensing (CS) algorithm for recovering signals that are sparse or compressible under a certain basis, with far fewer noisy measurements than that needed by the Nyquist sampling theorem. The sparse signal can be reconstructed exactly with high probability by solving an t1-minimization problem. Due to the sparse nature of localization in the spatial domain, the CS algorithm, which offers exact deterministic recovery using a linear programming, is preferable.

In another aspect of the invention, the online phase is divided into two stages: (1) a coarse localization stage to reduce the region of interest; and (2) a fine localization stage to determine an accurate location. The use of two stage localization can significantly reduce processing requirements, thereby enabling real-time or near real-time localization of a mobile device. The localization engine preferably implements a cluster matching algorithm in the coarse localization stage and a compressive sensing algorithm in the fine localization stage.

Additionally, past position estimates and motion dynamics can be used in the coarse localization stage to more accurately reduce the region of interest. The motion dynamics can be modeled by a general Bayesian tracking model and a filter can then be derived to refine the position estimates.
By assuming the Gaussian tracking noise model and linear motion dynamics, the general filter becomes a Kalman filter, whose optimal solution is a minimum mean square error (MMSE) estimate. Although the assumption of Gaussian RSS-position relationship is not often the case, the application of the Kalman filter as the post-processing step is able to improve the accuracy of the positioning systems. The accuracy of the estimate can be improved further by using a particle filter. This filter can be applied on non-Gaussian and non-linear models and it can also be refined by additional information such as map, accelerometers, etc. Therefore, in the coarse localization stage, the previous estimate may be used to select the nearby reference points, in addition to the clusters of reference points selected according to the online RSS readings.
The tracking system may also implement the Kalman filter to smooth the estimate update.

The localization engine of the present invention is operable to provide relatively accurate location data associated with a mobile device, based on radio information derived from the mobile device only, without the need for information from a remote server tracking the location of the mobile device.

Fig. 1 illustrates a system in accordance with the present invention. The system may include one or more network access points (APs), a network accessible server for administering a fingerprint database, the fingerprint database linked to the server for providing a radio map, and one or more mobile devices, each linked to a network adaptor compatible with the protocol implemented by the APs so as to be operable to receive the signal from the one or more access points. For example, the APs may be IEEE 802.11 wireless access points and the network adaptors may be WLAN adaptors.

The network access points may have known or unknown location and may be associated with different networks. Each network access point emits a signal. The radio map is based on received signal strength from the one or more network access points at one or more reference points.
Each of the mobile devices may further include or be linked to a localization engine. The localization engine is operable to obtain the radio map or a subset thereof from the server, and to determine the location of the mobile device based on the radio map and the received signal from the one or more access points. The one or more mobile devices may also be linked to a navigation module for enabling a user of the mobile device to provide initial set up, and to provide the user with path routing and tracking updates. One or more of the mobile devices may further include or be linked to a radio mapping utility. Alternatively, certain mobile devices may be linked to a radio mapping utility and used for generating the radio map, while others may be linked to a localization engine and used by users, for example.

The one or more mobile devices will be referred to hereinafter as a single mobile device, linked to both the radio mapping utility and the localization engine, for simplicity.

The mobile device may continuously or intermittently collect online RSS
readings from each AP
(that is within radio range of the mobile device) at a time interval At, which may be limited or dependent on the mobile device's network adaptor and computing performance, denoted as r(t) _ [r,(t),r2(t),...,rL(t)], t = 0, 1, 2, ... and then computes the estimated positions, denoted as p(t) _ [z(t), y(t)]T , where superscript T denotes transposition.

During the offline phase, the time samples of RSS readings are collected at the reference points, by pointing the mobile device to different orientations (e.g., north, south, east, west). The raw set of RSS time samples collected from AP i at reference point j with orientation o is denoted as { v i) (r), r =1, ..., q, q > 1} , with q as the total number of time samples collected. Then, the average of these time samples may be computed and stored in a database, which is referred to as the radio map. The radio map gives a sufficient representation of the spatial RSS properties in the given region of interest, and can be represented by T('):

((/ 0 T 1,1 W1,2) ylI,N
(o) (o) (0) qj(o) _ W2,1 W2,2 ... V2,N (1) 'L1 Y1L2 ~LON
where yr(1" 0.) _ 4 1 yr; ) (z) is the average of RSS readings (in dBm scale) over time domain from AP i at reference point j with orientation o, for i = 1, 2, ...,L, j = 1, 2, ...,N, and o E O= {0o, 900, 180 , 270 }. L is the total number of APs that can be detected, and N is the number of reference points. The columns of `P >, radio map vectors, represent the RSS
readings at each reference point with a particular orientation o, which can be referred to as yr~ ) =[yiii),YV ~,...,VIL11 IT, j =1,2,...,N(2) where the superscript T denotes transposition.

In addition, the variances of these time samples may be stored. The variance vector for each reference point is defined as A(0) _[,&(a) ,...,~i;IT,j=1,2,...,N(3) where A _ q 1 q-i (yr( ) (z) - yr! o) )2 is the unbiased estimated variance of RSS readings from AP i at reference point j with orientation o.

The radio map is then the table (xl,y,;W0),AJ )), j=1,===,N, oE0 , where (x,, yj) is the coordinates of the jth reference point. If no RSS reading is found for an AP
at a reference point, the corresponding RSS entity in the radio map is set to a small value (in dBm scale) to imply its invalidity.

The reference points collected in the offline phase may be divided into a number of clusters.
Since the database at different orientations has a different set of RSS
readings, the clustering may be performed independently for each orientation. The affinity propagation algorithm may be used to generate the clusters, as it does not require initialization of exemplars in the traditional K-means clustering algorithm. Affinity propagation considers all reference points equally as potential exemplars by assigning the same real number, known as preference, for each reference point as an input. Then, real-valued messages are recursively transmitted between pairs of reference points based on a measure of similarity, until exemplars and corresponding clusters are generated. The pair-wise similarity s(i, j)(0) indicates how well the reference point j is suited to be the exemplar for reference point i, which is defined as s(i, = (o) - - I I W; ' -,V; ) I I2 (4) Vi, j E {1, 2,..., N}, j:;t, i, o E O

The self-similarity value s(j, j)(0) , j = 1, 2, ...,N, indicates the possibility that reference point j may become an exemplar. Since all the reference points are equally desirable to be exemplars, their preferences may be set to a common value. In order to generate a moderate number of clusters, the common preference for each orientation is defined as pe ) = y( ) . median{s(i, j)( ), t/i, j e {1, 2,..., N}, j x i} (5) where y( ) is a real number which is experimentally determined, such that a desired number of clusters is generated.

The core operation of the algorithm is the transmission of two kinds of real-valued messages between pairs of reference points. The responsibility message r(i, j)(O), sent from reference point i to candidate exemplar reference point j, is given by r(i, j)(0) = s(i, j)(0) - max{a(i, j')( ) + s(i, j')( )} (6) j,J

where i ~ j, and the availability message a(i, j)('), sent from candidate exemplar reference point j to reference point i, is defined as a(i, j)( ) = min 10, r(j, j)( ) + Z max{0, r(i', j)( )}} (7) Psi,!

The messages may be passed recursively between pairs of reference points within each radio map and the above updating rules may be followed until a good set of exemplars and corresponding clusters emerges.

This process is conducted after the fingerprints are collected during the offline phase. For each radio map with a particular orientation o, let H( ) be the set of exemplars;
and for each reference point j E H() , let Cf ) denote the set of reference points for which reference point j is an exemplar. Each outlier, referred to as a reference point that is in the set of C(0) but physically far away from its exemplar j on the map, is further adjusted by assigning a new exemplar that is in its close proximity. Therefore, using the set of exemplars and their corresponding radio map vector, a coarse localization stage may be provided to select the clusters that match the online RSS observations, and then the reference points of these candidate clusters may be used to localize the mobile device during the fine localization stage.

The actual localization of the mobile device takes place in the online phase.
During the online phase, an RSS measurement vector, denoted as V/r = VIL,r]T (8) where {yrk r, k =1,..., L} , is collected by the mobile device pointed to an arbitrary orientation at unknown location. As shown in Fig. 2, there may be two stages in the online phase, the coarse localization by cluster matching to reduce the area of interest; and the fine localization by using compressive sensing to recover the location estimation.

The goal of the coarse localization stage is to reduce the region of interest from the whole radio map to a subset thereof. Thus, it removes outliers, and reduces the complexity for the fine localization stage, as fewer reference points are considered. Furthermore, it confines the maximum localization error to the size of this subset, whereas this error can be much larger when no coarse localization is implemented.

The coarse localization is operated by comparing the similarity between the online RSS
measurement vector and each exemplar to identify the cluster to which the online readings belong. Instead of selecting one cluster, a few best-matched exemplars S with their corresponding cluster member set C may be chosen to avoid the edge problem, which can lead to inaccurate estimation when the location of the mobile device is at the boundaries of clusters.
Meanwhile, due to the time variation of the RSS, the online measurement can deviate from the values stored in the database.

Coarse localization can be implemented using a cluster matching scheme, such as exemplar-based cluster matching, average RSS-based cluster matching, weighted cluster matching or strongest AN for cluster matching to define the appropriate similarity function. Then the clusters with the largest similarity values may be selected as the candidate clusters.

In exemplar-based cluster matching, similar to (4), the similarity function is defined as the negative of Euclidean distance of the online measurement vector yrr to the individual exemplar's RSS radio map vector.

S(r, j)'O) _ - II wr -Y/j ' IIZ, dj E H( 1, `do E 0 (9) In average RSS-based cluster matching, instead of using the RSS radio map vector of each exemplar for cluster matching, the average of the RSS radio map vectors of all the cluster members is used to average out the possible RSS variations that come from a specific exemplar.
It gives a more comprehensive and representative readings of the cluster. In this case, the Euclidean distance of the online measurement vector W- to the cluster with reference point j as its exemplar can be computed by s(r,j)( ) y/, - - II r I C 1 ) l keC(e) ( Wk II ' ) (O) 2 , Vj E H( ), V0 E O

where I C(') I denotes the number of members in the cluster where reference point j is the exemplar.

In weighted cluster matching, since the variance of the RSS readings from each AP at each reference point is recorded during the offline phase, the stability of the RSS
readings from a specific AP within a certain cluster can be considered as a weight for cluster matching. In weighted cluster matching, different weights are added to the above similarity function for each AP, so that stable RSS readings have larger weights. The corresponding similarity function is defined as s(r' J}c ) = - w; ) V/1. V1k ) (11) I C() keC5.) Vi ,r= H( ),`do c- O

where is the element-wise multiplication between two vectors.
W(0) _[a~(0),...,rvl~),...,0)( ]r E {1,...,L}, where o 6) represents the weight for the RSS reading from AP 1 in the cluster j with orientation o, which is proportional to the inverse of the corresponding RSS variance, namely, ( ) I and 0( ) AI (O) (12) xI.J I Cj I kEC;
The weights are normalized, so that L w("? =1.

In strongest APs for cluster matching, since the strongest AN provide the highest probability of the coverage over time, only the set of the APs with the highest online RSS
readings is selected.
Thus, in strongest APs for cluster matching, the similarity is calculated using any of the above schemes by only considering these selected APs.

All the above cluster matching schemes attempt to reduce the possibility of choosing the wrong cluster, which is the main source for the maximum localization error.

The best-matched clusters can be found by using one or more of the above schemes. By evaluating the similarity function described above, the set of best-matched exemplars S with their corresponding cluster member set C can be found as S = {(j,o) : s(r, j)( ) > a, j E H( ),Vo E O} (13) C = U C( ) (14) (j. )-ES
where a is a pre-defined threshold to obtain a moderate number of clusters in S. Since only a small number of clusters is desired to be included in S, a may be set to be a percentage of the maximum similarity, that is a=a, =J.Hmax o{s(r, j)( )}+a2. mine {s(r, j)( '} (15) where a, + a2 =1, and a, = 0.95 are possible examples of such settings.

After the coarse localization, the set of interest can be reduced to the set C. The partial radio map matrix iPLJ , with 9 =1 C I can be obtained by Y'_[V/, ~:`d(j,o)EC] (16) The matrix `P will be used by the following fine localization stage. Note that it is possible that more than two columns in `P represent the same reference point, but with different orientations, as all clusters from different orientations are considered for the cluster matching.

The localization problem has a sparse nature, as the position of the mobile device is unique in the discrete spatial domain at a certain time. Ideally, assuming that the mobile device is located exactly at one of the reference points pointing at one of the orientations, the device's location can be formulated as a 1-sparse vector, denoted as 0 (this assumption can be relaxed). Thus, 0 is a N x 1 vector with all elements equal to zero except 9(n) =1, where n is the index of the reference point at which the mobile device is located, namely 9 = [0'..., 0, 1, 0'..., Of. (17) Then, the online RSS reading measured by the mobile device can be expressed as y = I '9+c (18) where `P is the partial radio map matrix as defined in (16), and a is an unknown measurement noise that comes from RSS deviations. The M x L matrix cis is an AP selection operator applied on the online RSS measurement vector V/,, such that Y=(D V/,. (19) Due to the wide deployment of APs, the total number of detectable APs is generally much greater than that required for positioning, which leads to redundant computations. Furthermore, unreliable APs with large RSS variances may also lead to biased estimation and affect the stability of the positioning system. This motivates the use of AP selection techniques to select a subset of available APs for positioning. Different AP selection schemes can be used to increase the accuracy of the fine localization stage.

According to (1), the set of APs covering the reference points can be denoted as L, with I L J= L.
The objective of AP selection is to determine a set M c L such that I M J= M:5 L. This process is carried out by using the AP selection matrix (D. Each row of CD is a 1 x L
vector with all elements equal to zero except q(l) =1, where I is the index of the AP that is selected for positioning:

om = [0,..., 0, 1, 0, ..., 0], Vm c= {l, 2,..., M} (20) Different approaches can be used to determine the matrix CD , including strongest APs, Fisher criterion and random combination.

In strongest APs, similar to the coarse localization, the set of AN with the highest RSS readings is selected, arguing that the strongest APs provide the highest probability of the coverage over time. Here, the measurement vector (8) is sorted in the decreasing order of RSS readings, and the APs corresponding to the least indices are used. Since C is created based on the current online measurement vector, this criterion may create different CD for each location update.

The Fisher criterion is used to quantify the discrimination ability for each AP across reference points over four orientations. By comparing the metric ~,, Vi E {1,..., L} , defined as E(jj////(o) ~~/ 2 j,o)EC (Y' i, f - Y ) - Quo) (21) 2:0,o)eC ( ai ) The denominator of ~, ensures that RSS values do not vary much where yr; _ (j.o)Ec yr") over time so that the offline and online values are similar; while the numerator represents the discrimination ability of each AP by evaluating the strength of variations of mean RSS across reference points. The APs with the highest ~, are selected to construct the matrix CD for the fine localization.

In a random combination, unlike the above two schemes, which select the appropriate APs based on different criteria and create the matrix (1) dynamically for each location update, the AP
selection operator CD is defined as a random M x L matrix with i.i.d Gaussian entries. The random combination scheme has less computational complexity, as the matrix is fixed at different runs, and it does not require as much RSS time samples to calculate the variance as required by the Fisher criterion.

Besides sparsity in (18), incoherence is another important property that should be satisfied to enable the use of the CS theory. However, 0 (generated by either the strongest APs or the Fisher criterion) and LI' are in general coherent in the spatial domain, which violates the incoherence requirement for the CS theory. The following orthogonalization pre-processing procedure restores such property.

Define an orthogonalization operator T as T=QRt (22) where R = CD`s' , and Q = orth(RT )T , where orth(R) is an orthogonal basis for the range of R, and Rt is a pseudo-inverse of matrix R.

The orthogonalization process is done by applying the operator T on the measurement vector y, such that z = Ty = QRt R9 + s' (23) where e'= Ts. It is straightforward to show that QRtR = Q. Therefore, the localization problem formulated in (18) can be reformulated as z =Q9+s'. (24) Here Q is a row orthogonal matrix with unit norm. It has been proved that Q
obeys the Restricted Isomatry Property (RIP) that is needed by the CS. Since 0 has a sparse nature, according to the theory of compressive sensing, if the number of APs M is in the order of log(N), the location indicator 0 can be well recovered from z with very high probability, by solving the following 1, -minimization problem.

9 = arg min 110111, s.t., z = Q9 + c'. (25) BERN

where is the 1,-norm of a vector.

On a special note, the complexity of the 1, -minimization algorithm grows proportional to the dimension of vector 0, which represents the number of potential reference points. Therefore, the coarse localization stage, which reduces the area of interest from all the N
reference points into a subset of N reference points IN << N) , reduces the computational time for solving the I,-minimization problem and thus, allows this procedure to be carried out by resource-limited mobile devices.

If the mobile device is located at one of the reference points pointing at one of the measured orientations, the recovered position is almost exact. However, in a real scenario, the mobile device may not be exactly located at a certain reference point facing a certain orientation. In such cases, the recovered location 9 is not an exact 1-sparse vector, but with a few non-zero coefficients. In order to compensate for the error induced by the grid assumption, a post-processing procedure is conducted. It is preferable to choose the dominant coefficients in B
whose values are above a certain threshold A, and take the normalized value in B as the corresponding weight for each potential reference point to calculate the location estimation. Let R be the set of all indices of the elements of 8 such that R={nIB(n)>A}. (26) The location of the mobile user can be estimated by a weighted linear combination of these candidate points, which is EneR9(n) nB(n) ('xn,Yn) (27) The radio map may need to be updated if the surrounding environment changes significantly.
Specifically, let vector r, represent the RSS readings from AP i over the reference points that cover the experimental area, which is also the transpose of the ith row of the RSS radio map database defined in (1). Let F denote the linear operator that transforms the r from the pixel representation in the spatial domain into the sparse representation in the frequency domain, namely, x=F-ri(28) Further define a sampling matrix GMXN . Each row of G is a 1 x N vector with all elements equal to zero except g(n) =1 where n is the index of the reference point that is measured on the radio map by the mobile device during the offline phase. The measured reference points are randomly selected.

Therefore, the offline RSS vector from a certain AP measured by the mobile device can be expressed as:

m Gri = GF`1x = Rx (29) Since x has a sparse feature, with the similar orthogonalization procedure in (23), namely, z =
Tm, the radio map can be reconstructed by solving the following 1, -minimization problem. Here, total variation minimization, a special case of the 1, -minimization, can be used to solve the sparse signal recovery problem, as it is widely used for 2D image recovery.

z=argminJIV(x)111,s.t.,z=Qx+s(30) X

where 11 O(x)1k,, defined as the total variation of x, is the sum of the magnitudes of the gradient at every point, and c is the measurement noise.

Finally, the reconstructed RSS radio map from AP i over the area of interest can be obtained by r. = F-'x (31) The radio map from the rest of the APs can be recovered using the same approach. Therefore, RSS is measured on a small number of grid points and (30) is used to reconstruct the radio map on the whole grid. Since the number of measurements (M) needed for the radio map recovery obeys O(k log(N)), where N is the total number of reference points, and k indicates the sparsity level of signal x, significant reduction in the number of measured reference points can be expected.

The CS-based positioning system can be extended as a tracking system, which improves the accuracy in estimating the mobile device's locations. By using the mobile device's previous estimated locations, the tracking system is able to refine the current estimate in two ways: 1) to select appropriate reference points in the coarse localization stage and 2) to apply Kalman filter for better location estimate. Map information is used to determine how the Kalman filter is updated to find the location. A modified coarse localization stage chooses the relevant reference points based on two criteria: (1) online RSS readings; and (2) physical proximity of previous estimate.

The localization engine first selects the clusters of reference points defined in the offline stage that have similar RSS reading patterns to the online RSS vector r(t). This cluster matching process is as previously described. The localization engine then compares the online RSS
readings to the averaged RSS readings of the reference points from the same cluster to select the best-matched clusters of reference points, which are denoted as a set C.

Besides the use of the online RSS readings to choose the relevant reference points, reference points can be chosen by finding the possible range of the device's current location based on the previous estimated location, p(t -1) = [z(t -1),$ (t -1)]T . Since a person cannot walk far away within a short period of time, it is reasonable that the system limit the region of interest into a range of possible walking range from the previous estimated position, if it is known and reliable.
There are two schemes to choose this possible walking range, unpredicted scheme and predicted scheme.

The unpredicted scheme selects the reference points which are within walking distance during the specified update time interval to the previous estimated location, that is CDIS, = {J (x~ - x(t -1))2 + (y; - $ (t -1))2 (32) <,3J E I,..,N) where /3 is the walking distance within the specified update time interval At.

The predicted scheme uses the previous estimated location to predict the current possible location based on a linear motion model and then chooses the reference points which are within the walking range of this predicted position. The state vector of this linear model contains the position and velocity of the mobile device, i.e..z(t) =
[.x(t),y(t),vx(t),vy(t)]T with vx(t) and vy(t) as the velocities in x and y direction at time t respectively. Then, the model is defined as 2(t) = Fz(t -1) (33) z(t) = Hi(t) (34) with 1 0 At 0 0 1 0 At 1 0 0 0 F= 0 0 1 O H 0 1 0 0 (35) where z(t) is the predicted current location. The estimation of the unknown velocities, v,,(t) and vy(t) can be obtained from the output of the Kalman filter based on the same linear model (33) in addition to Gaussian noises, which is implemented after the fine localization stage. The implementation of the Kalman filter is described above.

The localization engine then selects a set of reference points, CD,$,, which are in close proximity to the predicted current location, z(t), according to (32), where z(t) is used instead of p(t -1) .
After the selection of these two groups of relevant reference points based on RSS readings similarities and physical proximities, the localization engine includes the common reference points that appear in both groups as the set of reduced region, where the final localization stage is then applied. The common reference points are obtained as a set C, C=CRSS fl{(i, o) Ij C- CDio and o G O}
(36) This set contains reference points that satisfy both conditions of similar RSS
readings to the online RSS measurement and within close range to the mobile device's previous location. Thus, they are very likely to be the possible locations at which the mobile device is located. By introducing the constraint of physical range, the localization engine is able to identify the instant when the online RSS readings collected is not useful to find the mobile device's position. In normal operation, the mobile device must be within a range around its previous location. If the selected clusters of reference points in C. are far away from the previous location, then the online RSS readings can be regarded as invalid, as there are large deviations between the online readings and offline database, so that the cluster matching based on similarities of RSS readings fails to find the correct clusters of reference points. This scenario leads to an empty set of C and halts the fine localization stage. If such thing occurs, the localization engine discards this online RSS measurement vector and obtains a new one to restart the localization process.

There may be a possibility that all the consecutive online RSS measurement vectors lead to empty sets of C. This makes the localization engine continuously collect a new online RSS
measurement, which is then discarded, preventing it from computing the true estimate of the mobile device's location. This happens as the previous position estimate is not accurate and hence the selection of reference points based on such estimate does not match with the reference points selected based on the online RSS measurement vector. Thus, the localization engine only uses the online RSS measurement vector to select the reference points, when N,consecutive online RSS measurement vectors are discarded, arguing that the previous position estimate is no longer valid to reduce the localization problem into a smaller relevant region.

A Kalman Filter is applied on the location estimate computed in the fine localization stage to enhance the tracking performance. By adding Gaussian noises to the linear motion models as described in (37), the Kalman tracking model is formulated as x(t) = Fx(t -1) +a)(t) (37) z(t) = Hx(t)+v(t) (38) The process noise w(t) - N(0,P) and the measurement noise v(t) - N(0, U) are assumed to be independent with the corresponding covariance matrices P and U.

The steps to obtain the final estimates of state vector z(t) and the error covariance P(t) include prediction and update.

In prediction, (t) = Fz(t -1) (39) P-(t) = FP(t -1)FT + Q (40) In update, K(t) = P-(t)HT (HP-(t)HT + R)-' (41) x(t) = x (t) +K(t)(z(t) - Hx (t)) (42) P(t) = (I - K(t)H)P-(t) (43) Note that the observation z(t) in (42) is the estimation of position computed by the fine localization stage, i.e. z(t) = p(t). After the computation of the state vector, the final estimate of the mobile device's location can be found as p(t) = HH(t) .

In a real situation, the Kalman filter is able to enhance the tracking performance when the user with a mobile device is walking along a corridor inside a building, as the linear motion assumed by the filter is sufficient to model the user's trajectory. However, when user is making a turn at an intersection, the linear model does not apply on this behavior which involves abrupt change in direction and hence the Kalman filter requires several more updates to reflect the user's true trajectory and thus leads to more errors in position estimate.

By using the map information, the Kalman filter can be modified to follow the user's trajectory more closely. Since the Kalman filter behaves the best when the user is walking straight along a corridor but performs poorly around the intersections, the Kalman filter is reset when the user is in the region of intersection. According to the map, a region of intersection i can be identified as a non-rotated bounding box with (x,'n;n,y,,;,,)and (x;n y,'õ) as the lower-left and upper-right corners respectively. Thus, the user is within the intersection region at time t,n,,, if the below two conditions are satisfied:

xmin 5 x(t1Urn) <- xmax,Y,;n < Y(t,,,,,,) <_ Ymax (44) Then, the Kalman filter is reset by reassigning the initial condition of Kalman filter x(t,,,,,)=[p(tt,m),0,0]TandP(ttõm)=P(0) and the Kalman filter is updated as normal according to (39) to (43) for the next estimate using z(tn,,,,, + 1) = p(t,urn + 1) This removes the inaccurate estimation by Kalman filter when the user is making a turn.

The mobile device may further be linked to a navigation module to provide guidance to the mobile user to reach his desired destination. The navigation module may enable: 1) initial setup, 2) path routing and 3) tracking update.

The navigation module depends on the map of the region of interest, which shows the layout of different features such as rooms, corridors and elevators etc. During the setup stage, information about different map features are extracted from the map, in order to let the navigation system to generate a feasible path and descriptive instructions about the surrounding environment.

First, the layout of the map may be interpreted as a graph with nodes, which are a set of Cartesian coordinates of the possible passage points along the corridors or destinations and edges between nodes that means they can reach each other physically. Each edge may be assigned with a non-negative weight, which is defined as the Euclidean distance between two connected nodes.
This connected graph is used by the system to generate the desired path for path routing. In addition to the definition of this connected graph, a list of map features is recorded along with their locations, so that the navigation system can generate instructions based on these features.

At the beginning of the navigation, the mobile device first obtains the user's input of desired destination and user's current location, which can be either specified by the user or estimated by the device using the localization engine. Then, the system identifies the two nodes on the connected graph, predefined during initial setup, that are closest to the destination and user's current location, respectively. Path routing may be interpreted as finding the shortest path between these two nodes on the connected graph. This problem can be solved by applying the Dijkstra algorithm.

The generated path can be divided into series of line segments that are oriented at different directions. The generated path can be denoted as a set of line segments G =
{11,12,...,15}, where S
is the number of line segments and each segment is denoted as 1, = (p.' , p, }
, where p., = { x,, y.' }
and pe = {xe,ye} are the starting and ending points of the ith line segment respectively. The turning points are identified as the ending points between line segments, that is T 1,...,S -1} Q. Based on these generated line segments, the system is able to determine the turning points, the direction of turns and the distance traveled at each line segments. In addition, the system can also find out the list of relevant map features appeared along this generated path denoted as F = { p f, Feature] I j =1, ..., Q, where p f = (x f, y f } is the location of feature j and Feature, is the feature's name and C is the total number of relevant map features.

After the generation of the path that can lead the user to his targets, the navigation module begins tracking updates to keep track of user's position. For each tracking update, the navigation module compares the location estimate to the routed path to check if the user follows the path properly. The analysis is done according to Fig. 3.

The navigation module first determines if the user reaches the destination by checking the Euclidean distance between the user's current position and the target being within a range,(id,;;,,~;oõ . Otherwise, the navigation module attempts to match the user's current position p(t) to one of the line segments in the generated path set G. If this tracking update is within a line segment, 1; as illustrated in Fig. 4, then the navigation module can find the projection and the minimum distance of the tracking update point p(t) to the line segment l;
with p,' and pe by solving the two equations:

P' =P,' +A (P,, -Ps) (45) (P(t) - P')(Pe - Ps) = 0 (46) where p' is the projected point which is collinear p' and pe and is the ratio in terms of the distance between ps and pe indicating how far the point p' is away fromp. The solution to p;
from (45) is A - (P(t) - PS)(Pe - PS) (47) IIP` -pie 11' If the computed ,u; is within a range of [0, 1], then the projected point falls onto the line segment, which means the update estimate is within the range of this line segment. By substituting (47) into (45), the projected point p can be computed and the shortest distance of the tracking update point to the line segment can be obtained as dm;n =I1 p(t) - p` 11. Hence, the navigation module determines that the tracking estimate matches the line segment 1, if i) A E
[0,1] [0, 1] and ii) dm;. < /f,,,, . If there are consecutively No fff,, tracking estimates failing to match with any of the line segments in G, then the navigation module can prompt the user to stop moving and do the path rerouting following the same procedure described above using user's current position as the starting point.

In addition, if the value of i is close to one, which means the user is close to'the end of the line segment, then the navigation module can identify that the user is required to turn and give appropriate instructions. Note that, in normal situation, where the user follows the path correctly, the value of should increase along the same line segment for each update and eventually move to the next segment. The direction of turn can then be computed based on the current and next line segments' directions.

To determine the orientation of the mobile user, for each tracking update, a direction vector is computed between the current update and the previous one and then is compared with the currently matched line segment direction. If consecutive NR,,nõg dbea,on tracking updates are in opposite direction of the line segment, then a voice command of wrong direction may be issued to the user.

Finally, the navigation module computes the Euclidean distance between the user's current estimate p(t) to the map features in F. If the distance is smaller than /3f, then the module will generate the corresponding voice command regarding this specific map features to the user.

The present invention can be applied to a plurality of indoor and outdoor applications.

For example, the present invention can be used to augment current location-based services that are operable outdoors (for example, by use of GPS) but lose functionality indoors. Augmenting outdoor location-based services could be advantageous by providing users the ability to receive path routing within a building from an external origin. It could further be used to enhance emergency services by providing precise locations of emergency situations.
Advertisers could also extend advertising to a more precise location to enhance behavioral marketing.

Another application of the present invention is to enable data sharing between mobile devices within close proximity. Potential applications include file (photos and other media) sharing, document exchange and dating.

Further applications include enabling precise localization of a user within a blueprint provided by the radio map. For example, a user could use a mobile device to navigate a shopping mall that has a radio map augmented with location information including store locations, department locations within a store, sections with a department, and even product placement within a section. Conversely, the invention could be used to monitor/track the location of a child or adult in a busy mall setting.

Similarly, the invention could be used to: index and remember the location of parking a user's car in an indoor parking garage; locate services (bathrooms, restaurants, boarding gates, etc.) in an airport, conference center, theme park, hotel or other large or unfamiliar facility; and track locations of assets by placing a fingerprint at the asset location. Asset location tracking could be beneficial, for example, for enabling delivery companies to quickly and precisely locate a delivery point.

The invention could further be used as input to a mobile utility that is location based. For example, in an indoor location that has contextual feedback at a given location, the invention could provide the prompt necessary for the feedback to be provided to a user.
In a specific example, a user could be in a museum that has a mobile application providing information regarding the museum artifacts. When the user is in the vicinity of an artifact, the corresponding information can be automatically provided to the user. This could also be used at a site auction, for example, where information on the sale items could be presented to users based on the user being in proximity of the sale items. It could also be used in real estate sales, where owners could set up information to be presented for specific portions (e.g., rooms, views, etc.) of the real estate.

Experiment # 1 Real data were obtained from an office building. Specifically, the experiments were carried out on a 30 in x 46 m area of the fourth floor of an eight-story building (Bahen Center at the University of Toronto). A total of 26 APs were detected throughout the area of interest.

A PDA (HP iPAQ hx4700 with Windows Mobile 2003 pocket PC) was used to measure WLAN
signal strength value, and a software was developed in Visual Studio C# to implement the CS-based positioning system on the device. The RSS values were collected on the device by using the open source library OpenNetCF, which provides access to MAC address and RSS values of WLAN APs. During the offline phase, the RSS observations from 26 APs were recorded for a period of 50 seconds (one sample per second) over 72 reference points with an average grid spacing of 1.5 m. At each reference point, RSS values from four orientations were recorded. The online observations were collected on a different day by the device at unknown locations as the testing points to evaluate the actual performance of the system under time-varying environment.
Each online observation is an average of 2 RSS time samples, which takes 2 seconds for Wi-Fi scanning on the device.

In the following, the localization error, which is measured by averaging the Euclidean distance between the estimated locations of the mobile user and the actual location over the testing points, has been reported as the performance measure.

In order to mitigate the RSS variations and to remove potential outliers for coarse localization, affinity propagation is applied on each radio map to generate clusters and their corresponding exemplars during the offline phase. Fig. 5 shows an example of the clustering result on the PDA
for the radio map at the north orientation. Each point represents one reference point at which RSS readings are collected, and each color represents one cluster. It shows that the 72 reference points are divided into 13 clusters, and most of reference points belonging to the same cluster are geographically close to each other. We note that the number of clusters might be different at different orientations.

Since the coarse localization is used to reduce the area of interest for location estimate into a subset C, the dimension of the sparse signal in the CS algorithm is reduced tog . According to the theory of compressive sensing, the location indicator can be well recovered when the number of APs is in the order of log(N). This allows the system to reduce the number of APs required for accurate location recovery. Fig. 6 shows the average localization error as a function of the number of APs used in the algorithm, under different number of clusters generated by the affinity propagation. As illustrated in Fig. 6, only 8 APs are needed to achieve about 1.1 m error when a total of 58 clusters are generated in all four directions, and 1.9 m error under 29 clusters.
However, 18 APs are needed to achieve 1.8 m error if no clustering scheme is applied.
Furthermore, the number of clusters generated by the affinity propagation is determined by the input of preference value, which is experimentally set. In one hand, increasing the number of clusters helps to reduce the area of interest into a smaller region after the coarse localization and thus, improves the average localization accuracy and also reduces the complexity for the fine localization. On the other hand, this increases the chance of choosing the wrong cluster, which induces a large localization error of the positioning system. Therefore, we studied different coarse localization schemes to reduce the possibility of choosing the wrong cluster. Fig. 7 illustrates the Cumulative Distribution Function (CDF) of the localization error under different coarse localization schemes described above, when 10 AN are used. It is shown that the weighted cluster matching scheme reduces the maximum localization error from 9.2 m to 6.3 m over the experiments, as it takes into account the stabilities of the RSS
readings from different APs.

Fig. 8 shows the average localization error under different AP selection schemes for the fine localization. In the random combination scheme, according to (19), the value of x-axis implies the number of linear random combinations of online RSS values from the L APs.
Among the three schemes proposed, AP selection using the Fisher criterion achieves the best performance especially when the number of AN is less than 5, while the strongest AN
selection achieves the worst performance. The proposed random selection scheme achieves a localization error comparable to that of the Fisher criterion, but does not require a large number of offline RSS
time samples to calculate the variance. In addition, the matrix b can be reused for each location update, saving the computational time for the fine localization.

Meanwhile, using more APs for the fine localization may not necessarily increase the accuracy due to the biased estimation that is generated by unstable APs. As shown in Fig. 8, when the number of APs is above 11, the performance of the positioning system decreases. It is not affected by the way we choose the APs, as redundant APs are introduced for all of the three cases.

We compare the localization system of the present invention with the traditional fingerprinting approaches, known as the kNN and the kernel-based methods, in terms of the cumulative error distribution, when 10 APs are used. The proposed positioning system used affinity propagation to generate overall 58 clusters at four orientations during the offline phase, and then performed coarse localization by weighted cluster matching, followed by a fine localization stage consisting of a random AP combination, an 1, -minimization algorithm and a post-processing procedure. For fairness, the three positioning systems use the same coarse localization scheme, but are different in the fine localization stage. Fig. 9 shows the implementation result. As noticed, with 90% of the time, the proposed CS-based method achieves an error within 2.7 m, and outperforms the kNN and the kernel-based method by 25% and 28%, respectively.

In order to reduce the number of reference points for the fingerprinting approach, the same CS
scheme is also used in the offline phase to reconstruct the radio map based on RSS
measurements at only a small number of reference points. In the simulation, only 36 of the reference points are randomly picked, and we show that the radio map at the overall 72 reference points can be well recovered compared with the values we actually measured at these 72 reference points.

Fig. 10a shows an example of the actual measured RSS radio map from AP 1 at 72 reference points over the experimental area, while Fig. I Ob is the corresponding reconstructed radio map, based on samples from 36 randomly picked FPs using the same PDA. The same technique is used for recovering RSS readings from the rest of APs.

We further use all the reconstructed RSS radio map for localization, compared with the localization using the actual measured radio map. Fig. 11 shows that the proposed scheme is able to achieve an average error of 1.6 m by using the reconstructed radio map, when 10 APs are used. However, using the radio map recovered by the traditional interpolation approach reduces the average localization error to 2.6 m, when 10 APs are used.

Experiment #2 A software application is developed on smart devices installed with Windows Mobile platform to implement the proposed indoor tracking and navigation system. The software is developed in C#
using Microsoft Net Compact Framework version 3.5. In addition, two open source library:
OpenNetCF and DotNetMatrix are used to provide the RSS scanning function and matrix operations to the program. The software is tested on a PDA manufactured by HP, hp iPAQ
hx2750. The overview of our software is illustrated in Fig. 12.

The localization system with prediction is tested at the second floor of the Canadian National Institute for the Blind (CNIB) with an area dimensions of 18m x 36m. During the offline phase, we have run the developed software on the PDA to collect 100 RSS time samples for each of four orientations: North, East, South and West (with the sampling rate of 1 sample per second) over 128 reference points (N = 128) which are evenly distributed on the site with an average grid spacing of 1.5m. In this experiments, about 15 clusters are generated for each orientation RSS
database, such that the reference points within the same cluster are geographically close to each other and only 2 or 3 outliers are required to be modified.

Several traces are collected to evaluate the performance of the localization system with prediction. We have walked at a constant speed along 4 different traces, which are summarized in Table I and collected the RSS readings from visible APs using the same PDA
at 1 sample per seconds.

TABLE I TRACES SUMMARY

Trace # # of turns # Repetitions Distance Average Duration 1 2 4 53.63m 156.3s 2 2 4 29.43m 89.2s 3 0 4 30.80m 84.6s 4 4 2 91.84m 279.5s Fig. 13, for example, compares four different versions of the localization system. In the scheme called "CS-based Positioning", we only use the estimated location of the user.
In the "CS-based + Kalman filter", we input the location estimates obtained by the localizer into a Kalman filter to further refine the location estimates. The localization system is also used in two versions:
without prediction and with linear prediction. The details of these versions are discussed above.

The mean errors of these systems remain around the same once the number of APs used are beyond 10 and reflect the property of the CS theory that a minimum bound is required. The localization system with prediction using either scheme is able to improve the non-prediction localization system and also achieve better accuracy than by directly applying the Kalman filter.
When 10 APs are used, the localization system using the unpredicted scheme leads to the average error improvement of 0.98m (37%) and 0.45m (21%) over that of the non-prediction localization system and the Kalman filter respectively.

This tracking system with the unpredicted scheme is compared with the non-prediction localization system and the direct applications of the Kalman filter on both the KNN method and the non-prediction localization system. Fig. 14 shows the comparison results in terms of cumulative error distributions and Table II shows the position error statistics for these four systems. The localization system outperforms the other three methods, as it has the smallest mean error, 90th percentile error and variance when compared to the other systems.

TABLE II POSITION ERROR STATISTICS

Method Mean [m] 90 [m] Max [m] Var [m^2]
CS-based +Positioning 2.68 5.26 26.64 4.79 Positioning KNN+Kalman Fileter 2.41 4..41 10.95 2.42 CS-based + Kalman Filter 2.17 4.15 24.10 2.69 Proposed Tracking 1.74 3.36 17.93 1.91 We have tested the navigation module on the same experimental site using our developed software on the PDA. Fig. 15 shows the map with the proper defined nodes, which are used by the navigation module to generate path to the desired destination and give appropriate guidance to the user.

The navigation starts by first asking the user to choose the desired destination on the PDA, then the software finds the user's location and runs the Dijsktra shortest path algorithm on the predefined connected graph to generate the walking path. Then, the system starts our proposed tracking system, which updates the user's current position every 2 seconds (using 2 RSS time samples for each update). An example screenshot is illustrated in Fig. 16 where the user starts from Room 207 on the map and walks towards Room 218E.

We have asked several visually impaired people to try our navigation device on this experimental site. It is clear that the device is able to provide useful guidance to the user to reach his desired destination, as it is able to generate relevant instructions according to the user's locations. In particular, the device is able to lead the participants to reach the spring water fountain, a small, wall-mounted object that is often easily missed by the participants.

The foregoing description of embodiments has been presented for purposes of illustration and description. It is not intended to be exhaustive or to be limited to the precise forms disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of the invention. The embodiments were chosen and described in order to explain the principals of the invention and its practical application to enable one skilled in the art to utilize the invention in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the claims appended hereto and their equivalents.

Claims (20)

1. A system for localization of a mobile device, the system comprising:
(a) one or more network access points each emitting a signal;
(b) a network accessible server;

(c) a fingerprint database linked to the server, the fingerprint database providing a radio map based on received signal strength from the one or more network access points at one or more reference points; and (d) a mobile device, the mobile device linked to-(i) a network adaptor operable to receive the signal from the one or more access points; and (ii) a localization engine operable to obtain the radio map or a subset thereof from the server, and to determine the location of the mobile device based on the radio map and the received signal from the one or more access points.
2. The system as claimed in claim 1, wherein the localization engine provides a coarse localization stage to reduce a region of interest of the radio map, and a fine localization stage to determine the location within the region of interest.
3. The system as claimed in claim 2, wherein the localization engine implements the coarse localization stage with a cluster matching algorithm.
4. The system as claimed in claim 3, wherein the cluster matching algorithm is an affinity propagation algorithm.
5. The system as claimed in claim 2, wherein the localization engine implements the fine localization stage with a compressive sensing algorithm.
6. The system as claimed in claim 1, wherein the localization engine further bases the location determination on one or more past position estimates of the mobile device.
7. The system as claimed in claim 1, wherein the localization engine further bases the location determination on motion dynamics of the mobile device.
8. The system as claimed in claim 7, wherein the motion dynamics are modeled by a Bayesian tracking model and a filter.
9. The system as claimed in claim 8, wherein the filter is a Kalman filter.
10. The system as claimed in claim 1, wherein the mobile device is further linked to a navigation module enabling a user of the mobile device to obtain path routing and tracking updates based on a desired destination.
11. A method for localization of a mobile device, the method comprising:

(a) providing a radio map based on received signal strength of one or more signals emitted from one or more network access points at one or more reference points;
and (b) initiating a mobile device to receive, by means of a network adaptor linked to the mobile device, the signal from the one or more access points, and to obtain the radio map or a subset thereof; and (c) determining at the mobile device, by means of a localization engine linked to the mobile device, the location of the mobile device based on the radio map and the received signal from the one or more access points.
12. The method as claimed in claim 11, wherein determining the location further comprises a coarse localization stage to reduce a region of interest of the radio map, and a fine localization stage to determine the location within the region of interest.
13. The method as claimed in claim 12, wherein the coarse localization stage is provided by a cluster matching algorithm.
14. The method as claimed in claim 13, wherein the cluster matching algorithm is an affinity propagation algorithm.
15. The method as claimed in claim 12, wherein the fine localization stage is provided by a compressive sensing algorithm.
16. The method as claimed in claim 11, wherein determining the location is further based on one or more past position estimates of the mobile device.
17. The method as claimed in claim 11, wherein determining the location is further based on motion dynamics of the mobile device.
18. The method as claimed in claim 17, wherein the motion dynamics are modeled by a Bayesian tracking model and a filter.
19. The method as claimed in claim 18, wherein the filter is a Kalman filter.
20. The method as claimed in claim 11, wherein the mobile device is further linked to a navigation module enabling a user of the mobile device to obtain path routing and tracking updates based on a desired destination.
CA2725250A 2010-12-13 2010-12-13 System, method and computer program for anonymous localization Abandoned CA2725250A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CA2725250A CA2725250A1 (en) 2010-12-13 2010-12-13 System, method and computer program for anonymous localization

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CA2725250A CA2725250A1 (en) 2010-12-13 2010-12-13 System, method and computer program for anonymous localization

Publications (1)

Publication Number Publication Date
CA2725250A1 true CA2725250A1 (en) 2012-06-13

Family

ID=46232307

Family Applications (1)

Application Number Title Priority Date Filing Date
CA2725250A Abandoned CA2725250A1 (en) 2010-12-13 2010-12-13 System, method and computer program for anonymous localization

Country Status (1)

Country Link
CA (1) CA2725250A1 (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2014092996A2 (en) * 2012-12-14 2014-06-19 Apple Inc. Location determination using fingerprint data
WO2014120465A1 (en) * 2013-01-31 2014-08-07 Apple Inc. Survey techniques for generating location fingerprint data
CN104038901A (en) * 2014-05-30 2014-09-10 中南大学 Indoor positioning method for reducing fingerprint data acquisition workload
GB2557449A (en) * 2016-11-08 2018-06-20 Ford Global Tech Llc Vehicle localization based on wireless local area network
CN110361693A (en) * 2019-07-15 2019-10-22 黑龙江大学 A kind of indoor orientation method based on probability fingerprint
CN115683121A (en) * 2022-12-30 2023-02-03 武汉大学 Method for generating multi-source ubiquitous positioning fingerprint based on measured track

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104813186A (en) * 2012-12-14 2015-07-29 苹果公司 Location determination using fingerprint data
AU2013360083B2 (en) * 2012-12-14 2017-02-02 Apple Inc. Location determination using fingerprint data
WO2014092996A2 (en) * 2012-12-14 2014-06-19 Apple Inc. Location determination using fingerprint data
WO2014092996A3 (en) * 2012-12-14 2014-09-25 Apple Inc. Location determination using fingerprint data
US8934921B2 (en) 2012-12-14 2015-01-13 Apple Inc. Location determination using fingerprint data
US9198003B2 (en) 2013-01-31 2015-11-24 Apple Inc. Survey techniques for generating location fingerprint data
US9532184B2 (en) 2013-01-31 2016-12-27 Apple Inc. Survey techniques for generating location fingerprint data
WO2014120465A1 (en) * 2013-01-31 2014-08-07 Apple Inc. Survey techniques for generating location fingerprint data
CN104956236B (en) * 2013-01-31 2017-06-23 苹果公司 Technique for investigation for generating location fingerprint data
CN104038901A (en) * 2014-05-30 2014-09-10 中南大学 Indoor positioning method for reducing fingerprint data acquisition workload
CN104038901B (en) * 2014-05-30 2017-04-26 中南大学 Indoor positioning method for reducing fingerprint data acquisition workload
GB2557449A (en) * 2016-11-08 2018-06-20 Ford Global Tech Llc Vehicle localization based on wireless local area network
US10429190B2 (en) 2016-11-08 2019-10-01 Ford Global Technologies, Llc Vehicle localization based on wireless local area network nodes
CN110361693A (en) * 2019-07-15 2019-10-22 黑龙江大学 A kind of indoor orientation method based on probability fingerprint
CN115683121A (en) * 2022-12-30 2023-02-03 武汉大学 Method for generating multi-source ubiquitous positioning fingerprint based on measured track

Similar Documents

Publication Publication Date Title
US9763035B2 (en) System, method and computer program for anonymous localization
US9167386B2 (en) System, method and computer program for dynamic generation of a radio map
Nessa et al. A survey of machine learning for indoor positioning
Chen et al. Bayesian fusion for indoor positioning using bluetooth fingerprints
Hossain et al. A survey of calibration-free indoor positioning systems
Abdelnasser et al. SemanticSLAM: Using environment landmarks for unsupervised indoor localization
Hilsenbeck et al. Graph-based data fusion of pedometer and WiFi measurements for mobile indoor positioning
TWI500003B (en) Positioning and mapping based on virtual landmarks
Shin et al. Unsupervised construction of an indoor floor plan using a smartphone
Afuosi et al. Indoor positioning based on improved weighted KNN for energy management in smart buildings
US20170311127A1 (en) Sensor-based geolocation of a user device
CA2725250A1 (en) System, method and computer program for anonymous localization
Suski et al. Using a map of measurement noise to improve UWB indoor position tracking
Kim et al. Crowdsensing-based Wi-Fi radio map management using a lightweight site survey
Homayounvala et al. A novel smartphone application for indoor positioning of users based on machine learning
Conesa et al. Geographical and fingerprinting data to create systems for indoor positioning and indoor/outdoor navigation
Shokry et al. DynamicSLAM: Leveraging human anchors for ubiquitous low-overhead indoor localization
Junoh et al. Floor map-aware particle filtering based indoor navigation system
Kolakowski Automatic radio map creation in a fingerprinting‐based BLE/UWB localisation system
Beal Contextual geolocation: a specialized application for improving indoor location awareness in wireless local area networks
Rezazadeh et al. Fundamental Metrics for Wireless Sensor Networks localization.
Bejuri et al. Optimization of Rao-Blackwellized particle filter in activity pedestrian simultaneously localization and mapping (SLAM): an initial proposal
Keser et al. A priori verification and validation study of RFKON database
Au Rss-based wlan indoor positioning and tracking system using compressive sensing and its implementation on mobile devices
Chesser et al. bTracked: Highly Accurate Field Deployable Real-Time Indoor Spatial Tracking for Human Behavior Observations

Legal Events

Date Code Title Description
FZDE Discontinued

Effective date: 20161214