Next Article in Journal
Determination of Turning Radius and Lateral Acceleration of Vehicle by GNSS/INS Sensor
Next Article in Special Issue
RAUM-VO: Rotational Adjusted Unsupervised Monocular Visual Odometry
Previous Article in Journal
Combating Single-Frequency Jamming through a Multi-Frequency, Multi-Constellation Software Receiver: A Case Study for Maritime Navigation in the Gulf of Finland
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Fast Multi-UAV Path Planning for Optimal Area Coverage in Aerial Sensing Applications

by
Marco Andrés Luna
1,2,†,
Mohammad Sadeq Ale Isaac
1,2,†,
Ahmed Refaat Ragab
2,3,4,†,
Pascual Campoy
1,*,
Pablo Flores Peña
2 and
Martin Molina
5
1
Computer Vision and Aerial Robotics Group, Centre for Automation and Robotics, Universidad Politécnica de Madrid, 28040 Madrid, Spain
2
Drone-Hopper Company, 28919 Leganés, Spain
3
Network Department, Faculty of Information Systems and Computer Science, October 6 University, Giza 12511, Egypt
4
Department of Electrical Engineering, University Carlos III of Madrid, 28919 Leganés, Spain
5
Department of Artificial Intelligence, Universidad Politécnica de Madrid, 28040 Madrid, Spain
*
Author to whom correspondence should be addressed.
These authors contributed equally to this work.
Sensors 2022, 22(6), 2297; https://doi.org/10.3390/s22062297
Submission received: 16 February 2022 / Revised: 8 March 2022 / Accepted: 11 March 2022 / Published: 16 March 2022
(This article belongs to the Special Issue Aerial Robotics: Navigation and Path Planning)

Abstract

:
This paper deals with the problems and the solutions of fast coverage path planning (CPP) for multiple UAVs. Through this research, the problem is solved and analyzed with both a software framework and algorithm. The implemented algorithm generates a back-and-forth path based on the onboard sensor footprint. In addition, three methods are proposed for the individual path assignment: simple bin packing trajectory planner (SIMPLE-BINPAT); bin packing trajectory planner (BINPAT); and Powell optimized bin packing trajectory planner (POWELL-BINPAT). The three methods use heuristic algorithms, linear sum assignment, and minimization techniques to optimize the planning task. Furthermore, this approach is implemented with applicable software to be easily used by first responders such as police and firefighters. In addition, simulation and real-world experiments were performed using UAVs with RGB and thermal cameras. The results show that POWELL-BINPAT generates optimal UAV paths to complete the entire mission in minimum time. Furthermore, the computation time for the trajectory generation task decreases compared to other techniques in the literature. This research is part of a real project funded by the H2020 FASTER Project, with grant ID: 833507.

1. Introduction

Nowadays, the research and development of unmanned aerial vehicles (UAVs) and unmanned aerial systems (UASs) are constantly growing due to their notable characteristics, low cost, ability to integrate payload, and autonomous navigation. These features have made UAVs a powerful system used in civilian and military applications. In addition, multiple professional solutions are offered by single-UAV systems [1], and swarms and multi-agent techniques are a line of research that is increasingly gaining the interest of researchers in the last decade due to its high performance in terms of time efficiency, flexibility, and fault tolerance [2].
In contrast, current multi-UAV systems present several challenges in their control layers, communications, decision-making capacities, and practical applications, including those for whom the human operator closes the control loop [3]. In summary, multiple approaches study the dynamics and behavior of each entity inside the swarm, the communication with other entities, and the intelligence of the swarm. Additionally, other external factors were considered during the design stages, including legal restrictions and the complexity of the piloting, or safety problems [4]. As such, the system’s complexity tends to increase proportionally to many entities. Based on this, different methods in the state of the art address the trajectory planning problem for multiple UAVs based on GNNS navigation [5,6] and multi-UAV task allocation [7,8]. In this context, multi-agent coverage path planning (CPP) is a subfield of trajectory planning where the algorithms have to find the optimal paths of UAVs equipped with sensors of a limited footprint to cover the free workspace [9] and the optimal path allocation for each UAV. This technique is applicable for tasks such as inspection [10], precision agriculture[11,12], search and rescue [13], remote sensing [14], and others.
Through several researchers’ works, it was found that multiple approaches deal with the problem of CPP for UAVs in different ways, as stated in [15], where the authors distinguished between no decomposition, exact, and approximate cellular decomposition techniques. For the first method, a defined area is split into sub-areas to determine the optimal route that establishes the connection between them. Another example, in [16], the authors divided the free workspace into cells and took the center of each cell as a waypoint within a graph; they found the resulting path by graph optimization. In addition, the methods represented in [17,18] proposed an exact cellular decomposition method dividing the area into convex subregions and determining the optimal path based on the number of UAV turns. On the other hand, no decomposition methods consider the entire area for planning and include works such as [19] which proposed an energy-efficiency spiral pattern for CPP or [20] that applied the back-and-forth strategy.
In the multi-UAV system, the aforementioned techniques are applied with the additional challenge of task allocation. Some approaches such as [11,21] apply exact cellular decomposition methods; in the first case, the authors use auction-based algorithms to assign tasks and in the other, with a leader–follower approach. Proposals as in [22,23] address the problem using grid pattern map decomposition and linear programming methods to solve the graph generated by the possible trajectories and the agents. Others such as [24] use a column generation model to perform the coverage mission with multiple UAVs using energy constraints; only numerical simulations were collected in the results. More similarly to our work, in the proposal presented by [25], the authors divided the coverage area between the agents based on their single relative capabilities and used the back-and-forth path planning method to cover each partition; moreover, in [26], the authors performed the same path planning technique for the total area, generating a graph with the possible routes for each fixed-wing UAV; this graph has multiple constraints to optimize the flight time and ensure the safety of the agents; the solution is found with the graph optimization using the mixed integer linear programming method (MILP). In this context, the algorithm in [27] presents a similar approach for multirotor UAVs, changing the constraints and the optimization method to optimize the computation time.
The present proposal was developed within the H2020 project FASTER (First Responder Advanced Technologies for Safe and Efficient Emergency Response)  [28]; in which the company Drone Hopper must provide a fleet of UAVs to be used by first responders (FR) to perform multiple tasks such as mapping, monitoring, surveillance, or search and rescue. This framework proposes a new multi-UAV coverage path planning technique based on the heuristics of a bin packing problem combined with optimization methods to generate the individual routes for each UAV that minimizes the mission time. Due to its simplicity, this algorithm consumes less computational resources when compared with other proposals in the literature. Furthermore, it is defined in the system architecture, communications, hardware, and user interface for a real-time operation, considering the FR’s requirements.
The paper is structured as follows: Section 2 describes the problem definition statement; then, in the Methodology in Section 3, the system architecture, the algorithms for the multi-UAV CPP, and the software implementation are presented. The results and discussion for the simulation and real-flight operations are then shown in Section 4. Finally, in Section 5, the conclusions and future work are stated.

2. Problem Definition

