-
Notifications
You must be signed in to change notification settings - Fork 261
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Option to normalize volume in command line with -F
option
#1407
Comments
|
Well, can't it render to memory, normalize the audio and only then fire up the file driver? And also, the suggestion you've referenced is dynamic compression. I don't want that, I just want automatic gain adjustment for the entire song. |
How? Chunks are rendered with 64 samples. Amplifying every 64 samples surely wouldn't sound right.
If that's what you want, it's a simple postprocessing amplification step, which I don't really see in scope of fluidsynth. |
Wouldn't that just be this?
That's it, isn't it? Or am I missing something? |
I don't think you understand why this should be in fluidsynth. The processing needs to be done before writing out a wave file. Since fluid renders using float, we lose information when converting to short. This is especially the case with low gain levels: the dynamic range may span as little as 1/5th of the full -1 to 1 range. This results in wav's dynamic range being around -6k to 6k which is way less that the stock 32k range. Amplifying the output before writing a file will use the full dynamic range. Applying the postprocessing after the render will stretch out the limited 6k dynamic range. I hope this wall of text made at least some sense of my idea to you... |
This issue and the solution are not about adjusting the sound in real time. for example:
Sounds output this way do not lose relative dynamic range and do not seem to clip even above 0dbFS. Thanks. |
You're making two assumptions here:
Because of this, I consider your request to be not feasible and out of scope for fluidsynth. As stardusteyes said, you're free to produce a wav or raw file containing floats (or doubles) and adjust the amplitude afterward without worrying to lose dynamic range. |
Is your feature request related to a problem?
Currently, the only way to prevent clipping during fast rendering (via
-F
) is to reduce the gain value until it stops clipping, which is not ideal. It would be nice to have fluidsynth do that for you.Describe the solution you'd like
Here's my idea:
Since fluidsynth renders in float internally,
even if the gain is above 1, it's still preserved in the memory.
Adding an option for normalizing volume ( could be
-N
for example) would:That way, for example on a MIDI that's too loud:
Another example, on a very quiet MIDI. For example exporting any midi fron onlinesequencer.net will be just that because it forces all notes to have a velocity of 64:
Advantages
-o synth.gain
anymore or run the output through AudacityDescribe alternatives you've considered
This could also be a function within the libfluidsynth, but not sure about that one.
Additional context
My implementation
What do you think?
The text was updated successfully, but these errors were encountered: