This is a simple and efficient differentiable rasterization-based renderer which has been used in several GVV publications. The implementation is free of most third-party libraries such as OpenGL. The core implementation is in CUDA and C++. We use the layer as a custom Tensorflow op.
The renderer supports the following features:
- Shading based on spherical harmonics illumination. This shading model is differentiable with respect to geometry, texture, and lighting.
- Different visualizations, such as normals, UV coordinates, phong-shaded surface, spherical-harmonics shading and colors without shading.
- Texture map lookups.
- Rendering from multiple camera views in a single batch
Visibility is not differentiable. We do not approximate the gradients for the occluded regions. This simple strategy works for many use cases such as fitting parametric shape models to images.
- Tensorflow 2.2.0
- GPU that supports compute capability 7.0
- CUDA 10.0
- CUDNN 7.6.1
- Python 3.5
- CMake 3.9 and higher
- Clone the repository
- Change the cmake in cpp/cmakeTF2Linux (lines under "TO BE CUSTOMIZED") pointing to your CUDA and TF path
- Run createBuildLinux.sh
- Navigate to cpp/build/Linux and run make
- If compilation finished, there should be the files cpp/binaries/Linux/Release/libCustomTensorFlowOperators.so
- Clone the repository
- Change the cmake in cpp/cmakeTF2Windows (lines under "TO BE CUSTOMIZED") pointing to your CUDA and TF path
- Run createBuildWin64.bat
- Navigate to cpp/build/Win64 and compile with Visual studio (tested on VS 2015 x64)
- If compilation finished, there should be the files cpp/binaries/Win64/Release/CustomTensorFlowOperators.dll
- Forward pass in python/test_render.py
- Gradient tests in python/test_gradients*.py
Please cite the following papers if you use the renderer in your project:
@inproceedings{deepcap,
title = {DeepCap: Monocular Human Performance Capture Using Weak Supervision},
author = {Habermann, Marc and Xu, Weipeng and Zollhoefer, Michael and Pons-Moll, Gerard and Theobalt, Christian},
booktitle = {{IEEE} Conference on Computer Vision and Pattern Recognition (CVPR)},
month = {jun},
organization = {{IEEE}},
year = {2020},
}
@misc{r2020learning,
title={Learning Complete 3D Morphable Face Models from Images and Videos},
author={Mallikarjun B R and Ayush Tewari and Hans-Peter Seidel and Mohamed Elgharib and Christian Theobalt},
year={2020},
eprint={2010.01679},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
@misc{r2020monocular,
title={Monocular Reconstruction of Neural Face Reflectance Fields},
author={Mallikarjun B R. and Ayush Tewari and Tae-Hyun Oh and Tim Weyrich and Bernd Bickel and Hans-Peter Seidel and Hanspeter Pfister and Wojciech Matusik and Mohamed Elgharib and Christian Theobalt},
year={2020},
eprint={2008.10247},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
The contents of this repository, and the pretrained models are made available under CC BY 4.0. Please read the license terms.
- Marc Habermann
- Mallikarjun B R
- Linjie Liu
- Ayush Tewari