遺傳算法-遺傳算法_第1頁(yè)
遺傳算法-遺傳算法_第2頁(yè)
遺傳算法-遺傳算法_第3頁(yè)
遺傳算法-遺傳算法_第4頁(yè)
遺傳算法-遺傳算法_第5頁(yè)
已閱讀5頁(yè),還剩76頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、第10章 遺傳算法10.1 遺傳算法的基本原理1 遺傳算法簡(jiǎn)稱GA(Genetic Algorithms)是1962年由美國(guó)Michigan大學(xué)的Holland教授提出的模擬自然界遺傳機(jī)制和生物進(jìn)化論而成的一種并行隨機(jī)搜索最優(yōu)化方法。 遺傳算法是以達(dá)爾文的自然選擇學(xué)說為基礎(chǔ)發(fā)展起來的。自然選擇學(xué)說包括以下三個(gè)方面:2(1)遺傳:這是生物的普遍特征,親代把生物信息交給子代,子代總是和親代具有相同或相似的性狀。生物有了這個(gè)特征,物種才能穩(wěn)定存在。(2)變異:親代和子代之間以及子代的不同個(gè)體之間的差異,稱為變異。變異是隨機(jī)發(fā)生的,變異的選擇和積累是生命多樣性的根源。(3)生存斗爭(zhēng)和適者生存:具有適應(yīng)

2、性變異的個(gè)體被保留下來,不具有適應(yīng)性變異的個(gè)體被淘汰,通過一代代的生存環(huán)境的選擇作用,性狀逐漸逐漸與祖先有所不同,演變?yōu)樾碌奈锓N。3 遺傳算法將“優(yōu)勝劣汰,適者生存”的生物進(jìn)化原理引入優(yōu)化參數(shù)形成的編碼串聯(lián)群體中,按所選擇的適應(yīng)度函數(shù)并通過遺傳中的復(fù)制、交叉及變異對(duì)個(gè)體進(jìn)行篩選,使適適應(yīng)度高的個(gè)體被保留下來,組成新的群體,新的群體既繼承了上一代的信息,又優(yōu)于上一代。這樣周而復(fù)始,群體中個(gè)體適應(yīng)度不斷提高,直到滿足一定的條件。遺傳算法的算法簡(jiǎn)單,可并行處理,并能到全局最優(yōu)解。4遺傳算法的基本操作為:(1)復(fù)制(Reproduction Operator) 復(fù)制是從一個(gè)舊種群中選擇生命力強(qiáng)的個(gè)體位

3、串產(chǎn)生新種群的過程。具有高適應(yīng)度的位串更有可能在下一代中產(chǎn)生一個(gè)或多個(gè)子孫。 復(fù)制操作可以通過隨機(jī)方法來實(shí)現(xiàn)。首先產(chǎn)生01之間均勻分布的隨機(jī)數(shù),若某串的復(fù)制概率為40%,則當(dāng)產(chǎn)生的隨機(jī)數(shù)在0.401.0之間時(shí),該串被復(fù)制,否則被淘汰。5(2)交叉(Crossover Operator) 復(fù)制操作能從舊種群中選擇出優(yōu)秀者,但不能創(chuàng)造新的染色體。而交叉模擬了生物進(jìn)化過程中的繁殖現(xiàn)象,通過兩個(gè)染色體的交換組合,來產(chǎn)生新的優(yōu)良品種。 交叉的過程為:在匹配池中任選兩個(gè)染色體,隨機(jī)選擇一點(diǎn)或多點(diǎn)交換點(diǎn)位置;交換雙親染色體交換點(diǎn)右邊的部分,即可得到兩個(gè)新的染色體數(shù)字串。6 交杈體現(xiàn)了自然界中信息交換的思想。

4、交叉有一點(diǎn)交叉、多點(diǎn)交叉、還有一致交叉、順序交叉和周期交叉。一點(diǎn)交叉是最基本的方法,應(yīng)用較廣。它是指染色體切斷點(diǎn)有一處,例:7(3)變異(Mutation Operator) 變異運(yùn)算用來模擬生物在自然的遺傳環(huán)境中由于各種偶然因素引起的基因突變,它以很小的概率隨機(jī)地改變遺傳基因(表示染色體的符號(hào)串的某一位)的值。在染色體以二進(jìn)制編碼的系統(tǒng)中,它隨機(jī)地將染色體的某一個(gè)基因由1變?yōu)?,或由0變?yōu)?。8 若只有選擇和交叉,而沒有變異,則無法在初始基因組合以外的空間進(jìn)行搜索,使進(jìn)化過程在早期就陷入局部解而進(jìn)入終止過程,從而影響解的質(zhì)量。為了在盡可能大的空間中獲得質(zhì)量較高的優(yōu)化解,必須采用變異操作。91

