資源描述:
《用遺傳算法解決0-1背包問(wèn)題》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在工程資料-天天文庫(kù)。
1、實(shí)現(xiàn)遺傳算法的0-1背包問(wèn)題求解及其改進(jìn)姓名:學(xué)號(hào):班級(jí):提交日期:201?年6月27旦_實(shí)現(xiàn)遺傳算法的0-1背包問(wèn)題求解摘要:研究了遺傳算法解決0-1背包問(wèn)題中的幾個(gè)問(wèn)題:1)對(duì)于過(guò)程中不滿足重量限制條件的個(gè)體的處理,通過(guò)代換上代最優(yōu)解保持種群的進(jìn)化性2)對(duì)于交換率和變異率的理解和處理方法,采用逐個(gè)體和逐位判斷的處理方法3)對(duì)于早熟性問(wèn)題,引入相似度衡量值并通過(guò)重新生成個(gè)體替換最差個(gè)體方式保持種群多樣性。4)一種最優(yōu)解只向更好進(jìn)化方法的嘗試。通過(guò)實(shí)際計(jì)其比較表明,本文改進(jìn)遺傳算法在背包問(wèn)題求解中具有
2、很好的收斂性、穩(wěn)定性和計(jì)算效率。通過(guò)實(shí)例計(jì)算,表明本文改進(jìn)遺傳算法優(yōu)于簡(jiǎn)單遺傳算法和普通改進(jìn)的遺傳算法關(guān)鍵詞:遺傳算法;背包問(wèn)題;優(yōu)化1.基本實(shí)現(xiàn)原理:一、問(wèn)題描述0-1背包問(wèn)題屬于組合優(yōu)化問(wèn)題的一個(gè)例子,求解0-1背包問(wèn)題的過(guò)程可以被視作在很多可行解當(dāng)屮求解一個(gè)最優(yōu)解。01背包問(wèn)題的一般描述如下:給定n個(gè)物品和一個(gè)背包,物品i的重量為Wi,其價(jià)值為Vi,背包的容量為C。選擇合適的物品裝入背包,使得背包中裝入的物品的總價(jià)值最大。注意的一點(diǎn)是,背包內(nèi)的物品的重量之和不能大于背的容量C。在選擇裝入背的物品
3、時(shí),對(duì)每種物品i只有兩種選擇:裝入背包或者不裝入背包,即只能將物品i裝入背包一次。稱此類問(wèn)題為0/1背包問(wèn)題。其數(shù)學(xué)模型為:c的餅下f=l?其中1=Ir2.r3.r40-1背包問(wèn)題傳統(tǒng)的解決方法奮動(dòng)態(tài)規(guī)劃法、分支界限法、冋溯法等等。傳統(tǒng)的方法不能奮效地解決0-1背包問(wèn)題。遺傳算法(GeneticAlgorithms)則是一種適合于在火量的可行解屮搜索最優(yōu)(或次優(yōu))解的有效算法。二、遺傳算法特點(diǎn)介紹:遺傳算法(GeneticAlgorithm,GA}是1962年Holland教授首次提出了GA算法的思想
4、是近年來(lái)隨著信息數(shù)據(jù)量激增,發(fā)展起來(lái)的一種嶄新的全局優(yōu)化算法,它借用了生物遺傳學(xué)的觀點(diǎn),通過(guò)自然選擇、遺傳、變異等作用機(jī)制,實(shí)現(xiàn)各個(gè)個(gè)體的適應(yīng)性的提高?;具z傳算法求解步驟:Step1參數(shù)設(shè)置:在論域空間上定義一個(gè)適應(yīng)度函數(shù)/(x),給定種群規(guī)模W,交叉率Pc和變異率Pm,代數(shù)r;Step2初始種群:隨機(jī)產(chǎn)生<7中的W個(gè)染色體slzs2,sN,組成初始種群5={slzs2,…,sN},置代數(shù)計(jì)數(shù)器Step3計(jì)算適應(yīng)度:S中每個(gè)染色體的適應(yīng)度f(wàn)();SteP4判斷:若終止條件滿足,則取5中適應(yīng)度最大的
5、染色體作為所求結(jié)果,算法結(jié)束。Step5選擇?復(fù)制:按選擇概率PU,)所決定的選中機(jī)會(huì),每次從S中隨機(jī)選定1個(gè)染色體并將其復(fù)制,共做/V次,然后將復(fù)制所得的W個(gè)染色體組成群體51;Step6交叉:按交叉率所決定的參加交叉的染色體數(shù)c,從中隨機(jī)確定c個(gè)染色體,配對(duì)進(jìn)行交叉操作,并用產(chǎn)生的新染色體代替原染色體,得群體52;Step7變異:按變異率Pm所決定的變異次數(shù)m,從52中隨機(jī)確定m個(gè)染色體,分別進(jìn)行變異操作,并用產(chǎn)生的新染色體代替原染色體,得群體53;Step8更新:將群體53作為新一代種群,即用S
6、3代替5,轉(zhuǎn)步3;遺傳算法是一種仿生算法,即模擬生命演化的算法,它從一個(gè)代表問(wèn)題初始解的初始種群出發(fā),不斷重復(fù)執(zhí)行選擇,雜交和變異的過(guò)程,使種群進(jìn)化越來(lái)越接近某一目標(biāo)既最優(yōu)解,如果視種群為超空間的一組點(diǎn),選擇、雜交和變異的過(guò)程即是在超空間中進(jìn)行點(diǎn)集之間的某種變換,通過(guò)信息交換使種群不斷變化,遺傳算法通過(guò)模擬達(dá)爾文“優(yōu)勝劣汰,適者生存”的原理激勵(lì)好的結(jié)構(gòu),同時(shí)尋找更好的結(jié)構(gòu),作為一種隨機(jī)的優(yōu)化與搜索方法,遺傳算法有著其鮮明的待點(diǎn)。一遺傳算法一般是直接在解空間搜索,而不像圖搜索那樣一般是在問(wèn)題空間搜索,最
7、后才找到解(如果搜索成功的話)。一遺傳算法的搜索隨機(jī)地始于搜索空間的一個(gè)點(diǎn)集,而不像圖搜索那樣固定地始于搜索空間的初始節(jié)點(diǎn)或終止節(jié)點(diǎn),所以遺傳算法是一種隨機(jī)搜索算法。一遺傳算法總是在尋找優(yōu)解(最優(yōu)解或次優(yōu)解),而不像閣搜索那樣并非總是耍求優(yōu)解,而一般是設(shè)法盡快找到解(當(dāng)然包括優(yōu)解b所以遺傳算法乂是一種優(yōu)化搜索算法。一遺傳算法的搜索過(guò)程是從空間的一個(gè)點(diǎn)集(種群)到另一個(gè)點(diǎn)集(種群)的搜索,而不像圖搜索那樣一般是從空間的一個(gè)點(diǎn)到另一個(gè)點(diǎn)地搜索。因而它實(shí)際是一種并行搜索,適合大規(guī)模并行計(jì)算,而且這種種群到種
8、群的搜索有能力跳出局部最優(yōu)解。一遺傳算法的適應(yīng)性強(qiáng),除需知適應(yīng)度函數(shù)外,幾乎不需要其他的先驗(yàn)知識(shí)。一遺傳算法長(zhǎng)于全局搜索,它不受搜索空間的限制性假設(shè)的約束,不要求連續(xù)性,能以很大的概率從離散的、多極值的、含有噪聲的高維問(wèn)題中找到全局最優(yōu)解。3.程序步驟:一、使用基本遺傳算法解決0-1背包問(wèn)題:1:打開數(shù)據(jù)文件2:設(shè)罝程序運(yùn)行主界面3:調(diào)用初始化種群模塊3-1:按照一定的種群規(guī)模和染色體長(zhǎng)度以基因?yàn)閱挝挥秒S機(jī)產(chǎn)生的0-1對(duì)個(gè)體賦值3-2:調(diào)用計(jì)算適應(yīng)度函數(shù)