Skip to main content
Sensors (Basel, Switzerland) logoLink to Sensors (Basel, Switzerland)
. 2020 Aug 7;20(16):4420. doi: 10.3390/s20164420

A Method for Evaluating and Selecting Suitable Hardware for Deployment of Embedded System on UAVs

Nicolas Mandel 1,2,*, Michael Milford 1,2, Felipe Gonzalez 1,2
PMCID: PMC7472300  PMID: 32784776

Abstract

The use of UAVs for remote sensing is increasing. In this paper, we demonstrate a method for evaluating and selecting suitable hardware to be used for deployment of algorithms for UAV-based remote sensing under considerations of Size, Weight, Power, and Computational constraints. These constraints hinder the deployment of rapidly evolving computer vision and robotics algorithms on UAVs, because they require intricate knowledge about the system and architecture to allow for effective implementation. We propose integrating computational monitoring techniques—profiling—with an industry standard specifying software quality—ISO 25000—and fusing both in a decision-making model—the analytic hierarchy process—to provide an informed decision basis for deploying embedded systems in the context of UAV-based remote sensing. One software package is combined in three software–hardware alternatives, which are profiled in hardware-in-the-loop simulations. Three objectives are used as inputs for the decision-making process. A Monte Carlo simulation provides insights into which decision-making parameters lead to which preferred alternative. Results indicate that local weights significantly influence the preference of an alternative. The approach enables relating complex parameters, leading to informed decisions about which hardware is deemed suitable for deployment in which case.

Keywords: UAV, computer architecture, decision making, navigation, semantics

1. Introduction

Unmanned Aerial Vehicles (UAVs) are playing an increasingly important role in modern society. The past decade has seen an increased use of UAVs, with applications ranging from wildlife and agricultural monitoring [1,2,3], over racing [4], industrial monitoring [5], packet delivery [6], and search and rescue [7] to planetary exploration [8]. Solutions to computer vision problems, such as object detection [9], and robotics problems, such as localization [10], have been developed and disseminated at a rapid pace, with promising results on benchmarks [11]. Despite experiments on real robots being the common mode of evaluation for robotics applications [11], reproducing results requires a considerable effort [12]. Furthermore, computational performance has traditionally been considered a secondary factor [10], assuming that hardware progress will eliminate this issue.

At the same time, Wirth’s law states that the increasing complexity in software outgrows the increase in computational power. Additionally, UAVs are heavily constrained through their Size, Weight, Power, and Computation [6,13,14,15]. The main limitation for small multirotor UAVs is their flight time, which is bound by the battery capacity, which is in turn limited by the Size and Weight of the UAVs. Over 90% of Power is consumed by the motors supplying the thrust; however, the influence of computational capabilities on Power is complex. While increasing computational load uses more Power directly, faster computation can greatly reduce total power consumption for the same task due to reduced time spent at hover and lower accelerations, to up to 6 times faster completion of tasks [6].

Using the maximum computation available by offloading parts of the perception—planning—control loop over a network connection is the most common solution [6,16,17,18,19,20]. This method is highly effective, however it introduces networking effects and drop-outs, with potentially detrimental consequences when used in real-time cycles [21,22]. Furthermore, several remote-sensing applications cannot rely on network connections, making onboard computation the final goal. Some research has focused on the onboard application of algorithms [4,23,24,25], however most are the result of empirical processes. Only a finite amount of research is concerned with detailed evaluation of software and hardware performance [23,26,27]. Using a powerful laptop for computation is a possible solution, however Size and Weight do not always allow for such a payload. In this paper, the difference between onboard and real-time as illustrated in Figure 1 is termed configuration, while the combination of a software configuration and a specific hardware as illustrated in Figure 2 is termed alternative.

Figure 1.

Figure 1

Modules developed in [35], onboard (top) and a real-time (bottom) configuration, with the system load distributed across a PC (purple) and an onboard computer (magenta). The thin dashed line indicates a serial connection and the wireless symbol a network connection. Differences in software set-up are called configurations in this work.

Figure 2.

Figure 2

The three alternatives evaluated in this work. Differences in software configurations as shown in Figure 1 are shown on the x-axis. The y-axis denotes an additional mechanical variation through changing the companion computer.

The question as to which hardware is considered as a suitable solution is therefore highly complex and requires consideration of mechanical, electrical, and computational constraints imposed on small UAVs. Boroujerdian et al. [6] uncovered the influence of computation on power consumption, while Krishnan et al. [27] connected mechanical and computational performance in a “roofline” model. However, to the best of our knowledge, no method exists that holistically combines and analyses all four of these factors together. To this end, a decision-making approach from mathematical economics, the analytic hierarchy process (AHP) [28], is proposed.

Additionally, the question as to which indicators underline the quality of software is posed. While fast computation reduces flight time in some cases, in others the benefit is marginal, especially when tasks do not require compute-intensive dynamic recalculation steps [6]. On the other hand, some UAVs may have supplementary tasks to fulfill, such as manipulation [29,30], with different needs, such as the capacity to accommodate other software. These diverging specifications call for a framework with a balance between flexibility and rigidity in definitions of quality and associated metrics. The use of the ISO 25000 family “Systems and Software Quality Requirements and Evaluation” (SQUARE) [31,32,33] is proposed to meet these requirements. Software development is an intricate process, especially for robotic systems, which are commonly evaluated in experiments and therefore require implementation on realistic hardware [11]. Standardized frameworks such as the Robot Operating System (ROS) are universal and alleviate issues with interoperability, however, reproducing results remains an issue [12]. Pinpointing bottlenecks when implementing a software on a hardware system is a difficult task and requires detailed profiling [34].

In this work, we demonstrate the methods using a software-in-the-loop (SITL) ROS package developed and validated by the authors [35]. Figure 3 shows the simulation in the process. The left image shows the Gazebo simulation environment, the top panel shows the UAV view with a marker visible, and the right panel shows the reconstructed map.

Figure 3.

Figure 3

A software-in-the-loop (SITL) simulation in the Gazebo Environment is shown on the left. The UAV is conducting an autonomous remote-sensing search mission for a target marker. The top panel shows the view of the UAV; the right panel shows the map of detected markers.

The main driver of the subsequent hardware-in-the-loop (HITL) development is the preference of evaluation over experimentation as a factor of successful developments as put forward by Corke et al. [11]. Two embedded devices—a nVidia Jetson Nano and a Raspberry Pi 3A+—with deviating properties are evaluated. The Nano is computationally powerful, while incorporating a large volume and being heavier. The Pi is smaller, with less powerful computation.

Profiling techniques are used to inspect the computational performance of the software–hardware combination and are put into relation with one another using the SQUARE family. The computational performance is combined with electrical and mechanical factors through the AHP to provide numerical values which alternative is considered best.

Three case studies with different input weights for the AHP are proposed to verify the approach. The recorded parameters from the HITL simulation are used to show how the results change with varying the weights. Additionally, a Monte Carlo (MC) simulation is used over the admissible input space, which allows to compare the effects of different relative weights to give preference to another alternative.

Figure 1 presents one example of the differences between an onboard and a real-time system in the context of UAV onboard decision-making [35]. The split of the nodes is dependent on the frequency and the degree of closeness to hardware required by hardware components.

In this work, a methodical approach to HITL simulations is employed. The transition steps from SITL to HITL and their effects down the line of development are shown. A framework for evaluating the quality of software is proposed. Additionally, the AHP is drawn on for combining requirements along different dimensions, mainly mechanical and computational. Furthermore, to the best of our knowledge, the amount of research concerned with a systematic transition from simulation to experimental deployment is limited and we aim to augment the literature by providing an evaluation method.

2. Background

Evaluating system performance can be a slow, methodical task [34]. However, it is necessary to prevent detrimental effects down the line of development and deployment of UAVs. These can have catastrophic consequences when considering the deployment of robotic systems in critical conditions, such as near urban areas or oil rig inspection, where hardware failure may result in injuries to personnel on the ground or damage worth millions of dollars and years of work.

Models to evaluate the performance and potential of software on specific hardware are readily available. One example is the commonly known “roofline” model [36]. However, improvements implied by these models are gained through hardware-near programming techniques requiring profound knowledge of memory and CPU access. This is difficult to achieve for programmers working in a meta-environment such as ROS, which employs a complex variety of different tools in a software stack [12,37]. Models for evaluating the performance of GPUs in the context of contemporary deep learning approaches inspected the timeliness and performance [38] and the potential to be used with common embedded platforms [26]. The applicability of one of these algorithms on embedded platforms in the context of UAVs was evaluated by Kyrkou et al. [23] and subsequently a dedicated architecture solution was proposed [39].

The constraints on the computational capabilities of small multirotor UAVs caused by reduced availability of Size, Weight, and Power require a careful balance between computer hardware and algorithm efficiency [6,13,14,15]. Krishnan et al. [27] tied the computational performance together with mechanical properties of a UAV in the derivation of a modified “roofline” model [36] to provide hard limits on flying velocity. However, their model only considers obstacle avoidance as a task and neglects higher level navigation tasks [40]. While Size, Weight, and Power are relatively straightforward to approximate, Computation is more difficult to put into numbers. Tools to passively record the computational performance—commonly called “profiling” tools—are available in the scientific literature [22,23,26,27,36], as well as in industry [31,34,41]. However, the information gathered from these systems is either used to identify computational bottlenecks [34] or not used to make decisions at all. The use of the ISO 25000 SQUARE software model is proposed to relate computational performance indicators extracted from profiling.

2.1. The ISO SQUARE Family

The SQUARE family was published in the early 2010s [31]. It provides eight characteristics, each with varying sub-characteristics, on which to evaluate the quality of a software, and explicitly extends to embedded hardware–software systems. Which characteristics to use and at what point to define what is to be evaluated (e.g., at function calls, at server accesses, etc.) is up to the discretion of the developer, however it requires explicit definition. ISO 25021 defines quality measure elements, while ISO 25023 proposes some metrics on which to evaluate the sub-characteristics, as well as how to develop and combine these [33]. The analysis in this work is reduced to the following characteristics.

  1. Performance Efficiency

  2. Compatibility

  3. Reliability

The remaining criteria of the ISO are Functional Suitability, Usability, Security, Maintainability, and Portability. ROS as a standardized framework that handles Maintainability and Portability [12]. Functional Suitability, Usability, and Security are equal across all configurations for the evaluated software and are therefore not considered in this work. If alternatives would display differences across these characteristics, they would require integration into the hierarchy and thus the analysis.

CPU load and memory are recorded to evaluate Performance Efficiency and Compatibility, as these are commonly considered the main determining performance factors [36]. Resource Utilization is the sub-characteristic of Performance Efficiency targeted in this research. Time behavior is not evaluated due to its inherent issues discussed in the literature [21,22]. GPU usage has been broadly evaluated in the literature [23,26,27], and as the evaluated application does not target it [35], it is omitted. Capacity is deemed not adequate to evaluate, because the system load only changes minutely over time and inputs cannot be scaled infinitely.

For Compatibility, the sub-characteristic Interoperability is equated through ROS. This research focuses on Co-Existence, which refers to the property of not negatively influencing other software running on the same system.

Fault Tolerance and Recoverability are sub-characteristics of Reliability, which are governed by the flight controller. Availability is a network property not considered adequate for the evaluation of the system; however, Maturity is evaluated through the number of faults.

Commonly, profiling is used as an approach to identify bottlenecks in the system [6,34]. However, bottlenecks reduce issues to a single part of the system and neither consider the impact on the entire system nor other dimensions beyond computation. The use of the AHP is proposed to alleviate this issue, which was developed by Thomas Saaty in the late twentieth century [28] and has been applied to a diverse set of decisions systems [42], including, but not limited to, medical [43], mining [44], flood susceptibility [45], and transfer learning [46] analyses.

3. Materials and Methods

3.1. Analytic Hierarchy Process

In the AHP, a hierarchy of criteria, termed levels in the following sections, is developed. The criteria at each level are compared against one another and assigned a weight between 1 and 9 to describe their relative importance [42]. The weights are commonly assigned subjectively by stakeholders, for example, through consensus voting [28] or sampling from expert opinions [45]. While other methods are available, the choice of weights is beyond the scope of this paper and discussed in [28,42,47]. To illustrate, Power is considered twice as important as Weight and Weight three times more important than Size. A matrix is constructed with these weights and its normalized maximal Eigenvector is calculated, which yields the local priority of each criterion. Only matrices with consistencies as calculated by Equation (1),

CI=λmaxnn1 (1)

with λmax as the maximum Eigenvalue and n the dimension of the matrix, are allowed, as some constellations are considered unrealistic. For example, if Weight is twice as important as Size and Power is three times as important as Weight, Size cannot be more important than Power, as this would violate transitivity. However, small inconsistencies, which are bound to arise due to the constrained scale, are allowed and therefore the Consistency Index CI is divided by an empirically calculated RCR=CIR, to result in a value which should be below 0.1 [28,43]. This procedure is repeated for each hierarchical level, where the global priority is calculated through multiplication with the priority of the subsuming characteristic from the next higher level, thus resulting in a hierarchy of priorities.

The alternatives are compared pairwise with respect to each of the criteria and result in a relative preference for either one of the alternatives. For example, if one alternative is twice as heavy as another one, its preference for weight will be 12. These preferences are then multiplied with the priorities to result in a priority for each criterion for each alternative.

This method allows the hierarchical characteristics and sub-characteristics of the SQUARE family to be related to one another, as well as put into context with the criteria Power, Weight, and Size commonly mentioned in the literature [6,13,14]. It furthermore allows to evaluate discrete alternatives of embedded systems and put values into context with one another. Figure 4 shows the hierarchy developed and used in the following sections.

Figure 4.

Figure 4

The final analytic hierarchy process (AHP) hierarchy used in the evaluation steps. The first level (L1) depicts the parameters common to literature [6]. The second level (L2) includes the parameters that are derived from the SQUARE family [31] and the third (L3) includes common computational parameters [33,36].

3.1.1. Case Studies

The global preference of the available alternatives largely depends on the weights assigned to each of the criteria at the different levels of the hierarchy. Three cases inspired from remote sensing scenarios are used to derive weights for the levels of the AHP. These weights are used to calculate different priorities, which are then multiplied with the same preference values for the alternatives resulting from profiling as described in Section 4.2. Without loss of generality, the preference values from the same experiments are used to illustrate the influence of differing weights on final priority. The following three tasks are chosen.

  1. A fully autonomous UAV performing oil rig inspection [5]

  2. A UAV in a controlled environment with a suspended arm [29,30]

  3. An additional module on a UAV to improve performance by integrating semantics into its navigation [35]

These cases lead to assumptions concerning the assignment of weights, which require revision until the matrices can be considered consistent as defined by Equation (1). The weight matrices are explained in detail in Section 4.5.

3.1.2. Monte-Carlo Simulation

Each of the alternatives (presented in Figure 2) can result as the best alternative given certain input weights. A MC simulation is conducted to find these weights. The space of consistent weight matrices is searched for the most dominant results, and the relative weights are presented. The results collected from the initial experiments—detailed in Section 4.5 and shown in Table 1—are used as inputs for the MC simulation. Ten-thousand iterations are run to generate values for the upper right triangular matrix from the original range from 1 to 9 and their inverses f:SX,f(s)=1s, with D=XS, D_=17 admissible values [28]. Values from D are chosen at random to construct the upper right triangular matrix M, with the lower triangular matrix filled with the inverse, so mj,i=1mi,jj>i. The resulting matrix M is checked for consistency using Equation (1) and added to the set of admissible matrices only if it is consistent.

Table 1.

Profiling results for the three alternative cases presented in Figure 2.

Device Nano Pi
Load RT Onb RT Unit
CPU Load Max 82.9 91.3 94.5 %
Used Mem Max 547 966 218 MB
Avail Mem Min 3249 2830 154 MB
Current 3.981 4.233 3.689 A
Faults 1 0 310 #
Volume 0.4464 0.4464 0.0672 l
Weight 0.252 0.252 0.044 kg

To clarify, for rnk(M)=2 this leads to 17 possible combinations, because there is only one degree of freedom, m1,2, which can take all 17 values from the admissible set D. For 3 and 4, 1228 and 479 consistent matrices are saved, respectively. The set of applicable matrices is denoted with Yi,i2,3,4. Algorithm 1 details the process on calculating the final score for each alternative. Mi denotes a matrix from the set of consistent matrices. v^j the global priority after multiplication with the higher level j1. P denotes the matrix of recorded values derived from Table 1 and Section 4.4 and p^ the final priority of the alternative. The 10,000 resulting global priorities p^ are stored along with their respective weight matrices, M. In a final step, the constellation from the global priorities which would have led to the clearest preference of a given alternative are calculated and the weight matrices for that option are extracted for qualitative inspection.

Algorithm 1 Monte Carlo Simulation
  • for 1 to 10,000 do
    • MMjYi
    • vj max. Eigenvector of Mj
    • v^jvj·v^j1
    • p^P·v^j
    • returnp^, M
  • end for

4. Experimental Design

This work is targeting the HITL development step shown in Figure 5. Algorithm development, numerical simulations, and SITL—shown in Figure 3—were conducted in previous research and the performance of the developed package was verified [35]. The current work focuses on translating the simulation with the package into a distributed set-up, with the simulation running on a host PC—connected via Ethernet to the router—and parts of the package—in variations shown in Figure 1—running on the embedded system. The flight controller is connected to each device with an independent serial connection. This way it communicates with the simulator as well as the embedded computer.

Figure 5.

Figure 5

A generic autonomy development cycle, adapted from Ladosz et al. [48]. The arrow depicts the line of development, with the shading indicating the completeness. This work focuses on the transition included in Phase II.

4.1. System Specifications

All development procedures are undertaken on a Dell Notebook with an nVidia GeForce GTX 1060 Max-Q graphics card and an Intel i9-8950HK Processor with 16 GB of RAM and 24 GB of Swap. Ubuntu 18.04 with ROS melodic is used alongside Gazebo-9 for the simulation and development. A mix of C++ and Python nodes are used during development. An open source node developed in-house is used for the image detection, while all other nodes were verified previously [35]. A vanilla version 10.1 of the Px4 Firmware on a PixHawk 4 is used. OpenCV version 3.4.6 with contrib modules is used for image processing. The network setup is run over a dedicated router within 1 m in line-of-sight, operating in the 5 to 2.4 GHz range to minimize network effects. The implementation details to enable reproduction [12] are detailed in Appendix A.

4.2. Development Steps

The simulation environment is shown in Figure 3. An UAV is exploring its environment and uses the camera feed to look for markers. If a certain type of marker is detected, the position is recorded and the path recalculated under consideration of known and unknown areas, as well as location of markers. Ten different marker placements, which were used for SITL [35], are used to record values according to Section 4.4 for each alternative shown in Figure 2.

Translating from SITL to HITL requires consideration of non-local communication. Packages are downloaded to the more powerful embedded device, the Jetson Nano. In a first step, the device is connected via Ethernet to the router, as shown in the first row of Figure 6, and one simulation is run with the real-time configuration of the package, as shown in Figure 1. Upon successful completion without notable errors or warnings, one simulation in onboard configuration is run, shown in the last column of Figure 6. When this test passes without notable errors, the network connection is switched to wireless and the test is repeated with both configurations, shown in the second row of Figure 6. When all tests are passed, the package is translated to the less powerful embedded device, the Raspberry Pi, as shown in the last column of Figure 6.

Figure 6.

Figure 6

Hardware-in-the-loop set-ups. Each row shows changes in the hardware set-up and each column on the right changes in the software. The first row shows the transition from SITL to HITL using an Ethernet connection. The first column shows a real-time configuration as shown in Figure 1 and the the second column shows an onboard configuration. The second row shows the transition to a wireless connection. The third row shows the transition to the second embedded device.

Each of these steps has an impact on the performance of the system, which may manifest itself in different ways and can be counteracted through adaptive software or hardware measures before continuing with the next step. The impact of these measures down the line of development should not be neglected, and therefore these steps are kept separate. Each measure requires re-synchronizing the software across the devices.

4.3. Hardware and Software Alternatives

The preliminary development steps and checks lead to three software–hardware alternatives as candidates for the final evaluation detailed in Section 4.4. The configurations are chosen such that they represent opposite ends of the spectrum: the Nano is a powerful computing platform, with a selection of connectors and a large heat sink, therefore being larger and heavier than the Raspberry Pi. The Pi is a fraction of the Size and Weight of the Nano, however the decreased Size comes at the expense of connectors and processing power. The alternatives are shown in Figure 2.

The baseline alternative is the Nano real-time alternative, shown in the top left of Figure 2. The nodes running on the Nano are framed in pink in the bottom row of Figure 1, while all other nodes run on the host PC. This is equivalent to a distributed system where hardware-near and higher-frequency processing is done on the onboard computer, while higher-level, lower-frequency computational tasks are offloaded [6,40].

The high computational capacity of the Nano makes the system overpowered for these reduced tasks, therefore the other two alternatives shown in Figure 2 are evaluated to explore diverging specifications:

  1. Can the computational load of the onboard computer be increased, allowing for a higher level of autonomy, without a detrimental impact on its performance [6]?

  2. Can a smaller computer be used, allowing for a lighter payload and improved flight mechanics [27]?

These three alternatives are evaluated with the same experiments detailed in Section 4.4, after the development steps of Figure 6 are completed.

4.4. Profiling

Profiling—passive recording of system performance parameters—is undertaken with an independent ROS package. The official rosprofiler package [41] is updated to fit current psutil methods and message fields are adapted. Specifically, power logging, if available on the host, is included; CPU load is consolidated across all cores; virtual memory (used and available) as well as swap (used and available) are included. The package queries the host OS through psutil at a frequency of 5 Hz to collect samples. The number of samples, the average, the standard deviation, and the maximum or minimum—whichever is more conservative—over the samples is published at a frequency of 0.5 Hz. A client node is added, which is running on the notebook and records the values matching a predefined list of hosts and nodes. It writes the values to spreadsheet file at the end of each simulation run.

Postprocessing

The first and last five recorded values (equivalent to ten seconds each) are omitted during post-processing to reduce the influence of start-up and shutdown processes. Following this step, the number of samples per message is checked. Due to the publishing and querying frequencies, the number of samples should be ~10. If it is less than 8, a fault is recorded and all values of the sample omitted from further processing. This fault indicator has become evident during the development steps detailed in Figure 6. The current draw of the Raspberry Pi cannot be recorded through the OS, and therefore the nominal current draw of the device is multiplied with the CPU load as an approximation.

Using extreme values is preferred over average values in computational evaluation and aerospace systems, to account for worst case scenarios. The values of interest are therefore the maximum CPU load, the maximum used memory, as well as the minimum available memory. The 75th percentile value is extracted, to introduce robustness against outliers. These factors were determined through the inspection of intermittent development steps as shown in Figure 6.

The values recorded need to be consolidated into singular values and compared pairwise to map between 0 and 9 [28,42], depending on what is considered to be a priority. For Size comparisons, the volume of an, approximately square, 3D printed enclosure is measured: V=l·w·h. Both devices are weighed including their cases. An UAV, including a battery and excluding an onboard computer, is weighed: wUAV=1322 g. The relative increase in weight in percent, %w=wonbwUAV+wonb, is calculated. Power is commonly used as a proxy for flight time [6] and nominal values are used to calculate a baseline power usage P0:

P0=U0·(I·t)·ct0 (2)

With values U0 being the average voltage rating, calculated through U0=ncells*Ucell, with ncells=3 and Ucell=3.7V, common for UAV LIPO batteries. c is a safety factor for battery drainage, for which 0.8 is used. (I·t) is a capacity rating in Amph for batteries, for which 4.0 is used. t0 is a nominal flight time at hover, for which t0=13, equal to 20 min of flight time is used. As the decrease in flight time caused by the power consumption, without additional performance effects [6], is of interest, the new flight time is calculated using the additional electrical power consumption by the onboard computer calculated through Pe=V·I, evaluating to

tf=U0·(I·t)P0+Pe (3)

The influence of additional Weight on the flight time is omitted, because its influence is considered marginal in comparison to the relative decrease in flight time through additional power consumption Δt=t0tft0, which serves as a reasonable first approximation. The power draw of the device is either calculated through multiplication of the nominal voltage with the recorded current.

Computational performance is determined through the evaluation of Resource Utilization, Co-Existence, and Maturity. For Resource Utilization, CPU load, and memory usage are recorded.

For Co-Existence, available memory is recorded and CPU capacity calculated through 1 CPU load. Memory values are recorded as percentages of the nominal system capacity, with the capacity of the Nano being 4096 MB and the Raspberry Pi being 512 MB. These values are used for the comparison.

If the faults recorded are either 0 or 1, their value is considered equivalent. Otherwise, the logarithms are used as inputs for relative importance.

Figure 4 depicts the final hierarchy, which is to be used for the evaluation. The first level is derived from values common across literature. The second level is based on the SQUARE family [31] and the third level are common values from computational architectures [36].

4.5. Case Studies

4.5.1. Case 1—Oil Rig Inspection

The weights for the case of oil rig inspection are shown in Figure 7. The following assumptions lead to these weights; Computation would be most important, with Power following, due to the relationship uncovered by Boroujerdian et al. [6]. Size should be less important, albeit more important than Weight due to limited space. Reliability would be most important, as failures could have catastrophic consequences. Memory should be considered more important than CPU for both cases, because this would likely be the constraining factor for system updates in the distant future.

Figure 7.

Figure 7

Weights put into the analysis for the case of an oil rig inspection. The top row shows the first two levels, the bottom row the third level. Only the upper diagonal weights are shown for simplicity. Darker colors indicate less preference, lighter colors more preference.

4.5.2. Case 2—Suspended Arm

The weights for the assumed case of a suspended arm in a controlled environment are shown in Figure 8. Size and Weight should be considered most important, because the suspended arm should yield a large increase in Weight, coming close to legal limits. Power should be considered least important, as the controlled environment would allow for quick exchange of batteries. On the computational level, compatibility should be considered most important, because the control of the arm would require implementation space. Reliability should be considered least important, as motion capture systems could serve as a fallback. Memory should be considered more important than CPU, as the control of the arm could require additional software tools and slower CPU cycles could be compensated through time spent at hover.

Figure 8.

Figure 8

Weights put into the analysis for the case of a suspended arm. The top row shows the first two levels, the bottom row the third level. Only the upper diagonal weights are shown for simplicity. Darker colors indicate less preference, lighter colors more preference.

4.5.3. Case 3—Additional Module

Figure 9 shows the weights for the case of an additional module placed on an UAV. The assumptions are made that a module would have strict requirements on Size and Weight, because it would add to the total load. Power would be moderately important. Performance would be more important than compatibility, since the hardware would be entirely dedicated to the software module. Therefore, requirements on free space would be secondary, as would reliability, as the module would be considered nonessential. CPU performance would be more important than memory, as CPU load would likely be the first bottleneck.

Figure 9.

Figure 9

Weights put into the analysis for the case of an additional developed module. The top row shows the first two levels, the bottom row the third level. Only the upper diagonal weights are shown for simplicity. Darker colors indicate less preference, lighter colors more preference.

5. Results

Preliminary development steps, detailed in Section 4.2 and shown in Figure 6, are the reason for the following changes compared to SITL. First, the image type is changed to a compressed representation due to networking effects [21,22], which causes an increase in CPU load. Second, the MAVROS node responsible for translating between ROS and Mavlink is required to run on the onboard computer, increasing its load. Third, buffer sizes are increased for all messages except imaging. Fourth, the serial port speed is increased to 921,600 to allow for background messaging, increasing susceptibility to transmission errors. Fifth, the system load background usage through OS services is decreased. The final configuration for experiments are documented in Table A1 in Appendix A.

5.1. Profiling

Table 1 shows the values collected across the ten simulation runs exemplified by Figure 3. The values are collected for each of the three variations shown in Figure 2 and postprocessed according to Section 4.4.

The computational load is near the maximum across all devices, while the used memory is scaled according to the capacity of the device. The available memory of the Pi is much lower, in absolute as well as relative values. These effects can be explained by OS scheduling and paging techniques beyond the scope of this work. Current draw appears to be near the limits as well, which were recorded on the Nano and approximated on the Pi. The number of faults show a great variation. The Pi displays a substantial increase in number of faults compared with the Nano, while its Size and Weight are one order of magnitude lower than the Nano’s.

5.2. Case Studies

Figure 10 and Table 2 show the results of the case study. The first case of oil rig inspection leads to the result that the Nano in a real-time configuration is preferred over an onboard configuration. This can be explained through the omission of networking effects, which are addressed in the literature [21,22]. The second and third case show that the Pi can be a highly preferred alternative under relative priorities, despite the large count of faults. The Pi is a better alternative when mechanical requirements prevail, as described in Section 4.5.

Figure 10.

Figure 10

Relative preference for the case studies. The y-axis shows the relative preference, the x-axis a bar for each alternative: green for the Pi-real-time, blue for the Nanoreal-time and orange for the Nano-onboard alternative.

Table 2.

Relative preferences for each alternative for the three case studies. Higher values indicate higher preference. Bold numbers indicate which alternative is preferred/the best for each column.

Device Nano Pi
Load RT Onb RT
Inspection 0.3832 0.3818 0.2350
Suspended Arm 0.2267 0.2187 0.5546
Add. Module 0.2095 0.2087 0.5828

The first case, as shown in Figure 7, places an emphasis on Power and Computation, specifically reliability. These are the characteristics where the Nano has better values. Furthermore, free memory space leads to higher preference. The almost identical values are explained with the only slight difference in CPU and memory values (see Table 1), which only impacts the third level.

The second case as shown in Figure 8 emphasizes the importance of Size and Weight. This focus on values where the Pi is on another order of magnitude than the Nano renders the increased computational performance of the Nano almost negligible.

The same can be said about the third case, shown in Figure 9, albeit a little less pronounced. The increase in importance of performance on the second level and subsequent focus on CPU performance are rendered irrelevant through the high-level focus place on Size and Weight.

5.3. Monte Carlo Simulation

For each of the subsystem combinations listed in Table 1 and shown in Figure 2, there will be a case where the weights result in that combination being the most suitable alternative. The tabulated values for each of these alternative cases can be found in Appendix B. These cases are presented as follows.

5.3.1. Nano-Onboard

The first four heat maps of Figure 11 show the weights required to lead to a preference of the Nano-onboard alternative. The preference value is 0.37926, slightly above a third. The values indicate that the Nano is preferred over the Pi, however only a slight preference was given to the full load on the Nano over the partial load. The first level shows that Computation receives the highest preference compared to all others. The second level indicates that reliability is considered most important, with performance being the second most important. The third level shows that memory usage is very much preferred over CPU usage and memory space a little over CPU.

Figure 11.

Figure 11

The weight matrices leading to the highest preferences for each alternative. The first heat maps show the weights for the Nano-onboard-alternative, the second set of heatmaps the weights for the Nano-real-time-alternative, and the third row the weights for the Pi-real-time alternative. The top row shows the first two levels, the bottom row the third level. Only the upper diagonal weights are shown for simplicity. Darker colors indicate less preference, lighter colors more preference.

These values indicate that when mechanical parameters are not as important as computational and reliability plays a significant role, the Nano dominates the decision, as expected.

5.3.2. Nano-Real-Time

The preference value of the Nano in a real-time setting is 0.42533. This result indicates that the Nano in a real-time setting has quite a large preference over the other alternatives. The weights that lead to this preference are shown in the second set of Figure 11. The first level shows that Computation has the highest priority, followed by Power, while the other two are considered less important. The second level demonstrates the benefit of available space, which has a significantly higher value than reliability and lastly performance.

5.3.3. Pi-Real-Time

The last set of heatmaps in Figure 11 shows the weights leading to the highest preference for the Raspberry Pi-real-time alternative. The relative preference value is 0.64268, more than three times as high as the other two alternatives as shown in Appendix B. Inspecting the first level reveals that Weight is considered most important, and Size second most, while Power and Computation are considered relatively less important. Computational parameters have little significance through this; however, performance largely outweighs compatibility and reliability. On the third level, memory is preferred over CPU.

6. Discussion

6.1. The AHP

The AHP is a model mainly used for high-level decision-making and has both benefits and drawbacks. On one hand it is constrained by its scale and the required consistencies [47], as well as the subjectivity of the choice of weights by stakeholders. On the other hand, the scales and consistencies force users to put their criteria into numerical values by comparing pairwise and checks whether the criteria can be considered consistent. Users are required to re-evaluate their criteria if these are deemed inconsistent and increased dimensions allow for higher degrees of inconsistencies, which are more likely to arise.

The hierarchy allows to be extended or reduced. For example, Size could have included an additional parameter for the form factor (for example, cubic as bad, but flat as a good form factor). Alternatively, other characteristics of the ISO, as mentioned in Section 2.1, would require consideration if alternatives would differ with respect to these characteristics, for example, if a solution not based on ROS would be provided, the equalities mentioned in Section 2.1 would not hold. However, the hierarchy reduces the influence of lower levels on the higher levels, which is indicated through the limited influence of reliability, despite the evident shortcoming of the Pi. Shifting values between levels may result in different outcomes, however the model was chosen in compliance with contemporary literature and the ISO model. The question whether to place reliability on a higher level should be evaluated with respect to the decomposition of structurally similar indicators as described by Saaty [28], as well as the inclusion into the ISO [31]. Weights on the third level are diluted through the higher levels and have partial co-dependence, as indicated by the inverse relation of CPU used and CPU free. Additionally, the use of ROS limits the freedom of software optimizations [36] for developers, paying the price of flexibility for reduced complexity.

The complex structure of the problem [6,27] would render common optimization techniques difficult to be applicable and is beyond the scope of this work. Unlike convex optimization or gradient-based methods, the AHP does not yield absolute performance optima; however, it provides relative preferences on readily available alternatives that can be compared with each other. Furthermore, the evaluation disregards hardware settings that might have an influence, such as cable shielding or memory card wear.

The research could also be extended to further alternatives, as only three, with two comprising of the same hardware, were evaluated. However, with an increase in alternatives, final preferences become less pronounced due to the mathematical normalization inherent to the AHP. Furthermore, the alternatives were chosen such that they represent opposite ends of the spectrum: the Pi as a mechanically lightweight alternative, with little computing power and the Nano as a comparably large and powerful module. The variation between the onboard and real-time configurations is used to illustrate differences in software load, albeit the effects are less pronounced. This can be explained through smart OS priority and assignment schemes for memory and CPU, leading to marginal differences for these aspects.

6.2. Case Studies

The case studies, inspired by remote-sensing scenarios, indicate that varying requirements lead to different results which alternatives are preferred. While the step of decreasing mechanical Size or increasing Computation may trigger a logical choice in experienced engineers, evaluating the benefits may be difficult for other users.

Networking effects are omitted, because these were addressed in the literature [21,22] and with the deployment of ROS2. However, network settings hold the potential to impact decisions, as they have an influence in UAV remote sensing applications.

The case studies are used to illustrate the influence of relative weights and how these can differ on a case-by-case basis, however the tasks presented do not necessarily correlate with the task defined in the original work [35]. Nonetheless, the methodology serves its purpose of illustrating the effect that different weights have on a final preference.

6.3. Monte Carlo Simulation

The MC simulation compares a large variety of different weights as inputs, combined with the same results from profiling, as shown in Table 1. This exposes the relative weights, which could have led to the preference of an alternative. While these results are indicative of the relative weights which could have to the preference of an alternative, the AHP is not used to select weights. This would contradict the paradigm of the AHP that relative weights require assignment, and not alternatives. The method also depends on results from profiling and therefore a variation in recording performance values may lead to a change in preference. It also poses the questions whether shifting around certain aspects to other levels, such as reliability to the topmost level, should not be considered to ensure an increased focus.

6.4. Comparing Case Studies and Monte Carlo Simulation

The case studies are inspired by three remote-sensing scenarios and result in different preferences, as indicated in Table 2 and Figure 10, despite being run with the same performance indicators as shown in Table 1. Figure 7, Figure 8 and Figure 9 indicate that the distinctiveness of the first level has a significant influence on the outcome. The mechanical properties Size and Weight are considered more important for the case of an additional module (Figure 9) as well as the case of a suspended arm (Figure 8), which are also the cases which give preference to the Pi, as shown in Appendix B.

The dominance of the Pi under consideration of mechanical properties is underlined by the MC results as shown in Figure 11 and Appendix B, where the first level of the Pi real-time result is predominantly focused on Weight. The other two alternatives are almost equal, as their mechanical properties are equal and the influence of Computation is diminished. When Computation is considered important, the Nano prevails, albeit not by as large a margin as the Pi (see Appendix B), due to the reduced benefits arising from the lower levels.

Altogether the Nano shows considerable benefits when Computation, and foremost reliabilitity, is important, while the Pi prevails when Size and Weight are required to be small. However, the inclusion of reliability into the computational level may lead to be misleading for fully autonomous missions and may require researchers to ensure other safety measures are in place. Generally the weights tend to shift towards mechanical importance when the configuration is not considered mission-critical and safety can be guaranteed through other measures. If basic flight depends on the configuration, computational factors gain influence, which is in agreement with contemporary research [6,27].

7. Conclusions

This research details a method for evaluating and selecting suitable hardware for the hardware-in-the-loop development step for deployment of remote-sensing UAVs. While computational performance is often considered secondary, it has a significant influence on which choice of software–hardware combination should be considered as suitable for a given task. A HITL software package was tested under three different software–hardware setups and profiled to collect performance indicators. The indicators are used in a decision-making model alongside subjective preference values to show how changes in priorities lead to preference of different software–hardware combinations. A Monte Carlo simulation indicates weights under which one of the alternatives shown in Figure 6 would be preferred.

The results provide insights into the complex decisions required to deploy autonomous algorithms on hardware and require careful selection of the preference weights as they rely on subjective assignment. However, preference weights only require ordinal-scaled definition and are checked for mathematical consistency, therefore allowing awareness for priorities of potentially conflicting alternatives.

The methodology presented in this research can enable remote-sensing researchers to evaluate whether their choice of software–hardware combination is sustainable by running hardware-in-the-loop simulations. This can lead to a reduced failures, improve performance consistencies, and reduce development time, improving deployment of sophisticated UAV-based remote sensing technology.

Acknowledgments

N.M. acknowledges F. Vanegas, K. Morton, and G. Suddrey for their support during the development of this work. The authors acknowledge continued support from the Queensland University of Technology (QUT) through the Centre for Robotics.

Appendix A. Hardware Implementation Details

Table A1.

Configurations of the two embedded hardware devices following initial experiments.

Device Nano Pi
Software Type Installation Type Installation
OS Jetpack Ubuntu 18.04 Etcher Ubuntu Mate 18.04 Cross-compilation Pi 3B
Swap Swap 2048 MB Zram/Swap 256/1052 MB
ROS Melodic Package Manager Melodic Package Manager
MavRos 0.33.4 Source 0.33.4 Source
OpenCV 3.4.6. Source + Contrib 3.4.6 Source + Contrib
Cross-compilation
Timesync NTP ntp.qut NTP ntp.qut
Proprietary
Changes
Power Mode 0 Serial Clock speed Elevated-mavros
HDMI disabled HDMI disabled
WiFi Powersaving disabled WiFi Powersaving disabled
Power Supply Barrel Jack 4A Display Service disabled
SD-Card 32 GB SanDisk SDHC U3 SD-Card 32 GB SanDisk SDHC U1
Serial Port Config 921600 8N1 Serial Port Config 921600 8N1
Bluetooth disabled-Serial Port

Appendix B. Monte-Carlo Simulation Results

Figure A1.

Figure A1

Relative preference for the Monte Carlo simulation. The y-axis shows the relative preference, the x-axis a bar for each alternative: green for the Pi-real-time, blue for the Nano-real-time and orange for the Nano-onboard alternative. Each MC results in one of the alternatives being preferred.

Table A2.

Results from the Monte-Carlo Simulation. Each row shows the global preference of the alternatives. The rows indicate the case for which these values were the highest absolute preference. Bold numbers indicate which alternative is preferred/the best for each column.

Device Nano Pi
Load RT Onb RT
Nano-RT 0.42533 0.30175 0.27292
Nano-Onb 0.37235 0.37926 0.24840
Pi-RT 0.17570 0.18163 0.64268

Author Contributions

N.M. conceptualization, methodology, software, analysis, data curation, writing—original draft preparation, and visualization; M.M. conceptualization and writing—review and editing, supervision; F.G. conceptualization, resources, writing—review and editing, supervision, and project administration. All authors have read and agreed to the published version of the manuscript.

Funding

This research was conducted by the Australian Research Council project number CE140100016, and supported by the QUT Centre for Robotics and ARC grant FT140101229.

Conflicts of Interest

The authors declare no conflict of interest.

References

  • 1.Gonzalez L.F., Montes G.A., Puig E., Johnson S., Mengersen K., Gaston K.J. Unmanned Aerial Vehicles (UAVs) and Artificial Intelligence Revolutionizing Wildlife Monitoring and Conservation. Sensors. 2016;16:97. doi: 10.3390/s16010097. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 2.Vanegas F., Bratanov D., Powell K., Weiss J., Gonzalez F. A Novel Methodology for Improving Plant Pest Surveillance in Vineyards and Crops Using UAV-Based Hyperspectral and Spatial Data. Sensors. 2018;18:260. doi: 10.3390/s18010260. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 3.Villa T.F., Gonzalez F., Miljievic B., Ristovski Z.D., Morawska L. An Overview of Small Unmanned Aerial Vehicles for Air Quality Measurements: Present Applications and Future Prospectives. Sensors. 2016;16:1072. doi: 10.3390/s16071072. [DOI] [PMC free article] [PubMed] [Google Scholar]
  • 4.Kaufmann E., Loquercio A., Ranftl R., Dosovitskiy A., Koltun V., Scaramuzza D. Deep Drone Racing: Learning Agile Flight in Dynamic Environments. arXiv. 20181806.08548 [Google Scholar]
  • 5.Welburn E., Khalili H.H., Gupta A., Watson S., Carrasco J. A Navigational System for Quadcopter Remote Inspection of Offshore Substations; Proceedings of the Fifteenth International Conference on Autonomic and Autonomous Systems; Athens, Greece. 2–6 June 2019. [Google Scholar]
  • 6.Boroujerdian B., Genc H., Krishnan S., Cui W., Faust A., Reddi V. MAVBench: Micro Aerial Vehicle Benchmarking; Proceedings of the 2018 51st Annual IEEE/ACM International Symposium on Microarchitecture (MICRO); Fukuoka, Japan. 20–24 October 2018; pp. 894–907. [DOI] [Google Scholar]
  • 7.Vanegas F., Gonzalez F. Uncertainty based online planning for UAV target finding in cluttered and GPS-denied environments; Proceedings of the 2016 IEEE Aerospace Conference; Big Sky, MT, USA. 5–12 March 2016; pp. 1–9. [DOI] [Google Scholar]
  • 8.Galvez Serna J., Vanegas Alvarez F., Gonzalez F., Flannery D. IEEE Aerospace Conference. IEEE; Piscataway, NJ, USA: 2020. A review of current approaches for UAV autonomous mission planning for Mars biosignatures detection. in press. [Google Scholar]
  • 9.Liu L., Ouyang W., Wang X., Fieguth P., Chen J., Liu X., Pietikäinen M. Deep Learning for Generic Object Detection: A Survey. Int. J. Comput. Vis. 2019 doi: 10.1007/s11263-019-01247-4. [DOI] [Google Scholar]
  • 10.Cadena C., Carlone L., Carrillo H., Latif Y., Scaramuzza D., Neira J., Reid I., Leonard J.J. Past, Present, and Future of Simultaneous Localization and Mapping: Toward the Robust-Perception Age. IEEE Trans. Robot. 2016;32:1309–1332. doi: 10.1109/TRO.2016.2624754. [DOI] [Google Scholar]
  • 11.Corke P., Dayoub F., Hall D., Skinner J., Sünderhauf N. What can robotics research learn from computer vision research? arXiv. 20202001.02366 [Google Scholar]
  • 12.Cervera E. Try to Start It! The Challenge of Reusing Code in Robotics Research. IEEE Robot. Autom. Lett. 2019;4:49–56. doi: 10.1109/LRA.2018.2878604. [DOI] [Google Scholar]
  • 13.Zhao Y., Zheng Z., Liu Y. Survey on computational-intelligence-based UAV path planning. Knowl.-Based Syst. 2018;158:54–64. doi: 10.1016/j.knosys.2018.05.033. [DOI] [Google Scholar]
  • 14.Lu Y., Xue Z., Xia G.S., Zhang L. A survey on vision-based UAV navigation. Geo Spat. Inf. Sci. 2018;21:21–32. doi: 10.1080/10095020.2017.1420509. [DOI] [Google Scholar]
  • 15.Kang K., Belkhale S., Kahn G., Abbeel P., Levine S. Generalization through Simulation: Integrating Simulated and Real Data into Deep Reinforcement Learning for Vision-Based Autonomous Flight; Proceedings of the 2019 International Conference on Robotics and Automation (ICRA); Montreal, QC, Canada. 20–24 May 2019; pp. 6008–6014. [DOI] [Google Scholar]
  • 16.Toudeshki A.G., Shamshirdar F., Vaughan R. Robust UAV Visual Teach and Repeat Using Only Sparse Semantic Object Features; Proceedings of the 2018 15th Conference on Computer and Robot Vision (CRV); Toronto, ON, Canada. 8–10 May 2018; pp. 182–189. [DOI] [Google Scholar]
  • 17.Loquercio A., Maqueda A.I., del Blanco C.R., Scaramuzza D. DroNet: Learning to Fly by Driving. IEEE Robot. Autom. Lett. 2018;3:1088–1095. doi: 10.1109/LRA.2018.2795643. [DOI] [Google Scholar]
  • 18.Kouris A., Bouganis C. Learning to Fly by MySelf: A Self-Supervised CNN-Based Approach for Autonomous Navigation; Proceedings of the 2018 IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS); Madrid, Spain. 1–5 October 2018; pp. 1–9. [DOI] [Google Scholar]
  • 19.Kim D.K., Chen T. Deep Neural Network for Real-Time Autonomous Indoor Navigation. arXiv. 20151511.04668 [Google Scholar]
  • 20.Ross S., Melik-Barkhudarov N., Shankar K.S., Wendel A., Dey D., Bagnell J.A., Hebert M. Learning monocular reactive UAV control in cluttered natural environments; Proceedings of the 2013 IEEE International Conference on Robotics and Automation; Karlsruhe, Germany. 6–10 May 2013; pp. 1765–1772. [DOI] [Google Scholar]
  • 21.Tardioli D., Parasuraman R., Ögren P. Pound: A multi-master ROS node for reducing delay and jitter in wireless multi-robot networks. Robot. Auton. Syst. 2019;111:73–87. doi: 10.1016/j.robot.2018.10.009. [DOI] [Google Scholar]
  • 22.Bihlmaier A., Hadlich M., Wörn H. Advanced ROS Network Introspection (ARNI) In: Koubaa A., editor. Robot Operating System (ROS): The Complete Reference. Volume 1. Springer International Publishing; Cham, Switzerland: 2016. pp. 651–670. Studies in Computational Intelligence. [DOI] [Google Scholar]
  • 23.Kyrkou C., Plastiras G., Theocharides T., Venieris S.I., Bouganis C. DroNet: Efficient convolutional neural network detector for real-time UAV applications; Proceedings of the 2018 Design, Automation Test in Europe Conference Exhibition (DATE); Dresden, Germany. 19–23 March 2018; pp. 967–972. [DOI] [Google Scholar]
  • 24.Dang T., Papachristos C., Alexis K. Autonomous exploration and simultaneous object search using aerial robots; Proceedings of the 2018 IEEE Aerospace Conference; Big Sky, MT, USA. 3–10 March 2018; pp. 1–7. [DOI] [Google Scholar]
  • 25.Papachristos C., Kamel M., Popović M., Khattak S., Bircher A., Oleynikova H., Dang T., Mascarich F., Alexis K., Siegwart R. Autonomous Exploration and Inspection Path Planning for Aerial Robots Using the Robot Operating System. In: Koubaa A., editor. Robot Operating System (ROS): The Complete Reference. Volume 3. Springer International Publishing; Cham, Switzerland: 2019. pp. 67–111. Studies in Computational Intelligence. [DOI] [Google Scholar]
  • 26.Modasshir M., Li A.Q., Rekleitis I. Deep Neural Networks: A Comparison on Different Computing Platforms; Proceedings of the 2018 15th Conference on Computer and Robot Vision (CRV); Toronto, ON, Canada. 8–10 May 2018; pp. 383–389. [DOI] [Google Scholar]
  • 27.Krishnan S., Wan Z., Bhardwaj K., Whatmough P., Faust A., Wei G.Y., Brooks D., Reddi V.J. The Sky Is Not the Limit: A Visual Performance Model for Cyber-Physical Co-Design in Autonomous Machines. IEEE Comput. Archit. Lett. 2020;19:38–42. doi: 10.1109/LCA.2020.2981022. [DOI] [Google Scholar]
  • 28.Saaty R.W. The analytic hierarchy process—What it is and how it is used. Math. Model. 1987;9:161–176. doi: 10.1016/0270-0255(87)90473-8. [DOI] [Google Scholar]
  • 29.Suarez A., Vega V.M., Fernandez M., Heredia G., Ollero A. Benchmarks for Aerial Manipulation. IEEE Robot. Autom. Lett. 2020;5:2650–2657. doi: 10.1109/LRA.2020.2972870. [DOI] [Google Scholar]
  • 30.Morton K., Toro L.F.G. Development of a robust framework for an outdoor mobile manipulation UAV; Proceedings of the 2016 IEEE Aerospace Conference; Big Sky, MT, USA. 5–12 March 2016; pp. 1–8. [DOI] [Google Scholar]
  • 31.ISO. IEC . 25010:2011-Systems and Software Engineering-Systems and software Quality Requirements and Evaluation (SQuaRE)-System and Software Quality Models. ISO/IEC; Geneva, Switzerland: 2011. Standard 25010:2011. [Google Scholar]
  • 32.ISO. IEC . 25021:2012-Systems and Software Engineering-Systems and Software Quality Requirements and Evaluation (SQuaRE)-Quality Measure Elements. ISO/IEC; Geneva, Switzerland: 2012. Standard 25021:2012; revised 2019. [Google Scholar]
  • 33.ISO. IEC . 25023:2016-Systems and Software Engineering-Systems and Software Quality Requirements and Evaluation (SQuaRE)-Measurement of System and Software Product Quality. ISO/IEC; Geneva, Switzerland: 2016. Standard 25023:2016. [Google Scholar]
  • 34.Simmonds C. Mastering Embedded Linux Programming. Packt Publishing Ltd.; Birmingham, UK: 2017. [Google Scholar]
  • 35.Mandel N., Vanegas F., Milford M., Gonzalez F. IEEE Aerospace Conference. IEEE; Big Sky, MT, USA: 2020. Towards Simulating Semantic Onboard UAV Navigation. [Google Scholar]
  • 36.Williams S., Waterman A., Patterson D. Roofline: An insightful visual performance model for multicore architectures. Commun. ACM. 2009;52:65–76. doi: 10.1145/1498765.1498785. [DOI] [Google Scholar]
  • 37.Cervera E., Del Pobil A.P. ROSLab: Sharing ROS Code Interactively With Docker and JupyterLab. IEEE Robot. Autom. Mag. 2019;26:64–69. doi: 10.1109/MRA.2019.2916286. [DOI] [Google Scholar]
  • 38.Huang J., Rathod V., Sun C., Zhu M., Korattikara A., Fathi A., Fischer I., Wojna Z., Song Y., Guadarrama S., et al. Speed/accuracy trade-offs for modern convolutional object detectors; Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition; Honolulu, HI, USA. 21–26 July 2017. [Google Scholar]
  • 39.Kouris A., Venieris S.I., Bouganis C. Towards Efficient On-Board Deployment of DNNs on Intelligent Autonomous Systems; Proceedings of the 2019 IEEE Computer Society Annual Symposium on VLSI (ISVLSI); Miami, FL, USA. 15–17 July 2019; pp. 568–573. [DOI] [Google Scholar]
  • 40.Siegwart R. Introduction to Autonomous Mobile Robots. 2nd ed. MIT Press; Cambridge, MA, USA: 2011. (Intelligent Robotics and Autonomous Agents Series). [Google Scholar]
  • 41.Brooks D. Rosprofiler-ROS Wiki. [(accessed on 7 August 2020)]; Available online: http://wiki.ros.org/rosprofiler.
  • 42.Subramanian N., Ramanathan R. A review of applications of Analytic Hierarchy Process in operations management. Int. J. Prod. Econ. 2012;138:215–241. doi: 10.1016/j.ijpe.2012.03.036. [DOI] [Google Scholar]
  • 43.Mühlbacher A.C., Kaczynski A. Der Analytic Hierarchy Process (AHP): Eine Methode zur Entscheidungsunterstützung im Gesundheitswesen. Pharmacoecon. Ger. Res. Artic. 2013;11:119–132. doi: 10.1007/s40275-014-0011-8. [DOI] [Google Scholar]
  • 44.Ataei M., Shahsavany H., Mikaeil R. Monte Carlo Analytic Hierarchy Process (MAHP) approach to selection of optimum mining method. Int. J. Min. Sci. Technol. 2013;23:573–578. doi: 10.1016/j.ijmst.2013.07.017. [DOI] [Google Scholar]
  • 45.Dahri N., Abida H. Monte Carlo simulation-aided analytical hierarchy process (AHP) for flood susceptibility mapping in Gabes Basin (southeastern Tunisia) Environ. Earth Sci. 2017;76:302. doi: 10.1007/s12665-017-6619-4. [DOI] [Google Scholar]
  • 46.Zamir A., Sax A., Shen W., Guibas L., Malik J., Savarese S. Taskonomy: Disentangling Task Transfer Learning. arXiv. 20181804.08328 [Google Scholar]
  • 47.Franek J., Kresta A. Judgment Scales and Consistency Measure in AHP. Procedia Econ. Financ. 2014;12:164–173. doi: 10.1016/S2212-5671(14)00332-3. [DOI] [Google Scholar]
  • 48.Ladosz P., Coombes M., Smith J., Hutchinson M. A Generic ROS Based System for Rapid Development and Testing of Algorithms for Autonomous Ground and Aerial Vehicles. In: Koubaa A., editor. Robot Operating System (ROS): The Complete Reference. Volume 3. Springer International Publishing; Cham, Switzerland: 2019. pp. 113–153. Studies in Computational Intelligence. [DOI] [Google Scholar]

Articles from Sensors (Basel, Switzerland) are provided here courtesy of Multidisciplinary Digital Publishing Institute (MDPI)

RESOURCES