1. Introduction
Maritime transportation plays a vital role in the global economy, trade, and cultural exchanges as a basic logistic mode. Container terminals (CTs) were developed as one of the most critical components in logistic transportation systems. CTs consist of three major facilities: quay cranes (QCs), yard cranes (YCs), and automated guided vehicles (AGVs). AGVs cooperate with QC and YC operations. Effective task scheduling of AGVs is the key to reducing the operating cost of CTs. In the terminal’s traditional transportation mode, it is essential to ensure the working efficiency of the quay crane. Most terminals use more AGVs to avoid waiting for the quay crane. However, this will increase the waiting time of AGVs, thus reducing their utilization rate. Furthermore, the complex constraints among quay cranes, yard cranes, and AGVs further deteriorate the utilization of AGVs.
Many studies focused on the real-time scheduling of AGVs over the past few decades. For example, Mohammad and Saeed proposed a mathematical model composed of a job shop scheduling problem and a conflict-free routing problem [
1]. The objective was to minimize AGVs’ delay time and achieve multi-AGV integrated scheduling. A two-stage ant colony algorithm was proposed to solve it. Angeloudis and Bell studied job assignments of AGVs in CTs under various uncertainty conditions [
2]. A flexible algorithm for real-time AGV scheduling was proposed. Luo et al. designed an algorithm to prevent AGVs from collisions based on labeled Petri nets [
3]. Ji et al. studied the combinatorial optimization of two problems in the synchronous loading and unloading operation mode of the automated container terminal. They designed two bi-level optimization algorithms based on a conflict resolution strategy [
4]. Wang and Zeng investigated the AGV dispatching and routing problem with multiple bidirectional paths to generate conflict-free routes. A mixed-integer programming model was formulated to minimize the completion time of all jobs. A tailored branch-and-bound algorithm was developed to solve the problem [
5]. Zhong et al. studied a conflict-free AGV path planning problem and rail-mounted gantry crane scheduling problem [
6].
In terms of AGVs’ offline path planning, Graziana et al. showed how timed Petri nets can be efficiently used to solve problems related to resource planning in intermodal freight transport terminals. They considered a real case study and simulated it based on the timed Petri net model of the terminal [
7]. Rashidi and Tsang formulated an AGV scheduling problem as a least-cost flow model [
8]. They proposed an extended Network Simplex Algorithm (NSA+). Hu et al. analyzed a container-cluster operation and an optimal scheduling strategy of the yard truck [
9]. A multi-objective mathematical programming model was established and then solved by a genetic algorithm. Niu et al. proposed a cooperative strategy for scheduling trucks to minimize the total delay time of requests and the travel time of yard trucks [
10]. They applied a particle swarm optimization algorithm to solve the problem. The studies, as mentioned above, significantly improved the utilization of AGVs and the operational efficiency of CTs, but they cannot guarantee a full load and ensure the least total waiting time of AGVs during their transportation. Hence, we propose a double-cycling AGV route planning model in this work to maximize the loading rate and minimize the waiting time of AGVs during their transportation.
In CTs, AGVs cooperate with the working of QCs and YCs. The work efficiency of QCs directly affects the berth time, which is also an important research topic. Many studies focused on an efficient quay crane scheduling problem (QCSP) under various complex conditions. Huang and Li proposed a bounded two-level dynamic programming algorithm aiming at a QCSP [
11]. A method was proposed to evaluate the practicability of the algorithm. Ji et al. considered optimizing a loading sequence in CTs [
12]. A model was established to integrate the loading sequence and a rehandling strategy under parallel operations of multi-quay cranes. An improved genetic algorithm was proposed to solve the model. Zhang and Kim attempted to minimize the operational cycle time of a QC for unloading and loading containers in a ship bay [
13]. They formulated a QCSP as a mixed-integer programming model and solved it using a hybrid heuristic approach. Nguyen and Kim compared various pooling strategies for constructing the pool [
14]. Heuristic algorithms were evaluated in terms of the total delay time of QC operations and the total travel distance of AGVs. Zhen et al. studied an integrated optimization QCSP and yard truck scheduling problem (YTSP) in CTs [
15]. A mixed-integer programming model was formulated and solved by a particle swarm optimization-based method. Zhang et al. extended the QCSP by considering the stability of containers and proposed a QCSP with stability constraints [
16]. A bi-criteria evolutionary algorithm was proposed to solve it. Most of the above QC scheduling methods fail to consider the impact of uncertain factors, especially the tide fluctuation and manual operation, on QC transportation tasks, with a few exceptions (Zhen, 2014 [
17]; Sheikholeslami and Ilati, 2018 [
18]). Uncertainties can be good or bad for a transportation system (Wang and Wu, 2021 [
19]), and we analyze uncertainties in our model.
The dispatch of YCs is another crucial part of CTs. Most researchers combine the scheduling of YCs and AGVs to formulate the model closer to reality. Zheng et al. investigated single YC scheduling to minimize the total tardiness of tasks and focus on the case with uncertain release times of retrieval tasks [
20]. A two-stage stochastic programming model was proposed, and a genetic algorithm and a rule-based heuristic were developed to solve it, especially for large-scale instances. Ng and Mak studied the scheduling of a YC to perform a given set of loading and unloading tasks with different ready times, which minimizes the sum of the task waiting time [
21]. A branch and bound algorithm was proposed to solve it. Some studies focus on a yard crane scheduling problem (YCSP) under various conditions. Javanshir et al. studied a YCSP among different blocks in CTs to minimize cranes’ total travel time and the total delayed workload [
22]. It was formulated as a mixed-integer programming model and solved by a branch-bound method. He et al. addressed a YCSP with the uncertainty about the vessels’ arrival time and volumes [
23]. It optimized the total delay to the estimated ending time of all task groups based on a genetic algorithm-based framework combined with a three-stage algorithm.
In CTs, a double-cycling scheduling model of QCs and YCs requires that a crane transports a container, unloads it, and returns by taking another container. Meanwhile, AGVs transport a container to its destination and bring another one back. At present, double-cycling strategies are used in QCSP, YCSP, YTSP, and sequencing the loading of the container (i.e., Container Sequencing Problem, CSP, which refers to sequencing the loading/unloading of the container in the yard [
24]), as shown in 
Table 1. Most of these studies considering a double-cycling scheduling mode do not specifically consider the uncertainty of QC operation. Most of these studies do not obtain specific AGV scheduling, including which containers should be transported by each AGV and the sequence of transporting these containers by an AGV. In this work, a double-cycling model is proposed to realize the full load of AGVs by scheduling loading/unloading containers to minimize the waiting time of the AGVs. A hybrid particle swarm optimization (HPSO) algorithm with a penalty function is used to solve this issue.
The rest of this paper is organized as follows. 
Section 2 describes a double-cycling model and proposes a container scheduling sequence based on an HPSO algorithm. 
Section 3 shows experimental results. 
Section 4 concludes this paper and discusses the future work.
  3. Results
Matlab_R2019a was used to solve the double-cycling model. First, we randomly generated a container scheduling sequence. In this work, a queue was formulated for each QC or YC. The task points were arranged in queues according to the container’s transportation order of the container scheduling sequence. The waiting time of the task points and the number of task points that did not meet the LTQ were calculated according to the relationship among the task points in the queue. Then, the scheduling sequence with the least number of task points that did not meet the LTQ and the least AGV waiting time were obtained using an HPSO algorithm. We then analyzed some critical parameters.
Corresponding waiting areas were set up at the quayside and the yard for storing AGVs that needed to wait. AGVs in the waiting area could turn off the engine or keep the engine on for waiting according to the estimated waiting time. The waiting time of the AGV that remained after starting the engine was a key to be considered in the double-cycling model. 
Table 5 show the data obtained in Qingdao Port from our field investigation.
Table 6 show experimental results considering the total waiting time of the AGVs (Total Waiting Time), the number of task points that did not conform to LTQ (Not-Conform LTQ), the number of task points that did not conform to double-cycling (Not-Conform Double-cycling), and the fitness value.
 First, a time disturbance that conformed to the Gaussian distribution was added to the QC operation time. We randomized the assignment according to the Gaussian distribution, so the results were not the same each time. In the double-cycling model, the experimental results showed that most scheduling sequences satisfy both double-cycling and LTQ. This work simulated the time disturbance existing in the QC operation, so a few experimental results failed to satisfy LTQ at all task points on the basic constraint of double-cycling. The number of task points that did not conform to LTQ was significantly higher in the last experiment than in other experiments. This situation was generally caused by the significant difference in the QC operation time in the last experiment and other experiments’ QC operation time, resulting in a severe phenomenon of AGV delays. The QC operator caused the time disturbance of QC operating time. Therefore, we think that the AGV could not reach the quayside in time due to the operator’s operation error. This part of the data should be discarded or recalculated. However, according to the experimental results in 