Through this research, it is assumed that there is a group of k heterogeneous multirotor UAVs at the same altitude covering a polygonal convex area in the I R 2 space defined by a set of points P; all UAVs are supposed to take off at the same time from different positions. The sensor footprint is the main feature to be considered in the parameter setting of any mission, as shown in Figure 1.
To have similar measurements inside the scanned polygonal area, all UAVs must reach the same altitude and the space between lanes must be constant. However, these parameters can be configurable without affecting the system’s performance.
Additionally, to prevent collisions, each UAV will be assigned a different altitude to take off, navigate to the mission start point, and return to launch (RTL), as shown in Figure 2.
For this reason, the problem cannot be solved by dividing the area by the number of UAVs due to two main factors: the distance of each UAV from the starting point of the mission and the assigned altitude. As an additional safety constraint, the paths of each UAV will be continuous without interruptions between them. Additionally, each aircraft is equipped with the same onboard sensors (RGB or thermal cameras pointing down). Furthermore, the system interface will be user-friendly to allow the operator to connect the ground control station (GCS) to the group of UAVs, select the P points to cover a convex area in a given satellite map, and then launch the flight operation. Finally, the algorithms must optimize the calculation time to operate in emergency scenarios.
With these requirements, the main challenge is to develop a system to determine the paths for each UAV to cover the defined area and define its architecture to complete the mission in the minimum amount of time. In the following sections, the solutions proposed to deal with these problems are described.

3. Methodology

3.1. Architecture Proposal

A centralized architecture is proposed, where the central node assigns the task to each agent. In this case, the GCS computer performs all the calculations and uploads the waypoints to each UAV. For this, the robotic operating system (ROS) [29] framework and MAVROS package [30] are used. The system architecture is presented in Figure 3.
As clarified in Figure 3, each UAV has an onboard computer ( O B P C n ) to send and receive data from the flight control unit ( F C U n ) through serial communication (for hardware details, see Section 3.4). The onboard computer captures the FCU and video cameras ( v i d e o n ) and sends them to the GCS. The communications between the GCS and the UAVs OB-PC in the UAVs are performed using the standard IEEE 802.11ax (commonly known as WiFi 6). During the operation, the GCS obtains the input area from the user and calculates the optimal set of waypoints for each UAV. The waypoints are sent to each OB-PC using the ROS framework, which decodes the information for the FCU.

3.2. Multi-UAV CPP Algorithm

3.2.1. Area Decomposition

Based on previous works in the literature [26,27], it is clear that they used the back-and-forth strategy shown in [31] for the area decomposition. This method establishes the first step to find the optimal coverage direction. The authors in [31] proposed that this direction must be perpendicular to the shortest height of the polygon to obtain the smaller number of curves optimizing the rows number; additional parameters as spacing and row distances are calculated based on camera footprint [32]. In this context, given the field of view θ , the aspect ratio r, and the flight altitude h; the sides A F and B F of the footprint could be calculated through the following equations:
A F = 2 · h · tan ( θ / 2 ) 1 + r 2
B F = 2 · r · h · tan ( θ / 2 ) 1 + r 2
Unlike the aforementioned approaches that generate waypoints to cover the rows of the path, the newly implemented algorithm in this research will obtain waypoints generated for the entire route (similar to cell decomposition methods) to optimize the distribution of tasks between the agents, as shown in Figure 4.
Figure 4 was generated using open source Matplotlib libraries [33] and shows a comparison of the generated waypoints to be used in the algorithms presented in [26,27] and the one implemented through the present work. The reason for the difference is simple: while the calculation time in graph optimization algorithms increases exponentially with each added waypoint, in other heuristic methods, such as that presented in Section 3.2.2, the processing time is slightly affected. In addition to this, spacing and row distance are placed considering the desired overlapping; nevertheless, multiple GCS software as QGroundControl [34] allows the user to set them manually; however, it is not the aim of this study to determine their optimal values.

3.2.2. Multi-UAV Routing

Given the set of waypoints of the previous Section 3.2.1, it is proposed that the bin packing trajectory planner (BINPAT) is a routing strategy. This algorithm has two stages, respectively, track packing and task assignment. Assuming a constant average velocity for each UAV, the mission time for k UAVs can be modeled as
T k = i = 1 N j = 1 N D i j V i j k M i j k + H d k
where:
H d k = h m k + Δ h k V a k + h m k + Δ h k V d k
same as
H d k = ( h m k + Δ h k ) ( V a k + V d k ) V a k · V d k
Through Equation (3), D i j represents the distance cost of flying between two nodes and V i j k represents the UAV flight speed. The binary variable M i j defines whether the k t h UAV travels from point i to j; at this point, operational constraints proposed in Section 2 determine that all paths will be continuous. Finally, H d (Equations (4) and (5)) is the delay caused by the altitude assignment and will depend on the mission altitude ( h m ), ascent velocity ( V a ), descent velocity ( V d ), and the difference between assigned and mission altitudes ( Δ h k ). Consequently, the total mission time is the maximum k t h UAV mission time. With these considerations, the optimization will be performed by minimizing the maximum I R 2 distance-based mission cost, that is:
C k = i j D i j M i j k + H d k
Based on this, the algorithm for the BINPAT is presented in Algorithm 1.
Algorithm 1: BINPAT Algorithm
Sensors 22 02297 i001
    In Algorithm 1, the inputs are given by the set of points (P), the UAV weighted parameters (W), UAV locations (L), the camera footprint parameters (F), and the mission altitude ( M h ). The UAV weighted parameters vector represents weighted features that can influence the mission performance; these weights are the same when having a homogeneous multirotor. In addition, the outputs are the individual cost vector C and the three-dimensional matrix W P T with the set of 2D waypoints for each UAV. In the first stage of the algorithm, the set of waypoints is obtained using the back-and-forth ( B a c k & F o r t h ) technique (Section 3.2.1); then, the waypoints are separated into individual paths and each path distance is computed. During the track packing step, the result of the custom bin-packing algorithm (Algorithm 2) is the set of individual waypoints, where D is the distance that a UAV has to navigate based on its initial weight and M represents the traveling condition (if a track is assigned to a UAV or not). For the task assignment stage, the asset cost matrix ( A P ) is obtained through the modification on the Jonker–Volgenant method for a linear sum assignment problem [35,36]. After that, the altitude assignment matrix ( H k ) is obtained proportionally to the first cost matrix ( C ), i.e., UAVs with higher mission costs will be assigned lower takeoff altitudes. Then, the resultant cost vector (C) is calculated, adding the individual altitude delay cost ( H d k ) to the first cost matrix; finally, from A P and W p t S e t , it is calculated as W P T .
Furthermore, Algorithm 2 is an analogy to the bin-packing problem, in which a set of tracks (items) must be assigned to a set of UAVs (bins). In this case, the capacity of each UAV W k is the weighting of the total cost of the mission determined by the vector of weights W. Starting from mentioned values, tracks are iteratively assigned to each UAV until their maximum capacity is completed. As such, adding a new track to the UAV should not exceed its maximum capacity or improve the result of not adding it. As a result, the mission distance and the indices of the tracks to be traveled by each UAV are calculated.
Algorithm 2: CBinPack Algorithm
Sensors 22 02297 i002

3.2.3. Routing Optimization

Although the BINPAT algorithm can represent an optimal implementation result for specific UAVs (see Section 4), there may be cases where using fewer UAVs optimizes the mission time. BINPAT could not determine it since it will try to assign the entire mission to the set of available UAVs (especially for the case of homogeneous UAVs). For this reason, a new variation called Powell optimal BINPAT (POWELL-BINPAT) was implemented to solve the optimal assignment problem. In Section 3.2.2, one of the inputs of the BINPAT algorithm was a set of initial UAV weights W k , and the output was the individual set of waypoints and the individual mission cost whereby the optimal mission cost will be found by minimizing the maximum individual cost (Equation (7)):
min ( max C k )
For this reason, the objective of this step was to find the best set of weights W k for M given UAVs that produce the optimal cost subject to Equation (8):
0 W k 1 , k M
Dealing with W k as the input and the result of the BINPAT algorithm C k from Equation (6), an iterative process is used to enhance the minimum cost of the mission, and this is achieved using the Powell optimization method [37,38] using as main parameters Equations (7) and (8), respectively. Powell’s technique finds the best solution by performing one-dimensional minimizations along each vector of the directions in the N-dimensional set of solutions.

3.3. Software Implementation

The novel swarm application is implemented in both the virtual and real world, wherein the former, all the algorithms are interpreted in C++ and Python codes and then compiled in the Debian space, connected to a Qt visual application, as shown in Figure 5, to be easily modifiable, interacting the generated data using ROS bridge platform, as displayed in Figure 6, and finally, simulated inside the Gazebo area to check whether the swarm drones display any incoherent action. This subsection extensively addresses the schematic of accomplished work through simulation.
The graphical user interface (GUI) environment designed in this research is based on Qt C++ language, interacting with the ROS workspace to regulate the swarm algorithms and communicate with the drones. Accordingly, Figure 5 shows the main elements of the GCS SW divided into four main sections, connection, streaming tabs, flight instruments, and the map widget. The GUI imports all the generated drones’ data, including drone ID, position, attitude angles, velocities, and their battery information transformed to corresponding *.json files, as shown in Figure 5, and according to the user-chosen waypoints, a mainframe area for the swarm is created to be exported as *.json, *.yaml, and *.wp formats to be further utilized by the main algorithms to generate the interpolate and extrapolate points close to the frame. Optimizing calculated routes, the best route (considering the equal distance and flight time, the one that performs the fewest deviations is the most optimized method) will be the candidate to pass the ROS bridge and be subscribed by the simulation application. Furthermore, Figure 5 demonstrates a sample swarm mission in a stream, starting in the upper-left part, where three connected drones are displayed and then the PUBLISH ON COP button starts advertising the online location of the drones and sends the data to the ROS workspace. While the upper-middle section relates to the swarm parameters, Swarm Lines Distance determines the gap between each line of the mission in meters, while Swarm Altitude defines the flight altitude of all drones during the mission (more information is given in Section 2). In addition, setting the swarm parameters, creating a set of waypoints on the map, and then saving the green button exports them through the algorithms. On the upper-right corner of Figure 5, however, all information received from the connected drones is monitored and each drone could be directly armed or be returned to the landing point near the Home location by using ARM and RTL buttons, respectively; moreover, the three flight instruments show the necessary information of the flight regarding each connected drone. Additionally, the middle blue windows contain the number of waypoints chosen by the user and their relative distances to the Home, the right part demonstrates that all waypoints after that are produced by the swarm algorithms and imported in the application. Eventually, the map section shows the online location of the drones and the generated waypoints. Mainly, since all the path planning and optimization codes are compatible with ROS workspace, they are modulated with ROS launchers to rapidly change the main variables, which adds *.yaml formats and contains the addresses and properties of the connected drones which accelerate the running of the whole application. Furthermore, the SW is enriched with several *.qml codes to enhance the map view of the mission area to make it as realistic as feasible to choose waypoints, view determined routes, and have an online drones view. Further SW details are collected in Table 1.
As mentioned in Table 1, four programming languages are utilized to ensure each part of the SW performs optimally; for instance, there are myriad types of primary flight displays (PFDs) that visualize the actual state of the drone inside the SW; however, a great number of PFDs decelerate the system because of the large volume of code compiling behind. Here, nonetheless, a pre-designed Qt-based collection, QFlightInstruments: http://marekcel.pl/qflightinstruments (accessed on 10 March 2022) [39] is employed that loads dramatically quickly (with 200 Hz frequency) and demonstrates images with a high resolution using image coding (H.264). Through Figure 6, a complete schematic diagram for the swarm mission procedure is implemented, showing the online hybrid map used in the GUI, the communication of the GCS, and the swarm drones through an ROS interaction that concludes in generating the swarm waypoints to output the mission.
The communication status of the drones can be checked at any time before starting the mission using return-value ssh; then, connected ones start publishing the data on the Kafka server confined by a local network to advertise the flight data for the GCS and other drones. Definitely, the distance between the swarm lines and the number of surrounding mission lines is configurable before starting the mission. Meanwhile, the movement trace of the drones and the streaming lines are demonstrated on the hybrid map area.

3.4. Hardware Implementation

To conduct practical missions, a set of system configurations is chosen to function optimally; meanwhile, the GUI application supports monitoring up to eight drones simultaneously. Clearly, each drone is equipped with an onboard computer to function as a slave system for the ground master computer, communicating through an ROS network connection. Furthermore, the unmanned aerial system (UAS) employed a robust wireless dual-band connection lay on a TP-link 4G+ Cat6 AC1200 Wireless Dual Band Gigabit Router which is then enhanced by connecting to the global network; i.e., establishing unique identification ports (IPs) for each drone to be in a local communication published on the global network. Moreover, the drone’s configuration is shown in Figure 7 where onboard PCs advertised ROS topics for the master and further listened through the GCS. In addition, a set of video streaming is configured using OpenCV libraries for flying drones in which the GUI software received a real video stream from each drone through the local network, as shown in Figure 3.
Ultimately, Figure 7 demonstrates the equipped equipment for the drones through the swarm mission where each drone is empowered by various components: a Pixhawk 2.1 CubePilot integrated with here3 GPS, a powerful onboard PC (Jetson Xavier Developer), which has an eight-core ARM processor based on a 64-bit CPU module, a ZED2 StereoLabs camera mounted below the Jetson Xavier, and a wireless ASUS Dual-Band (5 GHz/2.4 GHz) Wireless USB 3.0 Adapter communicating with the TP-link router. Overall, the system integration utilized through this project, according to several observations, aims to conquer multi-UAV path planning, communication problems, and internal uncertainties.

3.5. Transformation between Relative and Absolute Coordinates

To prevent unbiased errors through the transformation of coordinates from the SW, ROS bridge, and the drones, a common interpreted form is assumed, that is, relative coordination. As such, waypoints generated by the user are transformed from absolute location (latitude and longitude) to the relative distances from the pre-defined Home location and then exported to the ROS workspace, as shown in Equation (9). According to Haversine formula [40], which determines the orthodromic distances of two points on a sphere and considering the radius of the Earth (6371 km), Equation (9) could be driven as
Δ l a t = R A D ( l a t p l a t h ) Δ l n g = R A D ( l n g p l n g h ) d = sin ( 0.5 Δ l a t ) 2 + cos ( D 2 R ( l a t h ) ) cos ( D 2 R ( l a t p ) ) sin ( 0.5 Δ l n g ) 2 Relative Distance = 2 R arctan ( d , 1 d )
where h represents the Home location, p is the target waypoint; function R A D transforms an angle from degree to radian; and l a t and l n g represent the latitude and longitude of the waypoints, respectively. Using Equation (9) through the SW planning, all the location data are relative for both GUI and the swarm algorithms to be with the same scale.

4. Results and Discussion

4.1. Algorithm Validation

The algorithms described in the previous sections were implemented using Python libraries for validation. At the same time, numerical simulation was tested in multiple scenarios to evaluate different combinations before implementing the real flights. The main idea is to combine simple back-and-forth and sampled back-and-forth for area decomposition, as shown in Figure 4, with route generation algorithms (BINPAT and POWELL-BINPAT). In addition, three possible combinations are evaluated: BINPAT+simple back-and-forth (SIMPLE-BINPAT), BINPAT+ sampled back-and-forth, and POWELL-BINPAT + sampled back-and-forth. The distance-based cost results are represented in Table 2 with the graphical results shown in Figure 8.
According to Equation (7), the total cost of the mission will be the highest of the individual costs for each UAV. To clarify the results in Figure 8 and future figures, the navigation order of the routes is from the lowest to the highest index. Regarding Table 2 and Figure 8, it can be noticed that SIMPLE-BINPAT reports the greatest cost (963.81 m). In contrast, the sampled back-and-forth decomposition improves the performance, first for the BINPAT (928.75 m) and then for the POWELL-BINPAT (911.77 m). Additionally, as a result of the optimization, the POWELL-BINPAT reduces the standard deviation of the cost, meaning that each UAV consumes similar resources to perform the mission. Through the context, graphical comparisons with other proposals in the literature are represented, as shown in Figure 9.
In Figure 9, the results obtained with simple and sampled back-and-forth decomposition are compared with the graph optimization methods in the literature [26,27]. Although the constraints used for the optimization in these methods are different, the BINPAT algorithm with simple area decomposition generates similar trajectories compared to these proposals. Moreover, using the approaches with sampled area decomposition, these results are improved for our specific constraints. Furthermore, the processing time was evaluated in a computer with an AMD Ryzen 7 3750H processor and 16-GB RAM, as shown in Table 3.
Based on the results presented in Table 3, it can be noticed that BINPAT achieves acceptable results in computation time during the planning stage when it is compared with the other proposals for coverage routing that uses processors with similar features. For instance, in the case of three UAVs, BINPAT variations achieve between 0.0014 and 0.3 s; in contrast, the approach presented by [11] reported processing times between 0.15 and 0.31 s for three UAVs. Moreover, the algorithm presented in [26] achieves computation times from 0.8 to 4.59 seconds depending on the constraints; and through the work presented in [27], the authors stated a computation time of 0.8 seconds for three UAVs and 19 waypoints.
Finally, one of the main features of POWELL-BINPAT concerning BINPAT is its ability to decide the optimal number of UAVs needed to complete a mission in the shortest time. Through Figure 10 and Table 4, the optimum UAV assessment results and the comparison of the cost-based results as represented show the best results of planning a mission, in contrast to the work performed in [26,27].
Furthermore, by analyzing Table 4, it is clear that UAV1 generated unnecessary distance costs by climbing to the assigned altitude, reaching the first waypoint, and returning; these costs are optimized with the Powell method to obtain better results in only planning missions for UAV2 and UAV3.

4.2. Simulation Results

The presented approaches were tested in the open source Gazebo simulator [41] with PX4 software in the loop (SITL). Two simulation scenarios are considered: short-track scenario and long-track scenario, as shown in Figure 11.
The difference between these scenarios is the length of the lane; while on the short track, the maximum street length is approximately 150 m, on the long track, the maximum is approximately 320 m. Furthermore, the experiments were carried out with three and five UAVs. Multiple mission altitudes (from 35 to 55 m) and different lane widths (between 5 and 15 m) were tested. The main objective was to evaluate the influence of multiple parameters in the algorithm’s performance such as the number of UAVs, the altitude, and the lane features. As an additional detail, the cruise velocity of each UAV is considered 5 m/s, and the route was completed with a constant heading. The metrics used to evaluate the simulation results depend on the time that the UAVs take to accomplish a mission. They include the maximum time ( M a x ), the average time ( A v ), the standard deviation ( S D ), and the coefficient of variation ( C V ), as shown in Equation (10):
C V = S D A v 100
The tables with the time results of multiple experiments are presented in Appendix A. Time histograms for average UAV time results obtained from Table A1, Table A2, Table A3, Table A4, Table A5, Table A6, Table A7, Table A8, Table A9, Table A10, Table A11 and Table A12 are shown in Figure 12.
In Figure 12, POWELL-BINPAT achieves better results in the mission assignment task for three and five UAVs compared with the BINPAT and SIMPLE-BINPAT approaches. This fact can be noted by evaluating the coefficient of variation (CV) in each mission; in this context, the behavior of the coefficient of variation is shown in Figure 13.
In Figure 13, the CV indicates the uniformity in the distribution of the mission for each UAV. In general terms, the results obtained with the short-track scenario are lower compared with the values obtained for the long-track scenario. Moreover, the coefficient of variation is more sensitive to changes in the mission parameters and the number of UAVs in the SIMPLE-BINPAT method. Although the changes are milder in BINPAT; in POWELL-BINPAT, the values tend to be lower and more uniform in all cases. Finally, the average maximum time for each method is presented in Table 5.
In Table 5, SIMPLE-BINPAT has the lower maximum time in the short-track scenario; however, this is similar to the other approaches. The main differences can be noticed in the long-track scenario, where SIMPLE-BINPAT has a poor performance and POWELL-BINPAT is better than the other algorithms.

4.3. Real-Flight Test Results

The scenario for the real test results was similar to the short-track stated in Section 4.2. A picture of the pictures of the real implementation is shown in Figure 14 and the routes completed with the POWELL-BINPAT method obtained from the datalog are presented in Figure 15.
The altitude of the mission was 20 m and the space between lanes was 10 m; moreover, the cruise velocity was set to 5 m/s for each UAV.
Time results are presented in Table 6 and the time histograms are shown in Figure 16.
The implementation results show a behavior similar to the simulation in the Gazebo software. POWELL-BINPAT optimizes the total mission time by minimizing the difference in the individual flight time of each UAV. The real flight results are thus consistent with those obtained in multiple simulations.
Finally, an early implementation of BINPAT for two UAVs with simple area decomposition could be found at the Policía Municipal de Madrid: https://www.youtube.com/watch?v=m6CssNmgwH0 Youtube Channel (accessed on 10 March 2022).

5. Conclusions and Future Work

This paper presents a complete software framework, algorithms, and a special architecture for the practical implementation of area coverage missions for multiple UAVs. This system was generalized to be used with different sensors in function of the application, with the only possible variations being that of the sensor footprint (to calculate the lane width and waypoint separation).
The results of the validation tests show the performance of the algorithms in multiple hypothetical scenarios. The hypotheses are corroborated through the Gazebo simulator and during real-flight tests. The two main highlights of BINPAT and POWELL-BINPAT are the low computation time for multiple waypoint paths and the ability to optimize the mission times.
Additionally, dynamic re-planning tests are proposed; i.e., if one or more drones are lost during the mission, the system will detect the missing waypoints and reorganize all the routes for the available UAVs.
As confirmed, the success of the algorithms largely depends on the correct calculation of the cost matrices; in this case, it has been tested with routes generated in the 2D space at a constant altitude. For future development, various 2D approaches and 3D trajectories could be analyzed (containing altitude changes along the path).

Author Contributions

Conceptualization, M.A.L., M.S.A.I., A.R.R., P.C. and P.F.P.; data curation, M.A.L. and M.S.A.I.; formal analysis, M.A.L., M.S.A.I. and A.R.R.; funding acquisition, P.F.P.; investigation, M.A.L., M.S.A.I., A.R.R., P.C., P.F.P. and M.M.; methodology, M.A.L., M.S.A.I., A.R.R., P.C. and M.M.; project administration, P.C. and P.F.P.; resources, P.C. and P.F.P.; software, M.A.L. and M.S.A.I.; supervision, A.R.R., P.C., P.F.P. and M.M.; validation, M.A.L., M.S.A.I., A.R.R., P.C., P.F.P. and M.M.; visualization, M.A.L. and M.S.A.I.; writing—original draft, M.A.L., M.S.A.I. and A.R.R.; writing—review and editing, A.R.R., P.C. and M.M. All authors have read and agreed to the published version of the manuscript.

Funding

This research was supported by the European Commission-funded program FASTER, under H2020 Grant Agreement 833507 and partially funded by “Ayudas para la realización de Doctorados Industriales”, Community of Madrid REF: IND2020/IND-17478.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Not available.

Acknowledgments

We would thank the University of Carlos III, campus Leganes, Madrid, for performing laboratories and hangers through our research. Furthermore, last but not least, we thank our colleagues at Drone Hopper for their support during the project.

Conflicts of Interest

The authors declare no conflict of interest.

Abbreviations

The following abbreviations are used in this manuscript:
UAVUnmanned Aerial Vehicle
UASUnmanned Aerial System
H2020Horizon 2020
RTLReturn to Launch Point
GCSGround Control Station
GUIGraphical User Interface
BINPATBin Packing Trajectory Planner
CBinPackCustom Bin Packing Algorithm
POWELL-BINPATPowell Optimized Bin Packing Trajectory Planner
FCUFlight Control Unit
FRFirst Responder
FASTERFirst Responder Advanced Technologies for Safe and Efficient Emergency Response
PBDPower Distribution Board
ESCElectronic Speed Controllers
CPPCoverage Path Planning
GNSSGlobal Navigation Satellite System
IPInternet Protocol

Appendix A. Simulation Results

This appendix shows the mission time data in seconds of simulation tests that validate the algorithms for three and five UAVs. The performance was evaluated whilst the altitude and the lane distance of the mission were changing.

Appendix A.1. Time Results for Short-Track Scenario

Table A1. Time results using the SIMPLE-BINPAT algorithm and three UAVs in a short-track scenario.
Table A1. Time results using the SIMPLE-BINPAT algorithm and three UAVs in a short-track scenario.
SIMPLE-BINPAT
UAV1318.00330.00344.00266.00277.00287.00
UAV2331.00345.00356.00268.00280.00293.00
UAV3312.00326.00337.00226.00237.00248.00
Max331.00345.00356.00268.00280.00293.00
Av320.33333.67345.67253.33264.67276.00
SD9.7110.029.6123.6924.0124.43
CV3.113.072.8510.4810.139.85
Distance10.0010.0010.005.005.005.00
Altitude35.0045.0055.0035.0045.0055.00
Table A2. Time results using the BINPAT algorithm and three UAVs in a short-track scenario.
Table A2. Time results using the BINPAT algorithm and three UAVs in a short-track scenario.
BINPAT
UAV1214.00258.00280.00383.00385.00426.00
UAV2232.00294.00313.00396.00399.00412.00
UAV3244.00261.00272.00410.00411.00396.00
Max244.00294.00313.00410.00411.00426.00
Av230.00271.00288.33396.33398.33411.33
SD15.1019.9721.7313.5013.0115.01
CV6.197.657.993.293.173.79
Distance10.0010.0010.005.005.005.00
Altitude35.0045.0055.0035.0045.0055.00
Table A3. Time results using the POWELL-BINPAT algorithm and three UAVs in a short-track scenario.
Table A3. Time results using the POWELL-BINPAT algorithm and three UAVs in a short-track scenario.
POWELL-BINPAT
UAV1243.00262.00266.00397.00385.00401.00
UAV2258.00284.00286.00400.00413.00426.00
UAV3245.00280.00273.00373.00401.00412.00
Max258.00284.00286.00400.00413.00426.00
Av248.67275.33275.00390.00399.67413.00
SD8.1411.7210.1514.8014.0512.53
CV3.324.193.723.973.503.04
Distance10.0010.0010.005.005.005.00
Altitude35.0045.0055.0035.0045.0055.00
Table A4. Time results using the SIMPLE-BINPAT algorithm and five UAVs in a short-track scenario.
Table A4. Time results using the SIMPLE-BINPAT algorithm and five UAVs in a short-track scenario.
SIMPLE-BINPAT
UAV1225.00236.00249.00287.00302.00314.00
UAV2232.00247.00259.00283.00302.00308.00
UAV3249.00260.00271.00234.00246.00358.00
UAV4222.00233.00245.00259.00271.00284.00
UAV5222.00231.00245.00290.00304.00316.00
Max249.00260.00271.00290.00304.00358.00
Av230.00241.40253.80270.60285.00316.00
SD11.3812.1011.1923.8425.7726.72
CV4.955.014.418.819.048.46
Distance10.0010.0010.005.005.005.00
Altitude35.0045.0055.0035.0045.0055.00
Table A5. Time results using the BINPAT algorithm and five UAVs in a short-track scenario.
Table A5. Time results using the BINPAT algorithm and five UAVs in a short-track scenario.
BINPAT
UAV1237.00260.00258.00322.00335.00318.00
UAV2204.00231.00231.00319.00332.00350.00
UAV3210.00262.00260.00388.00298.00352.00
UAV4229.00233.00233.00380.00295.00312.00
UAV5244.00271.00269.00323.00336.00355.00
Max244.00271.00269.00388.00336.00355.00
Av224.80251.40250.20346.40319.20337.40
SD17.2218.2017.1434.4720.8020.63
CV7.667.246.859.956.526.12
Distance10.0010.0010.005.005.005.00
Altitude35.0045.0055.0035.0045.0055.00
Table A6. Time results using the POWELL-BINPAT algorithm and five UAVs in a short-track scenario.
Table A6. Time results using the POWELL-BINPAT algorithm and five UAVs in a short-track scenario.
POWELL-BINPAT
UAV1228.00254.00251.00289.00303.00311.00
UAV2213.00226.00239.00315.00324.00355.00
UAV3237.00242.00266.00304.00319.00329.00
UAV4240.00245.00266.00325.00338.00338.00
UAV5246.00257.00273.00327.00339.00351.00
Max246.00257.00273.00327.00339.00355.00
Av232.80244.80259.00312.00324.60336.80
SD12.8312.1913.7715.7814.8817.75
CV5.514.985.325.064.585.27
Distance10.0010.0010.005.005.005.00
Altitude35.0045.0055.0035.0045.0055.00

Appendix A.2. Time Results for Long-Track Scenario

