遺傳算法的實(shí)現(xiàn)及應(yīng)用舉例_第1頁
遺傳算法的實(shí)現(xiàn)及應(yīng)用舉例_第2頁
遺傳算法的實(shí)現(xiàn)及應(yīng)用舉例_第3頁
遺傳算法的實(shí)現(xiàn)及應(yīng)用舉例_第4頁
遺傳算法的實(shí)現(xiàn)及應(yīng)用舉例_第5頁
已閱讀5頁,還剩153頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

第六節(jié)算法實(shí)現(xiàn)及應(yīng)用一、算法實(shí)現(xiàn)遺傳算法提供了一種求解復(fù)雜系統(tǒng)優(yōu)化問題的通用框架。對于具體問題,可按下述步驟來構(gòu)造:確定問題編碼方案確定適配值函數(shù)設(shè)計(jì)遺傳算子(選擇、交叉、變異)確定算法參數(shù)確定算法終止條件生成初始種群SGA實(shí)現(xiàn)①個(gè)體適應(yīng)度評價(jià)在遺傳算法中,以個(gè)體適應(yīng)度的大小來確定該個(gè)體被遺傳到下一代群體中的概率。個(gè)體適應(yīng)度越大,該個(gè)體被遺傳到下一代的概率也越大;反之,個(gè)體的適應(yīng)度越小,該個(gè)體被遺傳到下一代的概率也越小。基本遺傳算法使用比例選擇算子來確定群體中各個(gè)個(gè)體遺傳到下一代群體中的數(shù)量。為正確計(jì)算不同情況下各個(gè)個(gè)體的遺傳概率,要求所有個(gè)體的適應(yīng)度必須為正數(shù)或0,不能是負(fù)數(shù)。為滿足適應(yīng)度取非負(fù)值的要求,基本遺傳算法一般采用下面兩種方法之一將目標(biāo)函數(shù)值變換為個(gè)體的適應(yīng)度。方法一:對于目標(biāo)函數(shù)是求極大化,方法為:式中,為一個(gè)適當(dāng)?shù)叵鄬Ρ容^小的數(shù)它可用下面幾種方法之一來選取:預(yù)先指定的一個(gè)較小的數(shù);進(jìn)化到當(dāng)前代為止的最小目標(biāo)函數(shù)值;當(dāng)前代或最近幾代群體中的最小目標(biāo)值。

②比例選擇算子比例選擇實(shí)際上是一種有退還隨機(jī)選擇,也叫做賭盤(RouletteWheel)選擇,因?yàn)檫@種選擇方式與賭博中的賭盤操作原理非常相似。比例選擇算子的具體執(zhí)行過程是:先計(jì)算出群體中所有個(gè)體的適應(yīng)度之和;其次計(jì)算出每個(gè)個(gè)體的相對適應(yīng)度的大小,此值即為各個(gè)個(gè)體被遺傳到下一代群體中的概率;最后再使用模擬賭盤操作(即0到1之間的隨機(jī)數(shù))來確定各個(gè)個(gè)體被選中的次數(shù)。③單點(diǎn)交叉算子單點(diǎn)交叉算子是最常用和最基本的交叉操作算子。單點(diǎn)交叉算子的具體執(zhí)行過程如下:對群體中的個(gè)體進(jìn)行兩兩隨機(jī)配對;對每一對相互配對的個(gè)體,隨機(jī)設(shè)置某一基因座之后的位置為交叉點(diǎn);對每一對相互配對的個(gè)體,依設(shè)定的交叉概率在其交叉點(diǎn)處相互交換兩個(gè)個(gè)體的部分染色體,從而產(chǎn)生出兩個(gè)新個(gè)體。④基本位變異算子基本位變異算子的具體執(zhí)行過程為:對個(gè)體的每一個(gè)基因座,依變異概率指定其為變異點(diǎn);對每一個(gè)指定的變異點(diǎn),對其基因值做取反運(yùn)算或用其他等位基因值來代替,從而產(chǎn)生出一個(gè)新的個(gè)體。簡單演示問題:求(1)編碼:編碼長度為5(2)初始群體生成:群體大小設(shè)置為4,隨機(jī)產(chǎn)生四個(gè)個(gè)體:編碼:01101,11000,01000,10011

解碼:1324819

適應(yīng)度:16957664361(3)適應(yīng)度函數(shù):(4)輪盤賭選擇:選擇概率個(gè)體:01101,11000,01000,10011

適應(yīng)度:16957664361

選擇概率:0.140.490.060.31選擇11000和01101交配產(chǎn)生下一代(5)交叉操作:發(fā)生交叉的概率取大交叉點(diǎn)位置的選取是隨機(jī)的(單點(diǎn)交叉)

0110101100

1100011001(6)變異:發(fā)生變異的概率取小改變某個(gè)字節(jié)1100111101(7)新群體的產(chǎn)生:保留上一代最優(yōu)個(gè)體,1個(gè)新個(gè)體取代舊個(gè)體

11101,11000,01000,10011(8)重復(fù)上述操作20次,或許就能夠得到最優(yōu)解!

