Académique Documents
Professionnel Documents
Culture Documents
ClusterHeads(i)=1;
Node.c(i)=TOS_LOCAL_ADDRESS;
Node.initclEn(i)=EnNode(i);
else ClusetHeads(i)=0;
Node.initclEn(i)=EnNode(i);
end
end
end
if sum(ClusterHeads)==0
continue;
end
else
if Node.d(i) > dist(j);
Node.d(i)=dist(j) ;
end
end
if Node.d(i)>(Tr.^2+Tr.^2);
if EnNode(i)>EntranPCH;
ClusterHeads(i)=1;
EnNode(i)=EnNode(i)-EntranPCH;
end
end
EnRecP = Elec * Kbit ;
if EnNode(i) >= EnRecP % the energy reciving a
boardcast packet can expend
EnNode(i) = EnNode(i) - EnRecP ;
else
StateNode(i)=0;
end
% end
end
if ClusterHeads(i)~=1;
Node.d(i)=dist(j);
Node.c(i)=j;
else
break;
end
%%%%% end of choosing the cluster head ,Node.c(i) save the id of
%%%%% cluster head
end
if StateNode(i)==1
Node.csize(Node.c(i))= Node.csize(Node.c(i))+1;
end
else % the node is cluster head
Node.d(i)=((Node.x(i)-Bx).^2)+((Node.y(i)-By).^2) ;
Node.c(i)=TOS_LOCAL_ADDRESS;
end
end
end
TolLengthPacket = Kbit.*Node.csize(i);
alldata=alldata+TolLengthPacket;
EntranPCH = Elec * TolLengthPacket+
Eamp*TolLengthPacket*(Node.d(i));
EntranPCH.*TDMA;
if EnNode(i) >= EntranPCH
EnNode(i) = EnNode(i) - EntranPCH ;
else
StateNode(i)=0;
end
else
EntranP = Elec * Node.l(i)+ Eamp*Node.l(i)*(Node.d(i));
EntranP=EntranP.*TDMA;
if EnNode(i) >= EntranP
EnNode(i) = EnNode(j)-EntranP;
else
StateNode(i)=0; % the node dead
end
EnRecP = Elec * Node.l(i) ;
EnRecP=EnRecP.*TDMA;
if EnNode(Node.c(i)) >= EnRecP
EnNode(Node.c(i)) = EnNode(i) - EnRecP ;
else
StateNode(Node.c(i))=0;
end
end
end
end
if Rounds==1
AmountData(Rounds)=alldata;
else
AmountData(Rounds)=alldata+AmountData(Rounds-1);
end
for i=1:NodeNums
if StateNode(i)==0
AliveNode(Rounds)= AliveNode(Rounds)-1;
end
end
% the TDMA Phase
% for RNum=1:TDMA
% for i=1:NodeNums
% if ClusterHeads(i)==1
% % EntranPCH = Elec * Node.l(i)+
Eamp*Node.l(j)*(Eamp*Node.l(j).^2);
% TolLengthPacket = 0;
% for j=1:NodeNums
% if Node.c(j) ==i
% TolLengthPacket =TolLengthPacket+ Node.l(j);
% EntranP = Elec * Node.l(j)+ Eamp*Node.l(j)*(Node.d(j)); % The
require energy of node transmitting a packet
% EnRecP = Elec * Node.l(j) ; % The require energy of recving
a packet
% if EnNode(j) >= EntranP
% EnNode(j) = EnNode(j)-EntranP;
% else
% StateNode(j)=0; % the node dead
% end
% if EnNode(i) >= EnRecP
% EnNode(i) = EnNode(i) - EnRecP ;
% else
% StateNode(i)=0;
% end
% end
% end
% EntranPCH = Elec * TolLengthPacket+
Eamp*TolLengthPacket*(Node.d(j));
% if EnNode(i) >= EntranPCH
% EnNode(i) = EnNode(i) - EntranPCH ;
% else
% StateNode(i)=0;
% end
% end
% end
% end
syms sumch sumno countch countno ;
sumch=0;
sumno=0;
countch=0;
countno=0;
for i=1:NodeNums
if Node.initclEn(i)>0
if ClusterHeads(i)==1
sumch=sumch+Node.initclEn(i);
countch=countch+1;
else
sumno=sumno+ Node.initclEn(i);
countno=countno+1;
end
end
if StateNode(i)==0
AliveNode(Rounds)= AliveNode(Rounds)-1;
end
end
LAECH(Rounds) = sumch/countch;
LAENO(Rounds) = sumno/countno;
% Rounds = Rounds+1
end
xtime= 1:1:MaxInteral;
plot(xtime,AliveNode);
%clear ;
% plot(Node.x,Node.y);
% plot(Node.x,Node.y,'--rs','LineWidth',2,...
% 'MarkerEdgeColor','k',...
% 'MarkerFaceColor','g',...
% 'MarkerSize',10);
% plot(Node.x,Node.y,'k*');
...