基于RSSI测距的三维无线传感网络萤火虫定位算法的研究
2021-10-14
来源:榕意旅游网
高技术通讯2016年第26卷第1期:1~7 doi:10.3772/j.issn.1002-0470.2016.01.001 基于RSSI测距的三维无线传感网络萤火虫定位算法的研究① 张立国②马 鹏金梅 范关常 刘宇浩 秦皇岛066004) (燕山大学河北省测试计量技术与仪器重点实验室摘要研究了三维空间无线传感器网络(WSN)未知节点的定位。针对目前三维空间 无线传感网络定位算法精度低的问题,提出一种基于接收信号强度指示(RSSI)测距的萤 火虫定位的算法。该算法首先利用RSSI进行测距,建立信号强度随传播距离衰减的模 型,然后在已知一定数量的锚节点的情况下,通过萤火虫算法寻找目标函数最优值,进而 对未知节点进行定位。仿真验证结果表明,该定位算法相比其他算法定位精度有很大提 高,在30m×30m x 30m的空间内定位误差仅为0.59m。 关键词无线传感网络(WSN),三维空间,接收信号强度指示(RSSI),萤火虫算法(FA) 优且计算比较复杂。此外还有多种测距和定位算 0 引言 无线传感网络(wireless sensor networks,WSN) 节点位置对整个网络的应用有重要影响,因此节点 法 J以及DV.Hop定位算法和改进的混合蛙跳算 法 。 本研究采用接收信号强度指标(received signal strength indicator,RSSI)方法实现测距,并且对所测 定位技术在无线传感网络中有着举足轻重的地位。 迄今为止无线传感网络的定位方法大都针对二维空 间,而在实际应用中网络节点主要分布在三维空间, 因而较好的三维空间定位方法有着良好的发展前 景。节点定位不但要考虑定位精度,而且要考虑定 位成本和复杂度。目前国内外针对此问题提出了多 种算法。例如胡伟等人提出了一种基于四面体质心 迭代的三维近似三角形内点测试(approximate point— in.triangle test,APIT)定位算法_1 J,该算法虽提高了 数据进行统计加权处理来减小环境等因素造成的测 量误差,建立起距离与信号强度之间精确的衰减模 型,然后用萤火虫算法对未知节点进行定位,并且与 传统的四边测量算法 以及交叉粒子群算法 和 遗传算法 进行对比,结果表明,萤火虫算法的定 位精度明显高于四边测量算法、交叉粒子群算法和 模拟退火算法,并且四点定位分八次测量再取均值 的方法误差最小,定位精度最优。 节点覆盖率,减小了计算量,但是实验过程较为复 杂,不容易实现;印第安大学的Zhang等提出了一种 Landscape.3D定位算法 J,此方法节点间无需通讯, 减小了功耗,但其存在即时迭代过程计算量大,LA 装置在移动过程中要严格保持同步等缺点;Zhang 等 利用粒子群优化(particle swarm optimization, 1 RSS!测距 1-1 RSSI测距原理 无线信号传输过程中,信号强度会随着距离的 增大而衰减。因此,接收信号强度指示(RSSI)测距 原理是将信号强度的衰减转变成信号的传播距离, 利用信号强度的衰减与传播距离之间的函数关系来 PSO)算法进行节点定位,但此算法容易陷入局部最 ①②河北省自然科学基金(F2015203392)和秦皇岛市科技计划(201502A043)资助项目。 男,1978年生,博士,副教授;研究方向:惯性导航,三维立体重构及智能信号处理;联系人,E.mail:zlgtime@163.corn (收稿日期:2015—10-20) 高技术通讯2016年1月第26卷第1期 估测传播距离 m]。 通常信号衰减模型采用对数——常态分布模型 来获得距离信息,但在实际测量时,通常将上述模型 转换为阴影模型,如下式所示: RSSI=一10n×lgd+A (1) 式中,RSSI为接收信号强度,单位为dBm;n为衰减 因子,其值与环境有关;d为接收端与发射端之问的 距离,单位为m;A为信号传播单位距离时接收到的 信号强度,显然,A与n的值决定了RSSI与d的大 小。 1.2数据的统计加权 由于RSSI测量结果容易随环境变化而产生误 差,因此有必要对测量数据进行加权处理以减小其 误差 。 本文提出了一种利用测量中值对数据进行统计 加权处理的方法。设每组数据测量次数为n,然后 将数据按照从小到大顺序排列,因此数据中值定义 如下式所示: MRss, ( [RSSI( ̄1,n为奇数 【 [Rss,(詈)+R 5,(号+ )],n为偶数 (2) 船 ,即为测量中值,再求出各个RSSI值和测 量中值之间的方差,如下式所示: D =(RSSI —MR跚) (3) 为了避免方差为零,进行加权系数处理,P 为 加权系数,用下式表示: _l (4) 对加权系数进行求和处理, 为归一化加权系 数,用下式表示: P F =} (5) P 。 由式(3)、(4)、(5)可以看出,测得的RSSI值与 测量中值肘 ,相差越大,加权系数 的值越小,即 所占比重越小;当RSSI值与 船,值相等时,加权系 数 值最大,此时RSSI值被赋予最大权重。 将测得的多组数据分别与对应的加权系数相 乘,再求和,所得结果即为两节点间RSSI信号的衰 一2一 减值:∑F ×RS‘=1 SIi。 此方法的优点在于以测量中值为基础计算权 值,将包含粗大误差结果的RSSI值赋予很小的权 值,累加时可以忽略,这样既没有简单的删掉粗差数 据,又能滤除一部分粗大信号,使得RSSI测距方法 能够适应更加复杂的环境。 2 萤火虫算法 2.1萤火虫算法简介 萤火虫算法(firefly ̄gofithm,FA)是由剑桥学 者Yang在2009年提出的一种基于生物群智能的随 机优化算法 引,随后应用在寻优问题上,并能够成 功寻找到函数最优解。 2.2萤火虫算法实现定位 萤火虫之问均可以相互吸引,且由亮度低的向 亮度高的靠近,发光强度由目标函数决定r1。,H]。 设未知节点坐标和锚节点坐标分别为(z,Y, z)和( ,Y , ),未知节点的估计坐标为( ,多, 三),未知节点和锚节点之间的真实距离为 d = ̄/( —Xi) +(y—Yi) +( —Zi) (6) 设未知节点与锚节点的测量距离为a ,因此可 得到目标函数 ,Y, )= ( —Xi) +(Y—Yi) +(z—z ) 一 I (7) 其中每一个萤火虫都是目标函数的一个解。当目标 函数取最小值时,误差最小,定位精度最高,即位置 最优,因此把定位问题转变为对目标函数求解优化 问题。最终,大多数萤火虫都聚集在最优解附近。 其中n为锚节点个数,得到的输出值即为未知节点 估算坐标( ,夕,三),因此定位误差为 卵=j(x一曼) +(y一多) +(z一三) (8) 程序执行步骤如下: 步骤1:获取锚节点与未知节点间距离。 步骤2:初始化萤火虫种群,在指定范围内随机 分布萤火虫。 张立国等:基于RSSI测距的三维无线传感网络萤火虫定位算法的研究 首先协调器节点与电脑相连,建立无线传感器 程序执行前萤火虫分布 3 网路,随后,作为终端发射信号的未知节点和作为路 由器的8个锚节点打开,开始加人网络。未知节点 发射信号,8个锚节点接收信号,将自己接收到的信 号强度传递给协调器节点并在电脑上显示 引。 本文先选取A、 、F、日4个点(选取点的原则为 4点不共面,且未知节点在4点所构成的区域内)对 未知节点』v进行定位,将萤火虫数量设置为30,迭 冒2 憾 掘1 0 30 图l0萤火虫初始分布图 代次数为200,用MATLAB仿真的效果如图8所示。 程序执行前萤火虫分布 3 2 鹊 恒1 0 3O 图8萤火虫初始分布图 如图9所示,大多数萤火虫基本上都聚集在未知 节点坐标附近,程序输出结果为( ,多,三)=(15.31, 21.13,I.19),根据式(8)得到定位误差为 = 1.42 mo 程序执行后萤火虫分布 3 §2 檀1 0 3O 图9萤火虫最终分布图 接下来,用8个锚节点共同为未知节点定位,本 次将萤火虫数量设置为60,迭代次数设置为300,仿 真效果图如图10所示。 如图l1所示,大部分萤火虫基本上都聚集在未 知节点坐标附近,程序输出结果为( ,多,三)= (15.12,21.16,2.40),根据式(8)得到定位误差为田 =1.23m 程序执行后萤火虫分布 3 互2 姬1 0 30 0 图l1萤火虫最终分布图 长方体共有8个端点,选取其中4个不共面的端 点对未知节点进行定位,从中任选8组包含未知节点 区域进行定位,定位之后,取8组定位结果平均值。 其中8组端点最终输出结果分别为ABFH(15.o3, 21.23,2.39)、AEFH(15.31,21.13,1.19)、BFGH (14.83,20.9l,2.25)、CDFH(15.45,21.38,2.o4)、 ABEH(15.17,21.13,2.4o)、BEFH(14.98,18.86, 2.40)、AFGH(15.03,21.27,2.02)、CDFG(14.72, 18.64,2.35)。最后取平均值( ,多,三)=(15.ar7, 20.57,2.13),.根据式(8)得到定位误差叼=0.59m。 3.3对比实验分析 依据上述仿真实验,当锚节点个数分别设置为 4,5,6,7,8时(每个锚节点只利用一次,一起进行定 位;当锚节点个数取8时,区别于上述8组四个节点 平均值的方法),萤火虫定位算法与交叉粒子群算法 和遗传算法相比较,如图12所示。 从图l2可以看出,萤火虫算法相比于这两种智 能算法有着更精确的定位精度,将8组4个节点萤火 虫定位算法与传统的四边定位算法加入对比,得到的 比较结果如表3所示。 一5一 高技术通讯2016年1月第26卷第1期 重 趟 删 图12三种算法对}匕图 表3几种算法比较表 经比较,采用8组四个节点萤火虫定位算法平 均值,不但充分利用上了全部8个锚节点,并且定位 精度要远远高于传统的四边定位算法以及交叉粒子 群算法和遗传算法的智能算法,相比于单次四个节 点萤火虫定位方法和八个节点萤火虫定位方法,能 够有效地将定位误差控制在1 m以内,因此效果最 好。 4 结论 本文主要提出了一种基于三维空间无线传感网 络的萤火虫定位算法,打破了二维空间定位算法的 局限性。该算法首先用RSSI方法对锚节点和未知 节点之间进行测距,得到稳定的拟合曲线,然后利用 加权算法处理误差,最后在此基础上利用测距结果 使用萤火虫算法对未知节点进行定位。经过仿真验 证,该算法相比于传统的四边定位算法以及交叉粒 子群算法和遗传算法,在定位精度上有了很大的提 ——6—— 高,在30m×30m×3m的空间内定位误差仅为 0.59m,对于分布在三维空问上的无线传感网络节 点的定位具有很好的理论和实际意义。 参考文献 [1]胡伟,朱西平,文红等.基于四面体质心迭代的三维 APIT定位算法研究.传感技术学报,2013,26(10): 1432—1436 [2]Zhang L,Zhou X,Cheng Q.Landscape一3D:a robust lo— calization scheme for sensor networks over complex 3 D terrains.Local Computer Network,2006,3 1 st:239-246 [3]Zhang Z,Cui H,Localization in 3D sensor networks using stochastic particle swaFITI optimization.Wuhan Uni— versity ̄urnal ofNatural Sc e es,2012,17(6):544— 548 [4]Dalce R,Val T,Bossche A.Comparison of indoor locali— zation systems based on wireless communications.Wire— less Engineering and Technology,2011,(2):240-256 [5]冯晨,张玲华.改进混合蛙跳算法在无线传感网定位 中的应用.计量学报,2013,34(004):360-365 [6]文举,金建勋,袁海.一种无线传感器网络四边测距 定位算法.传感器与微系统,2008,27(5):108-110 [7]王俊,李树强,刘刚.无线传感器网络三维定位交叉 粒子群算法.农业机械学报,2014,45(5):233-238 [8]王金鑫,赖旭芝,吴敏.基于遗传算法的三维无线传 感器网络定位新算法.高技术通讯,2008,18(6): 579-584 [9]徐世武,王平.ZigBee技术中基于RSSI测距的定位 算法研究.单片机与嵌入式系统应用,2012,12(1): 1I3 [10]Zhu X,Feng Y.RSSI—based algorithm for indoor localiza· tion.C andNetwork,2013,5(02):37-42 [11]陶金龙,康志伟,骆坚.基于RSSI测距的加权概率定 位算法.电子测量与仪器学报,2014,28(10):1123- 1129 [12]Yang X S.Firefly algorithms for muhimodal optimization. Stochastic algorithms: ̄undations and applications. Springer Berlin Heidelberg,2009.169-178 [13]高伟明.萤火虫算法的研究与应用:[硕士学位论文]. 兰州:兰州大学,2013.18-22 [14]王吉权,王福林.萤火虫算法的改进分析及应用.计 算机应用,2014,34(9):2552-2556 张立国等:基于RSSI测距的三维无线传感网络萤火虫定位算法的研究 [15]王瑛辉,石理碧,孙坚.基于ZigBee技术的无线传感 器网络在能源计量系统中的应用.计量技术,2013, 11:30-32 Research on a firefly localization algorithm based on RSSI ranging for 3 D wireless sensor networks Zhang Liguo,Ma Peng,Jin Mei,Fan Meichang,Liu Yuhao (Measurement Technology and Instrumentation Key laboratory of Hebei Province, Yanshan University,Qinhuangdao 066004) Abstract The techniques of localizing the unknown nodes of 3 D wireless sensor networks(WSN)were studied.Aiming .at the problem of low localization accuracy of current localization algorithms for 3 D wire1ess sensor networksa fire. lfy localization algorithm based on the ranging using received signal strength indication(RSSI)for 3 D wireless sen— sor networks was proposed.The algorithm uses RSSI to measure the signal—propagating distance and models the at. tenuation of sinalg strength with the sinalg—propagating distance,and thenuses the ireffly algorithm to find the op- ,timal value of the objective function to locate unknown nodes under the condition that a certain number 0f anchor nodes are known.The simulation resuhs showed that the localization accuracy of the new localization algorithm Was greatly higher than current algorithms,and its localizing error in the space of 1 0m x 1 0m×1 0m was just 0.59m. Key words:wireless sensor network(WSN),three—dimensional,received sinagl strength indication(RSSI), ifrefly algorithm(FA) ——一7——