掃描二維碼
隨時(shí)隨地手機(jī)看文章
引言
路徑選擇問(wèn)題是解決車(chē)載導(dǎo)航系統(tǒng)中的核心問(wèn)題,歸根結(jié)底是最短路徑問(wèn)題?,F(xiàn)有的最短路徑算法有很多,如迪杰斯特拉(Dijkstra)、弗洛伊德(Floyd)及其改進(jìn)算法、盲目捜索法,啟發(fā)式A*算法、人工神經(jīng)網(wǎng)絡(luò)、遺傳算法、蟻群算法等[%而這其中又是以迪杰斯特拉及其改進(jìn)算法最經(jīng)典,是研究得最多的一種算法,并取得了一定的成果,然而,對(duì)這些成果進(jìn)行分析發(fā)現(xiàn),研究的這些算法都是靜態(tài)的,以圖論為基礎(chǔ)的方法,并沒(méi)有考慮到障礙物的影響。因此,本文主要對(duì)有障礙物影響的情況下的最短路徑算法進(jìn)行研究,并利用MapX控件實(shí)現(xiàn)了最短路徑的算法,在車(chē)載導(dǎo)航中取得了較好的應(yīng)用。
1Dikjsrta算法存在的問(wèn)題
Dikjsrta算法是由荷蘭數(shù)學(xué)家E.W.Dikjsrta于1959年提出單源最短路算法,是目前求解最短路問(wèn)題的理論上最完備、應(yīng)用最廣的經(jīng)典算法,它可完成從指定圖中所有其他節(jié)點(diǎn)的最短路徑,它是主要路徑長(zhǎng)度遞增產(chǎn)生最短路徑算法,此算法在諸多教材中均有闡述。從所介紹的算法不難看出存在兩點(diǎn)不足:①只考慮靜態(tài)的最短路徑,沒(méi)有及時(shí)反映出存在障礙物(如交通阻塞、修路等情況)下的最短路徑;②圖的存儲(chǔ)結(jié)構(gòu)中存在著大量的8,浪費(fèi)了大量的存儲(chǔ)空間。因此本文從以上兩個(gè)方面加以改進(jìn)。
2Dikjsrta算法的改進(jìn)
2.1有障礙物存在時(shí)的改進(jìn)Dikjsrta算法
通過(guò)對(duì)各類(lèi)公交流量的分析和研究,可將城市道路障礙物分為阻塞和繁忙兩種狀態(tài),如修路行不通為阻塞狀態(tài)、上下班堵車(chē)為繁忙狀態(tài),在這兩種狀態(tài)情況下,必須另錄一條最短路徑以獲得時(shí)間最短。將障礙物反映到圖上,則存在兩種情況:一是正好在相應(yīng)節(jié)點(diǎn)上(如圖1節(jié)點(diǎn)2上),貝嶼其相連的節(jié)點(diǎn)上各邊權(quán)值變?yōu)?;二是在相應(yīng)的某一條邊上(如節(jié)點(diǎn)1-3)之間,貝懼相鄰接的鄰接矩陣變?yōu)?。其改進(jìn)算法如下:
建立鄰接矩陣A[v,][vJ]?若v障礙物正好處于圖的節(jié)點(diǎn),則此節(jié)點(diǎn)是車(chē)載不允許經(jīng)過(guò)的節(jié)點(diǎn),A[:][Vj]=8,亦矩陣中V所在的列的元素均取8。若障礙物正好位于兩節(jié)點(diǎn)之前,即此段路程不通必須加以回避,設(shè)e,j=(v?Vj)為必須回避的邊,則A[v;][vj]=8。
初始化。S={vs)(vseV),dist[vi]=A[vs][vi],path[Vj]={vs},vieV,i=1,2,…,n。
選擇Vk,使得dist[Vk]=min(dist[v』VieV-S),S=SU{Vk}。Vk為目前求得的下一條從Vs出發(fā)的最短路徑的終點(diǎn)。如果Vk夭Vt,轉(zhuǎn)向(4),否則結(jié)束,dist[Vt]即為回避的點(diǎn)、邊、路徑障礙下從Vs到頂點(diǎn)vt的最短路徑。
修改從v出發(fā)到集合V-S任一頂點(diǎn)Vi的最短路徑長(zhǎng)度。設(shè)V為路徑path[Vk]倒數(shù)第二個(gè)節(jié)點(diǎn)。若dist[Vk]+A[Vk][Vi]<dist[Vi],則dist[i]=dist[Vk]+A[Vk][Vi],path[Vi]=path[Vk]U{財(cái),轉(zhuǎn)向(3)。
圖1所示是一種有路障的加權(quán)圖G',圖1中,假設(shè)節(jié)點(diǎn)2號(hào)有路障,另外1-3號(hào)節(jié)點(diǎn)的路段正在修路不能通行,其存儲(chǔ)的鄰接矩陣如圖2所示。
圖2圖G'的鄰接矩陣
2.2存儲(chǔ)結(jié)構(gòu)的改進(jìn)
無(wú)論是有無(wú)障礙物的Dikjsrta算法,采用矩陣來(lái)存儲(chǔ)點(diǎn)與點(diǎn)間的拓?fù)潢P(guān)系,行數(shù)和列數(shù)相同,矩陣中i行J列的值對(duì)應(yīng)著點(diǎn)i和點(diǎn)J之間的權(quán)值,起點(diǎn)和終點(diǎn)為同一點(diǎn)時(shí)權(quán)值用0表示,兩點(diǎn)之間沒(méi)有直接通路時(shí)權(quán)值用8表示。矩陣中含有大量的0和8,增加了無(wú)效循環(huán)次數(shù),在存儲(chǔ)上也占用了大量的空間,浪費(fèi)了大量的空間。為提高內(nèi)存的利用率,本文采用的鄰接表存儲(chǔ)如圖3所示。
用鏈表數(shù)組MGrpah表示存儲(chǔ)矩陣G時(shí),可將其每一行用一個(gè)單鏈表來(lái)表示,鏈表中只有非8元素,每個(gè)節(jié)點(diǎn)有兩個(gè)元素,一個(gè)為所在的列值,一為點(diǎn)的權(quán)值。其偽代碼如下:
Typedfstruct
{Intr,v;
Mnode*next;
}Mnode;
ClassMGraph{
Public:
Mnode*first,*current;
Mgraph(){current=null;first=current;}
Voidsetfirst(Mnode*p){first=p;current=first;}
Mnode*GotoFirst(){if(first){current=first;returncurrent;}
Elsereturnnull;}
VoidAdd(Mnode*p){current->next=p;current=p;}
Mnode*Next(){if(current->next){current=current->next;returncurrent;}
ElsereturnNULL;}
}
然后可用一維數(shù)組D來(lái)存儲(chǔ)各頂點(diǎn)到源點(diǎn)的最短距離,并用一維數(shù)組P來(lái)存儲(chǔ)前驅(qū)點(diǎn),再用一個(gè)輔助雙向鏈表來(lái)存儲(chǔ)正在參與比較的節(jié)點(diǎn)(使用雙向鏈表的目的是在刪除節(jié)點(diǎn)時(shí)降低時(shí)間復(fù)雜度)。其代碼如下:
Typedefstruct{intr;Node*next,*prev;}chinaNode;
Classpath{
public:
chainNode*first,*current;
intn;
path(){n=0;current=null;first=null;}
voidsetfirst(chainnode*p){first=p;current=first;n=1;}
voidAddTail(chainNode*p){current->next=p;p->prev=current;current=p;n++}
intdelete(chainNode*p);
chainNode*Next(){if(current->next){current=current->next;
returncurrent;}elsereturnnull;}
boolIsEmpty(){returnn==0;}
}
2.3改進(jìn)算法的實(shí)現(xiàn)步驟
改進(jìn)算法的實(shí)現(xiàn)步驟如下:
將與V。直接相連的節(jié)點(diǎn)的D[vJ初始化為其權(quán)值,其余的置為機(jī)器所允許的最大值。
將與V。直接相連的頂點(diǎn)加入到鏈表Path中。
在Path中找到權(quán)值最小的節(jié)點(diǎn)w,并在Path中刪除此頂點(diǎn),如果剩余節(jié)點(diǎn)數(shù)為。則結(jié)束。
修改最短路徑:在G里與w直接相連的其余各節(jié)點(diǎn)Vj的權(quán)值中比較D[Vj]與D[w]+s(w,vD的大小,如果D[vJ小于D[w]+s(w,Vj),并且如果D[Vj]為8,則將Vj加入到Path中,然后將P[vJ的前驅(qū)設(shè)置為w,并修改最短路徑D[vJ=D[w]+s(w,V)。重復(fù)步驟(4)。
根據(jù)以上思路,利用MapX控件,結(jié)合可視化編程語(yǔ)言,對(duì)武漢市地圖矢量化,去除多余的結(jié)點(diǎn),構(gòu)建拓?fù)潢P(guān)系,結(jié)合改進(jìn)的算法,進(jìn)行編程,其實(shí)現(xiàn)的界面如圖4所示。
3結(jié)語(yǔ)
本文在研究現(xiàn)有的Dikjsrta算法的基礎(chǔ)上,討論了有障礙物存在的Dikjsrta的算法,并對(duì)其存儲(chǔ)結(jié)構(gòu)進(jìn)行了一點(diǎn)小的改進(jìn),給出了具體的實(shí)現(xiàn)過(guò)程,提高了存儲(chǔ)效率。存在的不足是沒(méi)有對(duì)時(shí)間與空間復(fù)雜度進(jìn)行量化,另外,對(duì)其搜索方法
也沒(méi)有加以改進(jìn),這將是下一步努力改進(jìn)的方向。
圖4障礙特存在的最短路徑展示圖
20211116_6193be3cc09ae__障礙物存在的最短路徑算法及其在車(chē)載導(dǎo)航中的應(yīng)用
摘要:無(wú)線傳感器網(wǎng)絡(luò)作為一種新興的信息獲取技術(shù),是當(dāng)前的研究熱點(diǎn)。由于無(wú)線傳感器網(wǎng)絡(luò)節(jié)點(diǎn)能量有限,因此對(duì)其路由協(xié)議的研究成為重中之重。對(duì)近年來(lái)無(wú)線傳感器網(wǎng)絡(luò)路由協(xié)議進(jìn)行歸納和分析,并基于分層路由協(xié)議提出一種均衡能量消耗的...
關(guān)鍵字: 無(wú)線傳感器網(wǎng)絡(luò) 路由協(xié)議 改進(jìn)算法 能量消耗摘要:RFID技術(shù)中的防碰撞算法分為閱讀器的防碰撞以及標(biāo)簽的防碰撞兩種。文章通過(guò)對(duì)RFID中各種主流防碰撞方法的思想、實(shí)現(xiàn)及算法的研究,在現(xiàn)有的二進(jìn)制搜索算法的基礎(chǔ)之上,提出了一種改進(jìn)算法,并對(duì)改進(jìn)算法的實(shí)現(xiàn)進(jìn)行了Mat...
關(guān)鍵字: RFID 防碰撞 二進(jìn)制搜索算法 改進(jìn)算法摘要:在基于Android系統(tǒng)的導(dǎo)航出現(xiàn)之前,智能導(dǎo)航系統(tǒng)更多是基于WinCE系統(tǒng)。但是,WinCE的軟件開(kāi)發(fā)需要繳納一定的授權(quán)費(fèi)用,這使得WinCE系統(tǒng)的可擴(kuò)展性受到了極大限制,在Andr
關(guān)鍵字: 3g Android 汽車(chē)電子 車(chē)載導(dǎo)航 wince系統(tǒng)中國(guó)LED產(chǎn)業(yè)起步于20世紀(jì)70年代。經(jīng)過(guò)30多年的發(fā)展,中國(guó)LED產(chǎn)業(yè)已初步形成了包括LED外延片的生產(chǎn)、LED芯片的制備、LED芯片的封裝以及LED成品應(yīng)用在內(nèi)的較為完整的產(chǎn)業(yè)鏈。
關(guān)鍵字: 車(chē)載導(dǎo)航 云計(jì)算 導(dǎo)航系統(tǒng)目前國(guó)內(nèi)車(chē)載導(dǎo)航市場(chǎng)可謂琳瑯滿目、種類(lèi)繁多,我們將通過(guò)介紹幾款融合了稀奇功能的個(gè)性車(chē)機(jī),來(lái)與大家分享一下目前車(chē)機(jī)的新鮮功能,同時(shí)為用戶在選購(gòu)個(gè)性車(chē)機(jī)產(chǎn)品的時(shí)候提供一些合理性的建議。
關(guān)鍵字: 車(chē)載導(dǎo)航 車(chē)載gps汽車(chē)電子GPS導(dǎo)航儀同質(zhì)化比較嚴(yán)重,最好在購(gòu)買(mǎi)之前,多比較幾家品牌,看看功能是否適用,同時(shí)盡量選擇市場(chǎng)上口碑較好的知名品牌,并到正規(guī)網(wǎng)站購(gòu)買(mǎi),以獲得良好的售后服務(wù)保障,避免一些商家&ldqu
關(guān)鍵字: 車(chē)載導(dǎo)航 gps導(dǎo)航儀一.問(wèn):如何進(jìn)行衛(wèi)星定位? 1、在室內(nèi)是無(wú)法定位的,確保您在室外比較空曠的地方 2、打開(kāi)GPS導(dǎo)航——工具——GPS測(cè)
關(guān)鍵字: 車(chē)載導(dǎo)航 gps導(dǎo)航儀大部分車(chē)主都選擇外去度假,娛樂(lè)旅游,GPS導(dǎo)航儀為有車(chē)主,帶來(lái)了方便,讓路暢游無(wú)阻。此段節(jié)假日過(guò)后,車(chē)主們更多的期盼是春節(jié)到來(lái),這又是一次自駕游的好機(jī)會(huì)。因此為五一的到來(lái),GPS導(dǎo)航儀將成為
關(guān)鍵字: 車(chē)載導(dǎo)航 gps導(dǎo)航儀GPS導(dǎo)航是現(xiàn)在車(chē)載必需品!準(zhǔn)確來(lái)說(shuō)GPS導(dǎo)航儀就是能夠幫助用戶準(zhǔn)確定位當(dāng)前位置,并且根據(jù)既定的目的地計(jì)算行程,通過(guò)地圖顯示和語(yǔ)音提示兩種方式引導(dǎo)用戶行至目的地的汽車(chē)駕駛輔助設(shè)備。
關(guān)鍵字: 車(chē)載導(dǎo)航 gps導(dǎo)航儀