# face3d: Python tools for processing 3D face ## Introduction I organize this repo just for fun & my personal research. Hope this helps and you'll enjoy it. : ) ## Structure ```python # Since triangle mesh is the most popular representation of 3D face, # the main part is mesh processing. mesh/ # written in python(numpy) | io.py # read & write obj | vis.py # plot mesh | transform.py # transform mesh & estimate matrix | light.py # add light & estimate light(to do) | render.py # obj to image using rasterization render # When can not use vercorization to optimize, loops in python are too slow to use. # So write core parts(loop) in c++, then use cython to compile them. mesh_cython/ # written in c++(cython) | render.py # the same API as in mesh/render.py, with faster speed. | light.py # the same API as in mesh/light.py, with faster speed. | mesh_core* # c++ codes of core parts. # 3DMM is one of the most popular methods to generate & reconstruct 3d face. morphabel_model/ # witten in python(numpy) | morphable_model.py # morphable model class: generate & fit | fit.py # estimate shape&expression parameters. 3dmm fitting. | load.py # load 3dmm data ``` ## Examples: * **3dmm**. `run examples/2_3dmm.py` left: random example generated by 3dmm right: 3d face generated by fitted 3dmm&pose parameters using 68 key points data:image/s3,"s3://crabby-images/5c9bc/5c9bc8a7af916d0a221d822b3d7161cf375ccecc" alt="" data:image/s3,"s3://crabby-images/05242/052427a3e1dec169797f3a7cd3fbd32b77a907ab" alt="" * **transform.** `python examples/3_transform.py` left: fix camera position & use orthographic projection. (often used in reconstruction) transform face object: scale, change pitch angle, change yaw angle, change roll angle right: fix obj position & use perspective projection(fovy=30). (simulating real views) move camera position and rotate camera: from far to near, down & up, left & right, rotate camera data:image/s3,"s3://crabby-images/74854/748544760138f47aa072634b2ebd32925cf5ff39" alt="" data:image/s3,"s3://crabby-images/91350/9135090b4ae722c1213ac4da2fb8cf00e164a814" alt="" * **light**. `python examples/4_light.py` single point light: from left to right, from up to down, from near to far data:image/s3,"s3://crabby-images/3110b/3110b8fbbfef3cd026791f49b86ff5bdc6cc0ecf" alt="" * **image map** `python examples/6_image_map.py` render different attributes in image pixels. : depth, pncc, uv coordinates data:image/s3,"s3://crabby-images/a6f1c/a6f1cbd387ea01d09a361a9139c41a7dc4f821bb" alt="" data:image/s3,"s3://crabby-images/c0991/c09916ed3a5c9e303ce8702448e7f4aed0f40606" alt="" data:image/s3,"s3://crabby-images/0e41f/0e41f0b5c71a4127821cfad9cb4b36775dca93c2" alt="" * **uv map** `python examples/7_uv_map.py` render different attributes in uv coordinates. : colors(texture map), position(2d facial image & corresponding position map) data:image/s3,"s3://crabby-images/8b828/8b828a27cdca1a79e063e44f338622768e1c506e" alt="" data:image/s3,"s3://crabby-images/010a0/010a0700ad71fcda2895490602ed447c64941c7d" alt="" data:image/s3,"s3://crabby-images/60900/609002c22490b665892d7a80fe6d32327e4e9217" alt="" ## Getting Started ### Prerequisite - Python 3 (python 2 should work, but I haven't tested) - Python packages: * numpy * skimage (for reading&writing image) * scipy (for loading mat) * Cython (for compiling c++ files) ### Usage 1. Clone the repository ```bash git clone https://github.com/YadiraF/face3d cd face3d ``` 2. Compile c++ files (ignore if you use numpy version) ```bash cd face3d/mesh_cython python setup.py build_ext -i ``` 3. Prepare **BFM** Data (ignore if you don't use 3dmm) see [Data/BFM/readme.md](https://github.com/YadiraF/face3d/blob/master/examples/Data/BFM/readme.md) 4. Run examples