應(yīng)用實(shí)例:TSP問題回顧給定n個(gè)城市以及兩兩城市之間的距離,求解一條從某個(gè)城市出發(fā)、不重復(fù)地遍歷所有其它城市并最終又回到起始城市的最短路徑。數(shù)學(xué)描述給定圖G=(V,E),V為頂點(diǎn)集,E為邊集,確定一條長度最短的Hamilton回路TSP問題問題復(fù)雜度:指數(shù)增長的!(NP完全問題)12個(gè)城市,具有39916800條不同的路徑。一條路徑對應(yīng)一個(gè)排列!交叉算子傳統(tǒng)的交叉算子可能產(chǎn)生無效路徑。交叉算子(1)基于位置的交叉把一個(gè)父代在向量上的被選元的位置強(qiáng)加到另一個(gè)父代。父代1:12345678910父代2:59246110738所選位置:****子代1:19236457810子代2:92345618107交叉算子(2)部分映射交叉利用父代所選段內(nèi)元的對應(yīng)定義子代。父代1:26438151079父代2:85110762439子代1:51437621089子代2:72610815439變異算子起雙重作用:1、提供和保持群體的多樣性;

2、搜索算子的作用。(1)基于位置的變異:隨機(jī)選擇兩個(gè)元,然后把第二個(gè)元放在第一個(gè)元之前;(2)基于次序的變異:隨機(jī)選擇兩個(gè)元,然后交換他們的位置;(3)打亂變異:隨機(jī)選擇一段,然后打亂這段內(nèi)的次序。編碼方案路徑表達(dá):對一個(gè)旅行最自然的表達(dá)一個(gè)旅行5—>1—>7—>8—>9—>4—>6—>2—>3的編碼就是(517894623)編碼空間和解空間一一對應(yīng),總量為n!個(gè)?其實(shí)一些解是相同的,因?yàn)椋?1789|4623)=(4623|51789)二者是同一個(gè)解(n-1)!/2應(yīng)用實(shí)例1:TSP適應(yīng)度函數(shù)就取為目標(biāo)函數(shù)的倒數(shù),即路徑總長度的倒數(shù)初始種群隨機(jī)生成40個(gè)終止條件2000次迭代參數(shù)設(shè)置自定......p1p2pir選擇操作算子:輪盤式選擇首先計(jì)算每個(gè)個(gè)體

i被選中的概率然后根據(jù)概率的大小將將圓盤分為n個(gè)扇形,每個(gè)扇形的大小為。選擇時(shí)轉(zhuǎn)動輪盤,參考點(diǎn)r落到扇形i則選擇個(gè)體i

。交叉操作算子Davis提出OX算子:通過從一個(gè)親體中挑選一個(gè)子序列旅行并保存另一個(gè)親體的城市相對次序來構(gòu)造后代例如:p1=(123|4567|89)p2=(452|1876|93)首先保持中間部分

o1=(XXX|4567|XX)

o2=(XXX|1876|XX)交叉操作算子然后移走p2中已在o1中的城市4、5、6和7后,得到2—1—8—9—3該序列順次放在o1中:o1=(218|4567|93)類似地,可以得到另一個(gè)后代:o2=(234|1876|59)變異操作算子采用倒置變異:在染色體上隨機(jī)地選擇兩點(diǎn),將兩點(diǎn)間的子串反轉(zhuǎn)例如原個(gè)體:(123456789)隨機(jī)選擇兩點(diǎn):(12|3456|789)倒置后的個(gè)體:(12|6543|789)中國城市TSP的一個(gè)參考解應(yīng)用實(shí)例2:函數(shù)優(yōu)化函數(shù)優(yōu)化編碼方案采用二進(jìn)制編碼對子變量定義域根據(jù)計(jì)算精度進(jìn)行離散化處理,然后根據(jù)離散化后待定解的個(gè)數(shù)選擇合適長度的二進(jìn)制字符串進(jìn)行編碼例如;[0,1],計(jì)算精度0.001,則0,0.001,0.002,…,0.998,0.999,1.000,個(gè)數(shù)為1001則用長度為10的二進(jìn)制字符串一次表征所有離散點(diǎn)0000000000,000000001,…,1111110001。適應(yīng)度函數(shù)例如,f(x)=x2-

x5,取Cmax=2,即可得到滿足要求的F(x)其它的就類似于TSP的求解了

已知函數(shù)

其中,用遺傳算法求解y的最大值。

例1多元函數(shù)優(yōu)化問題運(yùn)行步驟運(yùn)行步驟運(yùn)行步驟運(yùn)行步驟運(yùn)行步驟運(yùn)行步驟運(yùn)行步驟

例2一元函數(shù)優(yōu)化問題問題的提出

一元函數(shù)求最大值:問題的提出

用微分法求取

f(x)

的最大值:解有無窮多個(gè):問題的提出

當(dāng)i為奇數(shù)時(shí)xi對應(yīng)局部極大值點(diǎn),i為偶數(shù)時(shí)xi對應(yīng)局部極小值。x19即為區(qū)間[-1,2]內(nèi)的最大值點(diǎn)此時(shí),函數(shù)最大值

f(x19)

比f(1.85)=3.85稍大。編碼表現(xiàn)型:x

基因型:二進(jìn)制編碼(串長取決于求解精度)

串長與精度之間的關(guān)系:若要求求解精度到6位小數(shù),區(qū)間長度為2-(-1)=3,即需將區(qū)間分為3/0.000001=3×106等份。所以編碼的二進(jìn)制串長應(yīng)為22位。產(chǎn)生初始種群

產(chǎn)生的方式:隨機(jī)產(chǎn)生的結(jié)果:長度為22的二進(jìn)制串產(chǎn)生的數(shù)量:種群的大?。ㄒ?guī)模),如30,50,…111101001110000101100011001100111010101011101010100011110010000100101111001001110011100100011001010011000000110000011010010000000000……計(jì)算適應(yīng)度

不同的問題有不同的適應(yīng)度計(jì)算方法本例:直接用目標(biāo)函數(shù)作為適應(yīng)度函數(shù)①將某個(gè)體轉(zhuǎn)化為[-1,2]區(qū)間的實(shí)數(shù):

s=<1000101110110101000111>→x=0.637197②計(jì)算x的函數(shù)值(適應(yīng)度):

f(x)=xsin(10πx)+2.0=2.586345計(jì)算適應(yīng)度

二進(jìn)制與十進(jìn)制之間的轉(zhuǎn)換:

第一步,將一個(gè)二進(jìn)制串(b21b20…b0)轉(zhuǎn)化為10進(jìn)制數(shù):第二步,x’對應(yīng)的區(qū)間[-1,2]內(nèi)的實(shí)數(shù):(0000000000000000000000)→-1(1111111111111111111111)→2遺傳操作

選擇:輪盤賭選擇法;交叉:單點(diǎn)交叉;變異:小概率變異模擬結(jié)果

設(shè)置的參數(shù):

種群大小50;交叉概率0.75;變異概率0.05;最大代數(shù)200。

得到的最佳個(gè)體:

smax=<1111001100111011111100>;

xmax=1.8506;

f(xmax)=3.8503;模擬結(jié)果

進(jìn)化的過程:世代數(shù)自變量適應(yīng)度11.44953.449491.83953.7412171.85123.8499301.85053.8503501.85063.8503801.85063.85031201.85063.85032001.85063.8503主程序

%用遺傳算法進(jìn)行簡單函數(shù)的優(yōu)化clearbn=22;%個(gè)體串長度inn=50;%初始種群大小gnmax=200;%最大代數(shù)pc=0.75;%交叉概率pm=0.05;%變異概率Continue…

算法的設(shè)計(jì)與實(shí)現(xiàn)

主程序

%產(chǎn)生初始種群,0,1向量s=round(rand(inn,bn));%計(jì)算適應(yīng)度,返回適應(yīng)度f和累積概率p[f,p]=objf(s);Continue…主程序

gn=1;whilegn<gnmax+1forj=1:2:inn%選擇操作

seln=sel(s,p);%交叉操作

scro=cro(s,seln,pc);

scnew(j,:)=scro(1,:);scnew(j+1,:)=scro(2,:);%變異操作

smnew(j,:)=mut(scnew(j,:),pm);smnew(j+1,:)=mut(scnew(j+1,:),pm);endContinue…主程序

s=smnew;%產(chǎn)生了新的種群%計(jì)算新種群的適應(yīng)度

[f,p]=objf(s);

%記錄當(dāng)前代最好和平均的適應(yīng)度[fmax,nmax]=max(f);fmean=mean(f);ymax(gn)=fmax;ymean(gn)=fmean;Continue…主程序

%記錄當(dāng)前代的最佳個(gè)體x=n2to10(s(nmax,:));xx=-1.0+x*3/(power(2,bn)-1);

xmax(gn)=xx;

gn=gn+1endgn=gn-1;Continue…主程序

%繪制曲線subplot(2,1,1);plot(1:gn,[ymax;ymean]);title('歷代適應(yīng)度變化','fonts',10);legend('最大適應(yīng)度','平均適應(yīng)度');string1=['最終適應(yīng)度',num2str(ymax(gn))];gtext(string1);subplot(2,1,2);plot(1:gn,xmax,'r-');legend('自變量');string2=['最終自變量',num2str(xmax(gn))];gtext(string2);End計(jì)算適應(yīng)度和累計(jì)概率函數(shù)

%計(jì)算適應(yīng)度函數(shù)function[f,p]=objf(s);r=size(s);%讀取種群大小inn=r(1);%有inn個(gè)個(gè)體bn=r(2);%個(gè)體長度為bnContinue…計(jì)算適應(yīng)度和累計(jì)概率函數(shù)

fori=1:innx=n2to10(s(i,:));%將二進(jìn)制轉(zhuǎn)換為十進(jìn)制xx=-1.0+x*3/(power(2,bn)-1);%轉(zhuǎn)化為[-1,2]區(qū)間的實(shí)數(shù)

f(i)=ft(xx);%計(jì)算函數(shù)值,即適應(yīng)度endf=f‘;%行向量轉(zhuǎn)列向量Continue…計(jì)算適應(yīng)度和累計(jì)概率函數(shù)

%計(jì)算選擇概率fsum=0;fori=1:inn

fsum=fsum+f(i)*f(i);endfori=1:inn

ps(i)=f(i)*f(i)/fsum;endContinue…計(jì)算適應(yīng)度和累計(jì)概率函數(shù)

%計(jì)算累積概率p(1)=ps(1);fori=2:inn

