This application claims the benefit under 35 U.S.C. § 365 of International Application PCT/EP99/06377, filed Aug. 30, 1999, which was published in accordance with PCT Article 21(2) on Mar. 16, 2000 in English, and which claims the benefit of EPO Application No. 98250315.3, filed Sep. 7, 1998, EPO Application No. 98250387.2, filed Nov. 4, 1998, EPO Application No. 99250179.1, filed Jun. 8, 1999 and EPO Application 99250214.6, filed Jul. 1, 1999.
The invention relates to a method and to an apparatus for addressing a bitstream to be recorded or being recorded on a storage medium, e.g. an optical disc.
In bitstream recording one is free to subdivide the bit-stream into sub-units of more regular structure. Presentation data in DVDs (digital video or versatile disc) is organised into units called Video Object Unit, denoted VOBU, or Stream Object Unit, denoted SOBU, e.g. in the DVD VR Specification for DVD Video Recording in which the units are called VOBUs. VOBUs have a variable size (data amount measured in number of sectors), but have also a variable duration (measured in number of video fields). SOBUs have a constant size, but have also a variable duration.
For data retrieval from the disc the DVD VR specification foresees a ‘VOBU map’ which is a table where for every VOBU a recording the length in sectors and the duration in fields is entered. EP-A-O 729 153 discloses a table that is used for trick play mode, in which table a time code is assigned to each sector on an optical disc suited for variable transfer rate.
A table for data retrieval from a storage medium can be based on bitstream data being subdivided into pieces of constant duration. ‘Duration’ means the difference between the arrival time of the first packet of a piece and the arrival time of the packet following immediately the last packet of that piece.
‘Housekeeping’ in the general context of either DVD VR recording or Stream recording is the task to translate a given time value (presentation time in case of DVD VR recording or packet arrival time in case of Stream recording) into a disc address value where the desired data can be found.
In such systems the VOBU or SOBU map or ‘mapping list’, denoted MAPL, can contain a specific size or a specific offset or a specific delta size or, in general, a specific address-like quantity for each of these constant-duration pieces. By storing delta values instead of the total duration at a current VOBU or SOBU these entries can be described with shorter word length which helps to keep the total MAPL in a reasonable size.
A possible type of housekeeping process for these systems could include the following steps:
The big disadvantage of such type of MAPL which is based on constant-duration pieces lies in the following:
Therefore housekeeping based on constant-duration pieces can result in a too big MAPL in some cases (up to one half of the disc capacity), and can result in too coarse addressing in other cases.
It is one object of the invention to disclose a method for assigning to a given time value a storage medium address value which method avoids such disadvantages. This object is achieved by the method disclosed in claim 1.
According to the invention the mapping list MAPL is based on pieces of constant length or size, i.e. a constant number of bits per piece.
In a medium like DVD-RAM where data are physically organised into ‘ECC blocks’ (ECC: error correction code) of 32 kByte length each, particular advantages result if the above constant size or a multiple of it is used as the constant size of a piece. However, any other constant size can be used. In this case of pieces of constant size the MAPL contains for each of these pieces of constant size a specific absolute duration or, preferably, a specific delta duration which indicates the arrival time of the first packet of a piece and the arrival time of the packet following immediately the last packet of that piece.
The housekeeping process, i.e. the computation of the target VOBU or SOBU address includes the following steps:
The advantages of the inventive constant-size based MAPL are:
Advantageously, the address table contains an additional initialising value to initialise the accumulation of the delta time durations.
In principle, the inventive method is suited for addressing a bitstream to be recorded or being recorded on a storage medium, e.g. a DVD recorder, wherein an address table is used that is based on pieces of said bitstream, and wherein:
Advantageous additional embodiments of the inventive method are disclosed in the respective dependent claims.
Embodiments of the invention are described with reference to the accompanying drawings, which show in:
The DVD VR stream recording system is designed to use rewritable DVD discs for recording existing digital bitstreams, editing them and playing them back as bitstreams.
The following abbreviations are used:
AP: Application Packet, APAT: Application Packet Arrival Time, ATS: Application Timestamp, IAPAT: Incremental APAT (delta values with 12 bit resolution), LB: Logical Block, LSBs: least significant bits, MAPL: Mapping List, MSBs: most significant bits, MTU_SHFT: Mapping Time Unit Shift (an unsigned integer value, e.g. 18), PAT: Packet Arrival Time, RBN: relative byte number, RBP: relative byte position, RLBN: relative logical block number, SCR: system clock reference, SOB: Stream Object, SOBU: Stream Object Unit, SOB_E_APAT: APAT of the last AP of the SOB, SOB_S_APAT: APAT of the first AP of the SOB, SOBU_S_APAT: APAT of the first AP of the SOBU, STB: set top box, SUM_IAPAT=Summation of IAPAT values, TOC: table of content.
This system is designed to satisfy the following requirements:
A timing mechanism, i.e. a time stamp is added to every broadcast packet to enable proper packet delivery during playback.
To enlarge the fields of applications, non-real-time recording should be possible. However, in this case the STB has to generate the Time Stamp information.
Data allocation strategy and file support real-time stream recording.
Many digital services require Service Information which normally is embedded in the real-time stream. To support a STB fed by data from a DVD player, the DVD should provide additional space, which can be used by the STB to duplicate part of the service information and to add additional TOC information.
Copy Protection must be supported. In addition, any scrambling performed by the service provider or the STB must be kept unchanged.
User requirements can be grouped into requirements for recording, requirements for playback, and requirements for editing:
Real-Time Recording
The system should be designed to enable real-time recording of digital streams. It also should allow the user to concatenate recordings, even if those recordings consist of different stream formats. If recordings are concatenated, a seamless or close to seamless playback possibility would be nice but is not required.
Navigation Support
To support navigation two pieces of information (lists) should be generated during recording:
1) An ‘original’ version of a play list. This list contains quite low level information, e.g. time map or (broadcast) packet order of the recording. This list is accessible by the STB and the content is understood by the DVD streamer as well as by the STB. In its original version the playlist enables the playback of a complete recording. The playlist may be accessed and extended after recording by the STB to allow more sophisticated playback sequences.
2) The second piece of information, a mapping list, is generated to support the stream recorder to retrieve packet stream chunks (cells), that are described in terms of the application domain, e.g. ‘broadcast packets’ or ‘time’. This list is owned and understood by the DVD streamer only.
Content Description
The system should reserve space which can be used by the STB to store high level TOC and Service Information. This information is provided for the user to navigate through the content stored on disc and may contain sophisticated GUI information. The content needs not to be understood by the stream recorder. However a common subset of the TOC information, e.g. based on a character string, may be useful to be shared between STB and DVD, in order to enable the stream recorder to provide a basic menu by itself.
Playback of individual recording and playing all recordings sequentially should be possible via play list.
Player Menus for Entry Point Selection
The STB can generate a sophisticated menu based on the TOC information stored on the disc. However, it should be possible to generate a simple menu by the streamer itself, e.g. via some ‘character’ information which is shared by STB and DVD.
Trick Play Modes
The STB should be able to steer trick play via the ‘play list’. Due to the nature of the broadcast stream, the trick play features may be limited to basic ones, e.g. Time Search and Title Jump.
User defined playback sequence features like programming or parental control can be supported via the play list
The DVD streamer should create the ‘original version’ of the play list. It also should allow extensions and modifications of the play list by the STB for more sophisticated playback features. The DVD streamer is not responsible for the content of those sophisticated playlist(s).
The system must support the deletion of single recordings on user's request. If possible, the system should allow this feature under the control of the STB. The system may support insert editing.
In the simplified overall system of
Concerning the directory and file structure, the organisation of Stream Data and Navigation Data of DVD Stream Recording is done in a specific way such as to take into account the following:
Note that except for the files described above, the STRREC directory shall not contain any other files or directories.
Concerning the navigation data structure, Navigation data is provided to control the recording, playing back, and editing of any bitstreams that are recorded. As shown in
In addition to these, DVD Stream Recording also foresees the possibility of reserving a storage location for Application Private Data APD_MG, which may in general also be considered as Navigation Data.
STR_VMGI and SFI are the Navigation Data which are directly relevant for the Streamer operation. STR_VMGI includes two kinds of information tables, namely Video Manager Information Management Table (VMGI_MAT) and Play List Search Pointer Table (PL_SRPT), in this order. SFI includes three kinds of information tables, namely Stream File General Information (SF_GI), SOBI Search Pointers #n (SOBI_SRP#n) and all Stream Object Information #n (SOBI#n), in this order. There is no restriction in Stream Recording that each table within Navigation Information must be aligned with a sector boundary.
VMGI_MAT includes information items like end address of Streamer Information (STRI), end address of STR_VMGI, start address of Stream File Information Table (SFIT), start address of Original Program Chain Information (ORG_PGCI) and start address of User Defined Program Chain Information Table (UD_PGCIT).
PL_SRPT includes information items like Number of Playlist Search Pointers, end address of PL_SRPT, Program Chain numbers of Playlist Information, Playlist Create Time and Primary Text Information.
Stream Object Information General Information (SOBI_GI) includes information items like SOB Type (SOB_TY), SOB Recording Time (SOB_REC_TM), SOB Stream Information Number (SOB_STI_N), Access Unit Data Flags (AUD_FLAGS), SOB Start APAT (SOB_S_APAT), SOB End APAT (SOB_E_APAT), first SOBU of this SOB (SOB_S_SOBU), number of Mapping List entries (MAPL_ENT_Ns).
MAPL_ENT_Ns describes the number of mapping list entries to follow after SOBI_GI.
The purpose of the inventive Mapping List MAPL is to provide all necessary information so that given playlist entries are efficiently translated into disc address pairs, and viceversa.
It is also possible to include Application Private Data which consist of three kinds of information, namely Application Private Data General Information, a set of one or more Application Private Data Search Pointers, and a set of one or more Application Private Data Area. If any Application Private Data exists, these three kinds of information become recorded and stored in this order in the APPLICAT.IFO file.
Stream Data include one or more Stream Objects (SOBs) each of which can be stored as a ‘Program stream’ as described in ISO/IEC 13818-1, Systems.
A SOB can be terminated by a program_end_code. The value of the SCR field in the first pack of each SOB may be non-zero. A SOB contains the Stream Data packed into a sequence of ‘Stream Packs’ (S_PCKS). Stream data can be organised as one elementary stream and are carried in PES packets with a stream_id.
As shown in
The MAPL table depicted in
As shown in
The structure of the IAPAT value is depicted in
For an explanation on how to calculate IAPAT(i) during recording, the following notations will be used:
Then IAPAT(i) shall be chosen such that IAPAT(i)=
floor(SOBU—S—APAT(i+1)/2MTU
for i=0, 1, 2, . . . , M−1.
The IAPAT value range is limited by the resolution (12 bit) of an IAPAT value and its minimum value (IAPAT(i)=1 for i>0 and IAPAT(0)=0):
0≦IAPAT(0)<212 (eq 3)
and
1≦IAPAT(i)<212 for i>1 (eq 4)
The floor function floor(x) rounds down, e.g. floor(1.2)=floor(1.8)=1, floor(−1.2)=floor(−1.8)=−2.
SOBU_S_APAT(i) is described in the DVD Stream Recording PAT Describing Format. But, in evaluating the equations above they must be treated as if they were 6 byte unsigned integer values.
Mapping Time Unit is a duration corresponding to IAPAT=1, and can be calculated as
Mapping Time Unit=(2(MTU
For MTU_SHFT=18 bit it corresponds to approx. 5.69 milliseconds.
SOB_S_APAT describes the start Application Packet Arrival Time of a Stream Object, i.e. the packet arrival time of the first packet belonging to the SOB. SOB_S_APAT is described below in the DVD Stream Recording PAT Describing Format: PATs consist of a base part and an extension part. The base part holds the so-called 90 kHz unit value, and the extension part holds the less significant value measured in 27 MHz units.
(a) Choosing SOB_S_APAT for a New Recording
A newly recorded SOB will normally start with the first Application Packet of a SOBU. In this case, SOB_S_APAT and the Application Timestamp of the first Application Packet of the SOB will normally be set to 0.
(b) Calculation of SOB_S_APAT After Editing
After editing, e.g. deleting the start of a SOB, SOB_S_APAT, the Application Timestamp of the first Application Packet of the first SOBU of the SOB and the Application Timestamp of the first Application Packet belonging to the SOB may differ and may be not equal to 0.
All possible cases are covered by the following general definition of SOB_S_APAT:
With this definition of SOB_S_APAT, the APAT of the first Application Packet starting in the first SOBU of the SOB is equal to or greater than 0 and less than 2 MTU_SHIFT+12.
PAT_base: PAT's base value measured by 90 kHz unit
PAT_exten: PAT's extension value measured by 27 MHz unit
(0≦PAT—exten<300)
PAT in seconds=(PAT_base/90000 Hz)+(PAT_exten/27000000 Hz)
For an unique representation of times, PAT_exten must be in the range of 0≦PAT_exten<300. Together, PAT_base and PAT_exten cover a range of more than 1696 hours.
SOB_E_APAT describes the end Application Packet Arrival Time of the Stream Object, i.e. the packet arrival time of the last packet belonging to the SOB, in the DVD Stream Recording PAT Describing Format. The general definition of SOB_E_APAT is as follows:
The Application Time Stamp (ATS) in front of each Application packet consists of a 30-bit value. An ATS includes a base part and an extension part. The base part holds the so-called 90 kHz unit value, and the extension part holds the less significant value measured in 27 MHz units.
For a unique representation of times, ATS_exten must be in the range of 0≦ATS_exten<300. Together, ATS_base and ATS_exten cover a range of more than 23 seconds.
A significant advantage of the invention is that the mapping list generates timestamps SUM_IAPAT of which the 12 LSB bits No. 18 to 29 are identical to the 12 MSB bits No. 18 to 29 of the stream timestamps ATS. This feature allows to simplify the real-time recorder hardware.
Example Function for Scanning the Presentation Data Until the Desired Application Packet is Found
The following function describes how to scan Presentation Data in order to retrieve an individual application packet associated with a Packet Arrival Time ‘x’. Thereby the Mapping List and the access to it is described in more detail, e.g. internal intermediate values which are required in subsequent steps, see
Notes on nomenclature used:
In order to simplify the example it is assumed that each sector contains an integer number of at least one application packet(s).
Function get_application_packet_location (x48)
The desired application packet is now retrieved as packet #ap_no of sector #soff. A value of ap_no=1 denotes the first Application Packet starting in the Sector. A value of soff=0 denotes the first Sector of the first SOBU of the SOB.
The above function is a more general example. It can be simlified if MTU_SHFT<19. This requirement is fulfilled because MTU_SHFT is defined as 18.
The desired application packet is now retrieved as packet #ap_no of sector #soff. A value of ap_no=1 denotes the first Application Packet starting in the Sector. A value of soff=0 denotes the first Sector of the first SOBU of the SOB.
The 30 bits of ATS have the same weight as the 30 LSBs of APAT.
It is not required that the first sector of the first SOBU of a SOB belongs to this SOB. If the first part of a SOB was erased, then the remaining SOB may start in the middle of a SOBU, i.e. the first sector of this SOBU is not part of the SOB.
In Stream recording, the application performs its own padding, so that the pack length adjustment methods of DVD-ROM Video or DVD-VR need not to be used. In Stream recording it is safe to assume, that the Stream packets will always have the necessary length.
The data stream also contains application time stamps ATS, e.g. within the data packets.
Number | Date | Country | Kind |
---|---|---|---|
98250315 | Sep 1998 | EP | regional |
98250387 | Nov 1998 | EP | regional |
99250179 | Jun 1999 | EP | regional |
99250214 | Jul 1999 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP99/06377 | 8/30/1999 | WO | 00 | 3/7/2001 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO00/14744 | 3/16/2000 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5630005 | Ort | May 1997 | A |
5999698 | Nakai et al. | Dec 1999 | A |
6091674 | Tozaki et al. | Jul 2000 | A |
Number | Date | Country |
---|---|---|
673 034 | Sep 1995 | EP |
729 153 | Aug 1996 | EP |
797 204 | Sep 1997 | EP |
2 759 471 | Aug 1998 | FR |