基于改進(jìn)的遺傳算法軟硬件劃分方法研究
SoC軟硬件劃分問題實(shí)際上可以看作一個(gè)求解多個(gè)目標(biāo)的優(yōu)化問題。其目標(biāo)是在滿足一定系統(tǒng)約束的前提下實(shí)現(xiàn)系統(tǒng)性能的最優(yōu)化?;诟倪M(jìn)的軟硬件劃分步驟如下:
步驟1:將待優(yōu)化的SoC系統(tǒng)轉(zhuǎn)化為數(shù)據(jù)流圖DFG
步驟2:從IP庫中調(diào)出數(shù)據(jù)流圖中可實(shí)現(xiàn)每個(gè)任務(wù)節(jié)點(diǎn)的候選IP
步驟3:對個(gè)體進(jìn)行整數(shù)編碼初始化,形成群體P0
步驟4:對Pi中的每個(gè)個(gè)體進(jìn)行性能評估,計(jì)算其執(zhí)行時(shí)間、面積、功耗和成本
步驟5:適應(yīng)度賦值
步驟6:合并Pi和P*i群體,對其進(jìn)行Pareto排序,構(gòu)造非支配集(NDS)。復(fù)制Pareto最優(yōu)個(gè)體,即所得的非支配集,記做P*i+1
步驟7:判斷結(jié)束條件是否滿足,如果t>Gen,則進(jìn)化結(jié)束,P*i+1為最終輸出的非劣解,P*i+1中每個(gè)個(gè)體的實(shí)現(xiàn)方式即為候選的軟硬件劃分解。否則繼續(xù),轉(zhuǎn)步驟8
步驟8:構(gòu)造新群體。如果NDSpopsize,用分類方法構(gòu)造新群體;如果NDS>popsize,用聚類方法構(gòu)造新群體步驟9:對新群體執(zhí)行遺傳操作,操作的結(jié)果設(shè)為pi+l,令T=Pi+l;轉(zhuǎn)步驟4
3.1 數(shù)據(jù)流圖描述
數(shù)據(jù)流圖DFG(Data Flow Graph)是一個(gè)包含頂點(diǎn)和邊的有向無環(huán)圖。DFG由節(jié)點(diǎn)和弧線構(gòu)成,當(dāng)一個(gè)DFG用來描述一個(gè)SoC系統(tǒng)時(shí),其頂點(diǎn)通常用來表示一些功能單元,對應(yīng)構(gòu)成系統(tǒng)的軟硬件部件;而弧則表示數(shù)據(jù)處理的順序,或者說是頂點(diǎn)之間的數(shù)據(jù)依賴關(guān)系,如圖3所示。本文引用地址:http://cafeforensic.com/article/188731.htm
3.2 個(gè)體編碼和遺傳操作
在基于遺傳算法的軟硬件劃分中,最常見的編碼方法是二進(jìn)制編碼。通過二進(jìn)制編碼將數(shù)據(jù)流圖的節(jié)點(diǎn)映射到位串空間0和1上,然后在位串空間進(jìn)行遺傳操作。一般用0表示該節(jié)點(diǎn)由軟件實(shí)現(xiàn),用l表示該節(jié)點(diǎn)由硬件實(shí)現(xiàn)。設(shè)IP核數(shù)目為20,每個(gè)節(jié)點(diǎn)編碼長度為5,二進(jìn)制編碼的交叉變異情況如圖3、圖4所示。
在圖3、圖4的遺傳操作過程中,有兩個(gè)節(jié)點(diǎn)的個(gè)體{Xl,X2}的二進(jìn)制編碼長度為10,節(jié)點(diǎn)Xl、X2的編碼取值范圍均為[00000,l0011],經(jīng)過交叉和變異操作后,分別產(chǎn)生超出編碼取值范圍的無效個(gè)體{1011l,l0010}和{0llll,11010}。出于上述原因,本文采用整數(shù)向量編碼的個(gè)體編碼方案。該方法直接自然,避免了編碼、解碼的冗余,減輕了遺傳算法的計(jì)算負(fù)擔(dān),提高了運(yùn)算效率,能夠更好地保持群體的多樣性。
針對圖3所示為目標(biāo)對象,在交叉概率PC=0.62,變異概率Pm=0.02,種群大小sizePop=80,演化代數(shù)numGen=l00的條件下,通過Matlab遺傳工具箱進(jìn)行模擬仿真,得出仿真結(jié)果如圖5所示。圖5中群體均值隨著迭代次數(shù)的增加逐漸收斂,說明基于小生境技術(shù)和精英保持策略的改進(jìn)算法可以得到該優(yōu)化問題的最優(yōu)解。
4 結(jié)論
綜上所述,在小生境技術(shù)的基礎(chǔ)上引入精英保持策略和保持群體多樣性的方法,即經(jīng)過優(yōu)化策略之后的算法,能夠更好更快地搜索到最優(yōu)解集,從而達(dá)到了加速算法收斂速度、并避免陷入局部最優(yōu)的目的。
評論