[FFmpeg-devel] Seeking in Apple HTTP Live Streaming

Michael Niedermayer michaelni at gmx.at
Tue Nov 22 00:40:07 CET 2011


On Mon, Nov 21, 2011 at 03:01:43PM -0800, Takis Issaris wrote:
> Hi Michael,
> 
> 
> ----- Original Message -----
> > From: Michael Niedermayer <michaelni at gmx.at>
> > To: FFmpeg development discussions and patches <ffmpeg-devel at ffmpeg.org>
> > Cc: 
> > Sent: Monday, November 21, 2011 8:34 PM
> > Subject: Re: [FFmpeg-devel] Seeking in Apple HTTP Live Streaming
> > 
> > On Mon, Nov 21, 2011 at 08:21:28AM -0800, Takis Issaris wrote:
> >>  Hi all,
> >> 
> >> 
> >>  As a follow-up to my previous patch, I'd like to implement more exact 
> > seeking on HTTP Live Streams. Currently, when seeking to a specific timestamp in 
> > such a stream, the seeking results in arriving at the start of the correct 
> > segment, but not at the requested timestamp within that segment. Worse, when 
> > seeking to a specific timestamp which happens to be a part of the segment which 
> > is currently being played, the playback resets to the start of the current 
> > timestamp (that could most likely be fixed rather easily). So, when pressing 
> > forward arrow key when using ffplay, you'll actually move backwards to the 
> > start of the segment (if current timestamp+10s lies within the current segment).
> >> 
> >> 
> >>  I'd like to change that so that the applehttp.c seeking implementation 
> > uses mpegts.c to actually seek to the specified timestamp, but I'm not sure 
> > on how to implement this.
> >>  Currently, when seeking using applehttp_read_seek, I think there's no 
> > valid MPEG-TS demuxer context in that function. Should I make sure I get a valid 
> > demuxer there, or should I defer the actual seeking using the MPEG-TS demuxer 
> > until a valid demuxer is constructed elsewhere in the applehttp.c file?
> > 
> > I assume theres no way to tell the server to start a segment from a
> > specific time? (i havnt found one)
> 
> No, I don't think so (haven't found one either).
> 
> 
> > Do the servers support seeking to a specific byte position within a
> > segment ?
> 
> Yes, it's just an Apache HTTP server, so it supports GET with a byte range (If that
> was what you were hinting at).
> 
> 
> > If yes, seeking per CBR assumption is an option which also doesnt need
> > the demuxer
> 
> Yes, initially I'd never even considered CBR. But as I start to think about it,
> the seeking speedup could counterweight the quality/bitrate disadvantage.
> 
> 
> > The reason why i suggect to assume CBR is that the alternative is
> > the default seek per timestamp which does a binary search and this
> > could be quite slow with http needing to send a few packets back and
> > forth for each iteration of the search
> 
> 
> Yes, but the draft recommends using 10 second segments, so I'd hoped that
> the actual number of HTTP GETs needed would be rather limited.
> 
>  
> > depending on network speed, bitrate and segment size a linear search
> > could also be considered, that is demux and throw away packets until
> > the right time, this may or may not be faster than a binary search
> 
> Yes, I'd thought about doing something like that as the applehttp.c seek 
> already skips to the correct 10s segment, so a linear search within that should
> not take that long.
> 
> Would something like that be useful in applehttp.c or should it be kept in application
> specific code?

requireing applehttp specific code in every app does not seem a good
idea to me thus IMHO its better in applehttp.c

[...]
-- 
Michael     GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB

Complexity theory is the science of finding the exact solution to an
approximation. Benchmarking OTOH is finding an approximation of the exact
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: Digital signature
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20111122/e2df6c37/attachment.asc>


More information about the ffmpeg-devel mailing list