无线传感器网络Dv-hop定位算法

news/2024/10/22 5:03:04/

无线传感器网络Dv-hop定位算法

文章目录

  • 无线传感器网络Dv-hop定位算法
    • 1.算法原理
    • 2.算法测试
    • 3.参考文献
    • 4.Matlab代码

摘要:根据距离矢量和 GPS定位原理,2001年,Nieuleseu等人提出了 DV-Hop传感器节点定位算法,其只包含少数锚节点,剩余节点为未知节点,需要通过定位算法来确定它们的位置,具有无需测量距离,硬件要求低等点,在硬件条件有限的WSN得到了广泛的应用。

1.算法原理

DV-Hop算法的定位步骤如下:

(1)各锚节点向通信范围内的邻居节点广播自身的位置信息。接收节点则记录到每个锚节点的最小跳数,同时忽略来自同一个锚节点的较大的跳数信息,而后将跳数值加1转发给邻居节点。

(2)每个锚节点根据所记录的其他锚节点的坐标信息和跳数,通过式(1)估算网络平均跳距距离。
H o p S i z e i = ∑ j ≠ i ( x i − x j ) 2 + ( y i − y j ) 2 ∑ j ≠ i h o p S i j (1) HopSize_i=\frac{\sum_{j\neq i}\sqrt{(x_i-x_j)^2+(y_i-y_j)^2}}{\sum_{j\neq i }hopS_{ij}}\tag{1} HopSizei=j=ihopSijj=i(xixj)2+(yiyj)2 (1)
式中, j j j为锚节点 i i i数据表中的其他锚节点号, h o p S i j hopS_{ij} hopSij 为锚节点 i i i j j j​​之间的跳数。

