gpt4 book ai didi

audio - FFMPEG混合滤波器的音量问题,输入持续时间不同

转载 作者:行者123 更新时间:2023-12-03 01:10:12 25 4
gpt4 key购买 nike

我注意到ffmpeg amix过滤器在特定情况下无法输出良好的结果。如果输入文件具有相同的持续时间,则效果很好。在这种情况下,音量会降低为恒定值,并可以使用",volume=2"进行固定。

就我而言,我使用的文件具有不同的持续时间。产生的音量不好。第一个混合流的体积最小,最后一个最大。您可以在图像上看到音量随时间线性增加。

enter image description here

我的命令:

ffmpeg -i temp_0.mp4 -i user_2123_10.mp4  -i user_2123_3.mp4  -i user_2123_4.mp4  
-i user_2123_7.mp4 -i user_2123_5.mp4 -i user_2123_1.mp4 -i user_2123_8.mp4
-i user_2123_0.mp4 -i user_2123_6.mp4 -i user_2123_9.mp4 -i user_2123_2.mp4
-i user_2123_11.mp4 -filter_complex "[1:a]adelay=34741.0[aud1];
[2:a]adelay=18241.0[aud2];[3:a]adelay=20602.0[aud3];
[4:a]adelay=27852.0[aud4];[5:a]adelay=22941.0[aud5];
[6:a]adelay=13142.0[aud6];[7:a]adelay=29810.0[aud7];
[8:a]adelay=12.0[aud8];[9:a]adelay=25692.0[aud9];
[10:a]adelay=32143.002[aud10];[11:a]adelay=16101.0[aud11];
[12:a]adelay=40848.0[aud12];
[0:a][aud1][aud2][aud3][aud4][aud5][aud6][aud7]
[aud8][aud9][aud10][aud11]
[aud12]amix=inputs=13:duration=first:dropout_transition=0"
-vcodec copy -y temp_1.mp4

可以通过在每个剪辑的开头和结尾处应用静音来解决此问题,然后它们将具有相同的持续时间,并且音量将处于相同的水平。

请提出如何使用 amix混合许多输入并确保音量恒定的建议。

最佳答案

amix通过1/n缩放每个输入的音量,其中n =否。有效输入。对每个音频帧进行评估。因此,当输入丢失时,其余输入的音量将按较小的比例缩放,因此它们的音量会增加。

正如其他答案中所建议的那样,更改所有早期输入的dropout_transition是一种方法,但是我认为这将导致音量的粗调。更好的方法是将混合后的音频标准化。

目前,您有两种选择,loudnormdynaudnorm过滤器。后者快得多

语法是在混合后添加它,所以

[aud11][aud12]amix=inputs=13:duration=first:dropout_transition=0,dynaudnorm"

如果您想调整参数以获得最大音量或RMS模式归一化,请阅读文档。

关于audio - FFMPEG混合滤波器的音量问题,输入持续时间不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63831385/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com