This invention relates to a method for operating a scheduler for an optical pick-up. The pick-up reads data streams from an optical storage medium, wherein the data streams belong to different data types like audio, video or subtitles, and are distributed to several files on the storage medium.
Pre-recorded or self-recorded optical discs may support “Out Of Multiplex” (OOM) formats. Out of multiplex is a format that stores different presentation components, e.g. video, audio and subtitles, on different locations on the disc, i.e. different files. This may be possible with various standardized media, e.g. Blu-ray disc. Also, a video technique known as multi-angle, or seamless angle change, may be implemented. It is well known from DVD-Video, and it means that a video film may contain multiple video tracks that are parallel on the time-line, wherein each video track usually shows the same scene from a different perspective. The user may select a perspective, e.g. by pressing a dedicated button. It is a requirement that switching between the different video tracks is performed with minimal delay, and that the tracks are integrated seamlessly into the video.
During playback of OOM formats, a number of the presentation components need to be decoded separately, and then presented synchronously and continuously, i.e. without noticeable interruption of the presentation. Therefore it is required that each of the decoders is provided with a continuous stream of data. On the other hand, optical drives are usually equipped only with a single pick-up unit, which is capable of reading only one data stream from the disc at a time, at a higher data rate than required by any of the decoders. That means that the pick-up has to jump from stream to stream in order to serve all decoders simultaneously. This requires buffering, i.e. the data that are read from the disc are fed into properly sized buffers, wherein each of the buffers is associated with a decoder. Buffering the coded data is more effective than buffering the decoded data. Thus, any decoder is provided with a continuous data stream.
Feeding the buffers requires a scheduling algorithm, because any buffer under-run must be prevented for a continuous presentation. The buffer sizes strongly depend on the applied scheduling scheme.
A pick-up usually contains an actuator carrying an optical sensor, and the pick-up is movable by a mechanical drive for raw adjustment, while the actuator is separately movable for fine adjustment without a mechanical drive. When the pick-up has to read multiple streams, this requires a much higher pick-up jump frequency than a single, multiplexed stream.
One problem arising from the fact that multiple files must be read simultaneously is the high pick-up jump frequency causing noise and wastage due to the mechanical drive. A further problem is the delay appearing during seamless video angle switches. The delay is the time needed from requesting the video angle change until seeing the other video angle. It is determined mainly by the video buffer size, or by the amount of time until the video buffer has run empty and the new content reaches the video decoder. The same applies to the start up of OOM decoding. The time passing by from pressing the start button until effectively starting the display is quite long, since all buffers must be filled from scratch.
A problem to be solved by the invention is to provide a scheduling method for controlling a pick-up such that a reduction of the pick-up jump frequency is achieved, while using a minimum of buffering space. This problem is solved by the method disclosed in claim 1.
Advantageously, a method for reducing the delay times required for angle switch can be included. This method is disclosed in claim 6.
Another problem to be solved by the invention is to reduce the delay times required at presentation start up. This problem is solved by the method disclosed in claim 8.
The inventive method leads to a lower pick-up jump frequency and thus achieves noise reduction and improved pick-up durability. According to the invention, this is achieved by employing an appropriately adapted scheduling raster, and by individually increasing the lower-rated buffers by a small amount of memory. The proposed scheduling raster is static, i.e. based on a fixed time constant, and thus independent from the actual buffer filling. Further, the method provides a technique for OOM decoding that reduces the switching time for seamless angle changes. For a HDTV stream, the typical application of Blu-ray disc, the buffers are quite large. The large buffers cause a long delay for the user waiting for a requested angle change to get visible, which delay can be reduced by the inventive method. The same problem arises for the start-up of OOM decoding. According to the invention, the problem of optimizing the start-up or video switch procedure for the proposed scheduling scheme can be solved by filling the buffers only partially, such that the buffer filling situation matches with an optimal position in the static scheduling scheme.
According to the invention, it is possible to interrupt the scheme by an angle change request, and return to the scheme after serving the request, when the normal scheme is such that for any three successively read data streams, wherein the second is the video data stream, the first or the third data stream is also the video data stream.
Advantageously, the invention can also be used to optimize the partitioning of a given amount of buffering space for the described application.
Advantageous embodiments of the invention are disclosed in the dependent claims, the following description and the figures.
Exemplary embodiments of the invention are described with reference to the accompanying drawings, which show in
In the following, a detailed description of the invention including a detailed analysis of the problem is given. Though the invention is suitable for any number of data streams, the typical application case of three streams is described here, namely video, audio and subtitle streams.
OOM decoding is mainly influenced by the following mutually dependent parameters:
The pick-up jump time is the maximum time required by the mechanical move of the pick-up to a new position, ending when data from the new stream reach the buffer. This time may depend on the data allocation on the medium. The order of the component streams is the order of their data rates, i.e. the first component stream has the highest data rate RV, the second stream the second highest data rate RA etc. Therefore, in the typical application mentioned above RV refers to the video stream, RA to the audio stream and RS to the subtitle stream. The buffer sizes BV,BA,BS do not encompass any decoder internal buffers, and thus are independent from e.g. any special decoder.
Further, a basic system time constant T and integer numbers n and k are introduced. According to the invention, the system time constant T is selected such that the buffer of the component with the highest data-rate, e.g. video, is being continuously emptied and refilled in periods of T, while all lower rated component buffers are emptied and refilled in periods of multiples of T.
In
Advantageously this schema can also handle components with variable data-rate, up to a maximum allowed data rate. Variable data-rate of a component simply causes a higher remaining buffer filling level than calculated, at the time the buffer is refilled, and therefore results in quicker filling. However, according to the invention this shall not influence the scheduling raster. Instead, it results in some additional pick-up idle time.
An important aspect of the invention is that each of the lower rated component buffers, i.e. audio and subtitles, is being refilled and emptied at its own time-constant, wherein the time-constant for the audio component is n*T, and the time-constant for the subtitle component is k*n*T. As defined above, T is the time required for a complete cycle of filling and emptying the buffer for the highest rated stream, and n and k are integer numbers. Therefore the inventive scheduler is static also with respect to accessing the lower rated streams, i.e. the lower rated streams are accessed in a constant predetermined order. In the example shown in
Another important aspect of the invention is the distinction between “one-service-periods” 1SP and “two-services-periods” 2SP. A “one-service-period” 1SP is defined as the time T between two successive peak fillings of the video buffer, wherein the pick-up performs only one service, namely reading video data. Contrary, a “two-services-period” 2SP is defined as the time T between two successive peak fillings of the video buffer, wherein the pick-up performs two services, namely reading video data and reading data from a lower rated stream. Therefore any “two-services-period” 2SP requires the pick-up to jump twice, while any “one-service-period” 1SP requires no pick-up jump, and therefore provides some pick-up idle time, thus giving flexibility, as required below. In general, the inventive schema does not force the video buffer to run empty during these periods, as exemplarily illustrated. E.g. the buffer could also be kept at a certain level until the next service period starts.
The resulting frequency of pick-up jumps, in the following called the “jump-frequency” is for a system with three streams defined as
It means that two pick-up jumps are required to the medium rated stream within a time of n·T, and two further pick-up jumps to the lowest rated stream within a time of n·k·T. The buffer sizes for all components and the system time constant can be calculated according to the following equations.
A general relation describing the filling or emptying of a buffer of size B is
R is the resulting filling or leakage rate, i.e. filling the buffer with a filling rate R takes a time of t, and emptying the buffer with a leakage rate R also takes the time t. If the empty buffer is filled and emptied simultaneously, with the difference between leakage rate and filling rate being R and the filling rate being higher, it also takes a time of t until the buffer is full.
Thus, the following equations describe the filling and reading processes for three individual components, as shown in
with n being in the range of [2,nmax] and k in the range of [1,kmax]. Further, the system time constant T obeys to
This allows calculating the required buffer sizes according to
and the system time constant according to
General assumptions for this scheduler are
nmin=2 (Eq. 6.1)
Kmin=1 (Eq. 6.2)
Since the denominator in eq. 5.4 must be positive, this means
As a result of the different leakage rates for audio and subtitle buffers follows
The resulting jump-frequency is
To achieve minimal buffering requirements for the scheme, n and k are chosen to their minimal values n=2 and k=1, for the case of three presentation components.
In one embodiment of the invention, preferably the parameter k may be increased (k=1 . . . kmax) in a first step. This results in a reduced pick-up jump frequency with requiring only little additional buffer size. In another embodiment of the invention the second step is to increase also the parameter n (n=1 . . . nmax) to reduce the frequency of pick-up jumps even further.
Advantageously, the invention allows minimizing the start-up delay of a presentation.
It is also possible that e.g. during presentation start-up one or more data streams must be read from the medium that are required only once, e.g. configuration data, and that can be processed at the data rate provided by the pick-up. Therefore, all described procedures refer only to those data streams that are continuously required for the presentation. That means that the described static schedule starts at presentation start-up time S*, and may be flexible before and after the presentation.
In one embodiment of the invention, the process of reading the lower rated streams at start-up is optimized such that the streams are read in the same, or reverse, order that they have on the medium, depending on and starting from the current pick-up position. This minimizes the number of pick-up jumps required during start-up.
As another advantage, in one embodiment the inventive method reduces delay times required for seamless angle changes. This can be achieved by delayed servicing, as shown in
The additional buffer space, and thus the additional cost, depends directly on the data rate. Therefore this embodiment of the invention comprises an increase of buffer space for the lower rated streams.
To finish the angle switch process according to the invention, the scheduler returns to the original scheduling raster. This may be achieved by interrupting the delayed service Sd for the audio buffer at a time Td,a when the filling of the audio buffer is the same as it would be if a regular service Sr had been performed before. Thus, the audio buffer may return to the original scheduling raster. Then the pick-up may jump to the video stream and fill the video buffer, until at a time Td,v the filling of the video buffer is the same as it would be if no angle change had been requested before. Thus, also the video buffer may return to the original scheduling raster.
In one embodiment of the invention introducing “service interruption” may further reduce angle switch delay, as shown in
As described above for a delayed service Sd, the scheduler returns to the original scheduling raster by filling the audio buffer not completely, but only up to the level that it would have if it had been served regularly. When this level is reached at a time Td,a′, the pick-up is moved back to the video stream, and the video buffer is flushed down to the lowest possible angle switch position, as described below. Then the pick-up fills the video buffer up to the level that it would have if no angle change had been requested. At that time Td,v′ the system has returned to the original scheduling raster, and may continue with it.
The described service interruption requires another additional buffer space for the lower rated stream buffers, because an additional time of 2-Tj must be bridged. Thus, the equations eq. 8.l and eq. 8.2 become
The lowest possible angle switch position is used for buffer flushing, as mentioned above. In OOM, video sequences may contain angle switch labels that mark positions, where a seamless angle change is possible. According to one embodiment of the invention, these angle switch labels are stored together with their associated video data. The scheduler may determine the lowest possible angle switch position by selecting the first angle switch label above a certain minimum buffer filling level Bv,min, also called bonding label. This level Bv,min can be calculated as the amount of data that is required to continue video presentation until the new video data arrive at the buffer, roughly after a time of Tj plus a decoding time that is usually negligible. Buffer flushing means that the video data beyond the bonding label are overwritten with the new video data.
In a further embodiment of the invention the angle switch delay may also be improved for the case that an angle switch is requested while the video buffer is being served, as shown in
ΔBV=RV(Tj+TGOP) (Eq. 10)
Generally it is assumed that any buffer mentioned in this disclosure may be replaced by a plurality of cooperating buffers. Further, it is possible that buffers for different data streams may be implemented in a single device.
Advantageously, the invention can be used for devices that construct multi-media or audio-visual (AV) representations from data read from a storage medium, e.g. an optical storage medium such as a DVD or Blu-ray disc, wherein a single pick-up reads multiple data streams.
More generally, the invention can be used for devices that construct any combined data representation from a plurality of data streams that are read from a single storage medium, e.g. optical storage medium, wherein the data streams are read by a single pick-up and the data streams have different data rates.
Number | Date | Country | Kind |
---|---|---|---|
03007610 | Apr 2003 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2004/002996 | 3/22/2004 | WO | 00 | 7/28/2006 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2004/088657 | 10/14/2004 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5543861 | Harradine et al. | Aug 1996 | A |
6295409 | Ikeda | Sep 2001 | B1 |
6463208 | Kim | Oct 2002 | B1 |
6463209 | Schultz et al. | Oct 2002 | B2 |
RE37994 | Fukuda et al. | Feb 2003 | E |
20030190153 | Itoh et al. | Oct 2003 | A1 |
20050013583 | Itoh | Jan 2005 | A1 |
20070274681 | Andolph et al. | Nov 2007 | A1 |
Number | Date | Country |
---|---|---|
0944269 | Sep 1999 | EP |
1011268 | Jun 2000 | EP |
1328118 | Jul 2003 | EP |
11-144378 | May 1999 | JP |
WO 0223896 | Mar 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20060262679 A1 | Nov 2006 | US |