Abstract

The steelmaking and continuous-casting (SCC) process in integrated iron and steel enterprises can be described as two stages: the upstream stage and downstream stage. Raw materials are transformed into molten steel in the upstream stage, while the downstream stage is responsible for transforming molten steel which is released at regular intervals and has a limited time for being turned into slabs. This article focuses on the task assignment problem in the downstream stage within the given information resulting from the upstream stage. This problem is formulated as a nonlinear mixed-integer programming model aimed at minimizing total tardiness within the resource constraints and time windows constraints for the tasks. An improved solution algorithm based on particle swam optimization is developed to efficiently solve the proposed model. Finally, computational experiments are implemented to evaluate the performance of the solution algorithm in terms of solution quality and computational time.

1. Introduction

The iron and steel industry, as one of the most important economy sectors, is a large component of energy consumption and pollution emission. The energy consumption of iron and steel industry accounts for 10%–15% of the total energy consumption in the world, and the emission accounts for about 7% of the total anthropogenic emission [1]. Therefore, the iron and steel industry is an important study object because of the goal of emission reduction and energy saving. There are many scheduling tasks to be completed in the iron and steel industry. Because steelmaking and continuous-casting (SCC) process contributes the largest portion of the material loss in production and the SCC has important effects on the shape and quality of integrated iron and steel enterprises’ final products (slabs), scheduling of SCC process is one of the most important tasks among different scheduling tasks [2]. Hence, studying the effective scheduling methods solving SCC problems has timely significance for improving the iron and steel industry productivity [3]. Figure 1 illustrates the material flow of an integrated iron and steel enterprise, which is a typical process industry, where final products are produced by a sequence of processing operations (steelmaking, refining, and continuous-casting in sequence) to transform raw materials into solid slabs. The process can be described as two stages: an upstream stage and downstream stage. In the upstream stage, raw material is first turned into molten steel by a LDVC in order to initially reduce impurity content, which is called the steelmaking stage. And then, impurities are further eliminated by some refining techniques, such as RH and LF, which is called the refining stage. After the process of the upstream stage, the molten steel comes to the downstream stage, also called the continuous-casting stage, in which casting machines cast the molten steel into solid slabs uninterruptedly; the production process ends.

In the upstream stage, molten steel is produced in boilers. In order to save energy, upstream machines produce molten steel at regular intervals, which means that when boilers complete the production of a batch of molten steel, boilers continue to produce again rather than be cooled because it would require a lot of energy to restart boilers. Therefore, when upstream machines finish the production of molten steel, molten steel (upstream resource) is released immediately to the casting stage at regular intervals to service the casting machines processing of tasks.

The temperature of molten steel supplied has very important effects on the quality of continuous-casting slabs. In order to prevent nozzle clogging caused by bad fluidity of low temperature molten steel, the continuous-casting system requires strict control of the temperature of molten steel. Even worse, low temperature molten steel can lead to freezing of nozzles, which would subsequently interrupt the casting. Therefore, once molten steel is released, it must be used within the resource available time, or the remaining resource will be cold and idle.

In this article, we focus on the casting plans of the continuous-casting process within given information resulting from the upstream stages of steelmaking and refining. The casting plan is to make a decision on how to distribute all tasks to casting machines while satisfying all constraints.

Our work is motivated by a bottleneck problem arising in the steelmaking and the continuous-casting stage of steel production. Due to lower production capacity, the SCC production is always regarded as a bottleneck and restricts enterprises’ development. In steel production, molten steel is supplied to parallel casting machines in the continuous-casting stage, where every task needs its own amount of resources, and the total resource demanded does not exceed the resource supplied at any point in time. Therefore, during the whole processing time, resources are released at regular intervals, where the resource quantity at each resource release time is fixed.

The contributions of this article are as follows:(1)This study takes account of some realistic factors such as the resource available time for use, nonlinear supply resource, nonrenewable resource, and tardiness minimization. There are related studies that considered some of these factors, but few previous studies have covered all of these factors.(2)We formulate the task assignment problem as a nonlinear mixed-integer programming model and propose an efficient solution algorithm to solve the proposed model which combines the particle swarm optimization algorithm and artificial bee colony algorithm.

The remainder of this article is organized as follows. Section 2 provides an overview of related work. Section 3 describes the problem in detail and presents an integer programming model for the problem. In Section 4 we present an iterated local search approach for solving the problem. Section 5 presents computational experiments. Final remarks are given in Section 6.

2. Literature Review

