资源算法AnimeGAN

AnimeGAN

2019-09-09 | |  166 |   0 |   0

AnimeGAN

A simple PyTorch Implementation of Generative Adversarial Networks, focusing on anime face drawing.

Randomly Generated Images

The images are generated from a DCGAN model trained on 143,000 anime character faces for 100 epochs.

fake_sample.png

Image Interpolation

Manipulating latent codes, enables the transition from images in the first row to the last row.

fake_transition.png

Original Images

The images are not clean, some outliers can be observed, which degrades the quality of the generated images.

real_sample.png

Usage

To run the experiment,

$ python main.py --dataRoot path_to_dataset/

The pretrained model for DCGAN are also in this repo, play it inside the jupyter notebook.

anime-faces Dataset

Anime-style images of 126 tags are collected from danbooru.donmai.us using the crawler tool gallery-dl. The images are then processed by a anime face detector python-animeface. The resulting dataset contains ~143,000 anime faces. Note that some of the tags may no longer meaningful after cropping, i.e. the cropped face images under 'uniform' tag may not contain visible parts of uniforms.

How to construct the dataset from scratch ?

Prequisites: gallery-dl, python-animeface

  1. Download anime-style images

    # download 1000 images under the tag "misaka_mikoto"gallery-dl --images 1000 "https://danbooru.donmai.us/posts?tags=misaka_mikoto"# in a multi-processing mannercat tags.txt | xargs -n 1 -P 12 -I 'tag'  bash -c ' gallery-dl --images 1000 "https://danbooru.donmai.us/posts?tags=$tag" '
  2. Extract faces from the downloaded images

    import animefacefrom PIL import Imageim = Image.open('images/anime_image_misaka_mikoto.png')faces = animeface.detect(im)x,y,w,h = faces[0].face.posim = im.crop((x,y,x+w,y+h))im.show() # display

I've cleaned the original dataset, the new version of the dataset has 115085 images in 126 tags. You can access the images from: - Brine (a python-based dataset management library): https://www.brine.io/jayleicn/anime-faces - Google Drive: https://drive.google.com/file/d/0B4wZXrs0DHMHMEl1ODVpMjRTWEk/view?usp=sharing - BaiduYun: https://pan.baidu.com/s/1o8Nxllo

Non-commercial use please.

Things I've learned

  1. GANs are really hard to train.

  2. DCGAN generally works well, simply add fully-connected layers causes problems.

  3. In my cases, more layers for G yields better images, in the sense that G should be more powerful than D.

  4. Add noise to D's inputs and labels helps stablize training.

  5. Use differnet input and generate resolution (64x64 vs 96x96), there seems no obvious difference during training, the generated images are also very similar.

  6. Binray Noise as G's input amazingly works, but the images are not as good as those with Gussian Noise, idea credit to @cwhy ['Binary Noise' here I mean a sequence of {-1,1} generated by bernoulli distribution at p=0.5 ]

I did not carefully verify them, if you are looking for some general GAN tips, see @soumith's ganhacks

Others

  1. This project is heavily influenced by chainer-DCGAN and IllustrationGAN, the codes are mostly borrowed from PyTorch DCGAN example, thanks the authors for the clean codes.

  2. Dependencies: pytorch, torchvision

  3. This is a toy project for me to learn PyTorch and GANs, most importantly, for fun! :) Any feedback is welcome.

上一篇:stackGAN-v2

下一篇:seq2seq

用户评价
全部评价

热门资源

  • Keras-ResNeXt

    Keras ResNeXt Implementation of ResNeXt models...

  • seetafaceJNI

    项目介绍 基于中科院seetaface2进行封装的JAVA...

  • spark-corenlp

    This package wraps Stanford CoreNLP annotators ...

  • capsnet-with-caps...

    CapsNet with capsule-wise convolution Project ...

  • inferno-boilerplate

    This is a very basic boilerplate example for pe...