5、0.2 遺傳算法的特點(diǎn) (1)遺傳算法是對(duì)參數(shù)的編碼進(jìn)行操作,而非對(duì)參數(shù)本身,這就是使得我們?cè)趦?yōu)化計(jì)算過程中可以借鑒生物學(xué)中染色體和基因等概念,模仿自然界中生物的遺傳和進(jìn)化等機(jī)理;(2)遺傳算法同時(shí)使用多個(gè)搜索點(diǎn)的搜索信息。傳統(tǒng)的優(yōu)化方法往往是從解空間的單個(gè)初始點(diǎn)開始最優(yōu)解的迭代搜索過程,單個(gè)搜索點(diǎn)所提供的信息不多,搜索效率不高,有時(shí)甚至使搜索過程局限于局部最優(yōu)解而停滯不前。10 遺傳算法從由很多個(gè)體組成的一個(gè)初始群體開始最優(yōu)解的搜索過程,而不是從一個(gè)單一的個(gè)體開始搜索,這是遺傳算法所特有的一種隱含并行性,因此遺傳算法的搜索效率較高。(3)遺傳算法直接以目標(biāo)函數(shù)作為搜索信息。傳統(tǒng)的優(yōu)化算法不僅

6、需要利用目標(biāo)函數(shù)值,而且需要目標(biāo)函數(shù)的導(dǎo)數(shù)值等輔助信息才能確定搜索方向。而遺傳算法僅使用由目標(biāo)函數(shù)值變換來的適應(yīng)度函數(shù)值,就可以確定進(jìn)一步的搜索方向和搜索范圍,無需目標(biāo)函數(shù)的導(dǎo)數(shù)值等其他一些輔助信息。11 遺傳算法可應(yīng)用于目標(biāo)函數(shù)無法求導(dǎo)數(shù)或?qū)?shù)不存在的函數(shù)的優(yōu)化問題,以及組合優(yōu)化問題等。(4)遺傳算法使用概率搜索技術(shù)。遺傳算法的選擇、交叉、變異等運(yùn)算都是以一種概率的方式來進(jìn)行的,因而遺傳算法的搜索過程具有很好的靈活性。隨著進(jìn)化過程的進(jìn)行,遺傳算法新的群體會(huì)更多地產(chǎn)生出許多新的優(yōu)良的個(gè)體。12(5)遺傳算法在解空間進(jìn)行高效啟發(fā)式搜索,而非盲目地窮舉或完全隨機(jī)搜索;(6)遺傳算法對(duì)于待尋優(yōu)的函數(shù)

7、基本無限制,它既不要求函數(shù)連續(xù),也不要求函數(shù)可微,既可以是數(shù)學(xué)解析式所表示的顯函數(shù),又可以是映射矩陣甚至是神經(jīng)網(wǎng)絡(luò)的隱函數(shù),因而應(yīng)用范圍較廣;(7)遺傳算法具有并行計(jì)算的特點(diǎn),因而可通過大規(guī)模并行計(jì)算來提高計(jì)算速度,適合大規(guī)模復(fù)雜問題的優(yōu)化。 1310.3 遺傳算法的發(fā)展及應(yīng)用10.3.1 遺傳算法的發(fā)展 遺傳算法起源于對(duì)生物系統(tǒng)所進(jìn)行的計(jì)算機(jī)模擬研究。早在20世紀(jì)40年代,就有學(xué)者開始研究如何利用計(jì)算機(jī)進(jìn)行生物模擬的技術(shù),他們從生物學(xué)的角度進(jìn)行了生物的進(jìn)化過程模擬、遺傳過程模擬等研究工作。進(jìn)入20世紀(jì)60年代,美國(guó)密執(zhí)安大學(xué)的Holland教授及其學(xué)生們受到這種生物模擬技術(shù)的啟發(fā),創(chuàng)造出一種

8、基于生物遺傳和進(jìn)化機(jī)制的適合于復(fù)雜系統(tǒng)優(yōu)化計(jì)算的自適應(yīng)概率優(yōu)化技術(shù)遺傳算法。14 以下是在遺傳算法發(fā)展進(jìn)程中一些關(guān)鍵人物所做出的主要貢獻(xiàn):(1)J.H.Holland 20世紀(jì)70年代初,Holland教授提出了遺傳算法的基本定理模式定理,從而奠定了遺傳算法的理論基礎(chǔ)。模式定理揭示了群體中優(yōu)良個(gè)體(較好的模式)的樣本數(shù)將以指數(shù)級(jí)規(guī)律增長(zhǎng),從理論上保證了遺傳算法用于尋求最優(yōu)可行解的優(yōu)化過程。1975年,Holland出版了第一本系統(tǒng)論述遺傳算法和人工自適應(yīng)系統(tǒng)的專著自然系統(tǒng)和人工系統(tǒng)的自適應(yīng)性。20世紀(jì)80年代,Holland教授實(shí)現(xiàn)了第一個(gè)基于遺傳算法的機(jī)器學(xué)習(xí)系統(tǒng)分類器系統(tǒng),開創(chuàng)了基于遺傳算

9、法的機(jī)器學(xué)習(xí)的新概念。15(2)J.D.Bagley 1967年,Holland的學(xué)生Bagley在其博士論文中首次提出了“遺傳算法”一詞,并發(fā)表了遺傳算法應(yīng)用方面的第一篇論文。他發(fā)展了復(fù)制、交叉、變異、顯性、倒位等遺傳算子,在個(gè)體編碼上使用了雙倍體的編碼方法。在遺傳算法的不同階段采用了不同的概率,從而創(chuàng)立了自適應(yīng)遺傳算法的概念。16(3)K.A.De Jong 1975年,De Jong博士在其博士論文中結(jié)合模式定理進(jìn)行了大量純數(shù)值函數(shù)優(yōu)化計(jì)算實(shí)驗(yàn),樹立了遺傳算法的工作框架。他推薦了在大多數(shù)優(yōu)化問題中都較適用的遺傳算法的參數(shù),建立了著名的De Jong五函數(shù)測(cè)試平臺(tái),定義了評(píng)價(jià)遺傳算法性能的

