INFORMATION STORAGE MEDIUM, INFORMATION RECORDING METHOD, INFORMATION PLAYBACK METHOD, INFORMATION RECORDING APPARATUS, AND INFORMATION PLAYBACK APPARATUS

Abstract
This invention provides a scheme that can indicate whether or not a plurality of objects have logical continuity when there are plurality of objects recorded by stream recording. Management information of a storage medium includes information indicating continuity between a plurality of objects. When the plurality of objects include leading and trailing objects, and the information indicating continuity includes a continuous recording flag indicating that the trailing and leading objects are continuously recorded.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is based upon and claims the benefit of priority from prior Japanese Patent Application No. 2004-353392, filed Dec. 6, 2004, the entire contents of which are incorporated herein by reference.


BACKGROUND OF THE INVENTION

1. Field of the Invention


The invention relates to an information storage medium (or data structure), an information recording/playback method, and an information recording/playback apparatus, which are suited to record/play back a digital stream signal used in digital TV broadcast or the like.


2. Description of the Related Art


In recent years, TV broadcasting has entered the era of digital broadcasts having Hi-Vision programs (programs of high-definition AV information) as principal broadcast contents. The current digital broadcast (and forthcoming terrestrial digital broadcast) adopts an MPEG2 transport stream (to be abbreviated as MPEG-TS hereinafter). In the field of digital broadcast using moving pictures, MPEG-TS will be used as a standard format in the future. At the start of such digital TV broadcasting, market needs for a streamer that can directly record digital TV broadcast contents are increasing.


As an example of a streamer that utilizes an optical disc such as a DVD-RAM or the like, “A recording/playback apparatus” (Jpn. Pat. Appln. KOKAI Publication No. 2002-84479) is known.


For example, when a long music program in which a short news program is inserted (NHK Red & White Year-end Song Festival BS digital broadcasted on the new year eve) is stream-recorded in a news cut mode (video recording is paused at the news part), a stream object of a recorded program is divided into two stream objects at the news cut part. In such case, the two stream objects are normally continuously recorded at physically neighboring locations. However, these stream objects may be discontinuously recorded at physically separate locations. In this example, the playback times of the contents of the two stream objects are logically continuous independently of whether or not the two stream objects are physically continuous. The same applies to a case wherein one movie in which CMs are inserted is stream-recorded in a CM cut mode. Even when physical discontinuity occurs among a plurality of stream objects at CM cut parts, the playback times as a series of movie contents are logically continuous.


On the other hand, when program A of channel X is stream-recorded, and program B of channel Y is then stream-recorded, the playback times of the contents of stream objects of programs A and B are not continuous (logically discontinuous) even when their recording locations are physically continuous.


In this manner, when stream video recording is made by a plurality of stream objects, whether or not neighboring stream objects have logical continuity (continuity of playback times in a single program) in place of physical continuity influences the decoding process (setting process of system time clock STC and the like) upon playback. More specifically, when the STC setting is inappropriately made (STC reset, etc.) without recognizing continuity of playback times, a wait time by means of still picture display may be generated for a relatively long period of time when playback shifts from the end of the former stream object of a single program to the head of the latter stream object.


BRIEF SUMMARY OF THE INVENTION

According to an embodiment of the invention, management information (ESOBI in HR_SFIxx.IFO in FIG. 11) of a storage medium is configured to include information (ESOB_SMLI in FIG. 22) indicating continuity between a plurality of objects. In this configuration, when the plurality of objects include leading and trailing objects, the information (ESOB_SMLI in FIG. 22) indicating continuity can include a continuous recording flag which indicates that the trailing object is continuously recorded with the leading object.


When the contents of the plurality of objects are included in MPEG-encoded transport stream packets (MPEG-TS packets in FIG. 38) and each transport stream packet includes time information (PCR or the like) corresponding to a system time clock (STC), the information (ESOB_SMLI in FIG. 22) indicating continuity can include a system time clock continuous flag indicating whether or not the system time clocks (STC) are continuous between the plurality of neighboring objects. Furthermore, when each transport stream packet includes its arrival time information (PATS), the information (ESOB_SMLI in FIG. 22) indicating continuity can also include a packet arrival time continuous flag indicating whether or not a plurality of pieces of arrival time information are continuous between the plurality of neighboring objects.


When there are a plurality of objects recorded by stream recording such as MPEG-TS or the like, whether or not these objects have logical continuity can be detected from the information (ESOB_SMLI in FIG. 22) indicating continuity.




BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING


FIG. 1 is a view for explaining the data structure according to an embodiment of the invention;



FIG. 2 is a view for explaining the relationship among a playback management information layer, object management information layer, and object layer in the data structure according to the embodiment of the invention;



FIG. 3 is a view for explaining the file structure according to the embodiment of the invention;



FIG. 4 is a view for explaining an example of the configuration of a field (HDVR_MGI) of management information recorded on AV data management information recording area 130;



FIG. 5 is a view for explaining a practical example of DISC_RSM_MRKI;



FIG. 6 is a view for explaining a practical example of EX_DISC_REP_PICI;



FIG. 7 is a view for explaining a practical example of EX_PL_SRPT;



FIG. 8 is a view for explaining an example of the configuration of another field (EX_M_AVFIT) of one management information (HDVR_MG) in the data structure according to the embodiment of the invention;



FIG. 9 is a view for explaining a practical example of EVOB_TMAP_GI;



FIG. 10 is a view for explaining an example of the configuration of ESTR_FI;



FIG. 11 is a view for explaining a practical example of HR_SFIxx.IFO;



FIG. 12 is a view for explaining an example of the configuration of ESOBI_GI;



FIG. 13 is a view for explaining various kinds of information included in the ESOBI_GI;



FIG. 14 is a view for explaining an example of the configuration of ESOB_ESI;



FIG. 15 is a view for explaining an example of the configuration of ESOB_V_ESI and an example of the configuration of video attribute V_ATTR included in this ESOB_V_ESI;



FIG. 16 is a view for explaining an example of the configuration of ESOB_A_ESI and an example of the configuration of audio attribute AUDIO_ATTR included in this ESOB_A_ESI;



FIG. 17 is a view for explaining an example of the configuration of ESOB_OTHER_ESI;



FIG. 18 is a view for explaining an example of the configuration of copy control information (copyright protection information) CP_CTL_INFO;



FIG. 19 is a view for explaining a practical example of ESOB_DCNI;



FIG. 20 is a view for explaining an example of the configuration of ESOB_GPI;



FIG. 21 is a view for explaining an example of the configuration of ESOB_GPI_GI, GPI_SRP#, and GPI#;



FIG. 22 is a view for explaining an example of the configuration of ESOB_SMLI;



FIG. 23 is a view for explaining an example of the configuration of ESOB_TMAP (type A);



FIG. 24 is a view for explaining an example of the configuration of ESOB_TMAP (type B);



FIG. 25 is a view for explaining an example of the configuration of HR_VTMAP.IFO and HR_STMAPx.IFO included in the DVD_HDVR directory;



FIG. 26 is a view for explaining an example of the configuration of EX_VTMAPTI, each EX_VTMAP_SRP#, and each EX_VTMAPI;



FIG. 27 is a view for explaining an example of the configuration of the contents of each EVOBU_ENT#;



FIG. 28 is a view for explaining an example of the configuration of various kinds of information included in STMAPT (type A);



FIG. 29 is a view for explaining an example of the configuration of various kinds of information included in STMAPT (type B);



FIG. 30 is a view for explaining an example of information stored in ETMAPI_GI and ETMAPI#;



FIG. 31 is a view for explaining an example (example of type A) of the configuration of the contents of ESOBU_ENT#;



FIG. 32 is a view for explaining an example (example of type B) of the configuration of the contents of AT_ESOBU_ENT#;



FIG. 33 is a view for explaining an example of the configuration of PGC information (EX_ORG_PGC information and EX_playlist information/EX_UD_PGC information) included in HDVR_VMG;



FIG. 34 is a view for explaining an example of the configuration of EX_PGC information;



FIG. 35 is a view for explaining a practical example of EX_CI;



FIG. 36 is a view for explaining a practical example of C_EPI; .



FIG. 37 is a view for explaining an example of the configuration of PTM of ESOB (or EVOB);



FIG. 38 is a view for explaining an example of the configuration of a data unit (ESOBU) for a stream object;



FIG. 39 is a view for explaining a practical example of PKT_GRP_GI;



FIG. 40 is a view for explaining an example of the configuration of copy control information CCI# included in a packet group header;



FIG. 41 is a view for explaining an example of the configuration of FIRST_PATS_EXT;



FIG. 42 is a view for explaining a practical example of MNI;



FIG. 43 is a block diagram for explaining an example of an apparatus for recording and playing back AV information (digital TV broadcast program and the like) on and from an information storage medium (optical disc, hard disc, or the like) using the data structure according to the embodiment of the invention;



FIG. 44 is a flowchart (overall operation process flow) for explaining an example of the overall operation of the apparatus shown in FIG. 43;



FIG. 45 is a flowchart (edit operation process flow) for explaining an example of an edit process (ST28);



FIG. 46 is a flowchart for explaining an example of a video recording operation (part 1);



FIG. 47 is a flowchart for explaining an example of a video recording operation (part 2);



FIG. 48 is a flowchart (ESOB delimitation process flow) for explaining an example of an ESOB segmentation process (ST160);



FIG. 49 is a flowchart (buffer fetch process flow) for explaining an example of a buffer fetch process (ST130);



FIG. 50 is a flowchart (buffer fetch process flow) for explaining another example of FIG. 49;



FIG. 51 is a flowchart (PKT_GRP_GI setting process flow) for explaining an example of a packet group general information setting process (ST1340);



FIG. 52 is a flowchart (ESI setting process flow) for explaining a stream information (ESI) generation process (ST120);



FIG. 53 is a flowchart for explaining an example of a stream file information (ESTR_FI) generation process in a video recording end process (ST150);



FIG. 54 is a flowchart for explaining an example GPI setting process ST1530;



FIG. 55 is a flowchart for explaining an example TMAP setting process ST1540;



FIG. 56 is a flowchart for explaining EVOB/ESOB structure setting process ST15400;



FIG. 57 is a flowchart for explaining CP_CTL_INFO (CCI) generation process ST1220;



FIG. 58 is a flowchart (program setting process flow) for explaining an example of a program chain (PGC) generation process (including a program setting process) in the video recording end process (ST150);



FIG. 59 is a flowchart (overall playback operation flow) for explaining an example of a playback operation;



FIG. 60 is a flowchart for explaining a decoder setting process (ST217);



FIG. 61 is a flowchart for explaining an example of a process upon cell playback;



FIG. 62 is a flowchart for explaining an ESOB continuity check process (ST2201);



FIG. 63 is a flowchart for explaining an example of a data transfer process from a buffer RAM to a decoder;



FIG. 64 is a flowchart for explaining an example of a GP switching setting process;



FIG. 65 is a flowchart for explaining an example of a discontinuity process; and



FIG. 66 is a flowchart for explaining an example of a skip process.




DETAILED DESCRIPTION OF THE INVENTION

Various embodiments of the invention will be described hereinafter with reference to the accompanying drawings. An MPEG-TS scheme as a basic format common to broadcast schemes which broadcast (distribute) compressed moving picture data such as a digital TV broadcast, or a broadcast that uses a wired network such as the Internet or the like, and so on is divided into a packet management data field and payload.


The payload includes data to be played back in a scrambled state. According to ARIB, a PAT (Program Association Table), PMT (Program Map Table), and SI (Service Information) are not scrambled. Also, various kinds of management information are generated using the PMT and SI (SDT: Service Description Table, EIT: Event Information Table, BAT: Bouquet Association Table).


The contents to be played back include MPEG video data, Dolby AC3 audio data, MPEG audio data, data broadcast data, and the like. Also, the contents include information required upon playback (e.g., PAT, PMT, SI, and the like) although they are not directly related to the contents to be played back. The PAT includes the PID (Packet Identification) of the PMT for each program, and the PMT records the PIDs of video data and audio data.


A normal playback sequence of an STB is as follows. That is, when the user determines a program based on EPG information, the PAT is loaded at the start time of the target program. The PID of a PMT, which belongs to the desired program, is determined on the basis of that data, and the target PMT is read out in accordance with that PID. Then, the PIDs of video and audio packets to be played back, which are included in the PMT, are determined. Video and audio attributes are read out based on the PMT and SI and are set in respective decoders. The video and audio data are extracted and played back in accordance with their PIDs. Note that the PAT, PMT, SI, and the like are transmitted at intervals of several 100 ms since they are also used during playback.


Different digital broadcast schemes are adopted in respective countries and broadcast stations: for example, DVB (Digital Video Broadcasting) in Europe; ATSC (Advanced Television Systems Committee) in U.S.A.; and ARIB (Association of Radio Industries and Businesses) in Japan.


In DVB, the video format is MPEG2, the resolutions are 1152*1440i, 1080*1920(i, p), 1035*1920, 720*1280, (576, 480)*(720, 544, 480, 352), and (288, 240)*352, the frame frequencies are 30 Hz and 25 Hz, the audio format includes MPEG-1 audio and MPEG-2 Audio, and the sampling frequencies are 32 kHz, 44.1 kHz, and 48 kHz.


In ATSC, the video format is MPEG2, the resolutions are 1080*1920(i, p), 720*1280p, 480*704(i, p), and 480*640(i, p), the frame frequencies are 23.976 Hz, 24 Hz, 29.97 Hz, 30 Hz, 59.94 Hz, and 60 Hz, the audio format includes MPEG1 Audio Layer 1 & 2 (DirecTV) and AC3 Layer 1 & 2 (Primstar), and the sampling frequencies are 48 kHz, 44.1 kHz, and 32 kHz.


In ARIB, the video format is MPEG2, the resolutions are 1080i, 720p, 480i, and 480p, the frame rates are 29.97 Hz and 59.94 Hz, the audio format includes AAC (MPEG-2 Advanced Audio Coding), and the sampling frequencies are 48 kHz, 44.1 kHz, 32 kHz, 24 kHz, 22.05 kHz, and 16 kHz.


In this manner, digital broadcast schemes are different in different countries, and may be different for respective broadcast stations. For this reason, a recorder must record objects as one or a plurality of files in accordance with each individual scheme to be used. For this reason, files to be further added to the existing VR file configuration are configured to allow the presence of a plurality of “x”s in the file names HR_SFIX.IFO and HR_SFIx.bup, as shown in FIG. 3. One or more files with such configuration are added for respective broadcast schemes. For example, when “x”=00, such files can be used when the broadcast scheme is unknown or the recorder does not support that broadcast scheme. In this case, a stream whose broadcast scheme is unknown or a stream which is not supported by the recorder can be saved as a stream (SOB_STRB) of TYPE B. Hence, since ESTR_FI as management information for digital broadcast is changed for each broadcast station (or each broadcast scheme), a plurality of pieces of ESTR_FI exist.



FIG. 10 is a view for explaining an example of the configuration of ESTR_FIT. In this configuration, one or more pieces of file search pointer information ESTR_FI_SRP exist so as to designate ESTR_FI files to be used. As shown in FIG. 10, the structure of each ESTR_FI_SRP includes file name ESTR_FI_FN of ESTR_FI, update date information ESTR_FI_LAST_MOD_TM of the ESTR_FI file, ESTR_FI file size ESTR_FI_SZ, AP_FORMAT_1 as broadcast scheme information, country code Count_code, packet type PKT_TY, the number ESOBI_Ns of pieces of ESOBI, and the like. Note that the update date information is also set in the ESTR_FI file. When ESTR_FI is changed upon editing, that value is updated. Upon playback, the updated value is compared with the value in the ESTR_FI file. If the two values are the same, playback is permitted. The number of pieces of ESTR_FI is seven or less, and the number of pieces of ESOBI is 999 or less. A part “nn” of ESTR_FI file name: HR_SFInn.IFO is reflected in File Name: HR_STMnn.IFO of an STMAP, thus determining the file name of the STMAP.



FIG. 11 is a view for explaining a practical example of HR_SFIxx.IFO. The ESTR_FI file (HR_SFIxx.IFO) has the same configuration as that of normal ESTR_FI, as shown in FIG. 11. Furthermore, in case of a cognizable stream (STRA of TYPE A), a TMAP can be generated on the PTM base. However, in case of a non-cognizable stream (when data cannot be descrambled or when data of a scheme different from the assumed broadcast station is input: STRB of TYPE B), the TMAP may be generated in a reception time (PATS) base in place of PTM base. However, since the PATS is not a playback time, special playback or the like which is accurate in terms of time cannot be made, but rough special playback (fastforwarding playback, rewinding playback, or the like which allows the user to roughly confirm the recorded contents) can be made.


In FIG. 11, PATS_SS includes a value indicating the accuracy of the PATS. For example, when an apparatus shown in FIG. 43 to be described later fetches data itself of a network, IEEE1394, or the like, the PATS includes 4 bytes or is a dummy in some cases. In order to cope with such case, PATS_SS values “00=both PATS and FIRST_PATS_EXT (see FIG. 41) are valid: accuracy 6 bytes)”, “01=only PATS is valid: accuracy 4 bytes”, and “10=both PATS and FIRST_PATS_EXT are invalid: no accuracy” are prepared.


As one of the features of digital broadcasting, for example, multi-view broadcast is known. In multi-view broadcast, a plurality of video data are broadcasted at the same time (by time sharing), and the user can play back one of these video data of his or her choice. In this manner, the user can select one of a plurality of contents according to his or her favor or the like. For example, when a recorder receives, as one TS, streams X, Y, and Z as multi-view broadcast and stream U as rain attenuation broadcast, the control must be made to allow the user to select and play back a required stream upon playback, and to freely switch among streams using a key. To cope with this, grouping information (GPI) is added to achieve this object.


Furthermore, a DVD recorder normally has TMAPI as VOB management information. This information is used to divide VOB/SOB for each VOBU/SOBU and to implement playback, special playback, and the like for that unit, and a maximum of one information is required per 0.5 s. For this reason, if the disc size increases in the future or a compression method with high compression efficiency is adopted, the number of pieces of TMAPI increases, and complex management is required when performing editing or the like. If TMAPI is stored in IFO, management data in other non-related fields must be moved or rewritten every time TMAPI is changed, resulting in poor efficiency. In order to improve such situation, TMAPI is recorded in an independent field.


