Next Article in Journal
Rapid ELISA Using a Film-Stack Reaction Field with Micropillar Arrays
Next Article in Special Issue
An Optimized, Data Distribution Service-Based Solution for Reliable Data Exchange Among Autonomous Underwater Vehicles
Previous Article in Journal
Candle Soot Coating for Latent Fingermark Enhancement on Various Surfaces
Previous Article in Special Issue
Polar Grid Navigation Algorithm for Unmanned Underwater Vehicles
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Task Assignment and Path Planning for Multiple Autonomous Underwater Vehicles Using 3D Dubins Curves  †

1
School of Electronics & Information, Hangzhou Dianzi University, Hangzhou 310018, China
2
School of Electrical Engineering, Zhejiang University of Water Resources and Electric Power, Hangzhou 310018, China
3
Department of Electrical & Computer Engineering, Missouri University of Science and Technology, Rolla, MO 65409, USA
*
Authors to whom correspondence should be addressed.
The work ofWenyu Cai and Meiyan Zhang was performed during their one-year visit to Missouri University of Science and Technology in 2016.
Sensors 2017, 17(7), 1607; https://doi.org/10.3390/s17071607
Submission received: 1 March 2017 / Revised: 22 June 2017 / Accepted: 6 July 2017 / Published: 11 July 2017

Abstract

:
This paper investigates the task assignment and path planning problem for multiple AUVs in three dimensional (3D) underwater wireless sensor networks where nonholonomic motion constraints of underwater AUVs in 3D space are considered. The multi-target task assignment and path planning problem is modeled by the Multiple Traveling Sales Person (MTSP) problem and the Genetic Algorithm (GA) is used to solve the MTSP problem with Euclidean distance as the cost function and the Tour Hop Balance (THB) or Tour Length Balance (TLB) constraints as the stop criterion. The resulting tour sequences are mapped to 2D Dubins curves in the X Y plane, and then interpolated linearly to obtain the Z coordinates. We demonstrate that the linear interpolation fails to achieve G 1 continuity in the 3D Dubins path for multiple targets. Therefore, the interpolated 3D Dubins curves are checked against the AUV dynamics constraint and the ones satisfying the constraint are accepted to finalize the 3D Dubins curve selection. Simulation results demonstrate that the integration of the 3D Dubins curve with the MTSP model is successful and effective for solving the 3D target assignment and path planning problem.

1. Introduction

Autonomous Underwater Vehicles (AUVs) and underwater gliders have found important applications in ocean exploration, oil and gas production, environmental monitoring, underwater infrastructure monitoring, weather services, and coastal surveillance [1,2,3]. Typically, these vehicles are programmed to visit a number of predetermined targets, perform some tasks at the target locations, and then return home. With the increased demand and commercial success of the AUVs and gliders, it is of increasing interests to employ a fleet of vehicles simultaneously and cooperatively to perform a mission. Therefore, multi-vehicle task assignment and path planning become an important research topic in recent years.
Due to the size, weight, and fuel constraints, these vehicles have strong limitations in underwater missions, such as limited mission length, stringent nonholonomic motion constraints, and limited communication with each other or with the home base. A nonholonomic motion constraint requires that the vehicle motion is along a smooth curvature without reversing direction. This often requires that the vehicle paths satisfy geometric continuity to support their kinematic constraints [4,5]. For point-to-point path planning, Dubins curves have been widely utilized to achieve G 1 continuity and shortest path length [6,7]. Recent literatures on Dubins vehicles also consider environmental conditions such as ocean currents [8,9], obstacle avoidance [10,11], and vehicle/glider characteristics [12,13]. However, most of the works only consider 2-dimensional (2D) Dubins curve, and the extension to 3D Dubins curve is recently proposed in [14] for unmanned aerial vehicles by using linear interpolation. This method is also adopted in [12,13] for path planning of gliders and AUVs.
The multi-target multi-AUV task assignment and path planning problem is commonly modeled by the multiple traveling salesperson (MTSP) problem. In the review paper [10], Zhu et al. provided a detailed report on the recent progress in this area. The MTSP problems are often solved by the K-means clustering method [8], the genetic algorithm (GA) [15,16], or the heuristic search algorithms [17,18]. Due to the high computational complexity, the MTSP problem is often solved by using the Euclidean distances between targets as the cost function. The resulting task assignments and tour sequences are then post-processed to account for vehicle dynamics, environmental constraints, and possible environmental changes. Ocean environmental conditions, such as the effect of strong ocean current, are considered in many recent works [8,9,17,19,20]. In addition, several approaches have been developed to adapt to changing environment, including the fast marching-based approach in [20], the Self Organizing Map (SOM) neural network approach in [21], and the dynamic task assignment approach in [22].
To account for the nonholonomic motion constraint, the tour sequence is mapped to point-to-point Dubins curves with a constraint that the incoming and outgoing headings at the joints are the same. In a large tour sequence where the number of targets to be visited is large, the search for shortest Dubins path is also computationally intensive. Several approaches have been proposed in the literature. An Alternating Algorithm is proposed in [23], which only maps half of the tour points to Dubins curves, thus reducing the search size for the shortest Dubins path. Two beading methods have also been presented in [23] to map the point-to-point paths with shortest bead-shaped paths. Other path-smoothing methods are presented in [24], which use continuous-curvature paths such as Clothoids, Bezier curves, and B-splines.
Most of the Dubins TSP solutions also have the limitation of using the 2D Dubins curves without considering the 3D underwater space. A few recent works extend the 2D Dubins curves to 3D [12,13,14] without considering multiple targets. Some works in 3D multi-target task assignment [11] consider targets in the 3D space without path smoothing. In this paper, we integrate the 3D Dubins curve with the MTSP model for 3D multi-target task assignment and path planning. We impose the energy consumption constraint of each AUV with the Tour Hop Balance (THB) and Tour Length Balance (TLB) criteria in the GA algorithm when solving for the tour sequences of multiple AUVs. We call these algorithms the THB-3Dubins-MTSP algorithm and TLB-3Dubins-MTSP algorithm, respectively. We investigate the simple linear interpolation method of 3D Dubins curve in the multi-target path planning scenario and demonstrate that the simple 3D Dubins curves fail to meet with G 1 continuity at multiple targets, because although the 3D Dubins path may be G 1 continuous in the X Y plane, they are discontinuous in the Z-domain.
Based on this finding, we propose a simple solution for accommodating the vehicle dynamics. The interpolated 3D Dubins curves are checked against the AUV dynamics constraint in the Z-domain and the ones satisfying the constraint are accepted to finalize the 3D Dubins curve selection. We call this rejection-acceptance method. Simulation results demonstrate that the integration of the 3D Dubins curve with the MTSP model is successful and effective for solving the 3D target assignment and path planning problem.

