[Ffmpeg-devel] Audio bitrate
Michael Niedermayer
michaelni
Mon Nov 6 17:52:50 CET 2006
Hi
On Mon, Nov 06, 2006 at 05:28:24PM +0100, Michel Bardiaux wrote:
> Michael Niedermayer wrote:
> >Hi
> >
> >On Mon, Nov 06, 2006 at 04:49:46PM +0100, Michel Bardiaux wrote:
> >>Seems wrong in some cases:
> >>
> >>ffmpeg -i utc_1434.mpg -vn -acodec adpcm_ms -y -ar 8000 msadpcm.wav
> >>FFmpeg version SVN-r6917, Copyright (c) 2000-2006 Fabrice Bellard, et al.
> >> configuration:
> >> libavutil version: 49.0.2
> >> libavcodec version: 51.24.0
> >> libavformat version: 51.6.0
> >> built on Nov 6 2006 16:13:12, gcc: 3.3.5 (Debian 1:3.3.5-13)
> >>Input #0, mpeg, from 'utc_1434.mpg':
> >> Duration: 00:00:57.0, start: 92564.370489, bitrate: 668 kb/s
> >> Stream #0.0[0x1e0]: Video: mpeg1video, yuv420p, 352x288, 104857 kb/s,
> >>25.00 fps(r)
> >> Stream #0.1[0x1c0]: Audio: mp2, 48000 Hz, mono, 32 kb/s
> >>Output #0, wav, to 'msadpcm.wav':
> >> Stream #0.0: Audio: adpcm_ms, 8000 Hz, mono, 64 kb/s
> >>Stream mapping:
> >> Stream #0.1 -> #0.0
> >>Press [q] to stop encoding
> >>size= 235kB time=59.8 bitrate= 32.2kbits/s
> >>video:0kB audio:235kB global headers:0kB muxing overhead 0.018285%
> >>
> >>Should be 32kbits in the 0.0 line.
> >>
> >>With pcm_s16le, the bitrate is correct. But I dont see at once where it
> >>is set. "Use the source, Luke", all right, but if somebody just *knows*...
> >
> >ffmpeg.c audio_bit_rate default i guess
> >changing that of course wont help ...
>
> No. And after a bit of grepping, it appears that the only reason the
> message is right when pcm is used, is because avcodec_string
> deliberately ignores bitrate in the codec and recomputes. So, even
> though the output is right, the internal state is *not*. Which is rotten
> for those using the libs instead of the command line.
>
> >
> >you could try to set AVCodecContext.bitrate in adpcm.c to the correct value
> >but iam not sure if this is free of sideeffects
>
> IMHO the init method of a codec with a fixed bitrate, should force the
> correct value. Unfortunately, the init method is called LONG after
> avcodec_string is used. Maybe we need to add a method for codecs; one
> that should be called to change desired bitrate, framerate, number of
> channels, or to retrieve bitrate.
add a list to AVCodec similar to supported_framerates
[...]
--
Michael GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB
In the past you could go to a library and read, borrow or copy any book
Today you'd get arrested for mere telling someone where the library is
More information about the ffmpeg-devel
mailing list