Skip to content

Scripts to aid in preparing training data for riffusion.

License

Notifications You must be signed in to change notification settings

gitmylo/riffusion-scripts

 
 

Repository files navigation

Riffusion scripts

GUI - setup and usage (Windows, Mac and Linux)

Make sure you have python 3.10 (or later) installed.

  • Automatic (Windows, Mac and Linux):
    • .bat (Windows only):
      • Run rungui.bat
        • A: Run the file by clicking on it
        • B: Open a cmd in the root folder, and run rungui.bat
    • .sh (Windows (requires bash, like git bash), Mac and Linux)
      • Run rungui.sh
        • A: Run the file by clicking on it
        • B: Open a bash shell in the root folder, and run ./rungui.sh
  • Manual (Windows, Mac and Linux):
    1. Create a venv
      • Automatic (Windows)
        1. open a terminal in the project root folder
        2. run activate.bat, it will automatically create the venv if it doesn't exist yet
      • Manual (Windows, Mac and Linux):
        1. open a terminal in the project root folder
        2. run python -m venv venv --upgrade-deps or py -m venv venv --upgrade-deps
        3. activate the venv:
          • Windows: run start venv\Scripts\activate.bat
          • Mac and Linux: run source venv/bin/activate
    2. Install packages
      • run pip install -r requirements.txt or pip install -r requirements_all.txt
    3. For running again: activate venv again (skip this on first run)
      • Automatic (Windows)
        1. open a terminal in the project root folder
        2. run activate.bat
      • Manual (Windows, Mac and Linux):
        1. open a terminal in the project root folder
        2. activate the venv:
          • Windows: run start venv\Scripts\activate.bat
          • Mac and Linux: run source venv/bin/activate
    4. Run the GUI script
      • run python gui.py

