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

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

?? leach.m

?? 無線傳感器網絡的能量控制
?? M
字號:
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%                                                                      %
% SEP: A Stable Election Protocol for clustered                        %
%      heterogeneous wireless sensor networks                          %
%                                                                      %
% (c) Georgios Smaragdakis                                             %
% WING group, Computer Science Department, Boston University           %
%                                                                      %
% You can find full documentation and related information at:          %
% http://csr.bu.edu/sep                                                %
%                                                                      % 
% To report your comment or any bug please send e-mail to:             %
% gsmaragd@cs.bu.edu                                                   %
%                                                                      %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%                                                                      %
% This is the LEACH [1] code we have used.                             %
% The same code can be used for FAIR if m=1                            %
%                                                                      %
% [1] W.R.Heinzelman, A.P.Chandrakasan and H.Balakrishnan,             %
%     "An application-specific protocol architecture for wireless      % 
%      microsensor networks"                                           % 
%     IEEE Transactions on Wireless Communications, 1(4):660-670,2002 %
%                                                                      %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

clear;

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% PARAMETERS %%%%%%%%%%%%%%%%%%%%%%%%%%%%

%Field Dimensions - x and y maximum (in meters)
xm = 200;
ym = 200;

%x and y Coordinates of the Sink
sink.x =0.5 * xm;
sink.y = ym + 50;

%Number of Nodes in the field
n = 200

%Optimal Election Probability of a node
%to become cluster head
p=0.05;
packetLength = 4000;%數據包長度 
ctrPacketLength = 100;%控制包長度
%Energy Model (all values in Joules)
%Initial Energy 
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;

%Values for Hetereogeneity
%Percentage of nodes than are advanced
m=1;
%\alpha
a=1;
INFINITY = 999999999999999;
%maximum number of rounds
rmax=2000

%%%%%%%%%%%%%%%%%%%%%%%%% END OF PARAMETERS %%%%%%%%%%%%%%%%%%%%%%%%

%Computation of do
do=sqrt(Efs/Emp);

%Creation of the random Sensor Network
figure(1);
for i=1:1:n
    S(i).xd=rand(1,1)*xm;%坐標
    XR(i)=S(i).xd;
    S(i).yd=rand(1,1)*ym;
    YR(i)=S(i).yd;
    S(i).G=0;
    %initially there are no cluster heads only nodes
    S(i).type='N';%普通節點
   
    temp_rnd0 = i;
    %Random Election of Normal Nodes
    %if (temp_rnd0>=m*n+1) 
        S(i).E=Eo;
        S(i).ENERGY=0;
       % plot(S(i).xd,S(i).yd,'o');
       % hold on;
   % end
    %Random Election of Advanced Nodes
   % if (temp_rnd0<m*n+1) 
   %     S(i).E=Eo*(1+a)
   %     S(i).ENERGY=1;
   %     %plot(S(i).xd,S(i).yd,'+');
    %    %hold on;
   % end
end

S(n+1).xd=sink.x;
S(n+1).yd=sink.y;
%plot(S(n+1).xd,S(n+1).yd,'x');
    
        
%First Iteration
figure(1);

%counter for CHs
countCHs=0;
%counter for CHs per round
rcountCHs=0;
cluster=1;

countCHs;
rcountCHs=rcountCHs+countCHs;
flag_first_dead=0; 

for r=0:1:rmax %主循環,每次1輪
r

%Operation for epoch
if(mod(r, round(1/p) )==0)
    for i=1:1:n
        S(i).G=0;
        S(i).cl=0;
    end
end

hold off;

%Number of dead nodes
dead=0;
%Number of dead Advanced Nodes
dead_a=0;
%Number of dead Normal Nodes
dead_n=0;

%counter for bit transmitted to Bases Station and to Cluster Heads
packets_TO_BS=0;
packets_TO_CH=0;
%counter for bit transmitted to Bases Station and to Cluster Heads 
%per round
PACKETS_TO_CH(r+1)=0;
PACKETS_TO_BS(r+1)=0;

figure(1);

for i=1:1:n
    %checking if there is a dead node
    if (S(i).E<=0)
       % plot(S(i).xd,S(i).yd,'red .');
        dead=dead+1;
     end
    if S(i).E>0
        S(i).type='N';
     
    end
end
%plot(S(n+1).xd,S(n+1).yd,'x');
if (dead == n)%節點全部死亡退出循環
   break;
end

STATISTICS(r+1).DEAD=dead;
DEAD(r+1)=dead;
DEAD_N(r+1)=dead_n;
DEAD_A(r+1)=dead_a;

