Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Next Article in Journal
Robust Iris-Localization Algorithm in Non-Cooperative Environments Based on the Improved YOLO v4 Model
Next Article in Special Issue
A Review of Radio Frequency Based Localisation for Aerial and Ground Robots with 5G Future Perspectives
Previous Article in Journal
Machine Learning and Wearable Sensors for the Early Detection of Balance Disorders in Parkinson’s Disease
Previous Article in Special Issue
Visual SLAM: What Are the Current Trends and What to Expect?
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Resolution and Frequency Effects on UAVs Semi-Direct Visual-Inertial Odometry (SVO) for Warehouse Logistics

1
Department of Mechanical and Aerospace Engineering (DIMEAS), Politecnico di Torino, Corso Duca degli Abruzzi, 24, 10128 Turin, Italy
2
Dronomy, Paseo de la Castellana, 40, 28046 Madrid, Spain
3
Department of Electronics and Telecommunications (DET), Politecnico di Torino, Corso Duca degli Abruzzi, 24, 10128 Turin, Italy
*
Author to whom correspondence should be addressed.
Sensors 2022, 22(24), 9911; https://doi.org/10.3390/s22249911
Submission received: 2 October 2022 / Revised: 17 November 2022 / Accepted: 12 December 2022 / Published: 16 December 2022
(This article belongs to the Special Issue Aerial Robotics: Navigation and Path Planning)

Abstract

:
For the commercial sector, warehouses are becoming increasingly vital. Constant efforts are in progress to increase the efficiency of these facilities while reducing costs. The inventory part of the goods is a time-consuming task that impacts the company’s revenue. This article presents an analysis of the performance of a state-of-the-art, visual-inertial odometry algorithm, SVO Pro Open, when varying the resolution and frequency of video streaming in an industrial environment. To perform efficiently this task, achieving an optimal system in terms of localization accuracy, robustness, and computational cost is necessary. Different resolutions are selected with a constant aspect ratio, and an accurate calibration for each resolution configuration is performed. A stable operating point in terms of robustness, accuracy of localization, and CPU utilization is found and the trends obtained are studied. To keep the system robust against sudden divergence, the feature loss factor extracted from optical sensors is analyzed. Innovative trends and translation errors on the order of a few tens of centimeters are achieved, allowing the system to navigate safely in the warehouse. The best result is obtained at a resolution of 636 × 600 px, where the localization errors (x, y, and z) are all under 0.25 m. In addition, the CPU (Central Processing Unit) usage of the onboard computer is kept below 60%, remaining usable for other relevant onboard processing tasks.

1. Introduction

As the market rises due to the strong demand and diversification of products, warehouse logistics play an increasingly important role in the management of goods and delivery times. The latest are relevant parameters for the customer in which there is strong competition [1,2]. As a consequence of the pandemic period also, the e-commerce sector is growing fast and the only way to supply the chain is to go towards smart and autonomous warehouses [3]. For these reasons, robotic applications are growing in daily operations inside warehouses [4,5,6]. Several companies are already using this technology to speed up their operations while many others are on their way to incorporating it. However, to increase the autonomy level in these GPS-denied environments, it is first required to solve the problem of localizing the robot with adequate accuracy. If an inaccurate or unstable localization system is adopted, the probability of failing the task is high and even worse, the safety of humans can be compromised, especially if UAVs (Unmanned Aerial Vehicles), commonly known as drones, are employed. Therefore, an efficient localization system at its base is necessary [7]. Some of the state-of-the-art techniques for localization are presented in the following subsection. This work aims to analyze a low-cost and lightweight system that estimates the relative 3D position of a UAV inside a warehouse with respect to a known starting pose. Given the optical sensor and the available computational power, the goal is to find a stable operating point in terms of robustness, accuracy of localization, and CPU utilization, and to study the trends obtained. The localization problem itself has already been addressed with various approaches. Many of these need external access points to triangulate the robot’s position [8]. Others use heavy and expensive hardware such as LIDAR [9], not compatible with the small size required for UAVs to safely navigate along warehouse corridors. Instead, the system analyzed is independent of external aids and uses only the visual-inertial sensors onboard. In addition, a warehouse-specific training dataset is not needed as in [10]. The configuration presented has the advantage of being a low-cost and lightweight system and is easily adaptable to most warehouses and platforms. However, an accurate calibration phase is crucial to obtain an accurate and robust localization using only the onboard visual-inertial sensors [11,12,13,14,15]. To not overload the CPU, it is necessary to find a trade-off between the optical resolution adopted and the image acquisition frequency. This trade-off point is one of the main goals of the work. In addition, a detailed study of localization errors along the three dimensions is presented, not available in similar works such as [16]. Through the appropriate parameters, to minimize the risk of sudden divergence in the localization, the robustness of the system is also monitored. Lately, the use of this technology is growing fast in aerospace robotics, for terrestrial and non-terrestrial applications. For these reasons, the analyzed system suits both aerial and ground platforms. In this case, an aerial system with a quadcopter configuration is employed. UAVs unlike ground robots allow inventorying the shelves at every level, saving more time and reducing the risks that an operator would run by using traditional methods. Furthermore, thanks to this system, the drone can be programmed to be completely autonomous, and therefore, there is potentially no need for human pilot assistance.
The onboard computer employed is lightweight, inexpensive, and commercially available: NVIDIA Jetson Nano board. The optical sensor used is a fisheye stereo camera with an integrated IMU. The project in question uses a programming framework that is widespread in robotics, ROS (Robot Operating System). This system works as an operating system that connects different processes and commonly used applications. ROS organizes its content into packages containing executable files called nodes, programmed in C/C++, Python, and LISP. For the estimation of the noise parameters of the IMU (Inertial Measurement Unit), the ROS package IMU_utils is adopted. For the calibration of the optical system, the ROS package camera_calibration is used, while for the calibration of the visual-inertial system, the ROS package kalibr is adopted. Similarly, the localization algorithm implemented in this project is SVO Pro Open, described in [17,18], always compatible with ROS. The latter package is chosen for localization after several tests among the various open-source packages available, cited in the next section. This is one of the few packages able to run in real-time on the selected onboard computer and provide satisfactory performance. The ROS version installed is Melodic Morenia, compatible with Ubuntu 18, on both the Jetson Nano and the laptop used for the calibration phase. The experimental results presented are derived from data recorded during tests in an actual warehouse, and fully belong to a real industrial scenario.
The paper is organized as follows. The following subsection presents an overview of the state-of-the-art of visual-inertial odometry algorithms. Section 2 shows the methodology of data collection and hardware setup. This section presents the sensors adopted and the calibration process of the cameras and the visual-inertial system. Section 3 describes the obtained results and discussions. Conclusions and further developments are described in Section 4.

1.1. Related Work

As anticipated, one of the limits in mobile robotic applications is the uncertainty of vehicle localization. To overcome this problem, external aids such as GNSS (Global Navigation Satellite System), Motion Capture Cameras [19], Total Stations [20], or similar can be adopted. In addition, Ultra-Wideband technologies are recently taking over as a cheaper source to localize the vehicle, as described in [21]. However, these systems can rarely be employed in critical (GPS-denied) and unknown areas without additional equipment. Therefore, many of the robotic applications are quite limited in these scenarios.
For these reasons, several open-source algorithms (ORB-SLAM, SVO, VINS, Okvis, Rovio, and several others) grew up recently to perform Visual-Inertial Odometry for complete autonomous applications [22,23,24,25]. This particular technique performs a sensor fusion between optical sensors, such as monocular or stereoscopic cameras, and inertial sensors to estimate the traveled trajectory from the initial position, as explained in [26]. The process flow can be divided into (1) feature extraction from the current frame of the video stream, (2) search of the extracted features in the current frame among those of the previous one, (3) filtering features matched, (4) triangulation of the pose, and (5) fusion with the inertial data to scale the processed trajectory and refine the motion estimation. Specifically, there are relevant feature extraction, filtering techniques, and integration methods with inertial sensors, described in [17,18,22,23,24,25].
The commercial sector responded promptly by launching products such as the Intel RealSense T265 and the ZED series (ZED mini, ZED, and ZED2), ready-to-use sensors that provide directly the result of the Visual-Inertial Odometry to the user. Moreover, event cameras are also gaining ground. These are already powerful sensors for this application, even if still in a prototype state [27].

1.1.1. Visual-Inertial Odometry

This term groups together those techniques consisting of combining the data coming from one or more inertial sensors with one or more RGB or depth cameras. Recently, hybrid techniques such as SVO (Semi-direct Visual Odometry) emerged also [17]. In this case, pixels are extracted with a feature-based methodology, but the variation between frames in light intensity of pixels selected for triangulation is evaluated to estimate the camera motion.
The triangulation process and motion reconstruction are summarized in Figure 1, where the feature f j is recognized by two different consecutive images. It is possible to reconstruct the epipolar plane joining the two centers c 1 , c 2 , and f j . Detailed equations can be found in [28]. Inertial data fusion techniques are divided into two main categories, as described in [29]:
(i)
Loosely coupled: the visual and inertial systems are independent entities. In this case, the fusion is applied through Unscented Kalman filters or Extended Kalman Filters. Although not extremely accurate, this approach favors real-time performance. It also makes easier the integration of information coming from other sensors. The logic is represented in Figure 2.
(ii)
Tightly coupled: this approach combines visual and inertial parameters in a single optimization problem. This approach involves the data from cameras and the IMU as described in Equation (1). It results more computationally demanding than the loosely coupled approach. As described in [30], the cost function optimization can be written as in Equation (1):
J ( x ) = i = 1 I k = 1 K j J ( i , k ) e r i , j , k T W r i , j , k e r i , j , k v i s u a l + + k = 1 K 1 e s k T W s k e s k i n e r t i a l ,
where e r are the weighted reprojection errors of the camera, and e s are the weighted temporal errors of the IMU. Instead, i represents the camera index, k is the frame index, and j is the image feature index. The approach is shown in Figure 3.
In various visual-inertial odometry algorithms, some further steps and refinements are also performed. In particular, as explained in [31], loop closure, relocalization, feature retrieval, and bundle adjustment techniques are often adopted. These enhancements improve the precision of the pose estimation thanks to a global pose graph optimization using previously memorized features for relocation and to adjust the pose of current features.

1.1.2. Semi-Direct Visual Odometry for Multi-Camera Systems

In particular, we are considering a system M with c C cameras. By defining T C B as the extrinsic calibration matrix, we can estimate the previous position of the body, T B B 1 . The process is based on a minimization of the pixel intensity residual r I i c of the subsequent frames’ corresponding pixels. Through a projection of a known point on the scene plane ρ i = ˙ B 1 ρ i , it is possible to identify these corresponding pixels. The projection is performed into the C camera’s frames in the k and k 1 pose, expressed respectively as I k C and I k 1 C . The residual errors’ intensity is accumulated into small patches P centered into the 3D point projection. The variable Δ u is adopted to accumulate the intensities over each patch. The final objective of the algorithm is to find the translation and rotation of the camera, T k k 1 = ˙ ( R , p ) that minimizes the sum of the squared errors:
( R , p ) = a r g m i n C ( R , p ) C ( R , p ) = c C i = 1 N Δ u P 1 2 r I i , Δ u c I 2 + 1 2 r R R 2 + + 1 2 r p p 2
with N representing the number of 3-D visible points. The image intensity and prior residuals can be defined as:
r I i , Δ u c = ˙ I k C ( π ( T C B ( R ρ i + p ) ) + Δ u ) I k 1 C ( π ( T C B ρ i ) + Δ u ) r r = ˙ l o g ( R ˜ T R ) V r p = ˙ p p ˜ .
The cost function can be written as:
C ( R , p ) = r ( R , p ) T σ 1 r ( R , p )
with σ representing the measurement covariance diagonal matrix. The optimization process is then solved through a Gauss–Newton logic, [32] since residuals (R, p) are not linear. For these reasons, the relations defined for the perturbations can be written in Equation (5):
R R e x p ( δ ϕ ) , p p + R δ p
where ( . ) represents a 3 × 3 skew-symmetric matrix in the R 3 domain.

2. Methodology

This paper investigates the visual odometry performance under various combinations of image resolution and image acquisition frequency. Therefore, an ROS-compatible C/C++ code is developed to vary the frequency and resolution of video streaming, as illustrated in Figure 4.
Figure 4b is extrapolated from one of the recordings taken inside the warehouse during the test campaign. As shown, 3 different resolutions are tested: 848 × 800 px (original), 636 × 600 px, and 424 × 400 px. The frequencies tested can be expressed as done in Equations (6) and (7):
f s = 2 f f f f = f f 2 + 5 n , n = 0 3 ,
where f s is the sample frequency, f f the frame frequency, and f s is the new frame frequency tested. Instead, the resolutions tested can be expressed as:
w = n + 1 F i b ( n ) + 2 w h = n + 1 F i b ( n ) + 2 h , n = 0 3 ,
where w and h are the original width and height, respectively, while w and h are the new resolution tested.
The main goal is to evaluate the impact of the resolution on the performance of the localization algorithm, as shown in the next section. The resolutions are scaled with the same center since the central zone suffers less from lens distortion. In this way, features extracted from that zone, shown in Figure 4b, suffer from a reduced error in terms of 2D to 3D projection, and the pose calculation is more accurate. In addition, this cropping excludes pixels on the edges of the image, which do not carry information on the external environment. As shown in Figure 4a, where T c represents the sampling period, T 1 and T 2 are the original and the new streaming video frequency rate, respectively; a sampling period T c = 2 T 1 is chosen to reduce the number of lost frames, but at the same time, no denser sampling is adopted so as not to further increase the computational cost. Moreover, the impact of the acquisition frequency on the performance of SVO Pro Open is also evaluated. In particular, four characteristic frequencies are selected: 30 (original), 25, 20, and 15 Hz.

2.1. Hardware Setup

The system proposed is accessible on multiple platforms, since a low-cost, and lightweight commercial onboard computer is adopted, as shown in Figure 5: Jetson Nano embedded system (NVIDIA Maxwell™ 128 core, ARM A57 quad-core running at 1.43 GHz, LPDDR4 4 GB 64-bit 25.6 GB/s). It is equipped with an integrated GPU (Graphics Processing Unit) that allows running simple machine learning algorithms [33]. The optical sensor used is a stereo camera with a fisheye lens, with a resolution of 848 × 800 px, hemispherical FOV (Field of View) = 163 ± 5°. The camera is part of the Lazarus device, developed by the Spanish company Dronomy to facilitate the autonomous flight of UAVs in GNSS-denied/degraded environments. The 6-axis inertial sensor is the Bosch BNI055.

2.2. Sensor Calibration

This section describes the calibration operations carried out to run the visual-odometry algorithm with accurate results. Firstly, the white noise and bias instability parameters for the inertial sensor adopted are extracted. Later, the two optical sensors are calibrated to extract the distortion matrix and the intrinsic parameters. Once these data are obtained, it is possible to move on to calibrate the complete visual-inertial system.

2.2.1. IMU Parameter Extraction

To move on to the next stages of calibration, it is necessary to estimate the gyroscope and accelerometer noise parameters of our IMU (Inertial Measurement Unit) by analyzing the Allan Variance (Equation (8)).
σ y 2 ( M , T , τ ) = 1 M 1 { i = 0 M 1 [ x ( i T + τ ) x ( i T ) τ ] 2 + 1 M [ i = 0 M 1 x ( i T + τ ) x ( i T ) 2 τ ] 2 } ,
where x ( t ) is the clock reading measured at time t, M the number of frequency samples used in variance, T the time between each frequency sample, and τ is the time length of each estimation.
In particular, an accurate prediction of parameters in Table 1 allows for a more effective integration with the optical sensor data in the visual-inertial odometry. The ROS package IMU_utils extracted the results shown in Table 1 for the IMU employed, through a two-hour static acquisition.

2.2.2. Camera Calibration

After extracting the IMU parameters, the stereo camera’s intrinsics and calibration parameters are obtained. This phase is extremely important for an accurate 2D to 3D reprojection of the features extracted from the images, and consequently, for an accurate estimation of the motion. The equidistant distortion model, described in [35], is adopted. This model suits well to describe sensors with high FOV and a significant distortion, as described in [36].
It is possible to obtain accurate calibration parameters using the ROS camera-calibration package. Figure 6 shows some capture during this process with the respective feature extraction for each resolution tested.
Table 2 shows the calibration results for both lenses. As shown, the main differences as the resolution changes stay in the coordinates of the central point; on the other hand, the focal distances and the distortion parameters do not undergo significant changes as they are not only related to the resolution but to the sensor type.

2.2.3. Visual-Inertial System Calibration

As the last calibration step, obtaining the transformation matrices imu-left camera and the imu-right camera is needed. For this purpose, the kalibr software is used on the same target of Figure 6. A parameter to approximate correctly during this process is the delay between the output of the inertial sensor and the optical sensor. These sensors are inevitably asynchronous as they operate at frequencies of different orders of magnitude: 200 Hz for the IMU and 15–30 Hz for the cameras.
The following assumptions are made as described in [13]: (i) IMU white noise and random walk are correctly estimated; (ii) cameras’ intrinsic and distortion parameters are known; (iii) the gravity direction can be easily guessed in the IMU values; (iv) the size of the calibration target is known so that the calibration pattern of the target can be easily reprojected in the world reference frame. In this way, it is possible to have (v) an initial guess of the calibration matrix, c a m e r a _ t o _ i m u . The time offset is initially set to zero. A first estimate of the IMU pose with respect to the two optical sensors is obtained by estimating the position of the cameras for each frame with the calibration pattern and the accelerations recorded by the IMU. Then, the IMU pose is represented by a sixth-order B-spline. The random walks are also encoded by cubic B-splines, as shown in Figure 7.
The Levenberg–Marquardt (LM) algorithm [37] is finally used to minimize the objective function to find the maximum likelihood estimate of all unknown parameters at once. This particular algorithm achieves accurate calibration parameters with reprojection errors less than 0.13 px, as demonstrated in [37]. The estimator process is illustrated in [13], and not reported to avoid unnecessary redundancies.
In our case, d e l a y _ i m u _ c a m = 0.098 s is obtained. Figure 8 illustrates the reprojection error obtained for the two optical sensors during the calibration phase. Usually, a value between 0.1–0.2 px is a sign of a successful calibration, as in our case where an average value of 0.1734 px is achieved.
Equations (9) and (10) show the results obtained after calibration of the visual-inertial system. In particular, the transformation matrices i m u _ t o _ l e f t _ c a m and i m u _ t o _ r i g h t _ c a m are represented in quaternions, where the last column represents the translation vector between the two reference systems.
T _ I _ L = 0.99999847 0.00247529 + 0.00224508 0.01116282 0.00247665 0.99999675 0.00060109 0.01267902 0.00224358 0.00060664 0.99999730 0.00601156 0.0 0.0 0.0 1.0
T _ I _ R = 0.99999847 0.00171156 0.00036254 0.05166626 0.00171121 0.99999809 0.00094185 0.01265162 0.00036415 0.00094122 0.99999949 0.00598808 0.0 0.0 0.0 1.0
In addition, the parameters obtained in Equation (9) and (10) are validated by the fact that the translation values obtained are close ( e < 0.2 cm) to the parameters measured in the laboratory.

3. Results and Discussion

The results shown in this section are collected on a dataset recorded within the warehouse shown in Figure 9. The trajectory performed reaches an altitude of 1.40 m after take-off, and after a translation movement along the X-axis of 14.0 m, the same path is traveled in the opposite direction to return to the starting point for landing. The goal of the aircraft in this operation is to analyze and map the parcels on the shelf at that altitude while maintaining a safe distance from it. This approach makes it possible to automate warehouse logistics procedures, reducing the time and cost of inventories.
The algorithm implemented for localization is SVO Pro Open [17]. The values analyzed in this section are translation errors, % CPU usage, and feature loss (FL). These are studied by varying the optical sensor frequency (15, 20, 25, and 30 Hz) and resolution (424 × 400, 636 × 600, and 848 × 800 px).

3.1. Translation Error Analysis

In the experiments presented in this article, the visual-inertial system is transported by hand along a predetermined linear path. To estimate the translation error along the X and Z axes, and given that there is no absolute tracking system available in this warehouse to collect the ground truth data, the maximum deviation to the values 0.0–14.0 m, and 0.0–1.40 m, is respectively considered. While along the Y-axis, the path followed is equal to y = 0 m; then, any variation from this path is considered as an error. Figure 10 shows the analysis of the effect of changing the resolution at a fixed frequency for translation errors along the X, Y, and Z axes. It is notable in almost all trends (Figure 10c–f,h–l) that an increase in resolution does not necessarily indicate an improvement in localization accuracy. Taking as reference the 30 Hz configuration that provides the best performance, the translation error trend finds a minimum point in the intermediate resolution (636 × 600 px) along all axes. In fact, increasing the resolution allows extracting more features for the same frame; however, for fisheye optical sensors, the outermost features are the ones that suffer from a higher error due to the distortion model since the features extracted are more distant from the focal point. This can cause the performance degradation in the reprojection phase as recorded at 848 × 800 px, where the minimal intensity residuals r I i c , described in Equation (3) optimization, lose accuracy. Figure 11 shows the effects of frequency variation on translation errors. The errors along the X and Y axes are lower at high frequency, as shown in Figure 11a,b,d,g,h. The error along the Z-axis shows random trends at higher frequencies, but at low frequencies, it can increase considerably, as shown in Figure 11c,i. In Figure 12 are represented all the trajectories extracted with the various combinations of frequency and resolution. In addition, the low-resolution trajectories (424 × 400 Hz) are the most inaccurate, as can be noted graphically in Figure 12a–c. The solution of the algorithm improves at higher frequencies.

3.2. Computational Cost Analysis

To perform a computational cost analysis, the impact of the SVO Pro Open process on the CPU percentage is evaluated, as shown in Figure 13 and Figure 14.
In Figure 13, it can be seen how the impact of resolution on computational cost is substantial: a reduction of up to 30% between the maximum and minimum resolution is achieved. Furthermore, as the frequency increases, the trend as the resolution changes go from linear, Figure 13a, to a function approximating an exponential trend.
A similar phenomenon is shown in Figure 14, whereas the resolution increases, the computational benefits are reduced by decreasing the frequency, changing the function from linear, Figure 14a, to a function approximating a logarithmic trend. In addition, the effect of frequency on the CPU has a major impact on the intermediate resolution (636 × 600 px), as shown in Figure 14b, while for other resolutions, it has a lower effect, Figure 14a,c. All the computational data results are collected in Table 3, Table 4 and Table 5, respectively. The theoretical explanation for this trend can be found in the definition of the cost function described in Equations (2) and (5). As N, the number of 3D visible point increase, more iterations are needed to elaborate the cost function, and therefore more CPU resources.

3.3. Feature Loss Analysis

The Feature Loss (FL) parameter is monitored to estimate the robustness of the algorithm. This parameter indicates the characteristic features that are extracted by the algorithm in one frame and not found in the next. Higher values of this parameter can lead to non-tolerable errors in the localization or, in the worst case, sudden divergences. It is important to specify that during all the tests, the maximum number of extracted features was constant.
From the several data collected, it is clear that the trend of this parameter is influenced by the calibration parameters obtained in Table 2. For this reason, no clear and unidirectional trends are highlighted in Figure 15 and Figure 16. However, it can be noted that at low frequencies, for the lowest resolution (424 × 400 px), the FL value increases by an order of magnitude, as shown in Figure 15a,b and Figure 16a. This leads to the high errors for the 424 × 400 px resolution shown earlier in Figure 12a–c. Furthermore, analyzing Figure 15, the frequency of 30 Hz shows lower values of this parameter and therefore can be considered more robust.
Instead, it can be noted from Figure 16 that the intermediate resolution (636 × 600 px) shows better performance under this aspect, showing no divergence even at low frequencies. Naturally, lowering the frequency increases the time between frames; consequently, in some phases of the test, the motion of the camera can be wider than when sampling at higher frequencies. This can compromise the Feature Matching process and therefore increase the Feature Loss (FL) parameter.

4. Conclusions and Further Developments

This article presents an analysis of the performance of a state-of-the-art, visual-inertial odometry algorithm, SVO Pro Open, when varying the resolution and frequency of video streaming. The algorithm is deployed on lightweight commercial hardware to demonstrate the potential use of this technology in an industrial application and to provide a valid and useful platform configuration to the scientific community.
The results obtained for three different resolutions and four acquisition frequencies are promising. In particular, it emerges that for the analyzed intermediate resolution (636 × 600 px), an optimum compromise can be obtained in terms of localization accuracy, CPU utilization, and system robustness (i.e., feature loss). The study with the variation of the frequency shows that, at high frequencies (25 and 30 Hz), better results are obtained in terms of localization. Furthermore, from the computational analysis, it emerged that a frequency of 25 Hz allows a considerable saving in computational terms compared to 30 Hz for this intermediate resolution, albeit with slightly higher translation errors. Therefore, the user can find the appropriate trade-off, depending on the computational capabilities available. In addition to promising punctual results, one of the innovative aspects of this work is that mathematical trends are highlighted and discussed in CPU usage as the frequency and resolution of the system change. This approach opens up several possibilities for CPU savings and localization accuracy improvements without changing the sensor itself since this work demonstrates that localization quality does not necessarily improve by increasing the resolution.
As a future work, it would be interesting to estimate the trends as the frequency resolution changes when using other lenses than fisheye, and multiple visual-inertial odometry algorithms. In addition, a collection of data and a comparison between different environments would help further understand the problem in order to optimize solutions. Finally, it would be interesting to extend the system to multiple cameras (rig of cameras) and to evaluate the effects of resolution and frequency in this configuration also.

Author Contributions

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

Funding

We gratefully acknowledge the financial support that Simone Godio received from Dronomy and Politecnico di Torino.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Authors consent to publish the here presented work.

Data Availability Statement

Contact the authors for implementation details.

Acknowledgments

The PhD fellowship of Simone Godio is funded by Leonardo Company, Italy. The research program is shared with PIC4SeR, the Politecnico di Torino Interdepartmental Center for Service Robotics. We would especially like to thank Air Drone Logistics for their collaboration in this research.

Conflicts of Interest

We declare that we have no financial and personal relationships with other people or organizations that can inappropriately influence our work. There is no professional or other personal interest of any nature or kind in any product, service or company that could be construed as influencing the position presented in, or the review of, the manuscript entitled.

Abbreviations

The following abbreviations are used in this manuscript:
SVOSemi-direct Visual Odometry
GPSGlobal Positioning System
UAVUnmanned Aerial Vehicle
CPUCentral Processing Unit
ROSRobot Operating System
SLAMSimultaneous Localization And Mapping
RGBRed Green Blue
IMUInertial Measurement Unit
GPUGraphics Processing Unit
FOVField Of View
FLFeature Loss

References

  1. Subramanya, K.N.; Rangaswamy, T. Impact of Warehouse Management System in a Supply Chain. Int. J. Comput. Appl. 2012, 54, 14–20. [Google Scholar] [CrossRef]
  2. Chang, J. Research and Implementation on the Logistics Warehouse Management System. In Proceedings of the 2nd International Conference on Social Science and Technology Education (ICSSTE), Guangzhou, China, 14–15 May 2016. [Google Scholar] [CrossRef] [Green Version]
  3. Mostafa, N.; Hamdy, W.; Elawady, H. Towards a Smart Warehouse Management System. In Proceedings of the Third North American Conference On Industrial Engineering and Operations (2018), Washington, DC, USA, 27–29 September 2018. [Google Scholar]
  4. Rey, R.; Corzetto, M.; Cobano, J.A.; Merino, L.; Caballero, F. Human-robot co-working system for warehouse automation. In Proceedings of the 2019 24th IEEE International Conference on Emerging Technologies and Factory Automation (ETFA), Zaragoza, Spain, 10–3 September 2019; pp. 578–585. [Google Scholar] [CrossRef]
  5. Yuan, Z.; Gong, Y. Improving the Speed Delivery for Robotic Warehouses. In Proceedings of the MIM 2016—8th IFAC Conference on Manufacturing Modelling, Management and Control, Troyes, France, 28–30 June 2016; Volume 49. [Google Scholar]
  6. De Koster, R.B.M. Automated and Robotic Warehouses: Developments and Research Opportunities. Logist. Transp. 2018, 38, 33–40. [Google Scholar] [CrossRef]
  7. Panigrahi, P.K.; Bisoy, S.K. Localization strategies for autonomous mobile robots: A review. J. King Saud Univ. Comput. Inf. Sci. 2021, 34, 6019–6039. [Google Scholar] [CrossRef]
  8. Ubaid, A.; Poon, K.; Altayyari, A.M.; Almazrouei, M.R. A Low-cost Localization System for Warehouse Inventory Management. In Proceedings of the 2019 International Conference on Electrical and Computing Technologies and Applications (ICECTA), Ras Al Khaimah, United Arab Emirates, 19–21 November 2019; pp. 1–5. [Google Scholar]
  9. Goran, V.; Damjan, M.; Draganjac, I.; Kovacic, Z.; Lista, P. High-accuracy vehicle localization for autonomous warehousing. Robot. Comput. Integr. Manuf. 2016, 42, 1–16. [Google Scholar] [CrossRef]
  10. Gadd, M.; Newman, P. A framework for infrastructure-free warehouse navigation. In Proceedings of the 2015 IEEE International Conference on Robotics and Automation (ICRA), Seattle, WA, USA, 26–30 May 2015; pp. 3271–3278. [Google Scholar] [CrossRef]
  11. Oth, L.; Furgale, P.; Kneip, L.; Siegwart, R. Rolling Shutter Camera Calibration. In Proceedings of the 2013 IEEE Conference on Computer Vision and Pattern Recognition, Portland, OR, USA, 23–28 June 2013; pp. 1360–1367. [Google Scholar] [CrossRef] [Green Version]
  12. Joern, R.; Janosch, N.; Thomas, S.; Timo, H.; Roland, S. Extending kalibr: Calibrating the extrinsics of multiple IMUs and of individual axes. In Proceedings of the IEEE International Conference on Robotics and Automation (ICRA 2016), Stockholm, Sweden, 16–21 May 2016; pp. 4304–4311. [Google Scholar]
  13. Paul, F.; Joern, R.; Roland, S. Unified Temporal and Spatial Calibration for Multi-Sensor Systems. In Proceedings of the IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS 2013), Tokyo, Japan, 3–7 November 2013. [Google Scholar]
  14. Paul, F.; Timothy, D.B.; Gabe, S. Continuous-Time Batch Estimation Using Temporal Basis Functions. In Proceedings of the IEEE International Conference on Robotics and Automation (ICRA 2012), Saint Paul, MN, USA, 14–18 May 2012; pp. 2088–2095. [Google Scholar]
  15. Maye, J.; Furgale, P.; Siegwart, R. Self-supervised Calibration for Robotic Systems. In Proceedings of the IEEE Intelligent Vehicles Symposium (IVS 2013), Gold Coast, Australia, 23–26 June 2013. [Google Scholar]
  16. Beul, M.; Droeschel, D.; Nieuwenhuisen, M.; Quenzel, J.; Houben, S.; Behnke, S. Fast Autonomous Flight in Warehouses for Inventory Applications. IEEE Robot. Autom. Lett. 2018, 3, 3121–3128. [Google Scholar] [CrossRef] [Green Version]
  17. Christian, F.; Matia, P.; Davide, S. SVO: Fast Semi-Direct Monocular Visual Odometry; ICRA: Gurgaon, India, 2014. [Google Scholar]
  18. Christian, F.; Zichao, Z.; Michael, G. Manuel Werlberger, Davide Scaramuzza. SVO: Semi-Direct Visual Odometry for Monocular and Multi-Camera Systems; TRO: Richmond, VA, USA, 2017. [Google Scholar]
  19. Feng, B.; Zhang, X.; Zhao, H. The Research of Motion Capture Technology Based on Inertial Measurement. In Proceedings of the 2013 IEEE 11th International Conference on Dependable, Autonomic and Secure Computing, Chengdu, China, 21–22 December 2013; pp. 238–243. [Google Scholar] [CrossRef]
  20. Artyom, M.; Lerke, O.; Prado, M.; Dörstelmann, M.; Menges, A.; Schwieger, V. UAV Guidance with Robotic Total Station for Architectural Fabrication Processes. In ICD/ITKE Research Pavilion 2016-17 Aerial Construction—Flying Robots for Architectural Fabrication; Wißner: Augsburg, Germany, 2017. [Google Scholar]
  21. Hu, X.; Luo, Z.; Jiang, W. AGV Localization System Based on Ultra-Wideband and Vision Guidance. Electronics 2020, 9, 448. [Google Scholar] [CrossRef] [Green Version]
  22. Carlos, C.; Richard, E.; Gomez, J.J.; Montiel, J.M.M.; Tardós, J.D. ORB-SLAM3: An Accurate Open-Source Library for Visual, Visual-Inertial and Multi-Map SLAM. arXiv 2020, arXiv:2007.11898. [Google Scholar]
  23. Qin, T.; Li, P.; Shen, S. VINS-Mono: A Robust and Versatile Monocular Visual-Inertial State Estimator. IEEE Trans. Robot. 2018, 34, 1004–1020. [Google Scholar] [CrossRef] [Green Version]
  24. Sun, K.; Mohta, K.; Pfrommer, B.; Watterson, M.; Liu, S.; Mulgaonkar, Y.; Taylor, C.J.; Kumar, V. Robust Stereo Visual Inertial Odometry for Fast Autonomous Flight. IEEE Robot. Autom. Lett. 2017. [Google Scholar] [CrossRef] [Green Version]
  25. Bloesch, M.; Burri, M.; Omari, S.; Hutter, M.; Siegwart, R. Iterated extended Kalman filter.based visual-inertial odometry using direct photometric feedback. Int. J. Robot. Res. 2017, 36, 1053–1072. [Google Scholar] [CrossRef] [Green Version]
  26. Scaramuzza, D.; Fraundorfer, F. Visual Odometry: Part I—The First 30 Years and Fundamentals. IEEE Robot. Automat. Mag. 2011, 18, 80–92 (cit. on pp. 11–13, 16, 30–33). [Google Scholar] [CrossRef]
  27. Mueggler, E.; Gallego, G.; Rebecq, H.; Scaramuzza, D. Continuous-Time Visual-Inertial Odometry for Event Cameras. IEEE Trans. Robot. 2018, 34, 1425–1440. [Google Scholar] [CrossRef] [Green Version]
  28. He, Y.; Zhao, J.; Guo, Y.; He, W.; Yuan, K. PL-VIO: Tightly-Coupled Monocular Visual–Inertial Odometry Using Point and Line Features. Sensors 2018, 18, 1159. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  29. Burusa, A.K. Visual-Inertial Odometry for Autonomous Ground Vehicles. In Degree Project In Computer Science And Engineering, Stockholm; DiVA: Luleå, Sweden, 2017. [Google Scholar]
  30. Leutenegger, S.; Lynen, S.; Bosse, M.; Siegwart, R.; Furgale, P. Keyframe-based visual–inertial odometry using nonlinear optimization. Int. J. Robot. Res. 2015, 34, 314–334. [Google Scholar] [CrossRef] [Green Version]
  31. Suriano, F. Study of SLAM State of Art Techniques for UAVs Navigation in Critical Environments. In Degree Project in Aerospace Engineering, 16 Credits; Politecnico di Torino: Turin, Italy, 2021. [Google Scholar]
  32. Barfoot, T.D. State Estimation for Robotics—A Matrix Lie Group Approach; Cambridge University Press: Cambridge, UK, 2015. [Google Scholar]
  33. Valladares, S.; Toscano, M.; Tufino, R.; Morillo, P.; Vallejo, D. Performance Evaluation of the Nvidia Jetson Nano Through a Real-Time Machine Learning Application. Int. Conf. Intell. Hum. Syst. Integr. 2021, 1322, 343–349. [Google Scholar] [CrossRef]
  34. Woodman, O.J. An Introduction to Inertial Navigation (Research Report696); University of Cambridge: Cambridge, UK, 2007. [Google Scholar]
  35. Ciarán, H.; Robert, M.; Patrick, D.; Martin, G.; Edward, J. Equidistant fish-eye perspective with application in distortion centre estimation. Image Vis. Comput. 2010, 28, 538–551. [Google Scholar] [CrossRef]
  36. Shah, S.; Aggarwal, J.K. Intrinsic parameter calibration procedure for a (high-distortion) fish-eye lens camera with distortion model and accuracy estimation. Pattern Recognit. 1996, 29, 1775–1788. [Google Scholar] [CrossRef]
  37. Hu, G.; Zhou, Z.; Cao, J.; Huang, H. Nonlinear calibration optimization based on the Levenberg-Marquardt algorithm. IET Image Process. 2019, 14, 1402–1414. [Google Scholar] [CrossRef]
Figure 1. Visual-Inertial Odometry feature matching principle and IMU (Inertial Measurement Unit) measurements during motion [28].
Figure 1. Visual-Inertial Odometry feature matching principle and IMU (Inertial Measurement Unit) measurements during motion [28].
Sensors 22 09911 g001
Figure 2. Loosely coupled sensor fusion approach.
Figure 2. Loosely coupled sensor fusion approach.
Sensors 22 09911 g002
Figure 3. Tightly coupled sensor fusion approach.
Figure 3. Tightly coupled sensor fusion approach.
Sensors 22 09911 g003
Figure 4. (a) Streaming video frequency variation example from 30 Hz to 20 Hz. (b) Decrease in resolution from 848 × 800 px on the center of the image.
Figure 4. (a) Streaming video frequency variation example from 30 Hz to 20 Hz. (b) Decrease in resolution from 848 × 800 px on the center of the image.
Sensors 22 09911 g004
Figure 5. Platform employed in the warehouse: drone in a quadcopter configuration, developed by the Spanish company Dronomy.
Figure 5. Platform employed in the warehouse: drone in a quadcopter configuration, developed by the Spanish company Dronomy.
Sensors 22 09911 g005
Figure 6. (a) 848 × 800 px; (b) 636 × 600 px; (c) 424 × 400 px. ROS camera-calibration process capture for each of the resolutions selected with the respective target feature extraction. The marker employed is a 7 × 6 chessboard with a square size of 5.9 cm.
Figure 6. (a) 848 × 800 px; (b) 636 × 600 px; (c) 424 × 400 px. ROS camera-calibration process capture for each of the resolutions selected with the respective target feature extraction. The marker employed is a 7 × 6 chessboard with a square size of 5.9 cm.
Sensors 22 09911 g006
Figure 7. Example of modeling accelerometer and gyroscope bias by cubic B-spline.
Figure 7. Example of modeling accelerometer and gyroscope bias by cubic B-spline.
Sensors 22 09911 g007
Figure 8. (a) Left cam reprojection error; (b) Right cam reprojection error. ROS k a l i b r reprojection errors after the calibration optimization process. Mean reprojection error (left cam) px: 0.1627. Mean reprojection error (right cam) px: 0.1734.
Figure 8. (a) Left cam reprojection error; (b) Right cam reprojection error. ROS k a l i b r reprojection errors after the calibration optimization process. Mean reprojection error (left cam) px: 0.1627. Mean reprojection error (right cam) px: 0.1734.
Sensors 22 09911 g008
Figure 9. Example of a trajectory estimated inside the warehouse, with a resolution of 636 × 600 px at a sampling rate of 25 Hz.
Figure 9. Example of a trajectory estimated inside the warehouse, with a resolution of 636 × 600 px at a sampling rate of 25 Hz.
Sensors 22 09911 g009
Figure 10. (a) X max error, 15 Hz; (b) Y error, 15 Hz; (c) Z max error, 15 Hz; (d) X max error, 20 Hz; (e) Y error, 20 Hz; (f) Z max error, 20 Hz; (g) X max error, 25 Hz; (h) Y error, 25 Hz; (i) Z max error, 25 Hz; (j) X max error, 30 Hz; (k) Y error, 30 Hz; (l) Z max error, 30 Hz. Translation error analysis along the trajectory performed by varying resolution.
Figure 10. (a) X max error, 15 Hz; (b) Y error, 15 Hz; (c) Z max error, 15 Hz; (d) X max error, 20 Hz; (e) Y error, 20 Hz; (f) Z max error, 20 Hz; (g) X max error, 25 Hz; (h) Y error, 25 Hz; (i) Z max error, 25 Hz; (j) X max error, 30 Hz; (k) Y error, 30 Hz; (l) Z max error, 30 Hz. Translation error analysis along the trajectory performed by varying resolution.
Sensors 22 09911 g010
Figure 11. (a) X max err, 424 × 400; (b) Y err, 424 × 400; (c) Z max err, 424 × 400; (d) X max err, 636 × 600; (e) Y err, 636 × 600; (f) Z max err, 636 × 600; (g) X max err, 848 × 800; (h) Y err, 848 × 800; (i) Z max err, 848 × 800. Translation error analysis along the trajectory performed by varying frequency.
Figure 11. (a) X max err, 424 × 400; (b) Y err, 424 × 400; (c) Z max err, 424 × 400; (d) X max err, 636 × 600; (e) Y err, 636 × 600; (f) Z max err, 636 × 600; (g) X max err, 848 × 800; (h) Y err, 848 × 800; (i) Z max err, 848 × 800. Translation error analysis along the trajectory performed by varying frequency.
Sensors 22 09911 g011
Figure 12. (a) 424 × 400, 15 Hz; (b) 424 × 400, 20 Hz; (c) 424 × 400, 25 Hz; (d) 424 × 400, 30 Hz; (e) 636 × 600, 15 Hz; (f) 636 × 600, 20 Hz; (g) 636 × 600, 25 Hz.; (h) 636 × 600, 30 Hz; (i) 848 × 800, 15 Hz; (j) 848 × 800, 20 Hz; (k) 848 × 800, 25 Hz; (l) 848 × 800, 30 Hz. 3D trajectory of all the conditions analyzed.
Figure 12. (a) 424 × 400, 15 Hz; (b) 424 × 400, 20 Hz; (c) 424 × 400, 25 Hz; (d) 424 × 400, 30 Hz; (e) 636 × 600, 15 Hz; (f) 636 × 600, 20 Hz; (g) 636 × 600, 25 Hz.; (h) 636 × 600, 30 Hz; (i) 848 × 800, 15 Hz; (j) 848 × 800, 20 Hz; (k) 848 × 800, 25 Hz; (l) 848 × 800, 30 Hz. 3D trajectory of all the conditions analyzed.
Sensors 22 09911 g012
Figure 13. (a) CPU usage, 15 Hz; (b) CPU usage, 20 Hz; (c) CPU usage, 25 Hz; (d) CPU usage, 30 Hz. Jetson Nano board computational cost analysis along the trajectory performed by varying the resolution.
Figure 13. (a) CPU usage, 15 Hz; (b) CPU usage, 20 Hz; (c) CPU usage, 25 Hz; (d) CPU usage, 30 Hz. Jetson Nano board computational cost analysis along the trajectory performed by varying the resolution.
Sensors 22 09911 g013
Figure 14. (a) CPU usage, 424 × 400; (b) CPU usage, 636 × 600; (c) CPU usage, 848 × 800. Jetson Nano board computational cost analysis along the trajectory performed by varying the frequency.
Figure 14. (a) CPU usage, 424 × 400; (b) CPU usage, 636 × 600; (c) CPU usage, 848 × 800. Jetson Nano board computational cost analysis along the trajectory performed by varying the frequency.
Sensors 22 09911 g014
Figure 15. (a) FL, 15 Hz; (b) FL, 20 Hz; (c) FL, 25 Hz; (d) FL, 30 Hz. Feature loss analysis along the trajectory performed by varying resolution.
Figure 15. (a) FL, 15 Hz; (b) FL, 20 Hz; (c) FL, 25 Hz; (d) FL, 30 Hz. Feature loss analysis along the trajectory performed by varying resolution.
Sensors 22 09911 g015
Figure 16. (a) FL, 424 × 400; (b) FL, 636 × 600; (c) FL, 848 × 800. Feature loss analysis along the trajectory performed by varying frequency.
Figure 16. (a) FL, 424 × 400; (b) FL, 636 × 600; (c) FL, 848 × 800. Feature loss analysis along the trajectory performed by varying frequency.
Sensors 22 09911 g016
Table 1. Gyroscope and accelerometer calibration parameters. Equations are derived in [34].
Table 1. Gyroscope and accelerometer calibration parameters. Equations are derived in [34].
ParameterSymbolBNI055Unit
Gyroscope “white noise” σ g 0.0018491rad (s Hz ) 1
Accelerometer “white noise” σ a 0.01094m (s2 Hz ) 1
Gyroscope “bias instability” σ b g 2.5482 × 10 5 rad Hz ( s ) 1
Accelerometer “bias instability” σ b a 0.00058973m Hz ( s ) 2
Table 2. Intrinsic and distortion parameters for left (l) and right (r) fisheye cameras for the three resolutions selected. The parameters f x and f y represent the focal length along X and Y. Instead, c x and c y are the principal point coordinates along X and Y. While k 1 , k 2 , k 3 , k 4 are the distortion parameters of the equidistant camera model [36].
Table 2. Intrinsic and distortion parameters for left (l) and right (r) fisheye cameras for the three resolutions selected. The parameters f x and f y represent the focal length along X and Y. Instead, c x and c y are the principal point coordinates along X and Y. While k 1 , k 2 , k 3 , k 4 are the distortion parameters of the equidistant camera model [36].
Param 848 × 800 l 636 × 600 l 424 × 400 l 848 × 800 r 636 × 600 r 424 × 400 r
f x 285.3568285.3568285.7695285.5315285.5315285.3433
f y 285.4461285.4461285.6246285.5397285.5397285.1813
c x 419.0777310.2573207.0993414.3119305.4019202.1401
c y 399.5762297.1926200.8910396.4943294.4193196.9490
k 1 −0.005900−0.005900−0.005900−0.006894−0.006894−0.006894
k 2 0.041590.041600.041600.043970.043970.04397
k 3 −0.03861−0.03861−0.03861−0.04040−0.04040−0.04040
k 4 0.0064500.0064510.0064510.0068430.0068430.006843
Table 3. Low-resolution CPU usage values.
Table 3. Low-resolution CPU usage values.
Freq (Hz)Mean (% CPU)Max (% CPU)Min (% CPU)
1513.968165.5
2016.57819.254
2518.14821.59
3019.05624.257.5
Table 4. Mean-resolution CPU usage values.
Table 4. Mean-resolution CPU usage values.
Freq (Hz)Mean (% CPU)Max (% CPU)Min (% CPU)
1524.54330.521.25
2034.99345.2523.75
2537.29844.529.25
3045.315330.5
Table 5. High-resolution CPU usage values.
Table 5. High-resolution CPU usage values.
Freq (Hz)Mean (% CPU)Max (% CPU)Min (% CPU)
1540.6584634
2048.04850.7544.25
2549.4675148.5
3049.6375348.25
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Godio, S.; Carrio, A.; Guglieri, G.; Dovis, F. Resolution and Frequency Effects on UAVs Semi-Direct Visual-Inertial Odometry (SVO) for Warehouse Logistics. Sensors 2022, 22, 9911. https://doi.org/10.3390/s22249911

AMA Style

Godio S, Carrio A, Guglieri G, Dovis F. Resolution and Frequency Effects on UAVs Semi-Direct Visual-Inertial Odometry (SVO) for Warehouse Logistics. Sensors. 2022; 22(24):9911. https://doi.org/10.3390/s22249911

Chicago/Turabian Style

Godio, Simone, Adrian Carrio, Giorgio Guglieri, and Fabio Dovis. 2022. "Resolution and Frequency Effects on UAVs Semi-Direct Visual-Inertial Odometry (SVO) for Warehouse Logistics" Sensors 22, no. 24: 9911. https://doi.org/10.3390/s22249911

APA Style

Godio, S., Carrio, A., Guglieri, G., & Dovis, F. (2022). Resolution and Frequency Effects on UAVs Semi-Direct Visual-Inertial Odometry (SVO) for Warehouse Logistics. Sensors, 22(24), 9911. https://doi.org/10.3390/s22249911

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

Article Metrics

Back to TopTop