資源簡介
移動自組網aodv和dsr協議的matlab實現,寫了幾個主要函數,可以參考參考!

代碼片段和文件信息
?
function?[r_path?r_cost]?=?dijkstra(pathS?pathE?transmat)?
%?The?Dijkstra‘s?algorithm?Implemented?by?Yi?Wang?2005?
%?This?version?support?detecting?_cyclic-paths_?
%?
%?USAGE:?
%??[path?cost]=?dijkstra(pathStart?pathEnd??transMatrix)?
%?
%?PARAMETERS:?
%???pathS?:?the?index?of?start?node?indexing?from?1?
%???pathE?:?the?index?of?end?node?indexing?from?1?
%?transmat:?the?transition?matrix?or?adjacent?matrix?
%?
??
%?Ensure?the?transition?matrix?is?square?
%?
%if?(?size(transmat1)?~=?size(transmat2)?)?
%??error(?‘detect_cycles:Dijkstra_SC‘?...?
%????‘transmat?has?different?width?and?heights‘?);?
%end?
??
%?Initialization:?
%??noOfNode?????:?nodes?in?the?graph?
%??parent(i)????:?record?the?parent?of?node?i?
%??distance(i)??:?the?shortest?distance?from?i?to?pathS?
%??queue????????:?for?width-first?traveling?of?the?graph?
noOfNode?=?size(transmat?1);?
for?i?=?1:noOfNode?
??parent(i)?=?0;?
??distance(i)?=?inf;?
end?
??
queue?=?[];?
??
??
%?Start?from?pathS?
??
for?i=1:noOfNode?
?????
??if?transmat(pathS?i)~=inf??
????distance(i)?=?transmat(pathS?i);?
????parent(i)???=?pathS;?
????queue???????=?[queue?i];?
????
??end?
end?
%?Width-first?exploring?the?whole?graph?
??
while?length(queue)?~=?0?
???
??hopS??=?queue(1);?
??queue?=?queue(2:end);?
???
??for?hopE?=?1:noOfNode?
??????if?distance(hopE)?>?(distance(hopS)?+?transmat(hopShopE))?
??????distance(hopE)?=?distance(hopS)?+?transmat(hopShopE);?
??????parent(hopE)???=?hopS;?
??????queue??????????=?[queue?hopE];?
??????
????end?
??end?
??
end?
distance?
parent?
%?Back-trace?the?shortest-path?
r_path?=?[pathE];?????
i?=?parent(pathE);?
??
while?i~=pathS?&&?i~=0?
??r_path?=?[i?r_path];?
??i??????=?parent(i)?
end?
??
if?i==pathS?
??r_path?=?[i?r_path];?
else?
??r_path?=?[];?
end?
??
%?Return?cost?
??
r_cost?=?distance(pathE);?
?屬性????????????大小?????日期????時間???名稱
-----------?---------??----------?-----??----
?????文件???????1910??2003-07-14?21:08??TDSR.m
?????文件???????1896??2003-07-14?21:09??dijkstra.m
?????文件???????2212??2003-07-14?21:04??hopbyhop.m
?????文件???????1861??2003-07-14?21:11??TAODV.m
-----------?---------??----------?-----??----
?????????????????7879????????????????????4
評論
共有 條評論