Skip to content

Latest commit

 

History

History
71 lines (42 loc) · 3 KB

README.md

File metadata and controls

71 lines (42 loc) · 3 KB

FaderNet: Implementation & Study

Alex Liu & Kevin Li, NTU CSIE


Desciprtion

This is our final project repository of the course ADLxMLDS, 2017 Fall.

In this project, we implement FaderNet (NIPS 2017) and do capacity/reproducbility/ablation study. Our results can be found in the poster.

We've noticed that Facebook had released the offical github for FaderNet. Since we've started the project slightly earlier than it's release, ONLY in the part of testing FaderNet on unseen data (out of CelebA) had we used the model & modified the testing code FaceBook released. For all the remaining parts including training & experiments, we're using our own implementation.

The paper also specified their strategy on model selection, which we are not capable to reproduce due to resource limitaion. With our own model, we obtain a slightly worse result than the paper due to the limitation of computing power and time we have.

Dependency & Requirement

Packages used in this project

Please make sure each of them is installed with the correct version

  • numpy
  • SciPy
  • pytorch (0.3.0.post4)
  • pandas (0.20.3)
  • skimage (0.13.1)
  • matplotlib (2.1.1)

Hardware Requirement

We're running our experiments with following hardware setting

  • CPU : AMD Ryzen 5 1600 (6 cores 12 threads)
  • GPU : GTX 1070 (with 8G memory)
  • RAM : 16G (swap space on Disk is also 16G)

*** GPU with CUDA installed correctly *** *** GPU memory MUST provide 8G free memory AT LEAST ***

Training

FaderNet is trained on CelebA, which is a large scale human face dataset. If you'd like to train the network yourself, please download CelebA and preprocess it into 256x256 images by running

    python3 train_celeba.py

The training process tooks about 1 million steps (5~7 days) to generate result comparable to original paper.

Testing

Testing with our own code & model

The model we've trained can be find in checkpoint/. The testing images are the first 10 images in CelebA's testing set, we've uploaded the preprocessed version of them in data/img/ in order to let this part of testing can be done without downloading extra data/model

To generate fig2 in the poster (Reproducibility Study in Experiments), run

    make reproduce

The result will be slightly better than the one in the poster since it's now using the model 100000 steps after the one we've used in poster.

To generate fig3 & fig4 in the poster (Ablation Study in Experiments), run

    python3 train_celeba_aga_AttrFirstLayer.py

and

    python3 train_celeba_aga_NoDiscriminator.py

Note that to run the 3 training codes such as train_celeba.py, please download CelebA and put them in the places you want. Then you need to run python3 src/reshape.py after changing the paths there. You then need to change the 3 paths in these training codes.