Image-based Navigation in Real-World Environments via Multiple Mid-level Representations: Fusion Models Benchmark and Efficient Evaluation
This repository hosts the code related to the paper:
Marco Rosano, Antonino Furnari, Luigi Gulino, Corrado Santoro and Giovanni Maria Farinella, "Image-based Navigation in Real-World Environments via Multiple Mid-level Representations: Fusion Models Benchmark and Efficient Evaluation". Submitted to "Robotics and Autonomous Systems" (RAS), 2022.
For more details please see the project web page at https://iplab.dmi.unict.it/EmbodiedVN.
This code is built on top of the Habitat-api/Habitat-lab project. Please see the Habitat project page for more details.
This repository provides the following components:
-
The implementation of the proposed tool, integrated with Habitat, to train visual navigation models on synthetic observations and test them on realistic episodes containing real-world images. This allows the estimation of real-world performance, avoiding the physical deployment of the robotic agent;
-
The official PyTorch implementation of the proposed visual navigation models, which follow different strategies to combine a range of visual mid-level representations
-
the synthetic 3D model of the proposed environment, acquired using the Matterport 3D scanner and used to perform the navigation episodes at train and test time;
-
the photorealistic 3D model that contains real-world images of the proposed environment, labeled with their pose (X, Z, Angle). The sparse 3D reconstruction was performed using the COLMAP Structure from Motion tool, to then be aligned with the Matterport virtual 3D map.
-
An integration with CycleGAN to train and evaluate navigation models with Habitat on sim2real adapted images.
-
The checkpoints of the best performing navigation models.
- Python >= 3.7, use version 3.7 to avoid possible issues.
- Other requirements will be installed via
pip
in the following steps.
-
(Optional) Create an Anaconda environment and install all on it (
conda create -n fusion-habitat python=3.7; conda activate fusion-habitat
) -
Install the Habitat simulator following the official repo instructions .The development and testing was done on commit
bfbe9fc30a4e0751082824257d7200ad543e4c0e
, installing the simulator "from source", launching the./build.sh --headless --with-cuda
command (guide). Please consider to follow these suggestions if you encounter issues while installing the simulator. -
Install the customized Habitat-lab (this repo):
git clone https://github.com/rosanom/mid-level-fusion-nav.git cd mid-level-fusion-nav/ pip install -r requirements.txt python setup.py develop --all # install habitat and habitat_baselines
-
Download our dataset (journal version) from here, and extract it to the repository folder (
mid-level-fusion-nav/
). Inside thedata
folder you should see this structure:datasets/pointnav/orangedev/v1/... real_images/orangedev/... scene_datasets/orangedev/... orangedev_checkpoints/...
-
(Optional, to check if the software works properly) Download the test scenes data and extract the zip file to the repository folder (
mid-level-fusion-nav/
). To verify that the tool was successfully installed, runpython examples/benchmark.py
orpython examples/example.py
.
All data can be found inside the mid-level-fusion-nav/data/
folder:
- the
datasets/pointnav/orangedev/v1/...
folder contains the generated train and validation navigation episodes files; - the
real_images/orangedev/...
folder contains the real world images of the proposed environment and thecsv
file with their pose information (obtained with COLMAP); - the
scene_datasets/orangedev/...
folder contains the 3D mesh of the proposed environment. orangedev_checkpoints/
is the folder where the checkpoints are saved during training. Place the checkpoint file here if you want to restore the training process or evaluate the model. The system will load the most recent checkpoint file.
There are two configuration files:
habitat_domain_adaptation/configs/tasks/pointnav_orangedev.yaml
and
habitat_domain_adaptation/habitat_baselines/config/pointnav/ddppo_pointnav_orangedev.yaml
.
In the first file you can change the robot's properties, the sensors used by the agent and the dataset used in the experiment. You don't have to modify it.
In the second file you can decide:
- if evaluate the navigation models using RGB or mid-level representations;
- the set of mid-level representations to use;
- the fusion architecture to use;
- if train or evaluate the models using real images, or using the CycleGAN sim2real adapted observations.
...
EVAL_W_REAL_IMAGES: True
EVAL_CKPT_PATH_DIR: "data/orangedev_checkpoints/"
SIM_2_REAL: False #use cycleGAN for sim2real image adaptation?
USE_MIDLEVEL_REPRESENTATION: True
MIDLEVEL_PARAMS:
ENCODER: "simple" # "simple", SE_attention, "mid_fusion", ...
FEATURE_TYPE: ["normal"] #["normal", "keypoints3d","curvature", "depth_zbuffer"]
...
In order to use CycleGAN on Habitat for the sim2real domain adaptation during train or evaluation, follow the steps suggested in the repository of our previous resease.
To train the navigation model using the DD-PPO RL algorithm, run:
sh habitat_baselines/rl/ddppo/single_node_orangedev.sh
To evaluate the navigation model using the DD-PPO RL algorithm, run:
sh habitat_baselines/rl/ddppo/single_node_orangedev_eval.sh
For more information about DD-PPO RL algorithm, please check out the habitat-lab dd-ppo repo page.
The code in this repository, the 3D models and the images of the proposed environment are MIT licensed. See the LICENSE file for details.
The trained models and the task datasets are considered data derived from the correspondent scene datasets.
- Matterport3D based task datasets and trained models are distributed with Matterport3D Terms of Use and under CC BY-NC-SA 3.0 US license.
- Gibson based task datasets, the code for generating such datasets, and trained models are distributed with Gibson Terms of Use and under CC BY-NC-SA 3.0 US license.
This research is supported by OrangeDev s.r.l, by Next Vision s.r.l, the project MEGABIT - PIAno di inCEntivi per la RIcerca di Ateneo 2020/2022 (PIACERI) – linea di intervento 2, DMI - University of Catania, and the grant MIUR AIM - Attrazione e Mobilità Internazionale Linea 1 - AIM1893589 - CUP E64118002540007.