Moreover, a video recorder may have unique functions which are not described in the DVD format, depending on the manufacturer and model, and may be differentiated from other manufacturers. In this case, manufacturer unique information must be embedded in object data. Hence, in the embodiment of the invention, MNFI (Manufacturer's Information) is assured in a packet group header as its field.



FIG. 1 is a view for explaining the data structure according to an embodiment of the invention. As shown in FIG. 1, data in a DVD disc include a volume/file structure information area that stores a file system, and a data area that actually records data files. The file system includes information indicating the recording locations of files. The data area is divided into areas that record general computer data, and an area that records AV data. The AV data recording area includes an AV data management information area that stores a VMG file used to manage AV data, a VR object group recording area that records object data (EVOBS) files (VRO files) complying with the video recording standard, and a recording area that records stream object data (ESOBS: Extended Stream Object Set) files (SRO files) which record objects (ESOBS) compatible to digital broadcast. Note that different directories are prepared in correspondence with formats (e.g., VIDEO-TS for DVD-Video (ROM Video) and DVD-RTAV for DVD-RTR (recordable/reproducible DVD), and the digital broadcast compatible DVD standard to be described below is recorded in, e.g., a DVD_HDVR directory.



FIG. 2 is a view for explaining the relationship among a playback management information layer, object management information layer, and object layer in the data structure according to the embodiment of the invention. That is, a DVD_HDVR directory (to be described later with reference to FIG. 3) records a VMG file used to manage data, VRO files as object files for analog recording of analog broadcast data, line-in data, and the like, and an SRO file as a digital broadcast object. The SRO file records an SOBS (Stream Object Set). As shown in FIG. 2, management data is recorded in the VMG file common to VR, and undergoes control common to VR. The management data is linked for each cell, and the playback location is designated for each playback time. This management data is called VR_MANGER.IFO. When a TMAPT is recorded as an independent file, HR_VTMAP.IFO and HR_STMAP.IFO, and HR_VTMAP.BUP and HR_STMAP.BUP as their backup files are added, as shown in FIG. 3.


The structure of each ESOBU includes one or more ESOB data. Each ESOB corresponds to, e.g., one program. The ESOB includes one or more ESOBUs (Extended Stream object units), each of which corresponds to object data for a given time interval (which changes depending on the value of ESOBU_PB_TM_RNG) or one or more GOP data. When the transfer rate is low, one GOP data cannot often be sent within 1 s (1 second) (VR can freely set the data unit configuration since it adopts internal encoding, but a digital broadcast cannot specify the next incoming data since encoding is done by a broadcast station). On the other hand, the transfer rate may be high, and I-picture data may be sent frequently. In such case, the ESOBU is delimited frequently, and ESOBU management information increases accordingly, thus ballooning the whole management information. For this reason, it is appropriate to delimit ESOBUs by a given time interval (a minimum limitation is to delimit ESOBUs by picture data except for the last ESOBU of the ESOB: the delimitation unit corresponds to an I-picture (e.g., for each sec)) or by one or more GOP data. When management information is formed on the PATS base in case of a non-cognizable stream, the ESOBUs are delimited at time intervals indicated by SOBU_PATS_TM_RNG. There are two types of SOBU_PATS_TM_RNG: it is designated in seconds or by a 27-MHz count value.


In this embodiment, one ESOBU includes one or more packet groups, each of which can correspond to 16 (or 32) logical blocks (1 LB=2048 bytes; 16 LBs=32640 bytes). Each packet group includes a packet group header and (170) TS packets. The arrival time of each TS packet can be expressed by a PAT (Packet Arrival Time: 4 bytes) which is allocated before each TS packet.


The arrival times of TS packets must be linearly counted up until a video recording end time to have a video recording start time as 0 (or a predetermined value). Note that the STC and PATS do not always indicate the same value (due to different default values or the like). However, the count interval of a PATS counter must be synchronized with that of an STC counter which corresponds to the interval between neighboring PCR fetch timings in a playback synchronized state. Note that the PCR is included in an adaptation field (not shown) in an MPEG-TS shown in FIG. 38. However, a packet group can include a maximum of two ESOBs. That is, packet groups need not be aligned for respective ESOBs.



FIG. 38 is a view for explaining an example of the configuration of a stream object data unit (ESOBU). As shown in FIGS. 38 to 42, a packet group header sets a sync pattern at the head of a packet group, and includes packet group general information PKT_GRP_GI, copy management information CCI (Copy Control Information), extended bytes FIRST_PATS_EXT of the PATS of the first packet, and manufacturer's information MNI (or MNFI).



FIG. 39 is a view for explaining a practical example of the PKT_GRP_GI. The PKT_GRP_GI includes packet group type PKT_GRP_TY (indicating an MPEG-TS packet group when PKT_GRP_TY=01), DVD BOOK version number VERSION supported by the packet group, status information PKT_GRP_SS of the packet group, and the number Valid_PKT_Ns of valid packet in the packet group. Note that the FIRST_PATS_EXT in the packet group header includes the upper 2 bytes of the PATS for the first packet.


Furthermore, the status information PKT_GRP_SS (FIG. 39) of the packet group includes bit STUF indicating if stuffing is done (if this bit is set, it indicates that the Valid_PKT_Ns assumes a value other than 0xAA), and PATS_SS. Note that the PATS_SS (see a description of FIG. 11) includes a value indicating the accuracy of the PATS (00=both PATS and FIRST_PATS_EXT are valid: accuracy 6 bytes), 01=only PATS is valid: accuracy 4 bytes, and 10=both PATS and FIRST_PATS_EXT are invalid: no accuracy).



FIG. 40 is a view for explaining an example of the configuration of copy control information CCI# included in a packet group header. CCI may store digital copy control (00=copy never, 01=copy once, 11=copy free), analog copy control (00=no APS, 01=APS type 1, 10=APS type 2, 11=APS type 3), EPN (0=contents protection, 1=no contents protection), and ICT (Image_Constraint_Token: 0=analog video output resolution constraint, 1=no constraint), or may also store retention information (that allows temporary storage for a time indicated by state when the “copy never” mode and Retention=0 are set when copy never is set). Note that APS is an abbreviation for “Analog Protection System”, and the embodiment of the invention assumes Macrovision.



FIG. 41 is a view for explaining a practical example of extended bytes FIRST_PATS_EXT of the PATS of the first packet. The FIRST_PATS_EXT corresponds to the upper 2 bytes of the arrival time of the packet at the head of the packet group, and the remaining 4 bytes are assigned before each packet. In this manner, the playback process with an accurate time is allowed.



FIG. 42 is a view for explaining a practical example of the manufacturer's information (MNI or MNFI). The MNI or MNFI includes MNF_ID and MNF_DATA. The MNF_ID is a value representing each manufacturer (vendor). The MNF_DATA after the MNF_ID is a data field which can be freely set for each vendor.


The management information will be described below with reference to FIGS. 3 to 37. FIG. 3 is a view for explaining the file structure according to the embodiment of the invention. As shown in FIG. 3, the HDVR directory stores HR_MANGER.IFO as a DVD management information file, VRO files as analog video object files, and an SRO file that supports digital broadcast.



FIG. 4 is a view for explaining an example of the configuration of a field (HDVR_MGI) of management information recorded on AV data management information recording area 130. In the VMG file as the management information, an ESTR_FIT (Extended Stream File Information table) is added to the management information of the conventional DVD-VR standard, as shown in FIG. 4.



FIG. 5 is a view for explaining a practical example of DISC_RSM_MRKI. The resume mark information (DISC_RSM_MRKI) of the whole disc is set to include program chain number PGCN, program number PGN, cell number CN, mark pointer information MRK_PT including playback start PTM and the like (including the PTM/PATS/S_ESOB_ENT number, and the like on a target ESOB), ESI number V_ESN of a video stream to be played back, ESI number A_ESN of an audio stream to be played back, main/sub information in case of Dual-Mono (main/sub audio switch flag), date information MRK_TM indicating the date of creation of that marker, and the like, as information used to restart the paused playback.



FIG. 6 is a view for explaining a practical example of EX_DISC_REP_PICI. The representative picture information (EX_DISC_REP_PICI) of the disc is set to include picture pointer PIC_PT including the start PTM and the like of the representative picture (including the PTM/PATS/S_ESOB_ENT number, and the like on a target ESOB), ESI number V_ESN of a video stream to be played back, the playback time and/or playback end time of the representative picture, date information PIC_CL_TM indicating the date of creation of the representative picture, and the like, in addition to program chain number PCGN, program number PGN, and cell number CN of that representative picture.



FIG. 7 is a view for explaining a practical example of EX_PL_SRPT. The EX_PL_SRPT is a search pointer to each playlist, and also includes PL_RSM_MRKI, which is set with a resume marker (marker indicating the playback location upon pausing playback) for each playlist. As information used to restart playback, this PL_RSM_MRKI is set to include cell number CN corresponding to the resume marker, picture pointer PIC_PT (corresponding to the playback start PTM and the like) corresponding to the resume marker, date information of MRK_TM indicating the date of creation of the marker, ESI number V_ESN of a video stream to be played back, ESI number A_ESN of an audio stream to be played back, and a main/sub switch flag of audio information (main/sub information in case of Dual-Mono) included in the audio stream corresponding to the resume marker.


Furthermore, the EX_PL_SRPT includes PL_REP_PICTI, which is set with representative picture information (a marker of a picture to be displayed as a thumbnail on a title menu or the like) for each playlist. This PL_REP_PICTI is set to include target cell number CN, picture pointer PIC_PT (the start PTM, PATS, E_EVOB_ENT number, and the like of the representative picture of interest) on the target EVOB, ESI number V_ESN of a video stream (default stream) to be played back, date information PIC_CL_TM indicating the date of creation of the marker of the representative picture of interest, and the like.


Moreover, update date information of a VTMAPT as a TMAP (Time Map) for Video Recording (VR) for self recording/playback and that of an STMAPT as a TMAP for Stream Recording (SR) for digital broadcast recording are described. This value is compared with update date information described in each TMAPT file. If these values match, it is determined that they have consistency, and the processing is executed. Management information of stream data is saved in the VMG file, as shown in FIG. 3, and stream data are managed on the same level as VR data.


Stream management information is saved in the ESTR_FIT (Extended Stream File Information table). The ESTR_FIT includes ESTR_FITI (ESTR_FIT information), one or more ESTR_FI_SRPs, and one or more pieces of ESTR_FI (Extended Stream File Information) indicated by these SRPs. The ESTR_FITI includes the total number of pieces of ESTR_FI, and the end address of this table. Each ESTR_FI includes ESTR_FI_GI (ESTR_FI General Information), one or more ESOBI_SRPs (Extended Stream Object Information Search Pointers), and one or more pieces of ESOBI (ESOB Information) which are as many as the SRPs and are indicated by their values.


The ESTR_FI_GI includes the file name/file number of an object managed by the ESTR_FI of interest, the number of ESOBI_SRPs in the ESTR_FI of interest, the type (AP_FORMAT_1) of digital broadcast as a source of the contents to be recorded, the recording country code: Country code (JPN=Japan), PKT_TY (1=MPEG-TS), PKT_GP_SZ (fixed to 16 logical blocks), and PKT_Ns (0XAA: fixed to 170 TS packets).



FIG. 12 is a view for explaining an example of the configuration of ESOBI_GI included in the ESOBI shown in FIG. 11. The ESOBI_GI includes various kinds of information shown in FIG. 12 in the order listed in FIG. 12. That is, the ESOBI includes ESOBI_GI, ESOBI_ESI corresponding to ESOB_V_ESI (Extended Video Elementary Information) and/or ESOB_A_ESI (Extended Audio Elementary Information), ESOB_DCNI (Discontinuity Information), ESOB_SMLI (ESOB Seamless Information), ESOB_AGAPI (ESOB Audio GAP Information), ESOB_TMAP (ESOB Time Map), ESOB_ES_GPI (ESOB_ES Group Information), and the like.



FIG. 13 is a view for explaining various kinds of information included in the ESOBI_GI. FIG. 13 shows the contents of various kinds of information shown in FIG. 12. That is, the ESOBI_GI includes AP_FORMAT (1=ISDB-S: BS/CS broadcast, 2=ISDB-T: terrestrial digital broadcast), video recording start time/video recording time (ESOB_REC_TM, etc.), start Presentation Time (ESOB_S_PTM), end Presentation Time (ESOB_E_PTM). Furthermore, the ESOBI_GI includes PROGRAM_NUMBER (SERVICE_ID), PMT_PID, NETWORK_ID, TS_ID, and FORMAT_ID on the basis of the value of PSI (Program Specific Information/SI (Service Information), and ESOB_ES_Ns (the number of ESs selected for video recording), ESOB_V_ES_Ns (the number of ESs for which TMAP data are generated of recorded video ESs), ESOB_A_ES_Ns (the number of ESs for which TMAP data are generated of recorded audio ESs), CP_CTL_IFO (corresponding to copy control information CCI), a video recording rate, and the like on the basis of data to be recorded.


ESOB_REC_MODE included in the ESOB_GI indicates the TYPE of stream: 01=ESOB of Type A, and 02=ESOB of Type B. Type A is a stream whose stream structure is cognizable, and management information is managed on the PTM base. On the other hand, Type B is a stream whose structure is not cognizable and, hence, management information is managed on the PATS base. For this reason, Type A adopts a TMAP on the PTM base, and Type B adopts a TMAP on the PATS base.


Note that ESOB_ES_Ns, ESOB_V_ES_Ns, ESOB_A_ES_Ns, and ES_TMAP_Ns have the following relations:

ESOBESNs≧ESOBVESNs+ESOBAESNs
ESOBVESNs+ESOBAESNs≧EESTMAPNs


A region number indicates Japan (ARIB) when it is 00; U.S.A. (ATSC) when it is 01; and Europe (DVB) when it is 02. Of the recorded contents, data of a region corresponding to the region number can be played back.



FIG. 14 is a view for explaining an example of the configuration of the ESOB_ESI. As shown in FIG. 14, ESOB_ESI is classified into three types (ESOB_V_ESI in FIG. 15, ESOB_A_ESI in FIG. 16, and ESOB_OTHER_ESI in FIG. 17).



FIG. 15 is a view for explaining an example of the configuration of ESOB_V_ESI, and an example of the configuration of video attribute V_ATTR included in this ESOB_V_ESI. ESOB_ES_PID (the PID of an ES), STREAM_TYPE (STREAM type indicated in the PMT), STREAM_CONTENT (STREAM_CONTENT value indicated by the component descriptor), COMPONENT_TYPE (the value of COMPONENT_TYPE indicated by the component descriptor), COMPONENT_TAG (the value of COMPONENT_TAG indicated by the component descriptor), and CP_CTL_INFO are common to these three different types of ESOB_ESI. Furthermore, V_ATTR is added to V_ESI (FIG. 15).


The V_ATTR is set to include an Application flag (0=designate an Aspect ratio by the V_ATTR of interest, 1=the V_ATTR of interest may designate an Aspect ratio; the actual Aspect ratio is recorded in a stream), Aspect Ratio (0=4:3, 1=16:9), Horizontal resolution (00=1920, 01=1440, 02=1280, 03=720, 04=544, 05=480), and Vertical resolution (00=1080, 01=720, 02=480). Note that the ESOB_V_ESI may have a reserved area in addition to these areas, and can describe information (copy control information) shown in FIG. 15 in this reserved area as needed.



FIG. 16 is a view for explaining an example of the configuration of ESOB_A_ESI, and an example of the configuration of audio attribute AUDIO_ATTR included in this ESOB_A_ESI.


The A_ESI (FIG. 16) further includes SIMULCAST_GP_TAG (a gap value of audio frames at the beginning of multi-view broadcast), and AUDIO_ATTR (audio attribute values). The AUDIO_ATTR includes Simulcast_GP_tg (0=not simulcast, 1=simulcast), Multi_lng (1=Dual mono, 0=other), Main_Comp (1=main audio, 0=other), Quality_Indicator (indicating sound quality), and Sampling_Rate (001=16 kHz, 010=22.05 kHz, 011=24 kHz, 101=32 kHz, 111=48 kHz). These values are set based on the values of an audio component descriptor. Note that ESOB_A_ESI may have a reserved area in addition to these areas, and can describe information (language code, copy control information, etc.) shown in FIG. 16 in this reserved area as needed.



FIG. 17 is a view showing an example of the configuration of ESOB_OTHER_ESI. The ESOB_OTHER_ESI includes ES_TY, ES_PID, STREAM_TYPE, and COMPONENT_TAG as in the ESOB_V_ESI in FIG. 15 or ESOB_A_ESI in FIG. 16. Note that ESOB_OTHER_ESI may have a reserved area in addition to these areas, and can describe information (data encoding identifier, additional information of this identifier, copy control information, etc.) shown in FIG. 17 in this reserved area as needed.



FIG. 18 is a view for explaining another example of the configuration of copy control information (copyright protection information) CP_CTL_INFO. The copyright protection information such as copy control information (CP_CTL_INFO) or the like is stored in CCI (Copy Control Information) or the like in a packet group header, and the copy control of packet groups is made by the CCI in the packet group header. The values of the CP_CTL_INFO are set by a digital copy control descriptor and content use descriptor. The contents of CP_CTL_INFO are: CGMS (0=copy never; 1=copy free); APS (0=no APS, 1=append APS type 1, 2=append APS type 2, 3=append APS type 3); EPN (0=contents protection (Internet output protection), 1=no contents protection); and ICT (0=resolution constraint, 1=no constraint).



FIG. 19 is a view for explaining a practical example of the ESOB_DCNI. This ESOB_DCNI (Discontinue Information) includes DCNI_GI and CNT_SEGI#1 to CNT_SEGI#n. The DCNI_GI includes the number (CNT_SEGI_Ns) of pieces of CNT_SEGI. Each CNT_SEGI includes CNT_SEG_SZ (CNT_SEG size: the number of packet groups), and CNT_SEG_PKT_POS (the number of packets of the first CNT_SEG in a packet group). These pieces of information can indicate whether or not the count operation of system time counter STC of the recorder/player reaches an end (wrapped around). In this way, the number of CNT_SEGs from the head of an ESOB is substituted in time information PTM to confirm in advance if STC Wrap-around has occurred, and can be used in TMAP calculations and the like (see FIG. 37 for the configuration of this PTM).



FIG. 22 is a view for explaining an example of the configuration of the ESOB_SMLI. The ESOB_SMLI (Seamless Information) may have four different types of structures, as shown in FIG. 22. Any of the four different structures includes seamless general information SML_GI. SML_GI 221 in example 1 includes only a continuous recording flag which indicates that this ESOB is continuously recorded from the previous ESOB (ESOB with an ESOB_ID smaller by one). In this case, this ESOB can be continuously played back, but seamless playback is not guaranteed. SML_GI 222 in example 2 further includes a flag indicating if the STC values are continuous. This STC continuous flag is set with an offset value corresponding to a discontinuous period when the STC values of two ESOBs are discontinuous. SML_GI 223 in example 3 further includes a flag indicating if the PATS values are continuous. This PATS continuous flag is set with an offset value corresponding to a discontinuous period when the PATS values of two ESOBs are discontinuous. Finally, SML_GI 224 in example 4 includes only a flag indicating if the PATS values are continuous, and this flag is set with an offset value when they are discontinuous.



FIG. 23 is a view for explaining an example of the configuration of ESOB_TMAP (type A). The ESOB_TMAP includes ESOB_TMAP_GI and one or more pieces of ES_TMAPI. The ESOB_TMAP_GI includes ADR_OFS (a packet group number (or LB address) from the head of a file to the head of an ESOB), ESOBU_PB_TM_RNG (ESOBU playback time range: 1=0.4 s to 1.2 s, 2=1 s to 2 s, 3=2 s to 3 s), ESOB_S_PKT_POS (the start position of the head of an ESOB in a packet group: 1≦ESOB_S_PKT_POS≦170), and ESOB_E_PKT_POS (the end position of the head of an SOB in a packet group: 1≦ESOB_E_PKT_POS≦170).


Each ES_TMAPI_GI# includes ES_PID (the PID of a target ES of this TMAP: there are two description methods of the PID: a method of describing the PID using 13-bit real data, and a method of describing the order in the PMT), ES_S_ADR_OFS (logical address from the head of an ESOB file to the head of this ES), ES_S_PTM (start PTM), ES_E_PTM (end PTM), ES_ESOBU_ENT_Ns (the number of ESOBU_ENTs), LAST_ESOBU_E_PKT_POS (position of the last ESOBU in a packet group), and STMAP_N (the number of a TMAP in the STMAPT, which belongs to this ES: this number may be omitted when the STMAPTs are recorded in independent areas for each STR_FI or when STMAPs are recorded in turn).



FIG. 24 is a view for explaining an example of the configuration of ESOB_TMAP (type B). FIG. 24 shows an example of an actual TMAP on the PATS base. ESOB_SZ is the number of packet groups from a packet group to which the head of an ESOB belongs to that to which the end of the ESOB belongs. ESOB_TMAP_GI (FIG. 24) describes ADR_OFS, ESOB_SZ, and ESOB_E_PKT_POS as values associated with those of the entire ESOB. As TMAPI for each ES, ES_TMAPI (FIG. 23) describes ES_S_ADR_OFS (an address value (the number of packet groups) from the head of an ESOB to the first ESOBU of the ES of interest), ES_S_ADR_OFS (an address value (the number of packet groups) from the last ESOBU of the ES of interest to the end of the ESOBU), ES_LAST_SOBU_PKT_POS (the number of packets up to the last packet in a packet group of the last ESOBU), ES_ESOBU_ENT_Ns (the total number of ESOBU_ENTs), the default PID of the ES of interest (there are two description methods of the PID: a method of describing the PID using 13-bit real data, and a method of describing the order in the PMT), and the like, as the values of the entire ES_TMAP.



FIG. 25 is a view for explaining an example of the configuration of HR_VTMAP.IFO and HR_STMAPx.IFO included in the DVD_HDVR directory. An STMAPT is recorded in an area (file) independent from a VTMAPT. As shown in FIG. 25, this STMAPT includes STMAPTI, one or more STMAPI_SRPs, and one or more pieces of STMAPI as many as the number of STMAPI_SRPs.



FIG. 28 is a view for explaining an example of the configuration of various kinds of information included in the STMAPT (type A). FIG. 29 is a view for explaining an example of the configuration of various kinds of information included in the STMAPT (type B).


The STMAPTI (FIG. 28 or 29) includes identification information STM_ID and end address information STMAPT_EA of the STMAPT, version information VERN of the TMAP of interest, the number STMAP_SRP_Ns of STMAP search pointers (the number of pieces of TMAP_SRPI=the number of pieces of TMAPI), update date information STMAP_LAST_MOD_TM of the STMAP (the same value as that of update date information of VMGI), and the like. Each STMAP_SRP includes address information to STMAPI as an element of each STMAPT, and each STMAPI includes a required number of pieces of ETMAPI_GI and a required number of ESOBU_ENTs. The STMAP_GI includes ESOBU_ENT_Ns (the number of entries). Note that garbage data may be inserted among ESOBU_ENTs.


In case of the PATS base, the STMAPTI (FIG. 29) arrival time interval ESOBU_PATS_TM_RNG (ESOBU_PATS_TM_RNG: 1=0.5 s, 2=1 s, or the count value in case of 27 MHz is ESOBU_PATS_TM_RNG), ESOB_S_PATS/ESOB_E_PATS (arrival time of the first/last packet), difference time TM_OFS (not available in some cases) from the arrival time interval (TM_RNG) of the first ESOBU, and the like (although not shown). In this case, the edit process is made for respective ESOBUs, and adjustment upon editing can be made using the PATS start/end time (cell information CI). Note that a similar disclosure is available in FIG. 9 for TM_OFS.


The aforementioned ESOBU_PATS_TM_RNG is conceptually similar to ESOBU playback time range ESOBU_PB_TM_RNG in FIG. 23. Note that TMAPI information can be prevented from becoming extremely large by setting ESOBU/EVOBU_PB_TM_RNG even when a video recording time increases. However, since the time interval between neighboring entries is broadened, it is more likely to disturb smooth double-speed playback and the like.


As for the ESOBU/EVOBU intervals, when the TM_RNG value is available, a time interval indicated by this value is set as a maximum interval, and when a GOP division exists ahead of this time interval, SOBUs can be delimited there. On the other hand, if a sequence header (SH) and I-PIC exist, SOBUs can be delimited at the head of the SH.



FIG. 8 is a view for explaining an example of the configuration of another field (EX_M_AVFIT) of one management information (HDVR_MG) in the data structure according to the embodiment of the invention. The EX_M_AVFIT includes EX_M_AVFI, which includes a plurality of pieces of EVOBI as management information for respective EVOBs as many as the number of EVOBs. The EVOBI includes EVOB_TMAPI used to manage the TMAP of the EVOB, as shown in FIG. 8.



FIG. 9 is a view for explaining a practical example of the EVOB_TMAP_GI. The EVOB_TMAP_GI records general information used to manage the VTMAPT as an independent file, as shown in FIG. 9. The EVOB_TMAP_GI includes the total number (EVOBU_ENT_Ns) of entries (EVOBU_ENT) stored in the EVOBU of interest, a reserved area (which can be used to store offset value TM_OFS of the time of the head of the EVOBU of interest and the like as needed), the start address (ADR_OFS) of the EVOBU of interest, the size (EVOB_SZ) of the EVOBU of interest, EVOBU_PB_TM_RNG that determines the time interval of entries of the EVOBU of interest, the TMAP number (EX_VTMAP_N: which may be omitted if the TMAP number is determined to have one-to-one correspondence from the head of the EVOB) in the VTMAP file, and the like.


The EVOB_TMAP_GI allows to recognize information of the EVOB without reading out the TMAP file, since the TMAPs are stored in independent files (see FIG. 3). Especially, start address ADR_OFS, size EVOB_SZ, and total number EVOBU_ENT_Ns of entries of the EVOB allow to determine the data size to be read out from disc 100, the work RAM size to be assured, and the like before loading the TMAP file main body, thus facilitating the read preparation.



FIG. 26 is a view for explaining an example of the configuration of EX_VTMAPTI, each EX_VTMAP_SRP#, and each EX_VTMAPI. The VTMAPT (FIG. 25) includes VTMAPTI VTMAP_SRPT, and VTMAP#1 to VTMAP#n. The VTMAPTI (FIG. 26) includes VMG_ID (the same value as VMG_ID located at the head of VMGI), VTMAPT_EA (the end address of the VTMAP), VERN (version information of the TMAP), IFO_LAST_MOD_TM (update date information of the TMAPT, the same value as HR_MANGR.IFO), and VTMAP_SRPNs (the total number of pieces of search information). The VTMAP_SRPT includes one or more VTMAP_SRPs (search information of each VTMAP). Furthermore, each VTMAP_SRP includes VTMAP_SA (the start address of the VTMAP) and EVOBU_ENT_Ns (the total number of EVOBU_ENTs). The VTMAP includes one or more EVOBU_ENTs (corresponding to the EVOBU_ENT in FIG. 27).



FIG. 27 is a view for explaining an example of the configuration of the contents of each EVOBU_ENT. Each EVOBU_ENT includes size 1stREF_SZ of the first reference picture (I-pic) in the entry of interest, playback time EVOBU_PB_TM (indicated by the number of fields) of the EVOBU of interest, and size EVOBU_SZ of the EVOBU of interest.



FIG. 30 is a view for explaining an example of information to be stored in the ETMAPI_GI and ETMAPI shown in FIG. 28. Each ETMAPI_GI can store number ESOBU_ENT_Ns of ESOBU entries, and each ETMAPI can store one or more ESOBU entries ESOBU_ENT#1 to ESOBU_ENT#q.



FIG. 31 is a view for explaining an example (an example of type A) of the configuration of the contents of each ESOBU_ENT. The ESOBU_ENT in each STMAPI (FIG. 28) describes ESOBU_S_PKT_POS, ESOBU_SZ, and the like as values which belong to the ESOBU. As shown in FIG. 31, in case of a PTM base, the ESOBU_ENT includes 1st_Ref_PIC_SZ (end address information of the first reference picture (I-picture or the like) in the entry from the head of the ESOBU, which is expressed by logical blocks (LBs)), ESOBU_PB_TM (the playback time of the ESOBU indicated by the number of fields), ESOBU_SZ (ESOBU size expressed by the number of packet groups that belong to the ESOBU), ESOBU_S_PKT_POS (the position of a packet which is expressed by the number of packets from the head of a packet group and stores the first packet of the ESOBU), and the like.


Note that each ESOBU_ENT in FIG. 31 may have a reserved area in addition to the above areas, and the reserved area can store, e.g., SH information (a flag indicating whether or not sequence header SH is stored in the ESOBU or the like) as needed. This SH information can be adopted to delimit ESOBUs when the SH is constant in a program (in the ESOB) or so that the ESOBU always starts from the SH. In this way, playback using the SH in each ESOBU can be made.


In case of time search, an ESOBU corresponding to a target time is calculated by accumulating PB_TM data, and the playback start PTM is converted into the number of fields from the head of that ESOBU. Note that the address is given by:

A=ESOBADROFS+ESADROFS of target ES+Σk−1N=1ESOBUSZ(N)×16+1

where K is the target ESOBU, and A is the target address. Furthermore, the first packet becomes a packet corresponding to the value of ESOBU_S_PKT_POS, and this address is accessed.


There are two types of ESOBU_ENTs (corresponding to AT_ESOBU_ENT in FIG. 32) on the PATS base, i.e., that in a packet unit and that in a packet group unit. In case of the packet unit, accurate addresses can be obtained, but the number of ESOBU_ENT data increases. On the other hand, in case of the packet group unit, the number of ESOBU_ENT data is small, but addresses can only specify packet groups.


In case of the packet unit, each ESOBU_ENT on the PATS base can be configured by AT_ESOBU_SZ and AT_ESOBU_S_PKT_POS. In this case, the AT_ESOBU_S_PKT_POS indicates the first packet position of the ESOBU by the number of packets. On the other hand, in case of the packet group unit, each ESOBU_ENT on the PATS base can be configured by AT_ESOBU_SZ. In this case, AT_ESOBU_S_PKT_POS and AT_ESOBU_E_PKT_POS are fixed to zero.


Furthermore, when ESOB_SZ is available, as exemplified in FIG. 23, either ES_S_ADR_OFS or ES_E_ADR_OFS need only be present since the ES_E_ADR_OFS is given by:

ESEADROFS=ESOBSZ−(ESSADROFS+Σk−1N=1ESOBUSZ(N)+1)

Note that inequalities ESOB_SZ>ES_S_ADR_OFS, ESOB_SZ>ESOBU_SZ, and the like hold.



FIG. 32 is a view for explaining an example (an example of type B) of the configuration of the contents of the AT_ESOBU_ENT#. FIG. 32 shows an example of an actual structure of an ESOBU on the PATS base. Each AT_ESOBU_ENT in each STMAPI (FIG. 29) describes AT_ESOBU_S_PKT_POS, AT_ESOBU_SZ, and the like as values which belong to an AT_ESOBU. The ESOB_SZ in FIG. 24 indicates the number of packet groups from a packet group to which the first packet of the ESOB belongs to a packet group to which the last packet of the ESOB belongs. However, the AT_ESOBU_SZ in FIG. 32 is the number of packet groups from the first packet group of the ESOBU to the last packet group of the ESOBU. Also, the AT_ESOBU_S_PKT_POS in FIG. 32 represents the difference between the divisions of the ESOBU and packet group using the number of packets.


In this case, the time information is expressed by PATs to have ESOB_S_PATS as the ESOB start time, and ESOB_E_PATS as the end time, since it is on the PATS base. However, the ESOB_E_PATS is the PATS (arrival start time) of the last packet of the last packet group, but is not the last reception end time.


The edit process is performed for respective ESOBUs, and the playback start time (CELL_S_PATS of CI) is designated. Since the edit process is performed for respective ESOBUs, each ESOB_S_PATS always matches the head of the ESOBU. Note that the accuracy of the PATS is indicated by PATS_SS.


Although not shown in FIG. 32, an embodiment in which the AT_ESOBU_ENT has time offset TM_OFS which represents an actual difference between the first PATS of an ESOB and a TM range (time interval) designated by predetermined time interval information TM_RNG using a 27-MHz count value is also available. Note that an embodiment without this TM_OFS may be used.


When the processing is performed in the packet group unit, since the division of each ESOBU matches that of each packet group, the AT_ESOBU_S_PKT_POS can be omitted. Furthermore, the ESOB includes ESOB_ES_GPI (Group Information) to support multi-view broadcast, rain attenuation broadcast, and multi-program simultaneous recording.



FIG. 20 is a view for explaining an example of the configuration of ESOB_GPI. That GPI includes ESOB_GPI_GI, one or more GPI_SRPs, one or more pieces of GPI, and the like.



FIG. 21 is a view for explaining an example of the configuration of ESOB_GPI_GI, each GPI_SRP#, and each GPI#. The ESOB_GPI_GI stores GPI_TY (0=created within the recorder, 1=defined upon broadcast), and GPI_SRP_Ns (the number of ES_GPI_SRPs). Each GPI_SRP stores GPI_SA (the start address of the GPI). Each GPI includes GPI_GI and ES_PISs. The GPI_GI includes PRIORITY (priority: 0 if it is not designated, 1=top priority), and ES_PID_Ns (the number of ESs in the group of interest). If the video PID is stored, it does not belong to an identical GP.



FIG. 33 is a view for explaining an example of the configuration of PGC information (EX_ORG_PGC information and EX_playlist information/EX_UD_PGC information) included in HDVR_VMG. EX_PGC information as playback information has the same format as a normal VR format, and ORG_EX_PGC information is automatically generated by an apparatus upon video recording and is set in the order of video recording. UD_EX_PGC information is generated according to a playback order which is freely added by the user, and is called a playlist. These two formats have a common format in EX_PGC level, and FIGS. 34 to 36 show that EX_PGC format.



FIG. 34 is a view for explaining a practical example of EX_PGI. Note that EX_PG information saves update date information of this EX_PG. This information can identify when this EX_PG was edited. A program name as text information uses PRM_TXT, and an IT_TXT field saves other kinds of information (director name, leading actor name, . . . ) to save other kinds of text information. This EX_PGI is set with an SRP number of the IT_TXT field which saves these kinds of information to establish a link. Furthermore, a PG number is set in IT_TXT data. Note that the EX_PG number is an absolute number from the beginning of recording on this disc, and is an index number which remains unchanged even after other EX_PGs are deleted.


Furthermore, the EX_PGI includes RSM_MRKI to provide a resume marker (a marker indicating the playback position upon interrupting playback) for each program. As information used to restart playback, an EX_CELL number, playback start PTM and date information indicating the date of creation of that marker, an ESI number of a video stream to be played back, an ESI number of an audio stream to be played back, and main/sub information in case of Dual-Mono are set. This information is used as title resume.


Furthermore, the EX_PGI includes PG_REP_PICTI, which is set with representative picture information (a marker of a picture to be displayed as a thumbnail on a title menu or the like) for each PG. This PG_REP_PICTI is set with a cell number, start PTM, date information of the date of creation of that marker, and an ESI number of a video stream to be played back.


In order to utilize manufacturer's information (MNFI stored in the EX_MNFIT in FIG. 4 or the like) provided to implement functions unique to the manufacturer, the EX_PGI in FIG. 34 is set with an MNFI search pointer (not shown), and an EX_PG number can also be set in the MNFI information. In this way, the EX_PGCI/EX_PGI in FIG. 34 can be linked with data in the MNFI information (not shown).


Furthermore, when PG update date information (program update date information at the end in the PGI in FIG. 34) is set in both the MNFI and IT_TXT, whether or not the edit process has been made by an apparatus of another manufacturer can be verified by checking if these times (the set update date and current time) upon menu display.



FIG. 35 is a view for explaining a practical example of EX_CI. In EX_CELL information (EX_CI), an ESOB type (STRA_CELL, STRB_CELL) is added to the cell type, and an ESOB number, start time, end time, packet group number (GP number) to be played back, and the like can be designated. The start and end times can be expressed by either the playback time (in case of PTM base) or PATS time (in case of PATS base).


When time is designated by a playback time =real time upon playback, the same access method as in the existing DVD-Video recording (DVD-VR) is allowed although stream recording that records incoming bitstreams intact is made. Since the user can designate a recording position using a playback time, a user's desire can be perfectly reflected. However, this method can be adopted only when the stream contents can be sufficiently cognizable. If the contents cannot be sufficiently cognizable, a time must be designated using a transfer time of a stream packet (MPEG-TS packet in case of digital broadcast recording).


If the recording position is designated using a playback time while the contents of the recorded stream are not sufficiently cognizable, playback cannot always be started from the head of I-picture data. If a frame at the playback start position is not that of I-picture, decoding starts from the immediately preceding I-picture, and display of a playback video picture starts when the target frame is decoded. In this way, a picture can be presented to the user as if playback were started from the designated frame.


As for an ID to be referred to in the playback process or the like, a method of setting the PID of a representative one of streams to be played back, and a method of setting the ID of a component group in case of multi-view TV or the like are available (in case of the PID setting method, a method of describing the ID using 13-bit real data, a method of describing the order in the PMT, a method of describing the value of a component tag, and the like are available). Also, in still another method, a reference GRP number (or GRP_SRP number) may be set to switch groups. Unique ID numbers (EX_PGI#p, EX_CI#q, and the like in FIG. 35) are assigned to EX_PG and EX_CELL data, so that EX_PG and EX_CELL data can be designated using numbers which remain unchanged even when middle programs and cells are deleted. The EX_CELL information (EX_CI) is set with the file number (ESTR_FILE number) of a stream to be played back, and the ESOB_SRP number of the corresponding ESOB. Furthermore, the EX_CELL information includes information C_EPI (Entry Point Information) of a cell entry point corresponding to each chapter.



FIG. 36 is a view for explaining a practical example of C_EPI. There are two types of C_EPI for each cell type, i.e., a total of eight types of C_EPI. M_CELL_EPI_TY_A includes EPI_TY (EPI type information), and a PTM to which an EP is assigned. M_CELL_EPI_TY_B also includes PRM_TXTI (text information) and REP_PIC_PTM (thumbnail pointer). S_CELL_EPI_TY_A includes EPI_TY (EPI type information), and an S_EVOB_ENT number to which an EP is assigned. S_CELL_EPI_TY_B also includes PRM_TXTI (text information).


STR_A_CELL_EPI_TY_A (ESOB TYPE A) includes EPI_TY (EPI type information), a PTM to which an EP is assigned, an ESI number of an ES to which that ES is assigned, an ESI number of an audio ES, and main/sub information in case of Dual-Mono. STR_A_CELL_EPI_TY_B also includes PRM_TXTI (text information) and REP_PIC_PTM (thumbnail pointer).


STR_B_CELL_EPI_TY_A (ESOB TYPE B) includes EPI_TY (EPI type information), a PATS to which an EP is assigned, and a PID to which that ES is assigned. STR_B_CELL_EPI_TY_B also includes PRM_TXTI (text information) and REP_PIC_PTM (thumbnail pointer).



FIG. 37 is a view for explaining an example of the configuration of the PTM (Presentation Time) of an ESOB (or EVOB). This time information PTM includes information CNT_SEGN indicating the number of continuous segments CNT_SEG (the number of CNT_SEGs from the head of the ESOB), PTM_base that roughly counts on a 90-kHz base, and PTM_extention which finely counts on a 27-MHz base, as shown in FIG. 19. An actual time based on the PTM is expressed by a value as the sum of PMT_base and PMT_extension. As an ESOB, type A, which undergoes playback management based on this PTM (PMT_base+PMT_extension), and type B, which undergoes playback management based on the PATS (Packet Arrival Time), are available.


For example, information CNT_SEGN indicating the number of CNT_SEGs from the head of the ESOB can be set as follows. That is, in case of an ESOB of type A, the value of CNT_SEGN is valid, but CNT_SEGN is set to be zero for objects other than the ESOB. As the values of valid CNT_SEGN, for example, when CNT_SEGN=4, the number of CNT_SEGs in the ESOB of interest is zero; when CNT_SEGN=5, the number of CNT_SEGs in the ESOB of interest is 1; when CNT_SEGN=6, the number of CNT_SEGs in the ESOB of interest is 2; and when CNT_SEGN=7, the number of CNT_SEGs in the ESOB of interest is 3.


The example of the ESOB has been described. Also, in case of an EVOB, the PTM can have the same data structure.



FIG. 43 is a block diagram for explaining an example of the apparatus which records and plays back AV information (digital TV broadcast program or the like) on an information recording medium (optical disc, hard disc, or the like) using the data structure according to the embodiment of the invention. As shown in FIG. 43, this recorder/player comprises an MPU unit, display unit, decoder unit, encoder unit, TV tuner unit, STC (System Time Counter) unit, D-PRO unit, temporary storage unit, disc drive unit, key input unit, V-mixing unit, frame memory unit, TV D/A unit, terrestrial digital tuner unit, 1394 I/F unit, Ethernet(R) I/F unit, remote controller receiver, STB unit (BS digital tuner or the like), emergency broadcast detection unit, and HDD unit. In this arrangement, the functions of a streamer are added to a recordable/reproducible DVD recorder.


The encoder unit includes an A/D unit, video encode unit, audio encode unit, SP encode unit, formatter unit, and buffer memory unit. The decoder unit includes a demultiplexer, video decode unit, SP decode unit, audio decode unit, TS packet transfer unit, V-PRO unit, and audio D/A unit. Furthermore, an antenna for receiving digital broadcast is connected to the STB unit. Note that the STC unit is configured to count on a 27-MHz base.


The flow of signals upon recording is, for example, as follows. That is, TS packet data received by the STB unit (or terrestrial digital tuner) are packed into packet groups by the formatter unit and the packet groups are saved on a work area. When the saved packet groups reach a predetermined size, they are recorded on the disc. The arrival time of each TS packet is counted by PATS counter 90a, and that count value is appended to the head of each TS packet when the packet is buffered. This counter 90a can perform fine adjustment of count intervals by PCR (or SCR) values, but never loads the PCR (or SCR) values unlike STC 102. As the operations to be executed at that time, upon reception of TS packets, a group is formed every 170 packets, and a packet group header is generated.


In this case, only the upper 2 bytes of the PATS of the first packet of the packet group are stored in the header, and only the lower 4 bytes of each of other PATS are saved together with the TS packet (before the TS packet). An analog signal input from the terrestrial tuner or line input is converted into a digital signal by the A/D unit. That digital signal is input to respective encoder units. That is, a video signal is input to the video encode unit, an audio signal is input to the audio encode unit, and text data of, e.g., teletext broadcasting is input to an SP encode unit. The video signal is compressed by MPEG, the audio signal is compressed by AC3 or MPEG audio, and the text data is compressed by runlength coding.


Each encoder unit (for VR) packs compressed data to form 2048-byte packets and inputs them to the formatter unit. The formatter unit packs and multiplexes the packets as a program stream, and sends it to the D-PRO unit.


The D-PRO unit forms ECC blocks for every 16 logical blocks, appends error correction data to them, and records the ECC packets on the disc via the disc drive unit. When the disc drive unit is busy due to seek, track jump, and the like, data are stored in an HDD buffer unit, and wait until the disc drive unit is ready. Furthermore, the formatter unit generates each segmentation information during video recording, and periodically sends it to the MPU unit (GOP head interrupt or the like). The segmentation information includes the number of packs of an EVOBU (ESOBU), the end address of I-picture data from the head of the EVOBU (ESOBU), the playback time of the EVOBU (ESOBU), and the like.


In the flow of signals upon playback, data are read out from the disc by the disc drive unit, undergo error correction by the D-PRO unit, and are then input to the decode unit. The MPU unit determines the type of input data (i.e., VR or SR data) (based on CELL Type), and sets that type in the decoder unit before playback. In case of SR data, the MPU unit determines the PID to be played back based on EX_CELL information to be played back, determines the PIDs of items (video, audio, and the like) to be played back based on that PMT, and sets them in the decoder unit. In the decoder unit, the demultiplexer sends TS packets to the respective decode units based on the PIDs. Furthermore, the TS packets are sent to the TS packet transfer unit, and are transmitted to the STB unit (1394 I/F unit) in the form of TS packets. The respective decode units execute decoding, and decoded data are converted into an analog signal by the D/A unit, thus displaying data on the TV. In case of VR data, the demultiplexer sends data to the respective decode unit according to the fixed IDs. The respective decode units execute decoding, and decoded data are converted into an analog signal by the D/A unit, thus displaying data on the TV.


Upon playback, pack data read out from the disc are interpreted by the demultiplexer. Packs that store TS packets are sent to the TS packet transfer unit, and are then sent to the decoders, thus playing back data. When pack data are transferred to the STB (or are transmitted to an external apparatus such as a digital TV or the like), the TS packet transfer unit transfers only TS packets at the same time intervals as they arrived. The STB unit decodes to generate an AV signal, which is displayed on the TV via the video encoder unit in the streamer.


The features of medium 100 (100a) used in the apparatus of FIG. 43 will be briefly summarized below. That is, this medium has management area 130 and data area 131. Data is separately recorded on the data area as a plurality of object data (ESOB), and each object data includes a group of data units (ESOBU). One data unit (ESOBU) includes packet groups each of which is formed by converting a MPEG-TS compatible digital broadcast signal into TS packets and packing a plurality of packets (see FIGS. 1 and 33). On the other hand, management area 130 has EX_PGC information (EX_PGCI) as information used to manage the playback sequence. This EX_PGC information includes EX_CELL information (EX_CI). Furthermore, management area 130 has information used to manage object data (ESOB).


The apparatus shown in FIG. 43 can make stream recording on medium 100 (100a) with the above data structure in addition to video recording. In this case, in order to extract program map table PMT and service information SI from a TS packet stream, MPU unit 80 has a service information extraction unit (not shown; firmware that forms management data generation unit 80B). Also, MPU unit 80 has an attribute information generation unit (not shown; firmware that forms management data generation unit 80B) that generates attribute information (PCR pack number, PCR LB count number, and the like) on the basis of information extracted by the service information extraction unit.



FIG. 44 is a flowchart (overall operation process flow) for explaining an example of the overall operation of the apparatus shown in FIG. 43. In this case, data processes include five different processes, i.e., a video recording process, playback process, data transfer process (a digital output process to the STB or the like), program setting process, and edit process, as shown in FIG. 42. For example, when the power switch of the apparatus in FIG. 43 is turned on, MPU unit 80 makes initial settings (upon factory shipment or after user's settings) (step ST10). MPU unit 80 also makes display settings (step ST12) and waits for a user's operation. If the user has made a key input from key input unit 103 or remote controller 103a (step ST14), MPU unit 80 interprets the contents of that key input (step ST16). The following five data processes are executed as needed in accordance with this input key interpretation result.


That is, if the key input is, for example, a key operation made to set timer program recording, a program setting process starts (step ST20). If the key input is a key operation made to start video recording, a video recording process starts (step ST22). If the key input is a key operation made to start playback, a playback process starts (step ST24). If the key input is a key input made to output digital data to the STB, a digital output process starts (step ST26). If the key input is a key operation of an edit process, the edit process starts (step ST28).


The processes in steps ST20 to ST28 are parallelly executed as needed for respective tasks. For example, the process for outputting digital data to the STB (ST26) is parallelly executed during the playback process (ST24). Or a new program setting process (ST20) can be parallelly executed during the video recording process (ST22) which is not timer program recording. Or, by utilizing the feature of disc recording that allows high-speed access, the playback process (ST24) and digital output process (ST26) can be parallelly executed during the video recording process (ST22). Also, the disc edit process (step ST28) can be executed during video recording on the HDD.



FIG. 45 is a flowchart (edit operation process flow) for explaining an example of the edit process (ST28). When the control enters the edit process, the flow branches to one of four processes (one of A to D) (step ST280) in accordance with the edit contents. Upon completion of one of an entry point edit process (step ST282A), copy/move process (step ST282B), delete process (step ST282C), and playlist generation process (step ST282D), the program update date performed by this edit process is set in respective pieces of management information (EX_PGI, EX_IT_TXT, EX_MNFI) (step ST284).


When one of the program information EX_PGI, cell information EX_CI, or EVOB/ESOB has been changed, this program update date (FIG. 32) may be set. When EVOBI and/or ESOBI have/has been changed, the edit times/time (EDIT_TIME) of the EVOBI and/or ESOBI can be set in ESOB_EDIT_TIME (not shown) or the like. Alternatively, this program update date (FIG. 32) may be set.


In this connection, in the process in step ST284, the manufacturer ID of the apparatus that has made the operation in one of steps ST282A to ST282D may be set in editor ID (LAST_MNF_ID) 13326 in FIG. 32. Every time one of the PGI, CI, and SOB (or VOB) has been changed, this editor ID can be set (or updated) to the ID information of the apparatus used at that time.



FIGS. 46 and 47 are flowcharts for explaining an example of the video recording operation of the apparatus in FIG. 43. Data processes upon stream recording are as follows.


d1) A program to be recorded is determined using EPG (Electronic Program Guide) in the program setting process, reception of that program starts, and the determined program is recorded.


d2) Upon reception of a recording command from the key input unit, MPU unit 80 loads management data from disc drive unit 51 and determines a write area. At this time, the MPU unit checks the file system to determine whether or not recording can be proceeded. If recording cannot be proceeded, the MPU unit displays a message that advises accordingly so that the user can abort the recording process. On the other hand, if recording can be proceeded, the MPU unit executes a pre-recording process (step ST105 in FIG. 46). In this process, MPU unit 80 determines the recording position, generates management information (HDVR_MG, etc.), and writes required in formation in respective management areas. In this case, if data to be recorded is not digital broadcast data (e.g., an analog video input or analog TV broadcast) (NO in step ST106), video recording (VR) can be adopted as the recording format in place of stream recording (SR). In this case, the control branches to a VR recording process.


d3) If data to be recorded is digital broadcast data (YES in step ST106), MPU unit 80 checks if the stream to be recorded is cognizable. If the stream to be recorded is cognizable (YES in step ST107), MPU unit 80 makes settings to generate management information as a type A stream on the PTM base (step ST109A); otherwise (NO in step ST107), MPU unit 80 makes settings to generate management information as a type B stream on the PATS base (step ST109B). After that, the MPU unit sets the write start address of stream data (video data) in disc drive unit 51, thus preparing for data recording (step ST112).


d4) In this preparation process, the MPU unit resets the count time of STC unit 102. Note that STC unit 102 is a system timer, and recording/playback is done with reference to this STC value.


