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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? leachvsdeec.m

?? LEACH協議與DEEC協議的比較
?? M
?? 第 1 頁 / 共 2 頁
字號:
                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
if countCHs2~=0
   u2=(n-y2)/countCHs2;
for c=1:1:cluster2-1
    z2=(x2(c)-u2)*(x2(c)-u2)+z2;
end
LBF2(r+1)=z2/countCHs2;
else  LBF2(r+1)=0;
end
STATISTICS.PACKETS_TO_CH2(r+1)=packets_TO_CH2;
STATISTICS.PACKETS_TO_BS2(r+1)=packets_TO_BS2;
end


d1=0.765*xm/2;
K=sqrt(0.5*n*do/pi)*xm/d1^2;
d2=xm/sqrt(2*pi*K);
Er=4000*(2*n*ETX+n*EDA+K*Emp*d1^4+n*Efs*d2^2);
S3(n+1).xd=sink.x;
S3(n+1).yd=sink.y;
S4(n+1).xd=sink.x;
S4(n+1).yd=sink.y;
%3.網絡運行模塊
%簇頭節點數
countCHs3=0;
cluster3=1;%此定義的目的僅僅是給定一個1開始的下標參數,真正的簇頭數應該還減去1
flag_first_dead3=0;
flag_teenth_dead3=0;
flag_all_dead3=0;
%死亡節點數
dead3=0;
first_dead3=0;
teenth_dead3=0;
all_dead3=0;
%活動節點數
allive3=n;
%counter for bit transmitted to Bases Station and to Cluster Heads
packets_TO_BS3=0;
packets_TO_CH3=0;
%(1)循環模式設定
for r=0:1:rmax     %該 for 循環將下面的所有程序包括在內,直到最后一 end 才結束循環
    r
  %每過一個輪轉周期(本程序為10次)使各節點的S(i).G參數(該參數用于后面的簇選舉,在該輪轉周期內已當選過簇頭的節點不能再當選)恢復為零
  if(mod(r, round(1/P) )==0)
    for i=1:1:n
        S3(i).G=0;
        S3(i).cl=0;
    end
  end
Ea=Et*(1-r/rmax)/n;
%(2)死亡節點檢查模塊
dead3=0;
for i=1:1:n
    %檢查有無死亡節點
    if (S3(i).E<=0)
        dead3=dead3+1; 
        %(3)第一個死亡節點的產生時間(用輪次表示)
        %第一個節點死亡時間
        if (dead3==1)
           if(flag_first_dead3==0)
              first_dead3=r;
              flag_first_dead3=1;
           end
        end
        %10%的節點死亡時間
        if(dead3==0.1*n)
           if(flag_teenth_dead3==0)
              teenth_dead3=r;
              flag_teenth_dead3=1;
           end
        end
        if(dead3==n)
           if(flag_all_dead3==0)
              all_dead3=r;
              flag_all_dead3=1;
           end
        end
    end
    if S3(i).E>0
        S3(i).type='N';
    end
end
STATISTICS.DEAD3(r+1)=dead3;
STATISTICS.ALLIVE3(r+1)=allive3-dead3;
%(4)簇頭選舉模塊
countCHs3=0;
cluster3=1;
for i=1:1:n
 if Ea>0
 p(i)=P*n*S3(i).E*E3(i)/(Et*Ea);
 if(S3(i).E>0)
   temp_rand=rand;     
   if ( (S3(i).G)<=0)  
       %簇頭的選舉,當選的簇頭會把各種相關信存入下面程序所給定的變量中
        if(temp_rand<= (p(i)/(1-p(i)*mod(r,round(1/p(i))))))
            countCHs3=countCHs3+1;
            packets_TO_BS3=packets_TO_BS3+1;
            PACKETS_TO_BS3(r+1)=packets_TO_BS3;
             S3(i).type='C';
            S3(i).G=round(1/p(i))-1;
            C3(cluster3).xd=S3(i).xd;
            C3(cluster3).yd=S3(i).yd;
           distance=sqrt( (S3(i).xd-(S3(n+1).xd) )^2 + (S3(i).yd-(S3(n+1).yd) )^2 );
            C3(cluster3).distance=distance;
            C3(cluster3).id=i;
            X3(cluster3)=S3(i).xd;
            Y3(cluster3)=S3(i).yd;
            cluster3=cluster3+1;
           %計算簇頭發送4000bit數據到基站的能量消耗(這里應是所有節點包括簇頭每一輪發送4000bit數據)
           distance;
            if (distance>do)
                S3(i).E=S3(i).E- ( (ETX+EDA)*(4000) + Emp*4000*( distance*distance*distance*distance )); 
            end
            if (distance<=do)
                S3(i).E=S3(i).E- ( (ETX+EDA)*(4000)  + Efs*4000*( distance * distance )); 
            end
        end     
    
    end
    % S3(i).G=S3(i).G-1;  
   
 end 
 end