2. Problem Statement

Consider multiple AUVs constituting a collaborative team and performing the mission of tracking multiple underwater targets in a 3D underwater environment, as shown in Figure 1. Assume a set of static targets T = { T 1 , T 2 , , T N } and a set of homogeneous mobile AUVs A = { A 1 , A 2 , , A K } that are randomly deployed in the X × Y × Z three dimensional underwater space, with N and K denoting the total numbers of static targets and mobile AUVs, respectively. Also assume K < N , as this is commonly encountered in many practical applications. Each AUV has the same initial energy E i n i t and the same energy consumption model which is a linear function of its tour length. In order to illustrate design detailed methodology of proposed algorithm, we summarize the simplified notation in Table 1 for the reader’s convenience.
The objective of task assignment and path planning is to assign a tour sequence of targets D k , k = 1 , 2 , , K from the target set T to each AUV such that each target is visited by an AUV once and only once, and the total cost of visiting all targets is minimized.
Let N k and L k denote the number of targets and tour length of sequence D k , respectively. The tour cost of tour sequence D k is denoted as C ( D k ) , and the task assignment and path planning problem is to minimize
C T o t a l = k = 1 K C ( D k )
subject to
T = k = 1 K D k
D k D l = , k , l and k l
Var ( N k ) 0
Var ( L k ) 0
where Equations (4) and (5) are the Tour Hop Balance (THB) constraint and the Tour Length Balance (TLB) constraint, respectively, and Var ( · ) denotes the intra-AUV variance which is calculated in the following section, → means as small as possible. For example, N k = N K , k if N is divisible by K.

2.1. Vehicle Kinematic Constraints

An AUV belongs to a body-fixed coordinate system with six degrees of freedom, and so its motion can be described relative to an inertial-fixed reference frame. However, we only consider the position value and motion heading of an AUV in this paper since it is enough for path planning with Z-axis linear interpolation method. The location and motion of an AUV in three-dimensional Cartesian space are shown in Figure 2, where the position of the AUV is denoted as X = { x , y , z } , and its motion heading is denoted as Φ = { ϕ , θ } , where θ and ϕ are the X-Y plane angle and Z-axis angle projected from the AUV’s motion heading, respectively. The velocity scalar of the AUV is denoted as F, and the projected X-Y plane angle and Z-axis angle are bounded, making its motion nonholonomic constraints [8] such that
x ˙ = F cos θ cos ϕ y ˙ = F cos θ sin ϕ z ˙ = F sin θ
where the dot operator is the derivative, and
ϕ ˙ = ξ , ξ ω 1 , ω 1
θ ˙ = Θ , Θ ω 2 , ω 2
where ω 1 and ω 2 represent the curvature bounds. The nonholonomic constraints requires that the AUV paths satisfy the G 0 and G 1 continuities [24,25] which are defined as follows:
G 0 continuity: P ( u ) = [ x ( u ) , y ( u ) , z ( u ) ] and Q ( w ) = [ x ( w ) , y ( w ) , z ( w ) ] be two regular parametric 3D curves in the X × Y × Z space, where u [ 0 , 1 ] and w [ 0 , 1 ] are the parameters with 0 and 1 denoting the starting and ending points, respectively. If P ( 1 ) = Q ( 0 ) = J , then the two parametric curves meet at joint J with G 0 continuity.
G 1 continuity: If P ˙ ( u ) | u = 1 = Q ˙ ( w ) | w = 0 , then the two parametric curves meet at joint J with G 1 continuity.

2.2. The 2D Dubins Curve