d5) The PAT of a program to be recorded is loaded to determine the PID required to fetch the PMT of the target program. Then, the target PMT is loaded to determine the PIDs of data (video, audio) to be decoded (to be recorded). At this time, the PAT and PMT are saved in work RAM unit 80A of MPU unit 80, and they (PAT, PMT) are written in the management information (HDVR_MG). At this time, VMG file data is written in the file system (see FIG. 3), and required information is written in VMGI (HDVR_MGI in FIG. 4).


d6) Video recording settings are made in respective units (step ST114). At this time, a segmentation setting of data and a reception setting of TS packets are made in formatter unit 90. Also, the PID of data to be recorded is set to record only a target video stream. Furthermore, buffer 91 is set to start holding of TS packets (step ST116). Then, formatter unit 90 starts its operation as follows.


d7) ESOB_ESI is generated based on the PMT (step ST120 in FIG. 47).


d8) Next, a TS packet stream to be recorded is fetched onto buffer 91 (step ST130). If data stored in buffer 91 reaches a predetermined size (YES in step ST140), an ECC process is done via D-PRO unit 52, thus recording the data that have undergone the ECC process on disc 100 (and/or 100a) (step ST142).


d9) During video recording, segmentation information is saved in work RAM 80A of MPU unit 80 periodically (before buffer RAM 91 of formatter unit 90 becomes full of data) (YES in step ST114; step ST146). The segmentation information to be saved is ESOBU segmentation information, which includes the ESOBU start address, ESOBU pack length, I-Pic end address, the ESOBU arrival time (PATS), or the like.