%When the first node dies
if (dead==1)
    if(flag_first_dead==0)
        first_dead=r
        flag_first_dead=1;
    end
end


countCHs=0;
cluster=1;
for i=1:1:n
   if(S(i).E>0)
     temp_rand=rand;     
     if ( (S(i).G)<=0) %如果該節點在候選集合中
        %Election of Cluster Heads
        if( temp_rand <= (p/(1-p*mod(r,round(1/p)))))
            countCHs = countCHs+1;
            
            S(i).type = 'C';
            S(i).G = round(1/p)-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 );%到sink的距離
            C(cluster).distance = distance;
            C(cluster).id = i;
            X(cluster)=S(i).xd;
            Y(cluster)=S(i).yd;
            cluster=cluster+1;
            %%廣播自成為簇頭
            distanceBroad = sqrt(xm*xm+ym*ym);
            if (distanceBroad > do)
                S(i).E = S(i).E- ( ETX * ctrPacketLength + Emp* ctrPacketLength*( distanceBroad*distanceBroad*distanceBroad*distanceBroad ));%廣播自成為簇頭
            else
                S(i).E = S(i).E- ( ETX * ctrPacketLength + Efs * ctrPacketLength*( distanceBroad*distanceBroad)); 
            end
            %Calculation of Energy dissipated 簇頭自己發送數據包能量消耗
            distance;
            if (distance > do)
                 S(i).E = S(i).E- ( (ETX+EDA)*(packetLength) + Emp * packetLength*( distance*distance*distance*distance ));
            else
                 S(i).E = S(i).E- ( (ETX+EDA)*(packetLength) + Efs * packetLength*( distance * distance )); 
            end
            packets_TO_BS = packets_TO_BS+1;
            PACKETS_TO_BS(r+1) = packets_TO_BS;
        end     
    
     end
   end 
end

STATISTICS(r+1).CLUSTERHEADS = cluster-1;%統計第r輪簇頭數目,r是從0開始的,所以加1;cluster最后要-1,是應為上面的循環多加了1
CLUSTERHS(r+1)= cluster-1;

%Election of Associated Cluster Head for Normal Nodes
for i=1:1:n
   if ( S(i).type=='N' && S(i).E>0 ) %普通節點
    % min_dis = sqrt( (S(i).xd-S(n+1).xd)^2 + (S(i).yd-S(n+1).yd)^2 );%默認距離是到sink的距離
     min_dis = INFINITY; 
     if(cluster -1 >= 1)%如果有簇頭存在
         min_dis_cluster = 1;
         %加入最近的簇頭
         for c = 1:1:cluster - 1 %簇頭數量一共是cluster - 1
            %temp = min(min_dis,sqrt( (S(i).xd - C(c).xd)^2 + (S(i).yd - C(c).yd)^2 ) );
            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
            %接收簇頭發來的廣播的消耗
            S(i).E = S(i).E - ETX * ctrPacketLength; 
         end
       
         %Energy dissipated by associated Cluster Head普通節點發送數據包到簇頭消耗,和加入消息
         min_dis;
         if (min_dis > do)
             S(i).E = S(i).E - ( ETX*(ctrPacketLength) + Emp * ctrPacketLength*( min_dis * min_dis * min_dis * min_dis)); %向簇頭發送加入控制消息
             S(i).E = S(i).E - ( ETX*(packetLength) + Emp*packetLength*( min_dis * min_dis * min_dis * min_dis)); %向簇頭數據包
         else
            S(i).E = S(i).E - ( ETX*(ctrPacketLength) + Efs*ctrPacketLength*( min_dis * min_dis)); %向簇頭發送加入控制消息
            S(i).E = S(i).E - ( ETX*(packetLength) + Efs*packetLength*( min_dis * min_dis)); %向簇頭數據包
         end
         S(i).E = S(i).E - ETX*(ctrPacketLength); %接收簇頭確認加入控制消息
             
         %Energy dissipated %簇頭接收簇成員數據包消耗能量,接收加入消息和和確認加入消息
         if(min_dis > 0)
            S(C(min_dis_cluster).id).E = S(C(min_dis_cluster).id).E - ( (ERX + EDA)*packetLength ); %接受簇成員發來的數據包
            S(C(min_dis_cluster).id).E = S(C(min_dis_cluster).id).E - ERX *ctrPacketLength ; %接收加入消息
            if (min_dis > do)%簇頭向簇成員發送確認加入的消息
                S(C(min_dis_cluster).id).E = S(C(min_dis_cluster).id).E - ( ETX*(ctrPacketLength) + Emp * ctrPacketLength*( min_dis * min_dis * min_dis * min_dis));
            else
                S(C(min_dis_cluster).id).E = S(C(min_dis_cluster).id).E - ( ETX*(ctrPacketLength) + Efs * ctrPacketLength*( min_dis * min_dis));
            end
           PACKETS_TO_CH(r+1) = n - dead - cluster + 1; %所有的非死亡的普通節點都發送數據包
         end
       
         S(i).min_dis = min_dis;
         S(i).min_dis_cluster = min_dis_cluster;
     
     end
end
end
%hold on;

countCHs;
rcountCHs = rcountCHs + countCHs;



%Code for Voronoi Cells
%Unfortynately if there is a small
%number of cells, Matlab's voronoi
%procedure has some problems

%[vx,vy]=voronoi(X,Y);
%plot(X,Y,'r*',vx,vy,'b-');
% hold on;
% voronoi(X,Y);
% axis([0 xm 0 ym]);

end

x=1:1:r;
y=1:1:r;
z=1:1:r;

for i=1:r;
    x(i)=i;
    y(i) = n - STATISTICS(i).DEAD;
    z(i)=CLUSTERHS(i);
end
%plot(x,y,'r',x,z,'b');
plot(x,y,'r');

hold on;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%   STATISTICS    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%                                                                                     %
% DEAD : a rmax x 1 array of number of dead nodes/round 
% DEAD_A : a rmax x 1 array of number of dead Advanced nodes/round
% DEAD_N : a rmax x 1 array of number of dead Normal nodes/round
% CLUSTERHS : a rmax x 1 array of number of Cluster Heads/round
% PACKETS_TO_BS : a rmax x 1 array of number packets send to Base Station/round
% PACKETS_TO_CH : a rmax x 1 array of number of packets send to ClusterHeads/round
% first_dead: the round where the first node died         
% http://hi.baidu.com/benjevons/blog/item/b06533dfe0fc6b106327983a.html

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费人成在线不卡| 麻豆精品视频在线观看视频| 亚洲人成网站精品片在线观看| 亚洲手机成人高清视频| 日韩欧美你懂的| 国产精品国产三级国产普通话99 | 亚洲成在线观看| 久久狠狠亚洲综合| 色综合色狠狠综合色| 在线成人av网站| 国产精品三级电影| 欧美国产日韩在线观看| 国产精品福利一区| 青青草原综合久久大伊人精品 | 国产suv精品一区二区6| 色婷婷av久久久久久久| 2019国产精品| 亚洲国产精品久久久男人的天堂| 日韩国产在线观看| 99re在线视频这里只有精品| 日韩丝袜情趣美女图片| 亚洲激情综合网| 日本成人在线看| 成人妖精视频yjsp地址| 3d成人h动漫网站入口| 国产精品久久久久9999吃药| 免费成人av资源网| 91精品1区2区| 久久伊人中文字幕| 毛片av一区二区| 在线视频一区二区三| 国产清纯白嫩初高生在线观看91 | 欧美一二三区在线观看| 日韩一区日韩二区| 国产精品综合一区二区三区| 7777精品伊人久久久大香线蕉经典版下载 | 欧美国产一区视频在线观看| 首页亚洲欧美制服丝腿| 97久久精品人人做人人爽50路| 欧美成人官网二区| 偷窥国产亚洲免费视频| 色噜噜狠狠色综合欧洲selulu| 91精品国产91久久久久久一区二区 | 蜜桃一区二区三区在线观看| 欧洲视频一区二区| 国产精品国产三级国产aⅴ原创| 激情综合色播五月| 欧美一级精品大片| 日本v片在线高清不卡在线观看| 欧美日韩午夜精品| 亚洲国产人成综合网站| 欧美色欧美亚洲另类二区| 亚洲自拍偷拍网站| 欧美天堂一区二区三区| 亚洲一区二区三区免费视频| 在线视频一区二区三区| 亚洲高清免费视频| 欧美高清激情brazzers| 一区二区三区精品在线观看| 在线中文字幕不卡| 亚洲一区二区免费视频| 日韩av二区在线播放| 国产精品久久免费看| 成人福利在线看| 中文字幕一区二区三区四区不卡| 成人午夜精品在线| 久久亚洲综合色| 成人免费福利片| 亚洲欧洲成人自拍| 欧美怡红院视频| 久久疯狂做爰流白浆xx| 欧美xxx久久| 国产91精品欧美| 亚洲欧美日韩人成在线播放| 欧美无乱码久久久免费午夜一区| 日韩电影免费一区| 久久精品男人天堂av| 国产精品1区2区3区| 国产精品第四页| 欧美三级日韩在线| 国产盗摄视频一区二区三区| 亚洲欧洲国产日本综合| 欧美日韩高清影院| 国产美女娇喘av呻吟久久| 亚洲欧洲精品一区二区三区不卡 | 久久综合久久综合亚洲| 成人动漫一区二区| 五月激情丁香一区二区三区| 久久综合九色综合欧美98| 99精品一区二区| 日本午夜一本久久久综合| 国产区在线观看成人精品| 欧美自拍丝袜亚洲| 久久99精品国产91久久来源| 国产婷婷色一区二区三区在线| 91丨九色丨蝌蚪富婆spa| 美女性感视频久久| 亚洲乱码日产精品bd| 精品日韩99亚洲| 在线观看亚洲精品| 国产精品一区不卡| 亚洲一区二区在线观看视频 | 亚洲综合激情另类小说区| 日韩视频123| 成人精品小蝌蚪| 男女男精品视频网| 亚洲男人都懂的| 26uuu精品一区二区三区四区在线| 色哟哟一区二区| 国产在线观看一区二区| 亚洲超碰97人人做人人爱| 中文字幕精品—区二区四季| 欧美va亚洲va在线观看蝴蝶网| 欧美午夜精品一区二区三区 | 欧美精品一二三区| 国产乱理伦片在线观看夜一区| 香蕉成人啪国产精品视频综合网| 中文一区在线播放| 26uuu欧美| 欧美成人在线直播| 欧美妇女性影城| 在线精品视频免费播放| 成人免费不卡视频| 粉嫩久久99精品久久久久久夜| 亚洲不卡一区二区三区| 一区二区三区在线免费观看| 国产精品传媒视频| √…a在线天堂一区| 国产午夜亚洲精品理论片色戒| 91麻豆成人久久精品二区三区| 国产成人av一区二区三区在线观看| 国产精品自拍毛片| 国产一区二区不卡在线| 国内精品自线一区二区三区视频| 亚洲3atv精品一区二区三区| 国产乱人伦偷精品视频不卡 | 中文字幕av一区二区三区| 欧美mv日韩mv国产网站app| 色菇凉天天综合网| 91国产视频在线观看| 91麻豆产精品久久久久久| 在线影视一区二区三区| 欧美日韩夫妻久久| 欧美精品一区二区在线播放| 欧美国产丝袜视频| 亚洲大型综合色站| 国内精品视频一区二区三区八戒| 成人app软件下载大全免费| 欧美色手机在线观看| 久久久亚洲欧洲日产国码αv| 亚洲特级片在线| 麻豆视频一区二区| 91美女在线视频| 日韩欧美中文字幕制服| 亚洲男女一区二区三区| 日本强好片久久久久久aaa| 国产精品一区免费视频| 欧日韩精品视频| 国产网站一区二区| 日韩电影在线免费观看| 波多野结衣中文字幕一区二区三区| 日本电影欧美片| 久久久久久久综合日本| 五月婷婷综合在线| www.欧美色图| 欧美本精品男人aⅴ天堂| 亚洲综合激情另类小说区| 国产成人av在线影院| 日韩一区二区电影网| 亚洲精品高清视频在线观看| 九九视频精品免费| 在线一区二区三区四区| 国产精品午夜免费| 另类的小说在线视频另类成人小视频在线 | 国产a级毛片一区| 久久久久成人黄色影片| 岛国精品在线观看| 91精品国产日韩91久久久久久| 亚洲欧美综合另类在线卡通| 成人性色生活片免费看爆迷你毛片| av中文字幕在线不卡| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 日本不卡在线视频| 欧美性猛片xxxx免费看久爱| 国产精品色婷婷久久58| 国产精品一区二区免费不卡| 欧美一区二区三区免费| 亚洲大片精品永久免费| 欧洲人成人精品| 亚洲欧美激情视频在线观看一区二区三区 | 国产精品综合一区二区| 91精品国产麻豆国产自产在线| 一区二区国产视频| 色呦呦网站一区| 亚洲天堂精品视频| 日本福利一区二区| 一区二区三区四区蜜桃 | 亚洲色图在线播放| 99久久综合99久久综合网站| 国产精品久久久一本精品|