For 2D path planning kinematic constraints, a classical path model is to use the 2D Dubins curve [6,7] to satisfy the G 1 continuity. Given any two points in the X × Y plane, starting at x 0 = ( x 0 , y 0 ) and ending at x 1 = ( x 1 , y 1 ) , the Dubins curves satisfy the dynamic constraints expressed in Equations (6) and (7) by a combination of maximum curvature arcs (C) and/or a straight line segment (S) to form two families of curves: family CCC and family CSC. Note that all arcs are with radius ρ . The family CCC contains curves with types R L R and L R L , where R and L denote a right turn arc (or clockwise) and a left turn arc (counter clock), respectively; The family CSC includes four types: R S R , L S L , R S L , and L S R , where S is a straight line segment. Therefore, the shortest Dubins path between two points are selected from the six types = { L S L , R S R , R S L , L S R , R L R , L R L } . For example, Figure 3 shows the four CSC types of Dubins curves with ϕ 0 = π / 4 and ϕ 1 = 3 π / 4 and two points ( 0 , 0 ) and ( 0 , d ) . Note that ϕ 0 and ϕ 1 are measured counter-clockwise with respect to the positive x-axis. It is obvious that the Type 1 Dubins curve has the shortest length.
The 2D Dubins curves have been well investigated in the literature. It has been shown [7] that for the long path case where the distance between the starting point and ending point, denoted as d and normalized by the turning radius ρ , satisfies d > 4 ( | cos ϕ 0 | + | cos ϕ 1 | ) 2 + | sin ϕ 0 | + | sin ϕ 1 | , the shortest path cannot be in the CCC family. The shortest paths with given ϕ 0 and ϕ 1 can be easily determined by the quadrants that the two angles fall in Ref. [7]. The elements of the 4 × 4 matrix, a i , j , represents the quadrant number i of the starting angle and the quadrant number j of the ending angle. The shortest 2D Dubins curves starting from ( 0 , 0 ) and ending at ( d , 0 ) are then determined by Table 2, where the different types in Table 2 are determined by certain switching functions defined in [7].
The exact path and its length can be calculated by the three operators, L γ for left turn, R γ for right turn, and S γ for straight, which transform an arbitrary point [ x , ϕ ] into its corresponding image point
L γ ( x , ϕ ) = [ ( x + sin ( ϕ + γ ) sin ϕ , y cos ( ϕ + γ ) + cos ϕ ) , ϕ + γ ] R γ ( x , ϕ ) = [ ( x sin ( ϕ γ ) + sin ϕ , y + cos ( ϕ γ ) cos ϕ ) , ϕ γ ] S γ = [ ( x + γ cos ϕ , y + γ sin ϕ ) , ϕ ]
where x = ( x , y ) , and the index γ means that the path segment is of length γ . For example, the L S R path with respective lengths of t , p , q between point [ ( 0 , 0 ) , ϕ 0 ] and [ ( d , 0 ) , ϕ 1 ] is solved by
R q ( S p ( L t ( [ ( 0 , 0 ) , ϕ 0 ] ) ) ) = [ ( d , 0 ) , ϕ 1 ]
or
p cos ( ϕ 0 + t ) + 2 sin ( ϕ 0 + t ) sin ϕ 0 sin ϕ 1 = d , p sin ( ϕ 0 + t ) 2 cos ( ϕ 0 + t ) cos ϕ 0 cos ϕ 1 = 0 , ϕ 0 + t q = ϕ 1 { mod 2 π }
The solution is denoted t L S R , p L S R , and q L S R , respectively. The total path length is then L L S R = t L S R + p L S R + q L S R = ϕ 1 ϕ 2 + 2 t L S R + p L S R . Details of other types of paths can be found in [7].

2.3. The Multiple Traveling Salesmen Problem for Dubins Vehicle

Multi-vehicle path planning is often casted as a Multiple Traveling Salesmen Problem (MTSP) [15] which is to find a set of closed paths for multiple traveling salesmen to visit a set of cities such that each and every city is visited exactly once and the total cost of visiting all cities are minimized. In the AUV path planning problem, the cost is the sum of Euclidean distances along the paths. It is difficult to find the optimal solution to the MTSP and heuristic iterative algorithms, such as the Genetic Algorithm (GA), Reactive Tabu Search, and Clustering and Actioning [8] are often used. In this work, we use the GA algorithm [15].
The MTSP is first converted into an equivalent mixed integer programming (MIP) problem [15] by introducing a binary selection variable I i , j k { 0 , 1 } defined as the indicator for the kth iteration of GA algorithm. If I i , j k = 1 , then the AUV A k is assigned to travel from target T i to target T j . Otherwise, if I i , j k = 0 , then AUV A k is assigned not to visit targets T i and T j . Given an undirected graph G = ( T , E ) , where T is the set of static targets (nodes), E = { ( i , j ) , i , j T } is the set of edges, and  i , j = 0 , 1 , , N with i = 0 and j = 0 denoting the home node or the starting/returning location of the AUVs. A cost matrix C = { c i , j } is defined on edges ( i , j ) associated with E . The MIP optimization is to
minimize i = 0 N j = 0 N k = 1 K c i , j I i , j k
subject to
j = 1 N k = 1 K I 1 , j k = K ,
i = 1 N k = 1 K I i , 1 k = K ,
j = 0 N k = 1 K I i , j k = 1 , i = 2 , 3 , , N .
i = 0 N k = 1 K I i , j k = 1 , j = 2 , 3 , , N .
i j c i , j I i , j k S , k = 1 , 2 , , K .
The constraints (13) and (14) ensure that the K salesmen start from the home node and return to the home node. Constraints (15) and (16) ensure that each node is visited (entered and left) only once. The constraint (17) is to ensure that the cost of each AUV is capped at S. Note that the constraints in (4) and (5) are used as the stop criterion.
The GA algorithm solves the MTSP by treating all possible tour sequences as the population, a specific tour sequence as an individual, the nodes in a tour sequence as a chromosome, and the travel length of a tour sequence as the fitness function. The GA algorithm starts with a random population with M individuals, and calculates the fitness function for each of the M individuals; then it creates new population by parent selection, parent crossover, chromosome mutation, and descendant acceptance; A new population results from replacing individuals by descendants with better fitness. Next the generated new population is used in the next iteration that iterates through the new population generation process, until the stop condition is satisfied. The solution to the MTSP is the set of selection variables I i , j k . The tour sequence for the kth AUV is the set of edges selected by the GA algorithm with I i , j k = 1 . That is
D k = { ( i , j ) | I i , j k = 1 } { T n } , k = 1 , , K .
Note that the AUV dynamics and G 1 continuity constraints have to be considered when applying the MTSP model to AUVs target assignment and path planning. Using Dubins curves, the MTSP model can be applied to solve the Dubins target assignment and path planning problem in three steps:
  • Step 1 uses the Euclidean distances between the nodes as the cost c i , j and assigns the N targets to the K AUVs through the GA algorithm.
  • Step 2 converts the tour sequence of each AUV into the Dubins paths by selecting a set of headings at each node and computing the lengths of Dubins curves;
  • Step 3 chooses the Dubins path and its associated headings with the shortest total distance.