Table 6, there exists the phenomenon that some AGVs’ scheduling sequence was empty in the optimal scheduling sequence, which led to resource waste. To further improve the efficiency of the double-cycling system, this work continued to consider the influence of the number of AGVs on the efficiency of the double-cycling system. 
Table 7, 
Table 8, 
Table 9, 
Table 10 and 
Table 11 show the experimental results of changing the number of AGVs under a different number of task points on the base constraint of double-cycling, including the total waiting time of AGV and the number of task points that do not conform to LTQ. We selected three experimental results for each number of AGVs.
For the different number of task points, we set different numbers of AGVs to transport them. The number of AGVs was gradually reduced until the constraint of conforming to LTQ could not be satisfied at all task points in most experiments, and the number of AGVs was set as the lower bound to transport the number of task points successfully. The number of AGVs was gradually increased until some AGVs’ scheduling sequence was still empty in most experiments, and the number of AGVs was set as the upper bound under the number of task points. 
Table 7, 
Table 8, 
Table 9, 
Table 10 and 
Table 11 show that for different numbers of task points, there was a corresponding number of AGVs to ensure that all task points met LTQ and had the minimum waiting time. For the number of task points in 
Table 7, 
Table 8, 
Table 9, 
Table 10 and 
Table 11, the appropriate AGVs were 3, 4, 5, 5, and 6, respectively. Too few AGVs will increase the number of task points that do not conform to LTQ, and too many AGVs will result in an increase in the waiting time of AGVs. Therefore, only an appropriate number of AGVs can improve the efficiency of the double-cycling model and make full use of transportation resources. In the real world, we can deal with containers on a ship layer by layer to break down a significant problem into more minor ones, and our model can then be applied. As mentioned above, the time disturbance of QC operation obeys different Gaussian distributions. This work discusses the influence of QC operations conforming to different Gaussian distribution models on the double-cycling system. 
Table 12 show the experimental results under different Gaussian distributions with 30 task points and five AGVs.
The smaller the μ and σ mean QC operator’s operation experience more affluent, and the smaller the time disturbance of the QC operation is. When μ = 4, σ = 4, the AGV’s waiting time fluctuates around 1814 s, with almost no QC delay. With the increase of μ and σ, the AGV waiting time fluctuates, and the QC delay becomes more and more frequent. The rise of σ leads to the increase of the time disturbance of QC operation, resulting in the AGV waiting time and the number of task points that do not conform to LTQ fluctuating significantly. The increase of μ postpones the time disturbance interval of QC operation, resulting in the AGV waiting time being longer. The experimental results show that the more experienced the QC operator is, the lower the AGV waiting time and QC delay times.
According to the model presented and relevant experimental results in this work, as long as the information of the task points set can be obtained, the iterative calculation of the task points set can be carried out in advance. The optimal container scheduling sequence is selected by adjusting the relevant factors, which proves the feasibility of the double-cycling model in practical situations. In the real world, we only need to consider the top layer of containers in the ship to break down the large problem into several small sub-problems. The sizes of the experiments conform to the real situation.
To ensure that the HPSO algorithm is excellent, the Simulated Annealing (SA) algorithm and Genetic Algorithm (GA) are designed for comparison in this work. It assumes that the success rate is 
S and the total number of experiments is 
E, where the number of successfully obtaining scheduling sequences that satisfy both LTQ and double-cycling constraints is 
e. The algorithm’s success rate is:
Table 13, 
Table 14 and 
Table 15 show that the three algorithms are compared with the success rate under the different number of task points and the success rate under the different numbers of 
μ and 
σ. 
Table 15 show the average execution time of the algorithm under the different number of task points.
 Table 13 show that HPSO has the highest success rate in obtaining effective solutions. 
Table 14 show that HPSO has the most stable performance under different time disturbances. 
Table 15 show the HPSO algorithm takes the least time.
 Meanwhile, 
Table 13, 
Table 14 and 
Table 15 show when the values of the 
μ and 
σ are small, the success rate is high. With the increase of the values of 
μ and 
σ, the algorithms’ success rate gradually declines, and the average execution time of the algorithms is more extended. Only the HPSO algorithm maintains a 90% success rate and a short average execution time. The reason for this result is the uncertainty of the QC operation. If the number of task points or the value of 
μ and 
σ increases, the transportation uncertainty on the quayside increases, resulting in an increasing number of task point sequences that cannot satisfy LTQ and double-cycling constraints.