无线传感器网络路由优化中的能量均衡LEACH改进算法

article/2025/7/22 10:01:37

文章目录

  • 一、理论基础
    • 1、LEACH算法概述
    • 2、改进的LEACH算法
  • 二、算法流程图
  • 三、仿真实验与分析
  • 四、参考文献

一、理论基础

1、LEACH算法概述

请参考这里。

2、改进的LEACH算法

改进的LEACH算法(LEACH-N)主要针对LEACH算法分簇阶段的缺陷而改进的,具体步骤如下:
(1)每一个节点计算与其他节点距离小于 d 0 d_0 d0的节点数 a a a d 0 d_0 d0的计算公式如下: d 0 = ε f s / ε m p (1) d_0=\sqrt{\varepsilon_{fs}/\varepsilon_{mp}}\tag{1} d0=εfs/εmp (1)式中: ε f s \varepsilon_{fs} εfs表示自由空间信道模型信号放大器功耗; ε m p \varepsilon_{mp} εmp表示多路径衰减信道模型信号放大器功耗。
(2)计算节点剩余能量 E l E_l El
(3)节点根据剩余能量和特定范围内的节点数计算出各个节点可成为新的簇头节点的阈值, 阈值计算公式为: T ( n ) = { p i 1 − p i ( r m o d ( 1 / p i ) ) ⋅ E l E 0 , n ∈ G 0 , o t h e r w i s e (2) T(n)=\begin{dcases}\frac{p_i}{1-p_i\left(rmod(1/p_i)\right)}\cdot\frac{E_l}{E_0},\quad n∈G\\0,\quad\quad\quad\quad\quad\quad\quad\quad\quad\quad\quad\,\, otherwise\end{dcases}\tag{2} T(n)=1pi(rmod(1/pi))piE0El,nG0,otherwise(2)式中: p i = p ⋅ a / n p_i=p\cdot a/n pi=pa/n p p p为整个网络中簇头节点占总节点数 n n n的比例; E 0 E_0 E0为节点的初始能量; G G G代表在最近的 r − 1 r-1 r1轮中未当选簇头的节点集合, r r r是WSN进行的当前轮数; r m o d ( 1 / p i ) rmod(1/p_i) rmod(1/pi)为一轮循环中当选过簇头的传感器节点个数。
(4)节点会产生一个[0,1]的随机数。如果随机数小于这个阈值T(n),则该节点成为簇头。
(5)所有簇头选择完成之后,广播所有簇头节点位置信息,剩余的普通节点选择距离最近的簇头入簇,并将自己的标识记为该簇头的标识号。
(6)所有节点入簇完成,转为数据传输阶段,簇内的普通节点比较到簇头和Sink节点的距离,若到Sink节点的距离更小,则直接传输数据到 Sink节点,减少能量的消耗。
(7)簇头节点接收簇内非簇头节点的数据,通过计算、融合后将数据发送给Sink节点。该阶段运行一轮后,进入下一轮,转至步骤(2) ,计算剩余能量 E l E_l El

二、算法流程图

在这里插入图片描述

图1 改进LEACH算法流程图

三、仿真实验与分析

仿真网络中有100个节点且随机地分布在100m×100m范围内,Sink 节点的位置固定,每个节点的初始能量为0.5J,仿真参数如表1所示。
在这里插入图片描述

表1 仿真实验参数

图2~4分别是存活节点数目、网络剩余能量、基站接收的数据量随轮次的变化曲线。
在这里插入图片描述

图2 100m×100m区域内100节点生命周期对比

在这里插入图片描述

图3 网络剩余能量和时间关系

在这里插入图片描述

图4 基站接收数据和时间关系

四、参考文献

[1] 韩广辉, 张丽翠. 基于LEACH协议的无线传感网能效分簇算法[J]. 吉林大学学报(信息科学版), 2017, 35(1): 26-31.
[2] 何书前, 严晨, 邓正杰, 等. 无线传感器网络路由优化中的能量均衡LEACH改进算法[J]. 现代电子技术, 2020, 43(5): 6-9.


http://chatgpt.dhexx.cn/article/u6KFmLmd.shtml

相关文章

机器学习之自适应增强(Adaboost)

1.Adaboost简介 **Adaptive boosting(自适应增强)是一种迭代算法,其核心思想是针对同一个训练集训练不同的弱分类器,然后把这些弱分类器集合起来,构成一个强分类器,Adaboost可处理分类和回归问题。了解Adaboost算法之前&#xff…

自适应阈值(adaptiveThreshold)分割原理及实现

背景介绍及原理 前面介绍了OTSU算法和最大熵算法,但这两种算法都属于全局阈值法,所以对于某些光照不均的图像,这种全局阈值分割的方法会显得苍白无力,如下图: 显然,这样的阈值处理结果不是我们想要的&…

优化算法+神经网络:神经网络自动参数优化

当智能群优化算法遇上神经网络 优化算法进行神经网络的参数寻优,解放深度调参1.已经实现的Genetic Algorithm优化Neural Network2.已经实现的PSO优化Neural Network3.已实现的SSA[^1]优化Neural Network 三种方法的可视化搜索过程对比三种优化算法性能总结总结目前来…

Java stream().sorted()实现排序(升序、降序、多字段排序)

1 自然排序 sorted()&#xff1a;自然排序&#xff0c;流中元素需实现Comparable接口 package com.entity;import lombok.*;Data ToString AllArgsConstructor NoArgsConstructor public class Student implements Comparable<Student> {private int id;private String …

linux centos查找某个文件,Linux查找命令(文件、文件中的关键字)

1、grep &#xff1a;查找文件中的内容 $ grep [option] pattern [file] 例&#xff1a; $ grep un day Sunday 例: $grep include doulinked.c doulinked1.c doulinked.c:#include doulinked.c:#include doulinked.c:#include doulinked1.c:#include doulinked1.c:#includ…

Linux下查找\命令(收集整理)

以下为总结&#xff0c;其实可直接跳过&#xff0c;查看locate部分&#xff0c;这个是类似windows下verything搜索工具&#xff01; 一.Linux查找文件的相关命令 常 用 命 令 简要中文说明 程序所在目录 whereis 寻找文件工具 /usr/bin find 寻找文件工具 /usr/bin l…

Linux查找命令 which和find命令

目录 前言一、which命令二、find命令 前言 一、which命令 格式&#xff1a; which [选项] 命令|程序名 #默认当找到第一个目标后不再继续查找选项说明-a查找全部内容&#xff0c;而非第一个文件-n<文件名长度>  指定文件名长度&#xff0c;指定的长度必须大于或等于所有…

Linux文件查找的4个命令

1. find find 命令应该是最经典的命令了&#xff0c;谈到搜索工具第一个想到的肯定是 find 命令。但是&#xff0c;find 命令非常强大&#xff0c;想要把它的功能都介绍一遍&#xff0c;恐怕要写好几篇文章。 所以&#xff0c;这里介绍最基本的&#xff0c;根据文件名查找文件…

Linux下的查找命令合集(which/whereis/locate/find)

Linux 下的查找命令有很多&#xff0c;常用的有which、whereis、locate、find。那么这4个命令之间各自有什么特点&#xff0c;又有什么区别&#xff0c;什么时候该用哪个才最合适呢&#xff1f;方便我们在开发和学习中能更加有效的使用。 1、which 该命令主要是用来查找系统P…

【Linux命令】查找文件命令

文章目录 一、查找文件locateupdatedbfind测试条件操作符操作预定义操作自定义操作 find命令选项&#xff08;常用&#xff09; 一、查找文件 locate locate命令会查找其路径名数据库&#xff0c;输出所有包含查找字符串的匹配项&#xff1a; locate settings.xmlupdatedb …

Linux常用查找命令

1、命令名称&#xff1a;which&#xff08;查看命令文件位置和命令可能出现的别名&#xff09; which 命令 2、whereis&#xff08;查找命令及帮助文档所在位置&#xff09; whereis 命令 3、locate&#xff08;按照文件名查找&#xff0c;按照数据库查找&#xff09; locate…

【Linux学习笔记】8. Linux查找命令:find和grep详解

Linux查找命令 find查找文件grep查找字符串 1. find命令 有多种使用方式&#xff1a; 根据文件名搜索根据文件大小搜索根据文件类型搜索根据修改时间搜索根据文件权限搜索根据文件所有者搜索 上面的各种方式可以利用逻辑与或非组合起来使用。 功能一&#xff1a;按文件名…

linux查找命令,文件就这些which,whereis,locate,find,grep,|

linux生产中我们经常需要查看某个软件是否安装&#xff0c;某个文件在哪里等&#xff0c;某个命令是否存在等。 1. which 查看可执行文件的位置 which命令的作用是&#xff0c;在PATH变量指定的路径中&#xff0c;搜索某个系统命令的位置&#xff0c;并且返回第一个搜索结果…

linux 查找命令

CentOS Linux学习笔记总结(八十六)-CentOS Linux系统的查找命令find find命令是用于在指定目录下查找文件,并可以对查找到的文件进行指定的操作。它的查找是从指定目录开始,并向下递归搜索它的所有各个子目录,查到后标准输出,并对其进行指定操作。 find语法: find [参…

Linux下4个查找命令which、whereis、locate、find

1.which 作用:从环境变量PATH中,定位、返回与指定名字相匹配的可执行文件所在的路径 原理:执行which命令时,which会在当前环境变量PATH中依次寻找能够匹配所找命令名字的可执行文件 适用场合:一般用于查找命令、可执行文件所在的路径 2.whereis 作用:定位、返回与指定名字…

Linux 查找命令(find、locate 、grep )

学习Linux系统的第五篇博客&#xff1a;学习如何查询文件。 一、find 命令 作用&#xff1a; 在指定范围内迅速查找到文件。 用法&#xff1a; find 路径 参数 文件名 例如&#xff1a; 查找自己账户下文件名为test.txt的文件 命令&#xff1a;find /home/ygt -name test.tx…

景区门票管理系统

1、项目介绍 景区门票管理系统拥有两种角色 管理员&#xff1a;景点管理、留言管理、用户管理、订单管理等 用户&#xff1a;留言、门票购买、修改个人信息等 2、项目技术 后端框架&#xff1a; Servlet、mvc模式 前端技术&#xff1a;Bootstrap、jsp、css、JavaScript、…

景点景区门票购买核销宴会活动报名公众号系统开发

景点景区门票购买核销宴会活动报名公众号系统开发 功能特性 1.活动管理 可以新建一场或多场活动&#xff0c;管理每一场活动&#xff1b;与此同时&#xff0c;可以添加多张收费或免费门票&#xff0c;满足特定的需求&#xff1b;填写举办城市后&#xff0c;客户可通过定位服务&…

条件判断练习:门票价格【Python练习】

if-else语句 在 Python 中&#xff0c;if-else语句用于控制程序执行&#xff0c;基本形式为&#xff1a; if 判断语句1&#xff1a; step1 else:step2当判断语句1为真时&#xff0c;执行step1&#xff0c;否则执行step2。例如&#xff1a; name choose #判断变量name是否…

旅游景区怎么在抖音上卖门票?

抖音日活超8亿&#xff0c;流量巨大&#xff0c;而且是国内最大的短视频平台。 而景区拥有优美自然旅游资源&#xff0c;可以源源不断产出优质视频&#xff0c;非常适合短视频宣传&#xff0c;抖音如今堪称景区必做的营销渠道。 景区也想要在抖音上售卖门票&#xff0c;减少客户…