基于GPS的新型出租車調(diào)度系統(tǒng)設計
引言
在大多數(shù)國家,出租車都是一種十分普遍和便捷的交通工具。多數(shù)發(fā)達國家建設了完善的出租車調(diào)度系統(tǒng),實現(xiàn)了出租車高效運營,如美國,電話預約和站點候客的出租車運營方式占98%,“路拋式”僅占2%;在倫敦、巴黎、新加坡等發(fā)達國家城市,除非電話預約,或者在指定的??康攸c,否則很少能看到乘客在街頭打車,這大大提高了公共交通資源的運行效率。但是在我國的大多數(shù)城市,仍然以乘客街頭叫車為主,雖然部分城市已經(jīng)實現(xiàn)了出租車安裝GPS設備和實時記錄出租車位置信息,但是并沒有很好地利用這些GPS位置信息為出租車調(diào)度服務,導致很多出租車GPS系統(tǒng)成為擺設。為了進一步提高我國的出租車調(diào)度系統(tǒng)的運行效率和提高GPS系統(tǒng)的實用性,很有必要研究一種結合GPS/GIS技術的快速高效出租車調(diào)度系統(tǒng)。
本文設計和實現(xiàn)了一種新型的出租車調(diào)度系統(tǒng),該系統(tǒng)通過改進當前調(diào)度系統(tǒng)的叫車方式,并提出基于網(wǎng)格的出租車調(diào)度算法,該算法結合通信平臺上傳的出租車GPS位置信息和GIS系統(tǒng)網(wǎng)格信息把出租車分組,實現(xiàn)小組內(nèi)及小組間出租車高效協(xié)作和調(diào)度,很大程度上提高了出租車的調(diào)度效率。
1 系統(tǒng)設計
本系統(tǒng)包括三個部分:出租車調(diào)度終端、通信平臺和調(diào)度中心。調(diào)度終端是基于三星S3C2440硬件平臺和WINCE操作系統(tǒng)的智能嵌入式設備,實現(xiàn)了與調(diào)度平臺的通信和現(xiàn)場智能控制;調(diào)度終端實現(xiàn)GPS數(shù)據(jù)的采集、上報和調(diào)度信息的顯示;通信平臺提供準確、高效的信息傳輸功能;調(diào)度中心實現(xiàn)出租車快速調(diào)度以及基于GIS的車輛實時監(jiān)控功能。
1.1 出租車調(diào)度終端設計
出租車調(diào)度終端在硬件上包括兩部分:基于三星S3C2440的系統(tǒng)板和基于VK3224的設備擴展板。系統(tǒng)板和擴展板之間通過SPI接口進行通信。系統(tǒng)板包括:
S3C2440 ARM9核心處理器、存儲器FLASH、SDRAM、電源管理器件、RS232、I/O口空載標識燈接口及上報乘客信息按鈕等。接口板包括:VK3224、GPS模塊、GPRS模塊和RS232等。此調(diào)度終端在設計上增加了一個出租車司機上報乘客位置的按鈕,其作用是行駛在馬路上的每個出租車司機都可以上報在路上發(fā)現(xiàn)的乘客位置信息,系統(tǒng)收到信息就會調(diào)度最近的空載出租車前來服務。
終端的硬件結構如圖1所示。
出租車調(diào)度終端在軟件設計上采用透明通道提供可靠的數(shù)據(jù)傳輸層。透明通道是通過GPRS上面封裝TCP/IP協(xié)議和服務器進行通信,當主站控制終端上某個串口設備的時候,將主站發(fā)送的數(shù)據(jù)包中加載串口數(shù)據(jù),數(shù)據(jù)包傳輸?shù)搅私K端后,終端將這些串口數(shù)據(jù)直接發(fā)送給對應的串口設備,當串口設備返回數(shù)據(jù)后,系統(tǒng)將這些數(shù)據(jù)加載在TCP/IP數(shù)據(jù)包上,通過GPRS發(fā)送到主站,在主站應用層看來和直接操作串口沒有區(qū)別。調(diào)度終端和服務器之間GPS位置信息上傳,上報乘客信息,調(diào)度指令下發(fā)等都是通過透明通道完成的。調(diào)度終端軟件設計圖如圖2所示。
1.2 通信平臺
為了實現(xiàn)平臺和出租車的通訊以及收集乘客叫車信息,通信平臺包括M2M通信模塊、短信平臺和呼叫中心三個模塊。
?。?)M2M通信模塊實現(xiàn)出租車和調(diào)度中心的通信功能,具體包括:出租車位置上傳、路邊乘客位置上傳、調(diào)度中心指令下發(fā)等。M2M通信模塊使用基于GPRS網(wǎng)絡上的TCP/IP技術,服務器端采用Windows平臺的完成端口(IOCP)技術,從而保證單個服務器能同時接入大量出租車調(diào)度終端(大于5000臺)。完成端口的最大優(yōu)點在于其管理海量連接時的處理效率,通過操作系統(tǒng)內(nèi)核的相關機制完成I/O處理的高效率,由于出租車調(diào)度過程中連接量巨大,且每個連接上收發(fā)的數(shù)據(jù)包比較小,通常只有幾k甚至不到1k的字節(jié),因此很適合使用完成端口技術。
(2)短信平臺和呼叫中心模塊實現(xiàn)乘客和調(diào)度中心之間的通信,主要功能是乘客位置和打車請求收集。短信平臺負責接收短信調(diào)度的短信,再由調(diào)度中心分析短信內(nèi)容,完成短信調(diào)度。呼叫中心負責電話鏈路,話務員和系統(tǒng)根據(jù)來電內(nèi)容使用調(diào)度中心模塊實現(xiàn)電話調(diào)度。
1.3 調(diào)度中心設計 調(diào)度中心分為前臺應用程序和后臺服務程序。 前臺應用軟件采用B/S架構,主要包括:系統(tǒng)管理、注冊管理和調(diào)度管理三個部分, ?。?)系統(tǒng)管理包括:部門管理、用戶管理、角色管理和權限管理等; (2)注冊管理包括:固定電話注冊、手機注冊。固定電話注冊完成固定電話和單個固定叫車位置的關聯(lián)綁定,如酒店、公司等,通過GIS系統(tǒng)記錄該位置的經(jīng)緯度信息;手機短信注冊完成手機號碼和幾個固定叫車位置的綁定,每個綁定有一個標簽短信代替,同時將每個叫車位置在GIS系統(tǒng)中的經(jīng)緯度信息記錄下來。 (3)調(diào)度管理包括:司機互助調(diào)度、話務員調(diào)度、注冊電話調(diào)度、短信調(diào)度等模塊。 后臺服務程序采用C/S架構,將通信平臺所收集到的出租車GPS位置信息和乘客GPS位置信息聯(lián)系起來,通過下節(jié)所講的基于網(wǎng)格的調(diào)度算法完成綜合調(diào)度,調(diào)度平臺和通信平臺是一個密切聯(lián)系的模塊,具體關系如圖3所示。 圖3 調(diào)度系統(tǒng)整體架構(參見右欄) 2 系統(tǒng)關鍵模塊設計 2.1 叫車方式設計 國內(nèi)外現(xiàn)有出租車調(diào)度系統(tǒng)的叫車方式主要分為兩種類型:一是乘客打電話報告自己的位置,調(diào)度員或話務員在GIS地圖上標注乘客位置;二是乘客觸發(fā)TAXI站點應招按鈕叫車。 本系統(tǒng)在原有方式的基礎上增加和改進了叫車方式。 1)在調(diào)度終端上增加一個報告乘客位置按鈕,當出租車滿載期間在路上行駛時如若遇到路邊等車乘客就觸發(fā)此按鈕,實現(xiàn)出租車司機實時上報乘客位置,此方式體現(xiàn)了一種“我為人人,人人為我”的思想,這種互助協(xié)作的搜索,擴大了搜索乘客的空間范圍。 2)在GIS地圖中事先注冊乘車地點,將該地點的經(jīng)緯度信息與固定電話號碼綁定,乘客用綁定的固定電話撥打調(diào)度中心,調(diào)度中心即可確定撥入用戶的叫車位置,實現(xiàn)電話調(diào)度。這樣,注冊的固定電話(包括:家庭固話和公用電話亭電話等)都等價于出租車應召站點,這種叫車方式,調(diào)度中心無須人工參與,系統(tǒng)自動完成調(diào)度。 3)短信叫車,乘客事先注冊幾個自己經(jīng)常打車的地點,比如說家、公司等,然后將該地點的經(jīng)緯度信息、手機號碼和位置標簽關聯(lián),乘客需要叫車時發(fā)送事先注冊好的位置標簽短信,調(diào)度中心即可確定叫車乘客位置,從而實現(xiàn)短信調(diào)度。這三種叫車方式,調(diào)度中心端無須調(diào)度員人工干預,自動調(diào)度,方便乘客,節(jié)省資源。 2.2 基于網(wǎng)格的調(diào)度算法 現(xiàn)有的出租車調(diào)度中心大多設計為人工服務模式,首先調(diào)度中心不斷采集在系統(tǒng)中注冊的出租車的狀態(tài),然后將為空載狀態(tài)的出租車按照先進先出原則送入一個隊列;最后對于每個在線預約的乘客請求,調(diào)度員會按照自己以往的經(jīng)驗,人工確定最方便的一輛出租車,如果同時有多個出租車滿足請求,就按照先進先服務的方式前去服務,這種方式人工成本較高,且服務質(zhì)量難以提高。 本系統(tǒng)放棄人工服務方式,采用系統(tǒng)自動調(diào)度方式。 本調(diào)度服務程序采用基于網(wǎng)格的出租車調(diào)度算法,該算法具體過程如下: ?。?)劃分城市網(wǎng)格。在GIS地圖上根據(jù)城市大小,用適當?shù)木匦慰虬殉鞘懈采w,獲取矩形框?qū)蔷€的經(jīng)緯度信息:左上角經(jīng)緯度值為(a,b)、右下角經(jīng)緯度值為(c,d);結合城市出租車數(shù)量確定網(wǎng)格數(shù)(M×N)。 城市出租車總數(shù)為Tsum,出租車空載率為Pec,空載出租車數(shù)為Tec=Pec×Tsum。選取網(wǎng)格數(shù)約等于空載出租車數(shù)Tec≈M×N,為了計算方便,一般M、N選擇為2的冪次數(shù)(如:16、32、64、128、……),同時為了保證網(wǎng)格長寬盡量接近,所以選擇M/N比值盡量靠近值。 ?。?)劃分城市經(jīng)緯度數(shù)組。確定M、N值以后,把所選城市經(jīng)度范圍(a,c)均分為M份,存入經(jīng)度數(shù)組citylongitude[M]中,相鄰值間隔為;同時將城市緯度范圍(b,d)均分為N份,存入緯度數(shù)組citylatitude[N]中,相鄰值間隔為。劃分經(jīng)緯度數(shù)組是為了下面使用二分法計算出租車和請求乘客所在網(wǎng)格。 ?。?)網(wǎng)格信息維護。通過劃分城市經(jīng)緯度數(shù)組確定網(wǎng)格數(shù)組CityGrid[M][N],網(wǎng)格數(shù)據(jù)結構包括網(wǎng)格經(jīng)緯度等基本信息,同時每個網(wǎng)格動態(tài)維護兩個鏈表:網(wǎng)格空車鏈表和網(wǎng)格乘客鏈表。城市網(wǎng)格結構如圖4所示。
a.網(wǎng)格空車鏈表初始化。將當前系統(tǒng)中的所有空載出租車根據(jù)所處位置,通過二分法計算出租車所屬網(wǎng)格,加載到對應網(wǎng)格空車鏈表中,由于網(wǎng)格空車鏈表需要根據(jù)出租車終端上報的狀態(tài)信息實時調(diào)整,鏈表的增刪操作較為頻繁,因此本系統(tǒng)中網(wǎng)格空車鏈表采用雙鏈表結構。鏈表中的結點數(shù)據(jù)結構如表1所示。
表1 出租車數(shù)據(jù)結構
b.網(wǎng)格空車鏈表動態(tài)維護。根據(jù)出租車終端實時上報的狀態(tài)信息,判斷是否為空載狀態(tài),如果為空載,判斷鏈表中該出租車是否為空載狀態(tài),如果為空載判斷本次是否需要將出租車調(diào)整網(wǎng)格,如果鏈表中沒有該出租車,根據(jù)上報的GPS位置信息計算所屬網(wǎng)格,將該出租車插入該網(wǎng)格空車鏈表中,空載狀態(tài)計算完畢。如果上報狀態(tài)為滿載狀態(tài),判斷此前出租車是否為空載狀態(tài),如果為空載,將其從空車鏈表中刪除,滿載狀態(tài)計算完畢。具體處理流程圖如圖5所示。
未調(diào)度的乘客根據(jù)所處位置,通過二分法計算乘客所屬網(wǎng)格,加載到對應網(wǎng)格乘客鏈表中,遵循“先請求先服務”
原則,本系統(tǒng)中網(wǎng)格乘客鏈表采用鏈表隊列結構,鏈表中的結點數(shù)據(jù)結構如表2所示。
表2 乘客數(shù)據(jù)結構
(4)乘客請求調(diào)度。通過第(3)步將出租車和乘客按照網(wǎng)格分組,單個網(wǎng)格中如果網(wǎng)格乘客鏈表不為空,從鏈表選擇一個乘客,同時判斷該網(wǎng)格中空車鏈表是否為空,如果不為空,從該鏈表中選擇一個空車去滿足該乘客請求;如果該網(wǎng)格中空車鏈表為空,選擇相鄰網(wǎng)格中空車鏈表中的空車來滿足乘客請求,直到搜索到空車為止。搜索到空載出租車后把乘客GPS位置和乘客具體文字描述位置發(fā)送給出租車終端,發(fā)送成功后,將乘客從網(wǎng)格乘客鏈表中刪除,同時將對應的空車從網(wǎng)格空車鏈表中刪除。至此,調(diào)度過程完成。
3 模擬與性能測試
我們通過一臺服務器(DELLR710機架式服務器,XEON E5504×2JSDM/4G內(nèi)存條)作為調(diào)度服務器,模擬城市網(wǎng)格劃分為64×64=4096的系統(tǒng)調(diào)度,一臺PC機模擬10000臺出租車數(shù)據(jù)上傳GPS位置和狀態(tài)信息,上傳間隔為10s,測試內(nèi)容包括:出租車司機互助調(diào)度、電話調(diào)度、短信調(diào)度。通過模擬測試10000臺出租車運行,調(diào)度服務器CPU使用率49%,證明此系統(tǒng)是高效可行的。
4 結語
本文基于GPS/GIS設計和實現(xiàn)了一種新型的出租車調(diào)度系統(tǒng),該系統(tǒng)改進了現(xiàn)有出租車調(diào)度終端和叫車方式,并提出一種基于網(wǎng)格的出租車調(diào)度算法,實現(xiàn)出租車自動調(diào)度,最大限度地減少人工參與,通過模擬測試證明該算法高效實用。通過本系統(tǒng)可以有效降低乘客等待時間(CWT)和出租車空駛率(ECP),提高出租車系統(tǒng)運行效率。