莊夢婷
安徽財(cái)經(jīng)大學(xué)統(tǒng)計(jì)與應(yīng)用數(shù)學(xué)學(xué)院,中國·安徽 蚌埠 233030
同城配送存在路徑迂回問題,所謂迂回運(yùn)輸就是沒有從最短的路線運(yùn)輸,而是繞道運(yùn)輸?shù)男问?,如因到達(dá)地區(qū)順序不同而導(dǎo)致的總路徑變長。物流公司不能以最近的公路運(yùn)輸,將會直接影響公司的運(yùn)輸效率降低,也會導(dǎo)致不必要的運(yùn)輸成本增加[1]。而道路迂回問題是在很多物流配送過程中存在的問題。
配送車輛承載量的約束條件:每輛貨車都存在其重量承載量以及體積承載量,考慮到承載量的問題,每輛貨車所承載的貨物有限。綜合考慮不同城區(qū)物流件數(shù)之間存在的差異,派送車輛數(shù)量成為一個問題。時間約束因素包括即物流配送過程貨物有要求到達(dá)時間、大部分同城運(yùn)輸都要求在當(dāng)天完成貨物配送,其他因素包括路段時速限制、堵車的可能性、天氣限速。
針對起點(diǎn)到終點(diǎn)只有一種運(yùn)輸方式可供選擇,即直達(dá)的情況,我們擬建立模擬退火模型從運(yùn)輸路徑角度進(jìn)行優(yōu)化;綜合考慮車的承載量以及不同地區(qū)訂單數(shù)存在的差異的問題,利用聚類分析,將地區(qū)進(jìn)行分類,在不同地區(qū)上利用模擬退火算法進(jìn)行不同區(qū)域的最短路徑計(jì)算。具體包括:發(fā)貨點(diǎn)和收貨點(diǎn)的設(shè)置;規(guī)劃適當(dāng)?shù)穆肪€;使運(yùn)輸車輛能夠有序地通過計(jì)劃中的地點(diǎn)以及完成貨物的需求量和發(fā)貨量,并且滿足交貨時間,即達(dá)到實(shí)現(xiàn)最短時間內(nèi);最短運(yùn)輸成本下完成相應(yīng)的目標(biāo),去掉在路上的“浪費(fèi)”[2]。
模擬退火是一種通用概率算法,用來在一個大的搜尋空間內(nèi)找尋命題的最優(yōu)解。其來源于固體退火原理,將固體加溫至充分高,再讓其徐徐冷卻。加溫時,固體內(nèi)部粒子隨溫升變?yōu)闊o序狀,內(nèi)能增大,而徐徐冷卻時粒子漸趨有序,在每個溫度都達(dá)到平衡態(tài),最后在常溫時達(dá)到基態(tài),內(nèi)能減為最小[3]。對于地點(diǎn)之間的轉(zhuǎn)移概率矩陣兩兩相互之間是互通的,即可得出該轉(zhuǎn)移矩陣對應(yīng)的有限的馬爾科夫鏈?zhǔn)鞘諗康?。收斂說明過程將達(dá)到平衡狀態(tài),即此后過程取某一個狀態(tài)的概率不隨時間變化[4]。
①解空間S表示為{2,3, ,}n,1 … 的所有起點(diǎn)和終點(diǎn)的循環(huán)排列集合,即:
其中,每一個循環(huán)排列表示運(yùn)輸完n個運(yùn)輸點(diǎn)的一個回路,πi=m 表示在第i-1次運(yùn)輸目標(biāo)m,初始解可選為(1 , 2,3,…, n),這里使用蒙特卡洛法求得一個比較好的初始解。
②目標(biāo)函數(shù):目標(biāo)函數(shù)為一次走過所有運(yùn)輸點(diǎn)的路徑長度,即:
③新解的產(chǎn)生。設(shè)上一步迭代的解為:
應(yīng)用變換法時,任選序號u,v交換u和v之間的順序,變成逆序,此時的新路徑為:
④代價函數(shù)差:對于2變換法,路徑差可表示為:
⑤接受準(zhǔn)則:
⑥降溫:利用選定的降溫系數(shù)α進(jìn)行降溫,取新的溫度T為αT(這里T為上一步迭代的溫度),這里選定α = 0.999。
⑦結(jié)束條件:用選定的終止溫度e = 10-30,判斷退火過 程是否結(jié)束。若T<e,則算法結(jié)束,輸出當(dāng)前狀態(tài)[5]。
求解過程如模擬退火流程圖1所示。
圖1 模擬退火流程圖
由案例以及網(wǎng)上搜索可得到中國北京市某次單運(yùn)輸方式任務(wù)的物流采購點(diǎn)以及產(chǎn)品運(yùn)輸點(diǎn),并將中國北京市需要運(yùn)輸?shù)倪\(yùn)輸點(diǎn)以坐標(biāo)點(diǎn)的形式寫在一個平面上。
根據(jù)上述流程圖,我們?yōu)榭臻g設(shè)計(jì)了LINGO自動診斷的代碼,只要將某次需要向外運(yùn)輸或者采購原材料的運(yùn)輸點(diǎn)坐標(biāo)數(shù)據(jù)輸入并在程序中加入循環(huán)語句,運(yùn)行出運(yùn)行結(jié)果,得到最短運(yùn)輸路徑。這條運(yùn)輸路徑能保證運(yùn)輸人員在無一運(yùn)輸點(diǎn)遺漏的情況下,所走的運(yùn)輸路徑最短,也就是說此時達(dá)到了路徑的優(yōu)化。
為了更好地體現(xiàn)模擬退火模型在單一運(yùn)輸方式上的運(yùn)輸效果,我們以中國北京市某次運(yùn)輸案例為例,運(yùn)用模擬退火模型對路徑進(jìn)行優(yōu)化設(shè)計(jì)。選取中國北京市為例,提貨區(qū)為朝陽區(qū),剩余地區(qū)為所需配送地區(qū)。
距離矩陣如下表1所示。
表1 北京市各區(qū)距離矩陣
在不考慮訂單量的約束條件下,貨物從起點(diǎn)出發(fā),送達(dá)各目的地對應(yīng)的編號如表2所示[6]。
表2 地區(qū)編號
目標(biāo)函數(shù)為尋找從點(diǎn)出發(fā),遍歷中間點(diǎn),返回n的最短路徑。在計(jì)算機(jī)上運(yùn)行以上程序,總運(yùn)輸距離為462km,運(yùn)輸路徑為1-15-14-3-2-7-6-8-16-13-5-12-11-10-4-9,表明從朝陽區(qū)出發(fā),經(jīng)過東城區(qū)、西城區(qū)、海淀區(qū)、豐臺區(qū)、大興區(qū)、房山區(qū)、石景山區(qū)、門頭溝區(qū)、延慶區(qū)、昌平區(qū)、懷柔區(qū)、密云區(qū)、平谷區(qū)、順義區(qū),最終回到通州區(qū)。
考慮到訂單量的情況下,將中國北京市16各地區(qū)首先要根據(jù)地理位置進(jìn)行分類,再結(jié)合訂單多、少相互配合,聚類圖如下圖2所示[7]。
圖2 聚類結(jié)果圖
將地區(qū)分為三類:
第一類為順義區(qū)、平谷區(qū)、密云區(qū)、柔懷區(qū)、昌平區(qū)、延慶區(qū),這些地區(qū)中,順義區(qū)訂單最多,其余地區(qū)訂單較少,恰好滿足貨車的承載量需求。
第二類為在滿足貨車承載量的前提下訂單量較多的通州區(qū)和大興區(qū)。
第三類為東城區(qū),西城區(qū)、海淀區(qū)訂單較多和門頭溝區(qū)和房山區(qū)訂單較少的地區(qū)組成。重復(fù)上述計(jì)算過程,得出每個區(qū)的最短路徑和總路徑。
結(jié)果顯示,第一類的路徑為朝陽區(qū)、順義區(qū)、平谷區(qū)、密云區(qū)、柔懷區(qū)、昌平區(qū)、延慶區(qū),最終回到朝陽區(qū),路徑長度為333km。第二類路徑為從朝陽區(qū)出發(fā),先結(jié)果通州區(qū),再到大興區(qū),最后回到朝陽區(qū),路徑長度為98km。第三類路徑為朝陽區(qū)、東城區(qū)、海淀區(qū)、石景山區(qū)、門頭溝區(qū)、房山區(qū)、豐臺區(qū)、西城區(qū),最后回到朝陽區(qū),該路徑長度為127km。三類區(qū)域總路徑為558km。
由算例分析,我們可以發(fā)現(xiàn)模擬退火算法的優(yōu)點(diǎn)和在應(yīng)用中進(jìn)行推廣的原因:
①在用模擬退火模型處理最短路徑問題的時候,編程工作量少,且易于實(shí)現(xiàn),統(tǒng)計(jì)上可以保證找到全局最優(yōu)解。
②模擬退火算法是一種新的隨機(jī)搜索方法,適合于解決大規(guī)模組合優(yōu)化問題的通用而有效的近似算法。因此,也適用于論文中的運(yùn)輸優(yōu)化問題。
③與以往的近似算法相比,模擬退火算法具有描述簡單、使用靈活、運(yùn)用廣泛、運(yùn)行效率高和較少受到初始條件約束等優(yōu)點(diǎn)。
④模擬退火在找到最優(yōu)解時需要花費(fèi)非常多的時間,當(dāng)冷卻速度過快時,會導(dǎo)致模擬退火無法找到最優(yōu)解,但速度過慢,又會導(dǎo)致運(yùn)行時間變長。
此模型可以對各類運(yùn)輸問題的路徑進(jìn)行優(yōu)化,只要將運(yùn)輸點(diǎn)數(shù)量輸入程序和將運(yùn)輸點(diǎn)變換為坐標(biāo)格式,就能得到一次性走過各點(diǎn)的最短路徑,避免了重復(fù)走在運(yùn)輸上的“浪費(fèi)”,這也是基于節(jié)能減排理念的一種物流優(yōu)化。利用此方法,可以將很多交通以及其他方面的交通運(yùn)輸問題達(dá)到路徑最優(yōu)化,從而實(shí)現(xiàn)高效的交通運(yùn)輸速度。