《遼寧大學(xué)智能控制課件《蟻群優(yōu)化算法》.ppt》由會員分享,可在線閱讀,更多相關(guān)《遼寧大學(xué)智能控制課件《蟻群優(yōu)化算法》.ppt(60頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、第五部分,蟻群優(yōu)化算法Ant Colony Optimization,參考文獻,M. Dorigo and T. Stutzle, Ant Colony OptimizationM: MIT Press, 2004 段海濱,蟻群算法原理極其應(yīng)用M,2007.科學(xué)出版社,0 蟻群優(yōu)化算法的歷史沿革,意大利學(xué)者Marco Dorigo(Alberto Colorni)于1991年在其博士論文中提出。 和Vittorio Maniezzo一同設(shè)計了第一個ACO算法螞蟻系統(tǒng)(Ant System)。 在真實螞蟻覓食行為的啟發(fā)下提出的一種高度創(chuàng)新性的啟發(fā)式算法。,Marco Dorigo,Macro D
2、origo,重要文獻,Colorni等,1994,“Ant System for Job-shop Scheduling” Colorni等,1996,“Heuristics From Natrure for Hard Combinatorial Optimization Problems” Dorigo M等,1996,“Ant system: optimization by a colony of cooperating agents”,Ant system: optimization by a colony of cooperating agents,更加系統(tǒng)地闡述了蟻群算法的基本原理和
3、數(shù)學(xué)模型; 與遺傳算法、禁忌搜索算法、模擬退火算法、爬山法等進行了仿真實驗比較; 把單純地解決對稱TSP拓展到解決非對稱TSP、QAP和JSP; 對蟻群算法中的初始化參數(shù)對性能的影響做了初步探討; 蟻群算法發(fā)展史上的一篇奠基性文章。,近期發(fā)展,2000年,Dorigo M和Bonabeau E等在Nature上發(fā)表蟻群算法的研究綜述,把這一領(lǐng)域的研究推向了國際學(xué)術(shù)的最前沿; 進入21世紀的最近幾年里,Nature曾多次對蟻群算法的研究成果進行報告。,相關(guān)書籍,2004年9月,Marco Dorigo and Thomas SttzleAnt Colony Optimization; 系統(tǒng)介紹蟻
4、群算法,為蟻群算法的傳播和科普做出了很重要一步; 2007年翻譯成中文出版。,理論建設(shè),在理論建設(shè)方面,ACO取得的成果比較少,也是最薄弱的一方面。 1999年Gutjahr W J的技術(shù)報告和2000年的論文中首次對蟻群算法的收斂性進行了證明。 將蟻群算法的行為簡化為在一幅代表所求問題的有向圖上的隨機行走過程,進而從有向圖論的角度對一種改進蟻群算法圖搜索螞蟻系統(tǒng)(Graph-Based Ant System,GBAS)的收斂性進行了理論分析。 采用的數(shù)學(xué)工具是Markov鏈,證明了在一些合理的假設(shè)條件下他所提出的GBAS能以一定概率收斂到所求問題的最優(yōu)解。,蟻群優(yōu)化算法的發(fā)展,精華螞蟻系統(tǒng)(
5、Elitist Strategy for Ant System,EAS) 對解構(gòu)造過程中表現(xiàn)優(yōu)異的人工螞蟻給予特殊的信息素釋放獎勵; Ant-Q算法 將蟻群算法與Q學(xué)習算法結(jié)合,利用多個人工螞蟻的協(xié)同效應(yīng); 后期 蟻群系統(tǒng)(Ant Colony System,ACS), 基于排序的螞蟻系統(tǒng)(Rank Based version AS,ASrank), 最大最小螞蟻系統(tǒng)(Max-Min Ant System,MMAS),蟻群優(yōu)化算法的應(yīng)用,路由類問題 旅行商、車輛路由、順序排列等 分配類問題 二次分配、圖著色、廣義分配、頻率分配、大學(xué)生課程時間表等 調(diào)度類問題 工序車間、開放車間、工作流車間、總
6、延遲、總權(quán)重延遲、項 目調(diào)度、組車間等,蟻群優(yōu)化算法的應(yīng)用,子集類問題 多重背包、最大獨立集、冗余分配、集合覆蓋、帶權(quán)約束圖樹分割、邊帶權(quán)l(xiāng)-基樹、最大圖等 機器學(xué)習類問題 分配規(guī)則、貝葉斯網(wǎng)絡(luò)、模糊系統(tǒng)等 網(wǎng)絡(luò)路由類問題 面向連接的網(wǎng)絡(luò)路由、無連接的網(wǎng)絡(luò)路由、光學(xué)網(wǎng)絡(luò)路由等,1 蟻群優(yōu)化算法的生物學(xué)基礎(chǔ),阿根廷螞蟻 雙橋?qū)嶒?實驗結(jié)果(1),摘自Ant Colony Optimization,實驗結(jié)果(2),摘自Ant Colony Optimization,實驗結(jié)果(3),摘自Ant Colony Optimization,障礙實驗,摘自Ant System: Optimization b
7、y A Colony of Cooperating Agents,生物螞蟻的特點,沒有視覺 計算與記憶能力有限 依賴信息素(pheromone)通信、協(xié)作 釋放 揮發(fā) 正反饋,2 人工蟻群系統(tǒng),人工螞蟻與生物螞蟻的區(qū)別 人工螞蟻具有一定的記憶能力 人工螞蟻具有一定的視力(啟發(fā)) 人工螞蟻生活在離散的時間環(huán)境中,人工蟻群模型,摘自Ant System: Optimization by A Colony of Cooperating Agents,人工蟻群,a) 初始狀態(tài); b) t=0,無信息素,人工螞蟻以等概率選擇左 轉(zhuǎn)或右轉(zhuǎn); c) t=1 ,較短的路徑上信息素濃度較高,人工 螞蟻以較高
8、的概率選擇信息素濃度高的路徑,實例:TSP,Graph (N,E) Euclidean距離 螞蟻數(shù)量,實例:TSP,人工螞蟻的行為 路徑選擇的概率是城市距離和路徑上信息素濃度的函數(shù); 符合TSP規(guī)則; 完成一次旅行后,在經(jīng)過的路徑上釋放信息素; 無需按原路返回。,實例:TSP(參數(shù)與機制),路徑上的信息素濃度 信息素更新 信息素釋放(ant-cycle),實例:TSP(參數(shù)與機制),路徑選擇概率,TSP蟻群算法(ant-cycle),Step 1 Initialize: Set t:=0 t is the time counter Set NC:=0 NC is the cycles coun
9、ter For every edge (i,j) set an initial value for trail intensity and Place the m ants on the n nodes,TSP蟻群算法(ant-cycle),Step 2 Set s:=1 s is the tabu list index For k:=1 to m do Place the starting town of the k-th ant in tabuk(s),TSP蟻群算法(ant-cycle),Step 3 Repeat until tabu list is full this ste
10、p will be repeated (n-1) times Set s:=s+1 For k:=1 to m do Choose the town j to move to, with probability at time t the k-th ant is on town i=tabuk(s-1) Move the k-th ant to the town j Insert town j in tabuk (s),TSP蟻群算法(ant-cycle),Step 4.1 For k:=1 to m do Move the k-th ant from tabuk(n) to tabuk(
11、1) Compute the length Lk of the tour described by the k-th ant Update the shortest tour found,TSP蟻群算法(ant-cycle),Step 4.2 For every edge (i,j) For k:=1 to m do,TSP蟻群算法(ant-cycle),Step 5 For every edge (i,j) compute according to equation Set t:=t+n Set NC:=NC+1 For every edge (i,j) set,TSP蟻群算法(ant
12、-cycle),Step 6 If (NC < NCMAX) and (not stagnation behavior) then Empty all tabu lists Goto step 2 else Print shortest tour Stop,3 蟻群算法調(diào)整與參數(shù)設(shè)置,:信息素的相對重要性; :啟發(fā)性因素的相對重要性; :信息素殘留因子; Q :常數(shù),控制信息素的釋放; m :蟻群規(guī)模; 其他: 蟻群的初始分布,信息素釋放算法ant-cycle,ant-cycle,信息素釋放算法ant-density,ant-density,信息素釋放算法ant-quantity,ant-
13、quantity,信息素釋放算法對比,測試集: Oliver30 problem 循環(huán)次數(shù):NCMAX=5000 測試次數(shù):10,摘自Ant Colony Optimization,GA:424.635,實驗數(shù)據(jù)1 ant-cycle,摘自Ant Colony Optimization,實驗數(shù)據(jù)2 ant-cycle,摘自Ant Colony Optimization,實驗數(shù)據(jù)3 ant-cycle,摘自Ant Colony Optimization,參數(shù):,ant-cycle NCMAX=5000,摘自Ant Colony Optimization,蟻群規(guī)模:m,ant-cycle 4x4
14、grid,,摘自Ant Colony Optimization,蟻群初始分布,均勻分布優(yōu)于集中(單一城市)分布 隨機分布略好于均勻分布,算法復(fù)雜度,O(NCn2m) step 1 : O(n2+m), step 2 : O(m), step 3 : O(n2m), step 4 : O(n2m), step 5 : O(n2), step 6 : O(nm).,實驗數(shù)據(jù)(算法復(fù)雜度),摘自Ant Colony Optimization,4 實例:JSP,Job-shop Scheduling Problem M:機器數(shù)量 J :任務(wù)數(shù) ojm:工序 djm:工時 :工序集合,JSP(M
15、uth & Thompson 6x6),JSP,3x2 problem,JSP,路徑選擇,JSP,待訪問節(jié)點集合: 下一步允許訪問節(jié)點集合: 算法結(jié)束:,,5 實例:PID參數(shù)整定,整定參數(shù) 目標函數(shù),PID參數(shù)整定,Kp=12.345 Td=6.7890 Ti =9.8765 (123456789098765)x(1234567890),PID參數(shù)整定,信息素釋放,PID參數(shù)整定,路徑選擇概率,6 蟻群優(yōu)化算法研究現(xiàn)狀,蟻群系統(tǒng)(Ant Colony System,ACS) 基于排序的螞蟻系統(tǒng)(Rank Based version AS,ASrank) 最大最小螞蟻系統(tǒng)(Max-Min An
16、t System,MMAS),蟻群系統(tǒng)ACS,結(jié)合Q-learning; ACS采用了更為大膽的行為選擇規(guī)則; 只增強屬于全局最優(yōu)解的路徑上的信息素;,到當前為止全局最優(yōu)的路徑長度,蟻群系統(tǒng)ACS,引入負反饋機制。每當螞蟻由一個節(jié)點移動到另一個節(jié)點時,該路徑上的信息素按照如下公式被相應(yīng)的消除一部分,從而實現(xiàn)一種信息素的局部調(diào)整,以減小已選擇過的路徑再次被選擇的概率。,最大最小螞蟻系統(tǒng)MMAS,修改了AS的信息素更新方式; 每次迭代之后只有一只螞蟻能夠進行信息素的更新,以獲取更好的解; 為了避免搜索停滯,路徑上的信息素濃度被限制在MAX,MIN 范圍內(nèi); 信息素的初始值被設(shè)為其取值上限,有助于增加算法初始階段的搜索能力。,基于排序的螞蟻系統(tǒng)ASrank,與“精英策略”相似; 算法中總是更新更好進程上的信息素; 選擇的標準是其行程長度決定的排序;,基于排序的螞蟻系統(tǒng)ASrank,每個螞蟻釋放信息素的強度通過排序加權(quán)處理確定。其中,為每次迭代后釋放信息素的螞蟻總數(shù)。,