Denoise WAV audio using RNNoise, DeepFilterNet, and FacebookResearch Denoiser.
Project description
denoise-audio
A CLI tool for denoising WAV audio with 3 leading backends:
- rnnoise (fast, CPU-only, low-latency)
- deepfilternet (high-quality full-band denoising)
- fbdenoiser (FacebookResearch Denoiser / causal Demucs; strong enhancement)
Inputs/outputs are WAV files. If your audio is not WAV, convert it first.
Install with pip (PyPI)
Use this if you want to install and use the tool without cloning the repo.
Install
pip install denoise-audio
CLI usage (pip)
Global help:
python -m denoise --help
List available backends:
python -m denoise --list-models
Model-specific help:
python -m denoise --model rnnoise --help
python -m denoise --model deepfilternet --help
python -m denoise --model fbdenoiser --help
Basic command (all models):
python -m denoise --model <model> --input <in.wav> --output <out.wav>
<model>is one of:rnnoise,deepfilternet,fbdenoiser--inputand--outputmust be WAV files
Recommended environment (Python 3.10)
A fresh virtual environment with Python 3.10 is recommended to avoid dependency conflicts.
Troubleshooting: wheel / packaging conflicts
Some environments may already have a newer wheel installed that requires packaging>=24, while deepfilternet requires packaging<24.
If you see an error mentioning a wheel/packaging conflict, use a clean venv (recommended) or pin compatible versions:
python -m pip install --upgrade "packaging>=23,<24" "wheel<0.46"
python -m pip install --upgrade --force-reinstall denoise-audio
Python usage (import)
You can also use this package directly in your Python code after installing with pip install denoise-audio.
Quick sanity check
python -c "import denoise; print(denoise.__version__)"
List available models/backends
from denoise import available_models, backend_help
print(available_models())
print(backend_help())
Inspect supported keyword arguments for each model
from denoise import model_kwargs_help
print(model_kwargs_help("rnnoise"))
print(model_kwargs_help("deepfilternet"))
print(model_kwargs_help("fbdenoiser"))
Run denoising from a Python file
Create run_denoise.py:
from denoise import denoise_file
IN_WAV = "input.wav"
OUT_WAV = "output.wav"
# Choose one: rnnoise | deepfilternet | fbdenoiser
MODEL = "rnnoise"
# Model-specific kwargs (examples below)
kwargs = {}
# Example: RNNoise
# kwargs = {"rnnoise_sample_rate": 48000}
# Example: DeepFilterNet
# kwargs = {"df_model": "DeepFilterNet3", "df_pf": True, "df_compensate_delay": True}
# Example: FacebookResearch Denoiser
# kwargs = {"fb_model": "dns64", "fb_device": "cpu", "fb_dry": 1.0}
for _ in denoise_file(IN_WAV, OUT_WAV, model=MODEL, **kwargs):
pass
print(f"Wrote: {OUT_WAV}")
Run it:
python run_denoise.py
Install from GitHub (uv)
Install uv using Astral’s standalone installer:
https://docs.astral.sh/uv/getting-started/installation/#standalone-installer
Verify:
uv --version
Install dependencies
git clone https://github.com/Surya-Rayala/denoise-audio.git
cd denoise-audio
uv sync
CLI usage
Run everything with uv run to ensure you’re using the project environment:
Global help
uv run python -m denoise --help
List available backends
uv run python -m denoise --list-models
Model-specific help
Pass --model <name> and --help to see only that backend’s options:
uv run python -m denoise --model rnnoise --help
uv run python -m denoise --model deepfilternet --help
uv run python -m denoise --model fbdenoiser --help
Basic command (all models)
uv run python -m denoise --model <model> --input <in.wav> --output <out.wav>
<model>is one of:rnnoise,deepfilternet,fbdenoiser--inputand--outputmust be WAV files
Models
RNNoise (--model rnnoise)
Basic command
uv run python -m denoise --model rnnoise --input <in.wav> --output <out.wav>
Arguments
--rnnoise-sample-rate <int>: Force the RNNoise wrapper sample rate. If omitted, the tool infers the sample rate from the input WAV (recommended).
DeepFilterNet (--model deepfilternet)
Basic command
uv run python -m denoise --model deepfilternet --input <in.wav> --output <out.wav>
Arguments
--df-model <name>: Select which pretrained DeepFilterNet model to load. Common options:DeepFilterNet,DeepFilterNet2,DeepFilterNet3.- To see available models, visit: https://github.com/Rikorose/DeepFilterNet/tree/main/models
--df-pf: Enable the post-filter (can reduce residual noise; may sound more aggressive in very noisy sections).--df-compensate-delay: Add padding to compensate processing delay (useful when you need better alignment with the original audio).
FacebookResearch Denoiser (--model fbdenoiser)
Basic command
uv run python -m denoise --model fbdenoiser --input <in.wav> --output <out.wav>
Arguments
--fb-model <name>: Choose the pretrained model:dns48: pre-trained real time H=48 model trained on DNSdns64: pre-trained real time H=64 model trained on DNSmaster64: pre-trained real time H=64 model trained on DNS and Valentini
--fb-device <device>: Inference device, e.g.cpuorcuda. If omitted, it automatically uses CUDA if available, otherwise CPU.--fb-dry <float>: Dry/wet mix (0.0= original input only,1.0= denoised output only). Values outside[0.0, 1.0]are clamped.--fb-streaming: Enable streaming mode (flag is accepted by the CLI).--fb-batch-size <int>: Batch size (flag is accepted by the CLI).--fb-num-workers <int>: Number of workers (flag is accepted by the CLI).--fb-verbose: Enable verbose logging (flag is accepted by the CLI).
Updating from Git
If you’re using the repo locally with uv sync + uv run, updating to new code from Git is:
cd denoise-audio
git pull
uv sync
If you have local changes and git pull refuses
Use one of these (pick what you intend):
- Keep your local changes and rebase on top:
git pull --rebase
uv sync
- Discard local changes and reset to remote (⚠️ destructive):
git fetch origin
git reset --hard origin/main
uv sync
License
This project's source code is licensed under the MIT License.
Note on Dependencies: This tool relies on the denoiser library (Facebook Research), which is licensed under CC-BY-NC 4.0 (Non-Commercial). Consequently, this tool as a whole is suitable for research and personal use only, unless you obtain a commercial license for the denoiser dependency.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file denoise_audio-0.1.1.tar.gz.
File metadata
- Download URL: denoise_audio-0.1.1.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8c2ce85a21515afa167bd4138f7848173dd62356ee3c45bdfb20f030b7a42c27
|
|
| MD5 |
73b54fd8e1b5f2680b9af4844775c044
|
|
| BLAKE2b-256 |
d557361fd7485c60d2649e6a4b4e24cf79c0d97cefe971bb35e873b386b49c40
|
File details
Details for the file denoise_audio-0.1.1-py3-none-any.whl.
File metadata
- Download URL: denoise_audio-0.1.1-py3-none-any.whl
- Upload date:
- Size: 18.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b1c735d8026fc366ee7bf47b4feb964836938d86369e901a400fd3056f65378c
|
|
| MD5 |
371923ee4519410eb4dc31c68e5e22ea
|
|
| BLAKE2b-256 |
82dca901069645d23b883ac209aec7556c33bdf53730e103b604582670bf6360
|