Because the scheduling of SCC process plays an important role in the iron and steel industry, there exist numerous related studies on the SCC process. We review two streams of related literature on SCC scheduling problems. Readers interested in overviews can refer to Tang et al. [4], Tang et al. [5], Tang et al. [6], Pan [3], and Mori and Mahalec [2] to obtain a comprehensive overview on the scheduling of SCC process.

The first research stream is related to the task assignment problem (TAP). The TAP problem is a challenging combinatorial optimization problem which aims to assign different tasks to some distributed processors in a system in order to increase the effectiveness of the system and minimize a certain cost. The beginning of the development of practical solution methods solving the classic TAP is proposed by Kuhn [7]. Numerous solving methods have been presented by scholars for the generalized TAP which aims to find the minimum assignment cost. Studying the problem of assigning drivers to cover tasks with service time windows and uncertain task durations, Cheung et al. [8] propose an adaptive labelling solution procedure which incorporates various practical constraints and work rules. Yan and Tang [9] develop a heuristic approach which is embedded in a framework aimed for stochastic airport gate assignment under uncertain flight delays. Zhen et al. [10] provide a stochastic programming model and a robust optimization model to deal with task workload requirements. Zhen et al. [11] study a strategic-level decision problem on assigning production stages to minimize the fixed cost and the expected value costs under stochastic demands of customers. Task assignment in this article also belongs to the parallel machine scheduling problem which is one of the classical problems in production systems.

The second topic of related works is concerned with the parallel machine scheduling (PMS). The PMS problem is a relatively simple multimachine scheduling problem in actual production and is applied in a very wide range of production, so it is studied by many researchers. According to the statistical data through the web of science (SCIT + CPCI), there are about 160,000 articles related on the study of the parallel machines scheduling problem, and the number increases every year. Although there have been many researchers developing the parallel machine theory and practical applications, PMS still attracts more and more researchers’ interests. There are three main research directions related to the parallel machine problem now: the optimization of the parallel machine scheduling problem whose goal is to minimize total tardiness or makespan, the parallel machine scheduling problem considering a product family, machine processing equipment, etc., and the parallel machine scheduling problem with resource constraints. This article studies the parallel machine scheduling problem with resource constraints which aims to minimize total tardiness.

Many researchers have studied PMS problems and applied them to a variety of manufacturing cases due to their theoretical and practical significance, for example, in the semiconductor manufacturing industry [12] and the electronic industry [13]. However, machines are the only resource considered in most PMS studies. In most real-life manufacturing systems, additional resources, such as automated guided vehicles, machine operators, tools, pallets, and industrial robots, are required for some jobs [14].

The first systematic approach to PMS problems was proposed in the mid-1950s, which was further extended from single machine scheduling problems. Since then, thousands of articles have investigated this problem. Cheng and Sin [15] provide a comprehensive analysis of PMS. In the 1990s, many articles extended PMS problems. Allahverdi et al. [16] provide a comprehensive review of such problems, including dynamic and stochastic problem settings for single and parallel machines, flow shops, and job shops. Mokotoff [17] develops a new local search heuristic algorithm for parallel machine problems which minimizes the total weighted completion time. Pfund et al. [18] review and summarize the literature on nontraditional parallel machine scheduling problems.

Comprehensive surveys for the tardiness minimization scheduling problem are provided by Dileepan [19] and Koulamsa [20]. Compared to Emmons et al. [21] who study tardiness in a single machine scheduling problem, Du and Leung [22] propose a better solution using different algorithms and describe the optimal solution of the problem. Lawler [23] proposes a decomposition algorithm that decomposes the problem into multiple noninterfering subproblems. Later, Shim and Kim [24] propose to use the branch-and-bound method to solve a single machine problem aimed at tardiness minimization. More recently, Lee and Kim [25] apply the branch-and-bound method to parallel machine scheduling and tardiness minimization. In addition, Mensendiek et al. (2015) develop a mathematical model for optimal sequences on parallel machines with fixed delivery dates and present heuristics to solve the problem.

