leach协议matlab仿真代码

http://www.ilovematlab.cn/thread-177006-1-1.html

LEACH協議
clear;%清除內存變量

xm=100;%x軸範圍
ym=100;%y軸範圍

sink.x=0.5*xm;%基站x軸
sink.y=0.5*ym;%基站y軸

n=100;%節點總數

p=0.1;%簇頭概率

E0=0.02;%初始能量
ETX=50*0.000000000001;%傳輸能量,每bit
ERX=50*0.000000000001;%接收能量,每bit
Efs=10*0.000000000001;%耗散能量,每bit
EDA=5*0.000000000001;%融合能耗,每bit

cc=0.6;%融合率

rmax=1000;%總輪數

CM=32;%控制信息大小
DM=4000;%數據信息大小

figure(1);%顯示圖片

for i=1:1:n
    S(i).xd=rand(1,1)*xm;
    S(i).yd=rand(1,1)*ym;
    S(i).G=0;%每一週期結束此變量為0
    S(i).E=E0;%設置初始能量為E0
    S(i).type=‘N‘;%節點類型為普通

plot(S(i).xd,S(i).yd,‘o‘);
    hold on;%保持所畫的圖像
end%為每個節點隨機分配坐標,並設置初始能量為E0,節點類型為普通

S(n+1).xd=sink.x;
S(n+1).yd=sink.y;
plot(S(n+1).xd,S(n+1).yd,‘x‘);%繪製基站節點

flag_first_dead=0;%第一個死亡節點的標誌變量

for r=1:1:rmax%開始每輪循環
  r+1%顯示輪數
    if(mod(r,round(1/p))==0)
       for i=1:1:n
           S(i).G=0;
       end
    end%如何輪數正好是一個週期的整數倍,則設置S(i).E為0

hold off;%每輪圖片重新繪製
     cluster=0;%初始簇頭數為0
     dead=0;%初始死亡節點數為0
     
     figure(1);

for i=1:1:n
         if(S(i).E<=0)
         plot(S(i).xd,S(i).yd,‘red .‘);
         dead=dead+1;%將能量小於等於0的節點繪製成紅色,並將死亡節點數增加1
         
         if(dead==1)
           if(flag_first_dead==0)
             first_dead=r %第一個節點的死亡輪數
             save ltest, first_dead;
             flag_first_dead=1;
           end
         end%將能量小於等於0的節點繪製成紅色,並將死亡節點數增加1
           
         hold on;
         else
             S(i).type=‘N‘;
             plot(S(i).xd,S(i).yd,‘o‘);%繪製其他節點
             hold on;
         end

end

plot(S(n+1).xd,S(n+1).yd,‘x‘);%繪製基站

Dead(r+1)=dead; %每輪有死亡節點數
     save ltest, Dead(r+1);%將此數據存入ltest文件
     
     for i=1:1:n
         if(S(i).E>0)
           if(S(i).G<=0)
            temp_rand=rand;%取一個隨機數
            if(temp_rand<=(p/(1-p*mod(r,round(1/p)))))%如果隨機數小於等於
            S(i).type=‘C‘;%此節點為此輪簇頭
            S(i).G=round(1/p)-1;%S(i).G設置為大於0,此週期不能再被選擇為簇頭
            cluster=cluster+1;%簇頭數加1
            C(cluster).xd=S(i).xd;
            C(cluster).yd=S(i).yd;%將此節點標誌為簇頭
            plot(S(i).xd,S(i).yd,‘k*‘);%繪製此簇頭

distance=sqrt((S(i).xd-(S(n+1).xd))^2+(S(i).yd-(S(n+1).yd))^2);%簇頭到基站的距離
            C(cluster).distance=distance;%標誌為此簇頭的距離
            C(cluster).id=i; %此簇頭的節點id

packet_To_BS(cluster)=1;%發送到基站的數據包數為1
            end
           end
          end
         end

CH_Num(r+1)=cluster; %每輪的簇頭數
        save ltest,CH_Num(r+1);%保存每輪簇頭數到ltest
     for i=1:1:n
         if(S(i).type==‘N‘&&S(i).E>0)%對每個能量大於0且非簇頭節點
           min_dis=sqrt((S(i).xd-(C(1).xd))^2+(S(i).yd-(C(1).yd))^2);%計算此節點到簇頭1的距離
           min_dis_cluster=1;
           for c=2:1:cluster
               temp=sqrt((S(i).xd-(C(c).xd))^2+(S(i).yd-(C(c).yd))^2);
               if(temp<min_dis)
                  min_dis=temp;
                  min_dis_cluster=c;
               end
           end%選擇此幾點到哪個簇頭的距離最小
         packet_To_BS(min_dis_cluster)=packet_To_BS(min_dis_cluster)+1;%將此節點加入的簇
                                                                     %頭節點數據包數加1

Er1=ERX*CM*(cluster+1);%此節點接收各個簇頭的控制信息
                            %此節點加入的簇的簇頭時隙控制信息的總接收能耗
         Et1=ETX*(CM+DM)+Efs*(CM+DM)*min_dis*min_dis;%此節點發送加入信息和發送數據信息
                                                       %到簇頭的能耗
         S(i).E=S(i).E-Er1-Et1;%此輪後的剩餘能量
         end
      end

for c=1:1:cluster%各個簇頭
     packet_To_BS(c);%簇頭需發送到基站的數據包個數
     CEr1=ERX*CM*(packet_To_BS(c)-1);%收到此簇各個節點加入信息的能耗
     CEr2=ERX*DM*(packet_To_BS(c)-1);%收到此簇各個節點數據信息的能耗
     CEt1=ETX*CM+Efs*CM*(sqrt(xm*ym))*(sqrt(xm*ym));%此簇頭廣播成簇信息的能耗
     CEt2=(ETX+EDA)*DM*cc*packet_To_BS(c)+Efs*DM*cc*packet_To_BS(c)*C(c).distance*C(c).distance;%簇頭將所以數據融合後發往基站的能耗
     S(C(c).id).E=S(C(c).id).E-CEr1-CEr2-CEt1-CEt2;%此輪後簇頭的剩餘能量
     end
  
    for i=1:1:n
    R(r+1,i)=S(i).E;  %每輪每節點的剩餘能量
    % save ltest,R(r+1,i);%保存此數據到ltest
    end

hold on;

end

时间: 2024-12-28 08:24:28

leach协议matlab仿真代码的相关文章

通信算法之十五:WIFI-802.11a,b,g,n协议物理层仿真

一. 802.11协议-WIFI-对比 二. 802.11n物理层技术 OFDM-MIMO 三. MIMO技术 四.工程实践 802.11a,b,g,n,物理层基带matlab仿真已经完成,性能优异 DSP工程实践了 五.如需要协议相应的物理层仿真代码,matlab仿真链路代码,及DSP之C语言程序,请联系QQ:1279682290

经典功率谱估计及Matlab仿真

原文出自:http://www.cnblogs.com/jacklu/p/5140913.html 功率谱估计在分析平稳各态遍历随机信号频率成分领域被广泛使用,并且已被成功应用到雷达信号处理.故障诊断等实际工程中.本文给出了经典功率谱估计的几类方法,并通过Matlab的实验仿真对经典功率谱估计方法性能进行了分析,最后说明了经典功率谱估计法的局限性和造成这种局限性的原因. 1.引言 给定一个标准的正弦信号,我们可以通过傅里叶变换来分析它的频率成分.然而,实际工程应用中,由于存在着各种干扰.噪声,我

用MATLAB仿真BPSK调制

这是本人的处女贴,以后还会写更多ICT方面的blog.今天为大家呈上MATLAB仿真BPSK调制的codes: clear all;clc; SNR_dB=1:1:9; SNR=10.^(SNR_dB./10); size=length(SNR_dB); A=ones(1,size);%固定A,定义变量sigma sigma=sqrt(1./(2*SNR));%A=1 N=10000; s=randi([0,1],1,N); s1=2*s-1; s2=zeros(1,N); N_errB=zer

MATLAB仿真总结

MATLAB仿真过程中,编写MATLAB代码的时候犯了很多错误,做了很多蠢事.记录下自己犯错的点点滴滴,并引以为戒.使用MATLAB版本为2014a,以下内容如有不当还请指正. 1. 仿真开始前清理工作区 工作区存在的变量可能会对脚本运行产生影响,故代码(脚本)开头需要添加如下命令 clc;clear all;close all; 2. 养成良好的变量.函数命名习惯 MATLAB中有很多内置的常量.函数等.写代码的时候不能够随意命名,以防造成不必要的麻烦.譬如在循环时不应该使用i,j变量,在MA

UVW平台运动控制算法以及matlab仿真

UVW平台运动控制算法以及matlab仿真 最近公司同事因为对某视觉对位平台的运动控制算法有疑问,所以来请教我.由于我也是第一次接触到UVW自动对位平台(也可以叫XXY自动对位平台),于是找了一些资料学习一下,大概了解了运动模式后,使用matlab模拟了此平台,并验证了UVW平台资料提供的运动控制算法的正确性. 一.UVW平台介绍 1.这是一种可以实现以平面上任意一点为中心,进行旋转运动的装置,并可沿着任意的方向平移.2.此平台和视觉CCD纠偏系统对接在一起,可以很快完成高精度的纠偏工作,重复定

Ubuntu10.04中的Leach协议一键安装

1.HashMap的遍历 package com.sheepmu; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Map.Entry; public class KMPText { public static void main(String[] args) { Map<String,String> map=new HashMap<String,Str

Ubuntu10.04中间Leach协议一键安装

半天后,尝试,引用网络上的零散资源,成品博客Leach协议ubuntu10.04在安装(12.04也可以在右侧安装,然而,实施效果的不,求解决~~),并制作了补丁. 一个关键的安装步骤如下面: 1.在用户文件夹创建一个新的文件夹,所谓随机.忠告"Leach". 2.将一键安装包中的文件拷贝到Leach目录中. 3.运行脚本:./leach-install.sh 中间过程可能须要输入管理员权限的password.请依据自己设定输入. 因为无法上传附件,我在此将补丁文件和脚本贴出来,假设有

深度学习Matlab工具箱代码详解

最近研究了几天深度学习的Matlab工具箱代码,发现作者给出的源码中注释实在是少得可怜,为了方便大家阅读,特对代码进行了注释,与大家分享. 在阅读Matlab工具箱代码之前,建议大家阅读几篇CNN方面的两篇经典材料,对卷积神经网络Matlab工具箱代码的理解有很大帮助,稍后我会将这两篇文献上传到网上与大家分享.急需的也可以留言注明,我会及时发送至邮箱的. (1)<Notes on Convolutional Neural Networks>,这篇文章是与Matlab工具箱代码配套的文献,不过文

借助全新 MATLAB&#174; 适配器代码示例读取英特尔&#174; 实感? 摄像头数据流

下载源代码请访问原文地址:借助全新 MATLAB® 适配器代码示例读取英特尔® 实感™ 摄像头数据流 简介 该可下载代码示例简要介绍了如何使用英特尔® 实感™ SDK 和 MATLAB 的图像采集工具箱适配器套件在 MATLAB® 工作区获取英特尔® 实感™ 摄像头(R200 和 F200)的原始摄像头数据流. 该示例代码支持 MATLAB 开发人员开发面向英特尔® 平台.并具备以下特性的英特尔® 实感™ 应用: 多数据流同步. 同时获取颜色数据流和景深数据流(见图 1). 多摄像头支持. 同时