The headings of the AUVs are discretized to 2 B angles such that ϕ 0 , ϕ 1 , θ 0 and θ 1 take values at π b / 2 B with b = 1 , , 2 B + 1 1 and excluding multiples of π / 2 . The discretization can greatly reduce the computational complexity in searching for the shortest Dubins path. The total length of a tour sequence is then calculated as
C ( D k ) = L ( [ X N k , Φ N k ] ; [ X 0 , Φ 0 ] ) + m = 0 N k 1 L ( [ X m , Φ m ] ; [ X m + 1 , Φ m + 1 ] )
for k = 1 , , K , and the total cost of all AUVs is computed as in (1).
In comparison, an existing method called the Alternating Algorithm [23] also uses the first approach that solves the Euclidean MTSP then maps the tour sequences to Dubins path. However, to reduce the computational complexity of the Dubins search, only odd-indexed edges in the tour sequence are replaced by minimum length Dubins paths, the even-indexed edges keep the straight Euclidean path.

3. Target Assignment and Path Planning in 3D Space

This section extends the target assignment and path planning algorithms from 2D to 3D by incorporating the 3D Dubins curves. We use the first approach in which the GA algorithm solves the Euclidean MTSP for the multiple targets and multiple AUVs, then maps the Dubins curves in 3D. We follow the simple linear interpolation method in [13,14] and analyze the G 1 continuity of the resulting 3D Dubins paths.

3.1. The 3D Dubins Curves and Their Path Lengths

To extend the 2D Dubins curves to 3D space using the linear interpolation method, the 3D tour sequences are first projected on to the 2D X × Y plane in a global coordinate system. Taking a starting point [ X 0 , Φ 0 ] and an ending point [ X 1 , Φ 1 ] in the 3D space and project them on to the 2D plane, as shown in Figure 4. Then the starting and ending points become 2D parameters [ ( x 0 , y 0 ) , ϕ 0 ] and [ ( x 1 , y 1 ) , ϕ 1 ] . The 2D Dubins curve is designed as described in Section 2.2, and the lengths of the arcs and line segment are calculated by (10). Let L 0 , x and L 0 , 1 denote the lengths along the 2D Dubins curve from ( x 0 , y 0 ) to ( x , y ) and from ( x , y ) to ( x 1 , y 1 ) , respectively.
The linear interpolation adds the z coordinate by
z = z 0 + L 0 , x L 0 , 1 ( z 1 z 0 )
where z 0 and z 1 are the Z coordinates of the starting and ending points. The resulting 3D Dubins curve is illustrated in Figure 4a.
The length of the interpolated 3D Dubins curve is calculated as
L 3 D = t 2 + ( z 0 z m ) 2 + p 2 + ( z m z n ) 2 + q 2 + ( z n z 1 ) 2
where t , p , and q are the CSC segment lengths of the 2D Dubins curve, and z m and z n are the Z coordinates of the segment joints which are linearly interpolated as
z m = z 0 + t t + p + q ( z 1 z 0 ) ,
z n = z 0 + t + p t + p + q ( z 1 z 0 ) = z 1 q t + p + q ( z 1 z 0 ) .
Equation (21) is easily derived from Figure 5, since for the straight segment, the sides with length p , p , and z m z n form a right triangle. Thus, p = p 2 + ( z m z n ) 2 . For the left turn segment (the ending segment in this example), q = q 2 + ( z 1 z n ) 2 if the cylinder containing the arc segments q and q is opened and laid flat, thus the segments q , q and z m z 1 form a right triangle. Similar to the left turn segment, the right turn segment satisfies t = t 2 + ( z m z 0 ) 2 . As a result, the total length of the 3D Dubins curve is L 3 D = t + p + q .
Next, we show that the shortest 2D Dubins curve results in the shortest 3D Dubins curve and present the proof in Theorem 1. We also analyze the G 1 continuity of the interpolated 3D Dubins curves and present the results in Theorem 2.
Theorem 1.
The shortest 2D Dubins curve corresponds to the shortest 3D Dubins curve if linear interpolation is used to generate the Z coordinates.
Proof. 
Let L 2 D = t + p + q be the length of the 2D Dubins curve. Substituting (22) into (21) yields
L 3 D = t 1 + ( z 1 z 0 ) 2 L 2 D 2 + p 1 + ( z 1 z 0 ) 2 L 2 D 2 + q 1 + ( z 1 z 0 ) 2 L 2 D 2 = ( t + p + q ) × 1 + ( z 1 z 0 ) 2 L 2 D 2 = L 2 D 2 + ( z 1 z 0 ) 2 L 2 D + | z 1 z 0 |
Therefore, the shortest length L 2 D of 2D Dubins curve leads to the shortest 3D Dubins curve. ☐
Theorem 2.
The 3D Dubins curves generated by linear interpolation of Z coordinates from the 2D Dubins curve can preserve G 1 continuity in the X Y plane but would lose the G 1 continuity in Z.
Proof. 
As shown in Figure 4, the 2D Dubins curve between a starting and an ending target is composed of three segments: arc, line, and arc, which joint at two joints. These three segments meet at the joints with G 1 continuity because the line segment designed by (10) ensures the G 1 continuity of each Dubins curve on the X Y plane. When the tour sequence contains multiple targets, the two Dubins curves meet at one target location, and the G 1 continuity can be preserved by forcing the end heading ϕ 1 of the first Dubins curve equal to the start heading ϕ 0 of the second Durbins curve.
However, in the Z domain, the linear interpolation among three or more targets cannot guarantee the G 1 continuity at the joints. For example, let targets 1, 2, and 3 be linked by two line segments. The end of the first line segment joins the start of the second line segment. when the two line segments are not aligned, the start heading θ 0 of the second line segment (in Z domain) is not equal to the end heading θ 1 of the first line segment. Therefore, the two line segments meet at the joint without G 1 continuity. For a particular example: z i 1 = 10 , z i = 15 , z i + 1 = 10 , so the AUV will have to increase its height from X ( i 1 ) to X ( i ) , and it must decrease its height from X ( i ) to X ( i + 1 ) . If the AUV has an initial upward heading angle ϕ i 1 because z i z i 1 = 5 , then it might turn to a downward heading ϕ i at X ( i ) because z i + 1 z i = 5 . Therefore, the AUV will have to change its heading angle Φ = ( ϕ , θ ) suddenly before traveling down to z i + 1 = 10 . ☐