Table A7. Time results using the SIMPLE-BINPAT algorithm and three UAVs in a long-track scenario.
Table A7. Time results using the SIMPLE-BINPAT algorithm and three UAVs in a long-track scenario.
SIMPLE-BINPAT
UAV1817.00870.00985.00606.00693.00680.00
UAV2834.00917.00856.00652.00843.00799.00
UAV3749.001225.001050.00567.00759.00832.00
Max834.001225.001050.00652.00843.00832.00
Av800.001004.00963.67608.33765.00770.33
SD44.98192.8398.7442.5575.1879.95
CV5.6219.2110.256.999.8310.38
Distance10.0010.0010.0015.0015.0015.00
Altitude35.0045.0055.0035.0045.0055.00
Table A8. Time results using the BINPAT algorithm and three UAVs in a long-track scenario.
Table A8. Time results using the BINPAT algorithm and three UAVs in a long-track scenario.
BINPAT
UAV1859.00889.00973.00676.00652.00745.00
UAV2891.00973.001010.00675.00714.00697.00
UAV3915.00986.00946.00696.00763.00633.00
Max915.00986.001010.00696.00763.00745.00
Av888.33949.33976.33682.33709.67691.67
SD28.1052.6532.1311.8555.6356.19
CV3.165.553.291.747.848.12
Distance10.0010.0010.0015.0015.0015.00
Altitude35.0045.0055.0035.0045.0055.00
Table A9. Time results using the POWELL-BINPAT algorithm and three UAVs in a long-track scenario.
Table A9. Time results using the POWELL-BINPAT algorithm and three UAVs in a long-track scenario.
BINPAT
UAV1855.00970.00967.00606.00629.00636.00
UAV2894.00938.00961.00671.00692.00700.00
UAV3898.00900.00999.00625.00643.00652.00
Max898.00970.00999.00671.00692.00700.00
Av882.33936.00975.67634.00654.67662.67
SD23.7635.0420.4333.4233.0833.31
CV2.693.742.095.275.055.03
Distance10.0010.0010.0015.0015.0015.00
Altitude35.0045.0055.0035.0045.0055.00
Table A10. Time results using the SIMPLE-BINPAT algorithm and five UAVs in a long-track scenario.
Table A10. Time results using the SIMPLE-BINPAT algorithm and five UAVs in a long-track scenario.
SIMPLE-BINPAT
UAV1579.00637.00682.00494.00653.00596.00
UAV2619.00678.00752.00510.00596.00618.00
UAV3583.00644.00686.00461.00542.00547.00
UAV4544.00588.00596.00562.00581.00683.00
UAV5685.00727.00801.00551.00639.00673.00
Max685.00727.00801.00562.00653.00683.00
Av602.00654.80703.40515.60602.20623.40
SD53.4651.5977.7541.4944.8556.19
CV8.887.8811.058.057.459.01
Distance10.0010.0010.0015.0015.0015.00
Altitude35.0045.0055.0035.0045.0055.00
Table A11. Time results using the BINPAT algorithm and five UAVs in a long-track scenario.
Table A11. Time results using the BINPAT algorithm and five UAVs in a long-track scenario.
BINPAT
UAV1614.00675.00737.00460.00525.00555.00
UAV2633.00698.00756.00514.00595.00629.00
UAV3577.00690.00698.00462.00549.00558.00
UAV4608.00683.00717.00430.00538.00522.00
UAV5672.00720.00806.00488.00576.00584.00
Max672.00720.00806.00514.00595.00629.00
Av620.80693.20742.80470.80556.60569.60
SD35.0017.2241.4631.7028.5239.84
CV5.642.485.586.735.126.99
Distance10.0010.0010.0015.0015.0015.00
Altitude35.0045.0055.0035.0045.0055.00
Table A12. Time results using the POWELL-BINPAT algorithm and five UAVs in a long-track scenario.
Table A12. Time results using the POWELL-BINPAT algorithm and five UAVs in a long-track scenario.
POWELL-BINPAT
UAV1560.00634.00675.00489.00556.00591.00
UAV2602.00654.00774.00531.00571.00619.00
UAV3614.00720.00704.00501.00528.00579.00
UAV4557.00659.00733.00502.00552.00592.00
UAV5645.00709.00789.00532.00582.00627.00
Max645.00720.00789.00532.00582.00627.00
Av595.60675.20735.00511.00557.80601.60
SD37.3437.2847.4419.4020.5220.39
CV6.275.526.453.803.683.39
Distance10.0010.0010.0015.0015.0015.00
Altitude35.0045.0055.0035.0045.0055.00

References

  1. Ragab, A.R.; Isaac, M.S.A.; Luna, M.A.; Flores Peña, P. WILD HOPPER Prototype for Forest Firefighting. Int. J. Online Biomed. Eng. 2021, 17, 148–168. [Google Scholar] [CrossRef]
  2. Chung, S.J.; Paranjape, A.A.; Dames, P.; Shen, S.; Kumar, V. A Survey on Aerial Swarm Robotics. IEEE Trans. Robot. 2018, 34, 837–855. [Google Scholar] [CrossRef] [Green Version]
  3. Zhou, Y.; Rao, B.; Wang, W. UAV Swarm Intelligence: Recent Advances and Future Trends. IEEE Access 2020, 8, 183856–183878. [Google Scholar] [CrossRef]
  4. Skorobogatov, G.; Barrado, C.; Salamí, E. Multiple UAV Systems: A Survey. Unmanned Syst. 2020, 8, 149–169. [Google Scholar] [CrossRef]
  5. Hedrick, G.; Ohi, N.; Gu, Y. Terrain-aware path planning and map update for mars sample return mission. IEEE Robot. Autom. Lett. 2020, 5, 5181–5188. [Google Scholar] [CrossRef]
  6. Madridano, A.; Al-Kaff, A.; Martín, D. Trajectory planning for multi-robot systems: Methods and applications. Expert Syst. Appl. 2021, 173, 114660. [Google Scholar] [CrossRef]
  7. Wu, H.; Li, H.; Xiao, R.; Liu, J. Modeling and simulation of dynamic ant colony’s labor division for task allocation of UAV swarm. Phys. Stat. Mech. Its Appl. 2018, 491, 127–141. [Google Scholar] [CrossRef]
  8. Luna, M.A.; Ragab, A.R.; Ale Isaac, M.S.; Flores Pena, P.; Campoy Cervera, P. A New Algorithm Using Hybrid UAV Swarm Control System for Firefighting Dynamical Task Allocation. In Proceedings of the 2021 IEEE International Conference on Systems, Man, and Cybernetics (SMC), Melbourne, Australia, 17–20 October 2021; pp. 655–660. [Google Scholar]
  9. Otto, A.; Agatz, N.; Campbell, J.; Golden, B.; Pesch, E. Optimization approaches for civil applications of unmanned aerial vehicles (UAVs) or aerial drones: A survey. Networks 2018, 72, 411–458. [Google Scholar] [CrossRef]
  10. Jing, W.; Deng, D.; Wu, Y.; Shimada, K. Multi-UAV Coverage Path Planning for the Inspection of Large and Complex Structures. In Proceedings of the 2020 IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS), Las Vegas, NV, USA, 24 October–24 January 2021; pp. 1480–1486. [Google Scholar]
  11. Barrientos, A.; Colorado, J.; Cerro, J.D.; Martinez, A.; Rossi, C.; Sanz, D.; Valente, J. Aerial remote sensing in agriculture: A practical approach to area coverage and path planning for fleets of mini aerial robots. J. Field Robot. 2011, 28, 667–689. [Google Scholar] [CrossRef] [Green Version]
  12. Lottes, P.; Khanna, R.; Pfeifer, J.; Siegwart, R.; Stachniss, C. UAV-based crop and weed classification for smart farming. In Proceedings of the 2017 IEEE International Conference on Robotics and Automation (ICRA), Singapore, 29 May–3 June 2017; pp. 3024–3031. [Google Scholar]
  13. Nattero, C.; Recchiuto, C.T.; Sgorbissa, A.; Wanderlingh, F. Coverage algorithms for search and rescue with uav drones. In Proceedings of the Workshop of the XIII AI*IA Symposium on Artificial Intelligence, Pisa, Italy, 10–12 December 2014; Volume 12. [Google Scholar]
  14. Balampanis, F.; Maza, I.; Ollero, A. Coastal areas division and coverage with multiple UAVs for remote sensing. Sensors 2017, 17, 808. [Google Scholar] [CrossRef] [Green Version]
  15. Cabreira, T.M.; Brisolara, L.B.; Ferreira, P.R., Jr. Survey on coverage path planning with unmanned aerial vehicles. Drones 2019, 3, 4. [Google Scholar] [CrossRef] [Green Version]
  16. Valente, J.; Sanz, D.; Del Cerro, J.; Barrientos, A.; de Frutos, M.A. Near-optimal coverage trajectories for image mosaicing using a mini quad-rotor over irregular-shaped fields. Prec. Agric. 2013, 14, 115–132. [Google Scholar] [CrossRef]
  17. Li, Y.; Chen, H.; Er, M.J.; Wang, X. Coverage path planning for UAVs based on enhanced exact cellular decomposition method. Mechatronics 2011, 21, 876–885. [Google Scholar] [CrossRef]
  18. Coombes, M.; Chen, W.H.; Liu, C. Boustrophedon coverage path planning for UAV aerial surveys in wind. In Proceedings of the International Conference on Unmanned Aircraft Systems (ICUAS), Miami, FL, USA, 13–16 June 2017; pp. 1563–1571. [Google Scholar]
  19. Cabreira, T.M.; Di Franco, C.; Ferreira, P.R.; Buttazzo, G.C. Energy-aware spiral coverage path planning for uav photogrammetric applications. IEEE Robot. Autom. Lett. 2018, 3, 3662–3668. [Google Scholar] [CrossRef]
  20. Di Franco, C.; Buttazzo, G. Coverage path planning for UAVs photogrammetry with energy and resolution constraints. J. Intell. Robot. Syst. 2016, 83, 445–462. [Google Scholar] [CrossRef]
  21. Muñoz, J.; López, B.; Quevedo, F.; Monje, C.A.; Garrido, S.; Moreno, L.E. Multi UAV Coverage Path Planning in Urban Environments. Sensors 2021, 21, 7365. [Google Scholar] [CrossRef] [PubMed]
  22. Nedjati, A.; Izbirak, G.; Vizvari, B.; Arkat, J. Complete coverage path planning for a multi-UAV response system in post-earthquake assessment. Robotics 2016, 5, 26. [Google Scholar] [CrossRef] [Green Version]
  23. Cho, S.W.; Park, H.J.; Lee, H.; Shim, D.H.; Kim, S.Y. Coverage path planning for multiple unmanned aerial vehicles in maritime search and rescue operations. Comput. Ind. Eng. 2021, 161, 107612. [Google Scholar] [CrossRef]
  24. Choi, Y.; Choi, Y.; Briceno, S.; Mavris, D.N. Energy-constrained multi-UAV coverage path planning for an aerial imagery mission using column generation. J. Intell. Robot. Syst. 2020, 97, 125–139. [Google Scholar] [CrossRef]
  25. Maza, I.; Ollero, A. Multiple UAV cooperative searching operation using polygon area decomposition and efficient coverage algorithms. In Distributed Autonomous Robotic Systems; Springer: Tokyo, Japan, 2007; Volume 6, pp. 221–230. [Google Scholar]
  26. Avellar, G.S.; Pereira, G.A.; Pimenta, L.C.; Iscold, P. Multi-UAV routing for area coverage and remote sensing with minimum time. Sensors 2015, 15, 27783–27803. [Google Scholar] [CrossRef] [Green Version]
  27. Hong, Y.; Jung, S.; Kim, S.; Cha, J. Autonomous Mission of Multi-UAV for Optimal Area Coverage. Sensors 2021, 21, 2482. [Google Scholar] [CrossRef] [PubMed]
  28. Dimou, A.; Kogias, D.G.; Trakadas, P.; Perossini, F.; Weller, M.; Balet, O.; Patriakakis, C.Z.; Zahariadis, T.; Daras, P. FASTER: First Responder Advanced Technologies for Safe and Efficient Emergency Response. Technol. Dev. Secur. Pract. 2021, 1, 447–460. [Google Scholar]
  29. Stanford Artificial Intelligence Laboratory. Robotic Operating System. 2018. Available online: https://www.ros.org (accessed on 12 January 2022).
  30. Ermakov, V. MAVROS. Available online: http://wiki.ros.org/mavros (accessed on 12 January 2022).
  31. Huang, W.H. Optimal line-sweep-based decompositions for coverage algorithms. In Proceedings of the 2001 ICRA, IEEE International Conference on Robotics and Automation (Cat. No. 01CH37164), Seoul, Korea, 21–26 May 2001; Volume 1, pp. 27–32. [Google Scholar]
  32. Barna, R.; Solymosi, K.; Stettner, E. Mathematical analysis of drone flight path. J. Agric. Inform. 2019, 10, 15–27. [Google Scholar] [CrossRef]
  33. Hunter, J.D. Matplotlib: A 2D graphics environment. IEEE Comput. Sci. Eng. 2007, 9, 90–95. [Google Scholar] [CrossRef]
  34. QGroundControl. Available online: http://qgroundcontrol.com/ (accessed on 12 January 2022).
  35. Jonker, R.; Volgenant, A. A shortest augmenting path algorithm for dense and sparse linear assignment problems. Computing 1987, 38, 325–340. [Google Scholar] [CrossRef]
  36. Crouse, D.F. On implementing 2D rectangular assignment algorithms. IEEE Trans. Aerosp. Electron. Syst. 2016, 52, 1679–1696. [Google Scholar] [CrossRef]
  37. Powell, M.J. An efficient method for finding the minimum of a function of several variables without calculating derivatives. Comput. J. 1964, 7, 155–162. [Google Scholar] [CrossRef]
  38. Virtanen, P.; Gommers, R.; Oliphant, T.E. SciPy 1.0 Fundamental Algorithms for Scientific Computing in Python. Nat. Methods 2020, 17, 261–272. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  39. Cel, M.; Dave, C. QFlightInstruments. Available online: http://marekcel.pl/?lang=en&page=qfi (accessed on 22 January 2022).
  40. Dauni, P.; Firdaus, M.D.; Asfariani, R.; Saputra, M.I.N.; Hidayat, A.A.; Zulfikar, W.B. Implementation of Haversine formula for school location tracking. J. Phys. Conf. Ser. 2019, 1402, 077028. [Google Scholar] [CrossRef]
  41. Koenig, N.; Howard, A. Design and use paradigms for gazebo, an open-source multi-robot simulator. In Proceedings of the 2004 IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS), Sendai, Japan, 28 September–2 October 2004; Volume 3, pp. 2149–2154. [Google Scholar]
Figure 1. Footprint schema in a homogeneous UAV fleet.
Figure 1. Footprint schema in a homogeneous UAV fleet.
Sensors 22 02297 g001
Figure 2. Mission operation schema. Each UAV takeoff at its assigned altitude, then performing the operation at mission altitude, and RTL at assigned altitude again.
Figure 2. Mission operation schema. Each UAV takeoff at its assigned altitude, then performing the operation at mission altitude, and RTL at assigned altitude again.
Sensors 22 02297 g002
Figure 3. Architecture proposal.
Figure 3. Architecture proposal.
Sensors 22 02297 g003
Figure 4. Waypoint generation results: (a) waypoints generated using simple back-and-forth algorithm; (b) waypoints generated with a sampled back-and-forth for our proposal.
Figure 4. Waypoint generation results: (a) waypoints generated using simple back-and-forth algorithm; (b) waypoints generated with a sampled back-and-forth for our proposal.
Sensors 22 02297 g004
Figure 5. A snapshot of the ground control station (GCS) SW used for the swarm project.
Figure 5. A snapshot of the ground control station (GCS) SW used for the swarm project.
Sensors 22 02297 g005
Figure 6. A diagram of the swarm mission procedure.
Figure 6. A diagram of the swarm mission procedure.
Sensors 22 02297 g006
Figure 7. The drone properties utilized through the swarm mission.
Figure 7. The drone properties utilized through the swarm mission.
Sensors 22 02297 g007
Figure 8. Multi-UAV algorithm results: (a) defined search area and UAV locations; (b) SIMPLE-BINPAT; (c) BINPAT; and (d) POWELL-BINPAT.
Figure 8. Multi-UAV algorithm results: (a) defined search area and UAV locations; (b) SIMPLE-BINPAT; (c) BINPAT; and (d) POWELL-BINPAT.
Sensors 22 02297 g008
Figure 9. Multi-UAV routing comparison results with 3 UAVs: (a) results obtained with graph optimization for fixed wings; and (b) results obtained with graph optimization for multirotors; (c,d) SIMPLE-BINPAT; (e,f) BINPAT; and (g,h) POWELL-BINPAT.
Figure 9. Multi-UAV routing comparison results with 3 UAVs: (a) results obtained with graph optimization for fixed wings; and (b) results obtained with graph optimization for multirotors; (c,d) SIMPLE-BINPAT; (e,f) BINPAT; and (g,h) POWELL-BINPAT.
Sensors 22 02297 g009
Figure 10. Optimal UAV assignment results with POWELL-BINPAT: (a) paths generated with BINPAT; and (b) paths generated with POWELL-BINPAT.
Figure 10. Optimal UAV assignment results with POWELL-BINPAT: (a) paths generated with BINPAT; and (b) paths generated with POWELL-BINPAT.
Sensors 22 02297 g010
Figure 11. Robotic simulation scenario: (a) short-tracks scenario; and (b) long-tracks scenario.
Figure 11. Robotic simulation scenario: (a) short-tracks scenario; and (b) long-tracks scenario.
Sensors 22 02297 g011
Figure 12. Time histograms for average results in simulation tests: (a) three UAVs’ time histogram; and (b) five UAVs’ time histogram.
Figure 12. Time histograms for average results in simulation tests: (a) three UAVs’ time histogram; and (b) five UAVs’ time histogram.
Sensors 22 02297 g012
Figure 13. CV behavior obtained from experiments reported in Appendix A: (a) short-track scenario results; and (b) long-track scenario results.
Figure 13. CV behavior obtained from experiments reported in Appendix A: (a) short-track scenario results; and (b) long-track scenario results.
Sensors 22 02297 g013
Figure 14. Pictures of the real implementation.
Figure 14. Pictures of the real implementation.
Sensors 22 02297 g014
Figure 15. UAV positions reported by datalog in 3 UAV flights using POWELL-BINPAT: (a) main view; and (b) side view.
Figure 15. UAV positions reported by datalog in 3 UAV flights using POWELL-BINPAT: (a) main view; and (b) side view.
Sensors 22 02297 g015
Figure 16. Time histogram for real flight with 3 UAVs.
Figure 16. Time histogram for real flight with 3 UAVs.
Sensors 22 02297 g016
Table 1. Full properties of the swarm GUI application.
Table 1. Full properties of the swarm GUI application.
Based LanguageRoleConfiguration
Qt  C++
  • Contains the main functions, including widgets, buttons, frames, tabs, spinners, and text boxes;
  • Connects the master computer to the drones as slaves, using ROS connection, utilizing *.bash script handlers;
  • Connects the main c++ file with previously generated files to moderate the swarm mission, linked to corresponding modifier buttons;
  • Creates submodules to interact with *.qml visualizers.
C++ 11
Compiler qmake 3.0
Qt Meta
Language (qml)
  • Contains visualizer objects, namely rectangles, circles, buttons, map-inputs, map quick items, map routes, map polygons, map poly-lines, map routes, list models, grids, and mouse functions;
  • Manages the waypoint and the markers;
  • Corresponding functions to save the user desired frame and view the calculated points;
  • Determines the relative distances of the chosen points and the defined home which affects all the swarm algorithms.
Qt Quick
JavaScript
Hyper Test
Markup Language
  • Includes all the instruments with a high frequency, 100 Hz to update the flight information, related to the position, attitude (Euler angles), airspeed, altitude, battery, etc.;
  • Streams the video of each drone during the flight, broadcasting through a local or global web address;
  • Designates an especial API key of the Bing Maps for the map space used in the application;
HTML
Brian Fox Unix
Shell (Bash)
  • Connects the drones to the GUI application via ssh connection and regulates the vulnerability when various drones are simultaneously connected;
  • Manages the camera function of any connected drones, interacting with OpenCV libraries and fswebcam capturing SW;
  • Launches or kills programs related to the swarm and optimization;
  • Reports the online connectivity state of any drones during the flight to facilitate the ROS bridge to advertise and subscribe the topics according to available vehicles.
Table 2. Distance-based cost results using the BINPAT and POWELL-BINPAT for simple and sampled area decomposition.
Table 2. Distance-based cost results using the BINPAT and POWELL-BINPAT for simple and sampled area decomposition.
Distance-Based Cost
UAVSimple Back-and-ForthSampled Back-and-Forth
SIMPLE-BINPATBINPATPOWELL-BINPAT
UAV 1963.81928.75908.75
UAV 2944.65900.34911.77
UAV 3644.58789.27904.72
SD179.0373.73.53
Table 3. Processing time results for a different UAV number.
Table 3. Processing time results for a different UAV number.
UAVsSIMPLE-BINPATBINPATPOWELL-BINPAT
20.0007480.00210.296894
30.0014740.0022440.301134
40.0015220.0027560.512768
50.0019610.0031251.419654
60.0034790.0033651.853162
70.0042750.0039241.96757
Table 4. Cost-based results comparison.
Table 4. Cost-based results comparison.
Distance-Based Cost Results
UAV NumberBINPATPOWELL-BINPAT
UAV1390.720
UAV2401.93370.73
UAV3394.62383.99
Table 5. Average maximum time for the simulation experiments.
Table 5. Average maximum time for the simulation experiments.
SIMULATION SCENARIO
Short TrackLong Track
SIMPLE-BINPAT 300.42795.58
BINPAT330.08754.25
POWEL-BINPAT322.00735.42
Table 6. Time results for a real flight with three UAVs.
Table 6. Time results for a real flight with three UAVs.
UAVMETHOD
SIMPLE-BINPATBINPATPOWELL-BINPAT
UAV1289.00279.00285.00
UAV2305.00298.00282.00
UAV3276.00268.00271.00
Max305.00298.00285.00
Av290.00281.67279.33
SD14.5315.187.37
CV5.015.392.64
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Luna, M.A.; Ale Isaac, M.S.; Ragab, A.R.; Campoy, P.; Flores Peña, P.; Molina, M. Fast Multi-UAV Path Planning for Optimal Area Coverage in Aerial Sensing Applications. Sensors 2022, 22, 2297. https://doi.org/10.3390/s22062297

AMA Style

Luna MA, Ale Isaac MS, Ragab AR, Campoy P, Flores Peña P, Molina M. Fast Multi-UAV Path Planning for Optimal Area Coverage in Aerial Sensing Applications. Sensors. 2022; 22(6):2297. https://doi.org/10.3390/s22062297

Chicago/Turabian Style

Luna, Marco Andrés, Mohammad Sadeq Ale Isaac, Ahmed Refaat Ragab, Pascual Campoy, Pablo Flores Peña, and Martin Molina. 2022. "Fast Multi-UAV Path Planning for Optimal Area Coverage in Aerial Sensing Applications" Sensors 22, no. 6: 2297. https://doi.org/10.3390/s22062297

APA Style

Luna, M. A., Ale Isaac, M. S., Ragab, A. R., Campoy, P., Flores Peña, P., & Molina, M. (2022). Fast Multi-UAV Path Planning for Optimal Area Coverage in Aerial Sensing Applications. Sensors, 22(6), 2297. https://doi.org/10.3390/s22062297

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