Apart from this theoretical analysis, there are many researchers studying real problems related to industrial activities and considering the problems of resource constraints. Blazewicz et al. [26] point out that job processing not only needs a machine, but also needs automatic guided vehicles, machine operators, tools, pallets, abrasives, industrial robots, and other additional resources. Blazewicz et al. [27] discuss the single machine scheduling problem with a continual resource and also discuss the nonrenewable resources proposed by Shabtay and Kaspi [14]. Grigorive et al. (2005) consider the scheduling problem with raw material resource constraints, mainly with the following three constraints: each job has its own raw material, all jobs require a generic resource, and each job has many kinds of raw materials and has to choose one or some materials. The objective of different models in the above articles is to minimize the processing time, or minimize the maximum number of late jobs. Briskorn et al. [28] study the single machine scheduling problem aimed at minimizing the processing time or the maximum number of late jobs when the production process should stop if the resource demand cannot be met. Briskorn et al. [29] study the single machine scheduling problem with inventory constraints, and the goal is to minimize the total processing time. In order to solve the above problems, the branch-and-bound method and dynamic programming method are used to find the optimal solution. It was found that the heuristic algorithm outperforms a state-of-the-art commercial mixed integer programming solver even with 20 jobs. Györgyi et al. [30] study resource constraints in single machine scheduling, such as a nonrenewable raw material, where the goal is to minimize the total processing time. Wang et al. [31] study the PMS problem with two kinds of resource constraints (machines and molds), and the goal is to minimize the total processing time. It discusses preventive maintenance activities for the flexibility of resources.

In summary, many previous studies on SCC optimization problems disregarded the relationship between the PMS problem and the TSP problem. Although few studies have considered this relationship, they did not consider many realistic factors, such as the nonlinear supplied and required resource, and resource available time. Therefore, this article focuses on the scheduling problem with nonlinear required and consumed resource constraints aimed at minimization of total tardiness under parallel machines, and the production resource is a nonrenewable resource and has limited time for use.

This study conducts a comprehensive investigation of the SCC problem by considering several realistic factors, such as nonlinear supplied and required resource, and resource available time; these factors are related to the practical operation and production management in the iron and steel industry. In addition, an improved algorithm is also presented. In comparison to the existing literature, the model proposed in this study can provide more reasonable SCC scheduling plans in real-world application.

3. Problem Statement and Mathematical Model

3.1. Problem Description

The production scheduling problem studied in this article can be described as follows. In iron and steel enterprises, the main production and scheduling problems are the furnace plans and casting plans. The furnace plan determines how many batches of molten steel should be produced in the upstream stage. The casting plan means the pouring order of all tasks which are distributed to the same casting machine. This article focuses on how to distribute casting machines in the casting stage, which implies that, in order to achieve multifurnace casting and reduce energy consumption, the continuous-casting process in an iron and steel enterprise should have each casting machine produce as many casting sets as possible. Therefore, the main problem to be solved in this article is to determine each task’s casting machine and then determine the pouring order of each casting machine. Specifically, there are many tasks waiting to be processed by parallel casting machines. Tasks must be completed one by one because each machine can only process one task at a time. Additionally, each task requires a certain amount of common resource that is provided by the upstream stage.

The key of continuous-casting production schedules is the upstream resource constraints. An example of a production schedules is shown in Figure 2 which illustrates the implications of resource constraints over time. There are 6 tasks which should be processed by any one of two available machines in the continuous-casting process. At each resource’s release time, a fixed amount of resource from the upstream stage will be released to service casting machines processing tasks within the resource available time. (1, ) in Figure 2 represents that task 1 is processed on machine a, and (2, ) represents that task 2 is processed on machine . At time 0, upstream resources are released first. At time , task 1 is finished on machine , so task 3 is processed on machine , and the total resource requirement increases. At time where task 3 is finished on machine , because the remaining resource is not enough to process another task, machine will stop processing till the next resource release time. At time , task 2 is finished on machine , but the remaining resource is not enough to process any more tasks, so machine has to wait till the next resource release time, too. is the fixed quantity of released resource at each resource release time. The cumulative amount of resources required cannot exceed the cumulative amount of resource supplied at any time, and both of them are nonlinear over time. We assume that each task consumes resources at the beginning of the process.

As can be seen from Figure 3, since the cumulative resource demanded cannot exceed the cumulative resource supplied at any time, tasks may have a waiting time when they arrive and cannot be processed, and the remaining resource at the last resource release time is idle. Besides, since the upstream resource has a limited time for use, it will also be idle because of low temperature. Let denote the set of tasks to be processed by the parallel machines. Each task is characterized by its due date , processing time , and the quantity of resource required by the machine to process the task. The resource is supplied in the fixed quantity at each resource release time . The resource supplied can only be used within the resource available time , because, after time, the resource will be cold and will not meet the temperature requirements. The goal of this article is to find the optimal solution for task assignments which considers the resource constraints (resource release time and resource available time for use) and aims at minimization of total tardiness.

Before formulating the mathematical model for this problem, the assumptions of this study are clarified as follows:(1)Every machine can only process one task at any time and can be used if it is available during the whole production.(2)Resource is released and consumed at the beginning of each resource released cycle.(3)The preparation time is not necessary for all tasks.(4)The completion times of tasks are unknown. The given information is only each task’s processing time, amount of resource required, and due date.(5)All tasks are independent and must be processed once without interruption.

3.2. Mathematical Model

Notation: virtual starting artifacts: the due date of task : the fixed amount of the resource supplied each time: the index of a task, , where is the total number of tasks: the index of a resource released time; there are times of resource release: the index of a machine, , where is the total number of machines: a large positive number: virtual ending artifacts, where is the number of tasks: the processing time of task : the resource required by task : the resource release cycle: the resource availability time for use

Decision Variables: the completion time of task : the tardiness of task : a binary variable, which equals 1 if task is scheduled to be processed immediately after task on machine ; it is 0, otherwise:a binary variable, which equals 1 if task is scheduled to be processed at the th resource release time on machine ; it is 0, otherwise

The problem can be formulated as the following mathematical model:subject to

Objective (1) is to minimize the total tardiness of all tasks. Constraints (2) and (3) ensure that tasks are finished one by one. Constraints (4) state that if task is processed after task immediately on machine , the beginning processing time of task is later than the completion time of task . Constraints (5) restrict the tardiness of each task . Constraints (6) are nonlinear supply resource constraints and ensure that the total resource supplied at any time is not less than the resource required in each resource release time. Constraints (7) ensure that each task is fulfilled exactly once. Constraints (8) ensure that if task is processed after task immediately on machine , the index of task’s resource release time is not less than that of task . It is noted that Constraints (8) are nonlinear constraints and will be transformed to the linear form. Constraints (9) are the flow conservation constraint. Constraints (10) and (11) ensure that each machine begins to work with virtual task 0 and ends with virtual task . Constraints (12) and (13) ensure that if task is processed at the th resource released time, the starting processing time of task is later than this resource release time, and it should be processed within the resource available time for use . Constraints (14) to (16) restrict the domain of the decision variables.

3.3. Linearization of Constraints (8)

Constraints (8) contain a nonlinear part , which is the product of two binary variables. We define a new binary variable to replace the nonlinear part.

Newly Defined Variables. binary variable is equal to one if and only if task is processed after task immediately on machine , and the index of task ’s resource release time is .

Constraints (8) become

In addition, some more constraints need to be defined so that the newly defined variable can replace the function of .

Constraints (17) are linear and now the following [M2] is a MIP model, which can be solved by off-the-shelf solvers such as CPLEX.

[M2] An MIP model: Objective (1), subject to Constraints (2)–(7) and (9)–(21).

4. Solution Approach

4.1. PSO Algorithm

For some small-scale instances, the proposed model can be solved by using CPLEX solver directly. However, large-scale instances cannot be solved by CPLEX solver within a reasonable time, or can lead to an OutOfMemory error.

Particle swarm optimization (PSO) is a population-based optimization algorithm, where each particle has a position and velocity representing a solution. The position reflects the quality of the solution, and the velocity determines where the particle will move in the next iteration. The ordinary updating formulae for velocities and positions are as follows:where and represent the current and previous positions of particle in dimension , respectively; and represent the current and previous velocity of particle in dimension , respectively; the weights and are acceleration constants which are generally viewed as the cognitive acceleration coefficient and social acceleration coefficient, respectively; and are random numbers in ; is the best position of particle in dimension up to iteration ; and is the best position of the whole swarm in dimension up to iteration .

The pseudocode of our PSO algorithm is shown in Algorithm 1. The approach starts by generating an initial solution, which can be any sequence of tasks. It then initializes an iteration counter and repeats the same setup until the iteration counter reaches a given limit. In each iteration, the approach selects the next neighborhood operator from a randomly generated sequence of operators. For each operator, all possible moves are examined. If an improved solution is found, this solution is accepted as the new incumbent solution. If no improvement can be obtained by any of the operators, a locally optimal solution is found. The search process is repeated in order to be able to escape from a local optimum. Before continuing with the next iteration, the incumbent solution is perturbed in order to obtain a new solution that potentially can be improved using the operators.

1
maxEpoch
while do
 decode the particle to generate genes, obtain the reduced MIP and solve it by using CPLEX
 compare and update each swarm’s best position and particle’s best position
 update the velocity and position accordingly
+ 1
end while

Apart from the main steps, this article also designs a new encoding and decoding method to improve solution quality. This encoding and decoding method is specific to and is illustrated as follows. As Figure 4 shows, we have 5 tasks, and the number of available machines is 3. We first generate 5 random numbers in as genes, then use the value of genes times the total number of machines, round down fractions, and obtain each task’s processing machine. Then, we calculate the due date for each task and determine its urgency degree based on its due date. The task with an earlier due date is prior. We compare the urgency degrees of all tasks distributed to the same machine, and tasks are discharged from the processing sequence according to their degree of urgency. For example, as in Figure 4, tasks 2, 3, and 4 are arranged to be processed on machine 2, task 1 is arranged to machine 0, and task 5 is arranged to machine 1. Then, as Table 1 shows, each machine’s processing order is arranged according to the degree of urgency. So, just as Table 2 shows, the processing order on machine 0 is task 1, the order on machine 1 is task 5, and the order on machine 2 is tasks 3, 2, and 4. Therefore, .

4.2. Algorithm Improvement

The neighborhood structure is a key component of the algorithmic framework, and neighborhood search has an effect on the performance of heuristic algorithm. Therefore, we design an improved neighborhood search method for the PSO algorithm in order to improve solving ability. According to the experimental analysis of the example, we find that when CPLEX solves this problem directly, the time that the Gap value (percent) drops from 100% to 10% is very fast. In most cases, almost 80% of the whole computation time is spent on dropping the Gap value from 10% to 0. Therefore, it may need to take a long time to find the neighborhood of the optimal solution. And if the local search of the PSO algorithm does not find an improved solution, we employ another local search method to find it again. We use the behavior of bees in nature to explain the core idea of our improved algorithm more easily. During the searching process, a food source represents a candidate solution and the best food source found by bees is the model’s optimal solution. The initial solution of swarm is a vector of D dimension, where D is the number of the parameters to be optimized. Each has variables () and these variables will all be optimized to make the problem’s objective minimal. So all the bees’ first solution is generated by formula (24). In later iterations, scouts move to other solutions according to formula (25). And greedy selection is applied between the old solution and the new solution to find a better solution. After that, onlooker bees go out to exploit better solutions in their surroundings. Roulette wheel selection is applied to create further generation of new solutions. New solutions are updated by formula (26). When the number of iterations reaches the limit, the current global optimal solution is taken as the solution, and solution fitness is defined as the ABC algorithm’s solution tardiness.where is the th potential solution in the swarm, and are bounds of in the th dimension, and is a random number in the interval .where is the current solution, is a randomly selected solution among the solutions, and is a random number in the interval ].where is the th iteration solutions, and are bounds of in the th dimension, and is a random number in the interval .

This local search method searches iteratively in a feasible neighborhood till an upper limit on time, and then it starts to search in another feasible neighborhood. So, too much time is spent doing local search, which leads to poor results. Therefore, this article conjectures that the improved local search method is more suitable for a local search to solve the proposed model. Considering the global search ability of the particle swarm algorithm, and the local search ability of the abovementioned method, this article proposes an improved algorithm, called PSOB, to improve the existing algorithm, accelerate the resolving speed, improve the resolving ability, and generate better solutions.

The pseudocode of the PSOB algorithm is shown in Algorithm 2. In order to find the optimal neighborhood near the optimal solution as soon as possible, the PSOB algorithm searches the solution globally quickly like the PSO algorithm. Then, it uses the abovementioned local search algorithm to do a local search. The PSOB algorithm’s solving process is as follows. When the first part of the solving process is finished, the second part’s initial global optimal position is set as the current GlobalMin and GlobalParas. Then, the abovementioned local search algorithm is iterated. After maxCycle times, the final result is the PSOB algorithm’s optimal solution.

initialsolution()
1, 20, 30,
while do
 repeat
  select neighborhood operator
  for all solutions ’ that can be generated by applying to do
   if tardiness(’) < tardiness() then
    
   end if
  end for
 until s is locally optimal for all operators