OLD - Setup and usage (Windows, Mac and Linux)

  1. Make sure you have python 3.10 (or later) installed.
  2. Set up and activate venv
    • Automatic (Windows):
      1. run createvenv.bat
      2. run activate.bat
    • Manual (Windows, Mac and Linux) (Can't test this, so I hope I wrote it correctly):
      1. open a terminal in the project root folder
      2. run python -m venv venv --upgrade-deps or py -m venv venv --upgrade-deps
      3. activate the venv:
        • Windows: run start venv\Scripts\activate.bat
        • Mac and Linux: run source venv/bin/activate
  3. Install packages
    • Run pip install -r requirements.txt or pip install -r requirements_all.txt
  4. Set the settings in the script you want to run
    • Settings are described per script below
  5. Put your input files into the !input folder
    • The !input will be automatically created on the first run if it doesn't exist. And the script will exit
  6. Run the script
    • Run python script.py where script.py is the name of the script you want to run. For example python audiotoimageconverter.py
  7. Done
    • The script shows what it's doing at the moment, and when it's done
    • Outputs to the !output folder

Current scripts

  • Audio to image converter
    • Automatically split audio files into chunks of 512x512 pixels
    • Automatically use caption files (if included). Use title as caption if not included.
      • Simply place a file with the same name as the audio clip, with .txt instead of .wav.
      • Example: audio_file.wav gets a caption file named audio_file.txt, once processed it will be 00000.wav with 00000.txt.
    • Settings:
      • Backwards pass (backwards_if_not_fit): Get more clips (with overlap) by going backwards from the end if the pixel length isn't an exact multiple of chunk_jump. For better continuation.
      • Chunk jump (chunk_jump): Change the size of jumps, 512 is no overlap, 256 is for half overlap between clips, can be used as an alternative or in combination with backwards_if_not_fit
      • Options for changing what to do when an audio file is less than 5.(3/25 aka (12/100)) seconds (wrap_mode).
        • SKIP: Ignore the file entirely, will ignore all files shorter than 5.(3/25) seconds.
        • FILL: Fill the missing space with white (no sound) to make the clip end in silence.
        • REPEAT: Repeat the space to fill, repeats as many times as necessary to fill the entire 5.(3/25) second clip.

Old readme below V

🎸 Riffusion

CI status Python 3.9 | 3.10 MIT License

Riffusion is a library for real-time music and audio generation with stable diffusion.

Read about it at https://www.riffusion.com/about and try it at https://www.riffusion.com/.

This is the core repository for riffusion image and audio processing code.

  • Diffusion pipeline that performs prompt interpolation combined with image conditioning
  • Conversions between spectrogram images and audio clips
  • Command-line interface for common tasks
  • Interactive app using streamlit
  • Flask server to provide model inference via API
  • Various third party integrations

Related repositories:

Citation

If you build on this work, please cite it as follows:

@article{Forsgren_Martiros_2022,
  author = {Forsgren, Seth* and Martiros, Hayk*},
  title = {{Riffusion - Stable diffusion for real-time music generation}},
  url = {https://riffusion.com/about},
  year = {2022}
}

Install

Tested in CI with Python 3.9 and 3.10.

It's highly recommended to set up a virtual Python environment with conda or virtualenv:

conda create --name riffusion python=3.9
conda activate riffusion

Install Python dependencies:

python -m pip install -r requirements.txt

In order to use audio formats other than WAV, ffmpeg is required.

sudo apt-get install ffmpeg          # linux
brew install ffmpeg                  # mac
conda install -c conda-forge ffmpeg  # conda

If torchaudio has no backend, you may need to install libsndfile. See this issue.

If you have an issue, try upgrading diffusers. Tested with 0.9 - 0.11.

Guides:

Backends

CPU

cpu is supported but is quite slow.

CUDA

cuda is the recommended and most performant backend.

To use with CUDA, make sure you have torch and torchaudio installed with CUDA support. See the install guide or stable wheels.

To generate audio in real-time, you need a GPU that can run stable diffusion with approximately 50 steps in under five seconds, such as a 3090 or A10G.

Test availability with:

import torch
torch.cuda.is_available()

MPS

The mps backend on Apple Silicon is supported for inference but some operations fall back to CPU, particularly for audio processing. You may need to set PYTORCH_ENABLE_MPS_FALLBACK=1.

In addition, this backend is not deterministic.

Test availability with:

import torch
torch.backends.mps.is_available()

Command-line interface

Riffusion comes with a command line interface for performing common tasks.

See available commands:

python -m riffusion.cli -h

Get help for a specific command:

python -m riffusion.cli image-to-audio -h

Execute:

python -m riffusion.cli image-to-audio --image spectrogram_image.png --audio clip.wav

Riffusion Playground

Riffusion contains a streamlit app for interactive use and exploration.

Run with:

python -m riffusion.streamlit.playground

And access at http://127.0.0.1:8501/

Riffusion Playground

Run the model server

Riffusion can be run as a flask server that provides inference via API. This server enables the web app to run locally.

Run with:

python -m riffusion.server --host 127.0.0.1 --port 3013

You can specify --checkpoint with your own directory or huggingface ID in diffusers format.

Use the --device argument to specify the torch device to use.

The model endpoint is now available at http://127.0.0.1:3013/run_inference via POST request.

Example input (see InferenceInput for the API):

{
  "alpha": 0.75,
  "num_inference_steps": 50,
  "seed_image_id": "og_beat",

  "start": {
    "prompt": "church bells on sunday",
    "seed": 42,
    "denoising": 0.75,
    "guidance": 7.0
  },

  "end": {
    "prompt": "jazz with piano",
    "seed": 123,
    "denoising": 0.75,
    "guidance": 7.0
  }
}

Example output (see InferenceOutput for the API):

{
  "image": "< base64 encoded JPEG image >",
  "audio": "< base64 encoded MP3 clip >"
}

Tests

Tests live in the test/ directory and are implemented with unittest.

To run all tests:

python -m unittest test/*_test.py

To run a single test:

python -m unittest test.audio_to_image_test

To preserve temporary outputs for debugging, set RIFFUSION_TEST_DEBUG:

RIFFUSION_TEST_DEBUG=1 python -m unittest test.audio_to_image_test

To run a single test case within a test:

python -m unittest test.audio_to_image_test -k AudioToImageTest.test_stereo

To run tests using a specific torch device, set RIFFUSION_TEST_DEVICE. Tests should pass with cpu, cuda, and mps backends.

Development Guide

Install additional packages for dev with python -m pip install -r requirements_dev.txt.

  • Linter: ruff
  • Formatter: black
  • Type checker: mypy

These are configured in pyproject.toml.

The results of mypy ., black ., and ruff . must be clean to accept a PR.

CI is run through GitHub Actions from .github/workflows/ci.yml.

Contributions are welcome through pull requests.

About

Scripts to aid in preparing training data for riffusion.

Topics

Resources

License

Stars

Watchers

Forks

Languages

  • Python 99.1%
  • Other 0.9%