亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? leachm1vsleachm2.m

?? 無線傳感器網(wǎng)絡(luò) 路由算法 本科設(shè)計時的論文算法
?? M
字號:
clear
%1.初始參數(shù)設(shè)定模塊
%.傳感器節(jié)點區(qū)域界限(單位 M)
xm=100;
ym=100;
%(1)匯聚節(jié)坐標(biāo)給定
sink.x=0.5*xm;
sink.y=0.5*ym;
%區(qū)域內(nèi)傳器節(jié)數(shù)
n=100
%簇頭優(yōu)化比例(當(dāng)選簇頭的概率)
p=0.1;
%能量模型(單位 焦)
%初始化能量模型
Eo=0.5;
%Eelec=Etx=Erx
ETX=50*0.000000001;
ERX=50*0.000000001;
%Transmit Amplifier types
Efs=10*0.000000000001;
Emp=0.0013*0.000000000001;
%Data Aggregation Energy
EDA=5*0.000000001;
%高能量節(jié)點超出一節(jié)點能量的百分比
a=1;
%最大循環(huán)次數(shù)
rmax=5000
%算出參數(shù) do
do=sqrt(Efs/Emp);
%2.無線傳感器網(wǎng)絡(luò)模型產(chǎn)生模塊
%構(gòu)建無線傳感器網(wǎng)絡(luò),在區(qū)域內(nèi)均勻投放100個節(jié)點,并畫出圖形
for i=1:1:n
    S1(i).xd=rand(1,1)*xm;
    S2(i).xd=S1(i).xd;
    XR2(i)=S2(i).xd;
    XR1(i)=S1(i).xd;
    S1(i).yd=rand(1,1)*ym;
    S2(i).yd=S1(i).yd;
    YR2(i)=S2(i).yd;
    YR1(i)=S1(i).yd;
    S1(i).G=0;
    S2(i).G=0;
    S1(i).E=Eo*(1+rand*a);
    S2(i).E=S1(i).E;
    %initially there are no cluster heads only nodes
    S1(i).type='N';
    S2(i).type='N';
end

S1(n+1).xd=sink.x;
S1(n+1).yd=sink.y;
S2(n+1).xd=sink.x;
S2(n+1).yd=sink.y;
%3.網(wǎng)絡(luò)運行模塊
%簇頭節(jié)點數(shù)
countCHs1=0;
cluster1=1;%此定義的目的僅僅是給定一個1開始的下標(biāo)參數(shù),真正的簇頭數(shù)應(yīng)該還減去1
flag_first_dead1=0;
flag_teenth_dead1=0;
flag_all_dead1=0;
%死亡節(jié)點數(shù)
dead1=0;
first_dead1=0;
teenth_dead1=0;
all_dead1=0;
%活動節(jié)點數(shù)
allive1=n;
%counter for bit transmitted to Bases Station and to Cluster Heads
packets_TO_BS1=0;
packets_TO_CH1=0;
%(1)循環(huán)模式設(shè)定
for r=0:1:rmax     %該 for 循環(huán)將下面的所有程序包括在內(nèi),直到最后一 end 才結(jié)束循環(huán)
    r
  %每過一個輪轉(zhuǎn)周期(本程序為10次)使各節(jié)點的S(i).G參數(shù)(該參數(shù)用于后面的簇選舉,在該輪轉(zhuǎn)周期內(nèi)已當(dāng)選過簇頭的節(jié)點不能再當(dāng)選)恢復(fù)為零
  if(mod(r, round(1/p) )==0)
    for i=1:1:n
        S1(i).G=0;
        S1(i).cl=0;
    end
  end
%(2)死亡節(jié)點檢查模塊
dead1=0;
for i=1:1:n
    %檢查有無死亡節(jié)點
    if (S1(i).E<=0)
        dead1=dead1+1; 
        %(3)第一個死亡節(jié)點的產(chǎn)生時間(用輪次表示)
        %第一個節(jié)點死亡時間
        if (dead1==1)
           if(flag_first_dead1==0)
              first_dead1=r;
              flag_first_dead1=1;
           end
        end
        %10%的節(jié)點死亡時間
        if(dead1==0.1*n)
           if(flag_teenth_dead1==0)
              teenth_dead1=r;
              flag_teenth_dead1=1;
           end
        end
        if(dead1==n)
           if(flag_all_dead1==0)
              all_dead1=r;
              flag_all_dead1=1;
           end
        end
    end
    if S1(i).E>0
        S1(i).type='N';
    end