d10) After the segmentation information is saved in work RAM 80A (step ST146) or if the save timing of the segmentation information is not reached (NO in step ST144), MPU unit 80 checks if ESOB data are delimited. If ESOB data are delimited (YES in step ST147), the MPU unit executes an ESOB delimitation process (FIG. 48).


d11) It is checked if video recording is to end (if the user has pressed a video recording end key or if no recordable space of the disc (100/100a) remains). If video recording is to end (YES in step ST148), remaining segmentation information is fetched from formatter unit 90, and is added to work RAM 80A. These data are recorded in management data (VMGI or HDVR_MGI), the average recording rate upon video recording is recorded, and the remaining information is recorded in the file system (step ST150).


d12) If video recording is not to end (NO in step ST148), the control returns to d8), continue the data fetch and write processes.


In order to display the contents of stream data, whose video recording is in progress, on the TV or the like, the stream data to be recorded is sent to decoder unit 59 simultaneously with D-PRO unit 52, so as to make simultaneous video recording monitor. In this case, MPU unit 80 makes settings upon playback in decoder unit 59, which then automatically executes a playback process. D-PRO unit 52 forms ECC groups by combining, e.g., every 16 packs of stream data to be recorded, appends ECC data to each group, and sends them to disc drive unit 51 (and/or HDD 100a). When disc drive unit 51 is not ready to record on disc 100, D-PRO unit 52 transfers the ECC groups to temporary storage unit 53 and waits until disc drive unit 51 is ready to record. When disc drive unit 51 is ready, D-PRO unit 52 starts recording onto disc 100. As temporary storage unit 53, a large-capacity memory is assumed since it must hold recording data for several minutes or longer by high-speed access. Note that MPU unit 80 can make read/write access to D-PRO unit 52 via a dedicated microcomputer bus, so as to read/write the file management area and the like.


