1. Introduction
With the increasing number of shipping containers and the rising cost of port manual operations [
1], intelligence, unmanned, and automation are becoming the trends of port development. As the most representative equipment of an unmanned port, AGV are the main carriers of horizontal transportation at the front of the automated terminal. AGV can carry out container transportation along the specified automatic guidance route according to the operation instructions. Due to the advantages of convenient operation, intelligence, and integration, AGV are safer, more efficient, and more environmentally friendly than traditional container truck transportation. With the development of automated terminals and the application of AGV, their advantages are revealed, while their problems are gradually exposed. The operation environment of automated terminals is relatively complex, which manifests in dynamic, random, sudden, and other uncertainties, making the AGV path planning problem more complex. At the same time, AGV are an important link connecting the shore and the yard, which greatly impact the operation efficiency and overall operation of the entire terminal. As container ports are a complex multi-system aggregation [
2,
3], once the AGV break down or collide with other AGV on the original routing, it will cause the AGV to lock up, aggravating the traffic congestion of the terminal, which is not conducive to the improvement of port traffic efficiency and the reduction of operating costs. Therefore, current research focuses on the efficient container transport route planning of AGV in the terminal. An increasing number of experts and scholars have conducted research on AGV scheduling, AGV routes, and AGV collision avoidance. Qiu et al. [
4] introduced the problem of AGV scheduling and routing, investigated and classified the main existing algorithms, and pointed out that the existing algorithms are only suitable for small-scale use of AGV. AGV scheduling optimization is to allocate tasks and path planning for AGV according to container operation tasks [
5]. The purpose of scheduling optimization includes one or more of the following: shortest formal path, shortest total operation time, and lowest operating cost. Kim et al. [
6] used an integer programming model to study the AGV scheduling problem of automated terminals with the objective of minimizing the total delay time of tasks and the total transportation cost of AGV. Xin et al. [
7] put forward an equipment rescheduling method based on the current state to reduce the impact of interference (such as job delay or machine failure) on operation efficiency, aiming at the problem that the current container terminal scheduling is mostly offline scheduling, which reduces the container handling delay time and saves energy consumption. Confessore et al. [
8] established a model for the AGV scheduling problem, gave a mixed integer programming model with the shortest running time as the goal, and solved the running route and task order of AGV by using a soft time window and penalty factor constraints. Errico et al. [
9] established the hard time window and random processing time model of the AGV route based on the branching method and cutting plane rule. Wu et al. [
10] developed a novel AGV multi-state scheduling algorithm (MSSA), which achieved a good trade-off between AGV utilization and total processing span. Compared with the traditional idle scheduling strategy, MSSA schedules more AGV and tasks in each calculation, making its optimization goal closer to the global optimization goal. Li et al. [
11] studied the relationship between AGV scheduling tasks, charging threshold, and power consumption in the smart factory, and jointly optimizing the AGV charging problem and the AGV operation sequence.
AGV route planning is mainly divided into two categories: one is static research, and the other is dynamic research [
12]. In the research of static path planning, Zhong et al. [
13] proposed a mixed integer planning model based on path optimization, integrated scheduling, conflicts, and deadlocks to minimize the delay time of AGV under the condition of known task allocation, and conducted large-scale and small-scale experiments to prove the effectiveness of the model. Chen et al. [
14] developed an effective routing of multiple AGV based on the repulsive potential field optimized ant agent (Rf Ant agent). Aiming at the congestion phenomenon of nodes, they introduced a guiding factor into the path node selection model to determine the direction of AGV in the centralized control node. Xing et al. [
15] proposed a novel tabu search (NTS) algorithm to solve the conflict when multiple AGV work at the same time in the automatic warehouse, which improved the efficiency of AGV picking goods in the automatic warehouse. According to the location of each picking point in the warehouse, and the initial solution generation and termination conditions in the proposed algorithm, relocation and exchange operations were designed for the neighborhood search process. Homayouni et al. [
16,
17] studied the basic scheduling problem of AGVs and QCs. Taking the maximum completion time of QCs as the object, a mixed integer programming model was proposed by combining a quadratic genetic algorithm (GA) with a simulated annealing method. As for the research on static route planning, scholars mainly model and solve AGV route planning based on the stability of the static road network, with the goal of minimizing the total travel distance, and rarely consider AGV scheduling and AGV collision avoidance.
In the process of automated terminal AGV transporting of containers, due to the unmanned operation state, the implementation of AGV operation tasks will inevitably lead to hidden dangers of collision and deadlock. Jerzy et al. [
18] divided the transport road network into nonoverlapping unidirectional regions, and the transmission network can be expressed as a segment composed of unidirectional regions and a segment composed of other regions. The effectiveness of the proposed method was verified by simulation. If they cannot be resolved, they will directly affect the implementation of AGV tasks. AGV cannot complete the scheduled tasks on time. Therefore, in the process of AGV transportation, it is also necessary to consider AGV conflict control during driving. Liu et al. [
19] used Dijkstra algorithm to improve the optimal path search method of a single AGV. Priority based traffic rules were introduced into the directed graph, and the speed and geometric trajectory of the AGV were adjusted, thus effectively solving the collision and conflict between vehicles. Umar et al. [
20] proposed a genetic algorithm using task priority to detect and avoid AGV conflicts in order to solve the path interference problem of AGV. Dimitri et al. [
21] proposed a strategy based on time logic according to the problem of AGV collision avoidance in FMS, used time Petri nets to model, and proved its feasibility through simulation.
To sum up, the current literature on AGV route planning mainly focuses on the task allocation, route planning and collision avoidance of AGV. Most of the AGV route planning research on collision avoidance is based on intelligent factory. As a large logistics handling system, the automated terminal requires multiple operation subsystems to be optimized at the same time, so it has a certain complexity and challenge. The research on collision avoidance of AGV is generally based on the existing route to schedule the AGV in the collision. It ignores the impact of AGV’s task allocation on the route selection, so we propose a three-stage algorithm that combines heuristics and simulation, and uses the topology method to build an automatic container terminal network diagram. The AGV task allocation, route planning, and AGV collision avoidance are jointly optimized within a framework to reduce the AGV collision through a speed control strategy and improve the port operation efficiency
The remainder of this paper is organized as follows. 
Section 2 describes the problem formulation. 
Section 3 formulates three submodels about AGV route scheduling, AGV tasks assignment, and AGV collision avoidance control. 
Section 4 illustrates the framework of the proposed algorithm, the coding process, and the process of the simulation model. Case studies are presented in 
Section 5, and the conclusions are drawn in 
Section 6.
  2. Problem Formulation