10、在線指標(biāo)和離線指標(biāo)。(4)D.J.Goldberg 1989年,Goldberg出版了專著搜索、優(yōu)化和機(jī)器學(xué)習(xí)中的遺傳算法,該書全面地論述了遺傳算法的基本原理及其應(yīng)用,奠定了現(xiàn)代遺傳算法的科學(xué)基礎(chǔ)。17(5)L.Davis 1991年,Davis編輯出版了遺傳算法手冊(cè)一書,為推廣和普及遺傳算法的應(yīng)用起到了重要的指導(dǎo)作用。(6)J.R.Koza 1992年,Koza將遺傳算法應(yīng)用于計(jì)算機(jī)程序的優(yōu)化設(shè)計(jì)及自動(dòng)生成,提出了遺傳編程的概念,并成功地將遺傳編程的方法應(yīng)用于人工智能、機(jī)器學(xué)習(xí)和符號(hào)處理等方面。1810.3.1 遺傳算法的應(yīng)用(1)函數(shù)優(yōu)化。 函數(shù)優(yōu)化是遺傳算法的經(jīng)典應(yīng)用領(lǐng)域,也是遺傳算法進(jìn)

11、行性能評(píng)價(jià)的常用算例。尤其是對(duì)非線性、多模型、多目標(biāo)的函數(shù)優(yōu)化問題,采用其他優(yōu)化方法較難求解,而遺傳算法卻可以得到較好的結(jié)果。(2)組合優(yōu)化。 隨著問題的增大,組合優(yōu)化問題的搜索空間也急劇擴(kuò)大,采用傳統(tǒng)的優(yōu)化方法很難得到最優(yōu)解。遺傳算法是尋求這種滿意解的最佳工具。例如,遺傳算法已經(jīng)在求解旅行商問題、背包問題、裝箱問題、圖形劃分問題等方面得到成功的應(yīng)用。19(3)生產(chǎn)調(diào)度問題 在很多情況下,采用建立數(shù)學(xué)模型的方法難以對(duì)生產(chǎn)調(diào)度問題進(jìn)行精確求解。在現(xiàn)實(shí)生產(chǎn)中多采用一些經(jīng)驗(yàn)進(jìn)行調(diào)度。遺傳算法是解決復(fù)雜調(diào)度問題的有效工具,在單件生產(chǎn)車間調(diào)度、流水線生產(chǎn)車間調(diào)度、生產(chǎn)規(guī)劃、任務(wù)分配等方面遺傳算法都得到了

12、有效的應(yīng)用。20(4)自動(dòng)控制。 在自動(dòng)控制領(lǐng)域中有很多與優(yōu)化相關(guān)的問題需要求解,遺傳算法已經(jīng)在其中得到了初步的應(yīng)用。例如,利用遺傳算法進(jìn)行控制器參數(shù)的優(yōu)化、基于遺傳算法的模糊控制規(guī)則的學(xué)習(xí)、基于遺傳算法的參數(shù)辨識(shí)、基于遺傳算法的神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu)的優(yōu)化和權(quán)值學(xué)習(xí)等。21(5)機(jī)器人 例如,遺傳算法已經(jīng)在移動(dòng)機(jī)器人路徑規(guī)劃、關(guān)節(jié)機(jī)器人運(yùn)動(dòng)軌跡規(guī)劃、機(jī)器人結(jié)構(gòu)優(yōu)化和行為協(xié)調(diào)等方面得到研究和應(yīng)用。(6)圖像處理 遺傳算法可用于圖像處理過程中的掃描、特征提取、圖像分割等的優(yōu)化計(jì)算。目前遺傳算法已經(jīng)在模式識(shí)別、圖像恢復(fù)、圖像邊緣特征提取等方面得到了應(yīng)用。22(7)人工生命 人工生命是用計(jì)算機(jī)、機(jī)械等人工媒體

13、模擬或構(gòu)造出的具有生物系統(tǒng)特有行為的人造系統(tǒng)。人工生命與遺傳算法有著密切的聯(lián)系,基于遺傳算法的進(jìn)化模型是研究人工生命現(xiàn)象的重要基礎(chǔ)理論。遺傳算法為人工生命的研究提供了一個(gè)有效的工具。(8)遺傳編程 遺傳算法已成功地應(yīng)用于人工智能、機(jī)器學(xué)習(xí)等領(lǐng)域的編程。23(9)機(jī)器學(xué)習(xí) 基于遺傳算法的機(jī)器學(xué)習(xí)在很多領(lǐng)域都得到了應(yīng)用。例如,采用遺傳算法實(shí)現(xiàn)模糊控制規(guī)則的優(yōu)化,可以改進(jìn)模糊系統(tǒng)的性能;遺傳算法可用于神經(jīng)網(wǎng)絡(luò)連接權(quán)的調(diào)整和結(jié)構(gòu)的優(yōu)化;采用遺傳算法設(shè)計(jì)的分類器系統(tǒng)可用于學(xué)習(xí)式多機(jī)器人路徑規(guī)劃。2410.4.1 遺傳算法的構(gòu)成要素(1)染色體編碼方法 基本遺傳算法使用固定長(zhǎng)度的二進(jìn)制符號(hào)來表示群體中的個(gè)

14、體,其等位基因是由二值符號(hào)集0,1所組成。初始個(gè)體基因值可用均勻分布的隨機(jī)值生成,如就可表示一個(gè)個(gè)體,該個(gè)體的染色體長(zhǎng)度是18。10.4 遺傳算法的優(yōu)化設(shè)計(jì)25(2)個(gè)體適應(yīng)度評(píng)價(jià):基本遺傳算法與個(gè)體適應(yīng)度成正比的概率來決定當(dāng)前群體中每個(gè)個(gè)體遺傳到下一代群體中的概率多少。為正確計(jì)算這個(gè)概率,要求所有個(gè)體的適應(yīng)度必須為正數(shù)或零。因此,必須先確定由目標(biāo)函數(shù)值J到個(gè)體適應(yīng)度f之間的轉(zhuǎn)換規(guī)則。26(3)遺傳算子:基本遺傳算法使用下述三種遺傳算子: 選擇運(yùn)算:使用比例選擇算子; 交叉運(yùn)算:使用單點(diǎn)交叉算子; 變異運(yùn)算:使用基本位變異算子或均勻變異算子。27(4)基本遺傳算法的運(yùn)行參數(shù) 有下述4個(gè)運(yùn)行參數(shù)

15、需要提前設(shè)定:M:群體大小,即群體中所含個(gè)體的數(shù)量,一般取為20100;G:遺傳算法的終止進(jìn)化代數(shù),一般取為100500;Pc:交叉概率,一般取為0.40.99;Pm:變異概率,一般取為0.00010.1。28 對(duì)于一個(gè)需要進(jìn)行優(yōu)化的實(shí)際問題,一般可按下述步驟構(gòu)造遺傳算法:第一步:確定決策變量及各種約束條件,即確定出個(gè)體的表現(xiàn)型X和問題的解空間;第二步:建立優(yōu)化模型,即確定出目標(biāo)函數(shù)的類型及數(shù)學(xué)描述形式或量化方法;10.4.2 遺傳算法的應(yīng)用步驟29第三步:確定表示可行解的染色體編碼方法,即確定出個(gè)體的基因型x及遺傳算法的搜索空間;第四步:確定解碼方法,即確定出由個(gè)體基因型x到個(gè)體表現(xiàn)型X的對(duì)

16、應(yīng)關(guān)系或轉(zhuǎn)換方法;第五步:確定個(gè)體適應(yīng)度的量化評(píng)價(jià)方法,即確定出由目標(biāo)函數(shù)值到個(gè)體適應(yīng)度的轉(zhuǎn)換規(guī)則;第六步:設(shè)計(jì)遺傳算子,即確定選擇運(yùn)算、交叉運(yùn)算、變異運(yùn)算等遺傳算子的具體操作方法。第七步:確定遺傳算法的有關(guān)運(yùn)行參數(shù),即M,G,Pc,Pm等參數(shù)。30以上操作過程可以用圖10-1來表示。 圖10-1 遺傳算法流程圖 31利用遺傳算法求Rosenbrock函數(shù)的極大值10.5 遺傳算法求函數(shù)極值3210.5.1 二進(jìn)制編碼遺傳算法求函數(shù)極大值 求解該問題遺傳算法的構(gòu)造過程:(1)確定決策變量和約束條件;(2)建立優(yōu)化模型;(3)確定編碼方法 33 用長(zhǎng)度為10位的二進(jìn)制編碼串來分別表示兩個(gè)決策變量

17、x1,x2。10位二進(jìn)制編碼串可以表示從0到1023之間的1024個(gè)不同的數(shù),故將x1,x2的定義域離散化為1023個(gè)均等的區(qū)域,包括兩個(gè)端點(diǎn)在內(nèi)共有1024個(gè)不同的離散點(diǎn)。 從離散點(diǎn)-2.048到離散點(diǎn)2.048 ,分別對(duì)應(yīng)于從0000000000(0)到1111111111(1023)之間的二進(jìn)制編碼。34 將x1,x2分別表示的兩個(gè)10位長(zhǎng)的二進(jìn)制編碼串連接在一起,組成一個(gè)20位長(zhǎng)的二進(jìn)制編碼串,它就構(gòu)成了這個(gè)函數(shù)優(yōu)化問題的染色體編碼方法。使用這種編碼方法,解空間和遺傳算法的搜索空間就具有一一對(duì)應(yīng)的關(guān)系。例如: 表示一個(gè)個(gè)體的基因型,其中前10位表示x1,后10位表示x2。35(4)確定

