<html>
<head>
<base href="https://bugs.freedesktop.org/">
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW - Clipping with per-stream volume above 100% even though device volume below 100%"
href="https://bugs.freedesktop.org/show_bug.cgi?id=97777">97777</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>Clipping with per-stream volume above 100% even though device volume below 100%
</td>
</tr>
<tr>
<th>Product</th>
<td>PulseAudio
</td>
</tr>
<tr>
<th>Version</th>
<td>unspecified
</td>
</tr>
<tr>
<th>Hardware</th>
<td>x86-64 (AMD64)
</td>
</tr>
<tr>
<th>OS</th>
<td>Linux (All)
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>normal
</td>
</tr>
<tr>
<th>Priority</th>
<td>medium
</td>
</tr>
<tr>
<th>Component</th>
<td>daemon
</td>
</tr>
<tr>
<th>Assignee</th>
<td>pulseaudio-bugs@lists.freedesktop.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>bugs.freedesktop@haasn.xyz
</td>
</tr>
<tr>
<th>QA Contact</th>
<td>pulseaudio-bugs@lists.freedesktop.org
</td>
</tr>
<tr>
<th>CC</th>
<td>lennart@poettering.net
</td>
</tr></table>
<p>
<div>
<pre>I am doing the following:
1. Set my device volume to about 70% (approx. -10 dB gain)
2. Play a sine wave at -0 dBFS using a simple test client:
λ import Sound.Pulse.Simple
λ p <- simpleNew Nothing "pulse-simple" Play Nothing "testing" (SampleSpec (F32
LittleEndian) 48000 2) Nothing Nothing
λ simpleWrite p [ 1.0 * sin (w*x) | x <- [0..48000*5], let w = 0.01 :: Float ]
λ ...
λ simpleFree p
3. Change the per-stream volume for this stream (“pulse-simple” in pavucontrol)
Any value below 100% is fine, but as soon as I go above 100% even by a little
bit (e.g. 101%), I immediately hear obvious clipping artifacts.
4. Set the per-stream volume to 100%, and change the amplitude of the sine wave
produced instead (e.g. changing 1.0 to 1.1). I again hear obvious clipping
artifacts (even though the signal format is floating point).
Why is this the case? Shouldn't the overall volume of 70% give me more than
enough headroom to go above 100% on the per-stream volume? The only explanation
I can come up with is that the conversion to integer happens before the device
volume adjustment, e.g. perhaps if the device volume is being applied by ALSA
instead of by PulseAudio (since it does seem that changes to the device volume
are also visible in alsamixer).
If this is indeed the case and this is a limitation of the way device volumes
are implemented, would it be possible to apply some sort of global “gain”
setting to all sinks instead? I want to give them all 10 dB or so of mixing
headroom so I can use software volume controls to go above 100% without
clipping.
Obviously I can achieve this by setting up some sort of LADPSA filter or
whatever in the signal path of every single stream, but that seems like a
hassle to set up properly (especially since I'm using multiple audio devices).
If it would be possible to just add a simple “mixing headroom” variable to
daemon.conf that I can set to get headroom for free, I would be a very happy
man.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the QA Contact for the bug.</li>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>