p(i)=p(i-1)+ps(i);endp=p';Backtomain.m計(jì)算目標(biāo)函數(shù)值函數(shù)

%目標(biāo)函數(shù)functiony=ft(x);y=x.*sin(10*pi*x)+2;Backtoobjf.m函數(shù)n2to10()

Continue…functionx=n2to10(s)x=0;forj=1:22x=x+s(j)*2^(22-j);end

functionx=n2to10(s)x=s(1);forj=1:21x=x*2+s(j+1);end選擇操作函數(shù)

%“選擇”操作functionseln=sel(s,p);inn=size(p,1);%從種群中選擇兩個(gè)個(gè)體fori=1:2r=rand;%產(chǎn)生一個(gè)隨機(jī)數(shù)

prand=p-r;j=1;whileprand(j)<0j=j+1;end

seln(i)=j;%選中個(gè)體的序號endBacktomain.m交叉操作函數(shù)

%“交叉”操作functionscro=cro(s,seln,pc);r=size(s);inn=r(1);bn=r(2);pcc=pro(pc);%根據(jù)交叉概率決定是否進(jìn)行交叉操作,1則是,0則否Continue…交叉操作函數(shù)

ifpcc==1

chb=round(rand*(bn-2))+1;%在[1,bn-1]范圍內(nèi)隨機(jī)產(chǎn)生一個(gè)交叉位scro(1,:)=[s(seln(1),1:chb)s(seln(2),chb+1:bn)];scro(2,:)=[s(seln(2),1:chb)s(seln(1),chb+1:bn)];elsescro(1,:)=s(seln(1),:);scro(2,:)=s(seln(2),:);endBacktomain.m變異操作函數(shù)

%“變異”操作functionsnnew=mut(snew,pm);r=size(snew);bn=r(2);snnew=snew;Continue…變異操作函數(shù)

pmm=pro(pm);%根據(jù)變異概率決定是否進(jìn)行變異操作,1則是,0則否ifpmm==1

chb=round(rand*(bn-1))+1;%在[1,bn]范圍內(nèi)隨機(jī)產(chǎn)生一個(gè)變異位

snnew(chb)=abs(snew(chb)-1);endBacktomain.m運(yùn)行程序

運(yùn)行程序

運(yùn)行程序

運(yùn)行程序

策略調(diào)整針對不同實(shí)際問題需要調(diào)整相應(yīng)策略同一個(gè)實(shí)際問題不同的人也有不同的做法編碼方案適應(yīng)度函數(shù)設(shè)計(jì)選擇算子交叉算子變異算子初始種群編碼方案本質(zhì):如何表示解二進(jìn)制:自變量高維、大范圍連續(xù)、高精度的時(shí)候很難處理冗余問題,離散化后解的個(gè)數(shù)介于2(n-1)和2n之間D進(jìn)制,D=3,8,16,…實(shí)數(shù)編碼:無需編碼和解碼序列編碼:例如TSP的路徑表達(dá)樹編碼:非定長自適應(yīng)編碼-長度可調(diào)節(jié)適應(yīng)度函數(shù)是進(jìn)行自然選擇的定量標(biāo)準(zhǔn)直接采用目標(biāo)函數(shù)引入適應(yīng)值調(diào)節(jié)線性變換乘冪變換指數(shù)變換自適應(yīng)變換選擇算子輪盤賭選擇(roulettewheelselection)最基本、最常用的方式,又叫適應(yīng)度比例選擇算子最佳個(gè)體保存(elitistmodel)把適應(yīng)度最高的個(gè)體保留到下一代,又叫精英保留排序模型(rank-basedmodel)按適應(yīng)度函數(shù)大小排序,根據(jù)事先設(shè)定的概率表分配選擇概率聯(lián)賽選擇模型(tournamentselectionmodel)隨機(jī)選擇幾個(gè)進(jìn)行比較,高的被選,又叫錦標(biāo)賽模型選擇算子期望值模型(expectedvaluemodel)排擠模型(crowdingmodel)濃度控制策略共享機(jī)制截?cái)噙x擇交叉算子簡單交叉最基本、最常用的方式,雙親互換子串平坦交叉二者之間均勻隨機(jī)產(chǎn)生算術(shù)交叉雙親的凸組合線性交叉1:1,3:1,1:3比較最好的兩個(gè)留下交叉算子混合交叉離散交叉啟發(fā)式交叉模擬二進(jìn)制交叉單峰正態(tài)分布交叉單純形交叉父體中心交叉幾何交叉均勻交叉基于模糊聯(lián)接的交叉變異算子隨機(jī)變異區(qū)間內(nèi)均勻隨機(jī)取非一致變異某個(gè)區(qū)間內(nèi)隨機(jī)擾動邊界變異取邊界值多項(xiàng)式變異高斯變異Cauthy變異自適應(yīng)變異Muhlenbein變異初始種群對計(jì)算結(jié)果和計(jì)算效率有影響全局性要求初始解盡量分散設(shè)計(jì)一些生成方法求解TSP的策略調(diào)整編碼方案二進(jìn)制編碼:交叉和變異很難處理順序表示:1985年

Grefenstette提出,序表示是指所有城市依次排列構(gòu)成一個(gè)順序表(orderlist),對于一條旅程,可以依旅行經(jīng)過順序處理每個(gè)城市,每個(gè)城市在順序表中的順序就是一個(gè)遺傳因子的表示,每處理完一個(gè)城市,從順序表中去掉該城市.處理完所有城市以后,將每個(gè)城市的遺傳因子表示連接起來,就是一條旅程的基因表示.例如,順序表C=(1,2,3,4,5,6,7,8,9),一條旅程為5-1-7-8-9-4-6-3-2.按照這種編碼方法,這條旅程的編碼為表l=(5155533321)編碼方案路徑表示:最自然、直接的表示方法布爾矩陣表示:將一個(gè)旅程定義為一個(gè)優(yōu)先權(quán)布爾矩陣M,當(dāng)且僅當(dāng)城市i排在城市j之前時(shí)矩陣元素mij=1.這種方法用n×n矩陣M代表一條旅程,M具有如下三個(gè)性質(zhì):1)矩陣中1的數(shù)目為n(n-1)/2;2)mii=0,i=1,2,.,n;3)若mij=1,且mjk=1,那么mik=1.選擇算子輪盤賭選擇(roulettewheelselection),最佳個(gè)體保存(elitistmodel),期望值模型(expectedvaluemodel),排序模型(rank-basedmodel),聯(lián)賽選擇模型(tournamentselectionmodel)排擠模型(crowdingmodel)濃度控制策略上述機(jī)制混合交叉算子依賴于編碼方式基于路徑表示的順序交叉基于路徑表示的部分匹配交叉貪心交叉法:在一個(gè)父個(gè)體中選擇第一個(gè)城市作為子個(gè)體的第一個(gè)城市,然后在兩個(gè)父個(gè)體中進(jìn)行比較并找到與已經(jīng)選擇的那個(gè)城市相鄰且距離較近的城市作為下一個(gè)城市擴(kuò)展到旅程中;如果與該城市相鄰的兩個(gè)城市有一個(gè)已經(jīng)在旅程中,那么選擇另外一個(gè),如果兩個(gè)都在旅程中,那么就選擇其它沒有被選擇的城市.循環(huán)交叉邊重組交叉變異算子全局意義點(diǎn)位變異:變異僅以一定的概率(通常很小)對串的某些位做值的變異;逆轉(zhuǎn)變異:在串中,隨機(jī)選擇兩點(diǎn),再將這兩點(diǎn)內(nèi)的子串按反序插入到原來的位置中;對換變異:隨機(jī)選擇串中的兩點(diǎn),交換其值(碼);插入變異:從串中隨機(jī)選擇1個(gè)碼,將此碼插入隨機(jī)選擇的插入點(diǎn)中間.變異算子貪心對換變異:從一個(gè)染色體中隨機(jī)的選擇兩個(gè)城市(即兩個(gè)碼值),然后交換它們,得到新的染色體,以旅程長度為依據(jù)比較交換后的染色體與原來的染色體的大小,保留旅程長度值小的染色體.倒位變異算子:在個(gè)體編碼串中隨機(jī)選擇兩個(gè)城市,第一個(gè)城市的右城市與第二個(gè)城市之間的編碼倒序排列,從而產(chǎn)生一個(gè)新個(gè)體。如,若有父個(gè)體P(14

5236),假設(shè)隨機(jī)選擇的城市是4,3,那么產(chǎn)生的新個(gè)體為Offspring(14

3256).遺傳算法的前景性能分析并行遺傳算法分類系統(tǒng)圖像處理和模式識別優(yōu)化與調(diào)度機(jī)器學(xué)習(xí)智能控制其它……人工生命自動程序設(shè)計(jì)應(yīng)用

遺傳算法的應(yīng)用二、算法應(yīng)用領(lǐng)域遺傳算法提供了一種求解復(fù)雜系統(tǒng)優(yōu)化問題的通用框架,它不依賴于問題的具體領(lǐng)域,對問題的種類有很強(qiáng)的魯棒性,所以廣泛應(yīng)用于很多學(xué)科。下面列舉一些遺傳算法的主要應(yīng)用領(lǐng)域。

函數(shù)優(yōu)化、組合優(yōu)化、生產(chǎn)調(diào)度、自動控制、機(jī)器人學(xué)、圖象處理、人工生命、遺傳編程、機(jī)器學(xué)習(xí)等。函數(shù)優(yōu)化。函數(shù)優(yōu)化是遺傳算法的經(jīng)典應(yīng)用領(lǐng)域,也是對遺傳算法進(jìn)行性能測試評價(jià)的常用算例。對于一些非線性、多模型、多目標(biāo)的函數(shù)優(yōu)化問題,用其他優(yōu)化方法較難求解,而遺傳算法卻可以方便地得到較好的結(jié)果。組合優(yōu)化。遺傳算法是尋求組合優(yōu)化問題滿意解的最佳工具之一,實(shí)踐證明,遺傳算法對于組合優(yōu)化問題中的NP完全問題非常有效。