18、解碼方法:解碼時(shí)需要將20位長(zhǎng)的二進(jìn)制編碼串切斷為兩個(gè)10位長(zhǎng)的二進(jìn)制編碼串,然后分別將它們轉(zhuǎn)換為對(duì)應(yīng)的十進(jìn)制整數(shù)代碼,分別記為y1和y2。 依據(jù)個(gè)體編碼方法和對(duì)定義域的離散化方法可知,將代碼y轉(zhuǎn)換為變量x的解碼公式為 例如,對(duì)個(gè)體36 它由兩個(gè)代碼所組成 上述兩個(gè)代碼經(jīng)過解碼后,可得到兩個(gè)實(shí)際的值(5)確定個(gè)體評(píng)價(jià)方法:由于Rosenbrock函數(shù)的值域總是非負(fù)的,并且優(yōu)化目標(biāo)是求函數(shù)的最大值,故可將個(gè)體的適應(yīng)度直接取為對(duì)應(yīng)的目標(biāo)函數(shù)值,即37選個(gè)體適應(yīng)度的倒數(shù)作為目標(biāo)函數(shù)(6)設(shè)計(jì)遺傳算子:選擇運(yùn)算使用比例選擇算子,交叉運(yùn)算使用單點(diǎn)交叉算子,變異運(yùn)算使用基本位變異算子。(7)確定遺傳算法的

19、運(yùn)行參數(shù):群體大小M=80,終止進(jìn)化代數(shù)G=100,交叉概率Pc=0.60,變異概率Pm=0.10。 上述七個(gè)步驟構(gòu)成了用于求函數(shù)極大值的優(yōu)化計(jì)算基本遺傳算法。38 采用上述方法進(jìn)行仿真,經(jīng)過100步迭代,最佳樣本為即當(dāng) 時(shí),Rosenbrock函數(shù)具有極大值,極大值為3905.9。仿真程序:chap5_1.m 39 遺傳算法的優(yōu)化過程是目標(biāo)函數(shù)J和適應(yīng)度函數(shù)F的變化過程。 由仿真結(jié)果可知,隨著進(jìn)化過程的進(jìn)行,群體中適應(yīng)度較低的一些個(gè)體被逐漸淘汰掉,而適應(yīng)度較高的一些個(gè)體會(huì)越來越多,并且它們都集中在所求問題的最優(yōu)點(diǎn)附近,從而搜索到問題的最優(yōu)解。4010.5.2 實(shí)數(shù)編碼遺傳算法求函數(shù)極大值求解

20、該問題遺傳算法的構(gòu)造過程:(1)確定決策變量和約束條件;(2)建立優(yōu)化模型;(3)確定編碼方法:用2個(gè)實(shí)數(shù)分別表示兩個(gè)決策變量,分別將的定義域離散化為從離散點(diǎn)-2.048到離散點(diǎn)2.048的Size個(gè)實(shí)數(shù)。41(4)確定個(gè)體評(píng)價(jià)方法: 個(gè)體的適應(yīng)度直接取為對(duì)應(yīng)的目標(biāo)函數(shù)值,即 選個(gè)體適應(yīng)度的倒數(shù)作為目標(biāo)函數(shù) 42(5)設(shè)計(jì)遺傳算子:選擇運(yùn)算使用比例選擇算子,交叉運(yùn)算使用單點(diǎn)交叉算子,變異運(yùn)算使用基本位變異算子。(6)確定遺傳算法的運(yùn)行參數(shù):群體大小M=500,終止進(jìn)化代數(shù)G=200,交叉概率Pc=0.90,采用自適應(yīng)變異概率即變異概率與適應(yīng)度有關(guān),適應(yīng)度越小,變異概率越大。 43 上述六個(gè)步驟

21、構(gòu)成了用于求函數(shù)Rosenbrock極大值的優(yōu)化計(jì)算的實(shí)數(shù)編碼遺傳算法。 十進(jìn)制編碼求函數(shù)Rosenbrock極大值。仿真程序見chap10_2.m。 仿真程序經(jīng)過200步迭代,最佳樣本為即當(dāng) , 時(shí),函數(shù)具有極大值,極大值為3880.3。4410.6 基于遺傳算法優(yōu)化的RBF網(wǎng)絡(luò)逼近10.6.1 遺傳算法優(yōu)化原理 在7.3節(jié)的RBF網(wǎng)絡(luò)逼近算法中,網(wǎng)絡(luò)權(quán)值、高斯函數(shù)的中心矢量和基寬向量的初值難以確定,如果這些參數(shù)選擇不當(dāng),會(huì)造成逼近精度的下降甚至RBF網(wǎng)絡(luò)的發(fā)散。采用遺傳算法可實(shí)現(xiàn)RBF網(wǎng)絡(luò)參數(shù)的優(yōu)化。45 為獲取滿意的逼近精度,采用誤差絕對(duì)值指標(biāo)作為參數(shù)選擇的最小目標(biāo)函數(shù)。 式中, 為逼近

22、的總步驟, 為第 步RBF網(wǎng)絡(luò)的逼近誤差。 在應(yīng)用遺傳算法時(shí),為了避免參數(shù)選取范圍過大,可以先按經(jīng)驗(yàn)選取一組參數(shù),然后再在這組參數(shù)的周圍利用遺傳算法進(jìn)行設(shè)計(jì),從而大大減少初始尋優(yōu)的盲目性,節(jié)約計(jì)算量。4610.6.2 仿真實(shí)例 使用RBF網(wǎng)絡(luò)逼近下列對(duì)象: 在RBF網(wǎng)絡(luò)中,網(wǎng)絡(luò)輸入信號(hào)為2個(gè),即和 ,網(wǎng)絡(luò)初始權(quán)值及高斯函數(shù)參數(shù)初始值通過遺傳算法優(yōu)化而得。47 遺傳算法優(yōu)化程序?yàn)閏hap10_3a.m,取逼近總步驟為,每一步的逼近誤差由chap10_3b.m求得。采用二進(jìn)制編碼方式,用長(zhǎng)度為10位的二進(jìn)制編碼串來分別表示向量b、c和w中的每個(gè)值。 48 遺傳算法優(yōu)化中,取樣本個(gè)數(shù)為Size=30

23、,交叉概率為Pc=0.60,采用自適應(yīng)變異概率,即適應(yīng)度越小,變異概率越大,取變異概率為 取用于優(yōu)化的RBF網(wǎng)絡(luò)結(jié)構(gòu)為2-3-1,網(wǎng)絡(luò)權(quán)值wj的取值范圍為-1,+1,高斯函數(shù)基寬向量的取值范圍為0.1,3.0,高斯函數(shù)中心矢量的取值范圍為-3,+3。取則共有12個(gè)參數(shù)需要優(yōu)化。49 經(jīng)過150代遺傳算法進(jìn)化,優(yōu)化后的結(jié)果為:p=2.7732,2.6343,2.2630,1.8680,-0.0616,-0.7126,-0.3959,2.2669, -1.4047,-0.3099,0.7478,-0.3353。 則RBF網(wǎng)絡(luò)高斯基函數(shù)參數(shù)的初始值及權(quán)值的初始值為:50 RBF網(wǎng)絡(luò)遺傳算法優(yōu)化程序包

24、括三部分,即遺傳算法優(yōu)化程序chap10_3a.m、RBF網(wǎng)絡(luò)逼近函數(shù)程序chap10_3b.m和RBF網(wǎng)絡(luò)逼近測(cè)試程序chap10_3c.m。51 10.7 基于遺傳算法的伺服系統(tǒng)靜態(tài)摩擦參數(shù)辨識(shí) 摩擦分為靜摩擦和動(dòng)摩擦,它們之間的區(qū)別就是看兩個(gè)物體之間的接觸面有沒有相對(duì)位移,分為三種情況:如果沒有相對(duì)位移,也沒有位移的趨勢(shì),則是沒有摩擦力;如果沒有相對(duì)位移,但是有位移的趨勢(shì),則為靜摩擦力;如果有相對(duì)位移,則為動(dòng)摩擦。 摩擦現(xiàn)象是一種復(fù)雜的、非線性的、具有不確定性的自然現(xiàn)象。在高精度、超低速伺服系統(tǒng)中,由于非線性摩擦環(huán)節(jié)的存在,使系統(tǒng)的動(dòng)態(tài)及靜態(tài)性能受到很大程度的影響,主要表現(xiàn)為低速時(shí)出現(xiàn)爬

25、行現(xiàn)象,穩(wěn)態(tài)時(shí)有較大的靜差或出現(xiàn)極限環(huán)振蕩??朔@一問題的有效方法是進(jìn)行摩擦辨識(shí),從而進(jìn)行有效的補(bǔ)償。52 10.7.1 伺服系統(tǒng)的靜態(tài)摩擦模型 基于SISO的伺服系統(tǒng)可描述為 (10.7)其中 為轉(zhuǎn)動(dòng)慣量, 為轉(zhuǎn)角, 為控制輸入力矩,F(xiàn)為摩擦力矩。 許多伺服系統(tǒng)在低速情況下存在靜摩擦現(xiàn)象。靜摩擦力矩與轉(zhuǎn)速之間的穩(wěn)態(tài)對(duì)應(yīng)關(guān)系為: (10.8)其中 、 、 、 為靜態(tài)摩擦參數(shù), 為庫(kù)侖摩擦, 為靜摩擦, 為粘性摩擦系數(shù), 為切換速度。53 伺服系統(tǒng)在正反轉(zhuǎn)動(dòng)速度方向運(yùn)行時(shí),其靜態(tài)摩擦力矩的靜態(tài)參數(shù)通常為不同的值。當(dāng) 時(shí),靜態(tài)參數(shù)的值為 、 、 、 ;當(dāng) ,靜態(tài)參數(shù)的值為 、 、 、 ,表示如下:

26、 (10.9) 由上式所確定的轉(zhuǎn)速-摩擦力矩曲線稱為Stribeck曲線。對(duì)于摩擦模型中的靜態(tài)參數(shù),通過恒速跟蹤實(shí)驗(yàn)可以得到Stribeck曲線,再由Stribeck曲線,采用遺傳算法可辨識(shí)出靜態(tài)參數(shù)22。54 恒速跟蹤實(shí)驗(yàn)為在線條件下運(yùn)行,工程上很容易實(shí)現(xiàn),而遺傳算法是在離線情況下運(yùn)行,因而本方法具有較強(qiáng)的實(shí)際工程價(jià)值。 10.7.2 靜摩擦模型Stribeck曲線的獲取 在靜態(tài)摩擦條件下, ,由式(10.7)可知, 。由于u可測(cè)得,采用一組恒速跟蹤,可獲得一組相應(yīng)的控制輸入信號(hào)和靜態(tài)摩擦力矩,從而獲得Stribeck曲線。 具體方法為:取閉環(huán)系統(tǒng)的一組恒定轉(zhuǎn)速序列 作為速度指令信號(hào),通過采

