data:image/s3,"s3://crabby-images/5defc/5defc0e169e3f376178071a2d00a7baa14a6cdb8" alt="智能系统"
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.5 实验:WSN——节点分簇聚合模拟
2.5.1 实验目的
(1)了解Python的基本编程环境。
(2)了解Python程序的基本框架。
(3)对于Python如何实现一个WSN——对节点分簇聚合有整体认识。
(4)运行程序,查看结果。
2.5.2 实验要求
(1)熟悉Python的基本编程环境。
(2)用代码实现WSN——节点分簇聚合功能。
2.5.3 实验原理
(1)实验场景:给定WSN的节点数目,节点随机分布,根据 LEACH算法实现每轮对WSN的分簇。
(2)记录前k轮(本实验k=10)或绘制第k轮网络的分簇情况,即每个节点的角色(是簇头还是簇成员)及其关系,如果是簇成员,则标记其所属的簇头。
(3)实验中需要注意,节点数目不宜过小,本实验N=100;每轮只完成分簇,不考虑通信过程;每轮结束可以以定时器确定,也可以以完成当轮分簇为准。
(4)簇成员在寻找簇头时,以距离作为接收信号强弱的判断依据;约束条件为当选为簇头的节点在以后几轮的分簇中不再成为簇头。
2.5.4 实验步骤
本实验的实验环境为Python 2.7的环境。代码如下。
1.主程序
data:image/s3,"s3://crabby-images/2161d/2161da1e02ade7d388ac8c0e7bdce42c92ff085d" alt=""
2.判断距离函数
data:image/s3,"s3://crabby-images/1c306/1c306de2fe2cde3deb65edffb7b670bc94b4046d" alt=""
3.生成随机节点集
data:image/s3,"s3://crabby-images/1a652/1a652793dbdf2c8c4408e58d74ea49d3bf9f6a60" alt=""
data:image/s3,"s3://crabby-images/d6385/d638555e31618e0d82edf60b076b07cb061387e6" alt=""
4.根据LEACH算法选择簇头节点
data:image/s3,"s3://crabby-images/6766b/6766bb1e376e091c883ec7b4e8b27840a66b0726" alt=""
data:image/s3,"s3://crabby-images/04a90/04a906503a67f4fcc0bedf770b0538c521a86100" alt=""
data:image/s3,"s3://crabby-images/d2baa/d2baa54f2cf2077e428dbf749d06714e86a1493c" alt=""
5.节点分簇算法
data:image/s3,"s3://crabby-images/9046b/9046b478bf1ed81b0af63e0e3d6735b19b5b89e4" alt=""
data:image/s3,"s3://crabby-images/13c6c/13c6c13701cfab06afe672784b3feb3b35194fed" alt=""
data:image/s3,"s3://crabby-images/5ec34/5ec342e313c3ba9e88c4c50635902ae8bfed8500" alt=""
6.绘制分类图
data:image/s3,"s3://crabby-images/1dcac/1dcac764faf1667c837ce225d78745aaa23b46fe" alt=""
data:image/s3,"s3://crabby-images/be09e/be09ec77760a08d994cf14fc8a93ecef67265495" alt=""
2.5.5 实验结果
实验运行结果如图2-16所示。
data:image/s3,"s3://crabby-images/eb699/eb699bcdeb209e23fc40614961ea32201535b439" alt=""
图2-16 实验运行结果