chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

混合算法求解作業(yè)車間調(diào)度問題代碼解讀+完整JAVA代碼

電子設(shè)計(jì) ? 來源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-24 16:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前兩篇文章中,我們介紹了FJSP問題,并梳理了一遍HA算法。這一篇文章對小編實(shí)現(xiàn)的(很亂很爛的)代碼進(jìn)行簡單解讀。

往期回顧:

種群進(jìn)化+鄰域搜索的混合算法(GA+TS)求解作業(yè)車間調(diào)度問題(JSP)-算法介紹

混合算法(GA+TS)求解作業(yè)車間調(diào)度問題(JSP)-禁忌搜索部分

代碼下載請關(guān)注公眾號,后臺回復(fù)【FJSPHA】即可,不包括【】

代碼框架

代碼分為5個包,第一部分Data為用到的各類結(jié)構(gòu),第二部分GA為GA部分+第一個TS,第三部分主函數(shù),第四、五部分是兩個TS。

算例放置在input文件夾中,這里準(zhǔn)備了Mk系列算例,Kacem系列算例和論文中的簡單算例test.txt。

Main

算例輸入:

Main中還有一個輸出為CSV的函數(shù),需要一個jar包,已經(jīng)放在下載鏈接里了,不需要的同學(xué)也可以刪除。

Data

一堆亂七八糟的結(jié)構(gòu)。這里簡單講一下Solution類和Graph類。

Solution類中包含多個print函數(shù),比較重要的包括繪制甘特圖以及check解是否合法。

operationMatrix是解的主題,存放某個工件的某道工序的開始、結(jié)束時間,所在加工機(jī)器。

Graph類表示析取圖。nodeList是每臺機(jī)器上的node。其中起始點(diǎn)、終止點(diǎn)我單獨(dú)提取出來設(shè)置了兩個類。Graph中還包含了獲取critical path的DFS和update starting time & end time的Bellman算法。

GA

MyHybridAlgorithm類是GA的主函數(shù)。小編在實(shí)現(xiàn)的時候進(jìn)行了多種測試,比如迭代的noImprove次數(shù)達(dá)到limit時進(jìn)行擾動:

選擇哪種Tabu:

讀者在閱讀的時候請自己注意。

算法相關(guān)的參數(shù)我都做了初始化,請自行查找修改:

交叉、變異等操作包含在ChromosomeOperation類中,計(jì)算適應(yīng)度的函數(shù)在CaculateFitness類中,TabuSearch1類是基于編碼的tabu,這里都不多展示了。

NeighbourSearch

這個包包含的是基于析取圖的tabu。NeighbourAlgorithms類相當(dāng)于Main,包含解轉(zhuǎn)化為圖的函數(shù):

TabuSearch2類為tabu主函數(shù)。NeighbourGraph類存放析取圖鄰域搜索產(chǎn)生的解。

DeleteNeighbourGraph類為析取圖中暫時去掉某個點(diǎn)后的情況,PM、PJ、SM、SJ代表precede、succeed、machine、job四條邊對應(yīng)的點(diǎn),deleteNode為刪去的點(diǎn)。

其中還有findLandR位置的二分查找函數(shù),insert時的估值函數(shù):

NeighbourSearch2

這個包為第三個基于甘特圖的tabu。

RTS類為tabu的主函數(shù)。解通過:ArrayList<ArrayList<Operation>> 的形式表示。

replan函數(shù)中包含了在甘特圖上進(jìn)行swap操作后更新解的方法,有詳細(xì)注釋:

總結(jié)

到這里已經(jīng)大致梳理了一遍代碼,但其中還有很多細(xì)節(jié)沒有講到,包括很多東西實(shí)現(xiàn)的不好,歡迎隨時和我交流。

由于是自己研究時寫的代碼,其中很多東西會比較亂,但是代碼中做了很多注解,仔細(xì)閱讀應(yīng)該能看得懂的!

下載的壓縮包里包括我學(xué)習(xí)過程中看過的大部分文獻(xiàn),包括主要參考的文獻(xiàn),大家可以進(jìn)一步閱讀研究。

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4761

    瀏覽量

    97167
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2997

    瀏覽量

    115706
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4942

    瀏覽量

    73163
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    Arm Neoverse CPU上大代碼Java應(yīng)用的性能測試

    Java 是互聯(lián)網(wǎng)領(lǐng)域廣泛使用的編程語言。Java 應(yīng)用的一些特性使其性能表現(xiàn)與提前編譯的原生應(yīng)用(例如 C 程序)大相徑庭。由于 Java 字節(jié)碼無法直接在 CPU 上執(zhí)行,因此通常運(yùn)行時在
    的頭像 發(fā)表于 11-05 11:25 ?386次閱讀
    Arm Neoverse CPU上大<b class='flag-5'>代碼</b>量<b class='flag-5'>Java</b>應(yīng)用的性能測試

    Java 25正式發(fā)布,重要特性詳解(附代碼示例):靈活構(gòu)造函數(shù)體、模塊導(dǎo)入聲明、AOT方法分析等

    Java 25現(xiàn)已發(fā)布,更多新特性來了!配合Perforce JRebel,代碼修改即時生效,無需重啟服務(wù),即可實(shí)現(xiàn)“改完就看效果”。新特性+快工具,讓你的Java開發(fā)體驗(yàn)雙倍提升!
    的頭像 發(fā)表于 10-29 13:16 ?878次閱讀
    <b class='flag-5'>Java</b> 25正式發(fā)布,重要特性詳解(附<b class='flag-5'>代碼</b>示例):靈活構(gòu)造函數(shù)體、模塊導(dǎo)入聲明、AOT方法分析等

    外殼防護(hù)等級(IP代碼)全解讀

    什么是外殼防護(hù)等級(IP代碼)IP代碼,全稱為“國際防護(hù)等級”,是由國際電工委員會制定的全球通用標(biāo)準(zhǔn)。這一標(biāo)準(zhǔn)旨在為電子設(shè)備外殼的防護(hù)能力提供一個清晰、統(tǒng)一的評判體系。簡單來說,IP代碼就是電子設(shè)備
    的頭像 發(fā)表于 10-14 12:13 ?474次閱讀
    外殼防護(hù)等級(IP<b class='flag-5'>代碼</b>)全<b class='flag-5'>解讀</b>

    【產(chǎn)品介紹】Altair PBS Professional HPC工作負(fù)載管理器和作業(yè)調(diào)度管理系統(tǒng)

    AltairPBSProfessional行業(yè)領(lǐng)先的HPC工作負(fù)載管理器和作業(yè)調(diào)度管理系統(tǒng)PBSProfessional是一款快速、強(qiáng)大的工作負(fù)載管理器和作業(yè)調(diào)度管理系統(tǒng),旨在提高生產(chǎn)
    的頭像 發(fā)表于 09-19 17:03 ?386次閱讀
    【產(chǎn)品介紹】Altair PBS Professional HPC工作負(fù)載管理器和<b class='flag-5'>作業(yè)</b><b class='flag-5'>調(diào)度</b>管理系統(tǒng)

    HarmonyOSAI編程智能代碼解讀

    CodeGenie > Explain Code,開始解讀當(dāng)前代碼內(nèi)容。 說明 最多支持解讀20000字符以內(nèi)的代碼片段。 使用該功能需先完成CodeGenie登錄授權(quán)。 本文主
    發(fā)表于 09-02 16:29

    Perforce JRebel 簡介:即時加載代碼變更,加速Java應(yīng)用開發(fā)

    Perforce JRebel 專為Java開發(fā)提速而生!支持跳過構(gòu)建與重新部署,實(shí)時加載代碼變更,支持100+框架,無縫集成主流IDE與應(yīng)用服務(wù)器。
    的頭像 發(fā)表于 08-14 14:35 ?495次閱讀
    Perforce JRebel 簡介:即時加載<b class='flag-5'>代碼</b>變更,加速<b class='flag-5'>Java</b>應(yīng)用開發(fā)

    HarmonyOS AI輔助編程工具(CodeGenie)代碼智能解讀

    。 選中.ets文件或者.cpp文件中需要被解釋的代碼行或代碼片段,右鍵選擇CodeGenie > Explain Code,開始解讀當(dāng)前代碼內(nèi)容。 說明 ?最多支持
    發(fā)表于 07-17 17:02

    HarmonyOS AI輔助編程工具(CodeGenie)代碼測試

    放置于方法名稱上或框選完整的待測試方法代碼塊,右鍵選擇CodeGenie > Generate UT,開始生成單元測試用例。 說明 最多支持解讀20000字符以內(nèi)的代碼片段。Ar
    發(fā)表于 07-14 17:33

    【經(jīng)驗(yàn)分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺調(diào)試”到代碼解析

    FPGA開發(fā),思路先行!玩FPGA板子,讀代碼是基本功!尤其對從C語言轉(zhuǎn)戰(zhàn)FPGA的“寶貝們”來說,適應(yīng)流水線(pipeline)編程可能需要點(diǎn)時間。上篇點(diǎn)燈代碼解讀了基礎(chǔ),而如果能親手寫出串口通訊
    的頭像 發(fā)表于 06-05 08:05 ?889次閱讀
    【經(jīng)驗(yàn)分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺調(diào)試”到<b class='flag-5'>代碼</b>解析

    OLED代碼分享

    OLED代碼
    發(fā)表于 04-29 17:04 ?1次下載

    Java開發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多Java開發(fā)者在用?

    Perforce JRebel是一款Java開發(fā)效率工具,旨在幫助java開發(fā)人員更快地編寫更好的應(yīng)用程序。JRebel可即時重新加載對代碼的修改,無需重啟或重新部署應(yīng)用程序,就能讓開發(fā)者即時看到
    的頭像 發(fā)表于 04-27 13:44 ?659次閱讀
    <b class='flag-5'>Java</b>開發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多<b class='flag-5'>Java</b>開發(fā)者在用?

    18個常用的強(qiáng)化學(xué)習(xí)算法整理:從基礎(chǔ)方法到高級模型的理論技術(shù)與代碼實(shí)現(xiàn)

    本來轉(zhuǎn)自:DeepHubIMBA本文系統(tǒng)講解從基本強(qiáng)化學(xué)習(xí)方法到高級技術(shù)(如PPO、A3C、PlaNet等)的實(shí)現(xiàn)原理與編碼過程,旨在通過理論結(jié)合代碼的方式,構(gòu)建對強(qiáng)化學(xué)習(xí)算法的全面理解。為確保內(nèi)容
    的頭像 發(fā)表于 04-23 13:22 ?1320次閱讀
    18個常用的強(qiáng)化學(xué)習(xí)<b class='flag-5'>算法</b>整理:從基礎(chǔ)方法到高級模型的理論技術(shù)與<b class='flag-5'>代碼</b>實(shí)現(xiàn)

    沐渥科技:氮?dú)夤窆收?b class='flag-5'>代碼解讀及處理建議

    氮?dú)夤竦墓收?b class='flag-5'>代碼因品牌和型號不同而有所差異,但通常涵蓋一些常見問題。以下是沐渥科技對故障代碼解讀及處理建議:一、代碼解讀和原因分析1、E1
    的頭像 發(fā)表于 03-20 13:18 ?980次閱讀
    沐渥科技:氮?dú)夤窆收?b class='flag-5'>代碼</b><b class='flag-5'>解讀</b>及處理建議

    提取LSM6DSV16X內(nèi)置低功耗融合算法輸出的四元數(shù)后,轉(zhuǎn)換成歐拉角后遇到一個問題求解

    各位大佬好,在提取LSM6DSV16X內(nèi)置低功耗融合算法輸出的四元數(shù)后,轉(zhuǎn)換成歐拉角后遇到一個問題,當(dāng)Y軸與重力方向平行時,輸出的角度與慣性測量單元繞自身Y軸轉(zhuǎn)過的角度對應(yīng)不上,且抖動增加,請問有什么解決方法嗎?
    發(fā)表于 03-14 06:55

    村田電容標(biāo)簽材質(zhì)代碼如何看?

    村田電容的標(biāo)簽上通常包含一系列代碼,用以表示電容的具體參數(shù)和特性。以下是如何解讀村田電容標(biāo)簽上的材質(zhì)代碼的步驟: ?一、識別基本型號 村田電容的型號通常以字母開頭,如GRM、GR3、GRJ等,這些
    的頭像 發(fā)表于 01-13 14:14 ?1439次閱讀