end
STATISTICS.DEAD1(r+1)=dead1;
STATISTICS.ALLIVE1(r+1)=allive1-dead1;
%(4)簇頭選舉模塊
countCHs1=0;
cluster1=1;
for i=1:1:n
   if(S1(i).E>0)
   temp_rand=rand;     
   if ( (S1(i).G)<=0)  
       %簇頭的選舉,當(dāng)選的簇頭會把各種相關(guān)信存入下面程序所給定的變量中
        if(temp_rand<= (p/(1-p*mod(r,round(1/p)))))
            countCHs1=countCHs1+1;
            packets_TO_BS1=packets_TO_BS1+1;
            PACKETS_TO_BS1(r+1)=packets_TO_BS1;
             S1(i).type='C';
            S1(i).G=round(1/p)-1;
            C1(cluster1).xd=S1(i).xd;
            C1(cluster1).yd=S1(i).yd;
           distance=sqrt( (S1(i).xd-(S1(n+1).xd) )^2 + (S1(i).yd-(S1(n+1).yd) )^2 );
            C1(cluster1).distance=distance;
            C1(cluster1).id=i;
            X1(cluster1)=S1(i).xd;
            Y1(cluster1)=S1(i).yd;
            cluster1=cluster1+1;
           %計算簇頭發(fā)送4000bit數(shù)據(jù)到基站的能量消耗(這里應(yīng)是所有節(jié)點包括簇頭每一輪發(fā)送4000bit數(shù)據(jù))
           distance;
            if (distance>do)
                S1(i).E=S1(i).E- ( (ETX+EDA)*(4000) + Emp*4000*( distance*distance*distance*distance )); 
            end
            if (distance<=do)
                S1(i).E=S1(i).E- ( (ETX+EDA)*(4000)  + Efs*4000*( distance * distance )); 
            end
        end     
    
    end
    % S(i).G=S(i).G-1;  
   
 end 