3.2. Path Planning for Multiple AUVs in 3D Space

This section describes the detailed solution to the multiple targets tracking task assignment problem in three dimensional underwater workspace with constraints of Tour Hop Balance (THB) or Tour Length Balance (TLB). The three step approach in Section 2.3 is used, where step 1 applies the multiple traveling salesman problem (MTSP) algorithm with Euclidean distances as the fitness function.
fitness = 1 k L e ( X D k )
To incorporate the Tour Hop Balance (THB) or Tour Length Balance (TLB) constraints into the Genetic Algorithm, the variances of N k and L k are estimated as
σ ^ N k = 1 K 1 k = 1 K ( N k μ ^ ( N k ) ) 2
σ ^ L k = 1 K 1 k = 1 K ( L k μ ^ ( L k ) ) 2
where μ ^ ( N k ) and μ ^ ( L k ) are the estimated expectations of N k and L k , respectively. These variances are used by the GA as the termination rule. The resulting algorithms are called the THB-3Dubins-MTSP algorithm and TLB-3Dubins-MTSP algorithm, respectively. The outputs of the GA algorithms are a set of tour sequences for all AUVs.
Then step 2 maps the direct paths in a tour sequence into 2D Dubins curves, which is accomplished by projecting the 3D target locations onto the X Y plane and design 2D Dubins curves. Since different headings on the 2D plane can result in different solutions, the curves include all possible starting ϕ 0 and ending ϕ 1 for all target pairs. The shortest 2D path is selected by computing the total distances and selecting the smallest one.
The last step converts the 2D Dubins path into 3D curves by linear interpolation of the Z coordinates at each target pair. Then the headings θ 0 and θ 1 are calculated. Since linear interpolation loses the G 1 continuity, the difference between θ 0 and θ 1 at each joint J of the 3D Dubins path is computed as Θ ( J ) = θ 1 ( J ) θ 0 ( J ) . The results Θ ( J ) for all J are compared against the bound ω 2 . If any joint of the Dubins path has a Θ ( J ) > ω 2 , then the 3D Dubins path is rejected, and another 2D Dubins path, computed in Step 2, has to be used to be interpolated to the 3D Dubins curve. The process is repeated until the 3D Dubins path satisfies the vehicle dynamics constraint. This method is called rejection-acceptance method.
In summary, the pseudo-code of the proposed algorithms is described in Algorithm 1. For all we know, there are a small collision probabilities when multiple robots cruising in the same 3D underwater space. Two and more than two AUVs will be collided when multiple AUVs are arriving at the same coordinates at the same time. However, we run simulations of MTSP for collision check and find the collision between AUVs is negligible since the quantity of AUVs is small because of its high cost. Moreover, another sub-optimal paths can be generated with GA if there is a collision.
Algorithm 1 The pseudo-code of the proposed algorithms
Input:
Set of static targets T ;
Set of mobile AUVs A ;
Total number of static targets N;
Total number of mobile AUVs K;
Output:
Tour sequence for the kth AUV: D k , k = 1 , 2 , , K ;
Tour trajectory for the kth AUV: S k , k = 1 , 2 , , K ;
1:Initialization: n = 1 ;
2:while ( n N ) do
3: if(THB-3Dubins-MTSP)
4:  # GA based MTSP calculation
5:  # Break when reaching THB constraint;
6: else if (TLB-3Dubins-MTSP)
7:  #GA based MTSP calculation
8:  Break when reaching TLB constraint;
9: end if
10: n : = n + 1 ;
11:end while
12:Initialization: k = 1 , S k : = ;
13:while ( k K ) do
14: Initialization: v = 0 ;
15:while ( v < N k ) do
16:  # 3D Dubins curve plotting
17:   S k : = [ S k , 3 D _ Dubins ( T v , T v + 1 ) ] ;
18:   v : = v + 1 ;
19:end while
20: S k : = [ S k , 3 D _ Dubins ( T N k , T 0 ) ] ;
21: k : = k + 1 ;
22:end while
23:return S k , for k = 1 , 2 , , K

4. Simulation Results

Simulations were set up with multiple underwater targets deployed randomly in a cube of 20 × 20 × 10 units, where 1 unit is the minimum turning radius ρ of each AUV. For example, the turning radius of Iver2 AUV used in [8] is set to 5 m, so the proposed unit equals to 5 m. The number of targets varied from 10 to 50 in increments of 5, and the number of AUVs varied between 2 and 5. For the sake of simplicity, we choose the typical azimuth headings set for AUV movement as ϕ i j { b π 4 } with b = 1 , 3 , 5 , 7 . The proposed algorithm was implemented in Matlab and was developed on an Intel 2.5GHz i5-3210M CPU with 4GB RAM and running Windows 7. The computing time of the proposed algorithm with different targets number and AUV number are compared in Figure 6. The parameters for the GA is listed in Table 3.
Figure 7 illustrates 3D Dubins based MTSP trajectories of 2 or 4 AUVs generated by 3Dubins-MTSP algorithm. The x-axis and y-axis coordinates with their differential values are compared in Figure 8. In comparison, the 3D Alternating Algorithm (AA-3DTSP) extended the 2D Alternating Algorithm [23] by assigning Z-coordinates with linear interpolation and the resulting path is shown in Figure 9. A DTSP tour in (AA-3DTSP) can be constructed by retaining all odd-numbered edges (except the n-th), and replacing all even-numbered edges with minimum-length Dubins’ paths preserving the point ordering. In Figure 9, the Green curves denote odd-numbered edges, and the Blue curves denote even-numbered edges. It is clear non-smooth trajectories fail to G 1 continuity in either the XY plane nor the z-axis, as shown in Figure 10. Comparing Figure 10 to Figure 8, it is evident that cruise trajectories derived from our algorithm are G 1 continuous, however, cruise trajectories derived from Alternating Algorithm are only G 0 continuous because the tangent angle of each point on the path is not continuous. Therefore, 3D Alternating Algorithm (AA-3DTSP) is not appropriate for nonholonomic AUV and so it is excluded in the following simulations.
Next, we demonstrate the effectiveness of the THB-3Dubins-MTSP algorithm and TLB-3Dubins-MTSP constraints in comparison with the TSP without constraints and the Random Tour (RT) Algorithm. The Random Tour (RT) algorithm uses a set of random headings to achieve cruise paths without any constraints. The 3D Dubins based TSP (3Dubins-TSP) algorithm use only one AUV to trace all targets while cruising along 3D Dubins curves. Performance metrics include energy consumption, energy balance rate, cruise speed, and task life cycle. Energy consumption denotes the total energy consumption of all AUVs in the mission of tracking all targets, which is measured by the total tour length with assumption that each AUV consumes one unit energy at each unit tour length. Energy balance rate denotes with RMS (root mean square) value of energy consumption of each AUV, which is defined as Equation (28). Cruise speed is defined the maximal tour length of the AUV team in one cruise process, which denotes that the maximal time needed to finish one cruise for all targets. Task life cycle denotes the repeated number of each cruise mission, and it equals to the round number when one of AUV exhausts its energy. In this paper, it is assumed that the mobile AUV will carry out targets detection mission iteratively, and cruise lifetime is measured as the number of targets detection mission.
R M S = k = 1 K ( C ( D k ) C ( D k ) ¯ ) 2 K
For a given number of targets, we simulated 100 Monte Carlo trails and computed the average length of 3D tours generated by different algorithms. The standard deviation value is relatively small since the proposed algorithms can achieve progressive optimization using a large number of iterations of GA. The comparison results of energy consumption, energy balance, cruise speed and task life cycle are shown in Figure 11, Figure 12, Figure 13 and Figure 14, respectively.
Figure 11 shows that our proposed algorithms consume almost the same energy comparing to Random Tour algorithm, but they are much lower than 3Dubins-TSP algorithm. Figure 12 shows the improvements of energy balance ratio, there is at most 50% improvement with Random Tour algorithm on the RMS metric. Figure 13 shows the cruise speed comparisons of different mechanism, we find the cruise distance (e.g., the maximal cruise time) will decrease with the proposed algorithms clearly, and it is even obvious with more AUVs. Figure 14 shows the task life cycle comparisons, it is obvious the lifetime can be extended with our proposed algorithms, especially with more targets in the underwater region. In summary, the proposed THB-3Dubins-MTSP and TLB-3Dubins-MTSP algorithms will improve performances such as energy balance ratio, cruise speed and task life cycle comparing to Random Tour (RT) algorithm greatly, thus verify that the proposed algorithms can achieve better performance with G 1 continuous constraints. Moreover, the proposed THB-3Dubins-MTSP and TLB-3Dubins-MTSP algorithms have similar performances.

5. Conclusions and Future Work

This paper has studied the 3D Dubins curves for target assignment and path planning for multiple underwater targets visited by multiple AUVs. The MTSP for 3D path planning is solved by using the inverse of the Euclidean distances as the fitness function and the Tour Hop Balance (THB) and Tour Length Balance (TLB) constraints as the stop criterion. The resulting target assignment (tour sequence) is then projected onto the 2D X Y planes and 2D Dubins curves are designed with a set of possible headings and with nonholonomic motion constraints. The resulting 2D Dubins curves are interpolated linearly to obtain the Z-coordinates of each 2D curve. We derived the path length calculation for 3D Dubins curves and analyzed the G 1 continuity of the 3D Dubins curve. It is demonstrated that the linear interpolation fails to achieve G 1 continuity in the Z coordinate, and other smooth interpolation may have to be used when the continuity is required. Moreover, we find there are small collision probabilities between AUVs from above analysis. Therefore, in our future work, we will study how to avoid multiple underwater obstacles and inter-AUV collision for path planning of multi-AUV team.

Acknowledgments

The research work of Wenyu Cai was partially supported by the Natural Science Foundation of Zhejiang Province (No.LY16F030004, No.LY15F030018 and Y18F030025) and National Natural Science Foundation of China (No.6170060208). The work of Y.R. Zheng was support in part by the National Science Foundation of the USA under grant #ECCS1408316.

Author Contributions

