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/f9c5f/f9c5f7d6bead2f17acab43b75bd45c261842ccb7" alt=""
2.判断距离函数
data:image/s3,"s3://crabby-images/42770/42770574e58a53882c9dd9e8e2511e15bf74568d" alt=""
3.生成随机节点集
data:image/s3,"s3://crabby-images/5d787/5d787ab64bb62c0d8e42de4259282145e434b7e0" alt=""
data:image/s3,"s3://crabby-images/82e5b/82e5b887bef25b16303093117dcc4fc82c4905fe" alt=""
4.根据LEACH算法选择簇头节点
data:image/s3,"s3://crabby-images/231ae/231ae2ba2f4cde751eb3531193f145df54d49051" alt=""
data:image/s3,"s3://crabby-images/f15d0/f15d0eb3a782a899cceefcb8c0895ddcdb36d771" alt=""
data:image/s3,"s3://crabby-images/6180c/6180c8b4d2df380ff037543f9183c240922fadb3" alt=""
5.节点分簇算法
data:image/s3,"s3://crabby-images/d86e0/d86e0e92e2d1785fc8a6f0bd69db1bea50c5e573" alt=""
data:image/s3,"s3://crabby-images/85e21/85e21e6cf8a13909c7e76c3ccdadbb7308b2b594" alt=""
data:image/s3,"s3://crabby-images/f92d1/f92d12ceeaebd5da006c222b3ac33a3bbe0ce8b5" alt=""
6.绘制分类图
data:image/s3,"s3://crabby-images/f7c9a/f7c9ac20a4540c17a873f0505b0887df5320f57c" alt=""
data:image/s3,"s3://crabby-images/c6b0b/c6b0b8ba21e44efc5a45ab33cfd97428045b95f6" alt=""
2.5.5 实验结果
实验运行结果如图2-16所示。
data:image/s3,"s3://crabby-images/361a6/361a69b3f55a57339abdfb687ca178139e1dc775" alt=""
图2-16 实验运行结果