The flow of signals upon recording will be briefly summarized below. That is, MPEG-TS packet data received by STB 83 (or terrestrial digital tuner 89) are converted into packet groups by formatter 90, and the packet groups are saved in buffer 91. When data stored in buffer 91 reach a predetermined size (for one or an integer multiple of CDA size), they are recorded on the disc (100 and/or 100a).



FIG. 48 is a flowchart (ESOB delimitation process flow) for explaining an example of the ESOB delimitation process (ST160). An example of the ESOB delimitation process will be described below.


e1) It is checked if data is to be continuously recorded. If data is not to be continuously recorded (NO in step ST1600), this process ends.


e2) It is checked if STC values are continued. If STC values are not continued (NO in step ST1602), a continuous recording flag is set, an STC continuous flag is reset, and an offset value at that time is set in STC_OFS (ST1610). If STC values are not continued (YES in step ST1602), the control advances to e5).


e3) It is checked if PATS data are continuous. If PATS data are not continuous (NO in step ST1612), a PATS continuous flag is reset, and an offset value at that time is set in PATS_OFS (ST1614), and the control advances to e7).


e4) If PATS data are continuous (YES in step ST1612), the PATS continuous flag is set, 0 is set in STC_OFS (ST1616), and the control advances to e7).


e5) It is checked if PATS data are continuous. If PATS data are not continuous (NO in step ST1604), the continuous recording flag is reset, the STC continuous flag is set, the PATS continuous flag is reset, 0 is set in STC_OFS, and an offset value is set in PATS_OFS (ST1608), and the control advances to e8).


e6) If PATS data are continuous (YES in step ST1604), the continuous recording flag is set, the STC continuous flag is set, the PATS continuous flag is set, 0 is set in STC_OFS, and 0 is set in PATS_OFS, and the control advances to e7).


e7) ESTR_FI of the ESOB of interest is set (ST1618), thus ending this process.



FIG. 49 is a flowchart (buffer fetch process flow for managing 6 bytes of PATS data) for explaining an example of the contents of the buffer fetch process (ST130). Upon recording, TS packet data received by the STB unit (or terrestrial digital tuner) are converted into packet groups by the formatter unit, and are saved in the work RAM. When data saved in the work RAM reach a predetermined size (for one or an integer multiple of CDA size), they are recorded on the disc. As the operations at that time, upon reception of TS packets, a group is formed every 170 packets, and a packet group header is generated. More specifically, the following operation is made.


f1) A TS packet is received (step ST1300).


f2) It is checked if the STC has reached an end (Wrap-around). If the STC has reached an end (YES in step ST1301), a CNT_SEG is generated based on position information of the TS packet at the time of Wrap-around. In this manner, position information CNT_SEG_S_PKT_POS (see FIG. 19) of the TS packet at the time when the time count of STC unit 102 has reached an end is registered in management information CNT_SEGI (step ST1303). If the STC has not reached an end (the continuous count of the STC is in progress) (NO in step S1301), or if CNT_SEGI has been registered, the control advances to the next process.


f3) If the packet of interest is the first one of a packet group (YES in step ST1306), Sync_Pattern: OOffa5a5a is set (step ST1308A in FIG. 49 or step ST1308B in FIG. 50); otherwise (NO in step ST1306), the control advances to step f6).


f4) In step ST1308A in FIG. 49, PAT data is used as the arrival time of the TS packet, the lower 4 bytes of the PAT data are allocated before that TS packet, and the upper 2 bytes of the first PATS data are set in the packet group header as FIRST_PATS_EXT.


f5) In step ST1308A in FIG. 49, 0 is set in PATS_SS, and the control advances to f7).


f6) In the TS packet fetched in the TS packet data area, the lower 4 bytes of the PATS data are appended before that TS packet (step ST1317C), and the TS packet is set in a packet group data area (step ST1317D).


f7) It is checked if a packet group is formed (if 170 TS packets are grouped). If a packet group is not formed yet (NO in step ST1322), the flow returns to f1). If the packet group is formed (YES in step ST1322), a PKT_GRP_GI setting process (step ST1340), CCI process (ST1330), and MNFI process (ST1350) are executed, and group data for one packet group are temporarily saved in buffer RAM 91 (step ST1332).



FIG. 50 is a flowchart for explaining another example of FIG. 49 (buffer fetch process flow in case of 4-byte management of PATS data). Processes different from FIG. 49 are as follows. That is, when PATS data has 4-byte accuracy, the process of FIRST_PATS_EXT in f4) and f5) is skipped in step ST1308B in FIG. 50 (or 0 is set in FIRST_PATS_EXT), and the value of PATS_SS is set to be 01.



FIG. 51 is a flowchart (PKT_GRP_GI setting process) for explaining an example of the packet group general information setting process (ST1340). The PKT_GRP_GI setting process will be described below with reference to FIG. 51.


g1) The packet type is checked. If the packet type indicates an MPEG-TS packet, a value “01” is set in PKT_GRP_TY; otherwise, a value suited to that type is set in PKT_GRP_TY (step ST13400).


g2) A value (e.g., “11”) corresponding to the BOOK version of the standard of interest is set in VERSION, and a STUF bit indicating if stuffing is done is set (to be, e.g., “0”) (step ST13400).


g3) If 0 is set in the STUF bit, “0xaa” is set in Valid_PKT_Ns (including the number of valid packets in a packet group and the upper 2 bytes of PATS data appended to the first packet) (step ST13406).



FIG. 52 is a flowchart (ESI setting process flow) for explaining an example of the contents of the stream information (ESI) generation process (ST120). An example of the ESOB_ESI setting process will be described below.


h1) PSI and SI are examined to check the number of set streams (step ST1201).


h2) f4) and f5) are repeated in correspondence with the number of set streams (in case of YES in step ST12130).


h3) A stream type is checked based on PSI and SI (step ST1203) to determine if the stream of interest is a video/audio stream or another type of stream to branch the control to the next stream check processes.


h4) In this case, the stream type is categorized to MPEG1 video, MPEG2 video, MPEG1 audio, MPEG2 audio, . . . , and internal data are checked depending on the determined type to read out respective kinds of attribute information.


h5) In case of a video stream, ES_TY=0 (step ST1213A), and respective kinds of attribute information are set (especially, resolution data, aspect information, and the like are extracted) to generate V_ATR (step ST1213C). The control then advances to f8).


h6) In case of an audio stream, ES_TY=0x40 (step ST1215A), and respective kinds of attribute information are set (especially, the sampling frequency, the number of channels, and the like are extracted) to generate A_ATR (step ST1215C). The control then advances to f8).


h7) In case of another kind of stream, ES_TY=0x80 (step ST1217A), and respective kinds of attribute information are set (step ST1217C). The control then advances to f8).


h8) Copy information is extracted to generate CP_CTL_INFORMATION (CCI) (step ST1220).


h9) New ESI is set based on the attribute information, and the control returns to check the next stream (in case of NO in step ST1230).


An example of the ESTR_FI generation process will be described below. FIG. 53 is a flowchart for explaining an example of a stream file information (ESTR_FI) generation process in the video recording end process (ST150).


j1) The number of search pointers (ESOBI_SRP) is increased by one to add another ESOBI, an area for that ESOBI is assured, and 0: MPEG_TS is set in PKT_TY (step ST1500).


j2) The video recording time is set in ESOB_REC_TM (step ST1502A). Note that the internal clock of the apparatus is set and corrected based on a TDT (Time Data Table), so that an accurate time can always be obtained.


j3) In this case, ESOB_S_PTM and ESOB_E_PTM data are extracted from the stream, and STC discontinuity information (e.g., CNT_SEGN in FIG. 19) is checked to set start and end PTMs of an ESOB corresponding to the ESOBI added in j1) (step ST1502A).


j4) If the stream type is a TS stream (ARIB, DVB) (YES in step ST1506), “188” is set in AP_PKT_SZ and “16” is set in PKT_GRP_SZ (step ST1508A) (NO in step ST1506); otherwise, a value corresponding to the broadcast scheme is set in AP_PKT_SZ (step ST1510).


j5) MPEG_TS is set in PKT_TY (step ST1514).


j6) TS_ID, NETWORK_PID, and PMT_ID (the PID of PMT data used by the ESOB of interest: there are two description methods of the PID: a method of describing the PID using 13-bit real data, and a method of describing the order in the PMT) are set based on PAT data (step ST1514).


j7) Program_Number (SERVICE_ID in PMT) and PCR_PID are set based on PMT data. Furthermore, as for FORMAT_ID and VERSION, default values in the apparatus (in case of the built-in tuner) or Registration_Descriptor values sent via a digital input (in case of an external digital input) are set (step ST1516A).


j8) Moreover, the number of recorded ESs is set. (The PMT is set with information: the number of all broadcasted ESs, but since not all ESs are always recorded upon video recording, the number of recorded ESs is set.)


j9) The video recording start LB address is set in ADR_OFS (step ST1550A), and a default PID is set. Note that the default video PID corresponds to that with a smallest component tag value or that of a stream corresponding to a component tag described in a main component group in case of multi-view TV.


j10) A GPI setting process (ST1530), TMAP setting process (step ST1540), and the like are executed, and TMAPI is generated for each stream on the basis of each segmentation information (step ST1540).


j11) PATS_SS is set according to the PATS accuracy (the same value as that in the packet group header is set) (step ST1551).


j12) An edit date is set (step ST1554).



FIG. 54 is a flowchart for explaining an example of the GPI setting process (ST1530). This GPI setting process can be executed as follows.