In the automatic terminal loading and unloading process, when a container ship is berthed and QC are loading and unloading the ship according to the port operation schedule, AGV are required to work cooperatively to unload the container from the QC and send it to the yard blocks. With the layout of an automated terminal as a reference, we built an AGV road network model, as shown in 
Figure 1. We can see that AGV travel in a given direction in the specified road network model. When receiving task information, they pick up containers at the designated block or QC and send them to the designated block or QC.
In the process of traveling, AGV have four handling and transportation modes: (1) only unloading, (2) only loading, (3) loading first and unloading later, and (4) unloading first and loading later. Due to the large number of container terminal operations, AGV may encounter collisions during travelling, which are mainly divided into three categories: (A) pursuit in the same direction, (B) conflict at interaction points, and (C) conflict in the opposite direction. With the layout of an automated terminal as a reference, we built an AGV road network model, as shown in 
Figure 1.
We can see that AGV travel in a given direction in the specified road network model. When receiving task information, they picks up boxes at the designated box area or quayside bridge and send them to the designated box area or quayside bridge. In the process of driving, AGV have four transportation modes: (1) unloading only, (2) loading only, (3) loading first and unloading later, and (4) unloading first and loading later. Due to the large volume of container terminal operations, AGV may encounter collisions during driving, which are mainly divided into three categories: (A) chasing conflict in the same direction, (B) interaction conflict, and (C) conflict in the opposite direction. In actual operation, AGV locking is a difficult problem. When planning AGV road strength, we should consider the environment and task allocation of the actual port operation area, and pay attention to collision avoidance.
The essence of AGV scheduling planning is the AGV route optimization problem. Therefore, the core work of this paper is to realize a collision avoidance design of AGV by optimizing the trajectory of AGV. At present, route planning of AGV is an important part of intelligent control systems and the key to ensure work safety. When encountering obstacles, the traditional path planning algorithm is mainly used to solve the problem when the robot encounters obstacles, to find and plan the correct path. There are two main types of AGV route planning: one is carried out in a static environment, and the other is carried out in a dynamic environment.
- (1)
- AGV route planning in the static environment 
Under the condition of a static route network, AGV can sense the surrounding environment without fully understanding the surrounding environment, and use this method to determine the running trajectory of AGV. Therefore, this route is usually used when there are only static known obstacles in the environment. However, in order to plan the path of AGV in a stationary environment, the distance between the target point and the target must be determined first to avoid the existence of obstacles and blockage, and the shortest path needs to be planned to ensure that the AGV can reach the destination in the shortest time.
- (2)
- AGV route planning in the dynamic environment 
Due to the changing environment, a lot of information cannot be controlled. Safety and timeliness should be taken into account when planning routes. No matter which performance metric you use, you need to consider target attraction, dynamic security, and time constraints. In a complex road network, due to the large number of AGV running, it is difficult for path planning to avoid path conflicts between vehicles, and at the same time, road deadlock caused by path conflicts cannot be eliminated, which will lead to traffic efficiency decline, and may lead to the standstill of the lateral traffic system.
Therefore, we propose a three-stage optimization algorithm for joint AGV route and task allocation, using GA to find the initial AGV route scheme. On this basis, in the simulation model, the proposed speed control strategy is to make adjustments to the route scheme to prevent collisions.
  3. Modeling