end
STATISTICS.COUNTCHS1(r+1)=countCHs1;
%(5)簇內(nèi)成員選擇簇頭模塊(即簇的形成模塊)
%簇內(nèi)成員對簇頭的選擇(即簇的形成)算法
for i=1:1:n
   if ( S1(i).type=='N' && S1(i).E>0 )
     if(cluster1-1>=1)
       min_dis=Inf;
       min_dis_cluster=0;
       for c=1:1:cluster1-1
           temp=min(min_dis,sqrt( (S1(i).xd-C1(c).xd)^2 + (S1(i).yd-C1(c).yd)^2 ) );
           if ( temp<min_dis )
               min_dis=temp;
               min_dis_cluster=c;
           end
       end
       %簇內(nèi)節(jié)點(發(fā)送4000bit數(shù)據(jù))能量消耗
       
            min_dis;
            if (min_dis>do)
                S1(i).E=S1(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S1(i).E=S1(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
        %簇頭(接受和融合這一簇內(nèi)節(jié)點4000bit數(shù)據(jù))的能量消耗
            S1(C1(min_dis_cluster).id).E = S1(C1(min_dis_cluster).id).E- ( (ERX + EDA)*4000 ); 
            packets_TO_CH1=packets_TO_CH1+1;    
 
        S1(i).min_dis=min_dis;
        S1(i).min_dis_cluster=min_dis_cluster;
    else
        min_dis=sqrt( (S1(i).xd-S1(n+1).xd)^2 + (S1(i).yd-S1(n+1).yd)^2 );
            if (min_dis>do)
                S1(i).E=S1(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S1(i).E=S1(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
            packets_TO_BS1=packets_TO_BS1+1;
     end
  end
end
STATISTICS.PACKETS_TO_CH1(r+1)=packets_TO_CH1;
STATISTICS.PACKETS_TO_BS1(r+1)=packets_TO_BS1;
end



%3.網(wǎng)絡(luò)運行模塊
%簇頭節(jié)點數(shù)
countCHs2=0;
cluster=1;%此定義的目的僅僅是給定一個1開始的下標(biāo)參數(shù),真正的簇頭數(shù)應(yīng)該還減去1
flag_first_dead2=0;
flag_teenth_dead2=0;
flag_all_dead2=0;
%死亡節(jié)點數(shù)
dead2=0;
first_dead2=0;
teenth_dead2=0;
all_dead2=0;
%活動節(jié)點數(shù)
allive2=n;
%counter for bit transmitted to Bases Station and to Cluster Heads
packets_TO_BS2=0;
packets_TO_CH2=0;
%(1)循環(huán)模式設(shè)定
for r=0:1:rmax     %該 for 循環(huán)將下面的所有程序包括在內(nèi),直到最后一 end 才結(jié)束循環(huán)
    r
  %每過一個輪轉(zhuǎn)周期(本程序為10次)使各節(jié)點的S(i).G參數(shù)(該參數(shù)用于后面的簇選舉,在該輪轉(zhuǎn)周期內(nèi)已當(dāng)選過簇頭的節(jié)點不能再當(dāng)選)恢復(fù)為零
  if(mod(r, round(1/p) )==0)
    for i=1:1:n
        S2(i).G=0;
        S2(i).cl=0;
    end
  end
%(2)死亡節(jié)點檢查模塊
dead2=0;
for i=1:1:n
    %檢查有無死亡節(jié)點
    if (S2(i).E<=0)
        dead2=dead2+1; 
        %(3)第一個死亡節(jié)點的產(chǎn)生時間(用輪次表示)
        %第一個節(jié)點死亡時間
        if (dead2==1)
           if(flag_first_dead2==0)
              first_dead2=r;
              flag_first_dead2=1;
           end
        end
        %10%的節(jié)點死亡時間
        if(dead2==0.1*n)
           if(flag_teenth_dead2==0)
              teenth_dead2=r;
              flag_teenth_dead2=1;
           end
        end
        if(dead2==n)
           if(flag_all_dead2==0)
              all_dead2=r;
              flag_all_dead2=1;
           end
        end
    end
    if S2(i).E>0
        S2(i).type='N';
    end
end
STATISTICS.DEAD2(r+1)=dead2;
STATISTICS.ALLIVE2(r+1)=allive2-dead2;
%(4)簇頭選舉模塊
countCHs2=0;
cluster2=1;
for i=1:1:n
   if(S2(i).E>0)
   temp_rand=rand;     
   if ( (S2(i).G)<=0)  
       %簇頭的選舉,當(dāng)選的簇頭會把各種相關(guān)信存入下面程序所給定的變量中
        if(temp_rand<= (p/(1-p*mod(r,round(1/p)))))
            countCHs2=countCHs2+1;
            packets_TO_BS2=packets_TO_BS2+1;
            PACKETS_TO_BS2(r+1)=packets_TO_BS2;
             S2(i).type='C';
            S2(i).G=round(1/p)-1;
            C2(cluster2).xd=S2(i).xd;
            C2(cluster2).yd=S2(i).yd;
           distance=sqrt( (S2(i).xd-(S2(n+1).xd) )^2 + (S2(i).yd-(S2(n+1).yd) )^2 );
            C2(cluster2).distance=distance;
            C2(cluster2).id=i;
            X2(cluster2)=S2(i).xd;
            Y2(cluster2)=S2(i).yd;
            cluster2=cluster2+1;
           %計算簇頭發(fā)送4000bit數(shù)據(jù)到基站的能量消耗(這里應(yīng)是所有節(jié)點包括簇頭每一輪發(fā)送4000bit數(shù)據(jù))
           distance;
            if (distance>do)
                S2(i).E=S2(i).E- ( (ETX+EDA)*(4000) + Emp*4000*( distance*distance*distance*distance )); 
            end
            if (distance<=do)
                S2(i).E=S2(i).E- ( (ETX+EDA)*(4000)  + Efs*4000*( distance * distance )); 
            end
        end     
    
    end
    % S2(i).G=S2(i).G-1;  
   
 end 
end
STATISTICS.COUNTCHS2(r+1)=countCHs2;
%(5)簇內(nèi)成員選擇簇頭模塊(即簇的形成模塊)
%簇內(nèi)成員對簇頭的選擇(即簇的形成)算法
for i=1:1:n
   if ( S2(i).type=='N' && S2(i).E>0 )
     if(cluster2-1>=1)
       min_dis=sqrt( (S2(i).xd-S2(n+1).xd)^2 + (S2(i).yd-S2(n+1).yd)^2 );
       min_dis_cluster=0;
       for c=1:1:cluster2-1
           temp=min(min_dis,sqrt( (S2(i).xd-C2(c).xd)^2 + (S2(i).yd-C2(c).yd)^2 ) );
           if ( temp<min_dis )
               min_dis=temp;
               min_dis_cluster=c;
           end
       end
       %簇內(nèi)節(jié)點(發(fā)送4000bit數(shù)據(jù))能量消耗
       if(min_dis_cluster~=0)    
            min_dis;
            if (min_dis>do)
                S2(i).E=S2(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S2(i).E=S2(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
        %簇頭(接受和融合這一簇內(nèi)節(jié)點4000bit數(shù)據(jù))的能量消耗
            S2(C2(min_dis_cluster).id).E = S2(C2(min_dis_cluster).id).E- ( (ERX + EDA)*4000 ); 
            packets_TO_CH2=packets_TO_CH2+1;
       else 
            min_dis;
            if (min_dis>do)
                S2(i).E=S2(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S2(i).E=S2(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
            packets_TO_BS2=packets_TO_BS2+1;
            
       end
        S2(i).min_dis=min_dis;
        S2(i).min_dis_cluster=min_dis_cluster;
    else
        min_dis=sqrt( (S2(i).xd-S2(n+1).xd)^2 + (S2(i).yd-S2(n+1).yd)^2 );
            if (min_dis>do)
                S2(i).E=S2(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S2(i).E=S2(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
            packets_TO_BS2=packets_TO_BS2+1;
     end
  end
end
STATISTICS.PACKETS_TO_CH2(r+1)=packets_TO_CH2;
STATISTICS.PACKETS_TO_BS2(r+1)=packets_TO_BS2;
end
r=0:5000;
subplot(1,2,1);
plot(r,STATISTICS.DEAD1,'--k',r,STATISTICS.DEAD2,'-r');
legend('leachm1','leachm2');
xlabel('x(time)');
ylabel('y(dead)');
title('\bf leachm1和leachm2的生命周期對比');
subplot(1,2,2);
plot(r,STATISTICS.PACKETS_TO_BS1,'--k',r,STATISTICS.PACKETS_TO_BS2,'-r');
legend('leachm1','leachm2');
xlabel('x(time)');
ylabel('y(data)');
title('\bf leachsm和leachm2的數(shù)據(jù)傳輸對比');

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
最新日韩av在线| 国产成a人亚洲| 日本一区二区高清| 欧美哺乳videos| 久久久久久久久久久久久久久99| 欧美成人精品高清在线播放| 欧美成人高清电影在线| 久久久www成人免费无遮挡大片| 日韩欧美一级片| 久久免费看少妇高潮| 国产三区在线成人av| 国产女人18水真多18精品一级做| 久久精品亚洲精品国产欧美kt∨| 久久久蜜桃精品| 亚洲欧洲在线观看av| 亚洲天堂精品在线观看| 亚洲小说春色综合另类电影| 日韩高清欧美激情| 国产剧情一区二区| 成人激情午夜影院| 欧美午夜不卡视频| 欧美二区乱c少妇| 久久综合久久综合亚洲| 自拍偷拍亚洲综合| 香蕉影视欧美成人| 韩日精品视频一区| 99久久夜色精品国产网站| 欧美日韩在线三级| 精品国产自在久精品国产| 国产精品污污网站在线观看| 亚洲国产综合色| 国产成人亚洲综合a∨婷婷图片 | 91色视频在线| 精品视频一区二区三区免费| 日韩片之四级片| 成人免费在线视频观看| 视频一区国产视频| 成人sese在线| 91精品国产欧美日韩| 国产精品欧美久久久久一区二区| 亚洲电影在线免费观看| 丁香另类激情小说| 日韩一区国产二区欧美三区| 1000精品久久久久久久久| 日本不卡1234视频| 97se亚洲国产综合在线| 久久噜噜亚洲综合| 五月天亚洲精品| 99精品在线免费| 欧美精品一区二区三区四区| 亚洲制服欧美中文字幕中文字幕| 国产一区二区三区香蕉| 3d成人动漫网站| 亚洲欧美色一区| 风间由美一区二区三区在线观看 | 日本一区二区视频在线| 午夜精品国产更新| 91麻豆精品一区二区三区| 久久久青草青青国产亚洲免观| 午夜在线电影亚洲一区| 色综合久久综合网欧美综合网 | 99re成人精品视频| 久久久久久97三级| 激情丁香综合五月| 日韩丝袜美女视频| 免费欧美高清视频| 在线电影国产精品| 天天综合色天天| 欧美日韩成人一区二区| 亚洲午夜免费视频| 欧洲一区在线电影| 亚洲亚洲精品在线观看| 欧美浪妇xxxx高跟鞋交| 亚洲综合小说图片| 日本韩国欧美在线| 亚洲精品亚洲人成人网| www.亚洲在线| 亚洲免费观看高清完整版在线观看熊 | 国产一区二区精品久久99| 7777精品久久久大香线蕉 | 日韩精品成人一区二区在线| 欧美日韩综合一区| 视频一区免费在线观看| 欧美一区二区日韩| 韩国一区二区视频| 久久精品视频一区| 99亚偷拍自图区亚洲| 亚洲天堂网中文字| 在线观看免费亚洲| 午夜影院在线观看欧美| 日韩三级电影网址| 国产成a人亚洲| 亚洲精品福利视频网站| 欧美日韩电影一区| 国产美女娇喘av呻吟久久| 国产精品毛片无遮挡高清| 色综合中文综合网| 国产午夜精品在线观看| 91精品国产欧美日韩| 国产精品色哟哟| 91免费小视频| 日韩精品一卡二卡三卡四卡无卡| 欧美一区二区三区在线| 国产福利91精品一区| 亚洲精品高清视频在线观看| 日韩一级免费一区| www.日韩av| 日产国产欧美视频一区精品| 亚洲国产高清不卡| 欧美日韩一区二区电影| 国产一区二区看久久| 尤物视频一区二区| 久久久综合视频| 欧美少妇性性性| 国产自产2019最新不卡| 亚洲综合av网| 国产亚洲精品超碰| 欧美视频你懂的| 97精品国产97久久久久久久久久久久 | 亚洲免费色视频| 欧美成人性福生活免费看| 日本韩国一区二区三区| 国产在线日韩欧美| 日韩经典中文字幕一区| 中文字幕不卡在线观看| 欧美va日韩va| 欧美日韩精品系列| 99国产精品视频免费观看| 黑人巨大精品欧美一区| 亚洲国产一区在线观看| 国产精品情趣视频| 亚洲精品一区二区三区蜜桃下载| 欧美性xxxxxxxx| 99久久精品免费看国产免费软件| 激情综合色播五月| 爽好久久久欧美精品| 亚洲黄色在线视频| 中文幕一区二区三区久久蜜桃| 精品免费一区二区三区| 这里是久久伊人| 欧美色爱综合网| 欧美在线你懂的| 日本道色综合久久| 99国产麻豆精品| av网站一区二区三区| 国产成人在线看| 粉嫩av亚洲一区二区图片| 国产老肥熟一区二区三区| 精品系列免费在线观看| 日韩精品一二三区| 免费在线观看一区二区三区| 亚洲成人免费视频| 午夜精品影院在线观看| 亚洲电影激情视频网站| 亚洲一区二区四区蜜桃| 亚洲高清视频的网址| 亚洲成人自拍偷拍| 亚洲国产成人高清精品| 亚洲成人高清在线| 欧美aaa在线| 久久99精品网久久| 国产馆精品极品| 国产99精品视频| 99视频有精品| 欧美三电影在线| 欧美一区二区三区婷婷月色| 欧美成人艳星乳罩| 国产欧美日韩精品在线| 亚洲色图一区二区三区| 亚洲在线观看免费| 蜜桃视频第一区免费观看| 久久99精品久久久久| 国产成人福利片| 一本一道久久a久久精品综合蜜臀| 日本乱人伦一区| 日韩一区二区三区视频| 久久嫩草精品久久久久| 亚洲人成网站在线| 日本伊人午夜精品| 丰满少妇久久久久久久| 欧美日韩精品一区视频| 宅男噜噜噜66一区二区66| 国产亚洲制服色| 亚洲国产日韩在线一区模特| 精品一区二区日韩| 99国内精品久久| 精品久久五月天| 一区二区三区在线看| 久久国产夜色精品鲁鲁99| 成人的网站免费观看| 91麻豆精品国产自产在线观看一区| 精品av久久707| 亚洲香肠在线观看| 国产不卡在线播放| 欧美日韩精品一区二区三区四区 | 国产成人在线色| 777午夜精品视频在线播放| 久久精品夜夜夜夜久久| 亚洲va欧美va人人爽| 粉嫩在线一区二区三区视频|