k1) A stream type is checked (step ST15300B).


k2) If a plurality of programs form one stream (YES in step ST15300B), information indicating the presence of GPI is set in ESOB_TY, GPI_TY=0, PRIORITY=0 for all programs, one GPI is generated per program, and the number of groups is set (step ST15302B). The flow then advances to k5).


k3) In case of rain attenuation broadcast (YES in step ST15304B), information indicating the presence of GPI is set in ESOB_TY, GPI_TY=40 h, the top layer is set to be PRIORITY: 1, and other layers are set to be PRIORITY: 2. One GPI is generated per layer, and the number of groups is set (step ST15306B). The flow then advances to k5).


k4) In case of multi-view broadcast (YES in step ST15308B), information indicating the presence of GPI is set in ESOB_TY, GPI_TY=40 h, the top layer is set to be PRIORITY: 1, other layers are set to be PRIORITY: 2, and one GPI is generated per view (step ST15310B). Otherwise (NO in step ST15308B), 1 is set in ES_TMAP_Ns and information indicating the absence of GPI is set in ESOB_TY (step ST15321B). It is checked if ESs to be grouped (GP) still remain. If such ESs still remain (YES in step ST15314B), the flow returns to k1); otherwise (NO in step ST15314B), the number of groups is set, and the control advances to k5).


k5) It is checked if another group (GP) remains. If such group remains, the flow returns to k1); otherwise, a playlist is generated based on the PID of the currently selected group (step ST15316B), thus ending this process.


k6) In this way, if playback is made using the currently selected group, the playlist automatically generated in step ST15316B can be played back.



FIG. 55 is a flowchart for explaining the TMAP setting process (ST1540). An example of the TMAP setting process will be described below.


m1) The ESOB/EVOB structure is determined (step ST15400).


m2) In case of the ESOB, TMAP_TY is determined (step ST15403). If this ESOB is on the PTM base, ESs used to generate an STMAP are determined in consideration of the number of GPs, the number of ESs (the number of video ESs) is set as the number of TMAPs, and ES_PID to be generated is set for each TMAP. (However, one TMAP need not always be assigned to one GP. If no TMAP is available, another ES_TMAP of the identical ESOB is used to implement playback, search, special playback, and the like.) On the other hand, in case of an ESOB (AT_ESOB) on the PATS base or EVOB, one TMAP is added (see FIG. 24 for the data structure of a TMAP on the PATS base).


m3) The ESOB (PTM base)/EVOB start and end times, the start and end times for each TMAP, the number of entries, the arrival time of the first packet of the ESOB (PATS base), the arrival time of the last packet of the ESOB, and the like are set based on segmentation information (step ST15405).


m4) A TMAPT is added, and an entry information generation process is executed based on segmentation information (step ST15407). That is, in case of the ESOBU of TYPE A, 1st_REF_PIC_SZ (the end address of the first I-Pic; 0 is set if no I-Pic is available), ESOBU_SZ (indicating the ESOBU size by a packet group unit), ESOBU_S_PKT_POS (the position of the first packet in a packet group), and the like are set. On the other hand, in case of the ESOBU of TYPE B, ESOBU_SZ (indicating the ESOBU size by a packet group unit) and ESOBU_S_PKT_POS (the position of the first packet in a packet group (PKT unit)) are set. m5) ESOBU_SZ and ESOBU_PB_TM are generated. Note that the TMAPT information is stored as an independent file or is added to the end of the IFO file. m6) When an edit process is made, the update date information of the edited TMAP is set in STMAP_LAST_MOD_TM (or VTMAP_LAST_MOD_TM) (step ST15409).



FIG. 56 is a flowchart for explaining the EVOB/ESOB structure setting process (ST15400). An example of the EVOB/ESOB structure setting process will be described below.


n1) The recorded time is checked (step S154000). If the recorded time is equal to or shorter than two hours, the control advances to n2); if it falls within the range from two to four hours, the control advances to n3); or if it is equal to or longer than four hours, the control advances to n4) (step ST154001).


n2) “0” is set in EVOB/ESOB_PB_TM_RNG, and EVOBU/ESOBU_ENT data are generated based on segmentation information (information of 0.4 s to 1 s) so that each ESOBU has a time range of 0.4 s to 1 s (step ST154002). The control then advances to n5).


n3) “1” is set in EVOB/ESOB_PB_TM_RNG, and EVOBU/ESOBU_ENT data are generated based on segmentation information (information of 0.4 s to 1.0 s) so that each ESOBU has a time range of 1.0 s to 2.0 s (step ST154003). The control then advances to n5).


n4) “2” is set in EVOB/ESOB_PB_TM_RNG, and EVOBU/ESOBU_ENT data are generated based on segmentation information (information of 0.4 s to 1.0 s) so that each ESOBU has a time range of 2.0 s to 3.0 s (step ST154004). The control then advances to n5).


n5) This process ends.



FIG. 57 is a flowchart for explaining the CP_CTL_INFO (CCI) generation process (ST1220). An example of the CP_CTL_INFO setting process will be described below.


p1) It is checked if the latest PMT and EIT include copy information. If copy information is included (YES in step ST12200), its copy control descriptors are extracted (step ST12204), and copy information is formed and set based on the copy control descriptors (step ST12206). The control then advances to p3).


p2) If no copy information is included (NO in step ST12200), “copy free” is set (step ST12202).


p3) It is checked if the latest PMT and EIT include contents use descriptors. If the contents use descriptors are included (YES in step ST12208), the contents use descriptors are extracted (step ST12212), and ICT and EPN are set based on the information (step ST12214A).


p4) If no contents use descriptors are included (NO in step ST12208), ICT and EPN are formed as “copy free” (step ST12210). Note that the ICT, EPN, retention, and the like in step ST12214A or ST12210 have been described in the description of CCI with reference to FIG. 40.


Another example of the CCI setting process will be explained below using FIG. 57.


1) It is checked if the latest PMT and EIT include copy information. If copy information is included, copy information is formed and set based on that information (step ST12206). The control then advances to 3).


2) If the received TS packet does not include any copy information, the same information as in the previous pack is formed as copy information (this process is different from step ST12202).


3) It is checked if the latest PMT and EIT include contents use descriptors. If the contents use descriptors are included, the following process is made. That is, if the values of the contents use descriptors have changed in the middle of a packet group, dummy data is inserted in the previous packet group to form a new packet group after the changed position, and CCI is set based on that information (this process is different from step ST12214A). At this time, 1 is set in PKT_GRP_GI: STUF, and the number of valid packets is set in PKT_GRP_GI: VALID_PKT_Ns.


4) If the received TS packet does not include any copy information, CCI is formed as “copy free”.



FIG. 58 is a flowchart for explaining an example of the program chain (PGC) generation process (including a program setting process) in the video recording end process (ST150). The PGC generation process in this process will be described below.


q1) It is checked if a disc of interest undergoes the first video recording. If the disc of interest undergoes the first video recording (YES in step ST1600Z), new ORG_PGC is generated (step ST1602Z); otherwise (NO in step ST1600Z), a setting is made to add program PG after the already recorded PGC (ORG_PGC) (step ST1604Z).


q2) Erase permission: 0 is set in PG_TY, the number of cells is set in Cell_Ns, and the video ESI number is also set (step ST1700Z).


q3) In the setting of step ST1700Z, if the digital broadcast to be recorded is ARIB, and if language_code in a short event descriptor in an EIT is “jpn”, “0x12” is set in CHR in VMG_MAT, EVENT_NAME is set in the second field of PRM_TXTI, and representative picture information is set in REP_PICTI.


q4) The manufacturer ID of this apparatus is set in LAST_MNF_ID (step ST1702Z). As for this value, when PGI, CI, or EVOB has been changed, the manufacturer ID of the apparatus used to change such information is set to identify the manufacturer of the last apparatus used to execute edit and record processes. With this manufacturer ID, when the apparatus of another manufacturer is used to change the recorded contents of a disc, a reaction can be easily taken.


q5) In the setting of step S1702Z, the absolute number of PG is set in PG_INDEX to allow another application software or the like to refer to each PG. Furthermore, this PG update date information is recorded. At this time, if MNFI and IT_TXT (with the same manufacturer code) supported by this apparatus are found, the update date information of corresponding data is also set.


q6) Information unique to each manufacturer is set in MNFI.


q7) Information indicating a streamer is set in CELL_TY (e.g., cell type included in cell information EX_CI in FIG. 35) (step ST1704Z).


q8) In the setting of step ST1704Z, the reference ESOB number is set, the representative (video) PID or Component Group Id is set as the ID to be played back, and the number of pieces of entry point information EPI (FIG. 36), playback start and end PTMs, and entry points EPs are set. Furthermore, discontinuous segments CNT_SEG exemplified in FIG. 19 are read, the number of CNT_SEGs is set in, e.g., CNT_SEGN in FIG. 37, and the block number of the ESOB to be played back is set.


q9) Moreover, in the setting of step ST1704Z, start information is set in RG_RSM_INF (playback start PTM, video ESI number, audio ESI number, main/sub information of Dual-Mono) so that playback can start from the head of the program. The factors of automatic EP assignment in the video and time relationships are a constant time and a video mode change (an aspect ratio, and large motion vectors), and the first packet (the first packet of a sequence header, the first packet of I-PIC) of the first packet (Unit Start Indicator) GOP of a video frame is combined with these conditions. Furthermore, the factors of automatic EP assignment in the audio relationship are a change in audio (a change in audio volume or the like)/audio mode (ST/MONO), and the first packet (Unit Start Indicator, frame header) of an audio frame is combined with these conditions.



FIG. 59 is a flowchart (overall playback operation flow) for explaining an example of the playback operation. The data processes upon playback are executed as follows (see FIGS. 59 to 66).


r1) A disc check process is made first to check if the disc of interest is a rewritable disc (R, RW, RAM). If the disc of interest is not a rewritable disc, a message that advises accordingly is returned, and the process ends.


r2) If the disc of interest is a rewritable disc, the file system of the disc is read out to check if data has already been recorded (step ST207). If no data is recorded, a message “no data is recorded” is displayed, thus ending the process.


r3) The VMG file is loaded (step ST207) and programs and cells to be played back are determined (they are determined as defaults or are selected by the user) (step ST208). In this case, if a playback process in the recorded order is selected, playback is made according to ORG_PGCI; if a playback process for each program is to be made, playback is made according to UD_PGC (playlist) with a number corresponding to the program to be played back.


r4) The value of PKT_TY is read out to check if the broadcast scheme is supported. If the broadcast scheme is unsupported, a message that advises accordingly is displayed, and the process ends (or the control advances to process the next cell).


r5) The ESOB/EVOB to be played back, playback start PTM, and the like are determined based on title information, resume information (PL_RSM_IFO, PG_RSM_IFO), cell information EX_CI) to be played back, and the like (step ST211), and a playback start file pointer (logical address) and ESI of a stream to be played back are determined based on the playback start PTM. Furthermore, respective decoder units are set based on STI and ESI values to prepare for playback. Also, APS setups (e.g., APS=ON/OFF, APS type, and the like) are set in the video decoder based on CCI in the packet group header at the head position, and CGMSA settings are made in the video recorder based on digital copy control. Moreover, if a digital output (IEEE1394, Internet, or the like) is available, 0: scramble ON or output inhibition or 1: direct output is set in the output IC based on the EPN value. If ICT=0, the image resolution is constrained, i.e., HD is converted into SD; if ICT=1, “direct output” is set in the output IC. At this time, if the playback start frame is not I-picture data, decoding starts from immediately preceding I-picture, and display starts when the target frame is decoded, thus starting normal playback.


r6) A process upon playback start is executed. It is checked if an object to be played back is an ESOB. Even if the object to be played back is an ESOB (YES in step ST213), if it is a playback-inhibited ESOB (YES in step ST215), the next cell is set based on PGCI (step ST232), and the flow returns to step S211.


r7) If the object to be played back is an EVOB (NO in step ST213) or if it is an ESOB that can be played back (NO in step ST215), respective decoders are set (step ST217).


r8) Next, a cell playback process is executed (step ST220), and it is then checked if playback is to end. If playback is to end (YES in step ST230), an error check process is executed. If any error is found (YES in step ST240), a message that advises accordingly is displayed (step ST242), and a playback end process is executed (step ST244). If no error is found (NO in step ST240), anther playback end process is executed (step ST246), thus ending this operation.


r9) If playback is not to end (NO in step ST230), the next cell is determined based on PGCI (step ST232), and the flow returns to step ST211. It is checked if the settings of decoder unit 59 (step ST217) have been changed. If the settings of decoder unit 59 have been changed, changed attributes are set in decoder unit 59 so as to change decoder settings in response to the next sequence end code.


r10) The same processes (steps ST211 to ST232) are repeated while checking if playback is to end (step ST230).



FIG. 60 is a flowchart for explaining the decoder setting process (ST217). An example of the decoder setting process will be described below.


s1) If an object to be played back is an ESOB (YES in step ST2170), a group to be played back is determined first, and ESs to be played back are determined in accordance with GPI (step ST2171). If an object to be played back is an EVOB (NO in step S2170), the control skips step ST2171.


s2) Attribute information (STI, ESI) of the ESOB (or EVOB) to be played back is loaded (step ST2172).


s3) It is checked if the ESOB (or EVOB) to be played back has a format supported by the recorder (the apparatus in FIG. 43 or the like). If the format is unsupported (NO in step ST2173), apparatus settings are made not to play back the ESOB and display mute is set (step ST2175).


s4) If video data to be played back can be played back (YES in step ST2173), playback preparation is made (step ST2174A). In this case, the PID can be used intact if the 13-bit PID is set. However, the PID is determined with reference to PMT data if it is set based on the order in the PMT data.


s5) It is checked if audio data to be played back can be played back. If the audio data can be played back (YES in step ST2176), playback preparation is made (step ST2177A). In this case, the PID can be used intact if the 13-bit PID is set. However, the PID is determined with reference to PMT data if it is set based on the order in the PMT data. If the audio data cannot be played back (NO in step ST2176), apparatus settings are made not to play back the audio data and audio mute is set (step ST2178).


s6) A copy control process is executed based on CCI information which includes the contents generated in the process of, e.g., FIG. 57 (step ST2179).



FIG. 61 is a flowchart for explaining an example of the process upon cell playback. The cell playback process is executed as follows.


t1) Start file pointer FP (logical block number LBN) and end file pointer FP (logical block number LBN) of EX_CELL are determined on the basis of the contents of TMAPI. Furthermore, start ESOBU_ENTRY and end ESOBU_ENTRY are determined based on the start and end times in EX_CI, and the data lengths of entries until target ESOBU_ENTRY are accumulated in ADR_OFS, thus obtaining a start address (LB=FP) and end address. The remaining EX_CELL length is calculated by subtracting the start address from the end address, and the playback start time is set in the STC (step ST2200). The PID to be played back is determined and is set in the decoder (STB, digital tuner). In this case, the PID can be used intact if the 13-bit PID is set. However, the PID is determined with reference to PMT data if it is set based on the order in the PMT data.


t2) An ESOB continuity check process is executed (step ST2201).


t3) A read process during playback is executed to determine the read address and read size based on the start file pointer (step ST2206).


t4) The read unit size to be read out is compared with the remaining cell length. If the remaining cell length is larger than the read unit size (YES in step ST2207), a value obtained by subtracting the read unit size to be read out from the remaining cell length is set as the remaining cell length (step ST2208). If the remaining cell length is smaller than the read unit size (NO in step ST2207), the read unit size is set to be the remaining cell length, and the remaining cell length is set to be zero (step ST2209).


t5) The read length is set to be a read unit length, and the read address, read length, and read command are set in the disc drive unit (step ST2210).


t6) If data transfer starts (YES in step ST2212), the control waits until data for one ESOBU are stored. If data for one ESOBU are stored (YES in step ST2214), data for one ESOBU are loaded from the buffer (step ST2216), and a buffer decoder transfer process is executed (step ST2220). After read file pointer FP is incremented and the MPEG decoder is set in a normal mode (step ST2224), the control advances to t7).


t7) It is checked if transfer is complete. If transfer is complete (YES in step ST2226), the control advances to t8).


t8) It is checked if an angle key or the like has been pressed. If the angle key has been pressed (YES in step ST2238), it is checked if GPI is available. If GPI is available (YES in step ST2239), a GP switching process is executed (step ST2240); otherwise (NO in step ST2239), the control advances to the process in step ST2228 without any process.


t9) If the angle key or the like has not been pressed (NO in step ST2238), it is checked if a Skip SW has been pressed. If the Skip SW has been pressed (YES in step ST2248), a SKIP process is executed (step ST2250).


t10) If the Skip SW has not been pressed (NO in step ST2248), it is checked if a STOP SW has been pressed. If the STOP SW has been pressed (YES in step ST2258), resume information (RSM_IFO) is saved in PG_RSM_IFO in case of title playback or in PL_RSM_IFO in case of playlist playback, and an end process is executed (step ST2260A).


t11) If the STOP SW has not been pressed (NO in step ST2258), the remaining cell length is checked. If the remaining cell length is not “0”, i.e., if the current cell is not the last one (NO in step ST2228), the flow returns to step ST2206; if it is “0” (YES in step ST2228), this process ends.



FIG. 62 is a flowchart for explaining the ESOB continuity check process (ST2201). The ESOB continuity check process upon playback is executed, for example, as follows.


u1) It is checked if the current ESOB is continuously recorded with the previous ESOB (continuous recording flag in FIG. 22). If the two ESOBs are not continuously recorded (NO in step ST22010), this process ends.


u2) If the two ESOBs are continuously recorded (YES in step ST22010), it is checked if STC values are continuously input (STC continuous flag in FIG. 22). If STC values are continuously input (YES in step ST22012), an STC_OFS value is added to the current STC value to set a new STC value (step ST22014).


u3) After the STC_OFS value is added to the STC value (step ST22014), or if STC values are not continuously input (NO in step ST22012), it is checked if PATS values are continuously input (PATS continuous flag in FIG. 22). If PATS values are continuously input (YES in step ST22016), the control waits for data transfer to the decoder for a time corresponding to the value of PATS_OFS (step ST22018). For example, in case of the STB, the control waits for data transmission for a time corresponding to the value of PATS_OFS. If PATS values are not continuously input (or by adding the PATS_OFS time) (NO in step ST22016), this process ends.



FIG. 63 is a flowchart for explaining the data transfer process from the buffer RAM to the decoder. An example of the buffer data decoder transfer process will be described below.


v1) The number of packet groups in the buffer RAM is checked. If no packet group is found, the control skips the process in FIG. 63. If one or more packet groups are stored in the buffer RAM, a setting is made to process the first packet group (step ST22200).


v2) A target packet group is read out from the buffer RAM (step ST22201). The head of the packet group is detected based on the packet group length and Sync_Pattern.


v3) The STUF bit (FIG. 39) of the packet group header is checked. If “1” is set, valid packets are extracted in accordance with the value of VALID_PKT_Ns (step S22202A). If “1” is not set in the STUF bit, it is determined that 170 packets are valid ones.


v4) The PATS accuracy is detected based on PATS_SS, and a transfer time of each TS packet is calculated from the PATS data (FIRST_PATS_EXT+PATS of the immediately preceding TS packet: in case of 4-byte accuracy) and PATS_SS (step ST22202B), and each TS packet is sent to the decoder unit (STB unit) at that time (step ST22203). In case of the 6-byte accuracy, the upper 2 bytes of PATS data of the first packet of the packet group are used as FIRST_PATS_EXT, and lower 4 bytes of PATS data of the immediately preceding TS packet are set from there, thus calculating the transfer time of each TS packet. In case of 4-byte accuracy, PATS data is calculated from the immediately preceding PATS data in consideration of carry. In case of no accuracy, after packet data is extracted, a TS packet is output as soon as a request is received.


v5) Upon completion of packet transfer to the decoder unit (YES in step ST22204), a copy control setting process (CCI process) is executed (step ST22205).


v6) After that, it is checked if manufacturer information MNF is available. If manufacturer information MNF is available, it is checked if its manufacturer ID matches that of the manufacturer of the apparatus of interest. If the two IDs match, data of manufacturer information MNF is loaded to execute a predetermined process (process unique to each manufacturer) (step ST22270).


v7) Next, a discontinue process is executed (step ST22280).


v8) The control waits for completion of transfer, and it is checked if packet groups still remain in the buffer RAM. If no packet group remains in the buffer RAM (NO in step ST22206), this process ends.


v9) If packet groups still remain in the buffer RAM (YES in step ST22206), a setting is made to process the next packet group (step ST22207), and the flow returns to step ST22201.



FIG. 64 is a flowchart for explaining an example of the GP switching setting process. The GP switching process is executed, for example, as follows.


x1) The type of selector switch SW is checked (step ST22400X).


x2) Grouping information GPI of packet group GP whose playback is currently in progress is loaded (step ST22401X).


x3) It is checked if the GPI is stored. If no GPI is stored (NO in step ST22403X), this process ends.


x4) If the GPI is stored (YES in step ST22403X), the GPI information is loaded to switch another GP (step ST222405X), and a decoder setting process is executed (step ST22410).



FIG. 65 is a flowchart for explaining an example of the discontinue process. The discontinue process will be described below.


y1) Discontinuity information DCNI is read out and checked (step ST22800). If a CNT_SEG gap is found at the playback position (YES in step ST22802), the playback mode of the decoder is shifted to an internal clock mode (an operation mode that ignores the PTS value, makes playback using only internal clock values, and enables PTS data upon reception of PCR data: external sync mode) (step ST22804), thus ending this process.


y2) If no CNT_SEG gap is found at the playback position (NO in step ST22802), this process ends without any process.



FIG. 66 is a flowchart for explaining an example of the skip process. The skip process can be executed as follows.


z1) Entry point information table EPIT is loaded (step ST22500).


z2) The SKIP direction (determined by the type of SKIP key) is checked. If the SKIP direction is a forward direction (YES in step ST22502), entry point EP which is located ahead of the current playback position and has the same PID as the current playback PID is searched for, and its information is loaded (step ST22504). On the other hand, if the SKIP direction is a backward direction (NO in step ST22502), entry point EP which is located before the current playback position and has the same PID as the current playback PID is searched for, and its information is loaded (step ST22506).


z3) An ESOBU_ENT to be played back is determined based on the detected EPI (step ST22508).


z4) ESOBU_ENT information is loaded to determine the playback start time (STC) (step ST22510).


z5) It is checked if the target ESOBU_ENT includes I-PIC (by checking if 1ST_REF_SZ=0). If the target ESOBU_ENT includes no I-PIC (NO in step ST22512), the immediately preceding ESOBU_ENT information of the identical group is loaded (step ST22514) to repeat the processes in steps ST22512 to ST22514.


z6) If the target ESOBU_ENT includes I-PIC (YES in step ST22512), sequence header SH in the ESOBU_ENT is loaded and is set in the decoder (step ST22522). Then, the I-PIC found previously is read out, and the decoder is set to start decoding from that position, and to start display from the playback time designated by the EP (step ST22514), thus shifting to a normal playback process.


With this process, a file control operation corresponding to digital broadcast can be implemented.


<Summary>


1. In a digital recorder (DVD streamer or the like) which can record digital streams, if Wrap-around of the STC has occurred, that position is set in ESOBI as CNT_SEG, and the CNT_SEG count information from the head of the ESOB is appended to each PMT.


2. In the digital recorder (DVD streamer or the like) which can record digital streams, an ESI number used in a video stream upon playback is appended to each representative picture information so as to specify a video stream.


3. In the digital recorder (DVD streamer or the like) which can record digital streams, an ESI number used in a video stream upon playback, an ESI number used in an audio stream, and main/sub information when audio is Dual-Mono are appended to each resume information so as to specify a stream to be played back.


4. In the digital recorder (DVD streamer or the like) which can record digital streams, an ESI number used in a video stream upon playback, an ESI number used in an audio stream, and main/sub information when audio is Dual-Mono are appended to each EP information so as to specify a stream to be played back.


5. An STC continuous flag and/or PATS continuous flag and its offset value are appended as seamless information indicating continuity among logically continuous ESOBs in addition to a continuous recording flag.


<Effect of Embodiment>






    • Whether or not STC Wrap-around has occurred can be detected based on only playback information before execution of playback.

    • Continuity among a plurality of ESOBs can be detected. If ESOBs are continuous, cases that can seamlessly connect a plurality of ESOBs can increase. That is, the frequency of occurrence of a situation in which the control waits for a playback process at a joint portion of a plurality of ESOBs which are detected to be continuous (a still picture is inserted) can be lowered than in a case wherein this invention is not practiced.





Note that the invention is not limited to the aforementioned embodiments, and various modifications may be made on the basis of techniques available at that time without departing from the scope of the invention when it is practiced at present or in the future. The respective embodiments may be combined as needed, and combined effects can be obtained in such case. Furthermore, the embodiments include inventions of various stages, and various inventions can be extracted by appropriately combining a plurality of required constituent elements disclosed in this application. For example, even when some required constituent elements are omitted from all the required constituent elements disclosed in the embodiments, an arrangement from which those required constituent elements are omitted can be extracted as an invention.

Claims
  • 1. (canceled)
  • 2. An information medium comprising one or more data areas configured to store object information, and a management area configured to store management information for managing the object information, wherein one of said data areas is configured to record a stream object using a stream object unit in which are contained packet groups each including a packet group header and multiple pairs of packet arrival time information and an MPEG transport stream packet, and the management information to be stored in said management area includes program chain information for a chain of programs, said program chain information including program representative picture information which contains an elementary stream information number for a video elementary stream of a representative picture of the program.
  • 3. A method of recording information on an information medium comprising one or more data areas configured to store object information, and a management area configured to store management information for managing the object information, wherein one of said data areas is configured to record a stream object using a stream object unit in which are contained packet groups each including a packet group header and multiple pairs of packet arrival time information and an MPEG transport stream packet, and the management information to be stored in said management area includes program chain information for a chain of programs, said program chain information including program representative picture information which contains an elementary stream information number for a video elementary stream of a representative picture of the program, said method comprising: recording the stream object on the data area, and recording the management information on the management area.
  • 4. A method of reproducing information from an information medium comprising one or more data areas configured to store object information, and a management area configured to store management information for managing the object information, wherein one of said data areas is configured to record a stream object using a stream object unit in which are contained packet groups each including a packet group header and multiple pairs of packet arrival time information and an MPEG transport stream packet, and the management information to be stored in said management area includes program chain information for a chain of programs, said program chain information including program representative picture information which contains an elementary stream information number for a video elementary stream of a representative picture of the program, said method comprising: reproducing the management information from the management area, and reproducing the stream object from the data area.
  • 5. A recording apparatus for recording information on the information medium as defined in claim 2, said apparatus comprising: a first recorder configured to record the stream object on the data area, and a second recorder configured to record the management information on the management area.
  • 6. A reproducing apparatus for reproducing information from the information medium as defined in claim 2, said apparatus comprising: a first reproducer configured to reproduce the management information from the management area, and a second reproducer configured to reproduce the stream object from the data area.
Priority Claims (1)
Number Date Country Kind
2004-353392 Dec 2004 JP national
Continuations (1)
Number Date Country
Parent 11281531 Nov 2005 US
Child 11562530 Nov 2006 US