【物联网】基于RSSI的无线传感器网络距离修正定位算法

2024-03-23 08:59

本文主要是介绍【物联网】基于RSSI的无线传感器网络距离修正定位算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对于大多数无线传感器网络应用来说,没有位置信息的数据是毫无意义的。无线传感器网络目标定位跟踪的前提是节点自身定位。无线传感器网络节点定位算法可分为基于距离和距离无关两大类,基于距离的定位算法主要有RSSI、TOA、TDOA、AOA等,距离无关的定位算法主要有质心算法、DV-hop算法、凸规划、MDS-MAP等。
本文来源:http://www.iot101.com/tech/WSN/2012-09-26/366_2.html

引言

对于大多数无线传感器网络应用来说,没有位置信息的数据是毫无意义的。无线传感器网络目标定位跟踪的前提是节点自身定位。无线传感器网络节点定位算法可分为基于距离和距离无关两大类,基于距离的定位算法主要有RSSI、TOA、TDOA、AOA等,距离无关的定位算法主要有质心算法、DV-hop算法、凸规划、MDS-MAP等。

RSSI 测距无需额外硬件,实现简单,具备低功耗、低成本等特点,应用十分广泛。RSSI 的技术原理是已知锚节点发射信号的强度,根据未知节点接收到的信号强度,利用信号传播模型计算两点的距离。由于存在多径、干扰、遮挡等因素,RSSI 测距的精度较低,必须采用各种算法来减小测距误差对定位精度的影响,因而提出了一种基于RSSI 测距的无线传感器网络距离修正定位算法,可有效减小RSSI 测距误差对节点定位精度的影响。

1 算法模型
1.1 无线信号传播模型

RSSI 测距使用的无线信号传播模型包括经验模型和理论模型,理论模型是在大量经验模型数据的基础上总结提炼而成的。

对于经验模型,首先要按照一定的密度选取参考点,建立信号强度与到某个信标点距离的映射矩阵,在实际定位时根据测得的信号强度与映射矩阵进行对比,并采用数学拟合方式确定待测节点到锚节点距离。

LCD显示器的像素间距(pixel pitch)的意义类似于CRT的点距(dot pitch)。点距一般是指显示屏相邻两个象素点之间的距离。我们看到的画面是由许多的点所形成的,而画质的细腻度就是由点距来决定的,点距的计算方式是以面板尺寸除以解析度所得的数值,不过LCD的点距对于产品性能的重要性却远没有对后者那么高。

CRT的点距会因为荫罩或光栅的设计、视频卡的种类、垂直或水平扫描频率的不同而有所改变,而LCD显示器的像素数量则是固定的,因此在尺寸与分辨率都相同的情况下,大多数液晶显示器的像素间距基本相同。分辨率为1024×768的15英寸LCD显示器,其像素间距均为0.297mm(亦有某些产品标示为0.30mm),而17寸的基本都为0.264mm。所以对于同尺寸的LCD的价格一般与点距基本没有关系。

无线信号传播理论模型主要有自由空间传播模型、对数距离路径损耗模型、对数-常态分布模型等,其中对数-常态分布模型的使用最为广泛。

对数-常态分布模型如式(1)所示:
在这里插入图片描述
其中n 是路径损耗指数,表明路径损耗随距离增长的速率,范围在2~6 之间。d0 为近地参考距离,由测试决定。式(1)能够预测出当距离为d 时接收到的平均能量。由于相同距离d 的情况下,不同位置的周围环境差距非常大因而引入了Xσ,Xσ 是一个平均值为0 的高斯分布变量。

为了更好地描述距离修正定位算法,这里提出两个合理的假设条件:

①由于各种障碍物的影响,绝大多数实际情况中,式(1)预测出的PL(d)[dB]比实际信号能量偏大;

②当距离d 增大时,PL(d)[dB]与实际损耗能量的相对偏差也会增大。

1.2 确定相交区域质心的数学模型

已知三个节点A、B、C的坐标为(xa,ya)、(xb,yb)和(xc,yc),节点O到他们的距离为ra、rb 和rc,假设节点O的坐标(xo,yo),则(xo,yo)的数值可通过式(2)得出,也就是说以A、B 和C 三点为圆心,以ra、rb 和rc 为半径作圆,则三圆将相交与点O,如图1(a)所示。
在这里插入图片描述
图1 三圆相交情况
但在实际情况中,由于RSSI 测距存在误差,并且由于实际的路径损耗比理论模型的数值偏大,也就是说测量出来的未知点到锚节点的距离d 总是大于实际距离r。以A、B和C 三点为圆心,以da1、db1 和dc1 为半径作圆,三圆将不再相交于点O,而是存在一个相交区域,如图1(b)所示。

三圆相交区域的边界有三个交点,三点质心为点D。其中点D 的坐标可以通过式(3)求解。
在这里插入图片描述
但是二次方程,求解过程计算量较大,因而文中采用如图1(b)所示的点D1 的坐标近似质心D 的坐标。三圆两两相交,则三条交线将相交于点D1。将式(2)中的方程式两两相减,则分别得到每条交线的直线方程,D1 的坐标则可以通过这些直线方程求解,如式(4)。
在这里插入图片描述

1.3 距离修正

在某些文章中,以D1 的坐标作为点O 的近似值,其准确度虽然比三边定位等方法要高,但是还是可能存在较大的误差,尤其是当da1、db1、dc1 与ra、rb 和rc 的相对误差各不相同时尤其明显,因而需要对RSSI 方法测出的距离da1、db1和dc1 进行修正,然后再重复地求出新的三线交点D2 的坐标,则可以用点D2 的坐标作为点O 的近似坐标。

设点A、B 和C 到D1 的距离la1、la2 和la3,则总体修正系数如式(5)所示。
在这里插入图片描述
根据1.1 节中假设②,距离越远测距相对误差越大,则其修正程度越大,则da1 的修正系统如式(6)所示,db1 和dc的修正系数类似。
在这里插入图片描述
修正后的距离da2 通过式(7)得出,db2 和dc2 类似。
在这里插入图片描述

2 算法流程

算法流程如下:

①各锚节点以相同功率周期性地向周围广播定位信息,信息中包括节点ID 和坐标。普通节点收到定位信息后,计算同一锚节点的RSSI 平均值;

②当普通节点收集到一定数量的锚节点信息时,不再接收新信息。各普通节点根据RSSI 从强到弱对锚节点排序,由式(1)求出节点到锚节点的距离;

③选取距离最近的3个锚节点;

④通过式(4)计算三线交点D1坐标;

⑤分别计算3个锚节点与交点的距离;

⑥通过式(5)计算总体修正系数;

⑦通过式(6)分别计算各自的修正系数,然后通过式(7)计算修正后的距离;

⑧再次通过式(4)计算修正后的三线交点D2的坐标,D2的坐标即为点O的近似值。

3 仿真分析

用MATLAB 进行算法仿真,基本初始条件是无线传感器网络位于100 m×100 m 的区域内,该区域左下角为(0,0),右上角为(100,100)。区域内均匀部署4、9、16、25个锚节点,其中部署16 个锚节点的位置如表1 所示。

未知节点随机分布在区域内,路径损耗系数设为2.4,每次仿真实验进行500 次,仿真结果取500 次的平均值,各次仿真实验结果如表2 所示。
  
表1 16 个锚节点位置坐标
表1 16 个锚节点位置坐标
表2 仿真结果
在这里插入图片描述
从仿真结果可以看出,当锚节点数目较少时,增加锚节点数量可以显着提高定位精度。路径损耗系统对定位精度也有影响,路径损耗系统越大,定位精度越高。从表2 可以看出,距离修正次数增多对定位精度没有显着的影响,也就是说一般情况下只需要进行一次距离修正即可,采用距离修正与不采用距离修正相比,定位精度明显提高。

4 结语

无线传感器网络基于RSSI 测距的定位算法由于实现简单,应用十分广泛。但由于RSSI 测距的精度不高,降低了节点定位精度。基于RSSI 的无线传感器网络距离修正定位算法利用RSSI测距,通过确定相交区域近似质心,以此为参考点对距离进行修正,然后确定未知节点位置。仿真结果表明,该算法对测距误差具有较高的容忍程度,并且具备很高的定位精度。如上图2 所示,三圆相交还存在无3个交点的情况,下一步工作将详细研究图2所示各种情况对该算法的影响,从而对算法进行改进完善。

这篇关于【物联网】基于RSSI的无线传感器网络距离修正定位算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/837808

相关文章

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

Python使用DeepSeek进行联网搜索功能详解

《Python使用DeepSeek进行联网搜索功能详解》Python作为一种非常流行的编程语言,结合DeepSeek这一高性能的深度学习工具包,可以方便地处理各种深度学习任务,本文将介绍一下如何使用P... 目录一、环境准备与依赖安装二、DeepSeek简介三、联网搜索与数据集准备四、实践示例:图像分类1.

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为