This problem involves three mathematical models. Model 1 is the optimal route model of AGV. The objective is to minimize the traveling distance of AGV. The AGV transportation area network is the input data, and the output result is AGV route schedule. 
Figure 2 is the AGV transportation area network. Model 2 is the AGV task assignment model. The container task set is input data, and the output result is the assignment schedule of the container task. Model 3 is the AGV collision avoidance control model. The container assignment schedule and AGV route schedule are the input data, and the output result is the final driving scheme of AGV.
  3.1. Assumptions
- (1)
- In order to simplify the modeling, the route of AGV is only unidirectional, so there will be no opposite conflict. 
- (2)
- Only one AGV can be driving in any road section. 
- (3)
- The actual loading and unloading time of a container by QC follows the normal distribution of (120, 20), when the standard operation time of loading and unloading each container by the QC is about 120 s. 
- (4)
- Each task can only be completed by one AGV, and each AGV can only load one container at a time. 
- (5)
- The berths and yard blocks served by an AGV are not fixed. 
- (6)
- Ignore the weather, AGV damage, and other force majeure factors. 
- (7)
- The number of AGV and QC is known. 
- (8)
- The number of tasks and the corresponding loading and unloading blocks of each task are known. 
  3.2. AGV Route Modeling
| Set | 
|  | Set of QCs’ nodes | 
|  | Set of blocks’ nodes | 
|  | Set of nods in the route network, . | 
|  | Set of sections of the route between node a and node b, . | 
|  | Set of AGVs, . | 
|  | Set of containers, | 
|  | Set of loading containers | 
|  | Set of unloading containers | 
|  | Set of all tasks, ,  is virtual started task,  is virtual finished task | 
| Parameter |  | 
|  | Set of traveling time between QC q and block b | 
|  | The travelling time of AGVq transport task i and j | 
|  | The travelling time of AGVq transport task i | 
|  | The travelling time of AGVq transport task I and task j on empty state | 
|  | The waiting time of AGVq at QC i | 
|  | The waiting time of AGVq at block b | 
|  | The earliest time that the AGV can be operated at the QC for task i | 
|  | Time when quayside crane completes container task j, | 
|  | The length of AGV | 
|  | Safe distance to be kept by AGV when travelling or stopping for waiting | 
|  | AGV’s normal constant speed | 
|  | AGV deceleration speed | 
|  | The acceleration of AGV acceleration and deceleration under speed control | 
|  | The speed after AGV decelerates from normal speed | 
| Decision variable: | 
|  | 1, if the route path from node i to node j; 0, otherwise. | 
|  | 1, if AGV k chooses the route path from node a to node b; 0, otherwise. | 
|  | 1, AGV k completes task j after completing task i; 0, otherwise. | 
The objective function (1) is to minimize the total traveling distance of AGV from the QC to the yard block. AGV load (unload) containers at the QC and transport containers to the designated yard block through the AGV route network. The traveling distance of these three parts constitutes the total traveling distance from the QC to the yard block, and also corresponds to the first, second and third items in the formula.
        
Constraint (2) indicates that the AGV travelling path driving path is a cycle with a beginning and an end, and cannot be terminated halfway. Constraint (4) and (3) indicates the road section with node i to node j. Constraint (4) indicates elimination of sub-circuits.
  3.3. AGV Task Assignment Modeling
| Set | 
|  | Set of containers, | 
|  | Set of loading containers | 
|  | Set of unloading containers | 
|  | Set of all tasks, ,  is virtual started task,  is virtual finished task | 
|  | Set of traveling time between QC q and block b | 
| Parameter | 
|  | The travelling time of AGVq transport task i and j | 
|  | The travelling time of AGVq transport task i | 
|  | The travelling time of AGVq transport task I and task j on empty state | 
|  | The waiting time of AGVq at QC i | 
|  | The waiting time of AGVq at block b | 
|  | The earliest time that the AGV can be operated at the QC for task i | 
|  | Time when quayside crane completes container task j, | 
|  | The length of AGV | 
|  | Safe distance to be kept by AGV when travelling or stopping for waiting | 
|  | AGV’s normal constant speed | 
|  | AGV deceleration speed | 
|  | AGV acceleration speed | 
|  | The acceleration of AGV acceleration and deceleration under speed control | 
|  | The speed after AGV decelerates from normal speed | 
|  | The length of AGV | 
|  | Safe distance to be kept by AGV when travelling or stopping for waiting | 
|  | AGV’s normal constant speed | 
|  | AGV deceleration speed | 
| Variable | 
|  | 1, AGV k completes task j after completing task i; 0, otherwise. | 
In the automated container terminal operation system in 
Figure 1, AGV have four transportation modes: (a) only unloading; (b) only loading; (c) loading first and unloading later; and (d) unloading first and loading later. Different transportation modes determine the empty travelling time and overall travelling time of AGV. For example, the empty car travelling time algorithm of the loading only mode and the loading first unloading mode is completely different, so it is necessary to classify 
 and discuss 
, travelling time. 
 represents the time interval between AGV arriving at the QC of task 
i and at the QC of task 
j. Because 
 has different values under different loading and unloading task modes, the initial virtual start ends the task. 
 represents the deadhead time of the time interval between AGV arriving at the QC under task 
i and the QC under task 
j. 
 represents the time interval between AGV arriving at the QC of task 
i and the QC of task 
j. Under the above four transportation modes, the values of 
 are:
The QC operation is carried out according to the QC operation priority sequence planning. The sequence of tasks should be considered when calculating 
. For example, for the QC 
q, four loading and unloading tasks are arranged, and the third task is carried out after the first task completion. We explain the calculation of 
, 
 under 4 different types in 
Table 1 and 
Table 2. M is a maximum number to ensure that the QC operate in the sequence of the operation priority sequence planning.
Under the four transportation modes, the meaning of deadhead time is different. Under the unloading mode, deadhead time is the time from the container area in the yard of the previous task to the quayside bridge position of the next task. The idling time in the packing mode is the time of moving from the quayside bridge position of the previous task to the container area of the storage yard of the next task. The deadhead time under the loading and unloading mode is the moving distance from the quayside bridge position of the previous task to the quayside bridge position of the next task, In the unloading before loading mode, the idling time is the moving distance from the container area in the storage yard of the previous task to the container area in the storage yard of the next task.
 is the AGV’s waiting time for container loading and unloading at the QC may occur in the following two situations due to the arrival of the QC:
- (1)
- AGV arrived late and the QC waited for AGV.  
- (2)
- AGV arrives early and needs to wait for the QC.  
The objective function (5) is minimum AGV maximum completion time. Constraint (6) means that for each task, subsequent tasks can only be completed by the same individual AGV, and each task can only be completed once. Constraint (7) means that for each task, the previous task can only be completed by one AGV, and each task can only be started once. Constraint (8) indicates transportation balance, that is, for intermediate tasks, each task has a successor task and a successor task. Constraint (9) indicates that each AGV has a start task. Constraint (10) indicates that each task has an end task. Constraint (11) indicates that the decision variable AGV sequence is 0–1 variable. Constraints (12)–(15) represent the total time required to complete the task. Constraints (16)–(19) indicate the idling time of the vehicle during the task completion. Constraint (20)–(21) represent the time for AGV to complete the task. Constraints (22)–(24) represent the time when the quayside crane completes the container task.
  3.4. AGV Collision Avoidance Control Modeling
Because AGV may encounter intersection collision during driving, it is necessary to control the speed of vehicles to be collided. The speed control strategy is as follows: select AGV1 with lower control priority, AGV1 decelerates to v1 with acceleration a, then AGV1 moves at a constant speed with speed 
, then AGV2 with higher control priority accelerates to 
 with acceleration a, then continues to drive at a constant speed with acceleration 
, and finally passes the intersection.
        
The objective function (25) shows the time cost of AGV passing through the target node. Contract (26) illustrates time required for AGV with high priority and AGV with low priority to pass through the target node is the same. Contract (27) illustrates the distance required for the AGV to decelerate from normal speed  to speed . Contract (28) shows the time required for the AGV to arrive at the conflict node by slowing down. Contract (29) shows the travel time required for vehicles with higher priority to accelerate to reach the conflict node. Contract (30) shows the time required for vehicles with higher priority to accelerate from  to .
  4. Solution Technology
We propose a hybrid technique of combining algorithms and simulations to solve models. In the first stage, AGV route planning is essentially a “shortest path problem”. The classical Dijkstra algorithm is a mature and commonly used algorithm to solve the shortest path problem. We use Dijkstra to solve the model and obtain the AGV optimal route planning scheme. In the second stage, we use GA to solve the AGV task assignment problem, and the AGV route planning scheme is obtained from the first stage as known information. In the third stage, the simulation model is used to verify the AGV operation efficiency under the task sequence and speed control strategy compared with the conventional scheme. 
Figure 3 is the technical roadmap of the three-stage method.
  4.1. GA for the Assignment Model
  4.1.1. Coding of Chromosomes
We adapted the real number coding method to represent chromosomes. In 
Figure 4, the length of the chromosome is the sum of the number of containers plus the number of AGV plus one, that is, n + m + 1, and the value of the gene is the task to be handled. Tasks of different AGV are separated by 0. Part 3 in 
Figure 4 shows that the container operation task sequence of AGV1 is {10, 3, 2}, AGV2 is {5, 8, 1}, and AGV3 is {7, 4, 9}.
  4.1.2. Fitness Function
AGV scheduling problem is a minimization problem. Chromosomes with higher adaptability should have smaller objective functions , where  is the value of fitness value and  is the objective function value.
  4.1.3. Selecting and Crossing
Since the fitness function is to select the smaller fitness value, the roulette wheel gambling method can be used to save the superior genetic genes of the previous generation to the next generation, and combining with the elite retention strategy, so as to avoid the loss of the optimal solution or the decline of the quality of the optimal solution after cross mutation operation, thus ensuring that the designed algorithm is globally convergent to a certain extent.
Since there are zero elements in chromosomes, they cannot be crossed directly. The method of linear crossing is adopted here, and the specific steps are as follows in 
Figure 5:
  4.1.4. Chromosomal Mutation
The mutation mode is to select exchange mutation. In 
Figure 6, a chromosome is randomly selected from the parent, and two genes are randomly selected at any part of the chromosome and exchanged to generate offspring, so as to change the AGV operation sequence. Finally, the modified task sequence is repaired to make the container handling task legal.
  4.2. Simulation Considering AGV Collision Avoidance Control
Under the AGV road network of the automated terminal, due to the characteristics of random and discrete container terminal operations, it is affected by many factors in the scheduling optimization. In addition, the impact of many factors, including terminal structure layout, technology, and so on, have brought great impact and difficulties to the actual operation of the terminal.
We adapt the discrete simulation technology to carry out simulation research on the AGV route planning, and analyze the results under different AGV collision avoidance control modes, to compare the advantages and disadvantages of them, so as to apply them to the actual production process of the wharf.
We use plant simulation software to simulate the horizontal transportation layout of the automatic terminal, as shown in 
Figure 7. When building a simulation model in plant simulation, the first step we must perform is to select all the elements required for simulation, which mainly includes three kinds of entities: entity, container, and transporter. This model mainly designs the following elements:
When building a simulation model in plant simulation, it mainly includes three types of entities: entity, container, and transporter. This model mainly designs the following elements:
- (1)
- Entity: 1000 containers; three QC, five YCs and five Blocks. 
- (2)
- Events: container generation, container unloading operation, AGV pick-up operation, AGV transportation, YCs loading and unloading operation, etc. 
- (3)
- Control logic: sensor_ ctrl, conflict, exit_ ctrl, container_ in, container_ Out, etc. 
In plant simulation, we divide the basic unit objects used in logistics simulation modeling into five categories, for a total of 33. These object units can be divided into control and framework types according to their functions, and production, transportation, and resource types according to their uses. The objects used to create the simulation model in this paper are basically shown in 
Table 3.
This simulation is aimed at AGV route planning in the horizontal transportation area of the automated terminal.
  4.2.1. Simulation Experiment Observation Index
When using plant simulation for simulation, it is necessary to record relevant observation indicators in the simulation process for analysis. The specific observation indicators are as follows:
- (1)
- The makespan for AGV to complete loading and unloading tasks; 
- (2)
- Number of collision avoidance control strategies under speed control strategy; 
- (3)
- Utilization of AGVs 
  4.2.2. Simulation Experimental Parameters
The main content of this paper is to simulate the AGV path planning problem. Based on the determination of AGV route and AGV scheduling, the actual travelling of AGV at terminal is simulated.
The experimental parameters of some facilities and equipment in this model are initialized as follows: Unloading speed of QC follows normal distribution (2:00, 0:20). The mean value is 120 s, the variance is 20 s, the maximum value is 140 s, and the minimum value is 100 s, , , , . In addition, there are five container buffer areas in the terminal yard.