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

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

?? 誤差.txt

?? 無線傳感器網絡路由算法
?? TXT
字號:
%% 按照場地均勻安排錨節點
%考慮測距誤差為正負10%
%clear
%初始化節點及存放定位信息矩陣

a7=5;
for a8=1:a7










node_num=220+50*(a8-1);%一般節點數量
%錨節點數量大約為一般節點數量的10%,依場地情況而定
length=100;%場地長度
width=100;%場地寬度
rangemax=15;%節點間最大通信距離
[node_x,node_y]=creatnode(node_num,length,width);%返回節點的橫縱坐標
%開始生成錨節點位置,25個錨節點均勻分布
%anchor_length=sqrt(length*width*10/100);
%anchor_no=1;
%for temp_width=1:(1+width/(anchor_length-7))
%    for temp_length=1:(1+length/(anchor_length-7))
%        anchor_x(anchor_no)=(anchor_length-7)*(temp_length-1);
%        anchor_y(anchor_no)=(anchor_length-7)*(temp_width-1);
%        anchor_no=anchor_no+1;
%    end
%end
%anchor_num=anchor_no-1;%最后得到的錨節點數量
%開始生成錨節點位置,20個錨節點均勻分布
anchor_length=sqrt(length*width*10/100);
anchor_no=1;
for temp_width=1:(1+width/(anchor_length-7))
   for temp_length=1:(1+length/anchor_length)
        anchor_x(anchor_no)=anchor_length*(temp_length-1);
        anchor_y(anchor_no)=(anchor_length-7)*(temp_width-1);
       anchor_no=anchor_no+1;
    end
end
%anchor_num=40;
%[anchor_x,anchor_y]=creatnode(anchor_num,length,width);
anchor_num=anchor_no-1;%最后得到的錨節點數量
% 生成存放定位信息的矩陣
%縱坐標為到第一個錨節點的跳數,到第一個錨節點的距離和,到第二個錨節點的跳數……
%橫坐標為所需定位節點的序號,這個序號與最初生成的node序號是一致的
locateinf=ones(2*anchor_num,node_num)*inf;

ok='程序初始化'

%% 察看初始節點狀況
%plot(anchor_x,anchor_y,'*',node_x,node_y,'o');

%% 程序開始
%對圖進行廣度先遍歷
abcanchor=0;
abcnode=0;
for anchor_no=1:anchor_num
    %初始化隊列
    abcanchor=abcanchor+1
    queue=zeros(1,node_num);
    front=1;
    rear=1;
    %
	for node_no=1:node_num
        %abcnode=abcnode+1
        distance=dist(anchor_x(anchor_no),anchor_y(anchor_no),node_x(node_no),node_y(node_no));
        if distance<=rangemax%用此語句判斷是否在通信可達到距離范圍內
            locateinf(2*(anchor_no-1)+1,node_no)=1; 
            %跳數  里面的兩個元素是矩陣的位置坐標
            locateinf(2*anchor_no,node_no)=distance; %距離和
            %將該點加入隊列
            queue(1,rear)=node_no;%存放
            rear=rear+1;
%上面的這一塊描述的是現實狀態下,第一跳節點的錄入情況,dist的過程是flooding,后又聚集到錨 節點信息的過程
        end
        while(front<rear)
%從隊列中取出元素,該點為known 應該理解為,所有錨節點中每一個周圍相對的第一跳節點 哈哈
            known=queue(1,front);
            front=front+1;
            %
            for node_no=1:node_num
                distance=dist(node_x(known),node_y(known),node_x(node_no),node_y(node_no));
                %試圖進行第二跳范圍內的搜捕
                if distance<=rangemax
                    if locateinf(2*(anchor_no-1)+1,node_no)>(locateinf(2*(anchor_no-1)+1,known)+1)
                        %跳數比較 奇數行比較 與路由表的概念一致 最終達到所有的點都找到離錨節點最近的跳數
                        locateinf(2*(anchor_no-1)+1,node_no)=(locateinf(2*(anchor_no-1)+1,known)+1);
                        %選跳數少的錄入
                        
                  % if   locateinf(2*anchor_no,node_no)>locateinf(2*anchor_no,known)+distance;%增加采用距離和較短的算法
                        locateinf(2*anchor_no,node_no)=locateinf(2*anchor_no,known)+distance;
                       
                        %將該點加入隊列
                        queue(1,rear)=node_no;
                        rear=rear+1;
                        %
                  % end
                   
                   end
                end
            end
        end
    end
end 

ok='完成圖的廣度先遍歷'

% 生成錨節點優先選取矩陣anchorchosen,將距離遠的錨節點序號放在后面,即從好到壞排列
for node_no=1:node_num
    node_no
    for anchor_no=1:anchor_num
        %構造temp矩陣
        temp(anchor_no,1)=anchor_no;
        temp(anchor_no,2)=locateinf((2*anchor_no),node_no);
   %(注意討論的是距離,所以用2*anchor_no)以上,對于每個node,將temp矩陣初始化(注意,node的循環還沒有結束)
    end
    %對temp矩陣進行排序處理
    for ti=1:anchor_num-1
        min=ti;
        for tj=ti+1:anchor_num%(ti+1):anchor_num
            if temp(tj,2)<temp(min,2)
               min=tj;
            end
        end
        if ti~=min%同在第二列,ti行與min行互換
            tempintemp1=temp(ti,1);
            tempintemp2=temp(ti,2);
            temp(ti,1)=temp(min,1);
            temp(ti,2)=temp(min,2);
            temp(min,1)=tempintemp1;
            temp(min,2)=tempintemp2;
        end
    end
    for anchor_no=1:anchor_num
        anchorchosen(anchor_no,node_no)=temp(anchor_no,1);%排好的temp(anchor_no,1)
    end
end

ok='生成錨節點優先選取矩陣'

%% 改進算法,選取跳數少的錨節點進行定位,節點坐標存為(locate_near_x,locate_near_y)
locate_near_x=zeros(1,node_num);
locate_near_y=zeros(1,node_num);
for node_no=1:node_num
    tempflag=0;
    node_no
    for chosen1=1:(anchor_num-2)
        for chosen2=(chosen1+1):(anchor_num-1)
            for chosen3=(chosen2+1):anchor_num
               %[x,y]=barycenter(anchor_x(anchorchosen(chosen1,node_no)),anchor_y(anchorchosen(chosen1,node_no)),locateinf(2*anchorchosen(chosen1,node_no),node_no),anchor_x(anchorchosen(chosen2,node_no)),anchor_y(anchorchosen(chosen2,node_no)),locateinf(2*anchorchosen(chosen2,node_no),node_no),anchor_x(anchorchosen(chosen3,node_no)),anchor_y(anchorchosen(chosen3,node_no)),locateinf(2*anchorchosen(chosen3,node_no),node_no));
                [x,y]=barycenter(anchor_x(anchorchosen(chosen1,node_no)),anchor_y(anchorchosen(chosen1,node_no)),locateinf(2*anchorchosen(chosen1,node_no),node_no),anchor_x(anchorchosen(chosen2,node_no)),anchor_y(anchorchosen(chosen2,node_no)),locateinf(2*anchorchosen(chosen2,node_no),node_no),anchor_x(anchorchosen(chosen3,node_no)),anchor_y(anchorchosen(chosen3,node_no)),locateinf(2*anchorchosen(chosen3,node_no),node_no));
                %求三個圓所相交部分的三個交點坐標所成三角形的重心坐標(barycenter_x,barycenter_y)
               if((isreal(x)==1)&&(isreal(y)==1)) 
                    locate_near_x(node_no)=x;
                    locate_near_y(node_no)=y;
                    tempflag=1;
                end
                if(tempflag==1) break; end
            end
            if(tempflag==1) break; end
        end
        if(tempflag==1) break; end
    end
end

ok='定位完成'

%% 計算誤差
% 距離差
difference_x=abs(locate_near_x-node_x);
difference_y=abs(locate_near_y-node_y);

%% 顯示距離差
%plot(difference_x,difference_y,'+');

% 得出距離差,放在矩陣difference中
for node_no=1:node_num
    difference(node_no)=sqrt((difference_x(node_no))^2+(difference_y(node_no))^2);
end

%% 得到距離差大于值gatevalue的點,將節點序號存于badpoint中,badpoint_no為badpoint的數量
gatevalue=rangemax;
badpoint_no=1;
for node_no=1:node_num
    if difference(node_no)>gatevalue
        badpoint(badpoint_no)=node_no;
        badpoint_no=badpoint_no+1;
    end
end
badpoint_no=badpoint_no-1;

% 繪制node節點位置和計算出的位置,并用線段連接
figure(1)
%plot(anchor_x,anchor_y,'*',node_x,node_y,'o',locate_near_x,locate_near_y,'+');
hold on;
for node_no=1:node_num
    line([node_x(node_no),locate_near_x(node_no)],[node_y(node_no),locate_near_y(node_no)]);
end
hold off;
%plot(anchor_x,anchor_y,'*',node_x,node_y,'*')
%hold on;
%plot(locate_near_x,locate_near_y,'.','MarkerSize',15,'Color','r');
%for node_no=1:node_num
%    line([node_x(node_no),locate_near_x(node_no)],[node_y(node_no),locate_near_y(node_no)]);
%end
%hold off;

%門限值為最大通信距離,顯示距離差大于門限值的節點個數
badpoint_no

%計算連通度,并顯示結果
count=0;
for node_no=1:node_num
    if(isnan(difference(node_no))~=1)
        count=count+1;
    end
end
connectivity=count/node_num;
connectivity

range_error=mean(difference)/rangemax
ok='全部完成'










if(a8==1)
    a5=range_error*100;
    end
if(a8==2)
    a4=range_error*100;
    end
if(a8==3)
    a3=range_error*100;
    end
if(a8==4)
    a2=range_error*100;
    end
if(a8==5)
    a1=range_error*100;
    end
end

plot(200,a5,'*',250,a4,'*',300,a3,'*',350,a2,'*',400,a1,'*');
line([200,250,300,350,400],[a5,a4,a3,a2,a1]);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕一区二区三区色视频| 99久久久无码国产精品| 亚洲另类在线制服丝袜| 久久影视一区二区| 国产精品日韩精品欧美在线| 欧美高清激情brazzers| 欧美日韩www| 欧美性猛片aaaaaaa做受| aaa国产一区| 91麻豆文化传媒在线观看| 高清国产午夜精品久久久久久| 蜜臀精品久久久久久蜜臀| 日韩影院免费视频| 日本免费在线视频不卡一不卡二| 亚洲精品乱码久久久久久久久| 亚洲三级电影全部在线观看高清| 国产视频一区在线播放| 久久伊人中文字幕| 最新久久zyz资源站| 国产精品久久久久久久久久免费看 | 亚洲一区精品在线| 五月天一区二区| 亚洲成人福利片| 婷婷开心激情综合| 黄页网站大全一区二区| 国产精品一区在线| www.av亚洲| 欧美高清视频不卡网| 欧美日韩视频在线第一区| 精品久久久久久久久久久久包黑料 | 日本一区二区成人| 自拍偷自拍亚洲精品播放| 奇米精品一区二区三区在线观看| 亚洲一区二区在线播放相泽| 美女脱光内衣内裤视频久久影院| 久久99精品视频| 成人在线综合网站| 欧美亚日韩国产aⅴ精品中极品| 欧美视频在线一区| 精品电影一区二区三区| 国产精品视频一二| 亚洲高清免费视频| 懂色av一区二区夜夜嗨| 欧美在线一二三| 精品av久久707| 亚洲欧美日韩在线不卡| 男女男精品视频网| 韩国av一区二区三区| 日本大香伊一区二区三区| 日韩一区二区电影| 亚洲无线码一区二区三区| 久久99精品久久久久久| 99国产精品国产精品毛片| 日韩精品一区二区三区在线播放 | 免费成人性网站| 在线观看亚洲专区| 2021中文字幕一区亚洲| 亚洲一级在线观看| 成人av网站在线| 91精品国产欧美一区二区18 | 亚洲一区在线观看免费观看电影高清| 久久不见久久见免费视频1| 91网站最新地址| 欧美一卡2卡3卡4卡| 国产精品初高中害羞小美女文| 国产麻豆精品95视频| 337p亚洲精品色噜噜| 国产精品二三区| 成人av在线资源| 2019国产精品| 国产精品久久久久一区二区三区 | 日韩中文字幕一区二区三区| 91在线小视频| 欧美国产一区二区在线观看| 理论片日本一区| 91精品欧美一区二区三区综合在| 亚洲色图制服诱惑| 一本色道a无线码一区v| 亚洲国产欧美在线| 成人午夜短视频| 久久嫩草精品久久久久| 日韩电影在线观看一区| 日韩精品中文字幕在线一区| 五月天激情小说综合| 欧美日韩在线播放三区四区| 亚洲在线视频网站| 91女厕偷拍女厕偷拍高清| 国产日韩欧美电影| 不卡区在线中文字幕| 国产精品久久夜| 在线观看亚洲一区| 亚洲福利一区二区三区| 欧美日韩精品一区二区天天拍小说 | 国内一区二区在线| 久久综合国产精品| 岛国精品一区二区| 亚洲国产精品ⅴa在线观看| 国产精品性做久久久久久| 自拍偷在线精品自拍偷无码专区| 盗摄精品av一区二区三区| 久久精品欧美一区二区三区不卡| 国产很黄免费观看久久| 日本一区二区高清| 成人性视频免费网站| 亚洲视频一二三区| 在线观看中文字幕不卡| 一区二区三区四区视频精品免费 | 亚洲国产视频在线| 欧美xxxxxxxxx| 国产毛片精品一区| 国产精品欧美久久久久无广告 | 97se亚洲国产综合在线| 亚洲国产综合视频在线观看| 国产亚洲一区二区三区四区 | 一区二区三区四区五区视频在线观看 | 久久国产综合精品| 国产精品欧美极品| 91麻豆精品国产91久久久| 寂寞少妇一区二区三区| 日韩欧美高清dvd碟片| 国产美女久久久久| 成人欧美一区二区三区在线播放| 91美女在线观看| 美国三级日本三级久久99| 亚洲欧美影音先锋| 欧美一级淫片007| 99麻豆久久久国产精品免费| 一区二区成人在线| 久久久不卡网国产精品二区| 欧美丝袜丝交足nylons图片| 极品销魂美女一区二区三区| 国产偷国产偷精品高清尤物| 欧美一区二区视频在线观看2020| 国产露脸91国语对白| 日韩成人午夜精品| 亚洲色图视频网站| 精品久久久久久最新网址| 欧美色综合天天久久综合精品| 韩国中文字幕2020精品| 亚洲影院久久精品| 中文字幕一区二区三区在线播放| 777奇米四色成人影色区| 色女孩综合影院| 国产乱人伦精品一区二区在线观看| 一区二区激情视频| 亚洲另类在线视频| 国产精品视频免费看| 欧美一区二区福利视频| 欧美日韩一区二区不卡| 91精品国产美女浴室洗澡无遮挡| 欧美自拍偷拍一区| 成人永久免费视频| 日韩av电影天堂| 中文字幕综合网| 一本一道久久a久久精品综合蜜臀| 精品在线播放午夜| 日本一区二区久久| 欧美tickling挠脚心丨vk| 91在线视频在线| 成人午夜电影久久影院| 国产一本一道久久香蕉| 国产高清久久久| 国产老妇另类xxxxx| 国产成a人亚洲精品| 韩国毛片一区二区三区| 毛片基地黄久久久久久天堂| 免费观看久久久4p| 美女一区二区三区在线观看| 久久国产精品色| 韩日精品视频一区| 国产一区二区免费在线| 成人av影院在线| 成人综合在线观看| 91激情五月电影| 欧美天堂一区二区三区| 欧美日韩综合不卡| 日韩一区二区免费高清| 欧美大片国产精品| 国产三区在线成人av| 国产精品水嫩水嫩| 亚洲免费观看视频| 久久国产精品第一页| 精品一区二区三区久久久| 不卡的看片网站| 欧美一区二区三区四区在线观看| 成人av午夜影院| 91丝袜美女网| 欧美日韩精品欧美日韩精品一综合| 欧美日韩精品一区二区| 国产亚洲精品中文字幕| 亚洲天堂av一区| 精品一区二区免费在线观看| 国产成人精品www牛牛影视| 久久精品国产亚洲高清剧情介绍 | 欧美浪妇xxxx高跟鞋交| 欧美日韩精品一区视频| 国产精品三级av在线播放| 一区二区免费看| 成人免费视频免费观看| 欧美性色欧美a在线播放|