discoart


Namediscoart JSON
Version 0.12.1 PyPI version JSON
download
home_pagehttps://github.com/jina-ai/discoart
SummaryCreate Disco Diffusion artworks in one line
upload_time2023-04-20 08:17:29
maintainer
docs_urlNone
authorJina AI
requires_python
licenseMIT
keywords discoart diffusion art dalle disco-diffusion generative-art creative-ai cross-modal multi-modal artwork
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ![](.github/banner.png)

<p align="center">
<b>Create compelling Disco Diffusion artworks in one line</b>
</p>

<p align=center>
<a href="https://pypi.org/project/discoart/"><img src="https://img.shields.io/pypi/v/discoart?style=flat-square&amp;label=Release" alt="PyPI"></a>
<a href="https://hub.docker.com/repository/docker/jinaai/discoart"><img alt="Docker Cloud Build Status" src="https://img.shields.io/docker/cloud/build/jinaai/discoart?logo=docker&logoColor=white&style=flat-square"></a>
<a href="https://slack.jina.ai"><img src="https://img.shields.io/badge/Slack-3.1k-blueviolet?logo=slack&amp;logoColor=white&style=flat-square"></a>
<a href="https://colab.research.google.com/github/jina-ai/discoart/blob/main/discoart.ipynb"><img src="https://img.shields.io/badge/Open-in%20Colab-brightgreen?logo=google-colab&style=flat-square" alt="Open in Google Colab"/></a>
</p>

DiscoArt is an elegant way of creating compelling Disco Diffusion<sup><a href="#example-application">[*]</a></sup> artworks for generative artists, AI enthusiasts and hard-core developers. DiscoArt has a modern & professional API with a beautiful codebase, ensuring high usability and maintainability. It introduces handy features such as result recovery and persistence, gRPC/HTTP serving w/o TLS, post-analysis, easing the integration to larger cross-modal or multi-modal applications.

<sub><sup><a id="example-application">[*]</a> 
Disco Diffusion is a Google Colab Notebook that leverages CLIP-Guided Diffusion to allow one to create compelling and beautiful images from text prompts.
</sup></sub>


💯 **Best-in-class**: industry-level engineering, top-notch code quality, lean dependencies, small RAM/VRAM footprint; important bug fixes, feature improvements [vs. the original DD5.6](FEATURES.md). 

👼 **Available to all**: smooth install for *self-hosting*, Google Colab *free tier*, non-GUI (IPython) environment, and CLI! No brainfuck, no dependency hell, no stackoverflow. 

🎨 **Focus on create not code**: one-liner `create()` with a Pythonic interface, autocompletion in IDE, and powerful features. Fetch real-time results anywhere anytime, no more worry on session outrage on Google Colab. Set initial state easily for more efficient parameter exploration.

🏭 **Ready for integration & production**: built on top of [DocArray](https://github.com/jina-ai/docarray) data structure, enjoy smooth integration with [Jina](https://github.com/jina-ai/jina), [CLIP-as-service](https://github.com/jina-ai/clip-as-service) and other cross-/multi-modal applications.

☁️ [**As-a-service**](#serving): simply `python -m discoart serve`, DiscoArt is now a high-performance low-latency service supports gRPC/HTTP/websockets and TLS. Scaling up/down is one-line; Cloud-native features e.g. Kubernetes, Prometheus and Grafana is one-line. [Unbelievable simple thanks to Jina](https://github.com/jina-ai/jina).


## [Gallery with prompts](https://twitter.com/hxiao/status/1542967938369687552?s=20&t=DO27EKNMADzv4WjHLQiPFA) 

Do you see the `discoart-id` in each tweet? To get the config & prompts, simply:

```python
from discoart import show_config

show_config('discoart-id')
```

## Install

Python 3.7+ and CUDA-enabled PyTorch is required.

```bash
pip install discoart
```

This applies to both *self-hosting*, *Google Colab*, system integration, non-GUI environments.

- **Self-hosted Jupyter**: to run a Jupyter Notebook on your own GPU machine, the easiest way is to [use our prebuilt Docker image](#run-in-docker).
- **Use it from CLI**: [`python -m discoart create`](#cli) and `python -m discoart config` are CLI commands.
- **Use it as a service**: [`python -m discoart serve`](#serving) allows one to run it as gRPC/HTTP/websockets service.

### GUI

DiscoArt is the **infrastructure** for creating Disco Diffusion artworks. The built-in Jupyter Notebook support gives you basic yet limited user experience, e.g. it does not offer any intuitive GUI for [prompt scheduling](FEATURES.md#prompt-scheduling). Note that DiscoArt is developer-centric and API-first, hence improving consumer-facing experience is out of the scope. There are services, platforms and products (not Jina AI affiliated) that already integrate DiscoArt as a service and provide nice GUI on top of it, e.g. Fever Dreams, Replicate, RunPod and Renderflux.

<details>
  <summary>Click to see third-party GUI</summary>

- [Fever Dreams](https://www.feverdreams.app/): a free community-powered service with nice GUI and gallery, where people generate and share their DiscoArt artworks, prompts and configs.
- [Replicate](https://replicate.com/nightmareai/disco-diffusion): a free form-based GUI of DiscoArt with sandbox user experience and the visualizations.  
- [RunPod](https://www.runpod.io/blog/accelerate-your-generate-art-with-disco-diffusion-and-runpod): a paid GPU cloud provider that runs DiscoArt container with a simple and clean GUI to visualize the configs and creations.
- [Renderflux](https://beta.renderflux.com/register?invite=bughunting): a paid creative art platform that wraps DiscoArt and provides end-to-end GUI for creation management.

**Please be aware that these platforms, products or companies are not affiliated with Jina AI.** They define their own terms of services, paywall and data and privacy policies, which are not in the scope of DiscoArt MIT License.

</details>

## Get Started

<a href="https://colab.research.google.com/github/jina-ai/discoart/blob/main/discoart.ipynb"><img src="https://img.shields.io/badge/Open-in%20Colab-brightgreen?logo=google-colab&style=flat-square" alt="Open in Google Colab"/></a>

### Create artworks

```python
from discoart import create

da = create()
```

That's it! It will create with the [default text prompts and parameters](./discoart/resources/default.yml).

![](.github/create-demo.gif)

### Set prompts and parameters

Supported parameters are [listed here](./discoart/resources/default.yml). You can specify them in `create()`:

```python
from discoart import create

da = create(
    text_prompts='A painting of sea cliffs in a tumultuous storm, Trending on ArtStation.',
    init_image='https://d2vyhzeko0lke5.cloudfront.net/2f4f6dfa5a05e078469ebe57e77b72f0.png',
    skip_steps=100,
)
```

![](.github/parameter-demo.gif)

In case you forgot a parameter, just lookup the cheatsheet at anytime:

```python
from discoart import cheatsheet

cheatsheet()
```

The difference on the parameters between DiscoArt and DD5.6 [is explained here](./FEATURES.md). 


### Visualize results

Final results and intermediate results are created under the current working directory, i.e.
```text
./{name-docarray}/{i}-done.png
./{name-docarray}/{i}-step-{j}.png
./{name-docarray}/{i}-progress.png
./{name-docarray}/{i}-progress.gif
./{name-docarray}/da.protobuf.lz4
```

![](.github/result-persist.png)

where:

- `name-docarray` is the name of the run, you can specify it otherwise it is a random name.
- `i-*` is up to the value of `n_batches`.
- `*-done-*` is the final image on done.
- `*-step-*` is the intermediate image at certain step, updated in real-time.
- `*-progress.png` is the sprite image of all intermediate results so far, updated in real-time.
- `*-progress.gif` is the animated gif of all intermediate results so far, updated in real-time.
- `da.protobuf.lz4` is the compressed protobuf of all intermediate results so far, updated in real-time.

The save frequency is controlled by `save_rate`.

Moreover, `create()` returns `da`, a [DocumentArray](https://docarray.jina.ai/fundamentals/documentarray/)-type object. It contains the following information:
- All arguments passed to `create()` function, including seed, text prompts and model parameters.
- 4 generated image and its intermediate steps' images, where `4` is determined by `n_batches` and is the default value. 

This allows you to further post-process, analyze, export the results with powerful DocArray API.

Images are stored as Data URI in `.uri`, to save the first image as a local file:

```python
da[0].save_uri_to_file('discoart-result.png')
```

To save all final images:

```python
for idx, d in enumerate(da):
    d.save_uri_to_file(f'discoart-result-{idx}.png')
```

You can also display all four final images in a grid:

```python
da.plot_image_sprites(skip_empty=True, show_index=True, keep_aspect_ratio=True)
```
![](.github/all-results.png)

Or display them one by one:

```python
for d in da:
    d.display()
```

Or take one particular run:

```python
da[0].display()
```

![](.github/display.png)

### Visualize intermediate steps

You can also zoom into a run (say the first run) and check out intermediate steps:

```python
da[0].chunks.plot_image_sprites(
    skip_empty=True, show_index=True, keep_aspect_ratio=True
)
```
![](.github/chunks.png)

You can `.display()` the chunks one by one, or save one via `.save_uri_to_file()`, or save all intermediate steps as a GIF:

```python
da[0].chunks.save_gif(
    'lighthouse.gif', show_index=True, inline_display=True, size_ratio=0.5
)
```

![](.github/lighthouse.gif)

Note that >=0.7.14, a 20FPS gif is generated which includes all intermedidate steps. 

### Show/save/load configs

To show the config of a Document/DocumentArray,

```python
from discoart import show_config

show_config(da)  # show the config of the first run
show_config(da[3])  # show the config of the fourth run
show_config(
    'discoart-06030a0198843332edc554ffebfbf288'
)  # show the config of the run with a known DocArray ID
```

To save the config of a Document/DocumentArray,

```python
from discoart import save_config

save_config(da, 'my.yml')  # save the config of the first run
save_config(da[3], 'my.yml')  # save the config of the fourth run
```

To run `create` from a YAML config of Document/DocumentArray,

```python
from discoart import create, load_config

config = load_config('my.yml')
create(**config)
```

You can also export the config as an SVG image:

```python
from discoart.config import save_config_svg

save_config_svg(da)
```

![](.github/discoart-3205998582.svg)

One can also generate runnable Python code directly from the config:

```python
from discoart.config import export_python

export_python(da)
```

### Pull results anywhere anytime

If you are a free-tier Google Colab user, one annoy thing is the lost of sessions from time to time. Or sometimes you just early stop the run as the first image is not good enough, and a keyboard interrupt will prevent `.create()` to return any result. Either case, you can easily recover the results by pulling the last session ID.

1. Find the session ID. It appears on top of the image. 
![](.github/session-id.png)

2. Pull the result via that ID **on any machine at any time**, not necessarily on Google Colab:
    ```python
    from docarray import DocumentArray
    
    da = DocumentArray.pull('discoart-3205998582')
    ```

### Reuse a Document as initial state

Consider a Document as a self-contained data with config and image, one can use it as the initial state for the future run. Its `.tags` will be used as the initial parameters; `.uri` if presented will be used as the initial image.

```python
from discoart import create
from docarray import DocumentArray

da = DocumentArray.pull('discoart-3205998582')

create(
    init_document=da[0],
    cut_ic_pow=0.5,
    tv_scale=600,
    cut_overview='[12]*1000',
    cut_innercut='[12]*1000',
    use_secondary_model=False,
)
```

If you just want to initialize from a known DocArray ID, then simply:

```python
from discoart import create

create(init_document='discoart-3205998582')
```


### Environment variables

You can set environment variables to control the meta-behavior of DiscoArt. The environment variables must be set before importing DiscoArt, either in Bash or in Python via `os.environ`.

```bash
DISCOART_LOG_LEVEL='DEBUG' # more verbose logs
DISCOART_OPTOUT_CLOUD_BACKUP='1' # opt-out from cloud backup
DISCOART_DISABLE_IPYTHON='1' # disable ipython dependency
DISCOART_DISABLE_RESULT_SUMMARY='1' # disable result summary after the run ends
DISCOART_DEFAULT_PARAMETERS_YAML='path/to/your-default.yml' # use a custom default parameters file
DISCOART_CUT_SCHEDULES_YAML='path/to/your-schedules.yml' # use a custom cut schedules file
DISCOART_MODELS_YAML='path/to/your-models.yml' # use a custom list of models file
DISCOART_OUTPUT_DIR='path/to/your-output-dir' # use a custom output directory for all images and results
DISCOART_CACHE_DIR='path/to/your-cache-dir' # use a custom cache directory for models and downloads
DISCOART_DISABLE_REMOTE_MODELS='1' # disable the listing of diffusion models on Github, remote diffusion models allows user to use latest models without updating the codebase.
DISCOART_REMOTE_MODELS_URL='https://yourdomain/models.yml' # use a custom remote URL for fetching models list
DISCOART_DISABLE_CHECK_MODEL_SHA='1' # disable checking local model SHA matches the remote model SHA
DISCOART_DISABLE_TQDM='1' # disable tqdm progress bar on diffusion
```

## CLI

DiscoArt provides two commands `create` and `config` that allows you to run DiscoArt from CLI.

```bash
python -m discoart create my.yml
```

which creates artworks from the YAML config file `my.yml`. You can also do:

```bash
cat config.yml | python -m discoart create
```

So how can I have my own `my.yml` and what does it look like? That's the second command:

```bash
python -m discoart config my.yml
```

which forks the [default YAML config](discoart/resources/default.yml) and export them to `my.yml`. Now you can modify it and run it with `python -m discoart create` command.

If no output path is specified, then `python -m discoart config` will print the default config to stdout.

To get help on a command, add `--help` at the end, e.g.:

```bash
python -m discoart create --help
```

```text
usage: python -m discoart create [-h] [YAML_CONFIG_FILE]

positional arguments:
  YAML_CONFIG_FILE  The YAML config file to use, default is stdin.

optional arguments:
  -h, --help        show this help message and exit
```

## Serving

Serving DiscoArt is super easy. Simply run the following command:

```bash
python -m discoart serve
```

You shall see:

![](.github/serving.png)

Now send request to the server via curl/Javascript, e.g.

```bash
curl \
-X POST http://0.0.0.0:51001/post \
-H 'Content-Type: application/json' \
-d '{"execEndpoint":"/create", "parameters": {"text_prompts": ["A beautiful painting of a singular lighthouse", "yellow color scheme"]}}'
```

That's it. 

You can of course pass all parameters that accepted by `create()` function in the JSON.

### Polling intermediate results

We already know that `create` function is slow even on GPU it could take 10 minutes to finish an artwork. This means the after sending the above request, the client will have to wait 10 minutes for the response. There is nothing wrong with this behavior given that everything runs synchronously. However, in practice, client may expect a progress or intermediate results in the middle instead of waiting for the end.

`/result` endpoint is designed for this purpose. It will return the intermediate results as soon as they are available. All you need is to specify `name_docarray` in the request parameters as you specified in `/create` endpoint. Here is an example:

Let's create `mydisco-123` by sending the following request to `/create` endpoint:

```bash
curl \
-X POST http://0.0.0.0:51001/post \
-H 'Content-Type: application/json' \
-d '{"execEndpoint":"/create", "parameters": {"name_docarray": "mydisco-123", "text_prompts": ["A beautiful painting of a singular lighthouse", "yellow color scheme"]}}'
```

Now that the above request is being processed on the server, you can periodically check `mydisco-123` progress by sending the following request to `/result` endpoint:

```bash
curl \
-X POST http://0.0.0.0:51001/post \
-H 'Content-Type: application/json' \
-d '{"execEndpoint":"/result", "parameters": {"name_docarray": "mydisco-123"}}'
```

A JSON will be returned with up-to-date progress, with image as DataURI, loss, steps etc. [The JSON Schema of Document/DocumentArray is described here.](https://docarray.jina.ai/fundamentals/fastapi-support/#json-schema)

Note, `/result` won't be blocked by `/create` thanks to the smart routing of Jina Gateway. To learn/play more about those endpoints, you can check ReDoc or the Swagger UI embedded in the server.

### Skip & Cancel

Send to `/skip`, to skip the current run and move to the next run as defined in `n_batches`:

```bash
curl \
-X POST http://0.0.0.0:51001/post \
-H 'Content-Type: application/json' \
-d '{"execEndpoint":"/skip"}'
```

Send to `/stop`, to stop the current run cancel all runs `n_batches`:

```bash
curl \
-X POST http://0.0.0.0:51001/post \
-H 'Content-Type: application/json' \
-d '{"execEndpoint":"/stop"}'
```

### Unblocking `/create` request

It is possible to have an unblocked `/create` endpoint: the client request to `/create` will be **immediately** returned, without waiting for the results to be finished. You now have to fully rely on `/result` to poll the result. 

To enable this feature: 

1. Copy-paste the [default `flow.yml` file](./discoart/resources/flow.yml) to `myflow.yml`;
2. Change `floating: false` to `floating: true` under `discoart` executor section;
3. Run the following command:
    ```bash
    python -m discoart serve myflow.yml
    ```

Beware that the request velocity is now under **your control**. That is, if the client sends 10 `/create` requests in a second, then the server will start 10 `create()` in parallel! This can easily lead to OOM. Hence, the suggestion is only enabling this feature if you are sure that the client is not sending too many requests, e.g. you control the client request rate; or you are using DiscoArt behind a BFF (backend for frontend).

### Scaling out

If you have multiple GPUs and you want to run multiple DiscoArt instances in parallel by leveraging GPUs in a time-multiplexed fashion, you can copy-paste the [default `flow.yml` file](./discoart/resources/flow.yml) and modify it as follows:

```yaml
jtype: Flow
with:
  protocol: http
  monitoring: true
  port: 51001
  port_monitoring: 51002  # prometheus monitoring port
  env:
    JINA_LOG_LEVEL: debug
    DISCOART_DISABLE_IPYTHON: 1
    DISCOART_DISABLE_RESULT_SUMMARY: 1
executors:
  - name: discoart
    uses: DiscoArtExecutor
    env:
      CUDA_VISIBLE_DEVICES: RR0:3  # change this if you have multiple GPU
    replicas: 3  # change this if you have larger VRAM
  - name: poller
    uses: ResultPoller
```

Here `replicas: 3` says spawning three DiscoArt instances, `CUDA_VISIBLE_DEVICES: RR0:3` makes sure they use the first three GPUs in a round-robin fashion.

Name it as `myflow.yml` and then run 

```bash
python -m discoart serve myflow.yml
```

### Customization

[Thanks to Jina](https://github.com/jina-ai/jina), there are tons of things you can customize! You can change the port number; change protocol to gRPC/Websockets; add TLS encryption; enable/disable Prometheus monitoring; you can also export it to Kubernetes deployment bundle simply via:

```bash
jina export kubernetes myflow.yml
```

For more features and YAML configs, [please check out Jina docs](https://docs.jina.ai).


### Use gRPC gateway

To switch from HTTP to gRPC gateway is simple:

```yaml
jtype: Flow
with:
  protocol: grpc
...
```

and then restart the server.

There are multiple advantages of using gRPC gateway:
- Much faster and smaller network overhead.
- Feature-rich, like compression, status monitoring, etc.

In general, if you are using the DiscoArt server behind a BFF (backend for frontend), or your DiscoArt server does **not** directly serve HTTP traffic from end-users, then you should use gRPC protocol.

To communicate with a gRPC DiscoArt server, one can use a Jina Client:

```python
# !pip install jina
from jina import Client

c = Client(host='grpc://0.0.0.0:51001')

da = c.post(
    '/create',
    parameters={
        'name_docarray': 'mydisco-123',
        'text_prompts': [
            'A beautiful painting of a singular lighthouse',
            'yellow color scheme',
        ],
    },
)

# check intermediate results
da = c.post('/result', parameters={'name_docarray': 'mydisco-123'})
```

To use an existing Document/DocumentArray as init Document for `create`:

```python
from jina import Client

c = Client(host='grpc://0.0.0.0:51001')

old_da = create(...)

da = c.post(
    '/create',
    old_da,  # this can be a DocumentArray or a single Document
    parameters={
        'width_height': [1024, 768],
    },
)
```

This equals to run `create(init_document=old_da, width_height=[1024, 768])` on the server. Note:
- follow-up parameters have higher priorities than the parameters in `init_document`.
- if `init_document` is a DocumentArray, then the first Document in the array will be used as the init Document.
- there is no need to do any serialization before sending, Jina automatically handles it.

### Hosting on Google Colab

Though not recommended, it is also possible to use Google Colab to host DiscoArt server. 
Please check out the following tutorials:
- https://docs.jina.ai/how-to/google-colab/
- https://clip-as-service.jina.ai/hosting/colab/





## Run in Docker

[![Docker Image Size (tag)](https://img.shields.io/docker/image-size/jinaai/discoart/latest?logo=docker&logoColor=white&style=flat-square)](https://hub.docker.com/repository/docker/jinaai/discoart)

We provide a prebuilt Docker image for running DiscoArt out of the box. To update Docker image to latest version:

```bash
docker pull jinaai/discoart:latest
```

### Use Jupyter notebook

The default entrypoint is starting a Jupyter notebook

```bash
# docker build . -t jinaai/discoart  # if you want to build yourself
docker run -p 51000:8888 -v $(pwd):/home/jovyan/ -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart
```

Now you can visit `http://127.0.0.1:51000` to access the notebook

### Enable GPU in Docker on Windows

 You can use it on Windows Subsystem for Linux (WSL), Check the official guide [here](https://docs.microsoft.com/en-us/windows/ai/directml/gpu-cuda-in-wsl).

```bash
# Make sure you install Windows 11 or Windows 10, version 21H2
docker run -p 8888:8888 -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart
```

### Use as a service

```bash
# docker build . -t jinaai/discoart  # if you want to build yourself
docker run --entrypoint "python" -p 51001:51001 -v $(pwd):/home/jovyan/ -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart -m discoart serve
```

Your DiscoArt server is now running at `http://127.0.0.1:51001`.

### Release cycle

[Docker images are built on every release](https://hub.docker.com/repository/docker/jinaai/discoart), so one can lock it to a specific version, say `0.5.1`:

```bash
docker run -p 51000:8888 -v $(pwd):/home/jovyan/ -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart:0.5.1
```


## What's next?

[Next is create](https://colab.research.google.com/github/jina-ai/discoart/blob/main/discoart.ipynb).

😎 **If you are already a DD user**: you are ready to go! There is no extra learning, DiscoArt respects the same parameter semantics as DD5.6. So just unleash your creativity! [Read more about their differences here](./FEATURES.md).

You can always do `from discoart import cheatsheet; cheatsheet()` to check all new/modified parameters.

👶 **If you are a [DALL·E Flow](https://github.com/jina-ai/dalle-flow/) or new user**: you may want to take step by step, as Disco Diffusion works in a very different way than DALL·E. It is much more advanced and powerful: e.g. Disco Diffusion can take weighted & structured text prompts; it can initialize from a image with controlled noise; and there are way more parameters one can tweak. Impatient prompt like `"armchair avocado"` will give you nothing but confusion and frustration. I highly recommend you to check out the following resources before trying your own prompt:
- [Zippy's Disco Diffusion Cheatsheet v0.3](https://docs.google.com/document/d/1l8s7uS2dGqjztYSjPpzlmXLjl5PM3IGkRWI3IiCuK7g/mobilebasic)
- [EZ Charts - Diffusion Parameter Studies](https://docs.google.com/document/d/1ORymHm0Te18qKiHnhcdgGp-WSt8ZkLZvow3raiu2DVU/edit#)
- [Disco Diffusion 70+ Artist Studies](https://weirdwonderfulai.art/resources/disco-diffusion-70-plus-artist-studies/)
- [A Traveler’s Guide to the Latent Space](https://sweet-hall-e72.notion.site/A-Traveler-s-Guide-to-the-Latent-Space-85efba7e5e6a40e5bd3cae980f30235f#e122e748b86e4fc0ad6a7a50e46d6e10)
- [Disco Diffusion Illustrated Settings](https://coar.notion.site/Disco-Diffusion-Illustrated-Settings-cd4badf06e08440c99d8a93d4cd39f51)
- [Coar’s Disco Diffusion Guide](https://coar.notion.site/coar/Coar-s-Disco-Diffusion-Guide-3d86d652c15d4ca986325e808bde06aa#8a3c6e9e4b6847afa56106eacb6f1f79)

<!-- start support-pitch -->
## Support

- Join our [Slack community](https://slack.jina.ai) and chat with other community members about ideas.
- Join our [Engineering All Hands](https://youtube.com/playlist?list=PL3UBBWOUVhFYRUa_gpYYKBqEAkO4sxmne) meet-up to discuss your use case and learn Jina's new features.
    - **When?** The second Tuesday of every month
    - **Where?**
      Zoom ([see our public events calendar](https://calendar.google.com/calendar/embed?src=c_1t5ogfp2d45v8fit981j08mcm4%40group.calendar.google.com&ctz=Europe%2FBerlin)/[.ical](https://calendar.google.com/calendar/ical/c_1t5ogfp2d45v8fit981j08mcm4%40group.calendar.google.com/public/basic.ics))
      and [live stream on YouTube](https://youtube.com/c/jina-ai)
- Subscribe to the latest video tutorials on our [YouTube channel](https://youtube.com/c/jina-ai)

## Join Us

DiscoArt is backed by [Jina AI](https://jina.ai) and licensed under [MIT License](./LICENSE). [We are actively hiring](https://jobs.jina.ai) AI engineers, solution engineers to build the next neural search ecosystem in open-source.

<!-- end support-pitch -->
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/jina-ai/discoart",
    "name": "discoart",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "discoart diffusion art dalle disco-diffusion generative-art creative-ai cross-modal multi-modal artwork",
    "author": "Jina AI",
    "author_email": "hello@jina.ai",
    "download_url": "https://files.pythonhosted.org/packages/8e/3b/a2373d7d4c47e18f579942dbd8457b1fe7df46b4c2ad0ab68af11e7554f5/discoart-0.12.1.tar.gz",
    "platform": null,
    "description": "![](.github/banner.png)\n\n<p align=\"center\">\n<b>Create compelling Disco Diffusion artworks in one line</b>\n</p>\n\n<p align=center>\n<a href=\"https://pypi.org/project/discoart/\"><img src=\"https://img.shields.io/pypi/v/discoart?style=flat-square&amp;label=Release\" alt=\"PyPI\"></a>\n<a href=\"https://hub.docker.com/repository/docker/jinaai/discoart\"><img alt=\"Docker Cloud Build Status\" src=\"https://img.shields.io/docker/cloud/build/jinaai/discoart?logo=docker&logoColor=white&style=flat-square\"></a>\n<a href=\"https://slack.jina.ai\"><img src=\"https://img.shields.io/badge/Slack-3.1k-blueviolet?logo=slack&amp;logoColor=white&style=flat-square\"></a>\n<a href=\"https://colab.research.google.com/github/jina-ai/discoart/blob/main/discoart.ipynb\"><img src=\"https://img.shields.io/badge/Open-in%20Colab-brightgreen?logo=google-colab&style=flat-square\" alt=\"Open in Google Colab\"/></a>\n</p>\n\nDiscoArt is an elegant way of creating compelling Disco Diffusion<sup><a href=\"#example-application\">[*]</a></sup> artworks for generative artists, AI enthusiasts and hard-core developers. DiscoArt has a modern & professional API with a beautiful codebase, ensuring high usability and maintainability. It introduces handy features such as result recovery and persistence, gRPC/HTTP serving w/o TLS, post-analysis, easing the integration to larger cross-modal or multi-modal applications.\n\n<sub><sup><a id=\"example-application\">[*]</a> \nDisco Diffusion is a Google Colab Notebook that leverages CLIP-Guided Diffusion to allow one to create compelling and beautiful images from text prompts.\n</sup></sub>\n\n\n\ud83d\udcaf **Best-in-class**: industry-level engineering, top-notch code quality, lean dependencies, small RAM/VRAM footprint; important bug fixes, feature improvements [vs. the original DD5.6](FEATURES.md). \n\n\ud83d\udc7c **Available to all**: smooth install for *self-hosting*, Google Colab *free tier*, non-GUI (IPython) environment, and CLI! No brainfuck, no dependency hell, no stackoverflow. \n\n\ud83c\udfa8 **Focus on create not code**: one-liner `create()` with a Pythonic interface, autocompletion in IDE, and powerful features. Fetch real-time results anywhere anytime, no more worry on session outrage on Google Colab. Set initial state easily for more efficient parameter exploration.\n\n\ud83c\udfed **Ready for integration & production**: built on top of [DocArray](https://github.com/jina-ai/docarray) data structure, enjoy smooth integration with [Jina](https://github.com/jina-ai/jina), [CLIP-as-service](https://github.com/jina-ai/clip-as-service) and other cross-/multi-modal applications.\n\n\u2601\ufe0f [**As-a-service**](#serving): simply `python -m discoart serve`, DiscoArt is now a high-performance low-latency service supports gRPC/HTTP/websockets and TLS. Scaling up/down is one-line; Cloud-native features e.g. Kubernetes, Prometheus and Grafana is one-line. [Unbelievable simple thanks to Jina](https://github.com/jina-ai/jina).\n\n\n## [Gallery with prompts](https://twitter.com/hxiao/status/1542967938369687552?s=20&t=DO27EKNMADzv4WjHLQiPFA) \n\nDo you see the `discoart-id` in each tweet? To get the config & prompts, simply:\n\n```python\nfrom discoart import show_config\n\nshow_config('discoart-id')\n```\n\n## Install\n\nPython 3.7+ and CUDA-enabled PyTorch is required.\n\n```bash\npip install discoart\n```\n\nThis applies to both *self-hosting*, *Google Colab*, system integration, non-GUI environments.\n\n- **Self-hosted Jupyter**: to run a Jupyter Notebook on your own GPU machine, the easiest way is to [use our prebuilt Docker image](#run-in-docker).\n- **Use it from CLI**: [`python -m discoart create`](#cli) and `python -m discoart config` are CLI commands.\n- **Use it as a service**: [`python -m discoart serve`](#serving) allows one to run it as gRPC/HTTP/websockets service.\n\n### GUI\n\nDiscoArt is the **infrastructure** for creating Disco Diffusion artworks. The built-in Jupyter Notebook support gives you basic yet limited user experience, e.g. it does not offer any intuitive GUI for [prompt scheduling](FEATURES.md#prompt-scheduling). Note that DiscoArt is developer-centric and API-first, hence improving consumer-facing experience is out of the scope. There are services, platforms and products (not Jina AI affiliated) that already integrate DiscoArt as a service and provide nice GUI on top of it, e.g. Fever Dreams, Replicate, RunPod and Renderflux.\n\n<details>\n  <summary>Click to see third-party GUI</summary>\n\n- [Fever Dreams](https://www.feverdreams.app/): a free community-powered service with nice GUI and gallery, where people generate and share their DiscoArt artworks, prompts and configs.\n- [Replicate](https://replicate.com/nightmareai/disco-diffusion): a free form-based GUI of DiscoArt with sandbox user experience and the visualizations.  \n- [RunPod](https://www.runpod.io/blog/accelerate-your-generate-art-with-disco-diffusion-and-runpod): a paid GPU cloud provider that runs DiscoArt container with a simple and clean GUI to visualize the configs and creations.\n- [Renderflux](https://beta.renderflux.com/register?invite=bughunting): a paid creative art platform that wraps DiscoArt and provides end-to-end GUI for creation management.\n\n**Please be aware that these platforms, products or companies are not affiliated with Jina AI.** They define their own terms of services, paywall and data and privacy policies, which are not in the scope of DiscoArt MIT License.\n\n</details>\n\n## Get Started\n\n<a href=\"https://colab.research.google.com/github/jina-ai/discoart/blob/main/discoart.ipynb\"><img src=\"https://img.shields.io/badge/Open-in%20Colab-brightgreen?logo=google-colab&style=flat-square\" alt=\"Open in Google Colab\"/></a>\n\n### Create artworks\n\n```python\nfrom discoart import create\n\nda = create()\n```\n\nThat's it! It will create with the [default text prompts and parameters](./discoart/resources/default.yml).\n\n![](.github/create-demo.gif)\n\n### Set prompts and parameters\n\nSupported parameters are [listed here](./discoart/resources/default.yml). You can specify them in `create()`:\n\n```python\nfrom discoart import create\n\nda = create(\n    text_prompts='A painting of sea cliffs in a tumultuous storm, Trending on ArtStation.',\n    init_image='https://d2vyhzeko0lke5.cloudfront.net/2f4f6dfa5a05e078469ebe57e77b72f0.png',\n    skip_steps=100,\n)\n```\n\n![](.github/parameter-demo.gif)\n\nIn case you forgot a parameter, just lookup the cheatsheet at anytime:\n\n```python\nfrom discoart import cheatsheet\n\ncheatsheet()\n```\n\nThe difference on the parameters between DiscoArt and DD5.6 [is explained here](./FEATURES.md). \n\n\n### Visualize results\n\nFinal results and intermediate results are created under the current working directory, i.e.\n```text\n./{name-docarray}/{i}-done.png\n./{name-docarray}/{i}-step-{j}.png\n./{name-docarray}/{i}-progress.png\n./{name-docarray}/{i}-progress.gif\n./{name-docarray}/da.protobuf.lz4\n```\n\n![](.github/result-persist.png)\n\nwhere:\n\n- `name-docarray` is the name of the run, you can specify it otherwise it is a random name.\n- `i-*` is up to the value of `n_batches`.\n- `*-done-*` is the final image on done.\n- `*-step-*` is the intermediate image at certain step, updated in real-time.\n- `*-progress.png` is the sprite image of all intermediate results so far, updated in real-time.\n- `*-progress.gif` is the animated gif of all intermediate results so far, updated in real-time.\n- `da.protobuf.lz4` is the compressed protobuf of all intermediate results so far, updated in real-time.\n\nThe save frequency is controlled by `save_rate`.\n\nMoreover, `create()` returns `da`, a [DocumentArray](https://docarray.jina.ai/fundamentals/documentarray/)-type object. It contains the following information:\n- All arguments passed to `create()` function, including seed, text prompts and model parameters.\n- 4 generated image and its intermediate steps' images, where `4` is determined by `n_batches` and is the default value. \n\nThis allows you to further post-process, analyze, export the results with powerful DocArray API.\n\nImages are stored as Data URI in `.uri`, to save the first image as a local file:\n\n```python\nda[0].save_uri_to_file('discoart-result.png')\n```\n\nTo save all final images:\n\n```python\nfor idx, d in enumerate(da):\n    d.save_uri_to_file(f'discoart-result-{idx}.png')\n```\n\nYou can also display all four final images in a grid:\n\n```python\nda.plot_image_sprites(skip_empty=True, show_index=True, keep_aspect_ratio=True)\n```\n![](.github/all-results.png)\n\nOr display them one by one:\n\n```python\nfor d in da:\n    d.display()\n```\n\nOr take one particular run:\n\n```python\nda[0].display()\n```\n\n![](.github/display.png)\n\n### Visualize intermediate steps\n\nYou can also zoom into a run (say the first run) and check out intermediate steps:\n\n```python\nda[0].chunks.plot_image_sprites(\n    skip_empty=True, show_index=True, keep_aspect_ratio=True\n)\n```\n![](.github/chunks.png)\n\nYou can `.display()` the chunks one by one, or save one via `.save_uri_to_file()`, or save all intermediate steps as a GIF:\n\n```python\nda[0].chunks.save_gif(\n    'lighthouse.gif', show_index=True, inline_display=True, size_ratio=0.5\n)\n```\n\n![](.github/lighthouse.gif)\n\nNote that >=0.7.14, a 20FPS gif is generated which includes all intermedidate steps. \n\n### Show/save/load configs\n\nTo show the config of a Document/DocumentArray,\n\n```python\nfrom discoart import show_config\n\nshow_config(da)  # show the config of the first run\nshow_config(da[3])  # show the config of the fourth run\nshow_config(\n    'discoart-06030a0198843332edc554ffebfbf288'\n)  # show the config of the run with a known DocArray ID\n```\n\nTo save the config of a Document/DocumentArray,\n\n```python\nfrom discoart import save_config\n\nsave_config(da, 'my.yml')  # save the config of the first run\nsave_config(da[3], 'my.yml')  # save the config of the fourth run\n```\n\nTo run `create` from a YAML config of Document/DocumentArray,\n\n```python\nfrom discoart import create, load_config\n\nconfig = load_config('my.yml')\ncreate(**config)\n```\n\nYou can also export the config as an SVG image:\n\n```python\nfrom discoart.config import save_config_svg\n\nsave_config_svg(da)\n```\n\n![](.github/discoart-3205998582.svg)\n\nOne can also generate runnable Python code directly from the config:\n\n```python\nfrom discoart.config import export_python\n\nexport_python(da)\n```\n\n### Pull results anywhere anytime\n\nIf you are a free-tier Google Colab user, one annoy thing is the lost of sessions from time to time. Or sometimes you just early stop the run as the first image is not good enough, and a keyboard interrupt will prevent `.create()` to return any result. Either case, you can easily recover the results by pulling the last session ID.\n\n1. Find the session ID. It appears on top of the image. \n![](.github/session-id.png)\n\n2. Pull the result via that ID **on any machine at any time**, not necessarily on Google Colab:\n    ```python\n    from docarray import DocumentArray\n    \n    da = DocumentArray.pull('discoart-3205998582')\n    ```\n\n### Reuse a Document as initial state\n\nConsider a Document as a self-contained data with config and image, one can use it as the initial state for the future run. Its `.tags` will be used as the initial parameters; `.uri` if presented will be used as the initial image.\n\n```python\nfrom discoart import create\nfrom docarray import DocumentArray\n\nda = DocumentArray.pull('discoart-3205998582')\n\ncreate(\n    init_document=da[0],\n    cut_ic_pow=0.5,\n    tv_scale=600,\n    cut_overview='[12]*1000',\n    cut_innercut='[12]*1000',\n    use_secondary_model=False,\n)\n```\n\nIf you just want to initialize from a known DocArray ID, then simply:\n\n```python\nfrom discoart import create\n\ncreate(init_document='discoart-3205998582')\n```\n\n\n### Environment variables\n\nYou can set environment variables to control the meta-behavior of DiscoArt. The environment variables must be set before importing DiscoArt, either in Bash or in Python via `os.environ`.\n\n```bash\nDISCOART_LOG_LEVEL='DEBUG' # more verbose logs\nDISCOART_OPTOUT_CLOUD_BACKUP='1' # opt-out from cloud backup\nDISCOART_DISABLE_IPYTHON='1' # disable ipython dependency\nDISCOART_DISABLE_RESULT_SUMMARY='1' # disable result summary after the run ends\nDISCOART_DEFAULT_PARAMETERS_YAML='path/to/your-default.yml' # use a custom default parameters file\nDISCOART_CUT_SCHEDULES_YAML='path/to/your-schedules.yml' # use a custom cut schedules file\nDISCOART_MODELS_YAML='path/to/your-models.yml' # use a custom list of models file\nDISCOART_OUTPUT_DIR='path/to/your-output-dir' # use a custom output directory for all images and results\nDISCOART_CACHE_DIR='path/to/your-cache-dir' # use a custom cache directory for models and downloads\nDISCOART_DISABLE_REMOTE_MODELS='1' # disable the listing of diffusion models on Github, remote diffusion models allows user to use latest models without updating the codebase.\nDISCOART_REMOTE_MODELS_URL='https://yourdomain/models.yml' # use a custom remote URL for fetching models list\nDISCOART_DISABLE_CHECK_MODEL_SHA='1' # disable checking local model SHA matches the remote model SHA\nDISCOART_DISABLE_TQDM='1' # disable tqdm progress bar on diffusion\n```\n\n## CLI\n\nDiscoArt provides two commands `create` and `config` that allows you to run DiscoArt from CLI.\n\n```bash\npython -m discoart create my.yml\n```\n\nwhich creates artworks from the YAML config file `my.yml`. You can also do:\n\n```bash\ncat config.yml | python -m discoart create\n```\n\nSo how can I have my own `my.yml` and what does it look like? That's the second command:\n\n```bash\npython -m discoart config my.yml\n```\n\nwhich forks the [default YAML config](discoart/resources/default.yml) and export them to `my.yml`. Now you can modify it and run it with `python -m discoart create` command.\n\nIf no output path is specified, then `python -m discoart config` will print the default config to stdout.\n\nTo get help on a command, add `--help` at the end, e.g.:\n\n```bash\npython -m discoart create --help\n```\n\n```text\nusage: python -m discoart create [-h] [YAML_CONFIG_FILE]\n\npositional arguments:\n  YAML_CONFIG_FILE  The YAML config file to use, default is stdin.\n\noptional arguments:\n  -h, --help        show this help message and exit\n```\n\n## Serving\n\nServing DiscoArt is super easy. Simply run the following command:\n\n```bash\npython -m discoart serve\n```\n\nYou shall see:\n\n![](.github/serving.png)\n\nNow send request to the server via curl/Javascript, e.g.\n\n```bash\ncurl \\\n-X POST http://0.0.0.0:51001/post \\\n-H 'Content-Type: application/json' \\\n-d '{\"execEndpoint\":\"/create\", \"parameters\": {\"text_prompts\": [\"A beautiful painting of a singular lighthouse\", \"yellow color scheme\"]}}'\n```\n\nThat's it. \n\nYou can of course pass all parameters that accepted by `create()` function in the JSON.\n\n### Polling intermediate results\n\nWe already know that `create` function is slow even on GPU it could take 10 minutes to finish an artwork. This means the after sending the above request, the client will have to wait 10 minutes for the response. There is nothing wrong with this behavior given that everything runs synchronously. However, in practice, client may expect a progress or intermediate results in the middle instead of waiting for the end.\n\n`/result` endpoint is designed for this purpose. It will return the intermediate results as soon as they are available. All you need is to specify `name_docarray` in the request parameters as you specified in `/create` endpoint. Here is an example:\n\nLet's create `mydisco-123` by sending the following request to `/create` endpoint:\n\n```bash\ncurl \\\n-X POST http://0.0.0.0:51001/post \\\n-H 'Content-Type: application/json' \\\n-d '{\"execEndpoint\":\"/create\", \"parameters\": {\"name_docarray\": \"mydisco-123\", \"text_prompts\": [\"A beautiful painting of a singular lighthouse\", \"yellow color scheme\"]}}'\n```\n\nNow that the above request is being processed on the server, you can periodically check `mydisco-123` progress by sending the following request to `/result` endpoint:\n\n```bash\ncurl \\\n-X POST http://0.0.0.0:51001/post \\\n-H 'Content-Type: application/json' \\\n-d '{\"execEndpoint\":\"/result\", \"parameters\": {\"name_docarray\": \"mydisco-123\"}}'\n```\n\nA JSON will be returned with up-to-date progress, with image as DataURI, loss, steps etc. [The JSON Schema of Document/DocumentArray is described here.](https://docarray.jina.ai/fundamentals/fastapi-support/#json-schema)\n\nNote, `/result` won't be blocked by `/create` thanks to the smart routing of Jina Gateway. To learn/play more about those endpoints, you can check ReDoc or the Swagger UI embedded in the server.\n\n### Skip & Cancel\n\nSend to `/skip`, to skip the current run and move to the next run as defined in `n_batches`:\n\n```bash\ncurl \\\n-X POST http://0.0.0.0:51001/post \\\n-H 'Content-Type: application/json' \\\n-d '{\"execEndpoint\":\"/skip\"}'\n```\n\nSend to `/stop`, to stop the current run cancel all runs `n_batches`:\n\n```bash\ncurl \\\n-X POST http://0.0.0.0:51001/post \\\n-H 'Content-Type: application/json' \\\n-d '{\"execEndpoint\":\"/stop\"}'\n```\n\n### Unblocking `/create` request\n\nIt is possible to have an unblocked `/create` endpoint: the client request to `/create` will be **immediately** returned, without waiting for the results to be finished. You now have to fully rely on `/result` to poll the result. \n\nTo enable this feature: \n\n1. Copy-paste the [default `flow.yml` file](./discoart/resources/flow.yml) to `myflow.yml`;\n2. Change `floating: false` to `floating: true` under `discoart` executor section;\n3. Run the following command:\n    ```bash\n    python -m discoart serve myflow.yml\n    ```\n\nBeware that the request velocity is now under **your control**. That is, if the client sends 10 `/create` requests in a second, then the server will start 10 `create()` in parallel! This can easily lead to OOM. Hence, the suggestion is only enabling this feature if you are sure that the client is not sending too many requests, e.g. you control the client request rate; or you are using DiscoArt behind a BFF (backend for frontend).\n\n### Scaling out\n\nIf you have multiple GPUs and you want to run multiple DiscoArt instances in parallel by leveraging GPUs in a time-multiplexed fashion, you can copy-paste the [default `flow.yml` file](./discoart/resources/flow.yml) and modify it as follows:\n\n```yaml\njtype: Flow\nwith:\n  protocol: http\n  monitoring: true\n  port: 51001\n  port_monitoring: 51002  # prometheus monitoring port\n  env:\n    JINA_LOG_LEVEL: debug\n    DISCOART_DISABLE_IPYTHON: 1\n    DISCOART_DISABLE_RESULT_SUMMARY: 1\nexecutors:\n  - name: discoart\n    uses: DiscoArtExecutor\n    env:\n      CUDA_VISIBLE_DEVICES: RR0:3  # change this if you have multiple GPU\n    replicas: 3  # change this if you have larger VRAM\n  - name: poller\n    uses: ResultPoller\n```\n\nHere `replicas: 3` says spawning three DiscoArt instances, `CUDA_VISIBLE_DEVICES: RR0:3` makes sure they use the first three GPUs in a round-robin fashion.\n\nName it as `myflow.yml` and then run \n\n```bash\npython -m discoart serve myflow.yml\n```\n\n### Customization\n\n[Thanks to Jina](https://github.com/jina-ai/jina), there are tons of things you can customize! You can change the port number; change protocol to gRPC/Websockets; add TLS encryption; enable/disable Prometheus monitoring; you can also export it to Kubernetes deployment bundle simply via:\n\n```bash\njina export kubernetes myflow.yml\n```\n\nFor more features and YAML configs, [please check out Jina docs](https://docs.jina.ai).\n\n\n### Use gRPC gateway\n\nTo switch from HTTP to gRPC gateway is simple:\n\n```yaml\njtype: Flow\nwith:\n  protocol: grpc\n...\n```\n\nand then restart the server.\n\nThere are multiple advantages of using gRPC gateway:\n- Much faster and smaller network overhead.\n- Feature-rich, like compression, status monitoring, etc.\n\nIn general, if you are using the DiscoArt server behind a BFF (backend for frontend), or your DiscoArt server does **not** directly serve HTTP traffic from end-users, then you should use gRPC protocol.\n\nTo communicate with a gRPC DiscoArt server, one can use a Jina Client:\n\n```python\n# !pip install jina\nfrom jina import Client\n\nc = Client(host='grpc://0.0.0.0:51001')\n\nda = c.post(\n    '/create',\n    parameters={\n        'name_docarray': 'mydisco-123',\n        'text_prompts': [\n            'A beautiful painting of a singular lighthouse',\n            'yellow color scheme',\n        ],\n    },\n)\n\n# check intermediate results\nda = c.post('/result', parameters={'name_docarray': 'mydisco-123'})\n```\n\nTo use an existing Document/DocumentArray as init Document for `create`:\n\n```python\nfrom jina import Client\n\nc = Client(host='grpc://0.0.0.0:51001')\n\nold_da = create(...)\n\nda = c.post(\n    '/create',\n    old_da,  # this can be a DocumentArray or a single Document\n    parameters={\n        'width_height': [1024, 768],\n    },\n)\n```\n\nThis equals to run `create(init_document=old_da, width_height=[1024, 768])` on the server. Note:\n- follow-up parameters have higher priorities than the parameters in `init_document`.\n- if `init_document` is a DocumentArray, then the first Document in the array will be used as the init Document.\n- there is no need to do any serialization before sending, Jina automatically handles it.\n\n### Hosting on Google Colab\n\nThough not recommended, it is also possible to use Google Colab to host DiscoArt server. \nPlease check out the following tutorials:\n- https://docs.jina.ai/how-to/google-colab/\n- https://clip-as-service.jina.ai/hosting/colab/\n\n\n\n\n\n## Run in Docker\n\n[![Docker Image Size (tag)](https://img.shields.io/docker/image-size/jinaai/discoart/latest?logo=docker&logoColor=white&style=flat-square)](https://hub.docker.com/repository/docker/jinaai/discoart)\n\nWe provide a prebuilt Docker image for running DiscoArt out of the box. To update Docker image to latest version:\n\n```bash\ndocker pull jinaai/discoart:latest\n```\n\n### Use Jupyter notebook\n\nThe default entrypoint is starting a Jupyter notebook\n\n```bash\n# docker build . -t jinaai/discoart  # if you want to build yourself\ndocker run -p 51000:8888 -v $(pwd):/home/jovyan/ -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart\n```\n\nNow you can visit `http://127.0.0.1:51000` to access the notebook\n\n### Enable GPU in Docker on Windows\n\n You can use it on Windows Subsystem for Linux (WSL), Check the official guide [here](https://docs.microsoft.com/en-us/windows/ai/directml/gpu-cuda-in-wsl).\n\n```bash\n# Make sure you install Windows 11 or Windows 10, version 21H2\ndocker run -p 8888:8888 -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart\n```\n\n### Use as a service\n\n```bash\n# docker build . -t jinaai/discoart  # if you want to build yourself\ndocker run --entrypoint \"python\" -p 51001:51001 -v $(pwd):/home/jovyan/ -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart -m discoart serve\n```\n\nYour DiscoArt server is now running at `http://127.0.0.1:51001`.\n\n### Release cycle\n\n[Docker images are built on every release](https://hub.docker.com/repository/docker/jinaai/discoart), so one can lock it to a specific version, say `0.5.1`:\n\n```bash\ndocker run -p 51000:8888 -v $(pwd):/home/jovyan/ -v $HOME/.cache:/root/.cache --gpus all jinaai/discoart:0.5.1\n```\n\n\n## What's next?\n\n[Next is create](https://colab.research.google.com/github/jina-ai/discoart/blob/main/discoart.ipynb).\n\n\ud83d\ude0e **If you are already a DD user**: you are ready to go! There is no extra learning, DiscoArt respects the same parameter semantics as DD5.6. So just unleash your creativity! [Read more about their differences here](./FEATURES.md).\n\nYou can always do `from discoart import cheatsheet; cheatsheet()` to check all new/modified parameters.\n\n\ud83d\udc76 **If you are a [DALL\u00b7E Flow](https://github.com/jina-ai/dalle-flow/) or new user**: you may want to take step by step, as Disco Diffusion works in a very different way than DALL\u00b7E. It is much more advanced and powerful: e.g. Disco Diffusion can take weighted & structured text prompts; it can initialize from a image with controlled noise; and there are way more parameters one can tweak. Impatient prompt like `\"armchair avocado\"` will give you nothing but confusion and frustration. I highly recommend you to check out the following resources before trying your own prompt:\n- [Zippy's Disco Diffusion Cheatsheet v0.3](https://docs.google.com/document/d/1l8s7uS2dGqjztYSjPpzlmXLjl5PM3IGkRWI3IiCuK7g/mobilebasic)\n- [EZ Charts - Diffusion Parameter Studies](https://docs.google.com/document/d/1ORymHm0Te18qKiHnhcdgGp-WSt8ZkLZvow3raiu2DVU/edit#)\n- [Disco Diffusion 70+ Artist Studies](https://weirdwonderfulai.art/resources/disco-diffusion-70-plus-artist-studies/)\n- [A Traveler\u2019s Guide to the Latent Space](https://sweet-hall-e72.notion.site/A-Traveler-s-Guide-to-the-Latent-Space-85efba7e5e6a40e5bd3cae980f30235f#e122e748b86e4fc0ad6a7a50e46d6e10)\n- [Disco Diffusion Illustrated Settings](https://coar.notion.site/Disco-Diffusion-Illustrated-Settings-cd4badf06e08440c99d8a93d4cd39f51)\n- [Coar\u2019s Disco Diffusion Guide](https://coar.notion.site/coar/Coar-s-Disco-Diffusion-Guide-3d86d652c15d4ca986325e808bde06aa#8a3c6e9e4b6847afa56106eacb6f1f79)\n\n<!-- start support-pitch -->\n## Support\n\n- Join our [Slack community](https://slack.jina.ai) and chat with other community members about ideas.\n- Join our [Engineering All Hands](https://youtube.com/playlist?list=PL3UBBWOUVhFYRUa_gpYYKBqEAkO4sxmne) meet-up to discuss your use case and learn Jina's new features.\n    - **When?** The second Tuesday of every month\n    - **Where?**\n      Zoom ([see our public events calendar](https://calendar.google.com/calendar/embed?src=c_1t5ogfp2d45v8fit981j08mcm4%40group.calendar.google.com&ctz=Europe%2FBerlin)/[.ical](https://calendar.google.com/calendar/ical/c_1t5ogfp2d45v8fit981j08mcm4%40group.calendar.google.com/public/basic.ics))\n      and [live stream on YouTube](https://youtube.com/c/jina-ai)\n- Subscribe to the latest video tutorials on our [YouTube channel](https://youtube.com/c/jina-ai)\n\n## Join Us\n\nDiscoArt is backed by [Jina AI](https://jina.ai) and licensed under [MIT License](./LICENSE). [We are actively hiring](https://jobs.jina.ai) AI engineers, solution engineers to build the next neural search ecosystem in open-source.\n\n<!-- end support-pitch -->",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Create Disco Diffusion artworks in one line",
    "version": "0.12.1",
    "split_keywords": [
        "discoart",
        "diffusion",
        "art",
        "dalle",
        "disco-diffusion",
        "generative-art",
        "creative-ai",
        "cross-modal",
        "multi-modal",
        "artwork"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8e3ba2373d7d4c47e18f579942dbd8457b1fe7df46b4c2ad0ab68af11e7554f5",
                "md5": "76085d0033316c27dcb9097cb071f008",
                "sha256": "8dfcad991214cdb3c611f599d72a691a2bbba9d60726ff3e9a5226b330ce71e8"
            },
            "downloads": -1,
            "filename": "discoart-0.12.1.tar.gz",
            "has_sig": false,
            "md5_digest": "76085d0033316c27dcb9097cb071f008",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 74580,
            "upload_time": "2023-04-20T08:17:29",
            "upload_time_iso_8601": "2023-04-20T08:17:29.942368Z",
            "url": "https://files.pythonhosted.org/packages/8e/3b/a2373d7d4c47e18f579942dbd8457b1fe7df46b4c2ad0ab68af11e7554f5/discoart-0.12.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-04-20 08:17:29",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "jina-ai",
    "github_project": "discoart",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "discoart"
}
        
Elapsed time: 9.48474s