Tensorflow implementation of our end-to-end model to recover 3D layouts of indoor scenes.
This repository contains original implementation of the paper: 'Corners for Layout: End-to-End Layout Recovery from 360 Images' by Clara Fernandez-Labrador*, José M. Fácil*, Alejandro Perez-Yus, Cédric Demonceaux, Javier Civera and José J. Guerrero.
The page of the paper is https://cfernandezlab.github.io/CFL/
Please cite CFL in your publications if it helps your research:
@article{fernandez2020corners,
title={Corners for layout: End-to-end layout recovery from 360 images},
author={Fernandez-Labrador, Clara and Facil, Jose M and Perez-Yus, Alejandro and Demonceaux, C{\'e}dric and Civera, Javier and Guerrero, Josechu},
journal={IEEE Robotics and Automation Letters},
year={2020},
publisher={IEEE}
}
Now implemented for TF2 on the TensorFlow addons package! Check the tutorial in this link!
New implementation in PyTorch as well here link!
We recommend the use of a virtual enviroment for the use of this project. (e.g. pew)
$ pew new venvname -p python3 # replace venvname with your prefered name (it also works with python 2.7)
- python3
- g++-4.9
- cuda-10.0
- cuDNN 7.5
- TensorFlow 1.13
You are free to try different configurations. But we do not ensure it had been tested.
(venvname)$ pip install -r requirements.txt
We use this Deformable Convolutions implementation to create EquiConvs, a novel implementation of the convolution for 360º images that adapts the shape of the kernel accordingly to the equirectangular projection distortions. Valid for any task involving panoramic images!
First, make sure to modify Models/make.sh with your computer settings (i.e. CUDA_HOME, CUDA Architecture). Second run the following commands.
(venvname)$ cd Models
(venvname)$ bash make.sh
SUN360: download
StdConvs version: download
EquiConvs version: download
Edit the config file so that the path to the dataset folder and the network parameters is correct.
To run our demo please run:
(venvname)$ python test_CFL.py --dataset Datasets/SUN360/test --weights Weights/StdConvs/model.ckpt --network StdConvs --results results_std # Runs the test examples with Standard Convolutions and save results in 'results_std'
(venvname)$ python test_CFL.py --dataset Datasets/SUN360/test --weights Weights/EquiConvs/model.ckpt --network EquiConvs --results results_equi # Runs the test examples with Equirectangular Convolutions and save results in 'results_equi'
Check this notebook 2Dto3D.ipynb.
You can find our contact information in our personal websites Clara and Jose M.
This software is under GNU General Public License Version 3 (GPLv3), please see GNU License
For commercial purposes, please contact the authors.
This site and the code provided here are under active development. Even though we try to only release working high quality code, this version might still contain some issues. Please use it with caution.