Skip to content

Commit

Permalink
Allow disabling normalize.
Browse files Browse the repository at this point in the history
Refs #4305.
  • Loading branch information
smimram committed Jan 8, 2025
1 parent cde4dad commit 638ffe9
Showing 1 changed file with 20 additions and 12 deletions.
32 changes: 20 additions & 12 deletions src/libs/audio.liq
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ lufs_builtin = lufs
# @param ~target Desired RMS (dB).
# @param ~threshold Minimal RMS for activaing gain control (dB).
# @param ~window Duration of the window used to compute the current RMS power (second).
# @param ~enabled Whether normalization is enabled or not.
# @param ~debug How often to print debug messages, in seconds, useful to finetune the parameters. You should set `set("log.level", 5)` to see them.
# @param s Source to normalize.
# @method gain Current amplification coefficient (in linear scale).
Expand All @@ -114,6 +115,7 @@ def replaces normalize(
~window=getter(.5),
~threshold=getter(-40.),
~track_sensitive=true,
~enabled=getter(true),
~debug=null(),
s
) =
Expand All @@ -134,23 +136,29 @@ def replaces normalize(
gain_max = lin_of_dB(gain_max)

def update() =
target = lin_of_dB(getter.get(target))
threshold = lin_of_dB(getter.get(threshold))
rms = rms()
if
rms >= threshold
not (getter.get(enabled))
then
v := 1.
else
target = lin_of_dB(getter.get(target))
threshold = lin_of_dB(getter.get(threshold))
rms = rms()
if
v() * rms <= target
rms >= threshold
then
up = 1. - exp(0. - frame / getter.get(up))
v := v() + up * ((target / rms) - v())
else
down = 1. - exp(0. - frame / getter.get(down))
v := v() + down * ((target / rms) - v())
if
v() * rms <= target
then
up = 1. - exp(0. - frame / getter.get(up))
v := v() + up * ((target / rms) - v())
else
down = 1. - exp(0. - frame / getter.get(down))
v := v() + down * ((target / rms) - v())
end

v := max(gain_min, min(gain_max, v()))
end

v := max(gain_min, min(gain_max, v()))
end
end

Expand Down

0 comments on commit 638ffe9

Please sign in to comment.