27、用PD控制律,實(shí)現(xiàn)被控對(duì)象精確的速度跟蹤,得到相應(yīng)的控制力矩序列 ,從而獲得一組相應(yīng)的靜態(tài)摩擦力矩序列。 PD控制律為: (10.10)55 10.7.3 基于遺傳算法的靜態(tài)摩擦參數(shù)辨識(shí) 取待辨識(shí)靜態(tài)摩擦參數(shù)向量為個(gè)體,遺傳算法的每步迭代得到靜態(tài)摩擦參數(shù)的辨識(shí)值為: , (10.11) 其中M為種群規(guī)模。 由下式可得到相應(yīng)的摩擦力矩辨識(shí)值: (10.12)56 辨識(shí)誤差為: ,其中值根據(jù)所建立的Stribeck曲線得到。 取目標(biāo)函數(shù)為: (10.13)選擇個(gè)體適應(yīng)度函數(shù)如下: 或 , (10.14)57 采用十進(jìn)制浮點(diǎn)編碼格式,選擇操作采取保存最優(yōu)個(gè)體的隨機(jī)采樣選擇方法,交叉操作采用均勻交叉算

28、子,交叉概率 ,變異操作采用高斯變異算子,變異概率隨進(jìn)化代數(shù)自適應(yīng)調(diào)整,即, 其中 g當(dāng)前遺傳代數(shù)。 遺傳算法的步驟如下: Step 1. 置進(jìn)化代數(shù)計(jì)數(shù)器為 ,隨機(jī)產(chǎn)生初始化種群 ;Step 2. 計(jì)算個(gè)體適應(yīng)度 , ;Step 3. 判斷是否達(dá)到最大進(jìn)化代數(shù),若是,則算法終止,否則,轉(zhuǎn)step 4;Step 4. 經(jīng)過選擇操作,產(chǎn)生新一代種群 ;Step 5. 以概率 進(jìn)行交叉操作;Step 6. 以概率 進(jìn)行個(gè)體變異操作;Step 7. ,轉(zhuǎn)step 2;58 一旦辨識(shí)得到的參數(shù)估計(jì)值,便可以設(shè)計(jì)摩擦力矩的補(bǔ)償環(huán)節(jié),實(shí)現(xiàn)對(duì)系統(tǒng)的摩擦進(jìn)行補(bǔ)償,基于摩擦力矩補(bǔ)償?shù)目刂葡到y(tǒng)描述為: (10.1

29、5) 10.7.4 仿真實(shí)例 被控對(duì)象為(10.7)式,取 ,控制律取PD控制。參數(shù)辨識(shí)的仿真分以下兩步實(shí)現(xiàn)。 仿真之一:Stribeck曲線的測(cè)試 恒速跟蹤時(shí),為靜態(tài)摩擦,實(shí)際系統(tǒng)的摩擦模型取(10.9)式,被控對(duì)象為帶有靜態(tài)摩擦模型式(10.7)的實(shí)際對(duì)象,取 , , , , , , , 。取速度信號(hào) 作為指令信號(hào),共41個(gè)速度指令信號(hào)。針對(duì)每個(gè)指令信號(hào),采用PD控制律,取 , 。仿真結(jié)果如圖10-8至10-10所示。仿真結(jié)束后,將所得到的靜摩擦力矩估計(jì)值保存在文件Fi_中。59圖10-8 恒速斜波跟蹤(速度指令為1.0時(shí)) 60圖10-9 Stribeck曲線的實(shí)際值與測(cè)試值的比較 61

30、圖10-10 Stribeck曲線的辨識(shí)誤差62 仿真之二:遺傳算法的靜態(tài)摩擦參數(shù)辨識(shí) 首先將仿真之一“Stribeck曲線設(shè)計(jì)”所得到的摩擦力矩估計(jì)值 從文件Fi_中調(diào)入,作為實(shí)際系統(tǒng)的靜摩擦力矩的估計(jì)值。 恒速跟蹤時(shí)為靜態(tài)摩擦。取速度信號(hào) 作為指令信號(hào),共41個(gè)速度指令信號(hào)。針對(duì)每個(gè)指令信號(hào),采用PD控制律,取 , 。 在遺傳算法仿真中,取種群規(guī)模,最大遺傳代數(shù) 。參數(shù)搜索范圍為 , , , , 靜態(tài)摩擦模型取(10.9)式,將遺傳算法設(shè)計(jì)所得到了靜摩擦力矩與實(shí)際摩擦力矩比較得到目標(biāo)函數(shù)值。當(dāng)運(yùn)行到最大遺傳代數(shù) 時(shí),目標(biāo)函數(shù)值為 。 63遺傳算法的辨識(shí)過程及辨識(shí)曲線如圖10-11和10-1

