Audio processing nodes for comfyui.
This repo contains signal processing nodes for ComfyUI allowing for audio manipulation.
LICENSE-GPL-V3
The source code in this repository is licensed under "GNU General Public License Version 3".LICENSE-APACHE-2
Some components are built from parts of code licensed under "Apache License Version 2".LICENSE-CCA-ANY
Some components are built from parts of code licensed under "Creative Commons Zero v1.0 Universal"Gpu limiter - experimental
- Limiter optimized for parallel GPU executionSaturatation - experimental
- Added basic saturation node with couple algorithmsTests suite
- Added basic tests suite for most of the nodesThe Baxandall EQ is a smooth, wide-band tone control circuit widely used in audio systems, offering gentle boost or cut for bass and treble frequencies. Its simple design and musical response make it ideal for achieving natural tonal adjustments. Implementation is using the standard shelf filter equations from the Audio EQ Cookbook by Robert Bristow-Johnson
audio
self explanatory...bass_gain_db
Bass gain in decibelsmid_gain_db
Mid gain in decibelstreble_gain_db
Treble gain in decibelslow_freq
: The corner frequency for the low shelf (e.g. ~100 Hz).mid_freq
: The center frequency for the mid peaking filter (e.g. ~1 kHz).high_freq
: The corner frequency for the high shelf (e.g. ~10 kHz).mid_q
: Quality factor for the mid peaking band. Adjusting Q controls the bandwidth of the mid peak. A typical Q might be 0.7 for a broad bell.Harmonic enhancer boosts selected harmonics to enrich the sound.
harmonincs
comma separated numbers of harmonics to boostmode
whether to automatically detect base frequency based on an audio or use manual settingbase_frequency
base frequency to use in manual modegain_db
How much to boost harmonicsgain_db
Width of the filtersNormalizer is an amalgamate of multiple normalization approaches, including Loudness Units Full Scale (LUFS) with standard default set to -14db.
audio_input
: audio inputmode
: "lufs","rms","peak","auto"target_rms
: The desired RMS value for the audio signal. Default is 0.1, which corresponds to a moderate average signal level.target_lufs_db
: The desired loudness level in LUFS. Default is -14.0, which is a common loudness target for streaming platforms like Spotify.target_peak
: The desired peak amplitude for the audio signal. Default is 0.9, meaning the loudest sample will be scaled to 90% of the maximum possible amplitude.target_auto
: The desired amplitude level for the audio signal. The algorithm scales the audio to match this level. Default is 0.7 (normalized scale from 0 to 1).target_auto_alpha
: The smoothing factor for the gain adjustment. A smaller value of alpha makes the gain adjustment slower and smoother (avoiding sudden jumps). A larger value makes the gain adjustment faster but potentially introduces abrupt changes.The get_loudness function calculates the integrated loudness of an audio signal in LUFS (Loudness Units relative to Full Scale). This is a perceptual measure of loudness, taking into account the human ear's sensitivity to different frequencies and the entire audio signal's duration.
Open Source Stere Widening Plugin. The implementation is a direct copy of parts of the source code corresponding to this paper developed by Orchisama Das. The code is distributed under **CC0 1.0 Universal**
license.
Original Source Code
audio
: input audiomode
: "decorrelation" and "simple" - "decorrelation" is based on "Open Source Stere Widening Plugin" as described abovegain
: post width gainwidth
: width of the stereo effectConvolution reverb simulates realistic acoustic spaces by applying the impulse response of a physical environment to an audio signal. It captures the natural reverberation characteristics, providing authentic spatial depth and ambience.
I recommend downloading impulse response files from this location Voxengo-IR and Greg Hopkins EMT 140 Plate Reverb Impulse Response. They sound absolutely fantastic and have great licensing. In order for the files to show up for selection in the convolution reverb please download the files and organize them like this :
comfyui_signalprocessing/audio/ir/Voxengo/
<- copy wave files into this directorycomfyui_signalprocessing/audio/ir/EMT-140-Plate/
<- copy wav files into this directoryimpulse_response
: impulse response file selectedaudio_input
: audio to apply reverb towet_dry
: mix amount of the effectPaulStretch excels at extreme time-stretching with high-quality results, preserving the pitch and tonal characteristics of the original audio.
This node contains a port of algorithm developed by Nasca Octavian Paul.
Original Source Code
audio
The input audio signal to be stretched
stretch_factor
Determines the amount of stretching applied to the audio.
Range: 0
(no stretch) to 100
(maximum stretch).
Example: A stretch_factor = 10
stretches the audio to 10 times its original length.
window_size_seconds
Specifies the window length for the stretching algorithm, in seconds. Larger values produce smoother and more ambient results by averaging the time-domain samples over a longer period.
Example: window_size_seconds = 1.0
provides smooth stretching for most applications, while smaller values retain more transient detail.
This node is a synthesiser "PadSynth" based on a PADSynth algorithm This node contains a port of algorithm developed by Nasca Octavian Paul Original Source Code
samplerate
: sampleratefundamental_freq
: fundamental frequency for the sounds generationbandwidth_cents
: bandwidth centersnumber_harmonics
: number of harmonicsamplitude_per_harmonic
: amplitude per harmonic as a json, takes as list of amplitudes [0,1,4,...], it's count must match number of harmonicsaudios
: audio output one channel per note - use "SignalProcessingMixdown" node after to get single audio with monot channel copies to L and RThis node is a synthesiser "PadSynth" emulating choirs Original Source Code
samplerate
: sampleratebase_freq
: base frequencystep_size
: step sizenum_notes
: number of notesbandwidth_cents
: bandwidth centsnumber_harmonics
: number of harmonics to produceClassic filters
audio
: input audiocutoff
: filter cutofffilter_type
: filter type - "lowpass", "highpass", "bandpass", "bandstop"q_factor
: width of the filtermixdown outputs from PadSynths with volume control per note
audios
: audios inputaudio
: audio outputThis section contains nodes enabling basic analysis and development of other nodes
Renders Mel Spectrum Into An Image
audio
: audio inputimage
: image outputRenders Wave Shape Into An Image
audio
: audio inputimage
: image outputThis node lets you stretch audio to about 100x it's original speed whil mainting pitch. it's great for making pad sounds:
audio_file
: input audio filegain
: when to start audio fromThe development dependencies are specified in the pyproject.toml file and are not included in the requirements.txt. To run tests and contribute to development, you'll need the following tools and modules installed. My primary development and testing environment is Ubuntu Linux with an RTX 3090 GPU and CUDA 11.8.
-scalene
: High-performance CPU and GPU profiler.
-pytest
: Comprehensive testing framework.
-nox
: Automation tool for managing tasks.
-ruff/flake8
: Linter for ensuring clean and consistent code.
Contributions are always welcome! Feel free to fork the repository, make changes, and create a pull request. I'm open to collaboration and willing to make adjustments to improve the project. Let's build something great together! 🚀