StyleGAN2 Pytorch - Typed, Commented, Installable :)
A simple, typed, commented Pytorch implementation of StyleGAN2.
This implementation is adapted from here. This implementation seems more stable and editable than the over-engineered official implementation.
The focus of this repository is simplicity and readability. If there are any bugs / issues, please kindly let me know or submit a pull request!
Refer to my blog post for an explanation on the custom CUDA kernels. The profiling code to optimize the custom operations is here.
Installation
pip install stylegan2-torch
Training Tips
- Use a multi-GPU setup. An RTX 3090 can handle batch size of up to 8 at 1024 resolution. Based on experience, batch size of 8 works but 16 or 32 should be safer.
- Use LMDB dataset + SSD storage + multiple dataloader workers (and a big enough prefetch factor to cache at least one batch ahead). You never know how much time you waste on dataloading until you optimize it. For me, that shorted the training time by 30% (more time-saving than the custom CUDA kernels).
Known Issues
Pytorch is known to cause random reboots when using non-deterministic algorithms. Set torch.use_deterministic_algorithms(True)
if you encounter that.
To Dos / Won't Dos
- Tidy up
conv2d_gradfix.py
andfused_act.py
. These were just copied over from the original repo so they are still ugly and untidy. - Provide pretrained model conversion method (not that hard tbh, just go map the state_dict keys).
- Clean up util functions to aid training loop design.