Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/okotaku/vaeengine

VAE training with mmengine
https://github.com/okotaku/vaeengine

Last synced: 20 days ago
JSON representation

VAE training with mmengine

Awesome Lists containing this project

README

        

# VAEEngine

[![build](https://github.com/okotaku/vaeengine/actions/workflows/build.yml/badge.svg)](https://github.com/okotaku/vaeengine/actions/workflows/build.yml)
[![Docs](https://img.shields.io/badge/docs-latest-blue)](https://vaeengine.readthedocs.io/en/latest/)
[![license](https://img.shields.io/github/license/okotaku/vaeengine.svg)](https://github.com/okotaku/vaeengine/blob/main/LICENSE)
[![open issues](https://isitmaintained.com/badge/open/okotaku/vaeengine.svg)](https://github.com/okotaku/vaeengine/issues)
[![Linting: Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/charliermarsh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)
[![Checked with mypy](https://www.mypy-lang.org/static/mypy_badge.svg)](https://mypy-lang.org/)

[📘 Documentation](https://vaeengine0.readthedocs.io/en/latest/) |
[🤔 Reporting Issues](https://github.com/okotaku/vaeengine/issues/new/choose)

## 📄 Table of Contents

- [VAEEngine](#vaeengine)
- [📄 Table of Contents](#-table-of-contents)
- [📖 Introduction 🔝](#-introduction-)
- [🛠️ Installation 🔝](#️-installation-)
- [🐳 Docker](#-docker)
- [📦 Devcontainer](#-devcontainer)
- [👨‍🏫 Get Started 🔝](#-get-started-)
- [📘 Documentation 🔝](#-documentation-)
- [📊 Model Zoo 🔝](#-model-zoo-)
- [🙌 Contributing 🔝](#-contributing-)
- [🎫 License 🔝](#-license-)
- [🖊️ Citation 🔝](#️-citation-)
- [🤝 Acknowledgement 🔝](#-acknowledgement-)

## 📖 Introduction [🔝](#-table-of-contents)

VAEEngine is an open-source toolbox designed for training state-of-the-art Diffusion Models. Packed with advanced features including diffusers and MMEngine, VAEEngine empowers both seasoned experts and newcomers in the field to efficiently create and enhance diffusion models. Stay at the forefront of innovation with our cutting-edge platform, accelerating your journey in Diffusion Models training.

1. **Training state-of-the-art Diffusion Models**: Empower your projects with state-of-the-art Diffusion Models. Explore options like Stable Diffusion, DreamBooth, and LoRA.
2. **Unified Config System and Module Designs**: Thanks to MMEngine, our platform boasts a unified configuration system and modular designs. Easily customize hyperparameters, loss functions, and other crucial settings while maintaining a structured and organized project environment.
3. **Inference with diffusers.pipeline**: Seamlessly transition from training to real-world application. Effortlessly deploy your trained Diffusion Models for inference tasks. Enhance your productivity and project timeline.
4. **Optimized training speed**: Our platform is designed to accelerate training speed. We utilize the Apex, Nvidia NGC Container, `torch.compile`. You can achieve high-quality results in less time, accelerating your project timeline and enhancing your productivity.

## 🛠️ Installation [🔝](#-table-of-contents)

#### 🐳 Docker

Below are the quick steps for installing and running dreambooth training using Docker:

```bash
git clone https://github.com/okotaku/vaeengine
cd vaeengine
docker compose up -d
docker compose exec vaeengine vaeengine train autoencoderkl_sdv15_pokemon
```

#### 📦 Devcontainer

You can also utilize the devcontainer to develop the VAEEngine. The devcontainer is a pre-configured development environment that runs in a Docker container. It includes all the necessary tools and dependencies for developing, building, and testing the VAEEngine.

1. Clone repository:

```
git clone https://github.com/okotaku/vaeengine
```

2. Open the cloned repository in Visual Studio Code.

3. Click on the "Reopen in Container" button located in the bottom right corner of the window. This action will open the repository within a devcontainer.

4. Run the following command to start training with the selected config:

```bash
vaeengine train autoencoderkl_sdv15_pokemon
```

## 👨‍🏫 Get Started [🔝](#-table-of-contents)

vaeengine makes training easy through its pre-defined configs. These configs provide a streamlined way to start your training process. Here's how you can get started using one of the pre-defined configs:

1. **Choose a config**: You can find sample pre-defined configs in the [`configs`](vaeengine/configs/) directory of the vaeengine repository. For example, if you wish to train a AutoencoderKL model, you can use the [`configs/autoencoderkl/autoencoderkl_sdv15_pokemon.py`](vaeengine/configs/autoencoderkl/autoencoderkl_sdv15_pokemon.py).

2. **Start Training**: Open a terminal and run the following command to start training with the selected config:

```bash
vaeengine train autoencoderkl_sdv15_pokemon
```

3. **Monitor Progress and get results**: The training process will begin, and you can track its progress. The outputs of the training will be located in the `work_dirs/autoencoderkl_sdv15_pokemon` directory, specifically when using the `autoencoderkl_sdv15_pokemon` config.

```
work_dirs/autoencoderkl_sdv15_pokemon
├── 20230802_033741
| ├── 20230802_033741.log # log file
| └── vis_data
| ├── 20230802_033741.json # log json file
| ├── config.py # config file for each experiment
| └── vis_image # visualized image from each step
├── step627/vae # last step VAE model with diffusers format
| ├── config.json # conrfig file
| └── diffusion_pytorch_model.bin # weight for inferencing with diffusers.pipeline
├── epoch_1.pth # checkpoint from each step
├── last_checkpoint # last checkpoint, it can be used for resuming
├── scores.json # latest score
└── autoencoderkl_sdv15_pokemon.py # latest config file
```

4. **Inference with diffusers.pipeline**: Once you have trained a model, simply specify the path to the saved model and inference by the `diffusers.pipeline` module.

```py
from pathlib import Path

import torch
from diffusers import DiffusionPipeline, AutoencoderKL

checkpoint = Path('work_dirs/autoencoderkl_sdv15_pokemon/step627')
prompt = 'A yoda pokemon'

vae = AutoencoderKL.from_pretrained(
checkpoint, subfolder="vae", torch_dtype=torch.float16)
pipe = DiffusionPipeline.from_pretrained(
'runwayml/stable-diffusion-v1-5', torch_dtype=torch.float16)
pipe.to('cuda')

image = pipe(
prompt,
num_inference_steps=50
).images[0]
image.save('demo.png')
```

## 📘 Documentation [🔝](#-table-of-contents)

For detailed user guides and advanced guides, please refer to our [Documentation](https://vaeengine.readthedocs.io/en/latest/):

- [Get Started](https://vaeengine.readthedocs.io/en/latest/get_started.html) for get started.

User Guides

- [Learn About Config](https://vaeengine.readthedocs.io/en/latest/user_guides/config.html)
- [Prepare Dataset](https://vaeengine.readthedocs.io/en/latest/user_guides/dataset_prepare.html)

## 📊 Model Zoo [🔝](#-table-of-contents)


Supported algorithms




AutoencoderKL







## 🙌 Contributing [🔝](#-table-of-contents)

We appreciate all contributions to improve clshub. Please refer to [CONTRIBUTING.md](https://github.com/open-mmlab/mmpretrain/blob/main/CONTRIBUTING.md) for the contributing guideline.

## 🎫 License [🔝](#-table-of-contents)

This project is released under the [Apache 2.0 license](LICENSE).

## 🖊️ Citation [🔝](#-table-of-contents)

If VAEEngine is helpful to your research, please cite it as below.

```
@misc{vaeengine2024,
title = {{vaeengine}: diffusers training toolbox with mmengine},
author = {{vaeengine Contributors}},
howpublished = {\url{https://github.com/okotaku/vaeengine}},
year = {2024}
}
```

## 🤝 Acknowledgement [🔝](#-table-of-contents)

This repo borrows the architecture design and part of the code from [mmengine](https://github.com/open-mmlab/mmengine) and [diffusers](https://github.com/huggingface/diffusers).

Also, please check the following openmmlab and huggingface projects and the corresponding Documentation.

- [OpenMMLab](https://openmmlab.com/)
- [HuggingFace](https://huggingface.co/)

```
@article{mmengine2022,
title = {{MMEngine}: OpenMMLab Foundational Library for Training Deep Learning Models},
author = {MMEngine Contributors},
howpublished = {\url{https://github.com/open-mmlab/mmengine}},
year={2022}
}
```

```
@misc{von-platen-etal-2022-diffusers,
author = {Patrick von Platen and Suraj Patil and Anton Lozhkov and Pedro Cuenca and Nathan Lambert and Kashif Rasul and Mishig Davaadorj and Thomas Wolf},
title = {Diffusers: State-of-the-art diffusion models},
year = {2022},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/huggingface/diffusers}}
}
```