31、2所示,實(shí)際值與辨識(shí)值比較的仿真結(jié)果如表10-1所示。 表10-1 靜態(tài)摩擦參數(shù)實(shí)際值與辨識(shí)值的比較64圖10-11 目標(biāo)函數(shù)值變化曲線局部放大圖65圖10-12 辨識(shí)Stribeck曲線與實(shí)際 Stribeck曲線66 10.7.5 基于摩擦模型補(bǔ)償?shù)乃欧到y(tǒng)控制 為了驗(yàn)證基于遺傳算法的伺服系統(tǒng)靜態(tài)摩擦參數(shù)辨識(shí)的效果,將PD控制與基于靜態(tài)摩擦模型補(bǔ)償?shù)腜D控制進(jìn)行比較,采用低速正弦信號(hào) 作為位置指令。在PD控制中,取 , 。采用手動(dòng)轉(zhuǎn)換開關(guān)實(shí)現(xiàn)兩種控制方法的切換,一種為只采用PD控制,另一種為基于摩擦補(bǔ)償?shù)腜D控制,仿真結(jié)果如圖10-13和10-14所示。在圖10-13中,由于存在靜摩擦,造

32、成了位置跟蹤出現(xiàn)了“平頂”現(xiàn)象。67圖10-13 未加補(bǔ)償?shù)腜D控制位置跟蹤68圖10-14 基于摩擦補(bǔ)償?shù)腜D控制位置跟蹤69 10.8 基于遺傳算法的TSP問題優(yōu)化 在第8.5節(jié)已經(jīng)對(duì)旅行商問題進(jìn)行了描述。遺傳算法由于其全局搜索的特點(diǎn),在解決TSP問題中有明顯的優(yōu)勢(shì)。 10.8.1 TSP問題的編碼 設(shè) 是由城市i和城市j之間的距離組成的距離矩陣,旅行商問題就是求出一條通過所有城市且每個(gè)城市只通過一次的具有最短距離的回路。70 在旅行商問題的各種求解方法中,描述旅行路線的方法主要有如下兩種:(1)巡回旅行路線經(jīng)過的連接兩個(gè)城市的路線的順序排列;(2)巡回旅行路線所經(jīng)過的各個(gè)城市的順序排列。

33、大多數(shù)求解旅行商問題的遺傳算法是以后者為描述方法的,它們大多采用所遍歷城市的順序來表示各個(gè)個(gè)體的編碼串,其等位基因?yàn)镹個(gè)整數(shù)值或N個(gè)記號(hào)。 以城市的遍歷次序作為遺傳算法的編碼,目標(biāo)函數(shù)取路徑長(zhǎng)度。在群體初始化、交叉操作和變異操作中考慮TSP問題的合法性約束條件(即對(duì)所有的城市做到不重不漏)。71 10.8.2 TSP問題的遺傳算法設(shè)計(jì) 采用遺傳算法進(jìn)行路徑優(yōu)化,分為以下幾步: 第一步:參數(shù)編碼和初始群體設(shè)定 一般來說遺傳算法對(duì)解空間的編碼大多采用二進(jìn)制編碼形式,但對(duì)于TSP一類排序問題,采用對(duì)訪問城市序列進(jìn)行排列組合的方法編碼,即某個(gè)巡回路徑的染色體個(gè)體是該巡回路徑的城市序列。 針對(duì)TSP問題

34、,編碼規(guī)則通常是N取進(jìn)制編碼,即每個(gè)基因僅從1到N的整數(shù)里面取一個(gè)值,每個(gè)個(gè)體的長(zhǎng)度為N,N為城市總數(shù)。定義一個(gè)s行t列的pop矩陣來表示群體,t為城市個(gè)數(shù)N+1,即N+1,s為樣本中個(gè)體數(shù)目。針對(duì)30個(gè)城市的TSP問題,t取值31, 72 即矩陣每一行的前30個(gè)元素表示經(jīng)過的城市編號(hào),最后一個(gè)元素表示經(jīng)過這些城市要走的距離。 參數(shù)編碼和初始群體設(shè)定程序?yàn)椋簆op=zeros(s,t);for i=1:s pop(i,1:t-1)=randperm(t-1);end 第二步:計(jì)算路徑長(zhǎng)度的函數(shù)設(shè)計(jì) 在TSP的求解中,用距離的總和作為適應(yīng)度函數(shù),來衡量求解結(jié)果是否最優(yōu)。將POP矩陣中每一行表示經(jīng)過的距離的最后一個(gè)元素作為路徑長(zhǎng)度。73 兩個(gè)城市m和n間的距離為: (10.16) 用于計(jì)算路徑長(zhǎng)度的程序?yàn)閏hap10_1dis.m。 通過樣本的路徑長(zhǎng)度可以得到目標(biāo)函數(shù)和自適應(yīng)度函數(shù)。根據(jù)t的定義,兩兩城市組合數(shù)共有t-2組,則目標(biāo)函數(shù)為: (10.17) 自適應(yīng)度函數(shù)取目標(biāo)函數(shù)的倒數(shù),即: (10.18)74 第三步:計(jì)算

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論