end
STATISTICS.COUNTCHS3(r+1)=countCHs3;
%(5)簇內成員選擇簇頭模塊(即簇的形成模塊)
%簇內成員對簇頭的選擇(即簇的形成)算法
for c=1:1:cluster3-1
    x3(c)=0;
end
y3=0;
z3=0;
for i=1:1:n
   if ( S3(i).type=='N' && S3(i).E>0 )
     if(cluster3-1>=1)
       min_dis=Inf;
       min_dis_cluster=0;
       for c=1:1:cluster3-1
           temp=min(min_dis,sqrt( (S3(i).xd-C3(c).xd)^2 + (S3(i).yd-C3(c).yd)^2 ) );
           if ( temp<min_dis )
               min_dis=temp;
               min_dis_cluster=c;
               x3(c)=x3(c)+1;
           end
       end
       %簇內節點(發送4000bit數據)能量消耗
 
            min_dis;
            if (min_dis>do)
                S3(i).E=S3(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S3(i).E=S3(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
        %簇頭(接受和融合這一簇內節點4000bit數據)的能量消耗
            S3(C3(min_dis_cluster).id).E = S3(C3(min_dis_cluster).id).E- ( (ERX + EDA)*4000 ); 
            packets_TO_CH3=packets_TO_CH3+1;

            
      
        S3(i).min_dis=min_dis;
        S3(i).min_dis_cluster=min_dis_cluster;
   else
       y3=y3+1;
            min_dis=sqrt( (S3(i).xd-S3(n+1).xd)^2 + (S3(i).yd-S3(n+1).yd)^2 );
            if (min_dis>do)
                S3(i).E=S3(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S3(i).E=S3(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
           packets_TO_BS3=packets_TO_BS3+1;
   end
  end
end
if countCHs3~=0
   u3=(n-y3)/countCHs3;
for c=1:1:cluster3-1
    z3=(x3(c)-u3)*(x3(c)-u3)+z3;
end
LBF3(r+1)=z3/countCHs3;
else  LBF3(r+1)=0;
end
 STATISTICS.PACKETS_TO_CH3(r+1)=packets_TO_CH3;
 STATISTICS.PACKETS_TO_BS3(r+1)=packets_TO_BS3;
end



countCHs4=0;
cluster=1;%此定義的目的僅僅是給定一個1開始的下標參數,真正的簇頭數應該還減去1
flag_first_dead4=0;
flag_teenth_dead4=0;
flag_all_dead4=0;
%死亡節點數
dead4=0;
first_dead4=0;
teenth_dead4=0;
all_dead4=0;
%活動節點數
allive4=n;
%counter for bit transmitted to Bases Station and to Cluster Heads
packets_TO_BS4=0;
packets_TO_CH4=0;
%(1)循環模式設定
for r=0:1:rmax     %該 for 循環將下面的所有程序包括在內,直到最后一 end 才結束循環
    r
  %每過一個輪轉周期(本程序為10次)使各節點的S(i).G參數(該參數用于后面的簇選舉,在該輪轉周期內已當選過簇頭的節點不能再當選)恢復為零
  if(mod(r, round(1/P) )==0)
    for i=1:1:n
        S4(i).G=0;
        S4(i).cl=0;
    end
  end
Ea=Et*(1-r/rmax)/n;
%(2)死亡節點檢查模塊
dead4=0;
for i=1:1:n
    %檢查有無死亡節點
    if (S4(i).E<=0)
        dead4=dead4+1; 
        %(3)第一個死亡節點的產生時間(用輪次表示)
        %第一個節點死亡時間
        if (dead4==1)
           if(flag_first_dead4==0)
              first_dead4=r;
              flag_first_dead4=1;
           end
        end
        %10%的節點死亡時間
        if(dead4==0.1*n)
           if(flag_teenth_dead4==0)
              teenth_dead4=r;
              flag_teenth_dead4=1;
           end
        end
        if(dead4==n)
           if(flag_all_dead4==0)
              all_dead4=r;
              flag_all_dead4=1;
           end
        end
    end
    if S4(i).E>0
        S4(i).type='N';
    end
end
STATISTICS.DEAD4(r+1)=dead4;
STATISTICS.ALLIVE4(r+1)=allive4-dead4;
%(4)簇頭選舉模塊
countCHs4=0;
cluster4=1;
for i=1:1:n
 if Ea>0
 p(i)=P*n*S4(i).E*E4(i)/(Et*Ea);
 if(S4(i).E>0)
   temp_rand=rand;     
   if ( (S4(i).G)<=0)  
       %簇頭的選舉,當選的簇頭會把各種相關信存入下面程序所給定的變量中
        if(temp_rand<= (p(i)/(1-p(i)*mod(r,round(1/p(i))))))
            countCHs4=countCHs4+1;
            packets_TO_BS4=packets_TO_BS4+1;
            PACKETS_TO_BS4(r+1)=packets_TO_BS4;
             S4(i).type='C';
            S4(i).G=round(1/p(i))-1;
            C4(cluster4).xd=S4(i).xd;
            C4(cluster4).yd=S4(i).yd;
           distance=sqrt( (S4(i).xd-(S4(n+1).xd) )^2 + (S4(i).yd-(S4(n+1).yd) )^2 );
            C4(cluster4).distance=distance;
            C4(cluster4).id=i;
            X4(cluster4)=S4(i).xd;
            Y4(cluster4)=S4(i).yd;
            cluster4=cluster4+1;
           %計算簇頭發送4000bit數據到基站的能量消耗(這里應是所有節點包括簇頭每一輪發送4000bit數據)
           distance;
            if (distance>do)
                S4(i).E=S4(i).E- ( (ETX+EDA)*(4000) + Emp*4000*( distance*distance*distance*distance )); 
            end
            if (distance<=do)
                S4(i).E=S4(i).E- ( (ETX+EDA)*(4000)  + Efs*4000*( distance * distance )); 
            end
        end     
    
    end
    % S4(i).G=S4(i).G-1;  
   
 end 
 end
end
STATISTICS.COUNTCHS4(r+1)=countCHs4;
%(5)簇內成員選擇簇頭模塊(即簇的形成模塊)
%簇內成員對簇頭的選擇(即簇的形成)算法
for c=1:1:cluster4-1
    x4(c)=0;
end
y4=0;
z4=0;
for i=1:1:n
   if ( S4(i).type=='N' && S4(i).E>0 )
     if(cluster4-1>=1)
       min_dis=sqrt( (S4(i).xd-S4(n+1).xd)^2 + (S4(i).yd-S4(n+1).yd)^2 );
       min_dis_cluster=0;
       for c=1:1:cluster4-1
           temp=min(min_dis,sqrt( (S4(i).xd-C4(c).xd)^2 + (S4(i).yd-C4(c).yd)^2 ) );
           if ( temp<min_dis )
               min_dis=temp;
               min_dis_cluster=c;
               x4(c)=x4(c)+1;
           end
       end
       %簇內節點(發送4000bit數據)能量消耗
       if(min_dis_cluster~=0)    
            min_dis;
            if (min_dis>do)
                S4(i).E=S4(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S4(i).E=S4(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
        %簇頭(接受和融合這一簇內節點4000bit數據)的能量消耗
            S4(C4(min_dis_cluster).id).E = S4(C4(min_dis_cluster).id).E- ( (ERX + EDA)*4000 ); 
            packets_TO_CH4=packets_TO_CH4+1;
       else 
            min_dis;
            if (min_dis>do)
                S4(i).E=S4(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S4(i).E=S4(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
            packets_TO_BS4=packets_TO_BS4+1;
            
       end
        S4(i).min_dis=min_dis;
       S4(i).min_dis_cluster=min_dis_cluster;
   else
       y4=y4+1;
            min_dis=sqrt( (S4(i).xd-S4(n+1).xd)^2 + (S4(i).yd-S4(n+1).yd)^2 );
            if (min_dis>do)
                S4(i).E=S4(i).E- ( ETX*(4000) + Emp*4000*( min_dis * min_dis * min_dis * min_dis)); 
            end
            if (min_dis<=do)
                S4(i).E=S4(i).E- ( ETX*(4000) + Efs*4000*( min_dis * min_dis)); 
            end
            packets_TO_BS4=packets_TO_BS4+1;
   end
  end
end
if countCHs4~=0
   u4=(n-y4)/countCHs4;
for c=1:1:cluster4-1
    z4=(x4(c)-u4)*(x4(c)-u4)+z4;
end
LBF4(r+1)=z4/countCHs4;
else  LBF4(r+1)=0;
end
STATISTICS.PACKETS_TO_CH4(r+1)=packets_TO_CH4;
STATISTICS.PACKETS_TO_BS4(r+1)=packets_TO_BS4;
end

r=0:5000;
subplot(2,1,1);
plot(r,STATISTICS.DEAD1,':k',r,STATISTICS.DEAD2,'-r',r,STATISTICS.DEAD3,'--b',r,STATISTICS.DEAD4,'-.m');
legend('leachm1','leachm2','DEEC1','DEEC2');
xlabel('x(time)');
ylabel('y(dead)');
title('\bf leach(1,2)和DEEC(1,2)的生命周期對比');
subplot(2,1,2);
plot(r,STATISTICS.PACKETS_TO_BS1,':k',r,STATISTICS.PACKETS_TO_BS2,'-r',r,STATISTICS.PACKETS_TO_BS3,'--b',r,STATISTICS.PACKETS_TO_BS4,'-.m');
legend('leachm1','leachm2','DEEC1','DEEC2');
xlabel('x(time)');
ylabel('y(data)');
title('\bf leach(1,2)和DEEC(1,2)的數據傳輸對比');

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
经典三级一区二区| 黄色小说综合网站| 日韩毛片高清在线播放| 欧美国产日韩精品免费观看| 国产亚洲精品资源在线26u| 国产亚洲成aⅴ人片在线观看| 26uuu成人网一区二区三区| 久久精品欧美一区二区三区不卡 | 日韩一区中文字幕| 中文字幕免费在线观看视频一区| 国产欧美精品区一区二区三区| 国产精品午夜电影| 亚洲欧美日韩国产手机在线 | 亚洲视频免费在线| 亚洲精品乱码久久久久久久久 | 欧美一区二区三区公司| 日韩欧美激情一区| 国产精品系列在线| 亚洲一卡二卡三卡四卡| 男男gaygay亚洲| 国产成人亚洲综合a∨猫咪| 成人午夜av在线| 在线视频综合导航| 日韩午夜激情视频| 国产精品家庭影院| 日本三级韩国三级欧美三级| 国产91丝袜在线18| 欧美性大战久久久| 国产日韩视频一区二区三区| 一区二区三区在线免费播放| 日本欧美肥老太交大片| av电影天堂一区二区在线| 91精品国产入口| 国产欧美一区二区在线| 亚洲一二三区视频在线观看| 韩国女主播一区| 一本色道亚洲精品aⅴ| 精品福利一二区| 亚洲欧美另类在线| 国产一区二区三区四区在线观看| 99久久综合色| 久久综合五月天婷婷伊人| 一区二区三区精品视频| 国产精品18久久久久| 欧美日韩一本到| 国产精品久久久久久久久久久免费看| 午夜精品成人在线| av爱爱亚洲一区| 久久久久久久久久电影| 日韩精品三区四区| 欧美色图片你懂的| 亚洲欧洲美洲综合色网| 精品一区二区免费在线观看| 欧美精品丝袜久久久中文字幕| 中文字幕一区在线观看| 国产中文字幕一区| 日韩欧美一级精品久久| 亚洲一二三级电影| 日本高清视频一区二区| 国产精品国产三级国产aⅴ原创| 精品亚洲国内自在自线福利| 欧美日韩激情一区二区三区| 亚洲男人都懂的| 成人免费观看视频| 国产精品久久久久9999吃药| 国产黄色精品视频| 久久久久久久久99精品| 国产乱码精品一区二区三区忘忧草| 69堂精品视频| 免费视频一区二区| 欧美一区二区黄色| 麻豆精品在线视频| 日韩女同互慰一区二区| 美女国产一区二区三区| 精品国产凹凸成av人导航| 久久99九九99精品| 久久久高清一区二区三区| 成人午夜激情片| 一区视频在线播放| 91网页版在线| 亚洲不卡一区二区三区| 7777精品伊人久久久大香线蕉| 视频在线观看91| 日韩视频一区在线观看| 国产一区二区三区免费播放| 日本一区二区三区免费乱视频 | 91.com在线观看| 久久不见久久见免费视频1| 欧美va天堂va视频va在线| 精品在线免费观看| 国产欧美日韩综合| 色综合久久久久网| 视频一区在线播放| 久久久久国产精品人| 99re热这里只有精品免费视频| 一区二区三区中文免费| 91麻豆精品国产自产在线观看一区| 日本欧美一区二区| 国产精品色在线观看| 欧美色网站导航| 国产一区美女在线| 亚洲综合丝袜美腿| 精品国产一二三区| 91视频在线观看免费| 午夜成人免费电影| 欧美国产一区二区| 欧美视频一区在线观看| 国产成人在线影院| 亚洲一区二区三区在线看| 欧美精品一区二区三区高清aⅴ| 成人av在线看| 免费在线看成人av| 亚洲精品第一国产综合野| 日韩丝袜情趣美女图片| 99久久久久久| 国产一区二区伦理| 午夜在线电影亚洲一区| 国产欧美一区二区精品性| 欧美精品乱码久久久久久按摩| 国产成人免费视频一区| 天天影视色香欲综合网老头| 国产精品麻豆网站| 久久尤物电影视频在线观看| 欧美视频中文字幕| 99久久精品国产一区二区三区| 蜜桃久久av一区| 亚洲综合区在线| 国产精品久久久久影院老司| 欧美成人精品1314www| 欧亚一区二区三区| 成人免费视频网站在线观看| 美女在线一区二区| 日韩国产欧美在线视频| 亚洲最大成人综合| 亚洲婷婷在线视频| 欧美激情一区二区三区蜜桃视频 | 欧美日精品一区视频| 不卡的av中国片| 国产成人精品影视| 久久精品国产精品亚洲综合| 日韩av网站免费在线| 亚洲电影第三页| 亚洲一本大道在线| 亚洲午夜久久久| 一区二区三区四区不卡在线| 国产精品国产a级| 136国产福利精品导航| 欧美激情一区二区三区四区| 国产日产欧美一区| 国产精品久久久久毛片软件| 国产情人综合久久777777| 欧美经典三级视频一区二区三区| 精品国产乱码久久久久久免费| 日韩午夜激情视频| 精品成人一区二区| 久久久亚洲午夜电影| 国产三区在线成人av| 中文字幕av资源一区| 国产精品麻豆视频| 日韩伦理av电影| 亚洲香肠在线观看| 日本一道高清亚洲日美韩| 六月丁香婷婷色狠狠久久| 国产一区二区三区av电影 | 日韩欧美一区在线| ww亚洲ww在线观看国产| 久久久99精品免费观看| 国产精品午夜久久| 亚洲电影一区二区三区| 奇米四色…亚洲| 丁香婷婷综合五月| 91精品91久久久中77777| 欧美丰满少妇xxxxx高潮对白| 欧美一级片免费看| 久久久久国产精品麻豆| 亚洲欧美激情插| 欧美aaaaaa午夜精品| 国产不卡高清在线观看视频| 色哟哟一区二区在线观看| 欧美高清视频一二三区 | 国产91在线看| 欧美性欧美巨大黑白大战| 日韩视频免费观看高清完整版在线观看| 欧美videofree性高清杂交| 国产精品久久久久久久浪潮网站| 亚洲五月六月丁香激情| 国产在线精品一区在线观看麻豆| 99精品欧美一区二区蜜桃免费| 欧美日韩国产成人在线91| 久久精品综合网| 香蕉久久一区二区不卡无毒影院| 国产精品69毛片高清亚洲| 精品视频在线视频| 国产精品嫩草99a| 免费av成人在线| 色一区在线观看| 欧美激情一区二区三区不卡| 蜜臀精品一区二区三区在线观看| 成人午夜短视频| 精品国产一二三区|