This is the official code repository for the LiDAR-in-the-loop Hyperparameter Optimization, to be presented at CVPR 2023. This GitHub repository only contains the transient LiDAR simulator source code that was used to generate the realistic point cloud data. It does not contain the optimization algorithm and the object detector sources. The latter is based on the OpenPCDet library.
This package requires a customized Carla engine docker image which can be downloaded here and a corresponding carla python interface which can be installed from the carla wheel file located in this repository. Only python 3.8 is supported with this wheel and other python dependencies are listed in the setup.cfg file (see Installation for more detailed setup instructions).
.
├── litl_simulator # contains our LiDAR simulator and viewers
│ ├── bases.py
│ ├── data_descriptors.py
│ ├── exceptions.py
│ ├── gui.py
│ ├── settings.py
│ ├── utils.py
│ ├── lidargui # source code for viewer
│ │ └── ...
│ └── process_pipelines # contains source code for raw data processing
│ │ └── ...
│ └── simulation # contains tools for raw data generation
│ └── ...
├── tutorials # contains tutorial notebooks
│ └── ...
├── .gitignore
├── LICENSE
├── README.md
└── teaser.gif
-
Install anaconda.
-
Execute the following commands.
# Create a new conda environment.
conda create --name litl_simulator python=3.8 -y
# Activate the newly created conda environment.
conda activate litl_simulator
# Clone this repository (including submodules!).
git clone [email protected]:princeton-computational-imaging/LITL-Optimization.git
cd LITL-Optimization
# Install packages
pip install .
# Install carla python interface
pip install carla-0.9.13-cp38-cp38-linux_x86_64.whl
-
Download custom carla engine docker image here.
-
Load carla image into docker registry.
docker load -i path/to/carla_image.tar.gz
- Look at tutorial part 1 to run the custom carla engine.
There are 3 notebooks in the tutorials directory which explains in details how to use this repository. To run them, execute the following commands:
# install jupyter notebooks
pip install notebook
# run jupyter in the tutorials directory
# this will open a browser window from which you can select the desired notebook
jupyter notebook tutorials
- part 1 explains how to generate raw data from the custom carla engine which can be downloaded using the link above. It also details how to run the docker image in order to visualize the scene from which the point clouds are generated in real time.
- part 2 shows how to use the various models implemented in this repo in order to generate realistic point clouds.
- part 3 discribes the special GUI developed to visualize the point clouds generated with this project.
The code has been successfully tested on
- Ubuntu 18.04.6 and 20.04 LTS + CUDA 11.3 + python 3.8
This software is made available under the GPL v3 licence. See the LICENCE file for more info.
If you find this work useful, please consider citing our paper.
@inproceeding{goudreault2023lidarhyperoptim,
title={LiDAR-in-the-loop Hyperparameter Optimization},
author={Felix Goudreault and Dominik Scheuble and Mario Bijelic and Nicolas Robidoux and Felix Heide},
journal={Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
year={2023}
}
You may also want to check out our earlier works:
Differentiable Compound Optics and Processing Pipeline Optimization for End-to-end Camera Design.
@article{Tseng2021DeepCompoundOptics,
title={Differentiable Compound Optics and Processing Pipeline Optimization for End-to-end Camera Design},
author={Tseng, Ethan and Mosleh, Ali and Mannan, Fahim and St-Arnaud, Karl and Sharma, Avinash and Peng, Yifan and Braun, Alexander and Nowrouzezahrai, Derek and Lalonde, Jean-Francois and Heide, Felix},
journal={ACM Transactions on Graphics (TOG)},
volume={40},
number={2},
articleno = {18}
year={2021},
publisher={ACM}
}
Hardware-in-the-loop End-to-end Optimization of Camera Image Processing Pipelines.
@InProceedings{isp_opt_cvpr20,
author={Mosleh, Ali and Sharma, Avinash and Onzon, Emmanuel and Mannan, Fahim and Robidoux, Nicolas and Heide, Felix},
title={Hardware-in-the-loop End-to-end Optimization of Camera Image Processing Pipelines},
booktitle = {IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
month = {June},
year = {2020}
}
End-to-end High Dynamic Range Camera Pipeline Optimization.
@InProceedings{robidoux2021hdr_isp_opt,
author = {Nicolas Robidoux, Luis Eduardo García Capel, Dong-eun Seo, Avinash Sharma, Federico Ariza, Felix Heide},
title = {End-to-end High Dynamic Range Camera Pipeline Optimization},
booktitle = {Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition},
year = {2021}
}
Please feel free to suggest improvements to this repository.
We are always open to merge useful pull request.