Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/divamgupta/stable-diffusion-tensorflow
Stable Diffusion in TensorFlow / Keras
https://github.com/divamgupta/stable-diffusion-tensorflow
Last synced: about 2 months ago
JSON representation
Stable Diffusion in TensorFlow / Keras
- Host: GitHub
- URL: https://github.com/divamgupta/stable-diffusion-tensorflow
- Owner: divamgupta
- License: other
- Created: 2022-09-15T04:46:25.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-08-08T13:25:03.000Z (over 1 year ago)
- Last Synced: 2024-08-09T13:18:58.828Z (6 months ago)
- Language: Python
- Homepage:
- Size: 2.03 MB
- Stars: 1,576
- Watchers: 25
- Forks: 227
- Open Issues: 33
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- StarryDivineSky - divamgupta/stable-diffusion-tensorflow
README
# Stable Diffusion in TensorFlow / Keras
A Keras / Tensorflow implementation of Stable Diffusion.
The weights were ported from the original implementation.
## Colab Notebooks
The easiest way to try it out is to use one of the Colab notebooks:
- [GPU Colab](https://colab.research.google.com/drive/1zVTa4mLeM_w44WaFwl7utTaa6JcaH1zK)
- [GPU Colab Img2Img](https://colab.research.google.com/drive/1gol0M611zXP6Zpggfri-fG8JDdpMEpsI?usp=sharing)
- [GPU Colab Inpainting](https://colab.research.google.com/drive/1Bf-bNmAdtQhPcYNyC-guu0uTu9MYYfLu)
- [GPU Colab - Tile / Texture generation](https://colab.research.google.com/drive/1xCxsNvQMEywzlqbjH4tGfEyXamSAeFbn?usp=sharing)
- [GPU Colab - Loading Pytorch ckpt Weights](https://colab.research.google.com/drive/1wUdqxji-jxkThYf0OVW3F-0VVpTFdjMa?usp=sharing)
- [GPU Colab + Mixed Precision](https://colab.research.google.com/drive/15mQgITh3e9HQMNys0zR8JN4R2vp06d-N)
- ~10s generation time per image (512x512) on default Colab GPU without drop in quality
([source](https://twitter.com/fchollet/status/1571954014845308928))
- [TPU Colab](https://colab.research.google.com/drive/17zQOm_2Iu6pcP8otT-v6rx0D-pKgfaLm).
- Slower than GPU for single-image generation, faster for large batch of 8+ images
([source](https://twitter.com/fchollet/status/1572004717362028546)).
- [GPU Colab with Gradio](https://colab.research.google.com/drive/1ANTUur1MF9DKNd5-BTWhbWa7xUBfCWyI)
- [GPU Colab - Video Generation](https://colab.research.google.com/drive/1aUkXK4zE61iswyYBpUosz730bniNKqk_)## Installation
### Install as a python package
Install using pip with the git repo:
```bash
pip install git+https://github.com/divamgupta/stable-diffusion-tensorflow
```### Installing using the repo
Download the repo, either by downloading the
[zip](https://github.com/divamgupta/stable-diffusion-tensorflow/archive/refs/heads/master.zip)
file or by cloning the repo with git:```bash
git clone [email protected]:divamgupta/stable-diffusion-tensorflow.git
```#### Using pip without a virtual environment
Install dependencies using the `requirements.txt` file or the `requirements_m1.txt` file,:
```bash
pip install -r requirements.txt
```#### Using a virtual environment with *virtualenv*
1) Create your virtual environment for `python3`:
```bash
python3 -m venv venv
```
2) Activate your virtualenv:```bash
source venv/bin/activate
```3) Install dependencies using the `requirements.txt` file or the `requirements_m1.txt` file,:
```bash
pip install -r requirements.txt
```## Usage
### Using the Python interface
If you installed the package, you can use it as follows:
```python
from stable_diffusion_tf.stable_diffusion import StableDiffusion
from PIL import Imagegenerator = StableDiffusion(
img_height=512,
img_width=512,
jit_compile=False,
)
img = generator.generate(
"An astronaut riding a horse",
num_steps=50,
unconditional_guidance_scale=7.5,
temperature=1,
batch_size=1,
)# for image to image :
img = generator.generate(
"A Halloween bedroom",
num_steps=50,
unconditional_guidance_scale=7.5,
temperature=1,
batch_size=1,
input_image="/path/to/img.png"
)Image.fromarray(img[0]).save("output.png")
```### Using `text2image.py` from the git repo
Assuming you have installed the required packages,
you can generate images from a text prompt using:```bash
python text2image.py --prompt="An astronaut riding a horse"
```The generated image will be named `output.png` on the root of the repo.
If you want to use a different name, use the `--output` flag.```bash
python text2image.py --prompt="An astronaut riding a horse" --output="my_image.png"
```Check out the `text2image.py` file for more options, including image size, number of steps, etc.
### Using `img2img.py` from the git repoAssuming you have installed the required packages,
you can modify images from a text prompt using:```bash
python img2img.py --prompt="a high quality sketch of people standing with sun and grass , watercolor , pencil color" --input="img.jpeg"
```The generated image will be named `img2img-out.jpeg` by default on the root of the repo.
If you want to use a different name, use the `--output` flag.Check out the `img2img.py` file for more options, including the number of steps.
## Example outputs
The following outputs have been generated using this implementation:
1) *A epic and beautiful rococo werewolf drinking coffee, in a burning coffee shop. ultra-detailed. anime, pixiv, uhd 8k cryengine, octane render*
![a](https://user-images.githubusercontent.com/1890549/190841598-3d0b9bd1-d679-4c8d-bd5e-b1e24397b5c8.png)
2) *Spider-Gwen Gwen-Stacy Skyscraper Pink White Pink-White Spiderman Photo-realistic 4K*
![a](https://user-images.githubusercontent.com/1890549/190841999-689c9c38-ece4-46a0-ad85-f459ec64c5b8.png)
3) *A vision of paradise, Unreal Engine*
![a](https://user-images.githubusercontent.com/1890549/190841886-239406ea-72cb-4570-8f4c-fcd074a7ad7f.png)
### Inpainting
![a](https://user-images.githubusercontent.com/44222184/194685370-e87970f7-dbf5-4d6d-a9d1-31594cdf751a.png)
### Image2Image
1) *a high quality sketch of people standing with sun and grass , watercolor , pencil color*
### Keras Stable Diffusion Video Generation
1) *A beautiful street view of prague, artstation concept art, extremely detailed oil painting, vivid colors*
https://user-images.githubusercontent.com/63783894/201447745-6a3a96f4-f065-4e54-be5d-01941475a31c.mp4
## References
1) https://github.com/CompVis/stable-diffusion
2) https://github.com/geohot/tinygrad/blob/master/examples/stable_diffusion.py