(LBFSP)中间存储有限流水车间的最大完工时间Cmax的2种计算方法(含c++源代码)

本文主要是介绍(LBFSP)中间存储有限流水车间的最大完工时间Cmax的2种计算方法(含c++源代码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    查阅文献时,发现中间存储有限的流水车间在计算最大完工时间C_{max}时,常出现两种计算方式,一种用开始时间S_{i, j}计算,另一种用完工时间C_{i, j}计算:

(1) 用开始时间S_{i, j}计算

(p_{i, j}代表工件i在机器j上的加工时间,B_{j}代表机器jj-1之间的缓冲区容量)

(C_{max} = S_{\pi (n), m} + p_{\pi (n), m})

 (2) 用完工时间C_{i, j}计算

(P_{i, j}代表工件i在机器j上的加工时间,B_{j}代表机器jj+1之间的缓冲区容量)

    两种方式计算出来的C_{max}结果是一样的,但要注意的是,第1种方式求出来的矩阵S_{i, j}指的是各工序的最早可以开始加工的时间点, 而第2种方式求出来的矩阵C_{i, j}指的是各工序的最晚可以结束加工的时间点,因此两者画出来的甘特图略有差别,如下图所示: 

    从图中可以看出,按第1种方式求解画出的甘特图,相当于对所有的存在空闲的加工时间块进行了左移操作,而第2种方式则是进行了右移操作;对于不存在空闲的加工时间块,两种求解方式的甘特图是一致的,这也是它们求解出来的C_{max}一致的原因。

    同样的原理可以应用到一般的置换流水车间调度问题(PFSP)C_{max}的求解当中。

附:

(1) 用开始时间S_{i, j}计算LBFSP的源代码

/* 中间存储有限Cmax计算(使用开始时间计算) */
// solution -- 可行解(排列),如 π = {1,2,...,n}
// T -- 加工时间矩阵,T[π(i) - 1][j - 1]即P[π(i)][j]
// buffer -- buffer[i] (0 ≤ i ≤ n-1) 为机器i+1与机器i+2间的缓冲区容量
vector<vector<double>> calculate_makespan_start_time(const vector<int>& solution, const vector<vector<double>>& T, const vector<int>& buffer) {int n = solution.size(), m = T[0].size();vector<vector<double>> S(n, vector<double>(m, 0));  //调度(完工时间)矩阵,size = (n, m),存放各机器上的调度结果// 1. S(π1,1) = 0//S[0][0] = 0;// 2. S(π1,j) = S(π1,j - 1) + P(π1,j - 1)  j = 2, 3, ... , mfor (int j = 1; j < m; j++){S[0][j] = S[0][j - 1] + T[solution[0] - 1][j - 1];}for (int i = 1; i < n; i++) {// j = 0 时// 3. S(πi,1) = S(π(i - 1),1) + P(π(i - 1),1)  i ≤ B1 + 1if (i < buffer[0] + 1) S[i][0] = S[i - 1][0] + T[solution[i - 1] - 1][0];// 4. S(πi,1) = max( S(π(i - 1),1) + P(π(i - 1),1), S[i - B1 - 1][2] )  i > B1 + 1else S[i][0] = max(S[i - 1][0] + T[solution[i - 1] - 1][0], S[i - buffer[0] - 1][1]);for (int j = 1; j < m - 1; j++) {// 5. S(πi,j) = max( S(π(i - 1),j) + P(π(i - 1),j), S(π(i),j - 1) + P(π(i),j - 1) )  i ≤ Bj + 1, 2 ≤ j ≤ m - 1if (i < buffer[j] + 1) S[i][j] = max(S[i - 1][j] + T[solution[i - 1] - 1][j], S[i][j - 1] + T[solution[i] - 1][j - 1]);/* 6. S(πi,j) = max( S(π(i - 1),j) + P(π(i - 1),j), S(π(i),j - 1) + P(π(i),j - 1), S(π(i - Bj - 1), j + 1) )i > Bj + 1, 2 ≤ j ≤ m - 1  */else S[i][j] = max(max(S[i - 1][j] + T[solution[i - 1] - 1][j], S[i][j - 1] + T[solution[i] - 1][j - 1]), S[i - buffer[j] - 1][j + 1]);}// j = m - 1 时// 7. S(πi,m) = max( S(π(i - 1),m) + P(π(i - 1),m), S(π(i),m - 1) + P(π(i),m - 1) )S[i][m - 1] = max(S[i - 1][m - 1] + T[solution[i - 1] - 1][m - 1], S[i][m - 2] + T[solution[i] - 1][m - 2]);}// 如果只求Cmax,返回 S[n - 1][m - 1] + T[solution[i] - 1][j] 即可// 这里求的是开始时间矩阵S(πi,j),用于画调度结果的甘特图return S;
}

(2) 用完工时间C_{i, j}计算LBFSP的源代码

/* 中间存储有限Cmax计算(使用完工时间计算) */
// solution -- 可行解(排列),如 π = {1,2,...,n}
// T -- 加工时间矩阵,T[π(i) - 1][j - 1]即P[π(i)][j]
// buffer -- buffer[i] (0 ≤ i ≤ n-1) 为机器i+1与机器i+2间的缓冲区容量
vector<vector<double>> calculate_makespan(const vector<int>& solution, const vector<vector<double>>& T, const vector<int>& buffer) {int n = solution.size(), m = T[0].size();vector<vector<double>> C(n, vector<double>(m, 0));  //调度(完工时间)矩阵,size = (n, m),存放各机器上的调度结果// 1. C(π1,1) = P(π1,1)C[0][0] = T[solution[0] - 1][0];// 2. C(π1,j) = C(π1,j - 1) + P(π1,j)  2 ≤ j ≤ mfor (int j = 1; j < m; j++){C[0][j] = C[0][j - 1] + T[solution[0] - 1][j];}for (int i = 1; i < n; i++) {// j = 0 时// 3. C(πi,1) = C(π(i - 1), 1) + P(πi, 1)  i ≤ B1 + 1if (i < buffer[0] + 1) C[i][0] = C[i - 1][0] + T[solution[i] - 1][0];// 4. C(πi,1) = max( C(π(i - 1), 1) + P(πi, 1), C(π(i - B1 - 1), 2) )  i > B1 + 1else C[i][0] = max(C[i - 1][0] + T[solution[i] - 1][0], C[i - buffer[0] - 1][1]);for (int j = 1; j < m - 1; j++) {// 5. C(πi,j) = max{C(π(i - 1), j), C(πi, j - 1)} + P(πi, j)  i ≤ Bj + 1, 2 ≤ j ≤ m - 1if (i < buffer[j] + 1) C[i][j] = max(C[i - 1][j], C[i][j - 1]) + T[solution[i] - 1][j];/* 6. C(πi,j) = max(max( C(π(i - 1), j), C(πi, j - 1) ) + P(πi, j), C(π(i - Bj - 1), j + 1) )i > Bj + 1, 2 ≤ j ≤ m - 1  */else C[i][j] = max(max(C[i - 1][j], C[i][j - 1]) + T[solution[i] - 1][j], C[i - buffer[j] - 1][j + 1]);}// j = m - 1 时// 7. C(πi,m) = max( C(π(i - 1), m), C(πi, m - 1) ) + P(πi, m)C[i][m - 1] = max(C[i - 1][m - 1], C[i][m - 2]) + T[solution[i] - 1][m - 1];}// 如果只求Cmax,返回 C[n - 1][m - 1] 即可// 这里求的是完工时间矩阵C(πi,j),用于画调度结果的甘特图return C;
}

参考文献:

[1]    WANG L, ZHANG L, ZHENG D. An effective hybrid genetic algorithm for flow shop scheduling with limited buffers[J]. Computers & Operations Research, 2006,33(10): 2960-2971.

[2]    王鹏飞. 群智能优化算法及在流水车间调度问题中的应用研究[D]. 吉林大学, 2019.

这篇关于(LBFSP)中间存储有限流水车间的最大完工时间Cmax的2种计算方法(含c++源代码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323752

相关文章

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

如何提高Redis服务器的最大打开文件数限制

《如何提高Redis服务器的最大打开文件数限制》文章讨论了如何提高Redis服务器的最大打开文件数限制,以支持高并发服务,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录如何提高Redis服务器的最大打开文件数限制问题诊断解决步骤1. 修改系统级别的限制2. 为Redis进程特别设置限制

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit