The present invention relates to an improvement in a system for recording a digital video datastream and, more particularly, to a system capable of efficiently recording an MPEG transport stream to be digitally broadcasted. The present invention further relates to a system for recording support information of an MPEG transport stream in a management area.
In recent years, TV broadcast has entered an era of digital broadcast and, hence, the necessity of a streamer (an apparatus for saving digital data intact) for digital TV broadcast has come forth.
Digital TV broadcast currently uses an MPEG transport stream, which will probably become a standard in the field of digital broadcast of moving pictures in the near future.
As a streamer for recording digital broadcast data, for example, D-VHS (digital VHS) is available.
Digital TV broadcast data is broadcasted from a broadcast station via a communication satellite. The broadcasted digital data is received by a Set Top Box (to be abbreviated as an STB hereinafter as needed) set in each home, and is displayed on a TV monitor. This STB decrypts and plays back encrypted digital data on the basis of a key code distributed from the broadcast station.
Data is encrypted to prevent a user who does not have any contract with the broadcast station from illicitly receiving and viewing that data.
When the received data is directly played back, it is decrypted by the STB. The decrypted data is decoded by an MPEG decoder, and the decoded data is converted into a TV signal by a video encoder to be displayed on a TV monitor.
When broadcast data is recorded, digital data received by a tuner is recorded by a D-VHS recorder via an IEEE1394 digital interface.
Note that IEEE1394 specifies standard interface specifications, that implement command and data exchanges.
When recorded broadcast data is played back, the recorded data is read from the D-VHS recorder, and is sent to a data expansion unit in the STB, thus playing back the recorded data.
Digital data recorded by the D-VHS recorder normally has the following structure.
That is, digital data to be recorded is recorded as main data in a sync block in a main data area, while six tracks are handled as one ECC block. In this case, a header is appended to a transport stream (TS) packet upon recording.
In such D-VHS streamer, the broadcasted bitstream is directly recorded on tape. For this reason, a plurality of multiplexed programs are recorded on the tape.
Hence, all data are output from the tape upon playback irrespective of the playback start position. The STB selects only a desired program from the output data and plays it back.
Such system suffers very poor random-access performance, since a tape medium is used to record. For this reason, even when the user wants to quickly reach a desired position of a given program to play it back, such random access is impossible to attain.
On the other hand, even in large-capacity disc media such as DVD-RAMS and the like, recording of a streamer suffers certain problems. To realize random access, special playback, and the like, such DVD system inevitably requires to record management data together with broadcast data.
Also, in such DVD system, data must be managed or formatted in accordance with the DVD video format.
However, since the DVD video format does not assume satellite broadcast, it cannot often support special playback or the like.
Japanese Patent Application No. JP10-040876 has proposed the format that assumes a home recorder/player. However, even in this format, digital broadcast is not taken into consideration.
As mentioned above, in a digital TV broadcast compatible streamer system, TS stream data cannot be efficiently managed in a streamer that uses a DVD-RAM capable of random access, i.e., a read/write (R/W) disc.
It is an object of the present invention to provide a system that can efficiently record a transport packet in a streamer which uses media (DVD-RAM and the like) capable of random access.
It is another object of the present invention to add a streamer function to the DVD video format.
It is still another object of the present invention to efficiently manage digital TV broadcast data by proposing a novel format that assumes digital TV broadcast.
To achieve the object, the present invention uses information medium (including a signal or radio wave) which comprises an data object (VOB/SOB) formed of one or more data object units (VOBU/SOBU) each of which serves as a prescribed data unit; control information (VOBUI/SOBI) of the data object (VOB/SOB); access unit data (AUD) used for accessing an access unit (I-picture, etc.) which is a part of contents of the data object (VOB/SOB), the access unit data (AUD) being contained in the control information (VOBUI/SOBI); and a bitstream being formed of a series of packets, the bitstream including contents of the data object (VOB/SOB) and contents of the control information (VOBUI/SOBI).
Additional objects and advantages of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The objects and advantages of the invention may be realized and obtained by means of the instrumentalities and combinations particularly pointed out hereinafter.
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate presently preferred embodiments of the invention, and together with the general description given above and the detailed description of the preferred embodiments given below, serve to explain the principles of the invention.
A DVD recorder/player and the format of an optical disc on which the DVD recorder/player can write data according to an embodiment of the present invention will be described below with reference to the accompanying drawings.
The terminology of the format will be briefly explained first. Data is saved on an optical disc in a normal file format. A title corresponds to a single movie, and a plurality of titles are stored in a single disc. A group of titles is called a title set, which is formed of a plurality of files. Also, a file called a video manager (to be abbreviated as VMG hereinafter) is stored on a single disc as information for managing this disc.
Furthermore, the title set (to be referred to as VTS hereinafter) is composed of a management information file of video title set information (to be referred to as VTSI hereinafter), and a backup file of the VTSI.
The video file has a hierarchical structure, and a single file is formed of a plurality of program chains, each of which comprises a plurality of programs, each of which comprises a plurality of cells, each of which comprises a plurality of video object units (to be referred to as VOBUs hereinafter). Each VOBU is formed of a plurality of packs including various kinds of data. Each pack is formed of more than one packets and a pack header. The pack is a minimum unit for a data transfer process. Furthermore, the minimum unit for a logic process is a cell, and the logic process is done in units of cells.
A transport (TS) stream will be explained below. In general, in a method of broadcasting compressed moving pictures (e.g., digital TV broadcast, cable broadcast such as the Internet, and the like), a TS stream as a common basic format is specified to comply with the MPEG2 specifications.
The TS stream is composed of a large number of TS packets 38, as shown by (a) in
Data to be played back stored in payload 42 includes MPEG video data, Dolby AC3 audio data, MPEG audio data, and the like. On the other hand, information other than the data to be directly played back includes a program association table (PAT), a program map table (PMT), and the like which are required upon playing back data, and also electronic program guide (EPG) information.
The PAT includes packet identification information (PID) of PMTs in units of programs, and each PMT records the PID of video data, audio data, or the like.
With this format, as a normal playback procedure of an STB, when the user determines a program based on EPG information, a PAT is loaded at the start time of the determined piogram, and the PID of a PMT of the determined program on the basis of the PAT. The desired PMT is read out based on the determined PID, the PIDs of video and audio packets included in the PMT are determined, and the video and audio data are extracted and played back according to the PIDs. Note that the PAT is sent at intervals of several 100 ms since it is also used in the course of playback.
When such TS stream data are recorded on a disc medium such as a DVD-RW (read/write) or the like, these data are preferably recorded as digital data. However, since the current maximum bit rate of a DVD-RAM is 10.08 Mbps, satellite broadcast data (20 Mbps or more) itself in which all channels are multiplexed cannot be recorded. For this reason, when such data are recorded, one program must be selected and recorded.
When certain data are recorded on a disc medium, other data for managing recorded data are required to meet user needs (e.g., to start playback from a desired time of a desired program, to fast forward, and the like). However, since the data itself to be played back is encrypted, it is hard to generate management data for the data itself to be played back.
For this reason, management data is preferably generated using data in a packet header as control data in a TS stream packet, or data in a PAT or PMT packet as PSI (program specific information) data of a TS stream.
Note that such packet header contents may often include information which is not supported depending on the types of satellite broadcast, and may often use neither a PAT nor PMT. Hence, management data cannot often be generated in units of satellite broadcast services by the aforementioned method, and data cannot be recorded.
To solve this problem, upon recording, information of a packet header used by satellite broadcast, and information indicating the presence/absence of a PAT or PMT are saved in management information, and management data is generated in accordance with supported information. To provide only available services upon playback, service contents are preferably changed in accordance with that support information.
As a method of detecting support information, the following two methods can be used.
In the first method, support information is received from the STB. The STB varies in units of satellite broadcast services to be received, and is a dedicated apparatus. For this reason, the STB should recognize information pertaining to support in advance (upon delivery of STB). Hence, that support information is loaded from the STB at the beginning of recording.
In the second method, each data to be used is checked upon receiving TS stream data from the STB, and if that data is active, it is determined that the information is supported, and the support information is stored. At the same time, management data is generated based on the supported information, and the accumulated support information is recorded in a management area of an optical disc as management data.
The format that includes support information in management data will be explained below. The first example will explain management data that manages data complying with the DVD video format for which the format specifications have already been standardized.
Current DVD video format does not assume satellite broadcast or the like. Hence, when satellite broadcast data is recorded and the recorded data is played back in special modes, some special modes can not be supported in the status. Hence, to propose recording/playback specifications that comply with current DVD video, the following format is optimal.
In current DVD video, video object set (VOBS) 30 as an object to be played back has a structure shown by (a) to (d) in
More specifically, VOBS 30 shown by (a) in
In a streamer, streamer objects (SOBs) are defined as those corresponding to the VOBs, and streamer object units (SOBUs) are defined as those corresponding to the VOBUs.
In the following, descriptions pertaining to the VOB and VOBU may be interpreted by replacing them by the SOB and SOBU, respectively, as needed.
As for the structure of VOBU 33, two different format schemes can be proposed.
In the first scheme, one VOBU 33 is composed of one or more TS packs 34 that record transport streams (TS streams). One TS pack 34 shown by (a) in
Each TS pack 34 is formed of 10 TS packets 38, and packet header 36 includes a stream ID that describes 0xbd indicating a private stream in MPEG2. Also, a substream ID that specifies that data in a packet is a transport stream describes 0xf0.
Incidentally, a timestamp (ATS) may be placed at the leading portion of each of the TS packets, as shown by (b) in
As shown by (c) in
For example, in (c) of
In pack 34 shown by (d) of
With this packet access pointer 40, a field that must store padding data and cannot be used can be used as a storage field of packet data. At this time, if the packet access pointer is 0xffff, it indicates that the head packet is not present within a pack.
In this case, the head packet must be aligned after packet access pointer 40, as shown in the example of (c) in
Portions of a transport stream packet (TS packet) shown by (c) and (d) in
That is, when one packet is recorded across two sectors upon recording a TS packet, data pieces recorded in the first and second sectors, respectively, correspond to portions of the TS packet.
With this format, when one packet is recorded across two sectors, no padding data need be inserted, thus increasing the recording density.
In this case, a packet header can record position information indicating “the number of bytes from a reference position to the first TS start position of each sector”. As the reference position, for example, the position of a packet header, the head position of a TS packet, the end position of a TS packet, or the adjacent boundary position of successive adjacent TS packets, may be used.
When the head position of a TS packet is used as the reference position, packet access pointer=0 in (c) of
An example of the second scheme that has already been explained will be described in more detail below with reference to
More specifically, the head portion of TS packet 38 is always aligned after packet access pointer 40 in TS pack 34, and packet access pointer 40 stores zero relative address. Hence, when VOBU (SOBU) 33 is accessed to extract that packet, the head of that packet matches that of TS packet 38, and TS packet 38 can be extracted and immediately transferred. TS packets 38 are arranged after head TS pack 34 in VOBU (SOBU) 33, and the remaining portion of TS packet 38 that cannot be stored in one pack with 2,048 bytes is stored in packet 38 of next TS pack 34, as shown by (c) in
In this manner, TS packs 34 are arranged in turn in VOBU (SOBU) 33. Last TS pack 34 in that VOBU (SOBU) 33 cannot often store one TS packet 38 at the end of that pack unlike other TS packs 34, as shown by (c) in
In such case, padding packet 39 can be inserted in that end portion, as needed. By inserting the padding packet, head TS pack 34 in next VOBU (next SOBU) 33 can have a packet data field starting from head TS packet 38.
Note that a method that can cope with the aforementioned case without using any padding packet (one packet is recorded across two sectors upon recording a TS packet) is also available, and has already been explained.
In the example shown in
The structure of next TS pack 34 may be specified by a continuous packet flag shown by (a) and (b) in
More specifically, as shown by (a) in
That is, if continuous packet flag 41 is 1, a portion of TS packet 39 is stored at the end of that TS pack 34, and the remaining portion of that TS packet 39 is stored after continuous packet flag 41 in next TS pack 34.
If a TS packet 39 is aligned and arranged at the end of TS pack 34 and no portion of that packet remains to be stored in next pack 34, zero continuous packet flag 41 is set. This means that if TS packet 39 with zero continuous packet flag 41 is acquired, a smooth playback process is assured by playing back TS packet 39 that follows continuous packet flag 41.
The structure of management data in the aforementioned data structure will be described below.
Management data is recorded in a management area after a lead-in area on the inner periphery side of an optical disc, and the management area includes a table of video title set information (VTSI) or a table of streamer control information (STR_VMGI), as shown by (a) in
As shown by (a) in
User-defined PGC information (UD_PGCI) in the UD_PGCIT is a sequence of parts of a program. The play list may be used by a user to freely define the playback sequence of the parts of programs.
The VTS_PGCIT (UD_PGCIT) contains VTS_PGCIT information (VTS_PGCITI) (or UD_PGCITI); VTS program chain search pointers (VTS_PGC_SRP#n) (or UD_PGC_SRP#n) arranged in the playback order, and VTS program chain information (VTS_PGCI#n) (or UD_PGCI#n) designated by each of these search pointers, as shown by (b) in
As shown by (c) in
The PGC general information (PGC_GI) may have a configuration as shown by (a) in
In case of SC_GI, a cell type (C_TY1=010b) and a temporary erase (TE) flag are described in place of the ARCHIVE Flag. This SC_GI may further includes:
As the flow of signals upon recording, TS packet data received by the STB are packed and recorded by a formatter unit. At this time, the presence/absence of each information is detected and is saved in a work RAM. The saved information is recorded as management information upon completion of recording.
In the support information, as shown by (b) in
The identification code includes, e.g., an STB (001) of BS digital broadcast, a Ver2 STB (010) of DirecTV, and a Ver1 STB (011) of Sky Perfect TV.
Upon playback, pack data read out from a disc is interpreted by a distributor, and a pack that stores TS packets is sent to a TS packet transfer unit. The TS packet transfer unit transfers only TS packets to the STB in accordance with a request from the STB.
Each cell playback information (C_PBI) (or stream cell information SCI) preferably further describes support information, as shown in
More specifically, as shown in
Also, the cell playback information describes a TS packet length indicating the length of a transport stream packet (TS packet) in the 17th and 18th bytes (RBP).
Furthermore, the cell playback information (or SCI) records the number of I-pictures (REFPIC_Ns) (or the number of access units AU_Ns) as support information in the 19th to 22nd bytes (RBP).
Moreover, the cell playback information (or SCI) records the start addresses (REFPIC_SA#1 to REFPIC_SA#n) and end addresses (REFPIC_EA#1 to REFPIC_EA#n) of I-pictures (or Access Unit Start Map AUSM and Access Unit End Map AUEM) in turn in the 23rd byte and subsequent bytes (RBP).
REFPIC_SA# (I-picture start position) corresponds to an AUSM (access unit start map; to be described later). This AUSM indicates a data unit (SOBU) of a streamer object (SOB), which unit contains an access unit (AU).
REFPIC_EA# (I-picture end position) corresponds to an AUEM (access unit end map; to be described later). This AUEM is a bit array having the same length as that of the AUSM. Bits in this AUEM indicate which of the SOBUs contains the end of a bitstream segment associated with the access units of the SOB.
Note that the SOB and SOBU are names used in a streamer, and correspond to names VOB and VOBU used in DVD video (DVD_RTR).
The streamer directly records an incoming bitstream, and does not concern itself with its contents (that is, the streamer does not know the recording contents).
When a bitstream recorded by the streamer is an MPEG2 transport stream, decoding starts from an I-picture position. In this case, if a time search is made for a position between a given I-picture and the next I-picture (i.e., access is made based on only the time stamp), since there is no I-picture at that position, the start of decoding delays until the next I-picture is detected (thus the image output timing delays).
On the other hand, when a data unit (SOBU) is used as an access unit in the streamer, since the start/end positions of I-picture can be determined in units of SOBUs (i.e., determined from the AUSM and AUEM), an I-picture position can be immediately found by a time search using an MPEG transport stream.
That is, when the SOBU is used for the access unit, an I-picture position is immediately found by a time search. Therefore, decoding can be quickly started, and smooth fast forward (FF) and fast rewind (FR) can be attained.
Note that the TS packet length is described in
Thus, after data is read out from a disc, the data packet in the pack is segmented by the TS packet length to obtain packets.
When packets corresponding to the TS packet size (188 bytes) in an MPEG transport stream, the packet size in a DVD video (DVD_RTR) program stream, and other packet sizes (n bytes/packet) are considered as those to be recorded by the streamer, a generic bitstream called an application stream is used.
As another example, a case will be exemplified below wherein support information is recorded in management information in the currently proposed recording/playback video format.
Data area 23 is divided into a plurality of DVD areas 24, as shown by (c) in
VOB general information (VOB_GI) (or SF_GI) 27 has areas for recording VOBU_Ns (or SOBI_Ns), VOBI_End Address (or SOBU_SIZ), support information, etc., as shown by (f) in
More specifically, VOB_GI (or SF_GI) records: the number of VOBUs (VOBU_Ns) (or the number of SOBIs (SOBI_Ns)) in the 0th to 3rd bytes (RBP); the end address or the size (i.e., length) of the VOBI (or the number of sectors per SOBU (SOBU_SIZ)) in the 4th to 7th bytes (RBP); and support information which may be the same as that shown by (b) in
VOBUI (or SOBI) 29 shown by (e) in
More specifically, VOBUI (SOBI) 29 records: the VOBU start address in the 0th to 3rd bytes (RBP); and the VOBU end address or length in the 4th to 7th bytes (RBP).
Also, VOBUI (SOBI) describes: a system time clock (STC) or program clock reference (PCR) upon recording the head of the VOBU of interest as VOBU_RECTM in the 8th to 11th bytes (RBP); and a TS packet length indicating the length of a TS packet in the 12th and 13th bytes (RBP).
Furthermore, VOBUI (SOBI) records the number of I-pictures (REFPIC_Ns) in the 14th to 17th bytes (RBP).
Moreover, VOBUI (SOBI) records the start addresses (REFPIC_SA) and end addresses (REFPIC_EA) of I-pictures in turn in the 18th byte and the subsequent bytes (RBP).
When a VOBU is segmented into a plurality of sets of TS packets to always locate an I-picture at the head of each set, the I-picture address is used upon segmenting the VOBU.
REFPIC_SA# in
In this way, when an I-picture is always located at the head in a VOBU, the I-picture start address need not be described, and only the I-picture end address can be described.
As an example for recording management data contained in the TS packet described above in the aforementioned tables, the following five pieces of information will be explained.
The first information is the random access indicator contained in the TS packet header shown by (c) in
With this flag, the start position of the I-picture can be specified. Two methods are available to reflect this flag on the format.
In the first method, formatting is done using this information upon segmenting data into VOBUs (or SOBUs) 33, as shown by (a) in
With this method, since the start position of each VOBU (SOBU) always matches that of an I-picture, playback in units of VOBUs (SOBUs) can be easily done. In this case, a padding packet is inserted into a VOBU (SOBU) as needed to always locate I-picture data at the start position in the VOBU (SOBU), as shown by (a) in
As the second method, when the start positions of I-pictures are recorded in the management area, as shown in
In an actual system, since an I-decode end interrupt from the STB must be used, extra data is sent to the STB if only the I-picture start address is used, resulting in poor efficiency.
Furthermore, as the second information, the unit start indicator shown by (b) in
Thus, since the I-picture end address can be specified, a special playback mode such as fast forward (FF), fast rewind (FR), or the like that does not read out extra data can be implemented.
The unit start indicator can specify the start address of each I-picture. The I-picture end address is written as management information, as shown in
In this embodiment, a logical block address is used as address information. The logical block address does not match an actual physical address since skipping is done based on, e.g., error information and the like. Especially, in case of a DVD-RAM or the like, since an error occurs due to contamination such as scratches, fingerprints, and the like, the addresses may have a larger difference. For this reason, the logical block address is converted into a physical address by, e.g., a file system.
Also, as the address information, not only the logical block address but also a method of indicating an address using a transfer time, converting the time information into a logical block address using a correspondence table, and then converting the logical block address into a physical address may be used. That is, the address information indicates information that can be converted into a physical address with reference to a correspondence table or the like or via computations.
The third information is a splice countdown (SCD) contained in the TS packet header shown by (d) in
For this reason, as shown by (a) in
The fourth information is a method of presenting a cell or VOBU playback time, as shown in
Note that PCR indicates a transfer arrival reference time of a TS packet, and is not appended to all TS packets. But since a TS stream is data to be played back in real time, PCR is highly likely to indicate the same time as the playback time. However, since the playback time is contained in a payload, it cannot be used in a recording/playback DVD streamer unless the data is decrypted.
For this reason, the playback time is presented using PCR information and the STC in which that time data is set. In this manner, the playback time can be roughly represented. However, when PCR is not supported, the playback start time is set at STC=0, and counting is then started to use an STC value at a given timing as the playback time.
The fifth information is PAT and PMT packets shown by (b) in
For this reason, these packets can be used to segment data, as shown by (b) in
Note that the PAT and PMT_packets can be used in the following four segmentation methods in correspondence with the DVD video format.
First, as shown by (b) in
Second, as shown by (a) in
Third, as shown by (b) in
Fourth, as shown by (c) in
The identification code of the STB indicates the type of digital broadcast that the STB connected can receive. With this code, the STB connected is checked upon playback, and the same STB used upon recording can be selected to play back data. Furthermore, this code can change operation that pertains to playback time presentation.
When the STB supports a command for outputting a playback time to a recorder, the playback time is periodically read from the STB and is presented. This value is most accurate as the playback time.
The system arrangement of a satellite broadcast compatible DVD recorder/player will be explained below with reference to
Referring to
The recorder/player of
Decoder unit 59 in the system shown in
The playback data is demultiplexed by distributor 60 into video data, sub-picture data, and audio data (packet data). The video data is transferred to video decoder 61 having reduced-scale image (thumbnail picture) generator 62, and the sub-picture data and audio data are respectively transferred to sub-picture decoder 63 and audio decoder 64.
Digital video and sub-picture signals respectively decoded by video decoder 61 and sub-picture decoder 63 are synthesized by video processor (V-PRO) 65, and the synthesized signal is supplied to video mixing unit 66. Video mixing unit 66 is connected to frame memory 73 for temporarily storing a digital video signal in units of frames, and externally supplied text data or the like is mixed into a video frame. Then, the digital video signal is supplied to D/A converter 67, and a D/A-converted video signal is output to TV monitor 68. The digital video signal can be externally output via interface 69.
A digital audio signal from audio decoder 64 is supplied to D/A converter 70, and a D/A-converted audio signal is output to loudspeaker 72. The digital audio signal can also be externally output via interface 71.
Reduced-scale image (thumbnail picture) generator 62 of video decoder 61 generates a video signal of a reduced-scale image of transferred video data on the basis of a reduction ON command from main MPU 80, and supplies it to video processor 65 to display the reduced-scale image on TV monitor 68. Key input unit 103 having keys for instructing external commands such as playback (PLAY), stop (STP), a marker that appends a mark associated with a recording position, and the like, and display unit 104 are connected to main MPU 80.
Encoder unit 79 in the system shown in
An AV signal from external AV apparatus 81 or TV tuner 82 is converted into a digital signal by A/D converter 84. In this case, a digital audio signal is supplied to audio encoder 86 and a digital video signal to video encoder 87 via selector 85, and these signals are MPEG-encoded.
When caption information such as character information or the like is output from TV tuner 82, it is supplied to sub-picture encoder 88 and is runlength-encoded.
Data encoded by encoders 86, 87, and 88 are supplied to formatter 90, to which buffer memory 91 is connected, are stored in video, audio, and sub-picture packets appended with packet headers by formatter 90, and these packets are converted into pack structures by appending pack headers.
These packs are grouped together in units of VOBUs (SOBUs), as shown by (d) in
During the formatting process, formatter 90 generates management information with reference to segmentation information generated by TV tuner 82. For example, PGC information is generated with reference to segmentation information.
The generated management information and pack data are sent to data processor 52, which stores the generated management information in a management data table generated by and supplied from a management data generator 80B of main MPU 80. Then, the management and pack data are recorded on optical disc 50 via disc drive 51.
STB 83 directly supplies an MPEG2 transport stream corresponding to the selected program, i.e., title, to formatter 90. The stream is formatted, as shown in
STB 83 incorporates a decoder, which decodes AV data in TS packets to convert it into audio and video signals. The audio and video signals are respectively supplied to loudspeaker 72 and TV monitor 68 via D/A converters 70 and 67.
TS packs 34 supplied to optical disc 50 are supplied to distributor 60 of decoder unit 59 via data processor 52 and disc drive 51. Distributor 60 detects with reference to the stream and substream IDs that packet data in these packs are TS packet data, and distributes those TS packets to TS packet transfer unit 100.
TS packet transfer unit 100 supplies TS packets 38 to STB 83 at predetermined transfer timings. Data in each TS packet is decoded by STB 83, and decoded audio and video signals are respectively supplied to loudspeaker 72 and TV monitor 68 via D/A converters 70 and 67.
In the aforementioned recording/playback operation, decoder unit 59 and encoder unit 79 execute data transfer and the like under the control of system time clocks 102.
The recording and playback processes will be explained below with reference to
A data process upon recording will be described first with reference to the flow charts shown in
When main MPU 80 receives a recording command from key input unit 103 in step S10, the recording process starts.
Disc drive 51 loads management data from optical disc 50 in step S11, and it is checked in step S12 if a free space is available. If no free space is available, a message indicating no free space is displayed on display unit 103 in step S13, and the process ends in step S14.
On the other hand, if a free space is available, a write area is determined in an area corresponding to the free space, i.e., a write address is determined in step S15. In order to write recording data in the determined area, that address is written in the management area, and the write start address of video data is set in disc drive 51 to prepare for data recording. In step S16, a command for reading out. EPG (electronic program guide) information from STB 83 is issued.
In response to a request from MPU 80, STB 82 prepares the latest EPG at that time. That is, STB 82 receives the latest EPG and saves it in a work memory. The EPG data which has been received or saved in the work memory in the STB 83 is sent back to MPU 80.
MPU 80 displays that EPG data in step S17 to make the user select a program to be recorded. After that, if the program to be recorded is determined, MPU 80 issues a command for outputting support information to STB 83, and receives support information from STB 83, as shown in step S18. At this time, MPU 80 also receives an STB identification code from STB 83 together with support information. The support information is detected by support management information detector 80C in MPU 80.
If no support information is available in STB 83, the presence/absence of support information is checked during information, and detected information is used instead. MPU 80 designates a target program to be recorded in STB 83, and make STB 83 start reception of the program.
MPU 80 issues an instruction for writing management information in the management area on optical disc 50 in step S19. That is, VTS is registered in VMGI to generate VTSI as a management data table for a video title set, and support information is written in VTSI. Or, STR_VMGI (
In DVD_RTR (a system for internally converting analog video data into MPEG data and recording the MPEG data in real time), the roles of VMGI and VTSI are integrated in RTR video manager information (RTR_VMGI). Hence, when a DVD_RTR recorder is used as a streamer, VMGI and VTSI (or STR_VMGI) may be read as RTR_VMGI as needed.
MPU 80 resets the time of STC 102 as an initialization process for recording in step S20. Note that STC 102 is a system timer, and recording and playback are executed with reference to the value generated by STC 102. Data of VMG and VTS files are written in a file system, and required information is written in VMGI and VTSI.
At this time, if support information has been detected, the detected support information is written. Furthermore, the respective units undergo recording setups. At this time, data segmentation is set in the formatter, as has been explained above with reference to
Upon starting recording, the respective units undergo recording start setups in step S21 in
When recording has been started, MPU 80 checks in step S22 if an update input of segmentation information, i.e., data grouping information that has been explained with reference to
After the segmentation information is saved, or if segmentation information is not updated, it is checked in step S24-1 if a recording end key input is detected. If the recording end key input is detected, a recording end process is executed in step S28. If no recording end key input is detected, the size of the free area in optical disc 50 is checked in step S24-2 to compute the remaining space size.
It is checked in step S25 if the remaining space size has become equal to or smaller than a predetermined value. If the remaining space size is not equal to or smaller than the predetermined value, the flow repeats step S25 to periodically check the remaining space size. If the remaining space size has become equal to or smaller than the predetermined value, a process for a small remaining space size is done in step S26.
After that, it is checked in step S27 if no recordable space is available. If a sufficient recordable space is available, the flow returns to step S22 to repeat steps S22 to S26.
If no recordable space is available, a recording end process is done in step S28. In this recording end process, segmentation information for the remaining data is received from formatter 90, and is added to work RAM 80a. These data are recorded in management data (VMGI and VTSI; or RTR_VMGI; or STR_VMGI), and information for recorded data is recorded in the file system. After that, recording ends in step S29.
The flow of a video signal in the recording operation in the system shown in
TS packets input from STB 83 are input to the formatter. The time elapsed from the transfer start timing is read from the STC value, and is saved in buffer RAM 91 as management information. This information is sent to MPU 80 together with segmentation information, and is recorded in management information. As segmentation information, VOBU (or SOBU) segmentation information, cell segmentation information, program segmentation information, and PGC segmentation information are generated, and are periodically sent to MPU 80.
Note that the VOBU (SOBU) segmentation information includes the VOBU (SOBU) start address, VOBU (SOBU) playback time, and I-picture start and end addresses. In the I-picture start address, the address of a pack that records a TS packet including an active random access indicator is set.
As for the I-picture end address, since a TS packet that stores video data immediately before a TS packet including an active unit start indicator after the random access indicator is active is an I-picture end packet, the address of a pack which records that TS packet is set in the I-picture end address.
As the VOBU (SOBU) playback time, the time required from the start to end of transfer of a VOBU (SOBU) is used instead.
Formatter 90 temporarily saves TS packet data in buffer memory 91. Then, the formatter packs the TS packet data input to obtain packed data, formats the packed data to obtain a pack sequence shown by (e) in
D-PRO 52 groups 16 packs together to obtain an ECC group, appends error correction data thereto, and sends the ECC group to disc drive 51. When disc drive 51 is not ready to record, D-PRO 52 transfers the ECC group to temporary memory 53 and waits until disc drive 51 is ready to record. When disc drive 51 is ready, D-PRO 52 starts recording. As temporary memory 53, a large-capacity memory is assumed since it must hold recording data for several min or more by high-speed access.
Note that a microcomputer can make read/write access to D-PRO 52 via a microcomputer bus to read/write the file management area or the like.
Upon completion of recording, an erasure inhibition flag (protect or archive flag) is cleared to permit erasure. That is, at the beginning of recording, erasure is allowed.
A data process upon playback will be explained below with reference to
Upon receiving a playback command, MPU 80 starts a playback process in step S30. Disc drive 51 searches disc 50 to check for any defects in step S31.
If any defects on disc 50 are found upon checking disc 50, an error process is executed in step S32, and playback comes to an end in step S33.
If no problem is found on disc 50, STB 83 connected is checked in step S34 to fetch its identification code. After that, disc drive 51 searches the management area on disc 50 to load its management information (VMGI or STRI including STR_VMGI) via D-PRO 52 in step S35, thus allowing the user to select a title set (one or more PGCs) to be played back.
When the user determines the title set (PGCs) to be played back and its address is determined in step S36, MPU BO sends a read command of the determined address to disc drive 51. Hence, VTSI (or STR_VMGI) of the determined title set (PGCs) is loaded and PGCI (or play list search pointers) in the loaded VTSI (or STR_VMGI) is saved in work RAM 80A in step S37.
In step S38, all titles or PGCs (or programs (PGs)) corresponding to STB 83 connected in the selected title set are displayed. Based on this display, the user determines the title or PGC (or program) to be played back in step S39.
Subsequently, in step S40 support information in the management information shown in
If the random access indicator is not supported, it is checked in step S43 if PAT is supported. If PAT is supported, a flag that permits FF and FR special playback modes based on PAT is set in step S44. If PAT is not supported either, a flag that inhibits FF and FR special playback modes is set in step S45.
Upon completion of setups based on the support information, program and cell numbers from which playback starts are determined in step S46. MPU 80 sends a playback command of TS packets to STB 83 via an internal bus. MPU 80 also initially sets up distributor 60 to send TS packets to STB 83, and sets V mixing unit 66 to allow a display process of a video signal sent from STB 83 (step S47 in
Disc drive 51 reads out sector data from disc 50 in accordance with a command sent from MPU 80, i.e., the determined program and cell numbers. D-PRO 52 corrects errors of readout data, and outputs corrected data to decoder unit 59 as pack data.
In decoder unit 59, distributor 60 determines based on the stream and substream IDs of the pack data that incoming data contains TS packets, and sends TS packets to TS packet transfer unit 100. The TS packets are then transferred to STB 83 (step S47).
STB 83 then decodes incoming TS packets. In case of normal broadcast reception, incoming data is directly written. But in case of data exchange via the internal bus, data transfer is done using REC and ACK signals as follows. That is, when a buffer consumed by STB 83 is empty, an REC signal is activated. When distributor 60 is ready to transfer data, an ACK signal is activated every time data is sent onto the bus. In this manner, data is transferred in response to a data transfer request from STB 83.
The sent TS packet data are played back by STB 83, and video data is converted into a TV signal via V mixing unit 66 and is displayed on TV monitor 68. Also, an audio signal is sent to D/A converter 70 to be converted into an analog audio signal, and the converted signal is played back from loudspeaker 72.
During playback, PCR data is periodically set in the STC, and the contents of the STC are displayed as a playback time. When STB 83 can transfer a playback time, playback time data is periodically transferred and displayed. If STB 83 can display a playback time based on PTS in video data, that playback time is displayed.
The playback process is done in units of cells, as shown in step S48 in
If disc drive 51 is in operation, it is always checked if the current cell is the last cell. If the current cell is not the last cell (step S51), the cell number is counted up in step S52, and the flow returns to the cell playback process in step S48.
If the last cell has been reached in step S51, it is checked in step S53 if playback is to end. If playback is not to end, the flow returns to step S48 to start playback of a cell of another program (or another play list) or PGC.
If the end of playback is determined in step S53, a playback end process is done in step S54, and the playback operation comes to an end in step S55.
The cell playback process shown in
Initially, when the cell playback process corresponding to step S48 in
If VOBUs (SOBUs) are continuous, it is checked in step S65 if an FF key is input.
If VOBUs (SOBUs) are not continuous, a playback start address (logical block number LBN) is determined with reference to PGCI (or SOBI in
After that, cell playback starts from the playback start address, and it is also checked in step S65 during playback if the FF playback key is input.
If it is determined in step S65 that the FF playback key is input, it is confirmed in step S66 if FF playback is permitted. If FF playback is not permitted, a message “no FF playback permitted by broadcast station” is displayed in step S67, and the flow advances to step S71. Note that FF operation is inhibited and the message “no FF playback permitted by broadcast station” is displayed when support information neither specifies I-picture nor supports PAT.
If FF playback is permitted, an FF process is executed in step S68. It is checked (step S69) if disc drive 51 has stopped due to errors or the like during the FF process, and if disc drive 51 has stopped, the FF process and playback process end in step S70.
If it is determined in step S65 that the FF playback key is not input, or if an FF non-permission message is displayed in step S67, or when drive 51 is not stopped in step S69, then it is checked in step S71 whether STB 83 is of a type that outputs a playback time.
If STB 83 outputs a playback time, the playback time output from STB 83 is displayed in step S72. If STB 83 does not output any playback time, it is confirmed with reference to support information in step S73 whether management data of an incoming TS packet includes PCR that describes time information.
If PCR is supported, the PCR value in management data of that TS packet is displayed in step S75, and the flow advances to step S76. If PCR is not supported, the measured by STC 102 is displayed (step S74), and the flow advances to step S76.
It is confirmed in step S76 if the current cell is the last cell. If the current cell is not the last cell, the flow returns to step S65 to execute steps S65 to S75 again.
On the other hand, if the current cell is the last cell, the control waits for the end of playback of VOBUs (or SOBUs) in that cell in step S77. Upon completion of VOBU (or SOBU) playback, the flow returns to the aforementioned step S54 of
Special playback modes will be explained below with reference to
In the FF playback process in step S68, the flows shown in
That is, when the FF process starts in step S80, an only I-picture playback command is sent to STB 83 (step S81). It is confirmed with reference to support information in step S82 if a TS packet supports the random access indicator. If the TS packet does not support the random access indicator, an FF process using PAT is started in step S84. The FF process using PAT will be explained later with reference to
If the TS packet supports the random access indicator, it is confirmed in step S83 if a VOBU (SOBU) which is currently being transferred corresponds to the last VOBU (SOBU) in the cell. If the current VOBU (SOBU) is the last VOBU (SOBU), the I-picture start address in the next VOBU (SOBU) is read out in step S86, and the flow advances to step S87. On the other hand, if the current VOBU (SOBU) does not correspond to the last VOBU (SOBU), the I-picture start address, two VOBUs (SOBUs) ahead of the current VOBU (SOBU), is read out (step S85), and the flow advances to step S87.
It is checked in step S87 if the unit start indicator is supported.
If the unit start indicator is supported (YES in step S87), a transfer interrupt flag is cleared and the next I-picture end address is read out in step S91. Then, a read command designated with the start and end addresses of I-picture is sent to disc drive 51 in step S92, thus reading out I-picture data based on the I-picture start and I-picture end addresses.
In step S93, the control waits for a data transfer end interrupt, i.e., an interrupt from disc drive 51 to confirm if transfer of that I-picture data has ended.
If transfer has ended, the flow returns to step S91 to execute steps S91 and S92 again so as to playback the next I-picture. If transfer of the I-picture data has not ended, it is confirmed in step S94 if a STOP or PLAY key is pressed.
If neither of these keys are pressed, the flow returns to step S93 to wait for transfer of I-picture data. If either key is pressed, the flow advances to step S95 shown in
If it is determined in step S87 that the unit start indicator is not supported (NO in step S87), an I-picture playback interrupt flag is cleared and a read command designated with the start address of I-picture and continuous read is issued to disc drive 51 in step S88.
After that, the control waits for an I-picture decode end interrupt, i.e., an interrupt from STB 83, and if an interrupt is detected, the flow returns to step S88 to execute steps S88 and S89 again.
If no interrupt is detected, it is confirmed in step S90 if a STOP or PLAY key has been pressed. If neither of these keys are pressed, the flow returns to step S89 to wait for an interrupt from STB 83. On the other hand, if it is determined in step S90 that either key is pressed, the flow advances to step S95 shown in
The interrupt process (step S89 in
If this factor indicates a transfer end interrupt process from disc drive 51, a transfer end interrupt flag is set in step S122; if the factor indicates an I-picture playback interrupt process, an I-picture playback interrupt flag is set; or if the factor indicates a timer interrupt process, and if STB 83 can output a playback time, the playback time is received from STB 83 and is set in a work RAM. After such setups, the corresponding step is executed.
If it is determined in step S95 of
On the other hand, if it is determined in step S95 that the PLAY key has been pressed, a read command provided at the I-picture start address of the next VOBU (SOBU) is sent to disc drive 51 in step S98, and a data read is started based on that address in step S99, thus reading out data in turn. After that, the flow of process returns to step S48 in
As for FR playback, only the I-picture position to be read out is opposite to FF, and the flows shown in
When VOBUs (SOBUs) are grouped in units of I-pictures, since TS packets are aligned in units of VOBUs (SOBUs), no packet access pointer will be required. However, if VOBUs (SOBUs) are not grouped in units of I-pictures, a problem will be posed upon executing playback using the random access pointer.
More specifically, when a pack is to be read out based on the start address of I-picture, since I-picture is not always located at the head of a VOBU (SOBU), the start position of the data area of the pack is unlikely to match the segmentation (or split) start position of a TS packet. In such case, the packet access pointer (e.g., 0x2e as shown by (d) in
The FF process using PAT (program association table) in step S84 shown in
When the FF process using PAT is started in step S101, it is checked in step S102 if the transferred VOBU (SOBU) is the last VOBU (SOBU) in a cell. If the transferred VOBU (SOBU) is the last VOBU (SOBU), the start address of a VOBU (SOBU) at the head of the next cell is read out in step S104. On the other hand, if the transferred VOBU (SOBU) is not the last VOBU (SOBU), the start address, two VOBUs (SOBUs) ahead of the current VOBU (SOBU), is read out in step S103.
In step S105, an I-picture playback interrupt flag is cleared, a read command with the start and end addresses of a VOBU (SOBU) is sent to disc drive 51, and the control waits for an I-picture decode end interrupt, i.e., an interrupt from the STB.
If an I-picture playback interrupt is detected in step S106, the flow returns to step S105. On the other hand, if no I-picture playback interrupt is detected, and transfer has ended, it is checked in step S107 whether the STOP or PLAY key has been operated. If no key input is detected, the flow returns to step S106.
It is confirmed in step S108 whether or not the input key is the STOP key. If the STOP key has been entered, a stop command is supplied to disc drive 51 in step S109, and a playback end process (step S54 in
On the other hand, if the input key is the PLAY key, a read command with the I-picture start address of the next VOBU (SOBU) is sent to disc drive 51 in step S111, and a data read is started based on that address in step S112, thus reading out data in turn. After that, the flow returns to step S48 in
In the following, stream data according to an embodiment of the present invention will be explained.
The stream data is recorded as a group of stream objects (SOB) for each content of video information in the stream data. One SOB of them is shown by (f) in
When such stream data is recorded on a DVD-RAM disc, the recording will be performed in minimum units of sectors each having 2048 bytes. A group of 16 sectors constitutes an ECC block in which performed are interleaving (re-ordering of arrangement of data pieces) and adding of error correction codes.
In the embodiment, a unit of one or more ECC blocks is used to constitute a stream block. Recording and/or partial erasing of stream information will be performed in unit of the stream block. In the embodiment, the number of ECC blocks constituting the stream block depends on a transport rate of the stream data to be transmitted.
In digital broadcasting, one transponder receives packets of a plurality of programs which are time-divided. For instance, when a second program is to be recorded on a information storage medium, STB unit 83 of
Thereafter, when data is transmitted to formatter unit 90 of
More specifically, a pack header and a PES header are arranged at the leading portion of each sector (cf. (c) in
The timestamps (ATS) and transport packets as shown by (a) in
Note that in the example shown by (b) in
When one transport packet is recorded across a plurality of sectors, it is possible to record a large packet having a size larger than the one sector size.
The digital broadcasting utilizes a multiply-segmented scheme applicable to multi-programs, or utilizes a transport stream, wherein the size of one transport packet is relatively small (188 bytes or 183 bytes).
Meanwhile, as in the example of data structure of
In contrast, in a digital communication network as ISDN, a long packet having 4094 bytes may be transmitted.
According to the present invention, one packet can be continuously recorded across a plurality of data areas. By so doing, it is possible to achieve not only recording of transport packets in one data area of digital broadcasting, but also, recording of a large-size packet as the long packet of ISDN.
In other words, any type of packets, such as a transport packet of digital broadcasting or a long packet of digital communication, can be recorded in the stream block without fragments, independently of the packet size.
When a space remains in the stream block, padding data (that can be recognized as information of an unrecorded area) is recorded in the remaining space. More specifically, as shown by (b) in
In (d) of
Information similar to said sector data header is also recorded in sector data header information 613 (
Information pieces of stream block information 612 in which recorded is information relating to whole stream block are:
The above stream block time difference can be calculated as follows, when (b) in
[stream block time difference]=[the value of first timestamp in stream block #2]−[the value of timestamp a]
Formatter unit 90 in
In D-PRO unit 52, input data is grouped with 16 sectors to form an ECC block, and the ECC block is sent to disc drive unit 51.
Note that the sent ECC block data is sent to temporal storage unit 53 to temporarily store it, when disc drive unit 51 is not yet in a recordable condition, and the system waits for the preparation of recording. When disc drive unit 51 is in the recordable condition, the data stored in temporal storage unit 53 is read out to start the recording on the information storage medium.
The flow of signals in the stream data recording/reproducing apparatus according to an embodiment of the present invention will be as follows.
As mentioned, the structure of stream data to be recorded on information storage medium 50 is changed by formatter unit 90 to the data structure as shown by (c), (i) of
In an embodiment of the present invention, assume that the same transport packet is prohibited from being recorded across different stream blocks. Under this assumption, when the timestamp and packet data both temporarily stored in a buffer memory are segmented for each stream block, it is necessary to completely include a pair of the timestamp and transport packet within one stream block.
On the other hand, according to an embodiment of the present invention, the same transport packet can be recorded across different sectors (e.g., No. 0 and No. 1 shown by (d) in
In digital broadcasting, video information is compressed according to MPEG2 specification, and the resultant I-, B-, and P-picture information is recorded in different transport packets. Then, these transport packets are transmitted.
The transport packet is constituted by a transport packet header and payload.
In the first one of transport packets wherein I-picture information is recorded, a flag of the random access indicator (corresponding to AUSM of (c) in
Information of the random access indicator (AUSM) and information of the payload unit start indicator are used to prepare I-picture mapping table 641 (table of an access unit start map) and B, P-picture start position mapping table 642 (table of an access unit end map). These tables are shown by (e) in
Each mapping table in transport packet mapping table 632 shown by (d) in
For instance, when “n” transport packets are recorded in one stream block, the value of number of transport packet 631 shown by (d) in
In this case, each mapping table in (e) of
Sector data headers 12 and 13 as shown by (c) and (i) in
As shown in
As shown by (b) in
In the example shown by (b) in
According to an embodiment of the present invention, a value larger than the size of data areas 21-24 can be used as the value of first access point 651. By so doing, it is possible to specify the leading position of timestamp of a large packet which has a size larger than the sector size.
For instance, in the data structure of (d) in
Under the above assumption, the value of the first access point for sector No. 0 is “0”, the value of the first access point for sector No. 1 is “size of data area 22 of sector No. 1 plus T”, and the value of the first access point for sector No. 2 is “T”.
According to an embodiment of the present invention, reproduction or playback will be started basically from the start portion of the stream block. However, in a rare case, reproduction could be started from the leading portion of an ECC block which belongs to the second or subsequent one of ECC blocks in the stream block.
As in the case of
For this, special header information (cf. the sector data header as shown by (a) in
SOB (stream object) is stream data which belongs to an original PGC (program chain). The data structure of SOB complies with Program Stream prescribed in “Information Technology-Generic coding of moving pictures and associated audio: Systems (ISO/IEC 13818-1)”. A SOB is formed of only one type of data, that is stream data.
SOB data structure is defined as a sequence of Stream Packs, which have a fixed size of 2048 bytes. This is the same size as the Logical Block size of the DVD disc family, and every Stream Pack shall be recorded in a Logical Block.
More specifically, (1) a system header shall not be included in SOB; (2) a SCR (System Clock Reference) value in the first pack of SOB may have any value; (3) an MPEG_program_end_code shall not be included in SOB; and (4) a stream_id shall be equal to BFh (private_stream—2) in all PES packets.
Navigation data is provided to control the recording, playing back (or reproducing), and editing of any bitstreams. In DVD Stream Recording, navigation data is called “Streamer Information (STRI)”.
That is, STRI is constituted by (1) Streamer Video Manager (STR_VMGI); (2) Stream File Information Table (SFIT); (3) Original PGC Information (ORG_PGCI); (4) User Defined PGC information Table (UD_PGCIT); (5) Text Data Manager (TXTDT_MG); and (6) Application Private Data Manager (APDT_MG).
STR_VMGI, SFIT, ORG_PGCI, UD_PGCIT, and TXTDT_MG of
On the other hand, APDT_MG of
Stuffing coded as “00h” may or may not be inserted between tables of above (1)-(6) unless the size of STRI exceeds 512 kB, but no stuffing shall be inserted within a table of above (1)-(6)
Incidentally, most of information described in SR_MANGER.IFO is supposed to be kept in the system memory of streamer instruments (e.g.,
Streamer Video Manager Information STR_VMGI of
Stream File Information SFIT contains all navigation data which are directly relevant to the Streamer operation. As shown, SFIT is formed of one instance of Stream File Information Table Information (SFITI), zero or more instances of Stream Object Stream Information (SOB_STI), and zero or one instance of Stream File Information (SFI).
Stream File Information Table Information SFITI includes SFI_Ns indicating the number of stream files; SOB_STI_Ns indicating the number of SOB stream information items; SFIT_EA indicating the end address of SFIT; and SFI_SA indicating the start address of SFI.
As shown, Stream File Information SFI is formed of (1) Stream File General Information (SF_GI); (2) one or more (n pieces) SOB Information Search Pointers (SOBI_SRP#n); and (3) one or more (n pieces) SOB Information (SOBI#n).
Stream File General Information SF_GI includes SOBI_Ns indicating the number of SOBIs; SOBU_SIZ indicating the size of SOBU by the number of sectors per SOBU; and MTU_SHFT indicating a mapping time unit shift.
SOBU_SIZ describes the size in sectors of the SOBU, and is defined as the fixed value 32. This means that in each mapping list the first entry relates to the application packets contained in the first 32 sectors of the SOB, the second entry relates to the application packets contained in the next 32 sectors, and so on.
The mapping time unit shift MTU_SHFT describes the weight of the LSB (least significant bit) of the mapping list entries, relative to the bits of the PAT describing format. This MTU_SHFT shall be described as 18.
As shown, each Stream Object Information SOBI is formed of (1) Stream Object Information General Information (SOBI_GI); (2) Mapping List (MAPL); and (3) (optional) Access Unit Data (AUD).
As shown in
SOB_TY describes the Stream Object Type, containing bits for Temporal Erase state and for Copy Generation Management System.
SOB_REC_TM describes the recording time of the associated Stream Object in DVD Stream Recording's Date and Time Describing Format.
SOB_STI_N describes the index of the SOB_STI which is valid for this SOB.
AUD_FLAGS describes whether and what kind of Access Unit Data (AUD) exists for this SOB. If AUD exists, then AUD_FLAGS also describes several properties of the AUD.
The AUD itself is constituted by some general information including the table AUSM and the optional tables AUEM and PTSL (Presentation Time Stamp List; cf.
SOB_S_APAT describes the start Application Packet Arrival Time of the Stream Object, i.e., the packet arrival time of the first packet belonging to the SOB. SOB_S_APAT is described in DVD Stream Recording's PAT Describing Format.
PATs (Packet Arrival Times) are divided into two parts, namely 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.
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 DVD Stream Recording's PAT Describing Format.
SOB_S_SOBU describes the number of the start Stream Object Unit, i.e., the Stream Object Unit containing the first Application Packet of the Stream Object.
MAPL_ENT_Ns describes the number of Mapping List entries to follow after SOBI_GI.
Access Unit Data AUD (optional), if any, is formed of (1) Access Unit General Information (AU_GI); (2) Access Unit End Map (AUEM); and (3) Presentation Time Stamp List (PTSL). Which of these parts exist may be indicated by AUD_FLAGS of SOBI_GI.
AU_GI only exists, when AUD_FLAGS of SOBI_GI indicates that Access Unit Data exists.
Access Unit General Information AU_GI includes AU_Ns indicating the number of Access Units, and AUSM indicating Access Unit Start Map (MAPL_ENT_Ns elements).
AU_Ns describes the number of Access Units for SOB. At the same time, AU_Ns describes the number of locations of Access Units, where AUSM indicates the existence of an Access Unit.
The Access Unit Start Map (AUSM) indicates which of SOBUs of the SOB contain Access Units. For each SOBU of the SOB, exactly one AUSM element exists. So, the AUSM is formed of MAPL_EN_TNs elements.
Each AUSM element indicates an accessible Access Unit beginning somewhere within the corresponding SOBU, or within the subsequent SOBU. Exactly AU_Ns Access Units are indicated by the AUSM, equivalent to exactly AU_Ns bits of AUSM being equal to 1b (binary bit “1”).
AUSM shall be byte aligned. If the concatenated AUSM elements are formed of a number of bits which is not an integer multiple of 8, then the remaining LSBs (least significant bits) of the last byte of the AUSM shall be padded with 0b (binary bit “0”).
As will be seen from the illustration, each portion of bit “1” in AUSM indicates that the corresponding SOBU contains Access Unit (AU#).
Assume that AUSM_pos(i) is the bit position of the i-th set bit in AUSM (i≦i≦AU_Ns). Under this assumption, the location of the AU can be defined as follows:
(1) If SOBU#i, indicated by AUSM_pos(i), contains more than one starting AU described by AU_START and AU_END marks (if any) inside the stream, then AUSM_pos(i) is assigned to the first AU starting in SOBU#i which is located inside the SOBUs described by AUSM_pos(i) and (if AUEM exists) AUEM_pos(i).
(2) An AU ends with the first occurring AU_END mark after the start of this AU, and an AU ends with the last SOBU indicated by the assigned AUEM element (if AUEM exists).
Note that with this kind of Access Unit Data, no more than one addressable Access Unit can be described per each SOBU of the SOB.
AUEM, if exists, is a bit array of the same length as AUSM. The bits in AUEM indicate which of the SOBUs contain the end of the bitstream segment associated with the Access Units of the SOB.
The number of bits set in AUEM shall be equal to the number of bits set in AUSM, i.e., each set bit in AUSM has its corresponding set bit in AUEM.
Assume that AUSM_pos(i) is the bit position of the i-th set bit in AUSM (i≦i≦AU_Ns), and that AUEM_pos(i) is the bit position of the i-th set bit in AUEM (i≦i≦AU_Ns). Under this assumption, the following conditions are obtained:
(1) 1≦AUSM_pos(i)≦AUEM_pos(i)≦MAPL_ENT_Ns;
(2) AUSM_pos(i+1)>AUEM_pos(i);
(3) If i==AU_Ns, or if AUSM_pos(i+1)>1+AUEM_pos(i), then AU#i ends in SOBU#[AUEM_pos(i)], where 1≦i≦AU_Ns;
(4) If AUSM_pos(i+1)==1+AUEM_pos(i), then the AU#i ends in SOBU#[AUEM_pos(i)], or ends in SOBU#[1+AUEM_pos(i)]==SOBU#[AUSM_pos(i+1)]. Thus, AU#i may end in the SOBU in which AU#i+1 starts (1≦i≦AU_Ns).
As shown, one stream pack (2048 bytes) is formed of a pack header (14 bytes) and a stream PES packet (2034 bytes).
The pack header of the stream pack has 14-byte size. The first 4 bytes (000001BAh) of the pack header record a pack start code. Next 6 bytes of the pack header are defined by a provider and they record the base of system clock reference (SCR_base; total 32 bits), marker bits, and the extension of system clock reference (SCR_extension; 9 bits). The subsequent 3 bytes (0189C3h) of the pack header record a program-multiplex rate (program_mux_rate; 22 bits) and marker bits. The last 1 byte (F8h) of the pack header records a pack stuffing length (pack_stuffing_length; 3 bits) and has reserved area (5 bits).
Note that the 32nd bit of the SCR_base[32] shall be set to zero and the “program_mux_rate” shall be set to 10.08 Mbps.
In stream recording, the application performs its own stuffing, so that the pack length adjustment methods of DVD-ROM Video or DVD-VR need not be used. In stream recording, it is safe to assume that the stream packets will always have the necessary length.
The stream PES packet of the stream pack has the following data structure.
As shown, one stream PES packet (2034 bytes) is formed of a PES header (6 bytes), a substream ID (1 byte), and a stream data area (2027 bytes).
The first 3 bytes (000001h) of the PES packet header of stream PES packet record a prefix of packet start code (packet_start_code_prefix; 24 bits). The next 1 byte records a stream ID (stream_id=10111111b; 8 bits). The subsequent 2 bytes (07ECh) record a length of PES packet (PES_packet_length). The last 1 byte records a substream ID (sub_stream_id=00000010b; 8 bits).
The stream data area (2027 bytes) inside a stream packet shown in
The application packet area of
The application packet area may have a configuration similar to (b) in
In other words, at the start of the application packet area, there may exist, in general case, a partial application packet. At the end of the application packet area, there may exist, in general case, another partial application packet or a stuffing area of “reserved” bytes.
The application timestamp (ATS) in front of each application packet has a 32-bit value. An ATS is divided into two parts, namely 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.
In
Therefore, a data field in the application header is defined to describe the presence of the optional application header extension in the stream data area.
At stream recording, the first byte of the application timestamp ATS of the first application packet shall be aligned to the start of the application packet area in the first stream packet at the beginning of a stream object SOB.
Any following stream packets in a SOB may split (or divide) application packets across stream packet boundaries. The partial application packets shown in
The byte offset of the first application timestamp that starts in a stream packet, as well as the number of application packets starting in the stream packet, shall be described in its application header (cf.
This mechanism automatically allows for stuffing in front of the first application timestamp and after the last application packet in a stream packet.
The above automatic mechanism corresponds to “the application performs its own stuffing” described in the explanation of
The optional application header extension is formed of a list of entries, where there is exactly one entry of 1 byte length for each application packet which starts in the stream packet. These bytes of the entries are used to store information that may differ from application packet to application packet.
In the optional application header extension (1 byte), AU_START (1 bit), AU_END (1 bit), and COPYRIGHT (2 bits) are described.
When AU_START is set to “1”, this indicates that the associated application packet contains a random access entry point (start of a random access unit) in the stream.
When AU_END is set to “1”, this indicates that the associated application packet is the last packet of a random access unit.
COPYRIGHT describes the copyright status of the associated application packet.
The application header contains 1-byte VERSION (01h); 1-byte AP_Ns; 2-byte FIRST_AP_OFFSET; 2-bit EXTENSION_HEADER_INFO (00b, 10b, or 11b); 1-bit reserved for CCI_ESC; 5-bit reserved area; 2-byte SERVICE_ID; 1-byte MAX_BR_LOG 2; and 1-byte SMO_BS_LOG 2.
The VERSION describes the version number of the application header format.
The AP_Ns describes the number of application packets which are starting in the stream packet. An application packet is considered to be starting in a stream packet, if the first byte of its application timestamp is stored in that stream packet.
The FIRST_AP_OFFSET describes the position of the timestamp of the first application packet, which starts in the stream packet, relative to the first byte of the stream pack, in bytes. If no application packet starts in the stream packet, FIRST_AP_OFFSET shall be set to “0”.
The EXTENSION_HEADER_INFO describes whether an application header extension and/or a stuffing byte exist in the stream pack.
When EXTENSION_HEADER_INFO=00b, no application header extension follows this application header and no stuffing byte exists.
When EXTENSION_HEADER_INFO=10b, an application header extension follows this application header but no stuffing byte exists.
When EXTENSION_HEADER_INFO=11b, an application header extension follows this application header and a stuffing byte exists after the application header extension as well.
Here, EXTENSION_HEADER_INFO=01b is prohibited. The optional stuffing byte in front of the application packet area can be activated (EXTENSION_HEADER_INFO=11b) to avoid a “packing paradox”, where a contradiction exists between the number of bytes in the application header extension and the number of application packets which can be stored in the application packet area.
The SERVICE_ID describes an ID for the service that generated the stream. If the service is unknown, 0x0000 shall be described.
The MAX_BR_LOG 2 describes the binary logarithm of the output bitrate parameter of the leaky bucket flow control model.
The SMO_BS_LOG 2 describes the binary logarithm of the buffer size parameter of the leaky bucket flow control model.
To restate, according to the present invention, AUSM, AUEM and/or support information can be recorded and, hence, user friendly data management can be achieved.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the invention in its broader aspects is not limited to the specific details and representative embodiments shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
11-007842 | Jan 1999 | JP | national |
This application is a Divisional of and is based upon and claims the benefit of priority under 35 U.S.C. §120 for U.S. Ser. No. 11/829,562, filed Jul. 27, 2007, which is a divisional of U.S. Pat. No. 7,346,266, filed Sep. 3, 2002, which is a Continuation of U.S. Ser. No. 09/805,876, filed Mar. 15, 2001 (now abandoned), which is a Divisional of U.S. Pat. No. 7,076,153, issued Jul. 11, 2006, and claims the benefit of priority under 35 U.S.C. §119 from Japanese Patent Application No. 11-007842, filed on Jan. 14, 1999. The entire contents of each of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5801781 | Hiroshima et al. | Sep 1998 | A |
5809201 | Nagasawa | Sep 1998 | A |
5838678 | Davis et al. | Nov 1998 | A |
5918020 | Blackard et al. | Jun 1999 | A |
5923811 | Kawamura et al. | Jul 1999 | A |
6034942 | Yoshio et al. | Mar 2000 | A |
6078727 | Saeki et al. | Jun 2000 | A |
6112009 | Kikuchi et al. | Aug 2000 | A |
6118927 | Kikuchi et al. | Sep 2000 | A |
6166735 | Dom et al. | Dec 2000 | A |
6470135 | Kim et al. | Oct 2002 | B1 |
6701059 | Yoo et al. | Mar 2004 | B1 |
6813437 | Ando et al. | Nov 2004 | B2 |
7574118 | Ando et al. | Aug 2009 | B2 |
20030113096 | Taira et al. | Jun 2003 | A1 |
20080069523 | Hyodo et al. | Mar 2008 | A1 |
Number | Date | Country |
---|---|---|
0737975 | Oct 1996 | EP |
6-139704 | May 1994 | JP |
6-314176 | Nov 1994 | JP |
7-87443 | Mar 1995 | JP |
07-141116 | Jun 1995 | JP |
07-193785 | Jul 1995 | JP |
07-226032 | Aug 1995 | JP |
7-284060 | Oct 1995 | JP |
7-311950 | Nov 1995 | JP |
08-124309 | May 1996 | JP |
8-125971 | May 1996 | JP |
08-195072 | Jul 1996 | JP |
08-205085 | Aug 1996 | JP |
08-235832 | Sep 1996 | JP |
08-306137 | Nov 1996 | JP |
8-306137 | Nov 1996 | JP |
8-339637 | Dec 1996 | JP |
9-98381 | Apr 1997 | JP |
9-139914 | May 1997 | JP |
9-139937 | May 1997 | JP |
9-204758 | Aug 1997 | JP |
9-219085 | Aug 1997 | JP |
9-247619 | Sep 1997 | JP |
9-251762 | Sep 1997 | JP |
9-322148 | Dec 1997 | JP |
10-125003 | May 1998 | JP |
10-322661 | Dec 1998 | JP |
2000-195170 | Jul 2000 | JP |
2000-217066 | Aug 2000 | JP |
2002-157840 | May 2002 | JP |
2005-243235 | Sep 2005 | JP |
WO9523411 | Aug 1995 | WO |
WO 9707506 | Feb 1997 | WO |
Entry |
---|
Japanese Office Action issued Mar. 6, 2016 in Patent Application No. 2010-087281 with English translation. |
Office Action issued on Jan. 8, 2013, in Japanese patent Application No. 2011-209929 with English translation. |
Number | Date | Country | |
---|---|---|---|
20130315572 A1 | Nov 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11829562 | Jul 2007 | US |
Child | 13953267 | US | |
Parent | 10232814 | Sep 2002 | US |
Child | 11829562 | US | |
Parent | 09482085 | Jan 2000 | US |
Child | 09805876 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09805876 | Mar 2001 | US |
Child | 10232814 | US |