Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Junyi42/DiffStyle
DiffStyle: Leverage Diffusion Prior to One-for-All Style Transfer. Course project of CS3310 Computer Graphics, built on Prompt-to-Prompt and Null-Text.
https://github.com/Junyi42/DiffStyle
diffusion-models stable-diffusion style-transfer
Last synced: 2 months ago
JSON representation
DiffStyle: Leverage Diffusion Prior to One-for-All Style Transfer. Course project of CS3310 Computer Graphics, built on Prompt-to-Prompt and Null-Text.
- Host: GitHub
- URL: https://github.com/Junyi42/DiffStyle
- Owner: Junyi42
- Created: 2022-12-02T07:57:46.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-04-01T16:02:31.000Z (almost 2 years ago)
- Last Synced: 2024-06-11T07:32:35.649Z (7 months ago)
- Topics: diffusion-models, stable-diffusion, style-transfer
- Language: Python
- Homepage:
- Size: 80.3 MB
- Stars: 69
- Watchers: 2
- Forks: 5
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-cs - @Junyi42, 2022 Fall
README
# DiffStyle: Leverage Diffusion Prior to One-for-All Style Transfer
> *Stable Diffusion* Implementation, our method is built on Prompt-to-Prompt and Null-Text
![teaser](docs/teaser.png)
### [Project Page](https://prompt-to-prompt.github.io) [Paper](https://prompt-to-prompt.github.io/ptp_files/Prompt-to-Prompt_preprint.pdf)## Setup
This code was tested with Python 3.8, [Pytorch](https://pytorch.org/) 1.11 using pre-trained models through [huggingface / diffusers](https://github.com/huggingface/diffusers#readme).
Specifically, we implemented our method over [Latent Diffusion](https://huggingface.co/CompVis/ldm-text2im-large-256) and [Stable Diffusion](https://huggingface.co/CompVis/stable-diffusion-v1-4).
Additional required packages are listed in the requirements file.
The code was tested on a RTX3090 24GB but should work on other cards with at least **23GB** VRAM.You can set up the conda environment (with python3.8+CUDA11.1) using the command below:
```
pip install -r requirements.txt
```## QuickStart
To quickly generate results with **different styles and different extents**, you can use the following command:
```
bash bash/exp_styles.sh
```
To quickly generate results with **editable style transfer**, you can use the following command:```
bash bash/exp_modify.sh
```Alternatively, you can use the following command to generate results with specific parameters:
```
python cartoon_styles.py --description "A handsome man in short hair" --path example_images/portrait5.jpg --blend man --self_ratio 0.4
```
The `--description` parameter allows you to provide a description of the image. The `--path` parameter allows you to specify the path of the image. The `--blend` parameter allows you to specify the part of the image that you want to modify. The `--self_ratio` parameter allows you to control the strength of the style, with a range of $0.2$ to $0.8$, where a smaller value results in a stronger style.## Result
The generated images from the scripts above will be stored in the `\tmp` folder. We also provide some pre-generated results in the `\example_results` folder.
### One Model for All Styles
In these images, we show the results of generating multiple styles using a single model. These styles include different cartoon and art styles. By using a single model, we are able to generate multiple different styles in one run without the need to re-train the model or change parameters.![1](docs/result1.png)
![2](docs/result2.png)
### Not Only Faces
This image shows that our model is not only able to perform style transfer on faces, but also on other types of images. In this image, we used a landscape image and transformed it into different style. This demonstrates the wide applicability of our model, which can be used for a variety of different types of images.![3](docs/result_not_face.png)
### Editable Style Transfer
This image shows that our style transfer model is editable. We can select any portion of the transformed image and adjust its style. In this image, we selected a portion of the face and applied a personal modification over it.![4](docs/result_editable.png)
### Different Extent
In this image, we show that the strength of the generated style can be controlled. We demonstrate this by generating multiple images with the same source image and style, but with different levels of style intensity. The lefter image has a weaker style, while the righter image has a stronger style. This shows that our model is able to generate a range of different styles with varying levels of intensity.![5](docs/result_extent.png)