基于TinyOS平台的RSSI定位系统设计与实现
2013-09-14乔钢柱李雪莲曾建潮
乔钢柱,李雪莲,曾建潮
(太原科技大学电子信息工程学院,山西太原 030024)
WSN(Wireless Sensor Network)定位技术应用广泛,除可以反应出事发地点外,还可跟踪目标、实时监测目标的行动状态、预测目标的行动轨迹等[1]。目前的定位算法可分为两类:基于测距的定位算法和无需测距的定位算法[2]。由于基于测距的定位是采用实际测得节点间的距离或者角度,因此定位精度较高,对硬件也提出了一定的要求,在定位过程中相对消耗的能量较多。无需测距的定位算法不需要实际测量距离或角度信息,对节点不存在特殊要求,定位过程中无需考虑能量消耗问题,但定位精度及其节点覆盖率却有待提高。在基于测距的定位算法中,RSSI(Received Signal Strength Indicator)定位算法相对而言通信开销较小,对硬件要求较低,是一种较为实用的定位算法。文中在TinyOS软件平台下,利用Crossbow公司提供的硬件设施对RSSI定位系统进行了实验验证,并结合实际情况对所得数据进行了分析。
1 TinyOS操作系统及硬件平台
1.1 TinyOS
TinyOS是UC Berkeley开发的一种用于无线传感网络节点的开源操作系统,以其组件化的编程、事件驱动的执行模式、微型的内核以及良好的移植性等特点作为目前WSN系统上的主流操作系统。TinyOS操作系统没有进程或线程管理,没有虚拟内存管理,没有过于复杂的IO子系统及地址空间分配,这对于存储资源有限的系统尤为重要[3]。
1.2 NesC语言
加州大学伯克利分校在C语言的基础上开发出一种适用于无线传感网络编程的NesC(C Language for Network Embedded Systems)语言,TinyOS操作系统和其上运行的应用程序用NesC语言开发[4]。NesC是在C语言上做了一定的扩展,提出了组件化的编程思想,把组件化/模块化思想和基于事件驱动的模型结合在了一起。其主要用处是帮助应用程序设计者建立易于组合成完整、并发式系统的组件,并能够在编译时执行广泛检查[5]。
1.3 iris硬件特性
iris节点工作频率为2.4 GHz,支持IEEE802.15.4协议的Mote模块,用于低功耗无线传感网络[6]。它具有3倍的作用距离,双倍的存储空间;在户外测试不加放大器的情况下,节点间视距离可达500 m;使用直接序列扩频技术,抗RF干扰、数据隐蔽性较好;基于IEEE802.15.4/ZigBee协议的RF发送器,工作频率2.4 ~2.483 5 GHz,兼容 ISM 波段[7]。
2 RSSI定位算法
2.1 RSSI测距
节点间发送的信号在传播过程中都会有衰减,RSSI无线传感网络定位算法的核心是根据节点间发送信号的衰减计算出节点之间的距离,然后依据节点之间的距离计算出盲节点的位置坐标[8]。无线信号的发射功率与接收功率之间的关系如式(1)所示,其中PR是无线信号的接收功率,PT是无线信号的发射功率,d为收发节点之间的距离;n为传播因子,其值大小取决于无线信号传播的环境
在式(1)两边取对数,并把已知的网络发射功率带入,可得
式中10lgPR是接收信号功率转换为dBm的表达式,即RSSI值,其中A为信号传输1 m时,接收信号的功率值。所以可得到盲节点与信标节点之间的距离为
2.2 三边测量法定位
三边测量法[9]是无线传感器网络定位算法中较为最典型的一种。在盲节点通过基于RSSI的测距方法获取到3个或以上信标节点的距离后,就可利用三边测量法进行自身定位。如图1所示,已知3个信标节点A、B、C的坐标(x1,y1)、(x2,y2)、(x3,y3)。假设盲节点的坐标为(x,y),根据盲节点接收到的RSSI值,得盲节点到A,B,C的距离分别为d1、d2、d3。
图1 三边测量法的定位原理
则根据三边测量法原理,有式(4)成立
由式(4)可以求得盲节点的坐标如式(5)所示
3 RSSI定位算法在操作平台上的实现
在此环节中,主要用NesC语言在TinyOS环境下将RSSI定位算法具体实现,编译成功后将NesC程序分别烧写到对应的硬件节点中进行实验。其实验结构如图2所示,信标节点发送包含自身坐标的数据包到盲节点及基站节点。盲节点接收信标节点发送的数据包解析出每一个的RSSI值,结合信标节点的位置坐标计算出自身坐标值,并将结果发送至基站节点。基站节点接收一切数据包,并将其发送到XServe中转站。PC机上的XServe作为节点网络和操作者之间通信的主要通道,它提供多个通信端口用于输入信息,以便于网络间数据传送;操作者可以通过终端接口或XML RPC命令接口与其进行通信;它可以解析、转换和处理节点传送的数据;在解析过程中,将原始格式的数据转换到相应的传感器读数测量单位;最后将转换后的数据显示于XSniffer界面中。PC机上的XSniffer可以显示出XServe传送的所有数据;能够让操作者监测到网络中的所有节点是否都在正常通信、数据包的序列号以及传送地址是否正确、以及路由的更新和时间同步消息。
图2 实验结构图
3.1 总体实验思路
信标节点:负责发送包含自身位置的数据包到盲节点。盲节点:负责接收信标节点发来的数据包,提取出信标节点的坐标值,并从数据包中获得RSSI值,在此基础上计算出自身的坐标值,并将计算出的结果发送到基站节点。基站节点:负责接收所有能够听见的数据包,并将其转发到XServe,最后显示到XSniffer界面中,如图3所示。
图3 XSniffer数据显示界面
图3中,后5位数据是自行定义的,发送给2号节点的5位数据中,前3位是接收到的3个已知节点RSSI值,后两位是计算出的盲节点坐标值,为便于显示,最后两位数据分别扩大了10倍,实际值应当缩小10倍。发送给5号节点的数据是信标节点自身的坐标值。
3.2 具体实现思路
3.2.1 信标节点
实验中采用3个信标节点,首先分别指定各节点的ID,以便能够从XSniffer界面中观察出每个节点发送的数据。信标节点在实验中起着关键的作用,只有保证信标节点与盲节点之间进行正常通信,才可以得到可信的盲节点位置坐标。具体实现思路如下:(1)定义一个缓存区,用于存储自身的坐标值。(2)设置一个定时器,计时发送出缓存区中的数据到盲节点,指定红色led灯亮,并通过XSniffer界面观察发送数据是否正确。(3)数据发送成功,指定绿色led灯亮。
3.2.2 盲节点
实验目的是测出盲节点的位置,因此盲节点是实验的目标节点。首先指定其ID,以便在XSniffer界面中读取数据。其次要保证能够正常接收并提取信标节点发送的数据,才可以得到可信的自身位置坐标。具体实现思路如下:(1)定义接收和发送两个缓存区及其对应的变量指针。(2)设置4个不同的计时器,第1个计时器时间到,通过变量指针将接收缓存区中的数据复制到发送缓存区中。第2和第3个计时器时间到,重复上述操作。第4个计时器时间到,利用发送缓存区中数据计算出盲节点坐标值。(3)将盲节点的坐标值发送到基站,并通过XServe到XSniffer界面读取数据。
3.2.3 基站节点
基站节点用于接收信标节点和盲节点发送的数据,并将数据向上传送,使得实验者能够明确每个节点发送的数值。具体实现思路如下:(1)定义一个缓存区,用来存储接收到的数据。(2)利用接收函数接收可以听到的信号。(3)将接收到数据通过串口传送到XServe,通过XServe将数据显示到XSniffer界面中。
4 实验结果及数据分析
(1)两个信标节点放置在坐标轴上,另外一个随机放置。信标节点的坐标设为(0,2),(4,0),(6,6),盲节点坐标如表1和表2所示。
表1 室内实验结果
表2 室外实验结果
如表1所示,当信标节点置于坐标轴上时,数据误差较大,是因为室内坐标轴所选为墙壁,会发生信号反射现象,室外坐标轴所选为操场周围的栅栏,也会对无线信号的传输产生较大影响。从总体数据看,室内差值最大为2.16 m,最小为0.98 m;室外差值最大为1.56 m,最小为0.81 m。在室外定位中,距离越远误差则越大,其原因是室外无线信号干扰导致RSSI值衰减不稳定。
(2)双侧摆放信标节点。信标节点的实际坐标设为(4,1),(8,1),(6,5),盲节点坐标如表 3 和表 4所示。
表3 室内实验结果
表4 室外实验结果
从上表发现,双侧摆放信标节点成等边三角形时,数据误差较第一种情况好些,是因为此时信标节点的位置不在墙壁和操场围栏处,而且盲节点摆放的位置处于三角形之中。从总体数据看,盲节点摆放位置越接近三角形中心时差值越小。这种情形下,室内差值最大为1.8 m,最小为0.57 m,室外差值最大为1.2 m,最小为0.36 m。室外定位中,盲节点位置一直放于三角形之中,RSSI值衰减比第一种情况下要稳定,从而数据差值小些。
(3)随机摆放信标节点。信标节点的实际坐标设为(3,3),(5,2),(7,1),盲节点坐标如表5 和表6 所示。
表5 室内实验结果
表6 室外实验结果
从以上表格发现,在随机摆放信标节点的情况下,数据误差较第一种情况小,但比第二种情况大,因为此时盲节点放置的位置更远,室内物品较多,干扰较大,而室外无线信号干扰,导致RSSI衰减不稳定。从总体数据看,室内差值最大为2.05 m,最小0.85 m;室外差值最大为1.42 m,最小0.58 m。
(4)数据误差分析。实验环境为18×18的实验室内和室外操场,由于实验环境的局限性,RSSI值会受到多种因素的干扰,实验室内的设备以及人员走动都会对无线信号产生影响,使得信号发生反射、绕射、受到障碍物阻挡等现象,操场中会存在其他的无线通讯信号,以及铁栏杆等障碍物会使信号发生不稳定的衰减,导致RSSI值不稳定,产生误差。另外,每个节点所处的自身环境不相同,对其信号发射影响大小也不相同,但计算时采用同样的衰减指数,必然存在误差。
5 结束语
在TinyOS操作平台上利用Crossbow公司的硬件对无线传感网RSSI定位算法进行了验证。通过节点间的收发数据,得到RSSI值,从而计算出盲节点与信标节点之间的距离,最后利用三边定位算法计算出盲节点的具体位置坐标值。在大型网络中,此方法仍然实用,此时盲节点会接收到多个信标节点发送的数据,计算出多个距离值,只需提取3个最小的距离即可计算出盲节点的坐标值。
[1]孙利民,李建中,陈渝,等.无线传感器网络[M].北京:清华大学出版社,2005.
[2]李晓维.无线传感器网络技术[M].北京:北京理工大学出版社,2007.
[3]LEV I P,MADDEN S,POLASTRE J,et al.TinyOS:An operating system forwireless sensor networks[C].Berlin:Proceedings of the 7 th In2 Ternational Conference on Mobile Data Management(MDM 2006),2005:115-148.
[4]李丽娜,石高涛,廖明宏.传感器网络操作系统 TinyOS关键技术分析[J].哈尔滨工业大学学报,2005(6):86-91.
[5]李晶,王福豹,段渭军.无线传感器网络中 TinyOS的研究[J].计算机测量与控制,2006(6):41-46.
[6]CROSSBOW.Mica2 wireless measurement system[EB/OL].(2004-05-16)[2012-05-30]http://www.xbow.com.
[7]CROSSBOW.Mica2 dot wireless microsensor mote[EB/OL].(2004-08-12)[2012-03-24]http://www.xbow.com.
[8]汪炀,黄刘生,肖明军,等.一种基于RSSI校验的无线传感器网络节点定位算法[J].小型微型计算机系统,2009,30(1):59-62.
[9]SAVARESE C,RABAEY J M,BEUTEL J.Locationing in dist ributed Ad2Hoc wireless sensor network[C].Salt Lake:Proc.of the 2001 IEEE Int'l Conf.on Acoustics,Speech and Signal,IEEE Signal Processing Society,2001.