網(wǎng)站首頁 編程語言 正文
一、車間調(diào)度簡介
1 車間調(diào)度定義
車間調(diào)度是指根據(jù)產(chǎn)品制造的合理需求分配加工車間順序,從而達(dá)到合理利用產(chǎn)品制造資源、提高企業(yè)經(jīng)濟(jì)效益的目的。車間調(diào)度問題從數(shù)學(xué)上可以描述為有n個(gè)待加工的零件要在m臺機(jī)器上加工。問題需要滿足的條件包括每個(gè)零件的各道工序使用每臺機(jī)器不多于1次,每個(gè)零件都按照一定的順序進(jìn)行加工。
2 傳統(tǒng)作業(yè)車間調(diào)度
傳統(tǒng)作業(yè)車間帶調(diào)度實(shí)例
有若干工件,每個(gè)工件有若干工序,有多個(gè)加工機(jī)器,但是每道工序只能在一臺機(jī)器上加工。對應(yīng)到上面表格中的實(shí)例就是,兩個(gè)工件,工件J1有三道工序,工序Q11只能在M3上加工,加工時(shí)間是5小時(shí)。
約束是對于一個(gè)工件來說,工序的相對順序不能變。O11->O12->O13。每時(shí)刻,每個(gè)工件只能在一臺機(jī)器上加工;每個(gè)機(jī)器上只能有一個(gè)工件。
調(diào)度的任務(wù)則是安排出工序的加工順序,加工順序確定了,因?yàn)槊康拦ば蛑挥幸慌_機(jī)器可用,加工的機(jī)器也就確定了。
調(diào)度的目的是總的完工時(shí)間最短(也可以是其他目標(biāo))。舉個(gè)例子,比如確定了O21->O22->O11->O23->O12->O13的加工順序之后,我們就可以根據(jù)加工機(jī)器的約束,計(jì)算出總的加工時(shí)間。
M2加工O21消耗6小時(shí),工件J2當(dāng)前加工時(shí)間6小時(shí)。
M1加工O22消耗9小時(shí),工件J2當(dāng)前加工時(shí)間6+9=15小時(shí)。
M3加工O11消耗5小時(shí),工件J1當(dāng)前加工時(shí)間5小時(shí)。
M4加工O23消耗7小時(shí),工件J2加工時(shí)間15+7=22小時(shí)。
M1加工O12消耗11小時(shí),但是要等M1加工完O22之后才開始加工O12,所以工件J1的當(dāng)前加工時(shí)間為max(5,9)+11=20小時(shí)。
M5加工O13消耗8小時(shí),工件J2加工時(shí)間20+8=28小時(shí)。
總的完工時(shí)間就是max(22,28)=28小時(shí)。
3 柔性作業(yè)車間調(diào)度
柔性作業(yè)車間帶調(diào)度實(shí)例(參考自高亮老師論文
《改進(jìn)遺傳算法求解柔性作業(yè)車間調(diào)度問題》——機(jī)械工程學(xué)報(bào))
相比于傳統(tǒng)作業(yè)車間調(diào)度,柔性作業(yè)車間調(diào)度放寬了對加工機(jī)器的約束,更符合現(xiàn)實(shí)生產(chǎn)情況,每個(gè)工序可選加工機(jī)器變成了多個(gè),可以由多個(gè)加工機(jī)器中的一個(gè)加工。比如上表中的實(shí)例,J1的O12工序可以選擇M2和M4加工,加工時(shí)間分別是8小時(shí)和4小時(shí),但是并不一定選擇M4加工,最后得出來的總的完工時(shí)間就更短,所以,需要調(diào)度算法求解優(yōu)化。
相比于傳統(tǒng)作業(yè)車間,柔性車間作業(yè)調(diào)度的調(diào)度任務(wù)不僅要確定工序的加工順序,而且需要確定每道工序的機(jī)器分配。比如,確定了O21->O22->O11->O23->O12->O13的加工順序,我們并不能相應(yīng)工序的加工機(jī)器,所以還應(yīng)該確定對應(yīng)的[M1、M3、M5]->[M1、M2、M3]->[M1、M2、M3、M4、M5]->[M2、M3、M4、M5]->[M2、M4]->[M1、M3、M4、M5]的機(jī)器組合。調(diào)度的目的還是總的完工時(shí)間最短(也可以是其他目標(biāo),比如機(jī)器最大負(fù)荷最短、總的機(jī)器負(fù)荷最短)
二、模擬退火算法簡介
5 模擬退火算法的參數(shù)
模擬退火是一種優(yōu)化算法,它本身是不能獨(dú)立存在的,需要有一個(gè)應(yīng)用場合,其中溫度就是模擬退火需要優(yōu)化的參數(shù),如果它應(yīng)用到了聚類分析中,那么就是說聚類分析中有某個(gè)或者某幾個(gè)參數(shù)需要優(yōu)化,而這個(gè)參數(shù),或者參數(shù)集就是溫度所代表的。它可以是某項(xiàng)指標(biāo),某項(xiàng)關(guān)聯(lián)度,某個(gè)距離等等。
三、部分源代碼
clc; clear; close all; %% Problem Definition model=CreateModel(); % Create Model of the Problem CostFunction=@(q) MyCost(q,model); % Cost Function nVar=model.nVar; % Number of Decision Variables VarSize=[1 nVar]; % Size of Decision Variables Matrix %% SA Parameters MaxIt=100; % Maximum Number of Iterations MaxIt2=25; % Maximum Number of Inner Iterations T0=10; % Initial Temperature alpha=0.97; % Temperature Damping Rate %% Initialization % Create Initial Solution x.Position=CreateRandomSolution(model); [x.Cost, x.Sol]=CostFunction(x.Position); % Update Best Solution Ever Found BestSol=x; % Array to Hold Best Cost Values BestCost=zeros(MaxIt,1); % Set Initial Temperature T=T0; %% SA Main Loop for it=1:MaxIt for it2=1:MaxIt2 % Create Neighbor xnew.Position=CreateNeighbor(x.Position); [xnew.Cost, xnew.Sol]=CostFunction(xnew.Position); if xnew.Cost<=x.Cost % xnew is better, so it is accepted x=xnew; else % xnew is not better, so it is accepted conditionally delta=xnew.Cost-x.Cost; p=exp(-delta/T); if rand<=p x=xnew; end end % Update Best Solution if x.Cost<=BestSol.Cost BestSol=x; end end % Store Best Cost BestCost(it)=BestSol.Cost; % Display Iteration Information disp(['Iteration ' num2str(it) ': Best Cost = ' num2str(BestCost(it))]); % Reduce Temperature T=alpha*T; % Plot Solution figure(1); PlotSolution(BestSol.Sol,model); pause(0.01); end %% Results figure; plot(BestCost,'LineWidth',2); xlabel('Iteration'); ylabel('Best Cost'); grid on;
四、運(yùn)行結(jié)果
五、matlab版本及參考文獻(xiàn)
1 matlab版本
2014a
2 參考文獻(xiàn)
[1] 包子陽,余繼周,楊杉.智能優(yōu)化算法及其MATLAB實(shí)例(第2版)[M].電子工業(yè)出版社,2016.
[2]張巖,吳水根.MATLAB優(yōu)化算法源代碼[M].清華大學(xué)出版社,2017.
原文鏈接:https://qq912100926.blog.csdn.net/article/details/120960632
相關(guān)推薦
- 2022-07-15 C++面向?qū)ο笾惡蛯ο竽切┠悴恢赖募?xì)節(jié)原理詳解_C 語言
- 2023-01-09 基于Go語言實(shí)現(xiàn)插入排序算法及優(yōu)化_Golang
- 2023-04-18 MongoDB超大塊數(shù)據(jù)問題解決_MongoDB
- 2022-06-04 Jenkins安裝的時(shí)區(qū)問題分析解決_安裝教程
- 2022-09-18 AJAX實(shí)現(xiàn)文件上傳功能報(bào)錯(cuò)Current?request?is?not?a?multipart?r
- 2023-01-05 基于Go語言實(shí)現(xiàn)冒泡排序算法_Golang
- 2023-01-03 Qt學(xué)習(xí)之容器類的使用教程詳解_C 語言
- 2022-06-11 利用Nginx實(shí)現(xiàn)URL重定向的簡單方法_nginx
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支