The present disclosure relates to the technical field of wireless sensor networks, and in particular to a data processing method for node localization in wireless sensor networks.
Wireless Sensor Networks (WSNs) are regarded as one of the 21 most impactful technologies of this century and belong to the interdisciplinary frontier of computer science, communication, mathematics, etc. The wireless sensor network is a self-organizing data processing network formed by a plurality of sensor nodes with specific functions deployed in a monitoring area, using methods such as data collection and data transmission. The dense deployment of sensor nodes in the network enables quantitative data collection, data aggregation, and data transfer operations. As a modern intelligent network, the wireless sensor network has been widely applied in various fields such as military, the Internet of Things, environmental monitoring, modern transportation (such as shared bicycles in recent years), convenient express delivery, modern healthcare, industry, and space exploration, with a broad development prospect. In many applications of wireless sensor networks, without corresponding location information, the collected data loses its value. Therefore, the localization technology is one of the hot topics in the research field of wireless sensor networks.
In wireless sensor networks, localization algorithms can be divided into two stages: top-level distance estimation and bottom-level location estimation. The top-level distance estimation method is the main difference between ranging and range-free localization algorithms. Depending on whether it is necessary to directly measure the distance between the transmitter and receiver through hardware means, localization algorithms of the wireless sensor networks can be divided into range-free and range-based types. The core idea of range-based localization algorithms is to calculate a distances between a to-be-located node and anchor nodes using measured physical parameters and determine actual coordinates of the to-be-located node based on the distances between the to-be-located node and the anchor nodes.
In practical application of localization algorithms, various factors can affect the final localization accuracy. One of the more important influencing factors is environmental noise, which leads to deviations between the measured values and actual values of the physical parameters, causing errors in the calculation of distances between the to-be-located node and the anchor nodes. If such noise factors are not handled well, it can result in significant deviations in the final localization results.
Using the traditional received signal strength indicator (RSSI)-trilateration algorithm as an example, the main process involves calculating a distance between a to-be-located node and an anchor node based on the RSSI value of the anchor node received at the to-be-located node. With three such distances, coordinates of the to-be-located node can be calculated using trilateration. However, there is an error in the RSSI signal received at the to-be-located node due to the noise:
RSSIrecieved=RSSIreal+n (1)
where RSSIrecieved represents a received RSSI value, RSSIreal represents a real RSSI value at the position of the to-be-located node, and n represents noise.
Calculating the distance between the to-be-located node and the anchor node based on RSSI reception values with noise can result in a significant distance error, thus affecting the localization accuracy.
To address the impact of environmental factors on received RSSI data, existing solutions involve designing different filtering models to process multiple groups of RSSI data from the same anchor node, to reduce the impact of noise n in Equation (1).
Common filtering methods include mean filtering, mean+median filtering, Gaussian filtering, etc.
Mean filtering is the most commonly used and simplest filtering method. When K groups of RSSI values are received at the to-be-located node, denoted as RSSIi, i∈[1, K], the calculated value given by the following equation is taken as a basis for calculating the distance between the to-be-located node and the anchor node:
If the environmental noise follows a stationary random distribution, according to the law of large numbers, when K is large, this filtering method yields an RSSI calculated value close to the mathematical expectation of this set of RSSI values. However, this assumption is based on two premises: the environmental noise follows an additive Gaussian white distribution, and K is large. In practical environments, noise added to RSSI reception values generally does not follow a stationary distribution due to influences such as shadow fading, multipath propagation, impulse noise, etc. Due to limitations in computation time and storage space, the volume of RSSI data available for processing cannot be very large. Therefore, while mean filtering can reduce the impact of noise under certain conditions, it still has limitations.
The mean+median filtering method considers the influence of occasional impulse noise. The calculated value given by the following equation is taken as a basis for calculating the distance between the to-be-located node and the anchor node:
where R{dot over (S)}SI is the median of the K groups of RSSI values. This method introduces the median of data on the basis of mean filtering, reducing the impact of occasional large noise values. However, while this method decreases the influence of noise, it still retains noise in the calculated data, introducing inevitable errors.
The Gaussian filtering method determines the mean and variance of the Gaussian filtering model to be fit, thus solving the density function ƒ(RSSI):
An effective range of RSSI is determined according to Equations (4), (5), and (6), and an average value of the selected RSSI values after filtering is taken as the basis for calculation. Although Gaussian filtering can effectively screen out data deviating from the true values, it cannot eliminate data fluctuations.
In summary, various noises in real environments can contaminate the RSSI data received at the to-be-located node. The traditional filtering methods can reduce the impact of noises but cannot eliminate it. Moreover, since multiple groups of are required, it causes significant time consumption and space overhead.
An RSSI-based arc trilateration method for wireless sensor network is disclosed in the prior art. The method includes the following steps: S10, establishing an indoor localization layout model based on an arc trilateration layout, and arranging a plurality of beacon nodes on the indoor localization layout model; S20, initializing the indoor localization layout model and localization information of the beacon nodes; S30, continuously receiving a plurality of RSSI signals from a node under test, filtering the RSSI signals through a Kalman filter, selecting three RSSI signals with maximum values, and calculating three test distances corresponding to the three RSSI signals using a path loss model to determine a spatial range of the node under test; and S40, calculating predicted coordinates of the node under test using a particle swarm algorithm. In this patent, the RSSI signals are filtered using a Kalman filter and then three RSSI signals with maximum values are selected for localization. Filtering can only eliminate predictable noise effects and cannot eliminate unpredictable noise. Therefore, localization relying on RSSI data with noise will result in localization errors for the to-be-located node, affecting localization accuracy. Additionally, filtering requires a large volume of RSSI data, leading to significant time consumption and space overhead.
An objective of the present disclosure is to provide a data processing method for node localization in wireless sensor networks with high accuracy, low time consumption, and small space overhead.
To achieve the above objective, the present disclosure provides a data processing method for node localization in wireless sensor networks, including the following steps:
S1: obtaining RSSI data received by a to-be-located node from n anchor nodes, where m groups of RSSI data are collected for each anchor node, and n≥3.
S2: calculating distances between the to-be-located node and the anchor nodes based on the RSSI data.
S3: calculating coordinates of the to-be-located node based on coordinates of the anchor nodes and the distances between the to-be-located node and the anchor nodes; and obtaining a plurality of coordinate calculation values for the to-be-located node through permutations and combinations of the m groups of RSSI data of each of the n anchor nodes.
S4: calculating a centroid C1 of the plurality of coordinate calculation values for the to-be-located node obtained in step S3.
S5: screening out coordinate calculation values with distances to the centroid C1 less than a threshold from the plurality of coordinate calculation values for the to-be-located node obtained in step S3.
S6: calculating a centroid C2 of the coordinate calculation values of the to-be-located node screened out in step S5, and using a coordinate position of the centroid C2 as a position of the to-be-located node.
In one embodiment, coordinates of the to-be-located node are calculated using a ranging localization method in step S3.
In one embodiment, the coordinates of the to-be-located node are calculated based on trilateration in step S3, to obtain Cn3Am1Am1Am1 coordinate calculation values for the to-be-located node.
In one embodiment, n=3, and m=10.
In one embodiment, when the number of the coordinate calculation values for the to-be-located node in step S3 is k, the coordinate calculation values for the to-be-located node are Oi=(xi, yi), where i=1, 2, 3, . . . , k.
In step S5, when the centroid C1=(xC1, yC1), then:
In one embodiment, the threshold in step S5 is less than half of a distance between two furthest apart coordinate calculation values among the plurality of coordinate calculation values for the to-be-located node obtained in step S3.
In one embodiment, the threshold is a quarter of the distance between the two furthest apart coordinate calculation values among the plurality of coordinate calculation values for the to-be-located node obtained in step S3, where the threshold is denoted by r:
In one embodiment, t coordinate calculation values for the to-be-located node are screened out in step S5, and the coordinate calculation values for the to-be-located node are Oi=(xi, yi), where i=1, 2, 3, . . . , t.
In step S7, when the centroid C2=(xC2, yC2), then:
In one embodiment, a time interval between adjacent RSSI data collections for a certain anchor node is 10 seconds or more in step S1.
In one embodiment, the anchor nodes are wireless beacon nodes.
Compared with the prior art, the present disclosure has the following beneficial effects:
In the present disclosure, a plurality of potential coordinate calculation values for a to-be-located node are calculated based on RSSI data received by the to-be-located node from a plurality of anchor nodes. A centroid C1 of these coordinate calculation values is calculated. Then coordinate calculation values with distances to the centroid C1 less than a threshold are screened out, and a centroid C2 of the screened-out coordinate calculation values is calculated. A coordinate position of the centroid C2 is used as the position of the to-be-located node. In other words, a plurality of potential positions for the to-be-located node are calculated using multiple groups of RSSI data and these potential positions are then screened through calculation. Instead of directly processing the received RSSI data, the present disclosure processes the coordinate calculation values that are calculated based on the received RSSI data, offering improved precision, simplicity in computation, and reduced time and space overheads.
The specific implementations of the present disclosure are described in more detail below with reference to the accompanying drawings and embodiments. The following embodiments are intended to illustrate the present disclosure, but not to limit the scope of the present disclosure.
As shown in
In step S1, RSSI data received by a to-be-located node from n anchor nodes is obtained, where m groups of RSSI data are collected for each anchor node, and n≥3.
In step S2, distances between the to-be-located node and the anchor nodes are calculated based on the RSSI data.
In step S3, coordinates of the to-be-located node are calculated based on coordinates of the anchor nodes and the distances between the to-be-located node and the anchor nodes; and a plurality of coordinate calculation values for the to-be-located node are obtained through permutations and combinations of the m groups of RSSI data of each of the n anchor nodes.
In step S4, a centroid C1 of the plurality of coordinate calculation values for the to-be-located node obtained in step S3 is calculated.
In step S5, coordinate calculation values with distances to the centroid C1 less than a threshold are screened out from the plurality of coordinate calculation values for the to-be-located node obtained in step S3.
In step S6, a centroid C2 of the coordinate calculation values of the to-be-located node screened out in step S5 is calculated, and a coordinate position of the centroid C2 is used as a position of the to-be-located node.
In this embodiment, a plurality of potential coordinate calculation values for a to-be-located node are calculated based on RSSI data received by the to-be-located node from a plurality of anchor nodes. A centroid C1 of these coordinate calculation values is calculated. Then coordinate calculation values with distances to the centroid C1 less than a threshold are screened out, and a centroid C2 of the screened-out coordinate calculation values is calculated. A coordinate position of the centroid C2 is used as the position of the to-be-located node. In other words, a plurality of potential positions for the to-be-located node are calculated using multiple groups of RSSI data and these potential positions are then screened through calculation. Instead of directly processing the received RSSI data, the present disclosure processes the coordinate calculation values that are calculated based on the received RSSI data, offering improved precision, simplicity in computation, and reduced time and space overheads. In this embodiment, a plurality of coordinate calculation values for the to-be-located node is calculated based on received RSSI data. These coordinate calculation values represent potential positions of the to-be-located node. A location range of the to-be-located node is determined based on these coordinate calculation values. Then, the centroid C1 of these coordinate calculation values is determined, and coordinate calculation values with distances to the centroid C1 less than a threshold are screened out, further narrowing down the range. The position of the centroid C2 of the screened-out coordinate calculation values is then used as the position of the to-be-located node. This approach ensures that the calculated position of the to-be-located node has minimal error compared to the actual position of the to-be-located node. In this embodiment, there is no need to filter the RSSI data, and a minimal volume of RSSI data is required, resulting in reduced time consumption and space overhead.
In step S3, through permutations and combinations of m groups of RSSI data from each of the n anchor nodes, a plurality of coordinate calculation values for the to-be-located node are obtained. This involves selecting one set of RSSI data from the m groups of RSSI data obtained for one anchor node and pairing the selected set of RSSI data with one set of RSSI data selected from the m groups of RSSI data of another anchor node. The coordinate calculation value of the to-be-located node is then calculated, and this process is repeated until all coordinate calculation values for the to-be-located node are calculated based on the obtained RSSI data. For example, there are four anchor nodes, and three groups of RSSI data are connected for each anchor node. Moreover, the coordinate calculation values of the to-be-located node are calculated using trilateration. In this case, three anchor nodes are selected from the four anchor nodes, and one set of RSSI data is selected from the three groups of RSSI data of one of the selected anchor nodes, to pair with one set of RSSI data of each of the other two anchor nodes for calculation. The total number of the coordinate calculation values for the to-be-located node is Cn3Am1Am1Am1. Therefore, in this embodiment, all potential positions for the to-be-located node are calculated based on the RSSI data from the anchor nodes, and these potential positions are screened through calculation.
This embodiment differs from Embodiment 1 in that, on the basis of Embodiment 1, this embodiment further illustrates step S3 and step S6.
In this embodiment, in step S3, coordinates of the to-be-located node are calculated using a ranging localization method. In other words, the coordinates of the to-be-located node are calculated based on the distances from the anchor nodes to the to-be-located node. Specifically, in this embodiment, the coordinates of the to-be-located node are calculated based on a trilateration localization method, to obtain Cn3Am1Am1Am1 coordinate calculation values for the to-be-located node. Optionally, in this embodiment, n=3, and m=10. In other words, in this embodiment, RSSI data of three anchor nodes is obtained. 10 groups of RSSI data are obtained for each anchor node, thus obtaining 103 coordinate calculation values for the to-be-located node.
In addition, in this embodiment, the centroid C1 is calculated in the following manner in step S3:
If the number of the coordinate calculation values for the to-be-located node is k, the coordinate calculation values for the to-be-located node are Oi=(xi,yi), where i=1, 2, 3, . . . , k.
In step S4, when the centroid C1=(xC1, yC1), then:
In this embodiment, k=Cn3Am1Am1Am1=C33A101A101A101=103.
In addition, in this embodiment, the centroid C2 is calculated in the following manner in step S7:
In step S5, t coordinate calculation values for the to-be-located node are screened out, and the coordinate calculation values for the to-be-located node are Oi=(xi, yi), where i=1, 2, 3, . . . , t. t is a number less than k.
In step S6, when the centroid C2=(xC2, yC2), then:
Other steps of this embodiment are the same as those of Embodiment 1, and will not be repeated herein.
This embodiment differs from Embodiment 2 in that, on the basis of Embodiment 2, this embodiment further illustrates step S5.
In this embodiment, in step S5, the threshold is less than half a distance between two furthest apart coordinate calculation values among the plurality of coordinate calculation values for the to-be-located node obtained in step S3. To ensure localization accuracy, the selection of the threshold, which serves as the basis for filtering the coordinate calculation values, is crucial. If the threshold is excessively large, the impact of noise is not significantly reduced. If the threshold is excessively small, it may result in a large error in the second centroid calculation, introducing new inaccuracies.
Specifically, in this embodiment, the threshold is a quarter of the distance between the two furthest apart coordinate calculation values among the plurality of coordinate calculation values for the to-be-located node obtained in step S3, where the threshold is denoted by r:
The selection of the above threshold can effectively improve localization accuracy while also considering computational simplicity.
Other aspects of this embodiment are the same as those of Embodiment 2, and will not be repeated herein.
This embodiment differs from Embodiment 3 in that, on the basis of Embodiment 3, this embodiment involves simulation experiments for the data processing method.
In this embodiment, in step S1, a time interval between adjacent RSSI data collections for a certain anchor node is 10 seconds or more. This ensures that the collected RSSI data has a temporal aspect, avoiding sporadic accidental noise.
Optionally, the anchor nodes are Bluetooth beacon nodes, characterized by low power consumption, long standby time, and the ability to continuously broadcast without interruption. This enables the reception of periodic groups of RSSI data.
Other aspects of this embodiment are the same as those of Embodiment 3, and will not be repeated herein.
This embodiment differs from Embodiment 4 in that, on the basis of Embodiment 4, this embodiment involves physical inspection for the data processing method.
In this embodiment, the computer configuration for the experimental environment is as follows: CPU: Core™ i7-8700K; RAM: 16 GB; operating system: Windows 10; programming: Matlab. The specific experimental parameters are set as follows: three anchor nodes and one to-be-located node are established. To compare various data processing methods, calculation is performed based on ten groups of RSSI data received by the to-be-located node from each of the three anchor nodes. To simulate RSSI values affected by noise in an actual environment, a burst noise and additive Gaussian white noise with SNR=1 dB are introduced.
The burst noise is set as follows:
wherein a represents significant disturbance noise with an amplitude set at 10% of the RSSI value, and b represents minor disturbance noise with an amplitude set at 3% of the RSSI value.
In the simulation experiment of this embodiment, the to-be-located node and the three anchor nodes are fixed, and the signal-to-noise ratio is SNR=1 d B. As shown in
As shown in
Other aspects of this embodiment are the same as those of Embodiment 4, and will not be repeated herein.
This embodiment differs from Embodiment 5 in that, on the basis of Embodiment 4, this embodiment involves physical inspection for the data processing method.
In this embodiment, beacon nodes equipped with nRF52810/CC2640 R2F Bluetooth chips (with a Bluetooth version BLE4.2 and a receiving sensitivity of −96 dBm) are utilized for actual node localization in a real environment. In the laboratory setup, the Bluetooth beacon nodes serve as anchor nodes, and a mobile phone acts as a to-be-located node. RSSI data from each anchor node is received by software on the mobile phone corresponding to the Bluetooth beacon node. 10 groups of RSSI data are received and recorded for each anchor node, and RSSI data is refreshed at 10-second intervals.
During processing of the received RSSI data, a coordinate system is established in Matlab based on the positions of the Bluetooth beacon nodes and the mobile phone. The data is processed using mean filtering, median filtering, mean+median filtering, and the method proposed in the embodiment of the present disclosure, and traditional RSSI-triangulation is used to calculate node coordinates. The differences in localization accuracy resulting from different data processing methods are compared.
As shown in
Other aspects of this embodiment are the same as those of Embodiment 4, and will not be repeated herein.
In conclusion, the embodiments of the present disclosure provide a data processing method for node localization in wireless sensor networks. A plurality of potential coordinate calculation values for a to-be-located node are calculated based on RSSI data received by the to-be-located node from a plurality of anchor nodes. A centroid C1 of these coordinate calculation values is calculated. Then coordinate calculation values with distances to the centroid C1 less than a threshold are screened out, and a centroid C2 of the screened-out coordinate calculation values is calculated. A coordinate position of the centroid C2 is used as the position of the to-be-located node. In other words, a plurality of potential positions for the to-be-located node are calculated using multiple groups of RSSI data and these potential positions are then screened through calculation. Instead of directly processing the received RSSI data, the present disclosure processes the coordinate calculation values that are calculated based on the received RSSI data, offering improved precision, simplicity in computation, and reduced time and space overheads.
The foregoing are merely descriptions of the preferred embodiments of the present disclosure. It should be noted that several improvements and replacements can be made by a person of ordinary skill in the art without departing from the technical principle of the present disclosure, and these improvements and replacements shall also be deemed as falling within the protection scope of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
202210360751.9 | Apr 2022 | CN | national |
This application is a continuation of International Patent Application No. PCT/CN2022/124282 with a filing date of Oct. 10, 2022, designating the United States, now pending, and further claims priority to Chinese Patent Application No. 202210360751.9 with a filing date of Apr. 7, 2022. The content of the aforementioned applications, including any intervening amendments thereto, are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
9463054 | Mueckter | Oct 2016 | B2 |
9846220 | Kong et al. | Dec 2017 | B2 |
11327147 | Ylamurto et al. | May 2022 | B2 |
Number | Date | Country |
---|---|---|
102497666 | Jun 2012 | CN |
103906230 | Jul 2014 | CN |
104168649 | Nov 2014 | CN |
108989984 | Dec 2018 | CN |
112135249 | Dec 2020 | CN |
114745661 | Jul 2022 | CN |
Entry |
---|
Internation Search Report of PCT/CN2022/124282,Mailed Dec. 12, 2022. |
Number | Date | Country | |
---|---|---|---|
20240292365 A1 | Aug 2024 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2022/124282 | Oct 2022 | WO |
Child | 18530247 | US |