update()
+ 1
end while
BestSolution GlobalMin, Solution[] GlobalParas[]
initialsolution(): 1, 20, 30, 1, 20
maxEpoch
while do
 scouts: decode the particle to generate genes, obtain the reduced MIP and solve it by
  CPLEX
 calculate fitness
 generate employed bees and onlooker bees: trail() 0
 select neighborhood operator
 for all solutions ’ that can be generated by applying to do
 if tardiness(’) < tardiness() then
  
  trial()=0
 else
  trial()=trail()+1
 end if
 calculate Probability()
 if Probability() > rand()
  employed bees: select neighborhood operator
  for all solutions ’ that can be generated by applying to do
  if tardiness(’) < tardiness() then
   
    trial() 0
  else
   trial() trail()+1
  end if
 end if
 if trail() >
  scouts: generate the new food source
  update BestSolution
  +1
 end if
 if
  find BestSolution
 else
  generate employed bees and repeat
 end if
end while

5. Computational Experiments

This section presents the computational experiments conducted to evaluate the proposed algorithm. Several experiments are performed on a PC (Intel Core i7, 2.6 G Hz; Memory, 8 G). Each algorithm based heuristic is coded by using C#. In addition, Tables 3 and 4 list the parameter values of the proposed model, and PSO algorithm and the proposed algorithm, respectively.

The quality of solutions is affected by the number of machines and the number of tasks . Tables 5 and 6 summarize the small-scale instances and large-scale instances’ computational experiments solved by CPLEX, the PSO algorithm method, and the PSOB algorithm method in terms of the average computation time (CPU) and the solution quality. Each set has ten randomly generated cases and we record their corresponding average values.

As Tables 5 and 6 show, the average computation time required by CPLEX increases sharply with an increase in the number of tasks. For the instance with 2 machines, the 20-task case is already very difficult to solve; the instances with 3 machines and 4 machines are very difficult to solve with 16 tasks and 18 tasks, respectively. Analyzing Tables 5 and 6, the total number of instances is 27, and the solutions of PSOB algorithm are closer to the exact solutions obtained by CPLEX than that of PSO algorithm in all 27 instances, including 7 instances with equal solutions. Besides, the computation time by the PSO algorithm is longer than that of the PSOB algorithm. Therefore, the computational experiments show that the PSOB algorithm outperforms the PSO algorithm in terms of both solution quality and computation time.

In total, the heuristic algorithms are able to find equally good solutions for small-scale instances and can find better solutions than the CPLEX solver within a reasonable time. Tables 5 and 6 show that the PSOB algorithm’s solutions are closer to CPLEX’s solution than those of the PSO algorithm. Therefore, this article argues that, in the continuous-casting stage of iron and steel enterprises, the distribution of casting machines and casting molten steel tundish processing order problems based on upstream resource constraints are more suitable to be solved by the PSOB algorithm for large-scale problems.

6. Conclusions

The steelmaking and continuous-casting problems have been extensively studied in literature and widely adopted in industry. However, most studies only consider a single machine which has a linear resource supplied. In practice, the resource supply rate and consumption rate are nonlinear, and the available time for use of supplied resource is limited. Accordingly, we assume that the upstream resource is released at regular intervals and has limited time for use. The release and consumption of the resource happen at the beginning of each resource release cycle.

This article studies task assignment for continuous-casting production in integrated iron and steel enterprises. This problem differs from other similar problems without resource constraints because the optimal solution can be influenced by the resource constraints. The distribution of casting machine and casting molten steel tundish processing order problems are important planning problems for daily operational management in iron and steel enterprises. In order to deal with these problems efficiently, we present a mathematical model minimizing total tardiness and an improved heuristic algorithm to generate solutions automatically. We design a new encoding and decoding method and use the CPLEX, PSO algorithm, and proposed PSOB algorithm to solve the problem. From the computational experiments, we can find that the PSOB algorithm is able to find equally good solutions for small-scale instances and can find better solutions than the CPLEX solver and the PSO algorithm within a reasonable time.

Throughout this article, we assume that the resource is supplied at regular intervals and has a limited time for use. While these assumptions are essential and practical, the heuristic approach can easily be adapted to be used for different scenarios with arbitrary resource constraints. Therefore, the proposed approach can be used for a variety of industry production processes in which schedulers must take into account resource constraints.

Data Availability

The data used to support the findings of this study are included within the article.

Conflicts of Interest

The authors declare that they have no conflicts of interest.

Acknowledgments

This work was supported by the National Natural Science Foundation of China [grant numbers 71771143 and 71771180], Innovation Program of Shanghai Municipal Education Commission [No. 14YZ111], Shanghai Young Eastern Scholar Programme [QD2015041], Shanghai Pu Jiang Program (No. 13PJC066), and Human Arts & Social Science Foundation of Ministry of Education of China (No. 16YJC630112).