Compare commits

...

2 Commits

Author SHA1 Message Date
d3fault
bcf3d7b203
Merge 5831f6feef into 0153b387e5 2024-06-14 13:46:28 +00:00
d3fault
5831f6feef [postproc/ffmpeg] fix opus using default quality of 5 as bitrate (closes #28389)
Fix #28389. When extracting audio, and the containing format isn't 'opus',
but the requested format is, then youtube-dl will call ffmpeg to do the conversion.
Without specifying the preferred quality, youtube-dl defaults to '5'.
Integers 0-9 are currently sent to ffmpeg as the bitrate for 'opus',
which is clearly an error and this commit fixes that. It uses an arbitrary
(specific to opus) scale to convert 0-9 into reasonable bitrates between
6 kb/s to 210 kb/s.... with 5 (the default) giving 96 kb/s
2022-05-29 00:26:26 -07:00

View File

@ -22,6 +22,7 @@ from ..utils import (
dfxp2srt,
ISO639Utils,
replace_extension,
compat_str,
)
@ -300,9 +301,16 @@ class FFmpegExtractAudioPP(FFmpegPostProcessor):
extension = self._preferredcodec
more_opts = []
if self._preferredquality is not None:
# The opus codec doesn't support the -aq option
if int(self._preferredquality) < 10 and extension != 'opus':
more_opts += ['-q:a', self._preferredquality]
if int(self._preferredquality) < 10:
if extension == 'opus':
# The opus codec doesn't support the -q:a option
# Magic number of 24 used to give quality numbers 0-9 *some* meaning (as suggested by "knarrff" on Github)
# 0 (best quality) gives 210 kb/s
# 5 (default) gives 96 kb/s
# 9 (worst quality) gives 6 kb/s, which is the opus minimum (and 0 kb/s wouldn't make any sense)
more_opts += ['-b:a', compat_str(max(6, int((9 - int(self._preferredquality)) * 24))) + 'k']
else:
more_opts += ['-q:a', self._preferredquality]
else:
more_opts += ['-b:a', self._preferredquality + 'k']
if self._preferredcodec == 'aac':