锚节点将所计算的平均跳距广播至整个网络后,未知节点仅记录所收到的第一个平均跳距,并向邻居节点转发,未知节点接收到平均跳距后,跟据所记录的跳数信息,按式(2)估算未知节点 i 到某个锚节点的距离:
L i = S i ∗ H o p S i z e (2) L_i=S_i*HopSize \tag{2} Li=SiHopSize(2)
(3)设 P 1 ( x 1 , y 1 ) , . . . , P n ( x n , y n ) P_1(x_1,y_1),...,P_n(x_n,y_n) P1(x1,y1),...,Pn(xn,yn)表示 n n n个锚节点的坐标位置,待定位节点D的位置为 ( x , y ) (x,y) (x,y) ,其与标节点估计距离分别为 d 1 , d 2 , . . . , d n − 1 d_1,d_2,...,d_{n-1} d1,d2,...,dn1​ ,可以建立式(3)的方程。
{ ( x 1 − x ) 2 + ( y 1 − y ) 2 = d 1 2 ( x 2 − x ) 2 + ( y 2 − y ) 2 = d 2 2 . . . ( x n − x ) 2 + ( y n − y ) 2 = d n 2 (3) \begin{cases} (x_1-x)^2+(y_1-y)^2=d_1^2\\ (x_2-x)^2+(y_2-y)^2=d_2^2\\ ...\\ (x_n-x)^2+(y_n-y)^2=d_n^2 \end{cases}\tag{3} (x1x)2+(y1y)2=d12(x2x)2+(y2y)2=d22...(xnx)2+(yny)2=dn2(3)
第一个方程组减去第后一个方程后,到得:
{ 2 ( x 1 − x n ) x + 2 ( y 1 − y n ) y = x 1 2 − x n 2 + y 1 2 − y n 2 − d 1 2 + d n 2 2 ( x 2 − x n ) x + 2 ( y 2 − y n ) y = x 2 2 − x n 2 + y 2 2 − y n 2 − d 2 2 + d n 2 . . . 2 ( x n − 1 − x n ) x + 2 ( y n − 1 − y n ) y = x n − 1 2 − x n 2 + y n − 1 2 − y n 2 − d n − 1 2 + d n 2 (4) \begin{cases} 2(x_1-x_n)x+2(y_1-y_n)y=x_1^2-x_n^2+y_1^2-y_n^2-d_1^2+d_n^2\\ 2(x_2-x_n)x+2(y_2-y_n)y=x_2^2-x_n^2+y_2^2-y_n^2-d_2^2+d_n^2\\ ...\\ 2(x_{n-1}-x_n)x+2(y_{n-1}-y_n)y=x_{n-1}^2-x_n^2+y_{n-1}^2-y_n^2-d_{n-1}^2+d_n^2\\ \end{cases}\tag{4} 2(x1xn)x+2(y1yn)y=x12xn2+y12yn2d12+dn22(x2xn)x+2(y2yn)y=x22xn2+y22yn2d22+dn2...2(xn1xn)x+2(yn1yn)y=xn12xn2+yn12yn2dn12+dn2(4)
用线性方程组表示为 A L = b AL = b AL=b,其中,
A = [ 2 ( x 1 − x n ) 2 ( y 1 , y n ) . . . . . . 2 ( x n − 1 − x n ) 2 ( y n − 1 − y n ) ] (5) A=\left[\begin{matrix} 2(x_1-x_n)&2(y_1,y_n)\\ ...&...\\ 2(x_{n-1}-x_n)&2(y_{n-1}-y_n) \end{matrix}\right]\tag{5} A=2(x1xn)...2(xn1xn)2(y1,yn)...2(yn1yn)(5)

L = [ x y ] (6) L=\left[\begin{matrix} x\\ y\end{matrix}\right]\tag{6} L=[xy](6)

b = [ x 1 2 − x n 2 + y 1 2 − y n 2 + d n 2 − d 1 2 . . . x n − 1 2 − x n 2 + y n − 1 2 − y n 2 + d n 2 − d n − 1 2 ] (7) b=\left[\begin{matrix} x_1^2-x_n^2+y_1^2-y_n^2+d_n^2-d_1^2\\ ...\\ x_{n-1}^2-x_n^2+y_{n-1}^2-y_n^2+d_n^2-d_{n-1}^2 \end{matrix}\right]\tag{7} b=x12xn2+y12yn2+dn2d12...xn12xn2+yn12yn2+dn2dn12(7)

采用最小二乘法得到方程组的解为:
L = ( A T A ) − 1 A T b L=(A^TA)^-1A^Tb L=(ATA)1ATb

2.算法测试

设定节点覆盖范围为200x200,总节点数为:200,信标节点数20,通信半径为30,未知节点数为180。采用归一化平均定位误差作为评价指标:
e r r o r = ∑ i = 1 m ( x i − x i ∗ ) 2 + ( y i − y i ∗ ) 2 k ∗ m ∗ r (8) error = \frac{\sum_{i=1}^m\sqrt{(x_i-x_i^*)^2+(y_i-y_i^*)^2}}{k*m*r}\tag{8} error=kmri=1m(xixi)2+(yiyi)2 (8)
式中, m m m为未知节点的数目; k k k为实验次数; r r r​为节点的通信半径; ( x i , y i ) (x_i,y_i) (xi,yi)为未知节点的估计坐标; ( x i ∗ , y i ∗ ) (x_i^*,y_i^*) (xi,yi)为该未知节点的真实坐标。

请添加图片描述
请添加图片描述

基础DV-hop的归一化定位误差:0.5384

3.参考文献

[1]吴曦德,方杰,杨世杰,周庆标.基于GPSO-DVHop的传感器节点定位方法[J].计算机工程与应用,2013,49(22):95-99.

[1]张恒. 无线传感器节点定位方法的研究与实现[D].华南理工大学,2012.

4.Matlab代码


http://www.ppmy.cn/news/253539.html

相关文章

计算机网络DV和LS

前言(DV和LS的引导): 我们知道网络层的核心设备就是路由器,而核心功能就是路由和转发,然而路由器的转发依赖于转发表(路由表),那么转发表里面的内容是怎么来的呢? 前面也说过路由分为静态路由和…

ST25DV NFC调试记录

1、硬件层适配,主要是iic驱动的适配 只要按如下的进行适配相应实现即可 IO.Init NFCMEM_IO_Init;//iic相关初始化 IO.DeInit NFCMEM_IO_DeInit; IO.IsReady NFCMEM_IO_IsDeviceReady;//iic设备是否ready IO.Read NFCMEM_IO_M…

dvhop三边测量法MATLAB,基于非测距的DV-Hop定位算法改进

无线传感器网络是由大量随机分布的传感器节点组成,是一种分布式的、自组织的网络。其关键技术包括:网络拓扑控制、节点定位、时钟同步、数据融合、路由协议等。而节点定位问题则是无线传感器网络中的一个最为基本和重要的问题。目前,无线传感器网络定位算法可以分为基于测距…

dv路由算法c语言实现,路由协议之DV算法

#include #define ROUTER_OF_NUMBER 100 //网络中路由的最大数目 #define MaxExp 10000 //假设为此路由费用为无穷大 int RouterNum; //网络中路由的个数 //定义一个路由的信息 struct Router { int exp; //每条链路的费用 int neighbor; //相邻节点的信息,若两节点相邻设置为1…

MOSFET的dV/dt失效

MOSFET的失效机理 本文的关键要点 ・dV/dt失效是MOSFET关断时流经寄生电容Cds的充电电流流过基极电阻RB,使寄生双极晶体管导通而引起短路从而造成失效的现象。 ・dV/dt是单位时间内的电压变化量,VDS的上升坡度越陡,越容易发生MOSFET的dV/d…

产品生产的各个阶段:DV,EV,PV ········是什么意思

ES指:engineering sample 工程样板 EP是指工程设计阶段样板 FEP是指确认阶段样板 CS:comercial sample 商品试样 PP:pre-production or pilot production 预生产或 试生产 MP:mass production 批量生产 ---- DV design verification 设计验证 ---- EV engineering…

一篇文章看明白什么是DV、OV、EV证书

目录 一、序言 二、DV/OV/EV证书说明 三、DV/OV/EV证书区别 WIN系统 OV型和EV型证书在浏览器显示效果 WIN系统 DV证书显示效果​ MAC Firefox火狐浏览器DV证书显示效果 MAC Safari浏览器DV证书显示效果 四、单域名和泛域名证书 五、小结 一、序言 由于近期单位上线缴…

KVO实现原理

概览 本文分为两个大的方面。一、kvo的简单使用场景。二、kvo的来龙去脉,讲讲苹果的实现。 KVO 使用方法,和常用场景。 Key-value observing is a mechanism that allows objects to be notified of changes to specified properties of other objects…