Wenyu CAI proposed the main idea, Wenyu CAI and Meiyan Zhang generated the simulation results and drafted the manuscript. Yahong Rosa Zheng supervised the research work and refined the manuscript. They also responded the reviewers’ comments.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Hollinger, G.A.; Choudhary, S.; Qarabaqi, P.; Murphy, C.; Mitra, U.; Sukhatme, G.S.; Stojanovic, M.; Singh, H.; Hover, F. Underwater Data Collection Using Robotic Sensor Networks. IEEE J. Sel. Areas Commun. 2012, 30, 899–911. [Google Scholar] [CrossRef]
  2. Liu, L.; Liu, Y. On Exploring Data Forwarding Problem in Opportunistic Underwater Sensor Network Using Mobility-Irregular Vehicles. IEEE Trans. Veh. Technol. 2015, 64, 4712–4727. [Google Scholar] [CrossRef]
  3. Smith, R.N.; Huynh, V.T. Controlling Buoyancy-Driven Profiling Floats for Applications in Ocean Observation. IEEE J. Ocean. Eng. 2014, 39, 571–586. [Google Scholar] [CrossRef]
  4. Barsky, B.A.; DeRose, T.D. Geometric continuity of parametric curves: Three equivalent characterizations. IEEE Comput. Graph. Appl. 1989, 9, 60–69. [Google Scholar] [CrossRef]
  5. Elbanhawi, M.; Simic, M.; Jazar, R. The Role of Path Continuity in Lateral Vehicle Control. Elsevier Procedia Comput. Sci. 2015, 60, 1289–1298. [Google Scholar] [CrossRef]
  6. Dubins, L.E. On curves of minimal length with a constraint on average curvature, and with prescribed initial and terminal positions and tangents. Am. J. Math. 1957, 79, 497–516. [Google Scholar] [CrossRef]
  7. Shkel, A.M.; Lumelsky, V. Classification of the Dubins set. Elsevier Robot. Auton. Syst. 2001, 34, 179–202. [Google Scholar] [CrossRef]
  8. Chow, B.; Clerk, C.M.; Huisson, J.P. Assigning Closely-Spaced Task Points to Multiple Autonomous Underwater Vehicles. J. Ocean Technol. 2011, 6, 179–202. [Google Scholar]
  9. Soulignac, M. Feasible and Optimal Path Planning in Strong Current Fields. IEEE Trans. Robot. 2011, 27, 89–98. [Google Scholar] [CrossRef]
  10. Zhu, D.Q.; Yan, M.Z. Survey on technology of mobile robot path planning. Control Decis. 2010, 25, 961–967. [Google Scholar]
  11. Zhu, D.; Sun, B.; Li, L. Algorithm for AUV’s 3-D path planning and safe obstacle avoidance based on biological inspired model. Control Decis. 2015, 30, 798–806. (In Chinese) [Google Scholar]
  12. Cao, J.; Cao, J.; Zeng, Z.; Lian, L. Optimal path planning of underwater glider in 3D Dubins motion with minimal energy consumption. In Proceedings of the MTS/IEEE OCEANS 2016, Shanghai, China, 10–13 April 2016; pp. 1–7. [Google Scholar]
  13. Cao, X.; Zhu, D.; Yang, S.X. Multi-AUV Target Search Based on Bioinspired Neurodynamics Model in 3-D Underwater Environments. IEEE Trans. Neural Netw. Learn. Syst. 2016, 27, 2364–2374. [Google Scholar] [CrossRef] [PubMed]
  14. Lin, Y.; Saripalli, S. Path planning using 3D Dubins Curve for Unmanned Aerial Vehicles. In Proceedings of the 2014 International Conference on Unmanned Aircraft Systems (ICUAS), Orlando, FL, USA, 27–30 May 2014; pp. 296–304. [Google Scholar]
  15. Király, A.; Abonyi, J. Optimization of multiple traveling salesmen problem by a novel representation based genetic algorithm. In Intelligent Computational Optimization in Engineering; Springer: Berlin/Heidelberg, Germany, 2011; pp. 241–269. [Google Scholar]
  16. Yuan, S.; Skinner, B.; Huang, S.; Liu, D. A new crossover approach for solving the multiple travelling salesmen problem using genetic algorithms. Eur. J. Oper. Res. 2013, 228, 72–82. [Google Scholar] [CrossRef]
  17. Garau, B.; Alvarez, A.; Oliver, G. Path Planning of Autonomous Underwater Vehicles in Current Fields with Complex Spatial Variability: An A* Approach. In Proceedings of the 2005 IEEE International Conference on Robotics and Automation, Shatin, China, 18–22 April 2005; pp. 194–198. [Google Scholar]
  18. Sun, B.; Zhu, D. Three dimensional D*Lite path planning for Autonomous Underwater Vehicle under partly unknown environment. In Proceedings of the 2016 12th World Congress on Intelligent Control and Automation (WCICA), Guilin, China, 12–15 June 2016; pp. 3248–3252. [Google Scholar]
  19. Alvarez, A.; Caiti, A.; Onken, R. Evolutionary path planning for autonomous underwater vehicles in a variable ocean. IEEE J. Ocean. Eng. 2004, 29, 418–429. [Google Scholar] [CrossRef]
  20. Petres, C.; Pailhas, Y.; Patron, P.; Petillot, Y.; Evans, J.; Lane, D. Path Planning for Autonomous Underwater Vehicles. IEEE Trans. Robot. 2007, 23, 331–341. [Google Scholar] [CrossRef]
  21. Zhu, A.; Yang, S.X. An improved SOM-based approach to dynamic task assignment of multi-robots. In Proceedings of the 8th World Congress on Intelligent Control and Automation (WCICA), Jinan, China, 7–9 July 2010; pp. 2168–2173. [Google Scholar]
  22. Huang, H.; Zhu, D.; Ding, F. Dynamic task assignment and path planning for multi-AUV system in variable ocean current environment. J. Intell. Robot. Syst. 2014, 74, 999–1012. [Google Scholar] [CrossRef]
  23. Savla, K.; Frazzoli, E.; Bullo, F. Traveling salesperson problems for the Dubins vehicle. IEEE Trans. Autom. Control 2008, 53, 1378–1391. [Google Scholar] [CrossRef]
  24. Yang, K.; Sukkarieh, S. An Analytical Continuous-Curvature Path-Smoothing Algorithm. IEEE Trans. Robot. 2010, 26, 561–568. [Google Scholar] [CrossRef]
  25. Barsky, B.A.; DeRose, T.D. Geometric continuity of parametric curves: Constructions of geometrically continuous splines. IEEE Comput. Graph. Appl. 1990, 10, 60–68. [Google Scholar] [CrossRef]