TSP問題、背包問題、圖劃分問題生產(chǎn)調(diào)度問題。生產(chǎn)調(diào)度問題在很多情況下所建立起來的數(shù)學(xué)模型難以精確求解,即使經(jīng)過一些簡化之后可以進(jìn)行求解也會因簡化得太多而使求解結(jié)果與實(shí)際相差太遠(yuǎn)?,F(xiàn)在遺傳算法已經(jīng)成為解決復(fù)雜調(diào)度問題的有效工具。自動控制。遺傳算法已經(jīng)在自動控制領(lǐng)域中得到了很好的應(yīng)用,例如基于遺傳算法的模糊控制器的優(yōu)化設(shè)計(jì)、基于遺傳算法的參數(shù)辨識、基于遺傳算法的模糊控制規(guī)則的學(xué)習(xí)、利用遺傳算法進(jìn)行人工神經(jīng)網(wǎng)絡(luò)的結(jié)構(gòu)優(yōu)化設(shè)計(jì)和權(quán)值學(xué)習(xí)等。如:瓦斯管道控制、導(dǎo)彈控制、機(jī)器人控制等

機(jī)器人學(xué)。機(jī)器人是一類復(fù)雜的難以精確建模的人工系統(tǒng),而遺傳算法的起源就來自于對人工自適應(yīng)系統(tǒng)的研究,所以機(jī)器人學(xué)自然成為遺傳算法的一個(gè)重要應(yīng)用領(lǐng)域。圖象處理。圖像處理是計(jì)算機(jī)視覺中的一個(gè)重要研究領(lǐng)域。在圖像處理過程中,如掃描、特征提取、圖像分割等不可避免地存在一些誤差,這些誤差會影響圖像處理的效果。如何使這些誤差最小是使計(jì)算機(jī)視覺達(dá)到實(shí)用化的重要要求,遺傳算法在這些圖像處理中的優(yōu)化計(jì)算方面得到了很好的應(yīng)用。

如,模式識別、特征抽取人工生命。人工生命是用計(jì)算機(jī)、機(jī)械等人工媒體模擬或構(gòu)造出的具有自然生物系統(tǒng)特有行為的人造系統(tǒng)。。自組織能力和自學(xué)習(xí)能力是人工生命的兩大重要特征。人工生命與遺傳算法有著密切的關(guān)系,基于遺傳算法的進(jìn)化模型是研究人工生命現(xiàn)象的重要理論基礎(chǔ)。遺傳編程。Koza發(fā)展了遺傳編程的概念,他使用了以LISP語言所表示的編碼方法,基于對一種樹形結(jié)構(gòu)所進(jìn)行的遺傳操作來自動生成計(jì)算機(jī)程序。機(jī)器學(xué)習(xí)?;谶z傳算法的機(jī)器學(xué)習(xí),在很多領(lǐng)域中都得到了應(yīng)用。例如基于遺傳算法的機(jī)器學(xué)習(xí)可用來調(diào)整人工神經(jīng)網(wǎng)絡(luò)的連接權(quán),也可以用于人工神經(jīng)網(wǎng)絡(luò)的網(wǎng)絡(luò)結(jié)構(gòu)優(yōu)化設(shè)計(jì)。規(guī)劃生產(chǎn)規(guī)劃、并行機(jī)任務(wù)分配等;設(shè)計(jì)通信網(wǎng)絡(luò)設(shè)計(jì)、噴氣發(fā)動機(jī)設(shè)計(jì)等;信號處理濾波器設(shè)計(jì)等;機(jī)器人路徑規(guī)劃等。

遺傳算法的應(yīng)用

函數(shù)優(yōu)化

是遺傳算法的經(jīng)典應(yīng)用領(lǐng)域;組合優(yōu)化

實(shí)踐證明,遺傳算法對于組合優(yōu)化中的NP完全問題非常有效;自動控制

如基于遺傳算法的模糊控制器優(yōu)化設(shè)計(jì)、基于遺傳算法的參數(shù)辨識、利用遺傳算法進(jìn)行人工神經(jīng)網(wǎng)絡(luò)的結(jié)構(gòu)優(yōu)化設(shè)計(jì)和權(quán)值學(xué)習(xí)等;機(jī)器人智能控制

遺傳算法已經(jīng)在移動機(jī)器人路徑規(guī)劃、關(guān)節(jié)機(jī)器人運(yùn)動軌跡規(guī)劃、機(jī)器人逆運(yùn)動學(xué)求解、細(xì)胞機(jī)器人的結(jié)構(gòu)優(yōu)化和行動協(xié)調(diào)等;組合圖像處理和模式識別

目前已在圖像恢復(fù)、圖像邊緣持征提取、幾何形狀識別等方面得到了應(yīng)用;

遺傳算法的應(yīng)用

人工生命

基于遺傳算法的進(jìn)化模型是研究人工生命現(xiàn)象的重要理論基礎(chǔ),遺傳算法已在其進(jìn)化模型、學(xué)習(xí)模型、行為模型等方面顯示了初步的應(yīng)用能力;遺傳程序設(shè)計(jì)

Koza發(fā)展了遺傳程序設(shè)計(jì)的慨念,他使用了以LISP語言所表示的編碼方法,基于對一種樹型結(jié)構(gòu)所進(jìn)行的遺傳操作自動生成計(jì)算機(jī)程序;

遺傳算法的應(yīng)用

遺傳算法的應(yīng)用

約束最優(yōu)化問題(ConstrainedOptimizationProblems)的表述

1解決帶約束的函數(shù)優(yōu)化問題

