产品推荐:水表|流量计|压力变送器|热电偶|液位计|冷热冲击试验箱|水质分析|光谱仪|试验机|试验箱

全网搜索
2023版仪器仪表采购宝典电子书

仪表网>技术中心>技术原理>正文

欢迎联系我

有什么可以帮您? 在线咨询

经典AV三级在线观看 无线传感器网络分簇路由算法

   2011年06月29日 15:15  
  无线传感器网络由大量传感器节点和一个基站(BS)构成,基站是节点与其它网络通信的出入口,传感器节点监测环境并将收集的数据传给基站。然而,它能量有限,直接将数据传给基站会消耗很多能量(图1)。采用多跳的路由方法也不理想,因为zui接近基站的节点会因路由大量收到的数据而很快死亡,从而导致后来到达的数据不能传给基站。其它的路由方法中[3,4],PEGASIS中的节点只与邻居节点通信,节点轮流发送融合后的数据给BS,基于蚁群算法的路由在尽量选择zui短路径的同时考虑每个节点的能量消耗,以选出更合适的路径。
  
  本文中,我们重点评价更具有能量有效性的分簇路由算法,它将无线传感器网络分成若干簇,每个簇选举出一个簇头,簇头作为本地基站将簇内节点传给它的数据进行数据融合[5]后再传给基站(图2),因而大大降低了节点消耗的能量,延长了网络寿命。
  
  图1传感器系统模型一

  
  图2传感器网络系统模型二
  
   
  传统路由算法
  
  直接路由算法中节点直接将数据传送给基站,这样远离基站的节点会消耗很多的能量而很快死亡。而MTE(MinimumTransmissionEnergy)[6]是它的一个改进,它采用多跳的方法传送数据,每个节点运行建立路由以确定下一跳邻居节点,这个邻居节点是朝BS方向上离它zui近的节点(假设每个节点都知道网络中其它节点的位置),数据包通过下一跳邻居节点传送直到到达BS。
  
  在MTE这种路由算法中zui接近基站的节点会因路由大量传来的数据而很快死亡,而直接通信中是离基站zui远的节点zui快死亡。
  
  zui基本的分簇路由算法
  
  为了解决传统路由算法中的高能量耗散问题,提出了LEACH(Low-EnergyAdaptiveClusteringHierarchy)[7]—一种zui基本的分簇路由算法,每个节点根据一定的概率周期性地轮换做簇头,成为簇头的节点用相同的发射功率给网络中的所有节点广播消息,非簇头节点选择加入收到信号zui强的那个簇头的簇并用CSMAMAC协议发消息给簇头,通知其成为它的成员。之后,簇头根据簇中节点数目创建TDMA[8]时间表告诉每个节点发送数据的时隙,以避免碰撞的发生。另外,簇头还要通知簇成员使用哪种CDMA编码,簇头也使用这种编码过滤收到的数据,这样邻居簇的信号就会被当为噪声过滤掉,因此不会影响簇内通信。节点只在分配给它们的时隙内发送数据,其它时间关闭其无线发射机以节约能量,到此,簇就形成了。在数据发送阶段,簇头将成员节点传给它的数据进行融合后直接传给BS。
  
  在LEACH中,成员节点在分配的TDMA时隙内总有数据传给簇头,为了节约能量,节点也许只需在它检测到有兴趣的数据时才传送数据,另外,算法周期性地分簇会消耗节点很多能量。因此,我们需要在以后的路由算法中在这些方面对它进行改善。
  
  可形成*簇的中心控制分簇路由算法
  
  LEACH虽节约能量,但它不能形成*簇。中心控制算法通过基站来控制形成*的簇。
  
  LEACH-C中,每个节点发送包含自身位置信息和能量信息的消息给BS,位置信息可以保证形成优良的簇,为了将能耗平均分摊给所有节点,BS计算网络节点的平均能量,低于此能量的节点都不能做簇头,因此用LEACH-C可以形成比LEACH更优良的簇,它的其它阶段和LEACH一样。静态分簇(StaticClustering)中,簇形成方法和LEACH-C一样,只是这些簇头一旦形成,在整个网络生命期都固定不变,其余的数据传输方式和LEACH和LEACH-C一样,但是一旦簇头能量耗尽,簇内节点就失去了通信能力。
  
  LEACH-C和LEACH在仿真时间内比StaticClustering明显可以发送更多的数据给BS,并且每单位能量可传送更多的数据,但LEACH-C性能。
  
  由于LEACH在一些情况中所选的簇头可能全在区域的一端,在另一端的传感器节点可能侦听不到簇头发出的信息,而不能加入任何簇,因此提出了SC(SubstractiveClustering)和LMSSC(LeastMeanSquaredSubstractiveClustering)[9]分簇算法。
  
  SC的思想是具有zui多邻居数的节点被选为一个簇的中心,在一个确定半径内的其它节点归为它的簇,之后再寻找新的具有zui多邻居的节点,这样一直持续下去直到80%的节点已被分簇。
  
  LMSSC在SC上进行了修改以形成更好的簇,它的思想是在确定半径内与邻居节点的距离平方和平均值zui小的节点被选为一个簇的中心,所有这个半径内的它的邻居节点被划为它的簇。这两种方法都是在簇形成以后再在簇内选择合适的簇头。簇头将收到的数据进行融合后直接或选择一条代价zui小(到BS能量消耗zui小)的路径将数据传给BS。
  
  LMSSC中节点运行的周期比SC中的更长,所以LMSSC产生的簇更佳。并且,选择zui小代价路径传送数据的SC和LMSSC比直接传送数据的SC和LMSSC性能更优。
  
  HYENAS(HybridEnergy-AwareSensorNetworks)[10]也是先形成簇,再选择簇头,但它用CBR(Case-BasedReasoning)作为一种决策方法来保证形成合适的簇,CBR技术通过吸取每轮结束时的错误经历来创建黑名单,黑名单是用来存放一组簇的。这些簇的簇成员所用的能量超过了网络中所有节点所用能量的平均值,当当前每个簇的特性(如:簇成员数,簇头到其它节点的距离平方和等)和黑名单中簇的特性有相似之处时,基站就会增加一个簇。如果有少数节点离开了原来的簇时,它们会自己形成子簇,子簇簇头会单独为子簇创建TDMA时间表,然后把这个消息传给它zui初的簇头,簇头再传给基站。这种方法能处理少数移动节点的问题,还能大大减少簇头和移动节点的通信距离。
  
  当*个节点死亡或zui后一个节点死亡时,HYENAS运行的轮数要比LEACH多。因此,它的网络寿命也就相应更长。
  
  基于阈值信息的分簇路由算法
  
  TEEN(ThresholdSensitiveEnergyEfficientSensorNetworkProtocol)[11]协议在LEACH上进行了改进。它的分簇方法和LEACH一样,只是它的簇成员不像LEACH算法那样总是发送数据给簇头。它的每个节点设定了两个阈值,硬门限(HT)和软门限(ST),当节点监测到的数据大于HT并且与前次监测的数据变化值大于或等于ST时才发送数据给簇头,这样可以大大减少节点发射数据的次数,但节点不发送数据用户就会长时间收不到数据或者认为节点死亡。
  
  APTEEN(AdaptivePeriodicThreshold-sensitiveEnergyEfficientSensorNetworkProtocol)[12]协议弥补了TEEN的缺点,簇成员节点除了在数据发生明显变化时发送外,还会周期性地发送消息,这样节点除了能节约能量外,用户收到发送来的消息后也可以周期性得获得已存储在基站的数据。
  
  在每个节点的平均能量耗散和存活节点总数性能方面,APTEEN介于TEEN和LEACH之间,但TEEN性能,因为TEEN中簇内的节点发送数据的次数zui少。
  
  其它的分簇路由算法
  
  PEGASIS(Power-EfficientGatheringinSensorInformat*tem)[13]的主要思想是每个节点从zui近的邻居节点接收和发送数据给zui近邻居节点,并且轮流发送融合后的数据给BS,这个方法可将能量负载均匀地分摊给网络中的所有节点。
  
  PEGASIS:与LEACH相比,当相同数目的节点死亡时,PEGASIS比LEACH要运行多一倍的轮数。
  
  基于蚁群算法的路由算法[14,15]是通过在整个网络内建立梯度(节点与相邻节点到基站的zui小跳数之差称为梯度)和每个节点之间的信息素(提示数据包选择哪条路径的信息称为信息素)来进行路由选择。在设计信息素浓度的公式时,不仅考虑了节点间的梯度,还加入相邻节点剩余能量的因素。
  
  该算法在尽量选择zui短路径的同时,还考虑每个节点的能量消耗,以达到寻找*路由的目的。
  
  EBRA(Energy-BasedRadiusSelf-AdjustRoutingProtocol)[16]中节点会选择一条平均单位跳数消耗zui少能量的路径传送数据,当节点自身的能量降低到一定数值以后,它会向其邻居节点广播进行降低半径的请求来达到维护路由的目的。
  
  AdHoc中的分簇路由算法
  
  在无线传感器网络中少数节点移动的情况下,我们可以借鉴AdHoc网络中的分簇算法[17,18]。AdHoc中,由于节点的频繁移动,分簇的目的则是保证稳定的分簇结构,zui小化簇建立和维护的开销,zui大化系统中移动节点的寿命。DCA(DistributedClusteringAlgorithm)[19]网络拓扑结构在算法执行期间不变,因此它对静态网络很有用。算法中,只有当节点的具有较大权值的邻居节点决定了它自己的角色时,节点才决定自己承担什么样的角色。相反,DMAC(DistributedandMobility-AdaptiveClustering)适用于拓扑结构不断变化的网络,节点不仅对从其它节点发来的消息做出适当的反应,还对与其它节点连接的链路失败或新链路的出现做出适当的反应。DBCA(DistributedWeightedClusteringAlgorithmforAdHoc)[20]的簇形成方法和DWBCP的相似,在簇维护阶段,当节点移出了它的簇边界时,它就广播一个消息要求加入一个新簇,任何收到该消息的簇头都会发送应答消息给该节点,节点根据消息选择加入具有zui小权值的簇头的簇,如果在给定的时间内没收到任何消息,就宣布自己做为簇头。当簇头消耗的能量超过事先设定的阈值时,簇头就不再担任这个角色,该簇重新推选簇头。
  
  基于权值的分簇算法
  
  这里提出一种创新的分簇路由算法——基于权值的分簇路由算法。该算法主要研究的是簇头选举方法,每个节点根据自己的剩余能量、邻居数目、与所有邻居的平均距离、与基站的距离、以及能量消耗速度来计算出自己的权值:
  
  其中Ev为节点v的剩余能量,Nv为节点v的邻居数目,即在节点v发射范围内的节点数目之和,δ为簇头能够处理的理想的节点数,Dnv与Dbv分别为节点v与邻居节点的距离之和,与基站的距离,R为簇覆盖范围的直径,Numv为节点v做过簇头的次数,Tv为节点v在现在的能量消耗速度下,直到能量水平达到zui小可接受的阈值时的期望时间,W1—W6为权值因子,根据系统需要选择,它们之和为1。在邻居节点中具有zui小权值的节点做为簇头,其它的过程,诸如数据传输过程都与LEACH中的一样。
  
  系统主要操作步骤:
  
  Step1:根据以上的方法选取簇头形成簇;
  
  Step2:簇头为每个簇成员分配TDMA时间表;
  
  Step3:节点在分配的时隙内发送数据给簇头;
  
  Step4:簇头将收到的数据进行融合后通过单跳或多跳的形式传给基站;
  
  Step5:当簇头的剩余能量小于等于本轮开始时能量的某个百分比时,重新分簇。
  
  基于权值的分簇路由算法考虑了形成簇头的多种因素,如簇内通信代价、簇间通信代价、节点自身的能量状况,而LEACH算法只根据节点做过簇头的次数来决定簇头的选举,因此它选出的簇头更合理,产生的簇也更佳。
  
  结语
  
  由于传感器网络通常分布在环境恶劣或人不可到达的地方,所以人为维护是困难的,因此在进行数据通信的同时尽可能延长网络的寿命是我们需要解决的首要任务,分簇算法将无线传感器网络分成若干簇,每个簇选举出一个簇头,簇头作为本地基站将簇内节点传给它的数据进行数据融合后再传给基站,因而大大降低了节点消耗的能量,延长了网络寿命,本文综述的分簇路由算法及提出的创新的分簇路由算法——基于权值的分簇路由算法,都是实现这种目标的有效算法。但后者选出的簇头在节约能量方面*,更受推崇。
  
  基于权值的分簇路由算法对权值因子的选择是人为的,即认为哪个因素重要,就给相应的因素赋更大的权值,反之,赋更小的值,但这些值究竟应该多大,应该有一个更具说服力的模型来描述,比如,在作战环境、地震检测、动物移动中应该具体用什么模型,以及它们对网络寿命的影响,这些都是还需要进一步研究的问题。
  
  无线传感器网络中的路由算法对网络的寿命起着关键的作用,近年来,分簇路由算法已频繁地用于无线传感器网络中,因为它的路由算法更具有能量有效性。本文综述了近年来分簇路由算法的主要成果,及它们的性能比较,并提出了一种在能量方面更有效的创新性算法,以及还需期待研究的问题。
  
  作者:王斯瑶吴援明谢光忠电子科技大学光电信息学院

免责声明

  • 凡本网注明“来源:仪表网”的所有作品,均为浙江兴旺宝明通网络有限公司-仪表网合法拥有版权或有权使用的作品,未经本网授权不得转载、摘编或利用其它方式使用上述作品。已经本网授权使用作品的,应在授权范围内使用,并注明“来源:仪表网”。违反上述声明者,本网将追究其相关法律责任。
  • 本网转载并注明自其它来源(非仪表网)的作品,目的在于传递更多信息,并不代表本网赞同其观点或和对其真实性负责,不承担此类作品侵权行为的直接责任及连带责任。其他媒体、网站或个人从本网转载时,必须保留本网注明的作品第一来源,并自负版权等法律责任。
  • 如涉及作品内容、版权等问题,请在作品发表之日起一周内与本网联系,否则视为放弃相关权利。
仪表网-仪器仪表行业“互联网+”服务平台
浙公网安备 33010602001308号
网械平台备案证:(浙) 网械平台备字[2020]第00008号
ICP备案号:浙B2-20100369-24
  • 网上标识信息
  • 营业执照(副本)
  • 经营性网站备案信息
  • 行业网站百强奖状
  • 不良信息举报信息
联系我们

客服热线: 13199863987

加盟热线: 13199863987

媒体合作: 0571-87759945

投诉热线: 0571-87759942

关注我们
  • 下载仪表站APP

  • Ybzhan手机版

  • Ybzhan公众号

  • Ybzhan小程序

企业未开通此功能
详询客服 : 0571-87759942