[vlc-devel] Re: Transcode stereo stream to mono AMR
Jean-Paul Saman
jean-paul.saman at planet.nl
Tue Feb 27 09:12:24 CET 2007
Herman Meerlo wrote:
> Herman Meerlo wrote:
>> Hi,
>>
>> I am trying to transcode a public stereo stream to mobile format using
>> the AMR audio codec (and H.263 for video). This gives no problem if
>> the input source is mono because AMR is mono as well. But when the
>> input source is stereo (or more) then the transcode fails.
>> The problem has been around for a long time and I was wondering
>> whether there is a workaround for this? Can someone maybe explain what
>> is going wrong so I can try to make a patch mysel. I would think that
>> it can not be very hard to transcode the input to mono. Or am I
>> missing something?
> Because nobody seems to be able to help, I dove into the code myself. I
> have read lots of the code and had many debug session to try to
> understand how VLC internally works. I do not pretend to know the
> internals now because that is impossible for such a complex project. But
> my analysis had led me to believe there is a fundamental design problem
> with running audio_filters while transcoding a stream (please correct me
> if I am wrong!).
> I ran into this problem while trying to use the mono plugin to change
> the number of channels from 2 to 1 for the AMR codec. The problem lies
> in the fact that the plugin requires knowledge on the physical channels
> (i_physical_channels) during initialization of the plugin. But the
> filter is initialized before any input sample has been decoded.
> Therefore the channel configuration is not known yet. This causes the
> mono filter to think that there are 0 channels, which will cause it to
> divide by 0 => FPE (mono.c line 495)
> So while transcoding a stream the entire chain is setup before anything
> is known about the channel configurations which makes it impossible to
> apply any audio filter. It will probably only work if the output of the
> decoder and the input of the encoder have the same number of channels.
>
> Can anyone comment on this?
>
That is a correct observation. Mind the mono stream out audio filter can
only output DUAL mono (2 channels) to ffmpeg. The mono audio is send
over 2 channels left and right.
Gtz,
Jean-Paul Saman.
--
This is the vlc-devel mailing-list, see http://www.videolan.org/vlc/
To unsubscribe, please read http://developers.videolan.org/lists.html
More information about the vlc-devel
mailing list