Figure 1. Targets tracking with multiple AUVs.
Figure 1. Targets tracking with multiple AUVs.
Sensors 17 01607 g001
Figure 2. AUV and its motion heading in 3D Cartesian space.
Figure 2. AUV and its motion heading in 3D Cartesian space.
Sensors 17 01607 g002
Figure 3. Four CSC types of 2D Dubins curves with ϕ 0 = π / 4 and ϕ 1 = 3 π / 4 .
Figure 3. Four CSC types of 2D Dubins curves with ϕ 0 = π / 4 and ϕ 1 = 3 π / 4 .
Sensors 17 01607 g003
Figure 4. The RSL example of 2D and 3D Dubins curves. (a) 3D coordinates and its interpolated 3D Dubins curve; (b) 2D Dubins curve.
Figure 4. The RSL example of 2D and 3D Dubins curves. (a) 3D coordinates and its interpolated 3D Dubins curve; (b) 2D Dubins curve.
Sensors 17 01607 g004
Figure 5. 3D cylindrical spiral model.
Figure 5. 3D cylindrical spiral model.
Sensors 17 01607 g005
Figure 6. Computing time comparison.
Figure 6. Computing time comparison.
Sensors 17 01607 g006
Figure 7. 3D Dubins curves based targets tracking task assignment with 20 targets. Color online. (a) 3D Dubins curves with two AUVs; (b) 3D Dubins curve with four AUVs; (c) 3D Dubins curces projected 2D plane with two AUVs; (d) 3D Dubins curves projected 2D plane with four AUVs.
Figure 7. 3D Dubins curves based targets tracking task assignment with 20 targets. Color online. (a) 3D Dubins curves with two AUVs; (b) 3D Dubins curve with four AUVs; (c) 3D Dubins curces projected 2D plane with two AUVs; (d) 3D Dubins curves projected 2D plane with four AUVs.
Sensors 17 01607 g007
Figure 8. G 1 continuity of the 3D Dubins paths generated by the proposed algorithm. (a) in the X Y plane; (b) in the Z axis.
Figure 8. G 1 continuity of the 3D Dubins paths generated by the proposed algorithm. (a) in the X Y plane; (b) in the Z axis.
Sensors 17 01607 g008
Figure 9. The 3D Alternating Algorithm (AA-3DTSP) with one AUV. (a) with 10 targets; (b) with 20 targets.
Figure 9. The 3D Alternating Algorithm (AA-3DTSP) with one AUV. (a) with 10 targets; (b) with 20 targets.
Sensors 17 01607 g009
Figure 10. G 0 continuity in the X Y coordinates for the AA-3DTSP algorithm. The Z-axis continuity is similar to that in Figure 8b.
Figure 10. G 0 continuity in the X Y coordinates for the AA-3DTSP algorithm. The Z-axis continuity is similar to that in Figure 8b.
Sensors 17 01607 g010
Figure 11. Energy consumption comparisons. (a) 2 AUVs; (b) 4 AUVs.
Figure 11. Energy consumption comparisons. (a) 2 AUVs; (b) 4 AUVs.
Sensors 17 01607 g011
Figure 12. Energy balance comparisons. (a) 2 AUVs; (b) 4 AUVs.
Figure 12. Energy balance comparisons. (a) 2 AUVs; (b) 4 AUVs.
Sensors 17 01607 g012
Figure 13. Cruise speed comparisons. (a) 2 AUVs; (b) 4 AUVs.
Figure 13. Cruise speed comparisons. (a) 2 AUVs; (b) 4 AUVs.
Sensors 17 01607 g013
Figure 14. Task life cycle comparisons. (a) 2 AUVs; (b) 4 AUVs.
Figure 14. Task life cycle comparisons. (a) 2 AUVs; (b) 4 AUVs.
Sensors 17 01607 g014
Table 1. List of Notations.
Table 1. List of Notations.
NotationDefinition
T the set of static targets
A the set of mobile AUVs
T n the n-th static target
A k the k-th mobile AUV
Ntotal number of static targets
Ktotal number of mobile AUVs
D k tour sequence for the kth AUV, k = 1 , 2 , , K
S k tour trajectory for the kth AUV, k = 1 , 2 , , K
N k the number of targets in sequence D k
μ ( N k ) intra-AUV mean of the number of assigned targets
L k tour length of sequence D k
μ ( L k ) intra-AUV mean of the assigned tour lengths
x = ( x , y ) point coordinates in 2D plane
ϕ heading in 2D Dubins curve
L 2 D length of 2D Dubins curve
L ( [ x 0 , ϕ 0 ] ; [ x 1 , ϕ 1 ] ) length of 2D Dubins curve from point x 0 to point x 1
X = ( x , y , z ) point coordinates in 3D space
Φ = ( ϕ , θ ) azimuth and elevation headings of 3D Dubins curve
L 3 D length of 3D Dubins curve
L ( [ X 0 , Φ 0 ] ; [ X 1 , Φ 1 ] ) length of 3D Dubins curve from point X 0 to point X 1
Λ the set of possible headings in 2D plane
set of Dubins curves
t , p , q lengths of three segments of a Dubins curve
I n , k u binary indicator
Table 2. Decision table for shortest 2D Dubins curves based on the quadrant numbers of the starting and ending angles.
Table 2. Decision table for shortest 2D Dubins curves based on the quadrant numbers of the starting and ending angles.
a ij j = 1 j = 2 j = 3 j = 4
i = 1RSLRSR/RSLRSR/LSRLSR/RSL/RSR
i = 2LSL/RSLLSL/RSL/RSRRSRRSR/RSL
i = 3LSL/LSRLSLRSR/LSR/LSLRSR/LSR
i = 4RSL/LSR/LSLLSL/RSLLSL/LSRLSR
Table 3. The GA Parameters for the MTSP.
Table 3. The GA Parameters for the MTSP.
ParametersValues
Population Size80
Maximal Iterations5000
Mutation Ratio5%
Group Size5

Share and Cite

MDPI and ACS Style

Cai, W.; Zhang, M.; Zheng, Y.R. Task Assignment and Path Planning for Multiple Autonomous Underwater Vehicles Using 3D Dubins Curves . Sensors 2017, 17, 1607. https://doi.org/10.3390/s17071607

AMA Style

Cai W, Zhang M, Zheng YR. Task Assignment and Path Planning for Multiple Autonomous Underwater Vehicles Using 3D Dubins Curves . Sensors. 2017; 17(7):1607. https://doi.org/10.3390/s17071607

Chicago/Turabian Style

Cai, Wenyu, Meiyan Zhang, and Yahong Rosa Zheng. 2017. "Task Assignment and Path Planning for Multiple Autonomous Underwater Vehicles Using 3D Dubins Curves " Sensors 17, no. 7: 1607. https://doi.org/10.3390/s17071607

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop