一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

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

往期回顧:

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

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

代碼下載請(qǐng)關(guān)注公眾號(hào),后臺(tái)回復(fù)【FJSPHA】即可,不包括【】

代碼框架

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

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

Main

算例輸入:

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

Data

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

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

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

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

GA

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

選擇哪種Tabu:

讀者在閱讀的時(shí)候請(qǐng)自己注意。

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

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

NeighbourSearch

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

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

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

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

NeighbourSearch2

這個(gè)包為第三個(gè)基于甘特圖的tabu。

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

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

總結(jié)

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

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

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

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

    關(guān)注

    23

    文章

    4705

    瀏覽量

    95101
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2988

    瀏覽量

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

    關(guān)注

    30

    文章

    4894

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

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

    OLED代碼分享

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

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

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

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

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

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

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

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

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

    代碼與傳統(tǒng)開(kāi)發(fā)的區(qū)別 低代碼與無(wú)代碼開(kāi)發(fā)的區(qū)別

    在軟件開(kāi)發(fā)領(lǐng)域,傳統(tǒng)開(kāi)發(fā)、低代碼開(kāi)發(fā)以及無(wú)代碼開(kāi)發(fā)是三種不同的開(kāi)發(fā)方式,每種方式都有其獨(dú)特的優(yōu)勢(shì)和適用場(chǎng)景。 一、低代碼開(kāi)發(fā)與傳統(tǒng)開(kāi)發(fā)的區(qū)別 低代碼開(kāi)發(fā)是一種新興的應(yīng)用程序開(kāi)發(fā)方法,旨
    的頭像 發(fā)表于 01-31 10:48 ?581次閱讀

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

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

    Java代碼之美,從遵循樣式規(guī)范開(kāi)始

    作者:京東零售 劉仲偉 在軟件開(kāi)發(fā)的世界里,代碼不僅是程序的基石,更是程序員交流的通用語(yǔ)言。而Java,作為一門(mén)廣泛應(yīng)用于企業(yè)級(jí)應(yīng)用的編程語(yǔ)言,其代碼的可讀性和一致性對(duì)于項(xiàng)目的長(zhǎng)期維護(hù)和團(tuán)隊(duì)協(xié)作
    的頭像 發(fā)表于 11-27 11:42 ?543次閱讀
    <b class='flag-5'>Java</b><b class='flag-5'>代碼</b>之美,從遵循樣式規(guī)范開(kāi)始

    對(duì)比Python與Java編程語(yǔ)言

    Python與Java都是目前非常流行的編程語(yǔ)言,它們各有其獨(dú)特的優(yōu)勢(shì)和適用場(chǎng)景。以下是對(duì)這兩種編程語(yǔ)言的對(duì)比: 一、語(yǔ)法和易用性 Python 語(yǔ)法簡(jiǎn)潔,代碼更易讀,非常適合初學(xué)者。 動(dòng)態(tài)類(lèi)型系統(tǒng)
    的頭像 發(fā)表于 11-15 09:31 ?984次閱讀

    代碼整潔之道-大師眼中的整潔代碼是什么樣

    幾個(gè)月前寫(xiě)了一篇文章“如何寫(xiě)出難以維護(hù)的代碼”,從中能大概了解到不好維護(hù)的代碼是什么樣,有哪些壞味道,那肯定有人會(huì)反問(wèn),難以維護(hù)的代碼見(jiàn)的太多了,也知道長(zhǎng)什么樣,但是對(duì)于好維護(hù)的代碼
    的頭像 發(fā)表于 09-09 16:30 ?623次閱讀
    <b class='flag-5'>代碼</b>整潔之道-大師眼中的整潔<b class='flag-5'>代碼</b>是什么樣

    java反編譯能拿到源碼嗎

    Java反編譯是一種將編譯后的Java字節(jié)碼(.class文件)轉(zhuǎn)換回Java代碼的過(guò)程。雖然反編譯可以幫助理解代碼的邏輯和結(jié)構(gòu),但它并不
    的頭像 發(fā)表于 09-02 11:03 ?1735次閱讀

    java反編譯的代碼可以修改么

    Java反編譯是一種將編譯后的Java字節(jié)碼(.class文件)轉(zhuǎn)換回源代碼的過(guò)程。反編譯后的代碼可以進(jìn)行修改,但是需要注意,反編譯代碼的質(zhì)
    的頭像 發(fā)表于 09-02 11:00 ?1218次閱讀

    ida反編譯出來(lái)代碼能直接用嗎

    IDA反編譯出來(lái)的代碼通常 不能直接使用 ,這主要基于以下幾個(gè)方面的原因: 一、代碼的不完整性 IDA反編譯生成的代碼可能缺少原始源代碼中的
    的頭像 發(fā)表于 09-02 10:55 ?1381次閱讀

    國(guó)內(nèi)低代碼平臺(tái)推薦--萬(wàn)界星空科技低代碼平臺(tái)

    代碼平臺(tái)是一種應(yīng)用程序,它為編程提供圖形用戶(hù)界面,從而以極快的速度開(kāi)發(fā)代碼,減少傳統(tǒng)編程工作。 這些工具有助于快速開(kāi)發(fā)代碼,最大限度地減少手工編碼的工作量。這些平臺(tái)不僅有助于編碼,還有助于快速設(shè)置和部署。
    的頭像 發(fā)表于 07-18 15:39 ?553次閱讀
    國(guó)內(nèi)低<b class='flag-5'>代碼</b>平臺(tái)推薦--萬(wàn)界星空科技低<b class='flag-5'>代碼</b>平臺(tái)