This invention relates generally to wireless sensor networks, and more particularly to estimating locations of the sensor nodes.
With ever-increasing popularity of low cost wireless sensor networks, the deployment of such networks in an increasing number of applications is becoming feasible. Wireless sensing and monitoring, resource tracking and management, environmental monitoring, defense and security related applications are only a few domains that offer a wide-ranging market for wireless sensor networks.
Many applications need the locations of the sensors to make sensor data meaningful. Given the fact that sensors are very low-cost devices, sensors typically do not include a global positioning system (GPS). Moreover, many sensors may operate in areas where GPS may not be effective or feasible, e.g., inside buildings and in urban environments.
A number of method are know for measuring two-way time of arrival of ranging signals, including arrival data fusion, time difference of arrival data fusion and angle of arrival data fusion. For a 2D location, at least three sensors are needed, and more for a 3D location.
Distances r between the nodes can be used to estimate their locations. A target node t estimates distances to anchor nodes n at know locations by solving
{circumflex over (r)}
1t
2=(x1−xt)2+(y1−yt)2
{circumflex over (r)}
2t
2=(x2−xt)2+(y2−yt)2
. . . . (1)
{circumflex over (r)}
nt
2=(xN−xt)2+(yN−yt)2
A common way to solve these equations uses an over-determined non-linear system of equations, Sayed et al., “Network-based wireless location: challenges faced in developing techniques for accurate wireless location information,” IEEE Signal Processing Magazine, vol. 22, no. 4, pp. 24-40). Rearranging terms, and assuming that target node 1 is at an origin (x1/y1)=(0,0) without losing generality, these equations can be expressed in a matrix form as
As shown in
where T is a transpose operator, and “̂” indicates an estimate.
The initial location estimate {circumflex over (X)} (0) 251 is used to initialize an objective function 270
where a function max returns a maximum value, and σit is the variance of the multiple range measurements between the target and anchor nodes.
After obtaining an initial estimate for the target location, a numerical search method can be used, e.g., gradient descent or a Gauss-Newton approximation. The search procedure 260 searches for the global minimum of the cost function 270 to estimate x.
Unreliable ranges may degrade accuracy of the location estimate, because those measurements are embedded in b. Therefore, unreliable ranges need to be eliminated. In addition, the computational complexity in computing the inverse of H in Equation (3) is high, when the number of anchors is greater than three.
The embodiments of the invention provide a method for accurately estimating locations of nodes in a wireless sensor network. The invention uses an initial set of three nodes for 2D location estimation, or four nodes for 3D location estimation. The modes are designated as anchor nodes after estimating their locations.
The embodiments of our invention provide a method for estimating locations of nodes in a wireless network. In one embodiment, the nodes are sensors. The estimates are based on ranging signals transmitted by the nodes. The embodiments include estimating a location of a target node, converting the target node into an anchor node, and refining the location estimates after all target nodes are converted to anchor nodes.
As shown in
Estimating Location of a Target Node
There are N anchor nodes at known locations within communication range of the target node t, and the coordinates of the target are not known as shown in
An anchor sub-set generation unit 310 forms unique anchor sub-sets 311 from the 3-tuples, such that each sub-set contains coordinates of the three anchors and corresponding distances between those anchors and the target. The number of anchor sub-sets is
where N=3 or greater.
The anchor subsets 311 {(xi, yi, {circumflex over (r)}it), (xj, yj, {circumflex over (r)}jt), (xk, yk, {circumflex over (r)}kt)} for anchors i, cj, ck are entered into the anchor sub-set data restructuring units 320 that determine {Hm,bm} {321-323} for subset m. Then, we estimate the initial location 330 of the target by using the anchor sub-set m according to
as shown in
As a result,
location estimates are obtained for a single target.
A geometric constrain is applied to the estimated location based on the ranging distances to determine valid locations. The geometric constraint application 340 is shown in
From the initial target location, and the locations of the anchors used in the subset m, the angles 500 between the target 100 to the anchors are
where rit2=(xi−{circumflex over (x)}t(0,m))2+(yi−ŷt(0,m))2. The angle test 510 compares each of the angles 500 to a predetermined threshold.
If any angle is smaller than the threshold γ, then the target and anchors form a geometry that is unreliable for location estimation. In this case, a subset decision unit 520 excludes the corresponding subset data from target location estimation, and only the valid locations are further processed. If the angle is greater than the predetermined threshold, the location is valid.
The valid target location estimates that pass the angle test are entered into a non-linear filter 350 to determine filtered locations. The non-linear filter can be implemented in various forms, including median filtering. The purpose of the non-linear filter 350 is to eliminate singular location estimates.
The valid filtered location estimates are averaged 360 to obtain the initial location estimate
for the target node. Note that the coordinates of the locations are averaged independently.
As shown in
A search procedure 600 is used to find the coordinates 620 of the target n using a global minimum of the objective function 610. The obtained target coordinates are the estimate of the location
of the target node.
Converting to Anchor Node
We measure an accuracy Jn({circumflex over (x)}t, ŷt) of the location {circumflex over (x)} to ensure it satisfies the measured ranges between the target 100 and the N anchors.
If multiple target nodes are within the range of a required number of anchors, then we tentatively localize all of the targets, and then select the target with the minimum accuracy score.
As shown in
where min is a function that returns a minimum.
Estimates for all other target nodes are discarded. After successfully converted the target to an anchor, the node nc can be used as an anchor for localizing other nodes.
A next node can be selected for conversion if that node has at least three adjacent anchor nodes. The localization information is disseminated across the network until all nodes have been converted to anchor nodes. We use as many anchors as possible when localizing a target node. By increasing the number of anchors, the accuracy of estimated location improves.
Refining Location Estimates
After all nodes in the network are localized and converted to anchors, the locations can be refined to final location estimates by using the locations of all nodes in another round of localization. This process can be repeated until a termination condition is met, e.g., the locations remain stable, or a predetermined number of iterations, to make the network adaptive and equally suitable for applications where efficiency is of paramount importance with some tolerance for accuracy and, on the other hand, the applications where accuracy is highly desirable with some relaxation for efficiency constraints.
Although the invention has been described by way of examples of preferred embodiments, it is to be understood that various other adaptations and modifications may be made within the spirit and scope of the invention. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the invention.
This Non-Provisional Patent Application claims priority to Provisional Patent Application 61/165,421, “Method for Estimating Location of Nodes in Wireless Networks.” filed by Ghulam M. Bhatti on Mar. 31, 2009, incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61165421 | Mar 2009 | US |