解決途徑將有約束問題轉(zhuǎn)化為無約束問題(罰函數(shù)法,penaltyfunctionmethod),歷史較長;改進(jìn)無約束問題的方法,使之能用于有約束的情況(梯度投影算法),發(fā)展較晚。遺傳算法解決有約束問題的關(guān)鍵是對約束條件的處理(直接按無約束問題處理是行不通的:隨機(jī)生成的初始點(diǎn)中可能有大量不可行解;遺傳算子作用于可行解后可能產(chǎn)生不可行解)。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

一般方法罰函數(shù)法

將罰函數(shù)包含到適應(yīng)度評價(jià)中:關(guān)鍵是如何設(shè)計(jì)罰函數(shù),需要謹(jǐn)慎地在過輕或過重懲罰之間找到平衡,針對不同問題設(shè)計(jì)罰函數(shù)。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

一般方法協(xié)同進(jìn)化遺傳算法(CoevolutionaryGeneticAlgorithm,1997)

以食物鏈關(guān)系、共生關(guān)系等為基礎(chǔ)的生物進(jìn)化現(xiàn)象稱為協(xié)同進(jìn)化;一個(gè)種群由問題的解組成,另一個(gè)種群由約束組成,兩個(gè)種群協(xié)同進(jìn)化,較好的解應(yīng)滿足更好的約束,較優(yōu)的約束則被更多的解所違背。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

罰函數(shù)法評價(jià)函數(shù)的構(gòu)造:

加法

乘法

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

罰函數(shù)法罰函數(shù)分類:

定量懲罰——簡單約束問題

變量懲罰——復(fù)雜約束問題,包含兩個(gè)部分:可變懲罰率和違反約束的懲罰量。違反約束程度——隨違反約束程度變得嚴(yán)重而增加懲罰壓力,靜態(tài)懲罰;進(jìn)化迭代次數(shù)——隨著進(jìn)化過程的進(jìn)展而增加懲罰壓力,動態(tài)懲罰。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

罰函數(shù)法交叉運(yùn)算:設(shè)父個(gè)體為x=[x1,x2,…,xn]和y=[y1,y2,…,yn]

簡單交叉單點(diǎn)算術(shù)交叉整體算術(shù)交叉基于方向的交叉:x’=r(x-y)+x,r為(0,1)之間的隨機(jī)數(shù),并假設(shè)f(x)≥f(y)。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

罰函數(shù)法變異運(yùn)算:設(shè)父個(gè)體為x=[x1,x2,…,xn]

均勻變異非均勻變異(動態(tài)變異)邊界變異:x’=[x1,x2,…,xk’,…,xn],xk’等概率地取用變異量的上界或下界,當(dāng)最優(yōu)解在可行域邊界上或附近時(shí),邊界變異算子較為有效;基于方向的變異:x’=x+r?d,d為目標(biāo)函數(shù)的近似梯度。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

線性約束優(yōu)化問題一般形式為:

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

線性約束優(yōu)化問題:

目標(biāo)函數(shù)可以是線性函數(shù)或非線性函數(shù);

思路——消除可能的變量,消除等式約束設(shè)計(jì)罰函數(shù)設(shè)計(jì)特別的遺傳操作

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法例:7×7運(yùn)輸規(guī)劃問題將物品由7個(gè)起運(yùn)站運(yùn)到7個(gè)目的地;已知由i站運(yùn)到j(luò)

地的單位運(yùn)費(fèi)是Cij,

ai表示i

站的供應(yīng)量,

bj表示j

地的需求量,

xij表示從i

站到j(luò)

地的運(yùn)量。(i,j=1,2,…,7)

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

對于非線性目標(biāo)函數(shù)的構(gòu)造,可以選用以下幾種測試函數(shù):(1)函數(shù)A

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

(2)函數(shù)B

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法例:7×7運(yùn)輸規(guī)劃問題

(3)函數(shù)C

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

(4)函數(shù)D

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

(5)函數(shù)E

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

(6)函數(shù)F

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

目標(biāo)函數(shù)為罰函數(shù)為其中,k=1,P=1/14,f為第t代群體的平均適應(yīng)度,T為最大運(yùn)行代數(shù),dij為約束的違反度。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法例:7×7運(yùn)輸規(guī)劃問題對于約束,個(gè)體染色體表示為(v11,…,v77),其約束違反度定義為:

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

費(fèi)用參數(shù)表對于函數(shù)A,取S=2,對于函數(shù)B、E和F,取S=5。cij27282520202020200215062937710002021017546710004820501706098672523625460027100038269367982704742257710006710004703526100048253842350

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

消除多余變量:可以消除13個(gè)變量,x11,x12,…,x17,x21,x31,x41,x51,x61,x71,其余36個(gè)變量設(shè)定為y1,y2,…,y36

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

將原規(guī)劃問題轉(zhuǎn)化為:

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題

采用的參數(shù):種群大小40,均勻變異概率0.08,邊界變異概率0.03,非均勻變異概率0.07,簡單交叉概率0.10,單一算術(shù)概率0.10,整體算術(shù)概率0.10,運(yùn)行代數(shù)8000。

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

遺傳算法的應(yīng)用

1解決帶約束的函數(shù)優(yōu)化問題

求解線性約束優(yōu)化問題的遺傳算法

例:7×7運(yùn)輸規(guī)劃問題結(jié)果比較:GENOCOP(約束優(yōu)化的遺傳算法)GAMS(擬牛頓法非線性最優(yōu)化算法)函數(shù)ABCDEFGAMS96.001141.602535.29565.15208.2543527.54GENOCOP24.15205.602571.04480.16204.82119.61誤差%297.52455.25-1.4117.701.6736291.22多目標(biāo)優(yōu)化問題

解的存在性怎樣求解

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

Pareto最優(yōu)性理論

在一個(gè)有k個(gè)目標(biāo)函數(shù)最小化的問題中,稱決策向量x*∈F是Pareto最優(yōu)的,當(dāng)不存在另外一個(gè)決策向量x∈F同時(shí)滿足

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

Pareto最優(yōu)性理論

多目標(biāo)優(yōu)化問題的解通常是多個(gè)滿意解的集合,稱為Pareto最優(yōu)集,解集中的決策向量稱為非劣的。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

傳統(tǒng)方法

多目標(biāo)加權(quán)法層次優(yōu)化法目標(biāo)規(guī)劃法等特點(diǎn):將多目標(biāo)函數(shù)轉(zhuǎn)化為單目標(biāo)函數(shù)處理,只能得到特定條件下的某一Pareto解。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

多目標(biāo)優(yōu)化的遺傳算法

優(yōu)勢:

并行地處理一組可能的解;不局限于Pareto前沿的形狀和連續(xù)性,易于處理不連續(xù)的、凹形的Pareto前沿。目前基于Pareto的遺傳算法占據(jù)主要地位。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

多目標(biāo)優(yōu)化的遺傳算法

聚合函數(shù)法:把多個(gè)目標(biāo)函數(shù)表示成一個(gè)目標(biāo)函數(shù)作為遺傳算法的適應(yīng)函數(shù)(聚合);無需改動遺傳算法,但權(quán)值難以確定;

改進(jìn):自適應(yīng)權(quán)值。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

多目標(biāo)優(yōu)化的遺傳算法

向量評價(jià)遺傳算法(非Pareto法):

子種群的產(chǎn)生根據(jù)每一個(gè)目標(biāo)函數(shù)分別進(jìn)行選擇。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

多目標(biāo)優(yōu)化的遺傳算法

基于排序的多目標(biāo)遺傳算法:

根據(jù)“Pareto最優(yōu)個(gè)體”的概念對所有個(gè)體進(jìn)行排序,依據(jù)這個(gè)排列次序來進(jìn)行進(jìn)化過程中的選擇運(yùn)算,從而使得排在前面的Pareto最優(yōu)個(gè)體將有更多的機(jī)會遺傳到下一代群體。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

多目標(biāo)優(yōu)化的遺傳算法小生境Pareto遺傳算法:

為了保證尋優(yōu)過程不收斂于可行域的某一局部,使種群向均勻分布于Pareto前沿面的方向進(jìn)化,通過共享函數(shù)定義一小生境加以實(shí)現(xiàn)。

遺傳算法的應(yīng)用

2

解決多目標(biāo)優(yōu)化問題

TSPBenchmark問題

4194;3784;5467;2562;764;299;6858;7144;5462;8369;6460;1854;2260;8346;9138;2538;2442;5869;7171;7478;8776;1840;1340;827;6232;5835;4521;4126;4435;450

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題

編碼:直接采用解的表示形式,30位(30個(gè)城市)長,每位代表所經(jīng)過的城市序號(無重復(fù));

適應(yīng)度函數(shù):個(gè)體所代表的路徑距離的倒數(shù);

選擇:輪盤賭方法

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題

交叉:有序交叉法

1)隨機(jī)選取兩個(gè)交叉點(diǎn);

2)兩個(gè)父個(gè)體交換中間部分;

3)替換交換后重復(fù)的城市序號。X1:98|45671|320X2:87|14032|965X1’:98|14032|320X2’:87|45671|965X1’:98|14032|756X2’:83|45671|902

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題

變異:隨機(jī)選擇同一個(gè)個(gè)體的兩個(gè)點(diǎn)進(jìn)行交換;

初始參數(shù):種群規(guī)模100

交叉概率0.8

變異概率0.8

終止代數(shù)2000

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

TSPBenchmark問題運(yùn)行結(jié)果:

遺傳算法的應(yīng)用

3

解決組合優(yōu)化問題

優(yōu)化神經(jīng)網(wǎng)絡(luò)的權(quán)值神經(jīng)網(wǎng)絡(luò)建模:x1輸出層隱藏層輸入層x2yxn…………

遺傳算法的應(yīng)用

4

在過程建模中的應(yīng)用

優(yōu)化神經(jīng)網(wǎng)絡(luò)的權(quán)值

例:聚丙烯生產(chǎn)過程熔融指數(shù)的軟測量模型輸入變量:加氫量、釜壓、升溫時(shí)間、反應(yīng)時(shí)間、攪拌電流;輸出變量:熔融指數(shù);樣本數(shù)據(jù):240組現(xiàn)場數(shù)據(jù);

遺傳算法的應(yīng)用

4

在過程建模中的應(yīng)用

優(yōu)化神經(jīng)網(wǎng)絡(luò)

溫馨提示

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

最新文檔

評論

0/150

提交評論