Skip to content

The official code for "ImFace: A Nonlinear 3D Morphable Face Model with Implicit Neural Representations" presented at CVPR 2022, along with its extended version ImFace++.

License

Notifications You must be signed in to change notification settings

MingwuZheng/ImFace

Repository files navigation

ImFace: A Nonlinear 3D Morphable Face Model with Implicit Neural Representations

Official code for CVPR 2022 paper ImFace: A Nonlinear 3D Morphable Face Model with Implicit Neural Representations.

The paper presents a novel 3D morphable face model, namely ImFace, to learn a nonlinear and continuous space with implicit neural representations. ImFace explicitly disentangles facial shape morphs into two separate deformation fields associated with identity and expression, respectively. Then, we can interoperate identity and expression embeddings to generate high quality 3D faces.

Installation Requirmenets

The code is compatible with python 3.8.10 and pytorch 1.9.0. You can create an anaconda environment called imface with the required dependencies by running:

conda create -n imface
conda activate imface
pip install -r requirement.txt

[2023.12] ImFace++

Release the ImFace++ trained on FaceScape dataset. We propose a refinement displacement field which can faithfully encode high-frequency details, thereby enhancing the representation capabilities of ImFace++. ImFace++ can reconstruct and synthesize 3D faces spanning a wide range of facial expressions and it renders more vivid results.

Technical details of ImFace++ can be found in this research paper: ImFace++: A Sophisticated Nonlinear 3D Morphable Face Model with Implicit Neural Representations

Checkout to the branch ImFace++ for more details of generation and fitting.

Usage

Data

We sample 5,323 face scans from 355 persons with 15 expressions from the FaceScape Dataset. The data contains each individual's mesh and key points, which can be used in our experiment.

Data Preprocessing

First, you have to extracted the TU mesh downloaded from FaceScape to dataset/FacescapeOriginData. Then, to get pseudo watertight mesh and samples from the face, run:

python data_preprocess/preprocess.py

For more information on the preprocessing, we recommend you to our paper.

After preprocessing, the dataset folder sturture is as follow:

dataset
  |————FacescapeOriginData         # data extracted from FaceScape
  |       └——————1                 # person identity
  |         └——————1_neutral.obj   # TU mesh
  |         └——————2_smile.obj     # TU mesh
  |         └——————...
  |       └——————2                 # person identity
  |         └——————...
  |————Facescape
  |       └——————1                      # person identity
  |       	└——————1_free_grd.npy  # (15000, 3) sphere points gradient vector with neutral expression (number 1)
  |       	└——————1_free_pcl.npy  # (15000, 3) sphere points position 
  |       	└——————1_free_sdf.npy  # (15000, 1) sphere points SDF 
  |       	└——————1_surf_nor.npy  # (250000, 3) surface points normal
  |       	└——————1_surf_pcl.npy  # (250000, 3) surface points position
  |       	└——————1.bnd           # (68, 3) key points
  |       	└——————1.obj           # pseudo watertight mesh
  |             └——————2_free_grd.npy  # (15000, 3) sphere points gradient vector with smile expression (number 2)
  |       	└——————2_free_pcl.npy  # (15000, 3) sphere points position 
  |       	└——————2_free_sdf.npy  # (15000, 1) sphere points SDF 
  |       	└——————2_surf_nor.npy  # (250000, 3) surface points normal
  |       	└——————2_surf_pcl.npy  # (250000, 3) surface points position
  |       	└——————2.bnd           # (68, 3) key points
  |       	└——————2.obj           # pseudo watertight mesh
  |       	└——————...
  |       └——————2                     # person identity
  |       	└——————...

Train

For training ImFace, run:

python run/train.py [--config file's name]

Please check pathes in your config file are both correct. Results can be found in result/<timestamp>/. Our trained model can be downloaded as follow:

Trained Model Description
ImFace(SE3) deformation with a SE(3) field
ImFace(translation) common translation deformation

Evaluation

For evaluating chamfer distance and f1_score of testing set with trained model, run:

python run/fit.py [--config file's name]

Please modify the load_path in config file with your checkpoint's path and make sure warp_type matches the trained model. Results can be found in result/<timestamp>/fit.

Fit with one 3D face

For fitting one sample, which is generated from FaceScape toolkit, run:

# preprocess demo data
python demo/process.py
# fit demo
python run/fit_one_sample.py [--config file's name]

Please modify the load_path in config file with your checkpoint's path and make sure warp_type matches the trained model. Results can be found in demo/fit.

Related Projects

NeuFace: Realistic 3D Neural Face Rendering from Multi-view Images (CVPR 2023)

ImFace++: A Sophisticated Nonlinear 3D Morphable Face Model with Implicit Neural Representations (code coming soon)

Citation

If you find our work useful in your research, please consider citing:

@inproceedings{zheng2022imface,
  title={ImFace: A Nonlinear 3D Morphable Face Model with Implicit Neural Representations},
  author={Zheng, Mingwu and Yang, Hongyu and Huang, Di and Chen, Liming},
  booktitle={Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition},
  pages={20343--20352},
  year={2022}
}
@inproceedings{zheng2023neuface,
  title={NeuFace: Realistic 3D Neural Face Rendering from Multi-view Images},
  author={Zheng, Mingwu and Zhang, Haiyu and Yang, Hongyu and Huang, Di},
  booktitle={Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition},
  pages={16868--16877},
  year={2023}
}
 @article{zheng2023imface++,
  title={ImFace++: A Sophisticated Nonlinear 3D Morphable Face Model with Implicit Neural Representations},
  author={Zheng, Mingwu and Zhang, Haiyu and Yang, Hongyu and Chen, Liming and Huang, Di},
  journal={arXiv preprint arXiv:2312.04028},
  year={2023}
}

About

The official code for "ImFace: A Nonlinear 3D Morphable Face Model with Implicit Neural Representations" presented at CVPR 2022, along with its extended version ImFace++.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages