專利名稱::基于面向服務架構(gòu)的分布式交通仿真平臺及其仿真方法
技術(shù)領(lǐng)域:
:本發(fā)明屬于分布式交通仿真領(lǐng)域,具體涉及面向服務架構(gòu)(Service-OrientedArchitecture,S0A)、多智能體、數(shù)據(jù)庫和分布式仿真等技術(shù)。
背景技術(shù):
:鑒于交通系統(tǒng)的復雜性,基于交通仿真的優(yōu)化成為交通信號優(yōu)化控制的主要方法之一。它大大減少了在評估交通系統(tǒng)時對數(shù)學公式或物理模型的解算所造成的負擔,大大降低了現(xiàn)場試驗的要求,為科研工作者提供了一種節(jié)約時間、節(jié)省費用、安全可行的研究手段。分布式交通仿真主要研究如何將對大規(guī)模路網(wǎng)的復雜仿真過程分成許多較小的部分,并將它們分配到多個計算機上并行處理,最后綜合這些處理結(jié)果得到最終的仿真結(jié)果,可以大幅提高仿真的速度和效率。分布式交通仿真平臺往往包括新模塊的開發(fā)與已有模塊的集成。新舊模塊在開發(fā)語言、傳輸協(xié)議、軟硬件平臺等技術(shù)方面會有所不同,要求仿真系統(tǒng)具有較高的異構(gòu)性。此外,隨著信息化建設的不斷發(fā)展,不同應用系統(tǒng)之間的交互日益頻繁,要求分布式系統(tǒng)各個模塊具有較好的可重用性。目前分布式仿真平臺主要采用HLA(HighLevelArchitecture)規(guī)范,然而其重用性受限于特定的仿真支撐平臺(RTI平臺),與其它領(lǐng)域技術(shù)和標準脫節(jié)。雖然WebService提供了良好的標準服務接口,然而與J2EE或.NET平臺結(jié)合的傳統(tǒng)開發(fā)模式各自只能選擇EJB(EnterpriseJavaBean)或.NET語言的組件實現(xiàn)方式,異構(gòu)性較差。
發(fā)明內(nèi)容本發(fā)明的主要目的在于提供一種基于面向服務架構(gòu)的分布式交通仿真平臺,以解決傳統(tǒng)分布式交通仿真存在的上述各種問題,提高系統(tǒng)的異構(gòu)性,靈活性與模塊的可重用性,降低系統(tǒng)的開發(fā)難度。基于面向服務架構(gòu)的分布式交通仿真平臺包括4層結(jié)構(gòu)用戶界面層、協(xié)調(diào)仿真多智能體層、數(shù)據(jù)服務中心層與仿真資源層;其中,用戶界面層包括仿真客戶端和數(shù)據(jù)維護客戶端;協(xié)調(diào)仿真多智能體層包括交互智能體、路網(wǎng)生成智能體、協(xié)調(diào)智能體、仿真結(jié)果處理智能體與區(qū)域仿真模塊,區(qū)域仿真模塊由VC區(qū)域仿真模塊組成;數(shù)據(jù)服務中心層包括數(shù)據(jù)服務中心,而數(shù)據(jù)服務中心又包括Hibernate0RM子模塊(0RM即Object/RelationM即ping,對象-關(guān)系數(shù)據(jù)庫映射)、數(shù)據(jù)生成子模塊和數(shù)據(jù)調(diào)遣子模塊;仿真資源層是Oracle數(shù)據(jù)庫;用戶界面層中的仿真客戶端通過訪問協(xié)調(diào)仿真多智能體層中的交互智能體的仿真啟動服務,下達仿真任務,并在仿真過程中通過交互智能體的仿真數(shù)據(jù)獲取服務,獲得最終的統(tǒng)計數(shù)據(jù)結(jié)果和實時仿真結(jié)果,并將其顯示;用戶界面層中的數(shù)據(jù)維護客戶端,用來完成路網(wǎng)數(shù)據(jù)與信號機參數(shù)的添加、修改、查詢與刪除;協(xié)調(diào)仿真多智能體層中的交互智能體,連接著仿真客戶端與仿真平臺內(nèi)部組件,向外提供仿真啟動、仿真數(shù)據(jù)獲取與仿真結(jié)果上傳三個服務;交互智能體接受仿真任務,根據(jù)仿真任務,確定仿真區(qū)域以及參與仿真的區(qū)域仿真模塊中的VC區(qū)域仿真模塊,并調(diào)用數(shù)據(jù)服務中心層中數(shù)據(jù)服務中心的數(shù)據(jù)生成子模塊的服務,然后等區(qū)域仿真路網(wǎng)數(shù)據(jù)準備完畢后初始化VC區(qū)域仿真模塊,當所有的VC區(qū)域仿真模塊初始化結(jié)束后,仿真啟動服務開始調(diào)用協(xié)調(diào)仿真多智能體層中的協(xié)調(diào)智能體的協(xié)調(diào)初始化服務,并在仿真過程中接收協(xié)調(diào)仿真多智能體層中的仿真結(jié)果處理智能體通過仿真結(jié)果上傳服務,上傳的實時仿真結(jié)果;仿真結(jié)果處理智能體,提供實時結(jié)果上傳服務與統(tǒng)計結(jié)果生成服務;各VC區(qū)域仿真模塊調(diào)用仿真結(jié)果處理智能體的實時結(jié)果上傳服務,向仿真結(jié)果處理智能體更新本周期的仿真實時信息,而仿真結(jié)果處理智能體通過仿真結(jié)果上傳服務,上傳實時仿真結(jié)果給交互智能體;協(xié)調(diào)智能體,向外提供協(xié)調(diào)初始化服務,內(nèi)部包括協(xié)調(diào)判定服務與信號調(diào)整服務;協(xié)調(diào)智能體的協(xié)調(diào)初始化服務被調(diào)用時,首先開辟多個線程,接著循環(huán)執(zhí)行線程調(diào)用各VC區(qū)域仿真模塊的周期仿真服務,并在每一個仿真周期中根據(jù)上一周期仿真結(jié)果判斷是否需要區(qū)域協(xié)調(diào),若當前仿真周期無需進行區(qū)域間協(xié)調(diào),則協(xié)調(diào)智能體繼續(xù)調(diào)用VC區(qū)域仿真模塊的周期仿真服務,實現(xiàn)給定周期內(nèi)的區(qū)域交通仿真,若當前仿真周期需要進行區(qū)域間協(xié)調(diào),則協(xié)調(diào)智能體調(diào)用信號調(diào)整服務進行決策;區(qū)域仿真模塊,內(nèi)部嵌入SOA接入模塊,向交互智能體提供區(qū)域仿真初始化服務,向協(xié)調(diào)智能體提供周期仿真服務;區(qū)域仿真模塊產(chǎn)生交通流與車源,模擬車輛的運動行為,負責所屬子區(qū)域的仿真;VC區(qū)域仿真模塊調(diào)用數(shù)據(jù)服務中心的數(shù)據(jù)調(diào)遣子模塊的服務,獲取區(qū)域仿真路網(wǎng)數(shù)據(jù);路網(wǎng)生成智能體作為數(shù)據(jù)解析部分嵌入SOA接入模塊,向VC區(qū)域仿真模塊提供路網(wǎng)生成服務,路網(wǎng)生成服務從數(shù)據(jù)服務中心獲得路網(wǎng)與信號機的數(shù)據(jù)對象,并轉(zhuǎn)換成區(qū)域仿真模塊對應的數(shù)據(jù)結(jié)構(gòu)類型,使數(shù)據(jù)適用于區(qū)域仿真模塊;數(shù)據(jù)服務中心包括3個子模塊①HibernateORM子模塊,完成對象_關(guān)系映射,實現(xiàn)基于對象原語的數(shù)據(jù)建立,并將其持久化到仿真資源層中的Oracle數(shù)據(jù)庫中;②數(shù)據(jù)生成子模塊提供數(shù)據(jù)生成服務,從Oracle數(shù)據(jù)庫中獲取分布式交通仿真所需要的路網(wǎng)信息,并將其封裝為SDO數(shù)據(jù);③數(shù)據(jù)調(diào)遣子模塊提供數(shù)據(jù)調(diào)遣服務,通過WebService獲取路網(wǎng)生成智能體的仿真原始數(shù)據(jù)發(fā)送請求,將生成的SDO數(shù)據(jù)發(fā)送到區(qū)域仿真模塊;Oracle數(shù)據(jù)庫,存儲仿真所需的路網(wǎng)數(shù)據(jù)信息與信號機配置信息;交互智能體、協(xié)調(diào)智能體和仿真結(jié)果處理智能體以及數(shù)據(jù)服務中心采用服務組件架構(gòu)SCA(ServiceComponentArchitecture)規(guī)范,并各自封裝成SCA構(gòu)件;已有的單機仿真程序模塊則通過SOA接入模塊作為區(qū)域仿真模塊接入本發(fā)明的仿真平臺中。系統(tǒng)的區(qū)域協(xié)調(diào)仿真基于邏輯時鐘同步,每個仿真模塊調(diào)用或提供粗粒度的服務,基于不同的仿真服務,仿真平臺完成大規(guī)模的分布式交通仿真。所述的VC區(qū)域仿真模塊,指用VisualC++實現(xiàn)的單機仿真程序模塊通過SOA接入模塊作為區(qū)域仿真模塊的。所述的SOA接入模塊由兩個部分組成服務綁定模塊與服務調(diào)用模塊;服務綁定模塊采用SCAJava構(gòu)件實現(xiàn),包括數(shù)據(jù)解析子模塊和Socket請求子模塊,其應用原理為首先,服務綁定模塊接受SOA環(huán)境中的服務調(diào)用請求,并獲得SDO數(shù)據(jù);接著,數(shù)據(jù)解析子模塊解析SD0數(shù)據(jù),并通過Socket請求子模塊將數(shù)據(jù)經(jīng)Socket連接發(fā)送到VC單機仿真程序模塊,VC單機仿真程序模塊與SOA接入模塊位于同一臺計算機上,VC單機仿真程序模塊執(zhí)行其自身仿真程序的相關(guān)操作;然后,VC單機仿真程序模塊通過Socket連接將結(jié)果返回到服務綁定模塊;最后,服務綁定模塊將返回得數(shù)據(jù)結(jié)果封裝成SDO數(shù)據(jù)對象,并返回給服務調(diào)用者;服務調(diào)用模塊則采用組件對象模型COM(ComponentObjectModel)組件的實現(xiàn)方式,包括服務引用子模塊和數(shù)據(jù)轉(zhuǎn)換子模塊,服務引用子模塊采用公共語言運行時CLR(CommonLanguageRuntime)托管程序開發(fā),并以動態(tài)鏈接庫DLL(DynamicLinkLibrary)形式生成;VC單機仿真程序模塊通過COM組件接口調(diào)用服務引用子模塊,實現(xiàn)仿真服務(如數(shù)據(jù)發(fā)送服務)的引用,并得到SDO數(shù)據(jù);數(shù)據(jù)轉(zhuǎn)換子模塊解析SDO數(shù)據(jù)并進行重新組合,使數(shù)據(jù)存儲格式與VC單機仿真程序模塊中的一致。數(shù)據(jù)類型在VC程序,COM組件,托管DLL中需要進行相應的轉(zhuǎn)化,VC程序調(diào)用COM服務時傳遞的參數(shù)與返回值應使用Variant類型變量,COM組件訪問托管DLL時傳遞的參數(shù)與返回值則需要進行托管,非托管類型轉(zhuǎn)化?;诿嫦蚍占軜?gòu)的分布式交通仿真方法主要包括以下步驟步驟1、仿真啟動;仿真客戶端訪問交互智能體的仿真啟動服務,交互智能體根據(jù)仿真任務確定仿真區(qū)域以及參與仿真的VC區(qū)域仿真模塊;步驟2、數(shù)據(jù)準備;交互智能體調(diào)用數(shù)據(jù)服務中心的數(shù)據(jù)生成子模塊的服務,數(shù)據(jù)服務中心從Oracle數(shù)據(jù)中獲取原始的路網(wǎng)數(shù)據(jù),并按區(qū)域?qū)?shù)據(jù)重組并封裝成SDO數(shù)據(jù)對象,生成區(qū)域仿真路網(wǎng)數(shù)據(jù),數(shù)據(jù)準備完畢后,交互智能體初始化區(qū)域仿真模塊并同時等待初始化完成;步驟3、初始化區(qū)域仿真模塊,包括步驟3.1與步驟3.2,這兩個步驟都是多任務并發(fā);步驟3.l,仿真啟動服務根據(jù)參與仿真的VC區(qū)域仿真模塊的數(shù)量開辟多線程,在多線程中調(diào)用區(qū)域仿真初始化服務;步驟3.2,仿真啟動服務在主線程中通過標志位等待步驟3.1中的仿真初始化完成;步驟4、獲取區(qū)域仿真路網(wǎng)數(shù)據(jù);各VC區(qū)域仿真模塊通過調(diào)用路網(wǎng)生成智能體的路網(wǎng)生成服務,獲取在步驟2生成的區(qū)域仿真路網(wǎng)數(shù)據(jù);步驟5、區(qū)域協(xié)調(diào)仿真啟動,具體為步驟5.1,當所有的VC區(qū)域仿真模塊初始化結(jié)束后,仿真啟動服務開始調(diào)用協(xié)調(diào)智能體的協(xié)調(diào)初始化服務,此時仿真啟動服務的生命周期結(jié)束;步驟5.2,仿真客戶端開始循環(huán)調(diào)用交互智能體的仿真數(shù)據(jù)獲取服務,獲取公交車輛當前時刻坐標,干線、路口交通流情況以及各信號當前相位,協(xié)調(diào)智能體的協(xié)調(diào)初始化服務首先開辟多個線程,并循環(huán)執(zhí)行線程,調(diào)用各VC區(qū)域仿真模塊的周期仿真服務;步驟6、區(qū)域協(xié)調(diào)控制;協(xié)調(diào)智能體在每一個仿真周期中首先根據(jù)上一周期仿真結(jié)果判斷是否需要區(qū)域協(xié)調(diào),若當前仿真周期無需進行區(qū)域間協(xié)調(diào),則執(zhí)行步驟7,若當前仿真周期需要進行區(qū)域間協(xié)調(diào),則轉(zhuǎn)到步驟10;步驟7、周期性區(qū)域協(xié)調(diào)仿真;協(xié)調(diào)智能體調(diào)用區(qū)域仿真模塊的周期仿真服務,實現(xiàn)給定周期內(nèi)的區(qū)域交通仿真,根據(jù)子區(qū)域所處的位置進行邊界信息的更新,包括社會車輛交通流信息與公交車位置信息,然后執(zhí)行步驟8;步驟8、生成實時交通仿真數(shù)據(jù);各VC區(qū)域仿真模塊調(diào)用仿真結(jié)果處理智能體的實時結(jié)果上傳服務,向仿真結(jié)果處理智能體更新本周期的仿真實時信息,包括公交車輛經(jīng)緯度,行駛方向,信號狀態(tài);步驟9、仿真狀態(tài)判定與數(shù)據(jù)上載,包括步驟9.1與步驟9.2;步驟9.l,本周期的仿真實時信息更新后,仿真結(jié)果處理智能體通過交互智能體的仿真結(jié)果上傳服務,上傳實時仿真結(jié)果給交互智能體,仿真客戶端可以通過交互智能體的仿真數(shù)據(jù)獲取服務,獲得實時仿真結(jié)果并顯示;步驟9.2,協(xié)調(diào)智能體根據(jù)仿真時間判斷整個仿真過程是否結(jié)束,若仿真沒有結(jié)束則循環(huán)進行下一周期的仿真,執(zhí)行步驟6;否則結(jié)束區(qū)域仿真,執(zhí)行步驟12;步驟10、協(xié)調(diào)控制決策;協(xié)調(diào)智能體調(diào)用信號調(diào)整服務進行決策;步驟11、更新信號機參數(shù);根據(jù)步驟10信號調(diào)整服務的結(jié)果在下一個仿真周期中更新信號機的參數(shù),然后執(zhí)行步驟7;步驟12、仿真統(tǒng)計數(shù)據(jù)生成;交互智能體調(diào)用仿真結(jié)果處理智能體的統(tǒng)計結(jié)果生成服務,將生成的統(tǒng)計數(shù)據(jù)上傳到交互智能體,然后執(zhí)行步驟13;步驟13、統(tǒng)計數(shù)據(jù)顯示與結(jié)束;仿真客戶端通過交互智能體的仿真數(shù)據(jù)獲取服務獲得最終的統(tǒng)計數(shù)據(jù)結(jié)果并顯示,整個分布式仿真任務結(jié)束,并等待下一個仿真任務的到來。本發(fā)明的優(yōu)點與積極效果在于(1)采用SOA架構(gòu),提高分布式仿真平臺的靈活度,易于分散開發(fā),減少系統(tǒng)的開發(fā)成本與周期;(2)仿真模塊采用SCA構(gòu)件實現(xiàn)方式,系統(tǒng)的異構(gòu)性、可重用型與可集成性強;(3)S0A接入模塊進一步增強了系統(tǒng)的可重用性,整個系統(tǒng)易于在異質(zhì)環(huán)境中部署;(4)仿真方法相對現(xiàn)有方法速度較快。圖1為基于面向服務架構(gòu)的分布式交通仿真平臺架構(gòu)示意圖2為基于SCA組件的系統(tǒng)實現(xiàn)示意圖;圖3為基于面向服務架構(gòu)的分布式交通仿真平臺SOA接入模塊示意圖4為基于面向服務架構(gòu)的分布式交通仿真方法運行步驟示意圖5為本發(fā)明實施例驗證試驗中采用的路網(wǎng)示意圖6為本發(fā)明實施例驗證試驗所得數(shù)據(jù);圖中l(wèi)-仿真客戶端,2-數(shù)據(jù)維護客戶端,3-交互智能體,4-仿真結(jié)果處理智能體,5-協(xié)調(diào)智能體,6-區(qū)域仿真模塊,7-路網(wǎng)生成智能體,8-數(shù)據(jù)服務中心,801-數(shù)據(jù)調(diào)遣子模塊,802-數(shù)據(jù)生成子模塊,803-HibernateORM子模塊,9-0racle數(shù)據(jù)庫,10-服務綁定模塊,101-數(shù)據(jù)解析子模塊,102-Socket請求子模塊,11-服務調(diào)用模塊,111-數(shù)據(jù)轉(zhuǎn)換子?!姥?,112-服務引用子模塊,12-VC單機仿真程序模塊,a-仿真啟動服務,b-仿真數(shù)據(jù)獲取服務,c-仿真結(jié)果上傳服務,d-數(shù)據(jù)生成服務,e-數(shù)據(jù)調(diào)遣服務,f-實時結(jié)果上傳服務,g-統(tǒng)計結(jié)果生成服務,h-協(xié)調(diào)初始化服務,i-區(qū)域仿真初始化服務,j-周期仿真服務。具體實施例方式下面將結(jié)合附圖和實施例對本發(fā)明作進一步的詳細說明。如圖l所示,基于面向服務架構(gòu)的分布式交通仿真平臺包括四層結(jié)構(gòu)用戶界面層、協(xié)調(diào)仿真多智能體層、數(shù)據(jù)服務中心層與仿真資源層;其中,用戶界面層包括仿真客戶端1和數(shù)據(jù)維護客戶端2,仿真客戶端1包含多個客戶端(客戶端dl,客戶端d2,……客戶端dN)進行顯示;協(xié)調(diào)仿真多智能體層包括交互智能體3、仿真結(jié)果處理智能體4、協(xié)調(diào)智能體5、路網(wǎng)生成智能體7與區(qū)域仿真模塊6,區(qū)域仿真模塊6中根據(jù)仿真任務接入VC區(qū)域仿真模塊(VC區(qū)域仿真模塊j,VC區(qū)域仿真模塊—2,……VC區(qū)域仿真模塊—k,……,VC區(qū)域仿真模塊—N,1《k《N);數(shù)據(jù)服務中心層是數(shù)據(jù)服務中心8,數(shù)據(jù)服務中心8又包括Hibernate0RM子模塊803、數(shù)據(jù)生成子模塊802和數(shù)據(jù)調(diào)遣子模塊801;仿真資源層是Oracle數(shù)據(jù)庫9。結(jié)合圖l,基于面向服務架構(gòu)的分布式交通仿真平臺各模塊實現(xiàn)細節(jié)及模塊間關(guān)系如下1)用戶界面層參仿真客戶端1:采用VB(VisualBasic)與MapX實現(xiàn)。仿真客戶端1顯示的路網(wǎng)底圖來源于美國M即Info公司的桌面地理信息系統(tǒng)軟件M即Info電子地圖。仿真客戶端1與交互智能體3通過SOA接入模塊相互連接,所交互的數(shù)據(jù)采用SDO模型進行封裝。仿真客戶端1通過訪問交互智能體3的仿真啟動服務a下達仿真任務,如圖2,并在仿真過程中通過交互智能體3的仿真數(shù)據(jù)獲取服務b,獲得最終的統(tǒng)計數(shù)據(jù)結(jié)果和實時仿真結(jié)果,并將其顯示。參數(shù)據(jù)維護客戶端2:采用JavaSWT(StandardWidgetToolkit)實現(xiàn),通過Hibernate0RM子模塊803完成路網(wǎng)數(shù)據(jù)與信號機參數(shù)的添加、修改、查詢與刪除。2)協(xié)調(diào)仿真多智能體層參交互智能體3:采用SCAJava構(gòu)件實現(xiàn),與WebService綁定后向外提供仿真啟動服務a、仿真數(shù)據(jù)獲取服務b與仿真結(jié)果上傳服務c,如圖2。仿真啟動服務a的輸入?yún)?shù)是仿真客戶端1發(fā)送的仿真請求SDO數(shù)據(jù),該服務通過XSD(XMLSchemasDefinition)數(shù)據(jù)描述文件與SD0API(應用程序編程接口)提取出仿真路網(wǎng)范圍,區(qū)域劃分個數(shù),車輛設定參數(shù)等信息。仿真啟動服務a會通知數(shù)據(jù)服務中心8生成對應路網(wǎng)的數(shù)據(jù),并根據(jù)區(qū)域個數(shù)創(chuàng)建若干線程用于啟動區(qū)域仿真模塊6。仿真數(shù)據(jù)獲取服務b的返回參數(shù)是SDO數(shù)據(jù),包含當前仿真時刻車輛與信號機的狀態(tài)。仿真結(jié)果上傳服務c的輸入是仿真過程中產(chǎn)生的實時數(shù)據(jù)與仿真結(jié)束后生成的統(tǒng)計數(shù)據(jù)。交互智能體3接受仿真任務,根據(jù)仿真任務確定仿真區(qū)域,以及參與仿真的區(qū)域仿真模塊6中的VC區(qū)域仿真模塊,并調(diào)用數(shù)據(jù)服務中心8的數(shù)據(jù)生成子模塊802的服務,然后等區(qū)域仿真路網(wǎng)數(shù)據(jù)準備完畢后初始化VC區(qū)域仿真模塊,當所有的VC區(qū)域仿真模塊初始化結(jié)束后,仿真啟動服務a開始調(diào)用協(xié)調(diào)智能體5的協(xié)調(diào)初始化服務h,并在仿真過程中接收仿真結(jié)果處理智能體4通過實時結(jié)果上傳服務f上傳的實時仿真結(jié)果,如圖2。參仿真結(jié)果處理智能體4:采用SCAJava構(gòu)件實現(xiàn),提供實時結(jié)果上傳服務f與統(tǒng)計結(jié)果生成服務g,如圖2。實時結(jié)果上傳服務f的輸入?yún)?shù)為仿真實時數(shù)據(jù),包括公交車輛經(jīng)緯度與信號燈狀態(tài)等信息。統(tǒng)計結(jié)果生成服務g的輸入?yún)?shù)為各路口歷史狀態(tài),其根據(jù)歷史狀態(tài)計算區(qū)域信號控制整體指標,包括各路口的公交車平均延誤時間,各條公交線路的平均旅行時間等指標。各VC區(qū)域仿真模塊調(diào)用仿真結(jié)果處理智能體4的實時結(jié)果上傳服務f,向仿真結(jié)果處理智能體4更新本周期的仿真實時信息,而仿真結(jié)果處理智能體4通過仿真結(jié)果上傳服務c,上傳實時仿真結(jié)果給交互智能體3。參協(xié)調(diào)智能體5:通過邏輯時鐘同步區(qū)域仿真,確定區(qū)域協(xié)調(diào)決策;采用SCAJava構(gòu)件實現(xiàn),向外提供協(xié)調(diào)初始化服務h,內(nèi)部包括協(xié)調(diào)判定服務與信號調(diào)整服務,如圖2。協(xié)調(diào)初始化服務h的輸入?yún)?shù)是參與仿真的區(qū)域仿真模塊的編號。協(xié)調(diào)判定服務的輸入?yún)?shù)是包括公交車延誤與排隊長度在內(nèi)的路口狀態(tài)信息,返回值是協(xié)調(diào)方案決策。信號調(diào)整服務的輸入?yún)?shù)是協(xié)調(diào)方案與協(xié)調(diào)區(qū)域當前信號狀態(tài),返回值是調(diào)整后的信號參數(shù)。協(xié)調(diào)初始化服務h被調(diào)用時,首先會開辟多個線程,并循環(huán)執(zhí)行線程調(diào)用各VC區(qū)域仿真模塊(VC區(qū)域仿真模塊_1、VC區(qū)域仿真模塊_2、……、VC區(qū)域仿真模塊_N)的周期仿真服務j,并在每一個仿真周期中調(diào)用協(xié)調(diào)判定服務,根據(jù)上一周期仿真結(jié)果判斷是否需要區(qū)域協(xié)調(diào),若當前仿真周期無需進行區(qū)域間協(xié)調(diào),則協(xié)調(diào)智能體5繼續(xù)調(diào)用區(qū)域仿真模塊6中的VC區(qū)域仿真模塊的周期仿真服務j,實現(xiàn)給定周期內(nèi)的區(qū)域交通仿真,若當前仿真周期需要進行區(qū)域間協(xié)調(diào),則協(xié)調(diào)智能體5調(diào)用信號調(diào)整服務進行決策。參區(qū)域仿真模塊6:采用VC++實現(xiàn)。仿真模型采用宏觀微觀相結(jié)合的混合仿真模型,公交車輛采用微觀仿真模型精確描述其行駛,超車,進站等行為。社會車輛用宏觀交通流代替。區(qū)域仿真模塊6內(nèi)部嵌入SOA接入模塊,向外提供區(qū)域仿真初始化服務i與周期仿真服務j,如圖2。區(qū)域仿真初始化服務i實現(xiàn)區(qū)域仿真模塊內(nèi)部的路網(wǎng)構(gòu)建,公交車輛生成與社會車輛交通流生成等仿真初始化操作。周期仿真服務j實現(xiàn)各仿真子區(qū)域在一個周期內(nèi)的仿真。區(qū)域仿真模塊6產(chǎn)生車流與交通流,模擬車輛的運動行為,負責所屬子區(qū)域的仿真;其內(nèi)接入的VC區(qū)域仿真模塊調(diào)用數(shù)據(jù)服務中心8的數(shù)據(jù)調(diào)遣子模塊801的服務,獲取區(qū)域仿真路網(wǎng)數(shù)據(jù)。參路網(wǎng)生成智能體7:采用C++COM組件實現(xiàn),嵌入SOA接入模塊,提供路網(wǎng)生成服務。路網(wǎng)生成服務從數(shù)據(jù)服務中心8獲得路網(wǎng)與信號機的SDO數(shù)據(jù)對象,并轉(zhuǎn)換成區(qū)域仿真模塊6對應的struct數(shù)據(jù)結(jié)構(gòu)類型。3)數(shù)據(jù)服務中心層參數(shù)據(jù)服務中心8:采用SCAJava構(gòu)件實現(xiàn),包括HibernateORM子模塊803、數(shù)據(jù)生成子模塊802與數(shù)據(jù)調(diào)遣子模塊801。HibernateORM子模塊803基于Hibernate的關(guān)聯(lián)映射實現(xiàn)路網(wǎng)數(shù)據(jù)結(jié)構(gòu)及其在0racle數(shù)據(jù)庫9中的持久化存儲。數(shù)據(jù)生成子模塊802通過組件內(nèi)的數(shù)據(jù)生成服務d完成基于面向?qū)ο蟮穆肪W(wǎng)數(shù)據(jù)提取,并生成SDO數(shù)據(jù)對象。數(shù)據(jù)調(diào)遣子模塊801中的數(shù)據(jù)調(diào)遣服務e通過WebService將SDO數(shù)據(jù)發(fā)送到區(qū)域仿真模塊6。4)仿真資源層參Oracle數(shù)據(jù)庫9:所存儲的仿真路網(wǎng)采用包括拓撲信息,屬性信息,地理信息的三層模型。其中的地理信息存儲在OracleSpatial數(shù)據(jù)庫中。整個數(shù)據(jù)庫包括路網(wǎng)拓撲信息表,路網(wǎng)元素屬性信息表,路網(wǎng)元素地理信息表,信號機參數(shù)表與映射集合表等13個關(guān)系型數(shù)據(jù)表。本發(fā)明各模塊間的數(shù)據(jù)傳輸方式有四種,如圖1所示,仿真客戶端1與交互智能體3之間,交互智能體3與區(qū)域仿真模塊6之間,交互智能體3與數(shù)據(jù)服務中心8之間,仿真結(jié)果處理智能體4與區(qū)域仿真模塊6之間,協(xié)調(diào)智能體5與區(qū)域仿真模塊6之間,以及路網(wǎng)生成智能體7與數(shù)據(jù)服務中心8之間,均采用的是WebService進行數(shù)據(jù)傳輸;交互智能體3與仿真結(jié)果處理智能體4之間,交互智能體3與協(xié)調(diào)智能體5之間,數(shù)據(jù)維護客戶端2與數(shù)據(jù)服務中心8之間,以及數(shù)據(jù)服務中心8中的數(shù)據(jù)調(diào)遣子模塊801與數(shù)據(jù)生成子模塊802之間,數(shù)據(jù)生成子模塊802與HibernateORM子模塊803之間,采用的是SCAService進行數(shù)據(jù)傳輸;此外,數(shù)據(jù)服務中心8與Oracle數(shù)據(jù)庫9之間采用的是Java數(shù)據(jù)庫連接JDBC(JavaDataBaseConnectivity)進行數(shù)據(jù)傳輸,區(qū)域仿真模塊6與路網(wǎng)生成智能體之間采用COMService進行數(shù)據(jù)傳輸。本發(fā)明的基于面向服務架構(gòu)的分布式交通仿真平臺中各模塊的工作基于邏輯時間同步,從仿真客戶端1部署仿真任務到仿真結(jié)束返回統(tǒng)計數(shù)據(jù)結(jié)果。本發(fā)明仿真平臺的交互智能體3、協(xié)調(diào)智能體5、仿真結(jié)果處理智能體4以及數(shù)據(jù)服務中心8采用服務組件架構(gòu)SCA規(guī)范,并各自封裝成SCA構(gòu)件,SCA的語言無關(guān)性使得SCA組件可由多種語言實現(xiàn),包括Java、C、C++、BPEL、PHP、COBOL等等。每個SCA構(gòu)件由若干SCA組件構(gòu)成。每個SCA組件包含如下4個部分參服務組件本身向其他組件提供的業(yè)務功能;參實現(xiàn)特定業(yè)務功能的實現(xiàn)代碼;參屬性對業(yè)務功能中的數(shù)據(jù)值進行配置,進而影響實現(xiàn)的行為;參引用本組件實現(xiàn)對其他組件所提供服務的依賴。本發(fā)明實施例中SCA組件采用Java實現(xiàn),組件包括服務接口、實現(xiàn)、屬性、引用接口四部分。一個SCA組件可對外提供一個或多個服務,每個服務對應一個接口類,服務對應的方法在服務接口類中體現(xiàn)為一系列的抽象方法,若服務被定義為遠程調(diào)用,需要用@Remotable進行注釋,在實現(xiàn)類中,用@ServiCe(*.class)指定服務接口,并重寫服務接口中的方法。若組件的實現(xiàn)需包含對其它組件服務的引用,則需調(diào)用相應的set方法并以◎Reference進行注釋。屬性的配置需要在服務實現(xiàn)類中用@Property標記字段或Setter方法,并在配置文件中的〈property〉元素中進行配置。由于分布式仿真平臺結(jié)構(gòu)復雜,涉及多個模塊,僅由一名開發(fā)人員從底層開始完成系統(tǒng)的全部開發(fā)是不現(xiàn)實的。首先,分布式系統(tǒng)的開發(fā)應盡可能建立在現(xiàn)有的模塊之上,其次,分布式系統(tǒng)應先以模塊為單位進行分散開發(fā),最后將各模塊進行集成。仿真模塊SCA的實現(xiàn)與SD0數(shù)據(jù)封裝已經(jīng)解決了SCA模塊系統(tǒng)集成的問題,而獨立開發(fā)的非SCA模塊的集成需要設計相應的解決方案。為了將單機仿真程序與整個仿真平臺結(jié)合,其需要具備提供服務與調(diào)用服務的能力。雖然單機的仿真程序可以將關(guān)鍵部分分離出來,重新封裝成SCA組件,但這樣操作具有許多弊端。首先,作為一個完整的單機仿真程序,重新對其關(guān)鍵組件封裝會破壞軟件的整體結(jié)構(gòu),不利于軟件后續(xù)的升級與維護。其次,單機仿真程序本身規(guī)模較大,重新封裝成SCA組件代碼改動量大。再次,SCA組件的運行依賴特殊的Web容器,系統(tǒng)運行的獨立性降低。最后,單機仿真程序的開發(fā)人員須同時具有SOA、SCA、SDO的相關(guān)知識,否則不利于整個系統(tǒng)的分散開發(fā)。而本發(fā)明創(chuàng)新的實現(xiàn)了一種單機程序SOA接入模塊,可將單機仿真程序模塊接入SOA環(huán)境并作為分布式仿真平臺模塊的一部份,并進行極少的代碼修改。SOA接入模塊與VC單機仿真程序模塊12位于同一臺計算機上,如圖3所示,涉及到兩個環(huán)境SOA環(huán)境與非SOA環(huán)境,SOA環(huán)境指本發(fā)明的仿真平臺環(huán)境,VC單機仿真程序模塊是由用Visual0++實現(xiàn)的單機仿真程序模塊,處于非5(^環(huán)境。SOA接入模塊包括兩個部分服務綁定模塊10與服務調(diào)用模塊11。服務綁定模塊10采用SCAJava構(gòu)件實現(xiàn),包括數(shù)據(jù)解析子模塊101和Socket請求子模塊102,其應用原理為首先,服務綁定模塊10通過WebService傳輸數(shù)據(jù),接受SOA環(huán)境中的服務調(diào)用請求,并獲得SDO數(shù)據(jù);接著,數(shù)據(jù)解析子模塊101解析SDO數(shù)據(jù),并通過Socket請求子模塊102將數(shù)據(jù)經(jīng)Socket連接發(fā)送到VC單機仿真程序模塊12,VC單機仿真程序模塊12執(zhí)行其內(nèi)仿真程序的相關(guān)操作,然后,VC單機仿真程序模塊12通過Socket連接將結(jié)果返回到服務綁定模塊10;最后,服務綁定模塊10將返回的數(shù)據(jù)結(jié)果封裝成SDO數(shù)據(jù)對象,并返回給服務調(diào)用者。服務調(diào)用模塊11則采用COM組件的方式實現(xiàn),包括數(shù)據(jù)轉(zhuǎn)換子模塊111和服務引用子模塊112。服務引用子模塊112采用CLR托管程序開發(fā),并以DLL形式生成。VC單機仿真程序模塊12通過COM組件接口調(diào)用服務引用子模塊112,實現(xiàn)仿真服務(如數(shù)據(jù)發(fā)送服務)的引用,并得到SD0數(shù)據(jù)。數(shù)據(jù)轉(zhuǎn)換子模塊lll解析SDO數(shù)據(jù)并進行重新組合,使數(shù)據(jù)存儲格式與VC單機仿真程序模塊12中的一致。數(shù)據(jù)類型在VC程序,COM組件,托管DLL中需要進行相應的轉(zhuǎn)化,VC程序調(diào)用COM服務時傳遞的參數(shù)與返回值應使用Variant類型變量,COM組件訪問托管DLL時傳遞的參數(shù)與返回值則需要進行托管,非托管類型轉(zhuǎn)化。圖3中C0M組件提供的接口都需要從IUnknown接口繼承。基于面向服務架構(gòu)的分布式交通仿真平臺的仿真方法,其仿真流程如圖4所示,具體步驟說明如下步驟1、仿真啟動;仿真客戶端1訪問交互智能體3的仿真啟動服務,交互智能體3根據(jù)仿真任務確定仿真區(qū)域以及參與仿真的區(qū)域仿真模塊6接入的VC區(qū)域仿真模塊。步驟2、數(shù)據(jù)準備;交互智能體3調(diào)用數(shù)據(jù)服務中心8的數(shù)據(jù)生成子模塊802的服務,數(shù)據(jù)服務中心8從Oracle數(shù)據(jù)庫9中獲取原始的路網(wǎng)數(shù)據(jù),并按區(qū)域?qū)?shù)據(jù)重組并封裝成SDO數(shù)據(jù)對象,生成區(qū)域仿真路網(wǎng)數(shù)據(jù)。數(shù)據(jù)準備完畢后,交互智能體3初始化區(qū)域仿真模塊6并同時等待初始化完成。步驟3、初始化區(qū)域仿真模塊,包括步驟3.1與步驟3.2,這兩個步驟都是多任務并發(fā);步驟3.l,仿真啟動服務根據(jù)參與仿真的VC區(qū)域仿真模塊的數(shù)量開辟多線程,在多線程中調(diào)用區(qū)域仿真初始化服務;步驟3.2,仿真啟動服務在主線程中通過標志位等待步驟3.1中的仿真初始化完成;步驟4、獲取區(qū)域仿真路網(wǎng)數(shù)據(jù);各VC區(qū)域仿真模塊通過調(diào)用路網(wǎng)生成智能體的路網(wǎng)生成服務,獲取在步驟2生成的區(qū)域仿真路網(wǎng)數(shù)據(jù)。步驟5、區(qū)域協(xié)調(diào)仿真啟動,具體為步驟5.1,當所有的VC區(qū)域仿真模塊初始化結(jié)束后,仿真啟動服務開始調(diào)用協(xié)調(diào)智能體5的協(xié)調(diào)初始化服務,此時仿真啟動服務的生命周期結(jié)束;步驟5.2,仿真客戶端1開始循環(huán)調(diào)用交互智能體3的仿真數(shù)據(jù)獲取服務,獲取公交車輛當前時刻坐標,干線、路口交通流情況以及各信號等當前相位。協(xié)調(diào)智能體5的協(xié)調(diào)初始化服務首先會開辟多個線程,并循環(huán)執(zhí)行線程調(diào)用各VC區(qū)域仿真模塊的周期仿真服務。步驟6、區(qū)域協(xié)調(diào)控制;協(xié)調(diào)智能體5在每一個仿真周期中首先根據(jù)上一周期仿真結(jié)果判斷是否需要區(qū)域協(xié)調(diào)。若當前仿真周期無需進行區(qū)域間協(xié)調(diào),則執(zhí)行步驟7,若當前仿真周期需要進行區(qū)域間協(xié)調(diào),則執(zhí)行步驟IO。步驟7、周期性區(qū)域協(xié)調(diào)仿真;協(xié)調(diào)智能體5調(diào)用區(qū)域仿真模塊6的周期仿真服務,實現(xiàn)給定周期內(nèi)的區(qū)域交通仿真,根據(jù)子區(qū)域所處的位置進行邊界信息的更新,包括社會車輛交通流信息與公交車位置信息,然后執(zhí)行步驟8。步驟8、生成實時交通仿真數(shù)據(jù);各VC區(qū)域仿真模塊調(diào)用仿真結(jié)果處理智能體4的實時結(jié)果上傳服務,向仿真結(jié)果處理智能體4更新本周期的仿真實時信息,包括公交車輛經(jīng)緯度,行駛方向,信號等狀態(tài)等。步驟9、仿真狀態(tài)判定與數(shù)據(jù)上載,包括步驟9.1與步驟9.2;步驟9.1,本周期的仿真實時信息更新后,仿真結(jié)果處理智能體4通過交互智能體3的仿真結(jié)果上傳服務,上傳實時仿真結(jié)果給交互智能體3,仿真客戶端1可以通過交互智能體3的仿真數(shù)據(jù)獲取服務,獲得實時仿真結(jié)果并顯示;步驟9.2,協(xié)調(diào)智能體5根據(jù)仿真時間是否到期判斷整個仿真過程是否結(jié)束,若仿真沒有結(jié)束則循環(huán)進行下一周期的仿真,轉(zhuǎn)到步驟6執(zhí)行,若仿真結(jié)束,則結(jié)束區(qū)域仿真,然后轉(zhuǎn)步驟12。步驟10、協(xié)調(diào)控制決策;協(xié)調(diào)智能體5調(diào)用信號調(diào)整服務進行決策。步驟11、更新信號機參數(shù);根據(jù)步驟10信號調(diào)整服務的結(jié)果在下一個仿真周期中更新信號機的參數(shù),然后執(zhí)行步驟7。步驟12、仿真統(tǒng)計數(shù)據(jù)生成;交互智能體3調(diào)用仿真結(jié)果處理智能體4的統(tǒng)計結(jié)果生成服務,將生成的統(tǒng)計數(shù)據(jù)上傳到交互智能體3,然后執(zhí)行步驟13。步驟13、統(tǒng)計數(shù)據(jù)顯示與結(jié)束;仿真客戶端1通過交互智能體3的仿真數(shù)據(jù)獲取服務獲得最終的統(tǒng)計數(shù)據(jù)結(jié)果并顯示,整個分布式仿真任務結(jié)束,等待下一個仿真任務的到來。最后,為了驗證本發(fā)明的分布式交通仿真平臺的可行性,本文選擇了某區(qū)內(nèi)一真實路網(wǎng)進行實驗,路網(wǎng)如圖5所示。整個路網(wǎng)被分成3個子區(qū)域,用虛線框與實線框分出,路網(wǎng)內(nèi)設置了3條公交線路Linel:A1-A2-A14-A15-A16-A17-A18-A19-A7-A8-A9-A21-A31-A32-A33-A34,共有7站;Line2:A25-A26-A27-A28-A16-A17-A18-A19-A29-A30-A31-A21-A22-A23-A24,共有8站;Line3:A35-A36-A37-A38-A39-A28-A29-A40-A41-A42-A43,共有7站;每條線路上、下行方向共有20輛公交車,發(fā)車間隔為1分鐘,公交車輛的平均速度為12米/秒,社會車輛以交通流方式在路口處注入,信號控制采用半感應控制,信號周期為120秒,最小綠燈時間為20秒,最大綠燈時間為60秒,仿真時間設定為1小時。整個分布式仿真耗時87秒,證明了本發(fā)明的分布式交通仿真平臺的高效性。三條線路的平均旅行時間分別為1303.10秒,1159.58秒和1096.32秒。此外,本文統(tǒng)計了路口公交車輛通過數(shù)(APB)與公交車輛路口平均延誤(AD,秒)兩個指標,如圖6所示。以路口A8和A12為例,通過路口A8的公交車數(shù)量為96,公交車平均延誤為11.47秒;路口A12沒有公交車通過,則其平均延誤時間無法統(tǒng)計。分布式仿真所得數(shù)據(jù)與單機仿真程序所得數(shù)據(jù)基本一致,表明分布式仿真平臺可以正確模擬車輛的行為,驗證了其正確性。權(quán)利要求基于面向服務架構(gòu)的分布式交通仿真平臺,其特征在于,包括四層結(jié)構(gòu)用戶界面層、協(xié)調(diào)仿真多智能體層、數(shù)據(jù)服務中心層與仿真資源層;其中,用戶界面層包括仿真客戶端和數(shù)據(jù)維護客戶端;協(xié)調(diào)仿真多智能體層包括交互智能體、路網(wǎng)生成智能體、協(xié)調(diào)智能體、仿真結(jié)果處理智能體與區(qū)域仿真模塊,區(qū)域仿真模塊由VC區(qū)域仿真模塊組成;數(shù)據(jù)服務中心層包括數(shù)據(jù)服務中心,而數(shù)據(jù)服務中心又包括HibernateORM子模塊、數(shù)據(jù)生成子模塊和數(shù)據(jù)調(diào)遣子模塊;仿真資源層是Oracle數(shù)據(jù)庫;用戶界面層中的仿真客戶端通過訪問協(xié)調(diào)仿真多智能體層中的交互智能體的仿真啟動服務,下達仿真任務,并在仿真過程中通過交互智能體的仿真數(shù)據(jù)獲取服務,獲得最終的統(tǒng)計數(shù)據(jù)結(jié)果和實時仿真結(jié)果,并將其顯示;用戶界面層中的數(shù)據(jù)維護客戶端,用來完成路網(wǎng)數(shù)據(jù)與信號機參數(shù)的添加、修改、查詢與刪除;協(xié)調(diào)仿真多智能體層中的交互智能體,連接著仿真客戶端與仿真平臺內(nèi)部組件,向外提供仿真啟動、仿真數(shù)據(jù)獲取與仿真結(jié)果上傳三個服務;交互智能體接受仿真任務,根據(jù)仿真任務,確定仿真區(qū)域以及參與仿真的區(qū)域仿真模塊中的VC區(qū)域仿真模塊,并調(diào)用數(shù)據(jù)服務中心層中數(shù)據(jù)服務中心的數(shù)據(jù)生成子模塊的服務,然后等區(qū)域仿真路網(wǎng)數(shù)據(jù)準備完畢后初始化VC區(qū)域仿真模塊,當所有的VC區(qū)域仿真模塊初始化結(jié)束后,仿真啟動服務開始調(diào)用協(xié)調(diào)仿真多智能體層中的協(xié)調(diào)智能體的協(xié)調(diào)初始化服務,并在仿真過程中接收協(xié)調(diào)仿真多智能體層中的仿真結(jié)果處理智能體通過仿真結(jié)果上傳服務上傳的實時仿真結(jié)果;仿真結(jié)果處理智能體,提供實時結(jié)果上傳服務與統(tǒng)計結(jié)果生成服務;各VC區(qū)域仿真模塊調(diào)用仿真結(jié)果處理智能體的實時結(jié)果上傳服務,向仿真結(jié)果處理智能體更新本周期的仿真實時信息,而仿真結(jié)果處理智能體通過仿真結(jié)果上傳服務,上傳實時仿真結(jié)果給交互智能體;協(xié)調(diào)智能體,向交互智能體提供協(xié)調(diào)初始化服務,內(nèi)部包括協(xié)調(diào)判定服務與信號調(diào)整服務;協(xié)調(diào)智能體的協(xié)調(diào)初始化服務被調(diào)用時,首先開辟多個線程,接著循環(huán)執(zhí)行線程調(diào)用各VC區(qū)域仿真模塊的周期仿真服務,并在每一個仿真周期中根據(jù)上一周期仿真結(jié)果判斷是否需要區(qū)域協(xié)調(diào),若當前仿真周期無需進行區(qū)域間協(xié)調(diào),則協(xié)調(diào)智能體繼續(xù)調(diào)用VC區(qū)域仿真模塊的周期仿真服務,實現(xiàn)給定周期內(nèi)的區(qū)域交通仿真,若當前仿真周期需要進行區(qū)域間協(xié)調(diào),則協(xié)調(diào)智能體調(diào)用信號調(diào)整服務進行決策;區(qū)域仿真模塊,內(nèi)部嵌入SOA接入模塊,向交互智能體提供區(qū)域仿真初始化服務,向協(xié)調(diào)智能體提供周期仿真服務;區(qū)域仿真模塊產(chǎn)生交通流與車源,模擬車輛的運動行為,負責所屬子區(qū)域的仿真;VC區(qū)域仿真模塊調(diào)用數(shù)據(jù)服務中心的數(shù)據(jù)調(diào)遣子模塊的服務,獲取區(qū)域仿真路網(wǎng)數(shù)據(jù);路網(wǎng)生成智能體作為數(shù)據(jù)解析部分嵌入SOA接入模塊,向VC區(qū)域仿真模塊提供路網(wǎng)生成服務,路網(wǎng)生成服務從數(shù)據(jù)服務中心獲得路網(wǎng)與信號機的SDO數(shù)據(jù)對象,并轉(zhuǎn)換成區(qū)域仿真模塊對應的數(shù)據(jù)結(jié)構(gòu)類型,使數(shù)據(jù)適用于區(qū)域仿真模塊;數(shù)據(jù)服務中心包括3個子模塊①HibernateORM子模塊,完成對象-關(guān)系映射,實現(xiàn)基于對象原語的數(shù)據(jù)建立,并將其持久化到仿真資源層中的Oracle數(shù)據(jù)庫中;②數(shù)據(jù)生成子模塊提供數(shù)據(jù)生成服務,從Oracle數(shù)據(jù)庫中獲取分布式交通仿真所需要的路網(wǎng)信息,并將其封裝為SDO數(shù)據(jù);③數(shù)據(jù)調(diào)遣子模塊提供數(shù)據(jù)調(diào)遣服務,通過WebService獲取路網(wǎng)生成智能體的仿真原始數(shù)據(jù)發(fā)送請求,將生成的SDO數(shù)據(jù)發(fā)送到區(qū)域仿真模塊;Oracle數(shù)據(jù)庫,存儲仿真所需的路網(wǎng)數(shù)據(jù)信息與信號機配置信息;交互智能體、協(xié)調(diào)智能體、仿真結(jié)果處理智能體以及數(shù)據(jù)服務中心采用服務組件架構(gòu)SCA規(guī)范,并各自封裝成SCA構(gòu)件;已有的單機仿真程序模塊則通過SOA接入模塊作為區(qū)域仿真模塊接入仿真平臺中;系統(tǒng)的區(qū)域協(xié)調(diào)仿真基于邏輯時鐘同步,每個仿真模塊調(diào)用或提供粗粒度的服務,基于不同的仿真服務,仿真平臺完成大規(guī)模的分布式交通仿真;其中,SOA代表面向服務架構(gòu),SCA代表服務組件架構(gòu),VC即VisualC++,SDO即ServicedataObjects,ORM代表對象-關(guān)系數(shù)據(jù)庫映射。2.根據(jù)權(quán)利要求1所述的基于面向服務架構(gòu)的分布式交通仿真平臺,其特征在于,所述的VC區(qū)域仿真模塊,指用VisualC++實現(xiàn)的單機仿真程序模塊,通過SOA接入模塊接入?yún)^(qū)域仿真模塊。3.根據(jù)權(quán)利要求1或2所述的基于面向服務架構(gòu)的分布式交通仿真平臺,其特征在于,所述的SOA接入模塊由兩個部分組成服務綁定模塊與服務調(diào)用模塊;服務綁定模塊采用SCAJava構(gòu)件實現(xiàn),包括數(shù)據(jù)解析子模塊和Socket請求子模塊,其應用原理為首先,服務綁定模塊接受SOA環(huán)境中的服務調(diào)用請求,并獲得SDO數(shù)據(jù);接著,數(shù)據(jù)解析子模塊解析SDO數(shù)據(jù),并通過Socket請求子模塊將數(shù)據(jù)經(jīng)Socket連接發(fā)送到VC單機仿真程序模塊,VC單機仿真程序模塊與SOA接入模塊位于同一臺計算機上,VC單機仿真程序模塊接收數(shù)據(jù)執(zhí)行其自身仿真程序的相關(guān)操作;然后,VC單機仿真程序模塊通過Socket連接將結(jié)果返回到服務綁定模塊;最后,服務綁定模塊將返回得數(shù)據(jù)結(jié)果封裝成SDO數(shù)據(jù)對象,并返回給服務調(diào)用者;服務調(diào)用模塊則采用COM組件的實現(xiàn)方式,包括服務引用子模塊和數(shù)據(jù)轉(zhuǎn)換子模塊,服務引用子模塊采用CLR托管程序開發(fā),并以DLL形式生成;VC單機仿真程序模塊通過COM組件接口調(diào)用服務引用子模塊,實現(xiàn)仿真服務的引用,并得到SDO數(shù)據(jù);數(shù)據(jù)轉(zhuǎn)換子模塊解析SDO數(shù)據(jù)并進行重新組合,使數(shù)據(jù)存儲格式與VC單機仿真程序模塊中的一致;其中,COM代表組件對象模型,CLR代表公共語言運行時,DLL代表動態(tài)鏈接庫。4.根據(jù)權(quán)利要求1所述的基于面向服務架構(gòu)的分布式交通仿真平臺,其特征在于,所述的交互智能體采用SCAJava構(gòu)件實現(xiàn),提供的三個服務具體為仿真啟動服務的輸入?yún)?shù)是仿真客戶端發(fā)送的仿真請求SDO數(shù)據(jù),仿真啟動服務通知數(shù)據(jù)服務中心生成對應路網(wǎng)的數(shù)據(jù),并根據(jù)區(qū)域個數(shù)創(chuàng)建若干線程用于啟動區(qū)域仿真模塊;仿真數(shù)據(jù)獲取服務的返回參數(shù)是SDO數(shù)據(jù),包含當前仿真時刻車輛與信號機的狀態(tài);仿真結(jié)果上傳服務的輸入是仿真過程中產(chǎn)生的實時數(shù)據(jù)與仿真結(jié)束后生成的統(tǒng)計數(shù)據(jù)。5.根據(jù)權(quán)利要求1所述的基于面向服務架構(gòu)的分布式交通仿真平臺,其特征在于,所述的仿真結(jié)果處理智能體采用SCAJava構(gòu)件實現(xiàn),提供的兩個服務具體為實時結(jié)果上傳服務的輸入?yún)?shù)為仿真實時數(shù)據(jù),包括公交車輛經(jīng)緯度與信號燈狀態(tài)信息;統(tǒng)計結(jié)果生成服務的輸入?yún)?shù)為各路口歷史狀態(tài),其根據(jù)歷史狀態(tài)計算區(qū)域信號控制整體指標,包括各路口的公交車平均延誤時間,各條公交線路的平均旅行時間。6.根據(jù)權(quán)利要求1所述的基于面向服務架構(gòu)的分布式交通仿真平臺,其特征在于,所述的協(xié)調(diào)智能體采用SCAJava構(gòu)件實現(xiàn),其提供的三個服務具體為協(xié)調(diào)初始化服務的輸入?yún)?shù)是參與仿真的區(qū)域仿真模塊的編號;協(xié)調(diào)判定服務的輸入?yún)?shù)是包括公交車延誤與排隊長度在內(nèi)的路口狀態(tài)信息,返回值是協(xié)調(diào)方案決策;信號調(diào)整服務的輸入?yún)?shù)是協(xié)調(diào)方案與協(xié)調(diào)區(qū)域當前信號狀態(tài),返回值是調(diào)整后的信號參數(shù)。7.應用權(quán)利要求1所述的基于面向服務架構(gòu)的分布式交通仿真平臺的仿真方法,其特征在于,包括如下步驟步驟1、仿真啟動;仿真客戶端訪問交互智能體的仿真啟動服務,交互智能體根據(jù)仿真任務確定仿真區(qū)域以及參與仿真的VC區(qū)域仿真模塊;步驟2、數(shù)據(jù)準備;交互智能體調(diào)用數(shù)據(jù)服務中心的數(shù)據(jù)生成子模塊的服務,數(shù)據(jù)服務中心從Oracle數(shù)據(jù)中獲取原始的路網(wǎng)數(shù)據(jù),并按區(qū)域?qū)?shù)據(jù)重組并封裝成SDO數(shù)據(jù)對象,生成區(qū)域仿真路網(wǎng)數(shù)據(jù),數(shù)據(jù)準備完畢后,交互智能體初始化區(qū)域仿真模塊并同時等待初始化完成;步驟3、初始化區(qū)域仿真模塊,包括步驟3.1與步驟3.2,這兩個步驟都是多任務并發(fā);步驟3.l,仿真啟動服務根據(jù)參與仿真的VC區(qū)域仿真模塊的數(shù)量開辟多線程,在多線程中調(diào)用區(qū)域仿真初始化服務;步驟3.2,仿真啟動服務在主線程中通過標志位等待步驟3.1中的仿真初始化完成;步驟4、獲取區(qū)域仿真路網(wǎng)數(shù)據(jù);各VC區(qū)域仿真模塊通過調(diào)用路網(wǎng)生成智能體的路網(wǎng)生成服務,獲取在步驟2生成的區(qū)域仿真路網(wǎng)數(shù)據(jù);步驟5、區(qū)域協(xié)調(diào)仿真啟動,具體為步驟5.1,當所有的VC區(qū)域仿真模塊初始化結(jié)束后,仿真啟動服務開始調(diào)用協(xié)調(diào)智能體的協(xié)調(diào)初始化服務,此時仿真啟動服務的生命周期結(jié)束;步驟5.2,仿真客戶端開始循環(huán)調(diào)用交互智能體的仿真數(shù)據(jù)獲取服務,獲取公交車輛當前時刻坐標,干線、路口交通流情況以及各信號當前相位,協(xié)調(diào)智能體的協(xié)調(diào)初始化服務首先開辟多個線程,并循環(huán)執(zhí)行線程,調(diào)用各VC區(qū)域仿真模塊的周期仿真服務;步驟6、區(qū)域協(xié)調(diào)控制;協(xié)調(diào)智能體在每一個仿真周期中首先根據(jù)上一周期仿真結(jié)果判斷是否需要區(qū)域協(xié)調(diào),若當前仿真周期無需進行區(qū)域間協(xié)調(diào),則執(zhí)行步驟7,若當前仿真周期需要進行區(qū)域間協(xié)調(diào),則轉(zhuǎn)到步驟10;步驟7、周期性區(qū)域協(xié)調(diào)仿真;協(xié)調(diào)智能體調(diào)用區(qū)域仿真模塊的周期仿真服務,實現(xiàn)給定周期內(nèi)的區(qū)域交通仿真,根據(jù)子區(qū)域所處的位置進行邊界信息的更新,包括社會車輛交通流信息與公交車位置信息,然后執(zhí)行步驟8;步驟8、生成實時交通仿真數(shù)據(jù);各vc區(qū)域仿真模塊調(diào)用仿真結(jié)果處理智能體的實時結(jié)果上傳服務,向仿真結(jié)果處理智能體更新本周期的仿真實時信息,包括公交車輛經(jīng)緯度,行駛方向,信號狀態(tài);步驟9、仿真狀態(tài)判定與數(shù)據(jù)上載,包括步驟9.1與步驟9.2;步驟9.l,本周期的仿真實時信息更新后,仿真結(jié)果處理智能體通過交互智能體的仿真結(jié)果上傳服務,上傳實時仿真結(jié)果給交互智能體,仿真客戶端能夠通過交互智能體的仿真數(shù)據(jù)獲取服務,獲得實時仿真結(jié)果并顯示;步驟9.2,協(xié)調(diào)智能體根據(jù)仿真時間判斷整個仿真過程是否結(jié)束,若仿真沒有結(jié)束則循環(huán)進行下一周期的仿真,執(zhí)行步驟6;否則結(jié)束區(qū)域仿真,執(zhí)行步驟12;步驟10、協(xié)調(diào)控制決策;協(xié)調(diào)智能體調(diào)用信號調(diào)整服務進行決策;步驟11、更新信號機參數(shù);根據(jù)步驟10信號調(diào)整服務的結(jié)果在下一個仿真周期中更新信號機的參數(shù),然后執(zhí)行步驟7;步驟12、仿真統(tǒng)計數(shù)據(jù)生成;交互智能體調(diào)用仿真結(jié)果處理智能體的統(tǒng)計結(jié)果生成服務,將生成的統(tǒng)計數(shù)據(jù)上傳到交互智能體,然后執(zhí)行步驟13;步驟13、統(tǒng)計數(shù)據(jù)顯示與結(jié)束;仿真客戶端通過交互智能體的仿真數(shù)據(jù)獲取服務獲得最終的統(tǒng)計數(shù)據(jù)結(jié)果并顯示,整個分布式仿真任務結(jié)束,并等待下一個仿真任務的到來。全文摘要本發(fā)明公開了一種基于面向服務架構(gòu)(Service-OrientedArchitecture,SOA)的分布式交通仿真平臺及其仿真方法,主要包括交互智能體、仿真結(jié)果處理智能體、協(xié)調(diào)智能體、路網(wǎng)生成智能體、區(qū)域仿真模塊及數(shù)據(jù)服務中心等幾個模塊,通過不同智能體的相互協(xié)調(diào)完成基于大規(guī)模真實路網(wǎng)的仿真。本發(fā)明模塊采用服務組件架構(gòu)SCA、VisualC++和VisualBasic實現(xiàn)。此外,本發(fā)明設計了基于SCA的SOA接入模塊,用于集成已有的單機仿真程序,滿足了分布式仿真平臺對異構(gòu)性的要求,提高了系統(tǒng)的靈活性,業(yè)務模型的可重用性與服務的可互操作性,并使得系統(tǒng)更加易于集成。文檔編號G08G1/00GK101710361SQ20091026038公開日2010年5月19日申請日期2009年12月17日優(yōu)先權(quán)日2009年11月13日發(fā)明者劉倩,姜秉楠,張海,郭欣蕾申請人:北京航空航天大學