You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When applying negative delay to audio sources in OBS, OBS will internally delay both video and audio mix buffers by the maximum negative delay amount, so that it has room to bring these components into sync with each other.
The video and audio monitoring in OBS does not show this delay, as it is applied post-compositing, pre-encoding.
Shaderfilter Plus accesses the mix buffers after this has been applied, so shader effects using FFT data generated from those mix tracks are delayed by the maximum negative offset. This results in a delay in the shader effect by that amount. As that shader effect is applied to video source in real-time, it is effectively delayed twice.
Thank you for the detailed explanation of the issue. To be frank, I had absolutely no idea you could even use negative delays, so it never occurred to me this would be a problem.
I looked into this, and it seems like a difficult problem to solve. I assume video encoding is done immediately, whereas audio is synced up after an appropriate delay, and then both are combined and recorded/streamed. Hence it would be impossible to influence the video rendering/composition using the data from the resulting audio mixes.
However, there might be a compromise to be made: The Waveform plugin for FFT visualization (https://github.com/phandasm/waveform) uses audio sources instead of resulting audio mixes to gather audio data from. At that point, the audio data is not yet synchronized. If one were to use an audio source with no sync offset (no negative or positive delay), the audio data would be accessible to shaders immediately, which is what we need. The obvious disadvantage is that this solution provides no audio mixing capabilities -- you could only choose one audio source. It would be possible to implement mixing, but it seems like reinventing the wheel. Waveform does not provide mixing either.
When applying negative delay to audio sources in OBS, OBS will internally delay both video and audio mix buffers by the maximum negative delay amount, so that it has room to bring these components into sync with each other.
The video and audio monitoring in OBS does not show this delay, as it is applied post-compositing, pre-encoding.
Shaderfilter Plus accesses the mix buffers after this has been applied, so shader effects using FFT data generated from those mix tracks are delayed by the maximum negative offset. This results in a delay in the shader effect by that amount. As that shader effect is applied to video source in real-time, it is effectively delayed twice.
Here is an example video showing the result of the effect being delayed.
Ideally Shaderfilter Plus accesses these buffers before this delay has been applied, so that effects are rendered in real-time and not delayed twice.
The text was updated successfully, but these errors were encountered: