Abstract
Consider a disaster scenario where search and rescue workers must search difficult to access buildings during an earthquake or flood. Often, finding survivors a few hours sooner results in a dramatic increase in saved lives, suggesting the use of drones for expedient rescue operations. Entropy can be used to quantify the generation and resolution of uncertainty. When searching for targets, maximizing mutual information of future sensor observations will minimize expected target location uncertainty by minimizing the entropy of the future estimate. Motion planning for multi-target autonomous search requires planning over an area with an imperfect sensor and may require multiple passes, which is hindered by the submodularity property of mutual information. Further, mission duration constraints must be handled accordingly, requiring consideration of the vehicle’s dynamics to generate feasible trajectories and must plan trajectories spanning the entire mission duration, something which most information gathering algorithms are incapable of doing. If unanticipated changes occur in an uncertain environment, new plans must be generated quickly. In addition, planning multipass trajectories requires evaluating path dependent rewards, requiring planning in the space of all previously selected actions, compounding the problem. We present an anytime algorithm for autonomous multipass target search in natural environments. The algorithm is capable of generating long duration dynamically feasible multipass coverage plans that maximize mutual information using a variety of techniques such as -admissible heuristics to speed up the search. To the authors’ knowledge this is the first attempt at efficiently solving multipass target search problems of such long duration. The proposed algorithm is based on best first branch and bound and is benchmarked against state of the art algorithms adapted to the problem in natural Simplex environments, gathering the most information in the given search time.
Keywords: path planning, information gathering, branch and bound, target search, coverage planning
1. Introduction
Earthquakes and similar disasters in remote areas pose a challenge for relief efforts when the transportation infrastructure is damaged. Victims in such disasters have a greater chance of survival the sooner they are discovered; conducting an extensive search even just a few hours faster will save many more lives. Survival rates of earthquake victims continually drop significantly the longer the delay before rescue, with a sharp drop off at around 48 h [1,2]. In the 2013 earthquake that hit Lushan, China, Chinese researchers provided an autonomous rotary-wing UAV to assist search and rescue efforts [2]. Interest in using drones for search and rescue and assessing dangerous situations has also been increasing in local fire fighting departments [3].
Consider a scenario where an earthquake or flood causes a building to collapse, trapping survivors who are difficult to access by ground. It would be advantageous to have aerial vehicles autonomously fly at low altitudes navigating over rubble searching for survivors. However, such environments may be subject to change, requiring quick decision making while acting on a previously generated plan. There are several reasons why generating a multipass coverage plan is advantageous for target search. Scenarios involving noisy sensors or targets that appear or disappear over time require multiple passes to correctly determine whether or not a target is present. Further, given constraints in mission duration, the agent must be able to properly decide where to search, and for how long, before returning to base.
Mutual information [4] is an ideal metric to maximize for improving search. Mutual information measures the dependence of two random variables, such as a noisy sensor measurement in the future and the current best estimate of a target’s location. Picking a future sensor measurement that maximizes mutual information will effectively reduce the expected uncertainty of the target’s location [5]. Most importantly, assessing the mutual information of an action allows one to formally assess the trade-offs between searching a region multiple times or searching another region not searched, making it an ideal metric for multipass multi-target search [6]. The mutual information of conditionally independent events has been shown to be submodular [6], which implies that multiple correlated sensor measurements offer diminishing returns in how much information is gathered when summing the total information of each measurement individually. When trying to maximize the submodular reward function of mutual information, the reward is path dependent requiring one to plan in the space of trajectories (Section 3), making planning more computationally burdensome.
This presents several challenges to which we will outline our proposed solution. The algorithm must be able to react quickly to new information that can affect the search plan, suggesting an anytime formulation. An anytime algorithm is an algorithm that quickly finds a feasible solution, and continually improves the solution as available planning time permits. Greedy approaches to informative path planning that only consider all immediate actions are quick to react to changes in the environment, but may get trapped [7,8]. However, previous work has shown that for submodular optimization problems, greedy approaches can get to within a constant factor of the optimal solution [6,9]. Similarly, model predictive control based techniques can look multiple time steps into the future [10] further improving performance, but can be trapped similarly. While both discrete [11] and sample based motion planners [12] have been used in information gathering problems and are capable of generating plans of long duration, they have only been applied to relatively simple environments and have not been used to generate multipass coverage plans, with the exception of the authors’ previous work in the area [13].
We present what we believe to be the first multipass coverage planner that maximizes mutual information for long duration trajectories that span the entire mission duration. Since such path planning problems are at least as hard as other NP-hard planning problems, use of admissible heuristics to guide the search is essential to improve algorithm performance. While there are many admissible heuristics for path planning, these do not extend well to multipass coverage due to the path dependence of the reward. We discuss the heuristics we developed for multipass coverage planning and demonstrate how they improve solution quality in the given computational time budget. We also extend three other state-of-the-art coverage planners to handle the multipass coverage planning problem and benchmark how the four algorithms perform in simulated natural environments based on total information gathered, expected time for human ground crews to search a cell after the autonomous search, and the time to compute the solution.
This paper significantly extends the preliminary work by the authors [13] by benchmarking the proposed -admissible branch and bound algorithm in realistic simulated environments, and extending the analysis of the algorithm’s performance. The new realistic environment models account for sensors viewing multiple cells, the physics of the vehicle, and realistic variations in region shapes using state of the art environment decomposition techniques on simulated obstacle occupancy grids generated by gradient noise. Experimental results compare the performance of the proposed -admissible branch and bound algorithm to other state of the art algorithms and also assesses how well in expectation the various algorithms guide human relief crews using a simplified effort allocation model. Findings show that -admissible branch and bound is able to gather the most information and reduces the expected time for ground crews to search a cell the most. Such quality plans come at the cost of requiring the most time to compute, however. We conclude our analysis with a discussion on the low cost of supercomputing capabilities contrasted with the large value of a statistical life.
The paper is organized as follows, following the road-map in Figure 1. Section 1 offers an introduction and motivation to the topics presented. Section 2 covers related work in the literature. Section 3 offers a formal problem formulation for multipass coverage planning for target search. The detailed description of the algorithm presented in this paper is divided into three related sections. Cross references are provided to establish ties between related concepts; readers may skip the cross references on an initial read. Section 4 introduces important preliminary concepts and introduces the benchmark algorithms. Section 5 outlines the proposed algorithm in the paper, and outlines how the analysis will be conducted. Section 6 discusses implementation details of the algorithm outlining the simulated natural environment developed for benchmarking the algorithms. Section 7 covers the experiments and their results, Section 8 discusses the experiment results and Section 9 concludes the work and discusses future work.
2. Related Work
Research interest in probabilistic target search appeared as early as 1956 [14] studying the probability of detection of a target given various sensor conditions. Since then, a large body of work has been developed on the task of target search, including many surveys of the subject [15,16,17].
First and foremost, our literature survey will focus on problems requiring active search where agents keep moving to locate targets [18,19] instead of static surveillance [20] (consider placement of static sentries in the art gallery problem to detect intruders [21]). Several important factors that delineate different approaches in the literature include the number of targets to be tracked, the assumptions about the target motion model, and who is searching for the targets. Some approaches are only for finding a single target, while others are for finding multiple targets. When working under a Bayesian framework, it is common to track a probability density function of a single target’s location [22]. This can be extended to a predefined number of targets in parallel [23,24], or using random finite sets to track the likelihood of the existence of a random number of targets [7,18,25].
Further, whether or not targets are stationary or dynamic affects the search. If targets are known to be stationary (or static), one could divide the search space into cells on a grid and track hypotheses in each cell [7,22,26]. Or, one can track the number of targets contained within each cell [27,28]. Since our work assumes stationary targets, there is a grid of cells, but the approach collects multiple cells into regions for faster evaluation of coverage plans by planning at the coarser granularity of searching regions instead of cells, requiring fewer actions for a full duration coverage plan at the cost of generating suboptimal plans. Targets that react and move according to the agent’s position can be assumed to have an adversarial relationship characterized by pursuit-evasion games [16]. Alternatively, target motion can be modeled as a Markov process which is unaffected by the agent’s actions [19,29,30]. Certain approaches also factor coordination between agents to find the target(s), either implicitly or explicitly [30]. Regarding multiagent algorithms, in particular explicit coordination methods are exponentially complex with the number of agents [30]. Multiagent coordination where the agents share and fuse observed data is common [19,23,24,31,32,33]. Multiagent search can also be adversarial where two competing teams are searching for the same target [34].
The use of information theory to improve the gathering of information in target search is widespread. Mutual information is a natural choice for modeling uncertainty reduction, and it works for continuous, discrete, and hybrid representations and is compatible with Bayesian search techniques. However, computing plans of arbitrary length that maximize mutual information is exponentially complex [6]. Many approaches either greedily maximize mutual information [7,8] or look only several actions into the future, similar to model predictive control [10,19,22,23].
In contrast to finding trajectories that maximize mutual information, one could plan trajectories that minimize the time to detect the target [35,36,37]. Minimizing expected time to detection vs. guaranteeing capture or reducing target location uncertainty will be appropriate in different scenarios [37]. However, the mentioned works are formulated for either a single target [35,36] or for a fixed number of targets [37], which is unsuitable for widespread disasters on land where the number of survivors is unknown a priori.
Hierarchical approaches can be used to improve the representation of the target distribution or of the environment to speed up the search. Quad-tree like structures representing the target distribution have been used [7,38]. Alternate approaches take advantage of the structure of the environment (e.g., rooms in an indoor map) [30,39] but assume that regions are convex and a line of sight sensor is used. They do not generate coverage plans for each region, which is something we explicitly do. Other work considers uncertain or changing environments [8,40] and focuses on potentially hostile environments that can destroy robots.
Branch and bound is a discrete optimization technique that uses admissible heuristics to guide and significantly speed up the search for the optimal solution compared to e.g., brute force enumeration of all candidate solutions. Branch and bound was initially introduced for target search when search effort of a particular region was indivisible [29].
It is important to note that the term heuristic in the robotics community has multiple meanings that vary widely given context, often causing confusion. In the most general sense, heuristics use incomplete information about a problem to find a solution quicker. Certain heuristic algorithms tend to discover suboptimal solutions very quickly (which we denote as suboptimal heuristic algorithms), while admissible heuristics, when combined with a search algorithm such as Branch and Bound or A*, have formal properties that guarantee the discovery of optimal solutions or discover optimal solutions with a minimal number of iterations. Further, inadmissible heuristics do not formally qualify as admissible heuristics but tend to offer performance tradeoffs for the algorithm designer when substituted for admissible heuristics. An -admissible heuristic offers computational speedups at bounded loss in solution optimality.
Of particular interest is related work that considers a moving target but seeks to maximize the probability of target detection subject to fuel and risk constraints [41]. For information gathering, branch and bound has been used for feature subset selection [42], and has been used in the similar traveling salesman problem (TSP) [43,44]. Branch and bound has been combined with Gaussian Processes for informative path planning [11] and is arguably most closely related to our research. However, the bounding heuristic used cannot account for multiple sensor measurements in the same location, for which we must explicitly account.
An example recursive greedy algorithm heuristic solver solves the submodular orienteering problem [45]. This algorithm, however, assumes that each state is only visited once, making it unsuitable for our application.
In the scenario with uninformative prior information, there is a close resemblance between trajectories that maximize mutual information and coverage plans. A recent survey outlines the various techniques used in coverage planning [46]. Two approximate solutions are of interest which focus on the 2D case. Zelinsky’s algorithm uses dynamic programming to generate a value function, then traverses level sets to cover the entire region [47]. The proposed algorithm can get stuck in the presence of obstacles and must back out to continue its coverage plan. Boustrophedon coverage outlines an approach to partition polygonal environments and suggests using a modified version of depth first search (DFS) to dictate the search order of the various regions [48]. For optimal coverage on graphs, this is equivalent to the traveling salesman problem, which is NP-hard. Interestingly, the solution to the Chinese Postman Problem [49] where the goal is to find the optimal tour covering all edges of a graph can be solved in polynomial time.
With regards to information gathering algorithms not directed towards target search, a time-varying information objective was explored in [12], when using sampling based motion planning for environmental information gathering.
3. Problem Formulation
We define a common benchmark problem to solve multipass coverage planning problems by defining an environment (sensor model plus motion model) with an objective function to maximize. We are most interested in (1) the quality of the solution the algorithm generates (how much information the algorithm gathers which in turn changes how long it takes for relief crews to search a cell for survivors) and (2) how long it takes to compute the solution.
Define to be workspace of the robot where . Let be the configuration space consisting of time domain T, workspace W and all higher order tangent spaces required to define the robot’s trajectory. We assume that the robot starts at point . For our application, we are interested in planning in the space of feasible trajectories. A feasible trajectory is a time indexed curve in C that starts at and that the robot’s dynamics is capable of reproducing. We denote the space of all feasible trajectories in time domain with end time t as . Let be the space of all valid trajectories whose end times vary between 0 and t.
Sensor measurements used for target search are stored in a discrete evidence grid covering workspace W. Instead of counting the sensor measurements the agent observes, we count the sensor measurements observed in each cell separately with . Define grid cell for and for user defined resolution r (typically, ) where such that the collection exactly covers the workspace.
For each cell define X to be the hidden state of whether or not the cell contains a target. X may be discrete or continuous. is the kth sensor measurement in g and is the collection of the k sensor measurements . A continuous example is the Bernoulli process where and . This can model targets that disappear and reappear from view randomly. Let be an observed sequence of measurements (a realization of ). When it is necessary to denote the particular grid cell in which sensor measurements are taken we shall use superscripts, e.g., is the observed sequence of measurements in . Each cell in the evidence grid is assumed to be independent from all other cells, that is for and . For all we assume that is independent of time and thus and are not affected by the time(s) at which the measurements are taken. The rationale behind this is that targets with restricted mobility (can only move within one grid cell) can be accurately modeled with a stationary process model, plus removing the dependence on time improves the ability to precompute the mutual information of future sensor measurements. Given the forward sensor model , we compute the inverse sensor model using a recursive application of Bayes’ Rule, (Equation (1)):
(1) |
in which all sensor measurements are conditionally independent. From this model it is possible to compute the mutual information . In practice, this can be computed a priori for any process and sensor model, and tabulated on the number of positive and negative sensor measurements observed (see Section 5 and Table 1 in Section 6.3 ). This model can account for either static (consider the occupancy grid model) or stationary targets (target’s presence at any moment of time is the outcome of a Bernoulli Process, but the target’s distribution is independent of time). The outlined approach in this paper would need to be modified to be used with nonstationary targets (whose target distribution is time dependent such as a Markov chain) or dynamic targets (whose belief distribution may be in more than one cell). We will assume the use of an occupancy grid model [50]. This model has closed form solutions which are obtained by judiciously applying basic properties of probability and information theory; use of other process/sensor models lies beyond the scope of this paper. Define submodular function to be the total mutual information gathered by a total of q future sensor observations. We note that in this approach, mutual information is used to predict the total information gain of future trajectories conditioned on any previous sensor measurements observed.
Table 1.
nz0 | 0 | 1 | 2 | 0 | 1 | 2 | 0 | 1 | 2 |
---|---|---|---|---|---|---|---|---|---|
nz1 | 0 | 0 | 0 | 1 | 1 | 1 | 2 | 2 | 2 |
info ( 1) | 0.390 | 0.209 | 0.050 | 0.209 | 0.390 | 0.209 | 0.050 | 0.209 | 0.390 |
info ( 2) | 0.599 | 0.347 | 0.094 | 0.347 | 0.599 | 0.347 | 0.094 | 0.347 | 0.599 |
info ( 3) | 0.737 | 0.432 | 0.125 | 0.432 | 0.737 | 0.432 | 0.125 | 0.432 | 0.737 |
Given a particular configuration , the sensor model also defines a sensor configuration footprint, encoding which cells in are observed given the perspective (field-of-view), and characteristics of the sensor (consider the projection of the image plane onto the evidence grid for a downward facing camera). This extends to trajectories, defining the trajectory footprint of the sensor following the path of the trajectory (Equation (2)).
(2) |
It holds that different sensors have different footprints (e.g., downward facing camera vs. scanning LIDAR). is equivalent to a 2D array the same size as the evidence grid by defining to be the number of observations in the indexed cell. The cumulative mutual information collected by time t assuming the robot has followed is given by the sum of the mutual information of the future sensor measurements and the hidden state conditioned on previously observed data within each cell.
The problem of multipass coverage planning for information gathering with mission duration constraints is defined as follows: Find , the trajectory of time duration t that maximizes the cumulative mutual information in ,
(3) |
3.1. Motion and Sensor Model
We assume a motion model where the current trajectory and next action determine the subsequent trajectory (along with next state c and trajectory footprint). In order to minimize the number of actions required to generate a coverage plan to minimize the depth at which one must search to find the solution, we cluster the cells of the evidence grid into contiguous, connected regions. The agent then has the choice to either traverse between connected regions, or search a given region. See Figure 2 for an example motion model. At a lower level hidden from the planner trying to solve (Equation (3)), the agent stitches motion primitives together to generate a trajectory to complete a given action (Section 5.3). Previously, we tested the proposed approach in rectangular environments [13]. In this work we extend such findings to more natural simulated Boustrophedon environments as will be covered in Section 6.1 and Section 6.2.
4. Preliminaries
Now that we are given a proper problem formulation, we now introduce relevant background material before proceeding to the approach.
4.1. Benchmark Algorithms
In addition to our proposed algorithm, there are three additional algorithms we would like to benchmark for the described scenario, that we can classify as being either heuristic solvers or planning algorithms. It is reasonable to suppose that heuristic solvers will get solutions faster by solving an easier problem (often in polynomial time), but will get lower quality solutions. Planning algorithms, on the other hand, solve the problem at hand by reasoning over many candidate solutions. Planning algorithm performance can be improved by using heuristics to guide the search. In practice, the use of properly designed heuristics to guide the search reduces the computational effort by a significant constant factor making exponentially complex algorithms tractable, while still obtaining (near-)optimal solutions.
We evaluate two heuristic solvers including (1) a single step greedy heuristic solver; and (2) the depth first search coverage based planner which is used in covering Boustrophedon decomposed environments [48] and has been adapted to generate multipass coverage plans. For planning algorithms, we test both depth first branch and bound and -admissible branch and bound (-admissible B&B: Algorithm 1 [13]). -admissible B&B uses improved heuristics to dramatically increase the quality of the solutions. Similar to ARA* [51] and e-admissible search [52], -admissible B&B uses an inadmissible heuristic to speed up the search time for branch and bound to find a good solution with bounds on sub-optimality.
The greedy heuristic algorithm greedily maximizes total information gathered per unit of time for the next immediate action. When the greedy heuristic is selecting the next best action, it is possible (but unlikely in natural environments) that two or more actions result in the same (maximal) amount of information gathered per unit of time. Such ties are resolved by selecting the action that acquires more total information. This is done iteratively until the planned trajectory spans the entire mission duration.
For the depth first coverage solver, one uses a modified version of depth first search (DFS) to generate a tree that spans all regions in the environment. Further, the iterative greedy heuristic g computes how many times region i should be searched to maximize mutual information. The agent then traverses the tree based on the DFS order, keeping track of how many times it has searched each region . To ensure a more uniform coverage of the environment, the agent searches the current region at most once per visit. Traversing the DFS tree will have the agent visit most nodes multiple times, and the tree can be traversed multiple times until the time expires (provided there is enough time to search). Each region is searched at most .
To illustrate the necessity of using priority heuristics and -admissible heuristics, we contrast -admissible B&B to depth first branch and bound (DF-B&B), as this is the more typical implementation of branch and bound (especially when implemented using recursion instead of a queue). Common practices with branch and bound tends to favor a depth first ordering when enumerating partial solutions because it tends to find initial (complete) solutions quicker enabling one to start bounding the space earlier in the search. Best first search strategies, such as A* with good heuristics, will evaluate fewer nodes when looking for the optimal solution however. Note that DF-B&B differs from DFS in that DF-B&B computes for every node, where DFS finds a spanning tree of all regions which in turn defines the search order, and only computes once to determine how many times each region should be searched. DFS therefore is much faster to compute than DF-B&B.
Note that by convention our motion model returns actions that traverse regions (sorted based on edge information) before actions that exhaustively search regions. Without modification, DF-B&B will only focus on actions that traverse between many regions and find low quality solutions within the allotted time. To generate high quality solutions quickly, the action set ordering should be randomized (i.e., permuted) such that DF-B&B will deliberate over more diverse action sequences. Such permutation schemes should be complicated enough to prevent cycles in the action space. This modification remains within the scope of the depth first search algorithms since the motion models do not require a preference over the ordering of different actions.
In previous work [13] we used Zelinsky’s algorithm [47] as a benchmark, however Zelinsky’s algorithm does not readily extend to sensor models whose footprints extend beyond a single cell in the grid and hence the sensor models used in this study.
4.2. Heuristics
Several challenges exist in designing heuristics for information gathering for multipass trajectories that do not exist in path planning for waypoint following:
All regions must be explored (possibly multiple times), requiring the heuristic to be more computationally demanding and explore a larger portion of, if not the entire workspace.
The reward function is path dependent since mutual information is submodular, requiring planning in the space of trajectories instead of the configuration space.
There is an increased number of paths of equal or similar reward, further compounding the problem.
To counter these challenges we define the notion of an -admissible heuristic for branch and bound in previous work, and observe that at significant performance speedup we can more greedily prune the solution space with a bounded loss in optimality [13]. For our application we effectively transform the admissible iterative greedy heuristic g into an -admissible (see Section 6).
Iterative Greedy Heuristic
For completeness we now describe the iterative greedy heuristic developed for multipass search in previous work [13]. Relax the problem formulation in (Equation (3)) by permitting sequences of actions that are not feasible. In other words, regardless of the agent’s current state, the agent must select L discrete actions to take, from all actions that are available from any state (Note that to guarantee admissibility is the sum of all actions that transition between regions and all actions that search a given region, Section 3.1).
Define decision variable with the number of times the ith action is taken, with decision vector . For the multipass coverage planning problem, actions can be selected multiple times. Selecting action i the th time yields the incremental reward of . is monotone increasing and concave ( but ). The agent’s goal is to select to maximize the function:
(4) |
The strategy to find the optimal solution is to sort all actions based on the incremental reward. While picking one action may affect the reward of other actions, those actions affected are a small subset of all actions and can be recomputed, since information content is localized to a given cell, and the information in cells may be accessed by different actions. During each round the action with the most reward is selected; by the concavity of the reward function the reward for taking an action a the ith time is collected before taking action a the th time [13]. An illustration of how the iterative greedy heuristic works in practice can be found in Figure 3.
This formulation is similar to previous work that uses multi-armed bandit (MAB) relaxations for gathering information [53]. However, the MAB heuristic computes dynamic allocation indices [54] in scenarios where reward is uncertain. The iterative greedy heuristic gathers expected information gain, which automatically factors measurement uncertainty, offering a simpler approach for the problem at hand.
One of the main limitations to the iterative greedy heuristic is that it does not account for the flight time associated with the agent transitioning between regions. This means that many different distributions of information will have the same heuristic reward even though it will be easier to gather the reward in some scenarios and not in others. Algorithms like A* or best first branch and bound expand all nodes with optimistic reward greater than or equal to the optimal reward, dramatically increasing search time if there are many paths of similar cost. One might consider getting a tighter bound on total information a node can gather with the remaining time available before the mission ends by estimating the total remaining traversal time. One such way to obtain a lower bound is to generate a minimum spanning tree [55] of all regions the heuristic visits. While this approach works for traveling salesman problems [43], such an approach cannot properly bound the information gathered when traversing between regions, making it unsuitable for the problem at hand.
Further, in large maze-like environments, it is often difficult for the planner to explore the search frontier when a candidate solution backs itself into a corner and requires multiple actions to return to the frontier, which is likely to happen when a multipass algorithm is used in large environments.
The iterative greedy heuristic requires the evaluations of many footprints for their information content. In order to speed this up, we first note that changes in cost can be computed locally for the region being evaluated immediately. Second, caching the rewards for footprints is essential to improving the speed of the heuristic. Whenever a region is selected greedily, at the next iteration the rewards only have to be recomputed for the previously selected region (and any other regions it may overlap), resulting in a constant factor performance improvement with . Caching is therefore a constant factor improvement in the run time of the heuristic.
5. Approach
In order to solve (Equation (3)), we benchmarked four different algorithms using the same reward and motion model to determine their ability to generate quality solutions and determine how long it takes them to compute the solution. As we did in previous work [13], we observe that can be computed from as a 3D look-up table dependent on the number of positive and negative observations for a given cell by applying the chain rule for mutual information [4] and the exchangeability property of Binomial random variables, offering mutual information look-up speeds in RAM with as little as 32 kilobytes of memory for a 20 × 20 × 10 array of double precision floats.
Our proposed method is -admissible branch and bound [13], is based off of branch and bound [56] and is summarized in Algorithm 1 with subroutines Branch (Algorithm 2) and Bound (Algorithm 3). In short, branch and bound works by iteratively partitioning the solution space (branch), and determining if a subspace contains a solution that can potentially beat the current best known solution using an admissible heuristic (bound). Subspaces that can be determined to not contain the best solution are pruned or fathomed, speeding the search. When expanding the search tree denoting subsets of the solution space, define a search node N to be a partial solution with a family of candidate solutions, combined with a reference to its parent node, its priority, and other quantities required for improving the search. Search node N is different from a node in the graph of the motion model. DF B&B can be created by modifying Algorithm 1 such that is a stack (LIFO queue), priority heuristic is no longer required, line 14 in Algorithm 1 is eliminated, and admissible heuristic g is used in place of -admissible heuristic .
5.1. Priority Heuristic
For the priority heuristic in -admissible branch and bound (Algorithm 1 line 14), we use the weighted heuristic that discounts future reward to offer a compromise between best first and depth first ordering. For a node N in the search tree, define priority to be (Equation (5)) [13]:
(5) |
given current reward , admissible bounding heuristic , and future reward discount factor . Setting towards zero biases the search towards depth-first like behavior.
Algorithm 1 -Admissible Branch and Bound |
|
Algorithm 2 Branch |
|
Algorithm 3 Bound |
|
5.2. Agent Model
While this work is targeted at quadrotors, the outlined approach generalizes to other physical systems. Although quadrotors are a differentially flat system [57] requiring 4th order dynamics, we will focus on using a second order integrator subject to velocity and acceleration constraints for this work. We first observe that physical systems have bounds on their acceleration capabilities due to the force output of their actuators, or the maneuvers their controllers can reliably execute, imposing a maximum nominal acceleration on the platform . Lower accelerations for quadrotors reduces the maximum attitude angles observed (similarly with their derivatives), which can affect sensor measurements. Second, we observe that it is often the stopping distance vs. the range of onboard collision detection sensors that dictates how fast a vehicle can safely fly in partially known environments, requiring a hard bound on maximum nominal velocity . When traveling at maximum speed , decelerating at , the stopping distance before the system comes to rest is . The vehicle can safely stop if its stopping distance is shorter than its sensing range. Alternatively, if the vehicle wishes to steer around an obstacle distance ahead maintaining forward speed, the distance the robot can steer, . The robot steers clear if exceeds the distance it must move to avoid collision. In short, a vehicle that wishes to double its safe forward speed must quadruple its acceleration capabilities or sensing range. Further, analysis of single order integrator systems flying through Poisson forests suggest that above a certain speed, collision will occur with probability one regardless of the planner or controller used [58].
Define as the L2 norm while . Other flat states such as altitude or yaw could be included but are ignored for our work.
(6) |
5.3. Motion Primitives
In order to execute a high level behavior, sequences of waypoints are chained together to create multiple point to point maneuvers. For now we assume that a decomposition algorithm divides the environment into contiguous regions that are easy to search (how we do this is covered in Section 6.2). When traversing between regions (central point to central point), a simple line connecting the regions may not suffice due to the presence of obstacles. To solve this, we create an alternate motion model that is an 8 connected graph on the underlying evidence grid. A* can generate a sequence of cells minimizing path cost (path length). However, this sequence of waypoints is very dense; many of the waypoints are unnecessary to define the shape of the path and can be eliminated by the following method. One only keeps a waypoint in the sequence if the angle between vectors and is above some threshold, e.g., . Otherwise, remove waypoint i and continue.
In order to search a region, a dynamically feasible coverage plan is needed. The proposed method creates rectilinear uniform coverage plans (Figure 4) with “plow lines” that are parallel to the slice direction defined by the Boustrophedon Decomposition algorithm (Section 6.2). The agent transitions between adjacent “plow lines” rectilinearly. In order to compute the start and stop positions of the plow line, the geometry of the (boustrophedon) region is known, and line search is conducted to find the max and min values along a given plow line. Spacing between plow lines is dictated by the maximum sensing radius.
The use of a uniform coverage plan makes the tacit assumption that information is uniformly distributed within the region. This may or may not be the case in practice, reducing the effectiveness of the information gathering algorithm. Having a coverage planner that can directly reason over contiguous nonuniform regions is compatible with the proposed approach, but is to be considered in future work. An alternate approach is to use the distribution of information to guide the selection of regions. The mere act of intelligently decomposing the environment into separate regions can dramatically simplify the problem by solving information gathering problems in smaller contiguous regions. We note that for illustrative purposes, all algorithms benchmarked in this paper have access to the same motion model, suffering similarly.
Apart from rectilinear coverage plans, one might consider using spirals [37] due to their ability to efficiently cover 2D areas. However, given the problem specification of having to account for obstacles while generating dynamically feasible coverage plans, The task of covering non-circular/non-square regions found from a decomposition algorithm makes spiral based coverage plans impractical due to inefficiencies in covering the edges.
5.4. Point to Point Maneuver
For vehicle trajectory connecting points and for times , solve the following optimization problem:
(7) |
For the system in (6), the problem in (Equation (7)) is a simple bang-bang control problem [59] minimizing the trajectory time interval by selecting optimal control . The corresponding trajectory can be written in closed form with continuous position and velocity, and piece-wise constant acceleration at . The system either has one or two switching times depending on whether the system has enough time to accelerate to its maximum velocity.
Without loss of generality we will consider a scalar model, letting with dynamics . Let , and .
Theorem 1.
Necessary condition: the time optimal control resides within the domain .
Proof.
There are two cases, when there exists 1 switching time (when and t is not the switching time or when ) or when there are 2 switching times () for . When , one can show by using the Pontryagin’s Maximum Principle (PMP) [59] that control for the time optimal solution .
When , the velocity constraint will become active during the trajectory. As a simple illustration, suppose that the system accelerates to the maximum velocity . To continue accelerating would violate the velocity constraint, so the system must either stop accelerating or slow down. For any system slowing down before the prescribed deceleration at the end of the trajectory, the traversal time would increase, yielding a suboptimal solution to the time optimal problem. Therefore, the system will cruise at with until it is time to slow down and . ☐
For a more rigorous proof, consider a formulation of Pontryagin’s Maximum Principle with state inequality constraints to get the case when the velocity constraint becomes active. Typical formulations of PMP without inequality constraints will not elicit costate trajectories that have multiple switching times.
With the domain of u and known problem constraints, the switching times can be determined along with the optimal control by inspection (speed up, cruise, slow down). With known control u, and can be solved for closed-form by quadrature. To increase the average speed of the vehicle, it is advantageous to remove the zero velocity and acceleration constraints at the end of each maneuver. Boundary conditions with are easy to solve for closed form using the mentioned approach when the velocity is in the direction of the vector . Two extensions are to use splines (where it is difficult to guarantee hard bounds on velocity and acceleration) or to use Dubbins like trajectories where the use of circles connect adjacent plow lines.
5.5. Search Effort Allocation Model
For comparison of results between algorithms, we define a simplified search effort allocation model to see how effective the various multipass coverage planning algorithms are at directing rescue teams. This simplified model can study the practical consequences of having informative trajectories for search and rescue but ignores effects due to finite search resources/time, survivor survival rates, and the time spent transitioning between cells. The search effort allocation model is distinct from the sensor model used by the planner based on the different attributes or roles the autonomous agent and human ground crews have during the search and rescue operation. We assume that after executing the autonomous search using one of the benchmark algorithms outlined in Section 4.1, the agents generate an occupancy map which become prior probabilities for the human rescue teams on the ground. Let D be the event that the target is detected within a given cell, while is the absence of detection. X is the presence or absence of a target in the cell as in the previous model (Equation (1)). is the detection time constant effectively rescaling the given search time to search effort. Define the probability of detection of a target in a given cell (Equation (8)) [5,60]:
(8) |
Using Bayes’s rule and (Equation (8)), we compute the probability the target is still present despite there not being a detection after searching for t seconds (Equation (9)):
(9) |
The human rescue teams search the cell for T units of time for a survivor until the survivor is found or . If , the cell is skipped. Using this policy, the maximum search time for the cell is (Equation (10)):
(10) |
Note that the probability density function is due to (Equation (8)). We wish to compute the expected time for the search in a given cell to end by letting for a given trajectory generated by the algorithm. We start off by computing the expected time to search the cell given prior probability by using the law of total expectation over X (Equation (11)):
(11) |
This leaves the computation of the distribution of priors . For each cell in the evidence grid, the distribution of outcomes for given the sensor data (planned K sensor measurements) can be computed for all realizations. can be computed directly/deterministically from the known number of sensor measurements and known sensor data . Since we assume that all cells have the same characteristics, we marginalize over the distribution of sensor measurements (computed from the trajectory footprint) and marginalize over all realizations. We also use the exchangability property of the sensor measurements to use a Binomial random variable (Equation (12)):
(12) |
Without loss of generality we assume , meaning t implies the number of time constants spent searching a given cell.
6. Experimental Setup
We now discuss the formulation for modeling quadrotors with downward facing cameras in natural environments, and discuss experimental setup. When selecting our -admissible heuristic for -admissible branch and bound we only want the algorithm to expend effort when there may exist a solution that is at least a factor 1 + better than the current best known solution. We let where B is the reward of the current best known solution. at start up if no heuristic solution is known or computed. Unless otherwise stated we let . Simulations were run on a workstation laptop running 64 bit Ubuntu 14.04 LTS with a Core i7-6920HQ which has a 2.9 GHz clock with 64 GB RAM. The proposed branch and bound algorithm, the greedy algorithm and the depth first search (DFS) coverage planner were developed in Python, using NumPy [61] for array operations and networkx [62] for graph operations.
6.1. Procedurally Generated Natural Environments
In order to procedurally generate natural environments, we use multiple frequency bands of a gradient noise function (for a single band: Figure 5a) to generate elevation maps (Figure 5b is a colored elevation map, while Figure 5c is a 3D perspective of the colored elevation map in Figure 5b), and then threshold that map to create an obstacle grid (Figure 5d). In contrast to Perlin noise, Simplex noise (Figure 5a) has minimal directional artifacts making it most suitable for natural terrain [63,64] (we use the OpenSimplex algorithm developed by Kurt Spencer [65] and ported to Python by A. Svensson [66]).
The frequency content and hence the complexity of the environment can be controlled by summing multiple frequency components (e.g., Figure 5a). OpenSimplex defines the 2D gradient noise function where but we restrict to integer grid coordinates given a seed value for the random number generator. defines the elevation map. is the number of frequency components in the terrain generator, and is the frequency of the ith band and is the weight of the ith band.
For our experiments, we set , and . Define 5 different environment frequency contents: very low frequency (freq.) (vlf), low freq. (low), medium freq. (med), high freq. (high) and very high freq. (vhf). For (vlf,low,med,high,vhf), the frequencies correspond to and the frequencies correspond to . For each environment complexity, our database of benchmark environments consisted of 20 Simplex environments and 4 random starting locations per environment. Algorithm 4 outlines the approach used to generate Simplex environments. This is contrasted to defining random obstacles over, e.g., randomly generated quadtree maps [67].
Algorithm 4 Generate_Environments(T) |
|
6.2. Boustrophedon Decomposition
Given an environment, the free space must be decomposed into individual components that can be searched or “plowed” using the Boustrophedon (i.e., “the way of the ox”) decomposition algorithm [48]. We use a discrete implementation with the following modifications:
We ignore small obstacles under a given pixel count. We argue that small obstacles smaller than the sensing radius do not adversely affect the coverage plan yet including a small convex obstacle introduces 3 additional regions to the decomposition.
We impose a greedy merge rule to combine adjacent regions if their boundaries overlap sufficiently due to critical points far away causing otherwise continuous regions to be broken into smaller regions.
We also remove regions that are too small to sensibly cover and repair region connections afterwards.
Since we will be generating trajectories that cover the region, the Boustrophedon algorithm identifies start and end points for each plow line for the trajectory planner.
For the first computed environments, for the frequency content environments (low,med,high,vhf), the average/standard deviation of number of regions was . Simplex environments are more complex than previous environments [13] due to increased number of loops, and the fact that region traversals gather a significant amount of reward and create significant overlaps between actions. Observe in Figure 6 that the regions vary widely in size given the complexity of the environment. Having fewer nodes in the environment is advantageous in speeding up the search. Larger contiguous regions can be searched more efficiently by acceleration limited agents (Section 5.2). One disadvantage to having such large regions is that the information content of the region may not be uniformly distributed, and the coverage planner may not be able to account for this.
6.3. Camera and Sensor Model
For our experiments, we will restrict the sensor model to a binary Bayes static occupancy grid model [50] where is fully characterized by probability of detection and false positive rate . We let . Unless otherwise mentioned the target evidence grid is a 200 × 100 grid.
When computing the recursive Bayes filter (1) for the binary Bayes static occupancy grid model, define with defined using prior knowledge (we typically assume least informative prior ) for new sensor observation , resulting in (13):
(13) |
This results in parameter update equation (Equation (14)):
(14) |
In order to compute the multi-step look-up table for the binary Bayes static occupancy grid model, we can take a more direct approach using a Binomial random variable to represent the next q observations instead of using the chain rule of mutual information. Let be a Binomial RV where:
with known from the Bayes filter, using law of total probability. Mutual information for discrete random variables X,Y with being the joint probability mass function of and being the marginal probability mass functions of . Manipulation yields (15):
(15) |
Assuming the initial distribution , and , we compute the following table used in the experiments as shown in Table 1.
Observe that when nz0 =nz1, the mutual information for is a constant 0.390. This is a limitation of the sensor model itself and is unlikely to occur for large when the static binary Bayes sensor model accurately models the environment and . Since X is Bernoulli there is at most 1 bit of information. The table is also symmetric when swapping nz0 and nz1 because . Note that since mutual information is submodular, .
For this work, we assume that the quadrotor has a downward facing camera with a circular field of view and can make observations in multiple cells (Figure 7). We suppose that there exists image processing software that will identify the positive positions of detected targets in the image frame at a near continuous rate (overlap of FOVs of adjacent images processed is significant), while empty positions of the frame are considered negative detections. We assume that the probability of detection and false positive rate are known. These locations are then mapped from the image frame to the evidence grid. To avoid multiple correlated sensor measurements we only record a single observation for a given cell during a particular action (transition between regions or search a region). This implies that targets in cells within a given distance from the quadrotor can be detected.
For realistic flight scenarios factoring actual hardware capabilities, motion blur on a global shutter camera occurs when camera/environment motion causes the displacements of image features during the image exposure to be greater than one pixel. Both rotational and translational velocities of the quadrotor contribute to motion blur, placing constraints on both the altitude and forward speed of the vehicle to prevent motion blur. To compare, we will consider the IDS UI-3251LE camera with optics that have a 90deg FOV (7 mm focal length lens), 1600(H) × 1200(V) pixels, flying at 5–20 m altitude, and a 1 ms exposure time (suitable for brightly lit indoor environments) and outdoor environments.
Define to be the maximum speed of the ground in the image plane where assuming nominal altitude above the ground , and is the maximum attitude angle change expected of the camera during maneuver execution or disturbance rejection. We also note that where is the lens focal length and is the size of the image sensor along the direction of motion [68].
Define the displacement of the ground plane due to agent motion within the exposure time in pixels (Equation (16)):
(16) |
with as the number of pixels along the direction of motion and is the field of view in meters along the direction of motion. indicates motion blur. We note that an increase in altitude reduces motion blur by increasing pixel size on the ground but rotational disturbances will dominate for high altitudes. A gimballed camera can reduce rotational disturbances at increased payload costs. This results in the permissible flight envelope by . For example, setting results in a causing motion blur while results in not causing motion blur.
We define cell pitch m (not to be confused with camera pixel pitch) mapping cell indices to Euclidean coordinates in meters. We also assume that the camera has a circular 90deg FOV such that the sensing radius is 8.8 m. The trajectory footprint of every action in the motion model is created by sweeping the sensor footprint along the trajectory planned by the Boustrophedon coverage planner. Therefore in practice the shape of the field of view does not matter as the sensor acts as a sweep sensor with the given sweep radius.
7. Experimental Results
For each algorithm we normalize its performance with respect to the iterative greedy heuristic which always overestimates the reward. In other words, one computes the ratio of information each algorithm gathers in an environment by dividing the amount of mutual information (in bits) the algorithm gathers by the heuristic reward (in bits). Since the heuristic is admissible this ratio is ≤100%. This also normalizes for the variations in how much total information exists in a given environment. We ran 3 experiments; the first two were to understand various aspects about -admissible B&B.
Experiment 1: vary , and in low frequency environments for -admissible B&B to identify algorithm performance for different heuristic parameters.
Experiment 2: setting , vary size of evidence grid in low frequency environments and observe how -admissible B&B scales with the evidence grid size.
Experiment 3: benchmark the four algorithms in Simplex environments, setting for -admissible B&B.
For uniform environments, all cells are initialized with the most uninformative prior of . By inspecting the mutual information look up table, we observe that cells that have two or more prior sensor measurements have low enough information content that a nonuniform covering will gather more information than a uniform covering. When generating nonuniform environments, we want the geometry of low entropy regions to not correspond with the geometry of the obstacles. Therefore the nonuniform envionments generate a distribution of low entropy regions using Simplex noise thresholded at 50% (i.e., 50% of the environment is low entropy, while the remaining environment is set to high entropy).
For the environments (low,med,high,vhf), define the low entropy regions with the following frequency parameters (vlf,vlf,low,med).
7.1. Experiment 1
We tested the branch and bound algorithm in the low environment, terminating if the priority queue is empty or after 6000 iterations have occurred. We set , and and observe total information gathered, and number of nodes explored. Fewer nodes explored implies more nodes in the search space are pruned. As both and increase, the number of nodes explored decreases due to better prioritization or pruning. Results are summarized in Figure 8. In terms of the reduction in nodes expanded, for on average only expands 48% of the nodes that are expanded when suggesting that -admissible branch and bound can speed up the search by about a factor of two while finding solutions that are on average within of the optimal solution.
In determining the parameters for future experiments, was chosen for the following reasons . Setting ensures that -admissible B&B finds solutions within 0.2% of the optimal solution. While expands the fewest nodes in the lowf environments, in larger environments, setting instead of decreases the time to finding the first solution which significantly increases the success rate of the algorithm and reduces memory usage (Experiment 3).
7.2. Experiment 2
For Experiment 2 we varied the size of the evidence grid to consist of {4608, 10,368, 20,000, 39,200, 80,000, 180,000, 320,000 } where each environment has a 2:1 aspect ratio. In addition, the resolution of the cells changes such that the area of the environment in meters is the same in all trials. Also, the sensor footprint is the same in meters in all environments. For the Experiment 2 Simplex environments, the following parameters are: and .
For each environment size we generated 10 environments with 4 starting locations for a total of 40 trials. Environments are generated using Simplex noise for environments with 320,000 cells (or 800 × 400 cells) and are downsampled to smaller environment sizes.
After the environment is re-scaled, Boustrophedon decomposition generates the discrete graph before running the proposed branch and bound algorithm. The algorithm also scales parameters for Boustrophedon decomposition such as the minimum area of an obstacle before it is removed. The environments do not scale perfectly, however, and the number of regions per environment can still vary (Figure 9a). Note that the size of the environment in cell count varies by a factor of 70, while the number of regions varies by a factor of 1.3, implying that the increase is insensitive to increase in cell count. Also note that , defined by the total time to cover each region twice, is insensitive to the number of cells and its standard deviation over all cell sizes is about 750 s with a mean of 9980, varying by about 7.5% (Figure 9b). Branch and bound runs for 6000 iterations or until is empty. The time to the final solution is approximately linear (Figure 9e) when the number of nodes expanded remains constant (Figure 9c).
One thing of interest is that the quality of the solution degrades as the size of the environment increases (Figure 9f,g). This is not a limitation of the algorithm itself; Figure 10 shows that the quality of solutions found using DFS on the same environments degrades similarly with evidence grid size. One possibility that explains this is that the environment is not scaling perfectly. When the sensor footprint is discretized in a coarser grid (when is smaller resulting in larger grid resolutions), the footprint tends to be more square. This can introduce artifacts in the total area swept by a moving sensor by a factor at most when moving diagonally, dramatically increasing how much information per unit of time is gathered when traversing between regions. Traversals in environments with fewer cells would therefore get a slight performance boost.
Note that in certain environments, many of the resulting statistics are heavily skewed and non-Gaussian so the error bars (Figure 9d) which represent one standard deviation dip below 0. None of the trials violate constraints such as .
7.3. Experiment 3
For Experiment 3 we benchmarked the proposed branch and bound algorithm with against DFS and the greedy algorithm. The algorithm terminates after either the priority queue is empty or iterations have completed. All algorithms are benchmarked with both uniform and nonuniform prior distributions.
To get an understanding of how the various algorithms perform in different environments, we illustrate trajectory footprints representing median algorithm performance from -admissible B&B (Figure 11), greedy (Figure 12), DFS (Figure 13) and DF-B&B (Figure 14) in uniform environments. Figure 15 shows the entropy in example environments with information non-uniformly distributed in the environment. Figure 16, Figure 17, Figure 18 and Figure 19 show the median performance of their respective algorithms in nonuniform environments.
The trajectory footprints in Figure 11, Figure 12, Figure 13 and Figure 14 and Figure 16, Figure 17, Figure 18 and Figure 19 are an array representation of the best trajectory discovered by the mentioned algorithm, . Areas not visited are white, obstacles are black, and blue regions indicate how many times the areas have been visited (see the legend in Figure 11e). Multipass coverage plans that are more uniform should be more uniform in color. Notice that all cells in a given region are not the same color; dots and lines shown within the regions show the information gathered between region traversals as these are visited additional times along commonly traveled paths between regions. Other lines are due to sensor footprints overlapping between adjacent regions.
One can observe that branch and bound covers the environment most uniformly (resulting in the highest quality solution) while the greedy solver can get stuck or miss regions. DFS’s performance falls in between -admissible B&B and the greedy heuristic solver while DF-B&B has the worst performance. Results are summarized on the uniform environments in Table 2 and on the nonuniform environments in Table 3. denotes the number of solution improvements found during the search. The described effort allocation model computes the expected time to search a cell in number of time constants (e.g., with ), denoted as “effort” on Table 2 for the uniform environment using detection threshold . Figure 20 and Figure 21 summarize key results in Table 2 and Table 3 respectively.
Table 2.
Env. | Succ. Rate | -Admissible Branch and Bound | |||||
---|---|---|---|---|---|---|---|
1st Info | 1st Time | Final Info | Final Time | Effort | |||
low | 100% | 92.8% ± 5.3% | 5.8 ± 9 | 10 ± 4.1 | 99.1% ± 0.6% | 316 ± 169 | 1.4 ± 0.033 |
med | 98.8% | 95.9% ± 0.2% | 27 ± 47 | 9.3 ± 4.5 | 98.5% ± 0.5% | 648 ± 175 | 1.36 ± 0.030 |
high | 93.8% | 96.8% ± 1.1% | 76 ± 77 | 7.4 ± 4.2 | 98.2% ± 0.5% | 961 ± 308 | 1.31 ± 0.028 |
vhf | 98.8% | 96.6% ± 0.9% | 129 ± 143 | 8.9 ± 4.7 | 98.0% ± 0.9% | 1185 ± 273 | 1.27 ± 0.030 |
Env. | Greedy | DFS Coverage Planner | |||||
Info | Time | Effort | Info | Time | Effort | ||
low | 85% ± 7.8% | 0.3 ± 0.1 | 1.61 ± 0.01 | 97% ± 3% | 0.2 ± 0.02 | 1.48 ± 0.064 | |
med | 81% ± 11% | 0.57± 0.12 | 1.61 ± 0.15 | 97% ± 1.0% | 0.3 ± 0.03 | 1.40 ± 0.033 | |
high | 82% ± 11% | 0.78 ± 0.26 | 1.56 ± 0.18 | 97% ± 0.7% | 0.42 ± 0.04 | 1.35 ± 0.029 | |
vhf | 84% ± 10% | 0.87 ± 0.15 | 1.47 ± 0.16 | 96% ± 1% | 0.5 ± 0.04 | 1.30 ± 0.18 | |
Env. | Depth First Branch and Bound | ||||||
1st Info | 1st Time | Final Info | Final Time | Effort | |||
low | 71.2% ± 10% | 8.5 ± 4.7 | 42 ± 17 | 78.1% ± 8.8% | 235 ± 85 | 1.72 ± 0.11 | |
med | 66.3% ± 11.4% | 31 ± 12 | 38 ± 16 | 71.2% ± 10.1% | 466 ± 107 | 1.75 ± 0.14 | |
high | 61.9% ± 11.5% | 69 ± 21 | 34 ± 15 | 65.5% ± 10.6% | 712 ± 160 | 1.80 ± 0.15 | |
vhf | 61.6% ± 11.8% | 107 ± 31 | 30 ± 15 | 64.6% ± 11.6% | 862 ± 216 | 1.77 ± 0.17 |
Table 3.
Env. | Succ. Rate | -Admissible Branch and Bound | |||||
---|---|---|---|---|---|---|---|
1st Info | 1st Time | Final Info | Final Time | Effort | |||
low | 100% | 93.2% ± 4.3% | 6.8 ± 20 | 11 ± 5.8 | 98.6% ± 0.1% | 282 ± 137 | 1.21 ± 0.05 |
med | 98.8% | 97% ± 0.4% | 31 ± 51 | 9.5 ± 4.3 | 98.7% ± 0.4% | 596 ± 271 | 1.27 ± 0.04 |
high | 100% | 96.6% ± 1.5% | 111 ± 141 | 7.5 ± 4.1 | 98.1% ± 0.6% | 760 ± 264 | 1.23 ± 0.02 |
vhf | 95% | 96.3% ± 1.2% | 151 ± 199 | 8.7 ± 5.1 | 97.8% ± 0.8% | 965 ± 288 | 1.20 ± 0.03 |
Env. | Greedy | DFS Coverage Planner | |||||
Info | Time | Effort | Info | Time | Effort | ||
low | 83% ± 11% | 0.3 ± 0.01 | 1.34 ± 0.10 | 95% ± 3.3% | 0.19 ± 0.03 | 1.25 ± 0.05 | |
med | 79% ± 16% | 0.51 ± 0.13 | 1.41 ± 0.09 | 96% ± 1.3% | 0.31 ± 0.03 | 1.26 ± 0.03 | |
high | 80% ± 10% | 0.69 ± 0.01 | 1.35 ± 0.08 | 96% ± 1.0% | 0.42 ± 0.04 | 1.24 ± 0.02 | |
vhf | 81% ± 12% | 0.83 ± 0.16 | 1.31 ± 0.10 | 95% ± 1.3% | 0.5 ± 0.04 | 1.20 ± 0.02 | |
Env. | Depth First Branch and Bound | ||||||
1st Info | 1st Time | Final Info | Final Time | Effort | |||
low | 70.2% ± 13.9% | 7.3 ± 4.4 | 36 ± 16 | 77.3% ± 12.6% | 222 ± 78 | 1.4 ± 0.1 | |
med | 62.6% ± 13.0% | 29 ± 12 | 38 ± 16 | 68.2% ± 11.6% | 448 ± 124 | 1.43 ± 0.09 | |
high | 60.9% ± 11.2% | 68 ± 21 | 30 ± 14 | 64.6% ± 10.6% | 675 ± 169 | 1.45 ± 0.08 | |
vhf | 61.3% ± 11.4% | 101 ± 31 | 28 ± 10 | 64.7% ± 10.7% | 790 ± 210 | 1.42 ± 0.09 |
8. Discussion
Experiment 1 identifies the parameters that are to be used for -admissible B&B for the other experiments. The results of Experiment 2 demonstrate that -admissible B&B scales reasonably well with increasing environment size due to the hierarchical nature of the algorithm. Experimental results demonstrate that the -admissible heuristic is able to significantly speed up branch and bound with bounded loss in optimality.
We now direct our attention to assessing the four algorithms for their performances in solution quality and time to compute the solution in Experiment 3. -admissible B&B finds the highest quality solutions but takes the longest time to compute because it reasons over many candidate solutions. One limitation to -admissible B&B is that the heavy reliance on the iterative greedy heuristic and all the heuristic’s limitations (see Section 5.1) can cause the planner to continually expand too many candidate solutions at a fixed depth preventing the planner from finding a solution within the allotted time and memory constraints. Since Python is rather memory inefficient our experiments were limited to around 6000 iterations; more memory efficient languages ought to handle more iterations. Memory efficient search techniques such as beam-stack search [69] could alleviate such bottlenecks, but it is unknown how such techniques would interact with -admissible heuristics.
The heuristic solver DFS finds the second highest quality solutions in the shortest amount of time offering an effective trade-off in solution quality vs. speed to compute. We note that the quality of the DFS solutions degrades in environments with many more (smaller) regions due to the fact that more time is spent traversing between regions vs. searching the individual regions.
Comparing the two algorithms that gather the most information on average, -admissible B&B gathers 2.3% more information on average than DFS search taking 1–2 orders of magnitude longer to compute. To get a better sense of the real world performance improvement, -admissible B&B searches uniform environment at a rate that is 2.8% faster than the DFS coverage planner (where the search rate is inversely proportional to time to search a given cell), while -admissible B&B searches nonuniform environments at a rate that is 0.8% faster than DFS. We think that this decreased performance improvement in the nonuniform environments is a limitation of the Boustrophedon decomposition algorithm and/or the region coverage planner. Generating region coverage plans that factor in the information content by non-uniformly covering regions, or a polygonal decomposition that factors in information content (consider an extension of the weighted Voronoi Diagram that accounts for obstacles) would alleviate this and allow -admissible B&B to better reason about nonuniform distributions of information. When dealing with computational time budget constraints (fixed time budget for computing resources), we observe that -admissible B&B is an anytime algorithm. In the vhf uniform environments for example, around 90% of the time the first solution is discovered within 4.5 min (in contrast with about 90% of the trials terminating around 24 min).
One must consider the trade-offs between the added cost of computing better paths to the increased rate of rescuing survivors. We observe that the dramatic reduction in costs for supercomputing capabilities in recent years combined with the high value of a statistical life (around $7 million in 2005 USD [70]) imply that computer time is extremely cheap relative to human lives. Spending an additional $70,000 renting a sizeable chunk of supercomputing resources is considered cost effective if it increases the expected number of statistical lives rescued by at least 0.01 lives. Increasing the amount of area one is able to thoroughly search within 48 h by 2.8% is instrumental to increasing survival rates. More accurate figures are required for detailed analysis.
The greedy heuristic algorithm is able to find higher quality solutions than DF-B&B but not DFS or -admissible B&B. The greedy heuristic algorithm is also slower than DFS. The poor solution quality of DF-B&B despite the long time to compute the solution highlights the importance of generating effective heuristics to guide branch and bound to find high quality solutions. This is a finding that is not always recognized in the literature (usage of DF-B&B in place of heuristic guided B&B has occurred [11]). Note that DF-B&B is actually guaranteed to find optimal solutions when run to completion but is unable to find high quality solutions in a reasonable amount of time.
A practical way to verify the quality of heuristic solvers is through use of branch and bound which is guaranteed to find solutions near the optimal solution, suggesting use of branch and bound as a means of verifying suboptimal heuristic solvers.
9. Conclusions
In this paper we identify the task of generating multipass coverage plans for target search, as agents searching for targets must assess the trade-offs of searching a given region multiple times. This relatively unexplored area of research requires generating plans that visit most if not all of the workspace multiple times, where even seemingly small problems require long action sequences to solve.
Given the difficulty of the problem, we created the algorithm -admissible branch and bound (-admissible B&B) [13] which uses heuristics to improve the quality of the solution found in the given time. We benchmarked four different algorithms in Simplex environments assessing various performance metrics such as how long it takes to compute the solution and the quality of the solution (information gathered minimizing uncertainty in bits and expected time for a relief crew to search a cell).
The two most promising algorithms are -admissible B&B and the Depth First Search (DFS) heuristic solver [48]. -admissible B&B finds the highest quality solutions (gathers 2.2% more information than DFS and generates plans that search uniform environments 2.8% and nonuniform environments 0.8% faster than DFS) but takes the most time to compute. DFS on the other hand finds the second highest quality solutions but takes the shortest time to compute. The greedy algorithm and DF-B&B are both outperformed by DFS in terms of solution quality and time to solution. One of the greatest challenges to the practitioner not fully addressed by these findings is properly assessing the trade-offs in generating higher quality solutions at increased computational cost. Access to cheap supercomputing capabilities with the high value of a statistical life suggests that even small improvements in solution quality can be cost effective. However, for very large problem instances that we did not investigate in this paper (hundreds to thousands of regions, or tens of millions of cells), the findings of this study must be reinvestigated. Using branch and bound techniques may become intractable for very large problems, and heuristic techniques may offer the only feasible solution that can be computed in realistic time, with significant drops in solution quality.
For future work, we would like to improve the environment decomposition and region coverage planners in such a manner that can improve how information is gathered in a nonuniform environment. Extending techniques such as weighted Voronoi Diagrams offers a plausible means of doing so. We also plan to extend this work to a multiagent scenario by having multiple MAVs perform a coordinated search effort in a decentralized manner. During the plan execution, such agents will have to share their information in a robust fashion subject to communication network limitations.
Acknowledgments
The authors would like to thank Dana Nau for his thoughts on heuristic search algorithms, Jeff Byers for his discussions regarding information theory, and Corbin Wilhelmi for his feedback. This work was performed at NRL. Michael Kuhlman and Don Sofge were funded by ONR grant number N0001416WX01272, “Mobile Autonomous Navy Teams for Information Search and Surveillance (MANTISS)”. Michael Otte was supported by ONR grant number N0001416WX01271. Partial funding for open access provided by the UMD Libraries’ Open Access Publishing Fund.
Author Contributions
Michael J. Kuhlman developed the algorithms, performed the simulations, conducted the analysis and wrote the paper. Michael W. Otte assisted in the development of the algorithms and conducted the literature review. Donald Sofge supervised the research and identified relevant challenges from supporting projects. Finally, Satyandra K. Guptra provided technical direction and gave conceptual advice.
Conflicts of Interest
The authors declare no conflict of interest.
References
- 1.Murphy R.R., Tadokoro S., Nardi D., Jacoff A., Fiorini P., Choset H., Erkmen A.M. Search and Rescue Robotics. In: Siciliano B., Khatib O., editors. Springer Handbook of Robotics. Springer; Berlin/Heidelberg, Germany: 2008. pp. 1151–1174. [Google Scholar]
- 2.Qi J., Song D., Shang H., Wang N., Hua C., Wu C., Qi X., Han J. Search and Rescue Rotary-Wing UAV and Its Application to the Lushan Ms 7.0 Earthquake. J. Field Robot. 2016;33:290–321. doi: 10.1002/rob.21615. [DOI] [Google Scholar]
- 3.Court C. Drone brought in to monitor floods, wild fires, road crashes and missing person searches. The Mirror. Jul 28, 2016.
- 4.Cover T.M., Thomas J.A. Elements of Information Theory. John Wiley & Sons; Hoboken, NJ, USA: 2012. [Google Scholar]
- 5.Pierce J.G. The Maximum Entropy Formalism. MIT Press; Cambridge, MA, USA: 1978. A new look at the relation between information theory and search theory; pp. 339–402. [Google Scholar]
- 6.Krause A., Guestrin C.E. Near-optimal nonmyopic value of information in graphical models; Proceedings of the Twenty-First Conference on Uncertainty in Artificial Intelligence (UAI2005); Edinburgh, UK. 26–29 July 2005; pp. 324–331. [Google Scholar]
- 7.Dames P., Schwager M., Rus D., Kumar V. Active Magnetic Anomaly Detection Using Multiple Micro Aerial Vehicles. IEEE Robot. Autom. Lett. 2016;1:153–160. doi: 10.1109/LRA.2015.2511444. [DOI] [Google Scholar]
- 8.Schwager M., Dames P., Rus D., Kumar V. A Multi-robot Control Policy for Information Gathering in the Presence of Unknown Hazards. In: Christensen I.H., Khatib O., editors. Robotics Research. Springer Tracts in Advanced Robotics. Volume 100. Springer; Cham, Switzerland: 2017. pp. 455–472. [Google Scholar]
- 9.Williams J.L., Fisher J.W., III, Willsky A.S. Performance Guarantees for Information Theoretic Active Inference; Proceedings of the Eleventh International Conference on Artificial Intelligence and Statistics (AISTATS-07); San Juan, Puerto Rico. 21–24 March 2007; pp. 620–627. [Google Scholar]
- 10.Ryan A., Hedrick J.K. Particle filter based information-theoretic active sensing. Robot. Auton. Syst. 2010;58:574–584. doi: 10.1016/j.robot.2010.01.001. [DOI] [Google Scholar]
- 11.Binney J., Sukhatme G.S. Branch and bound for informative path planning; Proceedings of the 2012 IEEE International Conference on Robotics and Automation (ICRA); Saint Paul, MN, USA. 14–18 May 2012; pp. 2147–2154. [Google Scholar]
- 12.Hollinger G.A., Sukhatme G.S. Sampling-based robotic information gathering algorithms. Int. J. Robot. Res. 2014;33:1271–1287. doi: 10.1177/0278364914533443. [DOI] [Google Scholar]
- 13.Kuhlman M.J., Otte M.W., Sofge D.A., Gupta S.K. Maximizing Mutual Information for Multipass Target Search in Changing Environments; Proceedings of the 2017 IEEE International Conference on Robotics and Automation (ICRA); Singapore. 29 May–3 June 2017; pp. 4383–4390. [Google Scholar]
- 14.Koopman B. The theory of search. II. Target detection. Oper. Res. 1956;4:503–531. doi: 10.1287/opre.4.5.503. [DOI] [Google Scholar]
- 15.Waharte S., Trigoni N. Supporting Search and Rescue Operations with UAVs; Proceedings of the 2010 International Conference on Emerging Security Technologies; Canterbury, UK. 6–7 September 2010; pp. 142–147. [Google Scholar]
- 16.Chung T.H., Hollinger G.A., Isler V. Search and pursuit-evasion in mobile robotics. Auton. Robot. 2011;31:299–316. doi: 10.1007/s10514-011-9241-4. [DOI] [Google Scholar]
- 17.Robin C., Lacroix S. Multi-robot target detection and tracking: Taxonomy and survey. Auton. Robot. 2016;40:729–760. doi: 10.1007/s10514-015-9491-7. [DOI] [Google Scholar]
- 18.Dames P., Kumar V. Autonomous Localization of an Unknown Number of Targets without Data Association Using Teams of Mobile Sensors. IEEE Trans. Autom. Sci. Eng. 2015;12:850–864. doi: 10.1109/TASE.2015.2425212. [DOI] [Google Scholar]
- 19.Hollinger G.A., Yerramalli S., Singh S., Mitra U., Sukhatme G.S. Distributed data fusion for multirobot search. IEEE Trans. Robot. 2015;31:55–66. doi: 10.1109/TRO.2014.2378411. [DOI] [Google Scholar]
- 20.Schwager M., Slotine J.J., Rus D. Decentralized, adaptive control for coverage with networked robots; Proceedings of the 2007 IEEE International Conference on Robotics and Automation; Rome, Italy. 10–14 April 2007; pp. 3289–3294. [Google Scholar]
- 21.O’rourke J. Art Gallery Theorems and Algorithms. Oxford University Press; Oxford, UK: 1987. [Google Scholar]
- 22.Tisdale J., Kim Z., Hedrick J.K. Autonomous UAV path planning and estimation. IEEE Robot. Autom. Mag. 2009;16:35–42. doi: 10.1109/MRA.2009.932529. [DOI] [Google Scholar]
- 23.Wong E.M., Bourgault F., Furukawa T. Multi-vehicle Bayesian Search for Multiple Lost Targets; Proceedings of the 2005 IEEE International Conference on Robotics and Automation; Barcelona, Spain. 18–22 April 2005; pp. 3169–3174. [Google Scholar]
- 24.Furukawa T., Bourgault F., Lavis B., Durrant-Whyte H.F. Recursive Bayesian search-and-tracking using coordinated UAVs for lost targets; Proceedings of the 2006 IEEE International Conference on Robotics and Automation; Orlando, FL, USA. 15–19 May 2006; pp. 2521–2526. [Google Scholar]
- 25.Mahler R. “Statistics 102” for multisource-multitarget detection and tracking. IEEE J. Sel. Top. Signal Process. 2013;7:376–389. doi: 10.1109/JSTSP.2013.2253084. [DOI] [Google Scholar]
- 26.Bertuccelli L.F., How J.P. Robust UAV search for Environments with Imprecise Probability Maps; Proceedings of the 44th IEEE Conference on Decision and Control; Seville, Spain. 15 December 2005; pp. 5680–5685. [Google Scholar]
- 27.Shende A., Bays M.J., Stilwell D.J. Toward a mission value for subsea search with bottom-type variability; Proceedings of the 2012 Oceans; Hampton Roads, VA, USA. 14–19 October 2012; pp. 1–5. [Google Scholar]
- 28.Yetkin H., Lutz C., Stilwell D. Utility-based adaptive path planning for subsea search; Proceedings of the MTS/IEEE OCEANS’15; Washington, DC, USA. 19–22 October 2015; pp. 1–6. [Google Scholar]
- 29.Stewart T. Search for a moving target when searcher motion is restricted. Comput. Oper. Res. 1979;6:129–140. doi: 10.1016/0305-0548(79)90025-X. [DOI] [Google Scholar]
- 30.Hollinger G., Singh S., Djugash J., Kehagias A. Efficient multi-robot search for a moving target. Int. J. Robot. Res. 2009;28:201–219. doi: 10.1177/0278364908099853. [DOI] [Google Scholar]
- 31.Khan A., Yanmaz E., Rinner B. Information exchange and decision making in micro aerial vehicle networks for cooperative search. IEEE Trans. Control Netw. Syst. 2015;2:335–347. doi: 10.1109/TCNS.2015.2426771. [DOI] [Google Scholar]
- 32.Bourgault F., Furukawa T., Durrant-Whyte H.E. Coordinated decentralized search for a lost target in a Bayesian world; Proceedings of the 2003 IEEE/RSJ International Conference on Intelligent Robots and Systems; Las Vegas, NV, USA. 27–31 October 2003; pp. 48–53. [Google Scholar]
- 33.Hollinger G.A., Yerramalli S., Singh S., Mitra U., Sukhatme G.S. Distributed coordination and data fusion for underwater search; Proceedings of the 2011 IEEE International Conference on Robotics and Automation; Shanghai, China. 9–13 May 2011; pp. 349–355. [Google Scholar]
- 34.Otte M., Kuhlman M., Sofge D. Competitive Two Team Target Search Game with Communication Symmetry and Asymmetry; Proceedings of the 12th International Workshop on Algorithmic Foundations of Robotics (WAFR 2016); San Francisco, CA, USA. 18–20 December 2016. [Google Scholar]
- 35.Lanillos P., Besada-Portas E., Lopez-Orozco J.A., de la Cruz J.M. Minimum time search in uncertain dynamic domains with complex sensorial platforms. Sensors. 2014;14:14131–14179. doi: 10.3390/s140814131. [DOI] [PMC free article] [PubMed] [Google Scholar]
- 36.Perez-Carabaza S., Besada-Portas E., Lopez-Orozco J.A., de la Cruz J.M. A real world multi-UAV evolutionary planner for minimum time target detection; Proceedings of the 2016 Genetic and Evolutionary Computation Conference; Denver, CO, USA. 20–24 July 2016; pp. 981–988. [Google Scholar]
- 37.Meghjani M., Manjanna S., Dudek G. Multi-target rendezvous search; Proceedings of the 2016 IEEE/RSJ International Conference on Intelligent Robots and Systems; Daejeon, Korea. 9–14 October 2016; pp. 2596–2603. [Google Scholar]
- 38.Chung T.H., Carpin S. Multiscale search using probabilistic quadtrees; Proceedings of the 2011 IEEE International Conference on Robotics and Automation; Shanghai, China. 9–13 May 2011; pp. 2546–2553. [Google Scholar]
- 39.Lau H., Huang S., Dissanayake G. Probabilistic search for a moving target in an indoor environment; Proceedings of the 2006 IEEE/RSJ International Conference on Intelligent Robots and Systems; Beijing, China. 9–15 October 2006; pp. 3393–3398. [Google Scholar]
- 40.Yang Y., Minai A.A., Polycarpou M.M. Decentralized cooperative search by networked UAVs in an uncertain environment; Proceedings of the 2004 American Control Conference; Boston, MA, USA. 30 June–2 July 2004; pp. 5558–5563. [Google Scholar]
- 41.Sato H., Royset J.O. Path optimization for the resource-constrained searcher. Nav. Res. Logist. 2010;57:422–440. doi: 10.1002/nav.20411. [DOI] [Google Scholar]
- 42.Narendra P.M., Fukunaga K. A branch and bound algorithm for feature subset selection. IEEE Trans. Comput. 1977;26:917–922. doi: 10.1109/TC.1977.1674939. [DOI] [Google Scholar]
- 43.Held M., Karp R.M. The traveling-salesman problem and minimum spanning trees. Oper. Res. 1970;18:1138–1162. doi: 10.1287/opre.18.6.1138. [DOI] [Google Scholar]
- 44.Pearl J. Heuristics: Intelligent Search Strategies for Computer Problem Solving. Addison-Wesley Pub. Co., Inc.; Reading, MA, USA: 1984. [Google Scholar]
- 45.Chekuri C., Pal M. A recursive greedy algorithm for walks in directed graphs; Proceedings of the 46th Annual IEEE Symposium on Foundations of Computer Science (FOCS’05); Pittsburgh, PA, USA. 23–25 October 2005; pp. 245–253. [Google Scholar]
- 46.Galceran E., Carreras M. A survey on coverage path planning for robotics. Robot. Auton. Syst. 2013;61:1258–1276. doi: 10.1016/j.robot.2013.09.004. [DOI] [Google Scholar]
- 47.Zelinsky A., Jarvis R., Byrne J.C., Yuta S. Planning Paths of Complete Coverage of an Unstructured Environment by a Mobile Robot; Proceedings of the 1993 International Conference on Advanced Robotics; Tsukuba, Japan. 8–9 November 1993; pp. 533–538. [Google Scholar]
- 48.Choset H. Coverage of known spaces: The boustrophedon cellular decomposition. Auton. Robot. 2000;9:247–253. doi: 10.1023/A:1008958800904. [DOI] [Google Scholar]
- 49.Kwan M.K. Graphic programming using odd or even points. Chin. Math. 1962;1:273–277. [Google Scholar]
- 50.Thrun S., Burgard W., Fox D. Probabilistic Robotics. MIT Press; Cambridge, MA, USA: 2005. [Google Scholar]
- 51.Likhachev M., Gordon G.J., Thrun S. Advances in Neural Information Processing Systems 16: Proceedings of the 2003 Conference. MIT Press; Cambridge, MA, USA: 2004. ARA*: Anytime A* with provable bounds on sub-optimality; pp. 767–774. [Google Scholar]
- 52.Harris L.R. The heuristic search under conditions of error. Artif. Intell. 1974;5:217–234. doi: 10.1016/0004-3702(74)90014-9. [DOI] [Google Scholar]
- 53.Lauri M., Ritala R. Optimal sensing via multi-armed bandit relaxations in mixed observability domains; Proceedings of the 2015 IEEE International Conference on Robotics and Automation; Seattle, WA, USA. 26–30 May 2015; pp. 4807–4812. [Google Scholar]
- 54.Gittins J.C. Bandit Processes and Dynamic Allocation Indices. J. R. Stat. Soc. Ser. B. 1979;41:148–177. [Google Scholar]
- 55.Kruskal J.B. On the shortest spanning subtree of a graph and the traveling salesman problem. Proc. Am. Math. Soc. 1956;7:48–50. doi: 10.1090/S0002-9939-1956-0078686-7. [DOI] [Google Scholar]
- 56.Edelkamp S., Schroedl S. Heuristic Search: Theory and Applications. Elsevier; Waltham, MA, USA: 2011. [Google Scholar]
- 57.Mellinger D., Kumar V. Minimum snap trajectory generation and control for quadrotors; Proceedings of the 2011 IEEE International Conference on Robotics and Automation; Shanghai, China. 9–13 May 2011; pp. 2520–2525. [Google Scholar]
- 58.Karaman S., Frazzoli E. High-speed flight in an ergodic forest; Proceedings of the 2012 IEEE International Conference on Robotics and Automation; Saint Paul, MN, USA. 14–18 May 2012; pp. 2899–2906. [Google Scholar]
- 59.Liberzon D. Calculus of Variations and Optimal Control Theory: A Concise Introduction. Princeton University Press; Princeton, NJ, USA: 2012. [Google Scholar]
- 60.Stone L.D. Theory of Optimal Search. Volume 118 Academic Press, Inc.; New York, NY, USA: 1976. [Google Scholar]
- 61.Van Der Walt S., Colbert S.C., Varoquaux G. The NumPy array: A structure for efficient numerical computation. Comput. Sci. Eng. 2011;13:22–30. doi: 10.1109/MCSE.2011.37. [DOI] [Google Scholar]
- 62.Hagberg A.A., Schult D.A., Swart P.J. Exploring network structure, dynamics, and function using NetworkX; Proceedings of the 7th Python in Science Conference (SciPy2008); Pasadena, CA, USA. 19–24 August 2008; pp. 11–15. [Google Scholar]
- 63.Olano M., Hart J.C., Heidrich W., Lindholm E., Mark B., McCool M., Perlin K. [(accessed on 27 October 2017)];Real-Time Shading. 2001 SIGGRAPH 2001 Course Notes. Available online: https://www.csee.umbc.edu/~olano/s2001c24/
- 64.Lagae A., Lefebvre S., Cook R., DeRose T., Drettakis G., Ebert D.S., Lewis J.P., Perlin K., Zwicker M. A survey of procedural noise functions. Comput. Graph. Forum. 2010;29:2579–2600. doi: 10.1111/j.1467-8659.2010.01827.x. [DOI] [Google Scholar]
- 65.Spencer K. OpenSimplexNoise.java. [(accessed on 2 March 2017)]; Available online: https://gist.github.com/KdotJPG/b1270127455a94ac5d19.
- 66.Svensson A. Opensimplex 0.2. [(accessed on 2 March 2017)]; Available online: https://pypi.python.org/pypi/opensimplex/
- 67.Shah B.C., Gupta S.K. Speeding Up A* Search on Visibility Graphs Defined over Quadtrees to Enable Long Distance Path Planning for Unmanned Surface Vehicles; Proceedings of the Twenty-Sixth International Conference on International Conference on Automated Planning and Scheduling (ICAPS’16); London, UK. 12–17 June 2016; pp. 527–535. [Google Scholar]
- 68.Imaging Resource Guide. [(accessed on 13 April 2012)]; Available online: https://www.edmundoptics.com/resources/industry-expertise/imaging-optics/imaging-resource-guide/
- 69.Zhou R., Hansen E.A. Beam-Stack Search: Integrating Backtracking with Beam Search; Proceedings of the Fifteenth International Conference on International Conference on Automated Planning and Scheduling; Monterey, CA, USA. 5–10 June 2005; pp. 90–98. [Google Scholar]
- 70.Viscusi W. The Value of Life. Harvard Law School John M. Olin Center for Law, Economics and Business Faculty Discussion Papers; Cambridge, MA, USA: 2005. Technical Report Paper 517. [Google Scholar]