# mmgeneration **Repository Path**: open-mmlab/mmgeneration ## Basic Information - **Project Name**: mmgeneration - **Description**: 基于 PyTorch 和 MMCV 的图像和视频生成工具箱,支持多种生成模型如图像生成,条件生成,图像转换的训练和测试。它同时提供了丰富的应用,包含了 GANs 的插值,投影和图像编辑。 - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 42 - **Forks**: 11 - **Created**: 2022-04-18 - **Last Updated**: 2025-04-21 ## Categories & Tags **Categories**: image-processing **Tags**: None ## README
 
OpenMMLab 官网 HOT      OpenMMLab 开放平台 TRY IT OUT
 
[![PyPI](https://img.shields.io/pypi/v/mmgen)](https://pypi.org/project/mmgen) [![docs](https://img.shields.io/badge/docs-latest-blue)](https://mmgeneration.readthedocs.io/en/latest/) [![badge](https://github.com/open-mmlab/mmgeneration/workflows/build/badge.svg)](https://github.com/open-mmlab/mmgeneration/actions) [![codecov](https://codecov.io/gh/open-mmlab/mmgeneration/branch/master/graph/badge.svg)](https://codecov.io/gh/open-mmlab/mmgeneration) [![license](https://img.shields.io/github/license/open-mmlab/mmgeneration.svg)](https://github.com/open-mmlab/mmgeneration/blob/master/LICENSE) [![open issues](https://isitmaintained.com/badge/open/open-mmlab/mmgeneration.svg)](https://github.com/open-mmlab/mmgeneration/issues) [![issue resolution](https://isitmaintained.com/badge/resolution/open-mmlab/mmgeneration.svg)](https://github.com/open-mmlab/mmgeneration/issues) [📘使用文档](https://mmgeneration.readthedocs.io/en/latest/) | [🛠️安装教程](https://mmgeneration.readthedocs.io/en/latest/get_started.html#installation) | [👀模型库](https://mmgeneration.readthedocs.io/en/latest/modelzoo_statistics.html) | [🆕更新记录](https://github.com/open-mmlab/mmgeneration/blob/master/docs/en/changelog.md) | [🚀进行中的项目](https://github.com/open-mmlab/mmgeneration/projects) | [🤔提出问题](https://github.com/open-mmlab/mmgeneration/issues) [English](README.md) | 简体中文 ## 最新进展 我们将MMGeneration合入了[MMEditing](https://github.com/open-mmlab/mmediting/tree/1.x),并支持了新的生成任务和算法。请关注以下新特性: - 🌟 图文生成任务 - ✅ [GLIDE](https://github.com/open-mmlab/mmediting/tree/1.x/projects/glide/configs/README.md) - ✅ [Disco-Diffusion](https://github.com/open-mmlab/mmediting/tree/1.x/configs/disco_diffusion/README.md) - ✅ [Stable-Diffusion](https://github.com/open-mmlab/mmediting/tree/1.x/configs/stable_diffusion/README.md) - 🌟 3D生成任务 - ✅ [EG3D](https://github.com/open-mmlab/mmediting/tree/1.x/configs/eg3d/README.md) ## 简介 MMGeneration 是一个基于 PyTorch 和[MMCV](https://github.com/open-mmlab/mmcv)的强有力的生成模型工具箱,尤其专注于 GAN 模型。 主分支目前支持 **PyTorch 1.5** 以上的版本。
## 主要特性 - **高质量高性能的训练:** 我们目前支持 Unconditional GANs, Internal GANs, 以及 Image Translation Models 的训练。很快将会支持 conditional models 的训练。 - **强有力的应用工具箱:** 为用户提供了丰富的工具箱,包含 GANs 中的多种应用。我们的框架集成了 GANs 的插值,投影和编辑。请用你的 GANs 尽情尝试!([应用教程](docs/tutorials/applications.md)) - **生成模型的高效分布式训练:** 对于生成模型中的高度动态训练,我们采用 `MMDDP` 的新方法来训练动态模型。([DDP教程](docs/tutorials/ddp_train_gans.md)) - **灵活组合的新型模块化设计:** 针对复杂的损失模块,我们提出了一种新的设计,可以自定义模块之间的链接,实现不同模块之间的灵活组合。 ([新模块化设计教程](docs/tutorials/customize_losses.md))
训练可视化
GAN 插值
GAN 投影
GAN 编辑
## 亮点 - **Positional Encoding as Spatial Inductive Bias in GANs (CVPR2021)** 已在 `MMGeneration` 中发布. [\[配置文件\]](configs/positional_encoding_in_gans/README.md), [\[项目主页\]](https://nbei.github.io/gan-pos-encoding.html) - 我们已经支持训练目前主流的 Conditional GANs 模型,更多的方法和预训练权重马上就会发布,敬请期待。 - 混合精度训练已经在 `StyleGAN2` 中进行了初步支持,请到[这里](configs/styleganv2/README.md)查看各种实现方式的详细比较。 ## 更新日志 v0.7.3 在 14/04/2023 发布。 关于细节和发布历史,请参考 [changelog.md](docs/zh_cn/changelog.md)。 ## 安装 MMGeneration 依赖 [PyTorch](https://pytorch.org/) 和 [MMCV](https://github.com/open-mmlab/mmcv),以下是安装的简要步骤。 **步骤 1.** 依照[官方教程](https://pytorch.org/get-started/locally/)安装PyTorch,例如 ```python pip3 install torch torchvision ``` **步骤 2.** 使用 [MIM](https://github.com/open-mmlab/mim) 安装 MMCV ``` pip3 install openmim mim install mmcv-full ``` **步骤 3.** 从源码安装 MMGeneration ``` git clone https://github.com/open-mmlab/mmgeneration.git cd mmgeneration pip3 install -e . ``` 更详细的安装指南请参考 [get_started.md](docs/zh/get_started.md) . ## 快速入门 对于 `MMGeneration` 的基本使用请参考 [快速入门](docs/zh_cn/get_started.md)。其他细节和教程,请参考我们的[文档](https://mmgeneration.readthedocs.io/)。 ## 模型库 这些算法在我们的框架中得到了认真研究和支持。
Unconditional GANs (点击折叠) - ✅ [DCGAN](configs/dcgan/README.md) (ICLR'2016) - ✅ [WGAN-GP](configs/wgan-gp/README.md) (NIPS'2017) - ✅ [LSGAN](configs/lsgan/README.md) (ICCV'2017) - ✅ [GGAN](configs/ggan/README.md) (arXiv'2017) - ✅ [PGGAN](configs/pggan/README.md) (ICLR'2018) - ✅ [StyleGANV1](configs/styleganv1/README.md) (CVPR'2019) - ✅ [StyleGANV2](configs/styleganv2/README.md) (CVPR'2020) - ✅ [StyleGANV3](configs/styleganv3/README.md) (NeurIPS'2021) - ✅ [Positional Encoding in GANs](configs/positional_encoding_in_gans/README.md) (CVPR'2021)
Conditional GANs (点击折叠) - ✅ [SNGAN](configs/sngan_proj/README.md) (ICLR'2018) - ✅ [Projection GAN](configs/sngan_proj/README.md) (ICLR'2018) - ✅ [SAGAN](configs/sagan/README.md) (ICML'2019) - ✅ [BIGGAN/BIGGAN-DEEP](configs/biggan/README.md) (ICLR'2019)
Tricks for GANs (点击折叠) - ✅ [ADA](configs/ada/README.md) (NeurIPS'2020)
Image2Image Translation (点击折叠) - ✅ [Pix2Pix](configs/pix2pix/README.md) (CVPR'2017) - ✅ [CycleGAN](configs/cyclegan/README.md) (ICCV'2017)
Internal Learning (点击折叠) - ✅ [SinGAN](configs/dcgan/README.md) (ICCV'2019)
Denoising Diffusion Probabilistic Models (点击折叠) - ✅ [Improved DDPM](configs/improved_ddpm/README.md) (arXiv'2021)
## 相关应用 - ✅ [MMGEN-FaceStylor](https://github.com/open-mmlab/MMGEN-FaceStylor) ## 贡献指南 我们感谢所有的贡献者为改进和提升 MMGeneration 所作出的努力。请参考[贡献指南](https://github.com/open-mmlab/mmcv/blob/master/CONTRIBUTING.md)来了解参与项目贡献的相关指引。 ## 引用 如果您发现此项目对您的研究有用,请考虑引用: ```BibTeX @misc{2021mmgeneration, title={{MMGeneration}: OpenMMLab Generative Model Toolbox and Benchmark}, author={MMGeneration Contributors}, howpublished = {\url{https://github.com/open-mmlab/mmgeneration}}, year={2020} } ``` ## 开源许可证 该项目采用 [Apache 2.0 license](LICENSE) 开源许可证。`MMGeneration` 中的一些操作使用了其他许可证。如果您使用我们的代码进行商业事务,请参考 [许可证](LICENSES.md) 并仔细检查。 ## OpenMMLab 的其他项目 - [MMCV](https://github.com/open-mmlab/mmcv): OpenMMLab 计算机视觉基础库 - [MIM](https://github.com/open-mmlab/mim): MIM 是 OpenMMlab 项目、算法、模型的统一入口 - [MMClassification](https://github.com/open-mmlab/mmclassification): OpenMMLab 图像分类工具箱 - [MMDetection](https://github.com/open-mmlab/mmdetection): OpenMMLab 目标检测工具箱 - [MMDetection3D](https://github.com/open-mmlab/mmdetection3d): OpenMMLab 新一代通用 3D 目标检测平台 - [MMRotate](https://github.com/open-mmlab/mmrotate): OpenMMLab 旋转框检测工具箱与测试基准 - [MMSegmentation](https://github.com/open-mmlab/mmsegmentation): OpenMMLab 语义分割工具箱 - [MMOCR](https://github.com/open-mmlab/mmocr): OpenMMLab 全流程文字检测识别理解工具箱 - [MMPose](https://github.com/open-mmlab/mmpose): OpenMMLab 姿态估计工具箱 - [MMHuman3D](https://github.com/open-mmlab/mmhuman3d): OpenMMLab 人体参数化模型工具箱与测试基准 - [MMSelfSup](https://github.com/open-mmlab/mmselfsup): OpenMMLab 自监督学习工具箱与测试基准 - [MMRazor](https://github.com/open-mmlab/mmrazor): OpenMMLab 模型压缩工具箱与测试基准 - [MMFewShot](https://github.com/open-mmlab/mmfewshot): OpenMMLab 少样本学习工具箱与测试基准 - [MMAction2](https://github.com/open-mmlab/mmaction2): OpenMMLab 新一代视频理解工具箱 - [MMTracking](https://github.com/open-mmlab/mmtracking): OpenMMLab 一体化视频目标感知平台 - [MMFlow](https://github.com/open-mmlab/mmflow): OpenMMLab 光流估计工具箱与测试基准 - [MMEditing](https://github.com/open-mmlab/mmediting): OpenMMLab 图像视频编辑工具箱 - [MMGeneration](https://github.com/open-mmlab/mmgeneration): OpenMMLab 图片视频生成模型工具箱 - [MMDeploy](https://github.com/open-mmlab/mmdeploy): OpenMMLab 模型部署框架 ## 欢迎加入 OpenMMLab 社区 扫描下方的二维码可关注 OpenMMLab 团队的 [知乎官方账号](https://www.zhihu.com/people/openmmlab),加入 OpenMMLab 团队的 [官方交流 QQ 群](https://jq.qq.com/?_wv=1027&k=K0QI8ByU)
我们会在 OpenMMLab 社区为大家 - 📢 分享 AI 框架的前沿核心技术 - 💻 解读 PyTorch 常用模块源码 - 📰 发布 OpenMMLab 的相关新闻 - 🚀 介绍 OpenMMLab 开发的前沿算法 - 🏃 获取更高效的问题答疑和意见反馈 - 🔥 提供与各行各业开发者充分交流的平台 干货满满 📘,等你来撩 💗,OpenMMLab 社区期待您的加入 👬