DATA PROCESSOR

Information

  • Patent Application
  • 20090080509
  • Publication Number
    20090080509
  • Date Filed
    November 16, 2005
    19 years ago
  • Date Published
    March 26, 2009
    15 years ago
Abstract
To allow the user to specify easily a frame when video, of which the frame rate (or vertical scanning frequency) has been converted, is being edited.
Description
TECHNICAL FIELD

The present invention relates to a technique of facilitating the playback and editing of a content by efficiently managing the content data stream on a medium.


BACKGROUND ART

Recently, various types of digital appliances (such as optical disk recorders and camcorders) that can write and store content digital data on a number of types of media including an optical disk such as a DVD, a magnetic disk such as a hard disk, and a semiconductor memory, have become more and more popular. The content may be a broadcast program or the video and audio that have been captured with a camcorder, for example.


Also, lately PCs often have the functions of recording, playing and editing a content, and may also be counted among those digital appliances. In writing data such as document data, PCs have used various media such as a hard disk, an optical disk and a semiconductor memory. That is why a file system that has a data management structure compatible with a PC such as a file allocation table (FAT) has been adopted in such media. The FAT 32 file system that is often adopted currently can handle a file that may have a maximum size of 4 gigabytes or can manage a medium with a maximum storage capacity of 2 terabytes.


The bigger the maximum storage capacity of a medium, the longer the overall playback duration of the content stored there. The optical disks, hard disks, semiconductor memories and so on are so-called “randomly accessible” media. Therefore, when a content data stream with a long duration is stored on such a medium, it would be convenient if playback could be started from any arbitrary point of the content.


For example, Patent Document No. 1 generates time map information, defining correspondence between a presentation time and the address at which the AV data to play back at the time is stored, at regular time intervals from the beginning of a data stream. If the start time and end time, specified by the user, are converted into a start address and an end address, respectively, by reference to the time map information and if the data stored at those addresses are read, the content can start being played back at the specified time.


Meanwhile, camcorders having the function of recording video at a rate of 24 frames per second have been put on the market just recently. The commercial movies have been shot at that rate of 24 frames per second, and therefore, those camcorders have made it easier for general consumers to produce movies by themselves.


In general, to record video at the rate of 24 frames per second in a format compliant with the MPEG-2 standard, the 3:2 pull-down technology is employed. The video that can be viewed on TVs in the NTSC regions has a frame rate of 60 frames per second. That is why to convert the frame rates, 3:2 pull-down processing is carried out and video is recorded.



FIG. 37 shows the presentation timing relations of respective frames when video to be presented at a rate of 24 frames per second is converted into video to be presented at a rate of 60 frames per second by the 3:2 pull-down technology. Each frame is presented for 1/24 second before the conversion and for either 3/60 second or 2/60 second after the conversion. The latter means that two or three frames, each of which should be presented for 1/60 second, are output continuously.


In this case, those frames are presented at the rate of 60 frames per second with time codes that are updated 60 times a second. For example, a start frame is presented as “0 hr 0 min 0 s 0th frame”. On the other hand, the 50th frame from the start point is presented as “0 hr 0 min 0 s 50th frame”. In FIG. 37, only two-digit numerals representing the seconds and frame numbers are shown.

    • Patent Document No. 1: Japanese Patent Application Laid-Open Publication No. 11-155130


DISCLOSURE OF INVENTION
Problems to be Solved by the Invention

In editing such 3:2 pull-down processed video, if a frame is specified by one of the time codes to be updated 60 times a second, then sometimes the same type of editing should be repeated a number of times. This is because it is difficult to determine which of the identical frames to be presented two or three times consecutively has been specified by the time code.


For example, in a situation where the user need to specify an IN point, indicating the start point of a video interval, by a time code, suppose the IN point specified is the second one of the three identical frames to be presented three times in a row. In that case, he or she who is editing thinks a different frame would be presented next by advancing the video by a frame. Actually, however, the identical frame is presented once again for the next one frame period (i.e., for 1/60 second), thus making him or her uncomfortable. Furthermore, even if the user has deleted the second frame and the rest of the video interval by editing, the frame to be presented first has not been deleted yet and is presented anyway. That is why he or she has to do editing to delete that first frame, which is very inconvenient and troublesome for him or her.


An object of the present invention is to allow the user to specify easily a frame yet to be converted in a situation where video, of which the frame rate (or vertical scanning frequency) has been converted, needs to be edited.


By allowing the user to set an editing point easily using a time code associated with the original frame rate before the frames have been converted, an edit decision list (EDL) and other lists can be compiled more easily using the time codes. As a result, efficiency of editing can be increased significantly both in online editing and nonlinear editing. Also, even in generating editing information by combining the time codes and SMIL language with each other, the information can also be generated more easily.


In addition, by doing editing at the original frame rate before the conversion, there is no longer any need to pay attention to redundant frames or fields around the editing point and the editing can get done more easily.


Means for Solving the Problems

A data processor according to the present invention includes: a receiving section for receiving a signal representing first video in which a plurality of pictures are presented at a first frequency; an encoder for generating a data stream representing second video, in which the pictures are presented at a second frequency, different from the first frequency, based on the signal; and a writing section for writing the data stream on a storage medium. The encoder generates picture data about the respective pictures, first time information indicating presentation times at the first frequency, and second time information indicating presentation times at the second frequency, and stores the first time information, the second time information and picture data of the respective pictures to be presented based on the first time information in association with each other, thereby generating the data stream.


The data processor may further include a control section for generating management information to play back the video. The control section may generate, as the management information, meta-data that includes information on the first frequency and information on the second frequency.


The data processor may further include a control section for generating management information to play back the video. The control section may further generate, as the management information, meta-data that includes the first time information.


The encoder may generate a playback unit including the picture data, the first time information and the second time information on at least one picture, and may generate the first time information and the second time information for the picture of the playback unit.


The encoder may generate a playback unit including data about a base picture that is decodable by itself, data about at least one reference picture that needs to be decoded by reference to the key picture, the first time information and the second time information. And the encoder may generate the first time information and the second time information for at least the first key picture of the playback unit.


The receiving section may receive the signal representing the first video in which 24 pictures are presented one after another per second. And the encoder may generate the data stream representing the second video in which 60 pictures are presented one after another per second.


EFFECTS OF THE INVENTION

According to the present invention, when the frame rate (or vertical scanning frequency) of video is converted, each frame data is stored with not only time information at the converted frequency but also time information at the frequency yet to be converted. For example, if video with a rate of 60 frames per second is generated by subjecting video with a rate of 24 frames per second to 3:2 pull-down processing, not only time codes to be updated 60 times a second but also time codes to be updated 24 times a second are added. If the editor sets IN and OUT points using the latter time codes, video can be edited (e.g., frames can be deleted or a play list can be drawn up) based on the contents of the frames. As a result, editing can get done in a shorter time.





BRIEF DESCRIPTION OF DRAWINGS


FIG. 1 illustrates multiple types of data processors that operate in association with each other by way of removable media.



FIG. 2 shows an arrangement of functional blocks in the camcorder 100.



FIG. 3 shows the data structure of a transport stream (TS) 20.



FIG. 4(
a) shows the data structure of a video TS packet 30 and FIG. 4(b) shows the data structure of an audio TS packet 31.


Portions (a) to (d) of FIG. 5 show a stream correlation to be established when video pictures are played back from video TS packets.



FIG. 6 shows the data structure of a clip AV stream 60.



FIG. 7 shows an arrangement of functional blocks for the TS processing section 204.


Portion (a) of FIG. 8 shows the concept of a single content according to this preferred embodiment, portion (b) of



FIG. 8 shows the concept of clips, each including the management information of the content and stream data, and portion (c) of FIG. 8 shows three removable HDDs 112.



FIG. 9 shows the hierarchical directory structure in the removable HDD 112.



FIG. 10 shows the contents of information included in the clip meta data 94.



FIG. 11 shows a relation between key pictures and a key picture unit.


Portion (a) of FIG. 12 shows the data structure of the clip time line (ClipTimeLine) 95, portion (b) of FIG. 12 shows the data structure of the TimeEntry field 95g for one time entry, and portion (c) of FIG. 12 shows the data structure of the KPUEntry field 95h for one KPU entry.



FIG. 13(
a) shows a relation between the time entries and fields included in the clip time line 95 and FIG. 13(b) shows a relation between the KPU entries and fields included in the clip time line 95.



FIG. 14 shows the management information and clip AV stream of a content for one shot that are stored in two removable HDDs.



FIG. 15 shows the procedure of the content recording processing to be done by the camcorder 100.



FIG. 16 shows the procedure of the media switching processing.



FIG. 17 shows the procedure of content playback processing to be done by the camcorder 100.


Portions (a) and (b) of FIG. 18 show how the relation between the management information and the clip AV stream changes before and after a top portion of the TTS file has been deleted by editing.



FIG. 19 shows the procedure of content partial deletion processing to be done by the camcorder 100.



FIG. 20 shows a data structure for a second preferred embodiment that uses the 3:2 pull-down technology.


Portions (a) through (c) of FIG. 21 show the storage locations of PTS's and time codes in a stream.



FIG. 22 shows a partially detailed arrangement of functional blocks in a camcorder 100 according to a second preferred embodiment.



FIG. 23 shows the data structure of a clip meta-data file according to the second preferred embodiment.



FIG. 24 shows the procedure of processing of specifying a picture associated with a time code value by that time code value according to the second preferred embodiment.



FIG. 25 shows management parameters in a situation where one shot consists of a single TTS file according to the second preferred embodiment.



FIG. 26 shows the meanings of management parameters when ClipTimeLineAddressoffset is not equal to zero and when one shot consists of one TTS file according to the second preferred embodiment.



FIG. 27 shows the meanings of management parameters in a situation where one shot is a chain of multiple TTS files according to the second preferred embodiment.



FIG. 28 show a data structure according to a third preferred embodiment of the present invention in which the video to be presented at a rate of 24 frames per second is recorded by the 3:2 pull-down technology.



FIG. 29 shows the data structure of a clip meta-data file according to the third preferred embodiment.



FIG. 30 shows the data structure of a ClipTimeLine file according to the third preferred embodiment.



FIG. 31 shows the procedure of processing of specifying a picture associated with a time code value by that time code value according to the third preferred embodiment.



FIG. 32 shows the meanings of management parameters according to the third preferred embodiment in a situation where one shot consists of a single TTS file.



FIG. 33 shows the meanings of management parameters according to the third preferred embodiment in a situation where the ClipTimeLineAddressOffset is not zero and one shot consists of three TTS files.



FIG. 34 shows a general data structure of a time code compliant with the SMPTE M12 standard.



FIG. 35 shows the data structure of a video stream compliant with the MPEG-4 AVC standard.



FIG. 36 shows a data structure according to the third preferred embodiment in a situation where 3:2 pull-down is carried out.



FIG. 37 shows the presentation timing relations of respective frames when video to be presented at a rate of 24 frames per second is converted into video to be presented at a rate of 60 frames per second by the 3:2 pull-down technology.





DESCRIPTION OF REFERENCE NUMERALS




  • 100 camcorder


  • 108 PC


  • 112 removable HDD


  • 201
    a CCD


  • 201
    b microphone


  • 202 A/D converter


  • 203 MPEG-2 encoder


  • 204 TS processing section


  • 205 media control section


  • 206 MPEG-2 decoder


  • 207 graphic control section


  • 208 memory


  • 209
    a LCD


  • 209
    b loudspeaker


  • 210 program ROM


  • 211 CPU


  • 212 RAM


  • 213 CPU bus


  • 214 network control section


  • 215 instruction receiving section


  • 216 interface (I/F) section


  • 250 system control section


  • 261 TTS header adding section


  • 262 clock counter


  • 263 PLL circuit


  • 264 buffer


  • 265 TTS header removing section



BEST MODE FOR CARRYING OUT THE INVENTION

Hereinafter, preferred embodiments of a data processor according to the present invention will be described with reference to the accompanying drawings.


EMBODIMENT 1


FIG. 1 illustrates multiple types of data processors that operate in association with each other by way of removable media. In FIG. 1, the Data Processors are illustrated as a camcorder 100-1, a cellphone with camera 100-2 and a PC 108. The camcorder 100-1 and cellphone with camera 100-2 receive video and audio that have been captured by the user, encode them into digital data streams, and write the data streams on removable media 112-1 and 112-2, respectively. The data that has been written on each of these removable media is handled as a file on the file system that has been established on the removable medium. For example, FIG. 1 shows that a number of files are stored in the removable medium 112-2.


These removable media 112-1 and 112-2 are removable from the data processors and may be optical disks such as DVDs or BDs (Blu-ray Discs), ultra-small hard disks such as a micro drive, or semiconductor memories. The PC 108 includes a slot that can be loaded with each of these removable media 112-1 and 112-2, and reads data from the removable medium 112-1 or 112-2 inserted to perform playback or editing processing, for example.


In the removable HDD 112, data management is done based on the FAT 32 file system. According to the FAT 32 file system, a single file may have a file size of no greater than 4 gigabytes, for example. That is to say, according to the FAT 32 file system, if the data size exceeds 4 gigabytes, the data needs to be written in two or more files separately. For example, in a removable HDD 112 with a storage capacity of 8 gigabytes, two 4-gigabyte files may be stored. And four 4-gigabyte files may be stored in a 16-gigabyte removable HDD 112. It should be noted that the data size limit, beyond which the data needs to be written separately, does not have to be equal to, but may be just less than, the maximum file size.


In the following description, the data processor that writes a content data stream on a removable medium is supposed to be a camcorder, and the data processor that plays back and edits the data stream stored in the removable medium is supposed to be a PC.


Furthermore, the removable medium 112-1 is supposed to be an ultra-small removable hard disk. Just like a known micro drive, the removable medium has a drive mechanism for reading and writing data by driving a hard disk. Thus, the removable medium 112-1 will be referred to herein as the “removable HDD 112”. For the sake of simplicity of description, the removable HDD 112 is supposed to have a storage capacity of 4 gigabytes. That is why a content with a size of more than 4 gigabytes is written on two or more removable HDDs. However, even if the removable HDD has a storage capacity of more than 4 gigabytes and if a content with a size exceeding 4 gigabytes is going be written there, the content may also be written as two or more files on the same removable HDD. These two situations are essentially the same, because in both cases, a single content is recorded in multiple files separately, no matter whether the target storage medium is single or not. The removable HDD 112 has a cluster size of 32 kilobytes, for example. As used herein, the “cluster” is the minimum access unit for reading and writing data.



FIG. 2 shows an arrangement of functional blocks in the camcorder 100. The camcorder 100 may be loaded with multiple removable HDDs 112a, 112b, . . . and 112c at the same time, and writes a content data stream with video and audio that have been captured by the user (i.e., a clip AV stream) on the removable HDDs 112a, 112b, . . . and 112c sequentially.


The camcorder 100 includes a CCD 201a, a microphone 201b, a digital tuner 201c for receiving a digital broadcast, an A/D converter 202, an MPEG-2 encoder 203, a TS processing section 204, a media control section 205, an MPEG-2 decoder 206, a graphic control section 207, a memory 208, a liquid crystal display (LCD) 209a, a loudspeaker 209b, a CPU bus 213, a network control section 214, an instruction receiving section 215, an interface (I/F) section 216, and a system control section 250.


Hereinafter, the functions of these components will be described one by one. The CCD 201a and the microphone 201b receive an analog video signal and an analog audio signal, respectively. The CCD 201a outputs video as a digital signal, while the microphone 201b outputs an analog audio signal. The A/D converter 202 converts the incoming analog audio signal into a digital signal and supplies the digital signal to the MPEG-2 encoder 203.


The digital tuner 201c functions as a receiving section that receives a digital signal, including one or more programs, from an antenna (not shown). In a transport stream transmitted as a digital signal, packets of multiple programs are included. The digital tuner 201c extracts and outputs a packet representing a particular program (i.e., the program on the channel to be recorded) from the transport stream received. The stream being output is also a transport stream but will sometimes be referred to herein as a “partial transport stream” to tell it from the original stream. The data structure of the transport stream will be described later with reference to FIGS. 3 to 5.


In this preferred embodiment, the camera 100 is supposed to include the digital tuner 201c. However, this is not an essential requirement. As the configuration of the camcorder 100 shown in FIG. 2 is also applicable to the cellphone with camera 100-2 that has already been described with reference to FIG. 1, the tuner may also be a component of a cellphone with camera that can receive a digital broadcast and make it ready for viewing and listening to.


On receiving an instruction to start recording, the MPEG-2 encoder 203 (which will be simply referred to herein as an “encoder 203”) compresses and encodes the supplied digital audio and video data compliant with an MPEG standard. In this preferred embodiment, the encoder 203 compresses and encodes the supplied video data into the MPEG-2 format, generates a transport stream (which will be referred to herein as a “TS”) and passes it to the TS processing section 204. This processing is continued until the encoder 203 receives an instruction to end the recording. To perform bidirectional compression coding, the encoder 203 includes a buffer (not shown) for temporarily storing reference pictures and so on. It should be noted that the video and audio do not have to be encoded compliant with the same standard. For example, the video may be compressed and encoded in the MPEG format and the audio may be compressed and encoded in the AC-3 format.


In this preferred embodiment, the camcorder 100 generates and processes a TS. Therefore, the data structure of a TS will be described first with reference to FIGS. 3 through 5.



FIG. 3 shows the data structure of a transport stream (TS) 20. Examples of TS packets include a video TS packet (V_TSP) 30 in which compressed video data is stored, an audio TS packet (A_TSP) 31 in which compressed audio data is stored, a packet (PAT_TSP) in which a program association table (PAT) is stored, a packet (PMT_TSP) in which a program map table (PMT) is stored, and a packet (PCR_TSP) in which an program clock reference (PCR) is stored. Each of these TS packets has a data size of 188 bytes. Also, TS packets such as PAT_TSP and PMT_TSP that describe the program arrangement of TS are generally called “PSI/SI packets”.


Hereinafter, the video TS packets and audio TS packets, all of which are relevant to the processing of the present invention, will be described. FIG. 4(a) shows the data structure of a video TS packet 30. The video TS packet 30 includes a transport packet header 30a of 4 bytes and transport packet payload 30b of 184 bytes. Video data 30b is stored in the payload 30b. On the other hand, FIG. 4(b) shows the data structure of an audio TS packet 31. The audio TS packet 31 also includes a transport packet header 31a of 4 bytes and transport packet payload 31b of 184 bytes.


Audio data 31b is stored in the transport packet payload 31b. Data called “adaptation field” may be added to the TS packet header and may be used to align data to be stored in the TS packet. In that case, the payload 30b, 31b of the TS packet has a size of less than 184 bytes.


As can be seen from this example, a TS packet is usually made up of a transport packet header of 4 bytes and elementary data of 184 bytes. In the packet header, a packet identifier (PID) showing the type of that packet is described. For example, the PID of a video TS packet is 0x0020, while that of an audio TS packet is 0x0021. The elementary data may be content data such as video data or audio data or control data for controlling the playback. The type of the data stored there changes according to the type of the packet.


Hereinafter, the relationship between video data and pictures that form video will be described as an example. Portions (a) to (d) of FIG. 5 show a stream correlation to be established when video pictures are played back from video TS packets. As shown in portion (a) of FIG. 5, the TS 40 includes video TS packets 40a through 40d. Although the TS 40 may include other packets, only those video TS packets are shown here. A video TS packet can be easily identifiable by the PID stored in its header 40a-1.


A packetized elementary stream is made up of the video data of respective video TS packets such as the video data 40a-2. Portion (b) of FIG. 5 shows the data structure of a packetized elementary stream (PES) 41. The PES 41 includes a plurality of PES packets 41a, 41b, etc. The PES packet 41a is made up of a PES header 41a-1 and PES payload 41a-2. These data are stored as the video data of the video TS packets.


Each PES payload 41a-2 includes the data of a single picture. An elementary stream is made up of those PES payloads 41a-2. Portion (c) of FIG. 5 shows the data structure of an elementary stream (ES) 42. The ES 42 includes multiple pairs of picture headers and picture data. It should be noted that the “picture” is generally used as a term that may refer to either a frame or a field.


In the picture header 42a shown in portion (c) of FIG. 5, a picture coding type, showing the picture type of picture data 42b that follows, is described. A picture coding type, showing the picture type of picture data 42d, is described in the picture header 42c. The “type” is one of an I-picture (intra-coded picture), a P-picture (predictive-coded picture) and a B-picture (bidirectionally-predictive-coded picture). If the type shows this is an I-picture, its picture coding type may be “001b”, for example.


The picture data 42b, 42d, etc. is data corresponding to a single frame, which may consist of either that data only or that data and preceding/succeeding data to be decoded before and/or after the former data. For example, portion (d) of FIG. 5 shows a picture 43a consisting of the picture data 42b and a picture 43b consisting of the picture data 42d.


In playing back video based on a TS, the camcorder 100 gets video TS packets and extracts picture data by the processing described above, thereby getting pictures as components of video. As a result, the video can be presented on the LCD 209a.


As far as a video content is concerned, the encoder 203 may be regarded as generating a TS in the order shown in portions (d), (c), (b) and (a) of FIG. 5.


Next, the TS processing section 204 of the camcorder 100 (see FIG. 2) will be described. The TS processing section 204 receives the TS from the encoder 203 in recording moving pictures or from the digital tuner 201c in recording a digital broadcast, and generates a clip AV stream. The clip AV stream is a data stream, of which the format is suitable for recording it on the removable HDD 112a, for example. In this preferred embodiment, an extension TTS, meaning “Timed TS”, is added to a clip AV stream file stored on a removable HDD. The clip AV stream is implemented as a TS with arrival time information. In playing back a content, the TS processing section 204 receives the clip AV stream, which has been read out from the removable HDD 112a, for example, from the media control section 205, generates a TS from the clip AV stream, and outputs it to the MPEG-2 decoder 206.


Hereinafter, a clip AV stream, relevant to the processing done by the TS processing section 204, will be described with reference to FIG. 6, which shows the data structure of a clip AV stream 60. The clip AV stream 60 includes a plurality of TTS packets 61, each of which consists of a TTS header 61a of 4 bytes and a TS packet 61b of 188 bytes. That is to say, each TTS packet 61 is generated by adding the TTS header 61a to the TS packet 61b. It should be noted that the TS packet 61b is the TS packet that has already been described with reference to FIGS. 3, 4(a) and 4(b).


The TTS header 61a consists of a reserved area 61a-1 of 2 bits and an arrival time stamp (ATS) 61a-2 of 30 bits. The arrival time stamp 61a-2 shows the time when the TS packet supplied from the encoder 203 arrived at the TS processing section 204. At the specified time, the TS processing section 204 outputs the TS packet to the decoder 206.


Next, the configuration of the TS processing section 204 that generates the clip AV stream 60 will be described. FIG. 7 shows an arrangement of functional blocks for the TS processing section 204, which includes a TTS header adding section 261, a clock counter 262, a PLL circuit 263, a buffer 264 and a TTS header removing section 265.


The TTS header adding section 261 receives a TS, adds a TTS header to the top of each of TS packets that form the TS, and outputs them as TTS packets. The arrival time of the TS packet described in the arrival time stamp 61a-2 in the TTS header can be known by reference to the count value (i.e., count information) from the reference time as provided for the TTS header adding section 261.


The clock counter 262 and PLL circuit 263 generate information that is needed for the TTS header adding section 261 to find the arrival time of the TS packet. First, the PLL circuit 263 extracts a PCR packet (e.g., PCR_TSP shown in FIG. 2) from the TS to get a program clock reference (PCR) showing the reference time. The same value as the PCR value is set as a system time clock (STC) of the camcorder 100, which is used as the reference time. The system time clock STC has a system clock with a frequency of 27 MHz. The PLL circuit 263 outputs a 27 MHz clock signal to the clock counter 262. On receiving the clock signal, the clock counter 262 outputs the clock signal as the count information to the TTS header adding section 261.


The buffer 264 includes a write buffer 264a and a read buffer 264b. The write buffer 264a sequentially retains incoming TTS packets and outputs them all together to the media control section 205 (to be described later) when the total data size reaches a predetermined value (which may be the maximum storage capacity of the buffer, for example). A series of TTS packets (or data stream) output at this time is called a “clip AV stream”. On the other hand, the read buffer 264b temporarily buffers the clip AV stream that has been read by the media control section 205 from the removable HDD 112a, for example, and outputs the stream on a TTS packet basis.


The TTS header removing section 265 receives TTS packets, converts the TTS packets into TS packets by removing the TTS headers from the packets, and outputs them as a TS. It should be noted that the TTS header removing section 265 extracts the arrival time stamp ATS of the TS packet included in the TTS header, and outputs the TS packets at a timing (or at time intervals) associated with the original arrival time by reference to the arrival time stamp ATS and the timing information provided by the clock counter 262. The removable HDD 112a, etc. is randomly accessible, and data is arranged discontinuously on the disk. That is why by reference to the arrival time stamp ATS of a TS packet, the TS processing section 204 can output the TS packet at the same time as the arrival time of the TS packet during recording, no matter where the data is stored. To specify the reference time of the TS read, the TTS header removing section 265 sends the arrival time, which is specified in the first TTS packet, for example, as an initial value to the clock counter 262. In response, the clock counter 262 can start counting from that initial value and the results of counting after that may be received as timing information.


The camcorder 100 is supposed to include the TS processing section 204 for generating a clip AV stream by adding TTS headers to a TS. However, in encoding a stream at a constant bit rate (CBR) (i.e., at a fixed encoding rate), the TS packets are input to the decoder at regular intervals. In that case, the TS may be written on the removable HDD 112 with the TS processing section 204 omitted.


Referring back to FIG. 2, the other components of the camcorder 100 will be described.


The media control section 205 receives a clip AV stream from the TS processing section 204, decides which removable HDD 112a, 112b, . . . or 112c the stream should go to, and outputs it to that removable HDD. Also, the media control section 205 monitors the remaining storage space of the removable HDD on which writing is being carried out. When the remaining space becomes equal to or smaller than a predetermined value, the media control section 205 changes the destinations into another removable HDD and goes on to output the clip AV stream. In that case, the clip AV stream representing a single content will be split into two parts to be stored in two removable HDDs 112, respectively.


The media control section 205 generates a clip time line (ClipTimeLine) table, which constitutes one of the principal features of the present invention, and describes, in that table, a flag showing whether or not a key picture unit, which is the playback unit of the clip AV stream, is stored in two files separately. A more detailed operation of the media control section 205 and a detailed data structure of the clip time line table generated by the media control section 205 will be described later.


It should be noted that the processing of writing the clip AV stream on the removable HDD 112 is carried out by the removable HDD 112 itself on receiving a write instruction and the clip AV stream from the media control section 205. On the other hand, the processing of reading the clip AV stream is also carried out by the removable HDD 112 itself in response to a read instruction given by the media control section 205. In the following description, however, the media control section 205 is supposed to read and write the clip AV stream for the sake of convenience.


The MPEG-2 decoder 206 (which will be simply referred to herein as a “decoder 206”) analyzes the TS supplied to get compression-encoded video and audio data from TS packets. Then, the decoder 206 expands the compression-encoded video data, converts it into decompressed data and then passes it to the graphic control section 207. The decoder 206 also expands the compression-encoded audio data to generate an audio signal and then passes it to the loudspeaker 209b. The decoder 206 is designed so as to satisfy the system target decoder (T-STD) requirements defined by an MPEG standard about TS.


The graphic control section 207 is connected to the internal computer memory 208 and realizes an on-screen display (OSD) function. For example, the graphic control section 207 may combine any of various menu pictures with video and output the resultant synthetic video signal. The liquid crystal display (LCD) 209a presents the video signal supplied from the graphic control section 207 on an LCD. The loudspeaker 209b outputs the audio signal as audio. The content is played back for viewing on the LCD 209a and listening to through the loudspeaker 209b. It should be noted that the video and audio signal do not have to be output to the LCD 209a and the loudspeaker 209b, respectively. Alternatively, the video and audio signals may be transmitted to a TV set and/or a loudspeaker, which are external devices for the camcorder 100, by way of external output terminals (not shown).


The CPU bus 213 is a path for transferring signals in the camcorder 100 and is connected to the respective functional blocks as shown in FIG. 2. In addition, the respective components of the system control section 250 to be described later are also connected to the CPU bus 213.


The network control section 214 is an interface for connecting the camcorder 100 to the network 101 such as the Internet and is a terminal and a controller that are compliant with the Ethernet™ standard, for example. The network control section 214 exchanges data over the network 101. For example, the network control section 214 may transmit the captured and generated clip AV stream to a broadcaster over the network 101. Or when a software program that controls the operation of the camcorder 100 is updated, the network control section 214 may receive the updated program over the network 101.


The instruction receiving section 215 may be an operating button arranged on the body of the camcorder 100. The instruction receiving section 215 receives a user's instruction to start or stop a recording or playback operation, for example.


The interface (I/F) section 216 controls the connector for use to allow the camcorder 100 to communicate with other devices and also controls the communications themselves. The I/F section 216 includes a terminal compliant with the USB 2.0 standard, a terminal compliant with the IEEE standard, and a controller for enabling data communications according to any of these various standards and can exchange data according to a method that complies with any of these standards. For example, the camcorder 100 may be connected to the PC 108, another camcorder (not shown), a BD/DVD recorder or another PC by way of the USB 2.0 terminal or the IEEE 1394 terminal.


The system control section 250 controls the overall processing of the camcorder 100 including the signal flows there and includes a program ROM 210, a CPU 211 and a RAM 212, all of which are connected to the CPU bus 213. A software program for controlling the camcorder 100 is stored in the program ROM 210.


The CPU 211 is a central processing unit for controlling the overall operation of the camcorder 100. By reading and executing a program, the CPU 211 generates a control signal to realize the processing defined by the program and outputs the control signal to the respective components over the CPU bus 213. The memory 212 has a work area for storing data that is needed for the CPU 211 to execute the program. For example, the CPU 211 reads out a program from the program ROM 210 and outputs it to the random access memory (RAM) 212 through the CPU bus 213 and executes the program. The computer program may be circulated on the market by being stored on a storage medium such as a CD-ROM or downloaded over telecommunications lines such as the Internet. As a result, a computer system that is made up of a PC, a camera, a microphone and so on can also operate as a device having functions that are equivalent to those of the camcorder 100 of this preferred embodiment. Such a device will also be referred to herein as a “data processor”.


Next, the data management structure of a content, captured with the camcorder 100 and including audio and video, will be described with reference to portions (a), (b) and (c) of FIG. 8. Portion (a) of FIG. 8 shows the concept of a single content according to this preferred embodiment. Specifically, a content that has been captured from the beginning and through the end of a video recording session will be referred to herein as “one shot”. Portion (b) of FIG. 8 shows the concept of clips, each including the management information of the content and stream data. One shot (i.e., a single content) may be stored as a plurality of clips a, b and c in respective removable HDDs 112a, 112b and 112c. Alternatively, the content may be complete within a single clip. Each clip includes clip meta data 81, a time map 82 and a portion of the clip AV stream 83 (i.e., a partial stream). The clip AV stream 83 consists of partial streams 83a, 83b and 83c, which are included in the clips a, b and c, respectively. Portion (b) of FIG. 8 shows the three clips a, b and c. However, as all of these clips have the same configuration, only the clip a will be described as an example.


The clip a includes clip meta data a, a time map a and a partial stream a. The clip meta data a and the time map a are pieces of management information, while the partial stream a is data that forms a part of the clip AV stream 83. As a matter of principle, the clip AV stream 83 is stored in a single file. However, if the size of the stream exceeds the maximum permissible file size according to the FAT 32, the stream is stored in multiple TTS files. In Portion (b) of FIG. 8, the three partial streams 83a, 83b and 83c are stored in three different files. According to this preferred embodiment, if the files sizes of the respective partial streams were equal to the maximum permissible file size (of 4 gigabytes) according to the FAT 32 file system, then no spaces would be left in any of the removable HDDs 112a, 112b and 112c and the management information could not be written on the removable HDDs 112 anymore. That is why the file sizes of the respective partial streams should be less than 4 gigabytes. Furthermore, the TTS file may be supposed to include an integral number of TTS packets and have a size that is less than 4 gigabytes, which is the maximum permissible size according to the file system, and that is an integral number of times as large as the size of a TTS packet (of 192 bytes).


The clip meta data a is described in the XML format and defines information that is required to play back a content (such as the video and/or audio format(s)). The clip meta data a will be described in further detail later with reference to FIG. 10.


The time map a is a table that defines correspondence between the presentation times and their storage locations (addresses) on a playback unit basis. This time map will be referred to herein as a “clip time line (ClipTimeLine)” and a file that stores the clip time line is shown with an extension “CTL”. The clock time line will be described in detail later with reference to FIGS. 12 through 14.


The partial stream a is made up of a plurality of TTS packets as shown in FIG. 6.


It should be noted that if the clip AV stream 83 gets stored in files for multiple partial streams 83a, 83b and 83c during one shot, then the ATS clock counter 262 (see FIG. 7) that determines the transfer timings of the TS packets is never reset and never has a value that has nothing to do with its previous count value. The clock counter 262 (see FIG. 7) continues counting with respect to the predetermined reference time, thereby outputting a count value. That is why the arrival time stamps ATS of the respective TTS packets that form the clip AV stream 83 are continuous with each other at each boundary between two consecutive ones of the TTS files that form one shot.


Portion (c) of FIG. 8 shows three removable HDDs 112a, 112b and 112c. The data files of the respective clips a, b and c are written on the respective removable HDDs 112a, 112b and 112c, respectively.


Next, it will be described how the files are stored in the removable HDD 112. FIG. 9 shows the hierarchical directory structure in the removable HDD 112. The content's management information and the clip AV stream files are stored in the Contents folder 91 in the ROOT 90 on the uppermost layer and on lower layers. More specifically, in the Database folder 92 right under the Contents folder 91, stored are an XML format file containing the clip meta data 94 as a piece of management information and a CTL format file of the clip time line 95. On the other hand, in the TTS folder 93 right under the Contents folder 91, stored is a TTS format file of the clip AV stream (Timed TS) 96.


Optionally, the Contents folder 91 may further include a Video folder to store video stream data in the MXF format, an Audio folder to store audio stream data in the MXF format, an Icon folder to store thumbnail pictures in the BMP format, and a Voice folder to store voice memo data in the WAVE format. These additional folders may be adapted to the current recording formats of camcorders.


Next, the contents of the data included in the clip meta data 94 and clip time line 95 will be described with reference to FIGS. 10 through 14.



FIG. 10 shows the contents of information included in the clip meta data 94, which is classified into the two types of data: “Structural” data and “Descriptive” data.


The “Structural” data includes descriptions of clip name, essence list and relation information. The clip name is a piece of information that identifies the given file and a known unique material identifier (UMID) may be described as the clip name, for example. The UMID may be generated as a combination of the time when the content was produced and the media access control (MAC) address of the device that produced it. Furthermore, the UMID is also generated in view of whether the content has been newly produced or not. That is to say, if a content has been given a UMID once but has been edited or processed after that, a different value from the UMID of the original content is added to that content. That is why if UMIDs are used, mutually different values can be defined for all sorts of contents around the world, and therefore, any content can be identified uniquely.


The essence list includes descriptions of information that is required to decode video and audio (i.e., video information and audio information). For example, the video information includes descriptions of the format, compression coding method and frame rate of video data, while the audio information includes descriptions of the format and sampling rate of audio data. In this preferred embodiment, the compression coding method is compliant with the MPEG-2 standard.


The relation information defines a relation between clips in a situation where there are a number of clips 81a to 81c as in portion (b) of FIG. 8. More specifically, each clip meta data 94 provides a description of the information that identifies the first clip of that shot, i.e., pieces of information that identify the previous clip and the next clip, respectively. That is to say, the relation information may be regarded as defining in what order the clip AV stream (or the partial stream), consisting of those clips, should be presented, i.e., the presentation order of the clip AV stream. The information identifying a clip may be defined as an UMID and a unique serial number of that removable HDD 112.


The Descriptive data includes access information, device information, and shooting information. The access information includes descriptions of the person who updated the clip last time and the date of the update. The device information includes descriptions of the name of the manufacturer and the serial number and the model of the recorder. The shooting information includes the name of the shooter, the shooting start date and time, the end date and time, and the location.


Next, the clip time line 95 will be described. The clip time line 95 introduces the concepts of “key pictures” and “key picture unit” and defines information on these new concepts. Thus, first, it will be described with reference to FIG. 11 what the key pictures and the key picture unit are.



FIG. 11 shows a relation between key pictures and a key picture unit. In FIGS. 11, I-, B- and P-pictures are shown in their presentation order. A key picture unit (KPU) is a data presentation unit that is defined about video. In the example shown in FIG. 11, the presentation of the key picture unit KPU begins with a key picture 44 and ends with a B-picture 45. At least one group of pictures (GOP) compliant with the MPEG standard is interposed between the two pictures. The presentation of the next key picture unit KPU begins with the I-picture 46 that follows the B-picture 45. Each key picture unit has a video playback duration of 0.4 seconds to 1 second. However, the last key picture unit of one shot may have a duration of 1 second or less. This is because the duration could be less than 0.4 seconds depending on the end time of the shooting. In this example, the presentation is supposed to begin with an I-picture at the top of a GOP. However, the present invention is in no way limited to this specific example but the presentation may also begin with a B-picture according to a GOP structure. This is because the KPU period shows the overall playback duration of all pictures included in that KPU.


The key pictures 44 and 46 located at the respective tops of the key picture units are access units about video, including sequence_header_code and group_start_code compliant with the MPEG standard. For example, the key picture unit may be either the image of an MPEG-2 compressed and encoded I-picture (which may be either an image frame or a set of two image fields) or the image of a compressed and encoded I- or P-field.


Also, according to this preferred embodiment, the KPU period is defined by using PTS added to a TS. Specifically, the KPU period is the difference between the presentation time stamp (PTS) of the picture to be presented first in the next key picture unit KPU and that of the picture to be presented first in the current KPU. In FIG. 11, if the presentation time stamps of the key pictures 44 and 46 are supposed to be PTS(N) and PTS(N+1), respectively, then the KPU period (N) is defined as PTS(N+1)-PTS(N) in a situation where both key pictures are presentation start pictures. As is clear from the definition of the KPU period, to define the length of a KPU period, the pictures of the next key picture unit KPU need to be compressed and encoded and the presentation time stamp PTS of the first picture to be presented needs to be fixed. That is why the KPU period of a key picture unit KPU is not fixed until the next key picture unit starts to be generated. It should be noted, however, that the last KPU period of one shot sometimes needs to be figured out. Therefore, a method of summing up the playback durations of the pictures encoded may also be adopted. In that case, the KPU period may be determined even before the next KPU starts to be generated.


Next, the clip time line (ClipTimeLine) will be described with reference to portions (a), (b) and (c) of FIG. 12. Portion (a) of FIG. 12 shows the data structure of the clip time line (ClipTimeLine) 95. The clip time line 95 is written as a file with an extension CTL on each removable HDD 112.


The clip time line 95 is a table defining a relation between the presentation time of each playback unit and its storage location (i.e., the address). The “playback unit” corresponds to the key picture unit KPU described above.


A number of fields are defined for the clip time line 95. For example, the clip time line 95 may include a TimeEntryNumber field 95a, a KPUEntryNumber field 95b, a ClipTimeLineTimeOffset field 95c, a ClipTimeLineAddressOffset field 95d, a ClipTimeLineDuration field 95e, a StartKeySTC field 75f, a TimeEntry field 95g and a KPUEntry field 95h, for example. A predetermined number of bytes are allocated to each of these fields to define a particular meaning by its value.


For example, the TimeEntryNumber field 95a may describe the number of time entries and the KPUEntryNumber field 95b may describe the number of KPU entries. However, the data sizes of the TimeEntry field 95g and KPUEntry field 95h are variable with the number of time entries and the number of KPU entries, respectively, as will be described later.


Portion (b) of FIG. 12 shows the data structure of the TimeEntry field 95g for one time entry. In the TimeEntry field 95g, pieces of information showing the properties of its associated time entry are described in a plurality of fields including a KPUEntryReferenceID field 97a, a KPUEntryStart-Address field 97b and TimeEntryTimeOffset field 97c.


On the other hand, portion (c) of FIG. 12 shows the data structure of the KPUEntry field 95h for one KPU entry. In the KPUEntry field 95h, pieces of information showing the properties of its associated key picture unit KPU are described in a plurality of fields including an OverlappedKPUFlag field 98a, a KeyPictureSize field 98b, a KPUPeriod field 98c and a KPUSize field 98d.


Hereinafter, the meanings of the data defined in main fields of the clip time line 95 will be described with reference to FIGS. 13(a) and 13(b).



FIG. 13(
a) shows a relation between the time entries and fields included in the clip time line 95. In FIG. 13(a), one scale on the axis of abscissas represents one access unit time (AUTM), which corresponds to the playback duration of one picture. In this case, the type of the “picture” changes with the type of the video in question. More specifically, the “picture” corresponds to a single progressive scan image frame in progressive video and to a single interlaced scan image field (i.e., a single field) in interlaced video, respectively. For example, in progressive video to be presented at intervals of 24000/1001 seconds (i.e., 23.97 p), 1 AUTM may be represented as 1/(24000/1001) seconds=1126125 clocks/27 MHz.


First, the timing relation in a situation where a number n of clips are included in one shot will be described. The playback duration of each clip is described in the ClipTimeLineDuration field 95e. This value may be described using the AUTM. By calculating the sum of the values in the ClipTimeLineDuration fields 95e of all clips, the playback duration of one shot (i.e., shooting time length) can be obtained as represented by the following Equation (1):





Playback duration of one shot=ΣClipTimeLineDuration  (1)


This time length may also be described using the AUTM.


On the other hand, supposing KPU #0 through KPU #(k+1) shown in FIG. 13(a) are included in one clip, the ClipTimeLine Duration field 95e of each clip is obtained as the sum of the KPUperiod fields 98c of all key picture units KPU included in that clip as represented by the following Equation (2):





ClipTimeLineDuration=ΣKPUperiod  (2)


Since the KPUperiod is described using the AUTM value, the ClipTimeLineDuration field 95e is also described using the AUTM value.


The value of each KPUperiod field 98c corresponds with the sum of the video playback durations (i.e., the AUTM values) of the pictures included in that key picture unit KPU as described above (and as represented by the following Equation (3)):





KPUperiod=overall playback duration of all video in KPU  (3)


The TimeEntry refers to discrete points on the time axis, which are set at regular intervals (of 5 seconds, for example) and at any of which playback can be started. In setting the time entries, if the playback start time of the first key picture unit KPU #0 is supposed to be zero, the time offset to the TimeEntry #0 that has been set for the first time is defined as the ClipTimeLineTimeOffset field 95c. Also, a piece of information that identifies the key picture unit KPU to be presented at the set time of each time entry is described in the KPUEntryReferenceID field 97a. And a piece of information showing a time offset from the beginning of the key picture unit KPU through the set time of the time entry is described in the TimeEntryTimeOffset field 97c.


For example, if TimeEntry #t is specified, the time at which the TimeEntry #t is set (i.e., the amount of time that has passed since the beginning of the first key picture unit KPU #0) can be obtained by calculating (the value of ClipTimeLineTimeOffset field 95c)+(the interval of time entries t).


Alternatively, presentation may also be started at any presentation time by the following method. Specifically, when a requested playback start time is received from the user, that time is converted by known conversion processing into a PTS value, which is a piece of time information compliant with the MPEG standard. Then, the presentation is started from the picture to which the PTS value is allocated. It should be noted that the PTS value is described in the transport packet header 30a in the video TS packet (V_TSP) 30 (see FIG. 4(a)).


In this preferred embodiment, a single clip AV stream is split into multiple partial streams. That is why not every partial stream within a clip has a presentation time stamp PTS of zero at the top. Thus, in the StartSTC field 95f of the clip time line 95 (see portion (a) of FIG. 12), the presentation time stamp PTS of the picture to be presented first in the top KPU within the clip is described. And based on the PTS value of that picture and that associated with the specified time, a PTS (AUTM) differential value through the picture where presentation should be started can be obtained. It should be noted that the data size of the PTS value allocated to each picture is preferably equal to that of the PTS value defined for the StartSTC field 95f (e.g., 33 bits).


If the differential value is greater than the value of the ClipTimeLineDuration field 95e, then it can be determined that the picture to start presentation at will not be present within the clip. On the other hand, if the differential value is smaller than the value of the ClipTimeLineDuration field 95e, then it can be determined that the picture to start presentation at will be present within the clip. In the latter case, it can be further determined easily, by that PTS differential value, how distant that time is.



FIG. 13(
b) shows a relation between the KPU entries and fields included in the clip time line 95. In FIG. 13(b), one scale on the axis of abscissas represents one data unit length (timed TS packet byte length (TPBL)), which means that one data unit is equal to the data size of a TTS packet (of 192 bytes).


A single KPU entry is provided for each key picture unit KPU. In setting the KPU entries, the data size of each KPU is described in the KPUSize field 98d and the start address of the KPU associated with each time entry is described in the KPUEntryStartAddress field 97b. As shown in KPUSize #k in FIG. 13(b), for example, the data size of each key picture unit KPU is represented on the basis of data unit lengths (TPBL) as a data size from the first TTS packet that stores the data of the first picture in the KPU through a TTS packet just before the TTS packet that stores the first picture of the next KPU.


Furthermore, in the KPU entry, a fragment from the beginning of the file through the top of the key picture unit KPU #0 (i.e., a data offset) is set in the ClipTimeLineAddress Offset field 95d. This field is provided for the following reason. Specifically, if the data of a clip AV stream for one shot is stored separately in multiple files, a portion of the KPU at the end of the previous file may be stored at the top of the second file and so on. Decoding of respective pictures in the key picture unit KPU needs to begin with the key picture at the top of the KPU. That is why the data located at the beginning of a file cannot be decoded by itself. Therefore, such data needs to be skipped as meaningless data (i.e., the fragment). Consequently, skip is enabled by using that offset value in the offset field 95d described above.


Hereinafter, the OverlappedKPUFlag field 98a in a situation where the data of a clip AV stream for one shot has been stored separately in multiple files will be described with reference to FIG. 14. In the following example, the management information and clip AV stream of a content for one shot are supposed to be stored in two removable HDDs #1 and #2 and the clip meta data will not be mentioned for the sake of simplicity.



FIG. 14 shows the management information and clip AV stream of a content for one shot that are stored in two removable HDDs. In the removable HDDs #1 and #2, clip time line files 00001.CTL and 00002.CTL and clip AV stream files 00001.TTS and 00002.TTS are stored, respectively.


The following description will be focused on the KPU entries. Firstly, the KPU Entry #(d-1) on the removable HDD #1 is provided for the key picture unit KPU #(d-1) that is defined for the clip AV stream within the TTS. As shown in FIG. 14, every data of the key picture unit KPU #(d-1) is included within the 00001.TTS. In that case, 0b is set for the OverlappedKPUFlag field 98a in the KPU Entry #(d-1).


Next, look at the KPU Entry #d and its associated key picture unit KPU #d. A portion of the key picture unit KPU #d shown in FIG. 14 (i.e., key picture unit KPU #d1) is included within 00001.TTS of the removable HDD #1, while the other portion of the key picture unit KPU #d (i.e., key picture unit KPU #d2) is included within 00002.TTS of the removable HDD #2. The key picture unit KPU #d is separately stored in two removable HDDs because the remaining storage space became less than a predetermined value during writing on the removable HDD #1 and writing could not be performed anymore, for example. In that case, 1b is set in the OverlappedKPUFlag field 98a of the KPU entry #d.


On the other hand, every data of the key picture unit KPU associated with the KPU Entry #0 within the removable HDD #2 is stored within that removable HDD. That is why 0b is set in its OverlappedKPUFlag field 98a.


As described above, by checking the value of the OverlappedKPUFlag field 98a within the KPU Entry, it can be determined whether or not the key picture unit KPU is stored within the file of that medium. This will be very advantageous in the following type of processing, for example.


If the data of the KPU #d is stored separately in multiple TTS files (00001.TTS and 00002.TTS) as shown in FIG. 14, editing processing of deleting all data from the removable HDD #2 is supposed to be carried out. By performing such editing processing, the one shot playback is carried out based on only the data that is stored on the removable HDD #1.


As a result of the editing processing, the playback duration of the one shot changes. That is why an accurate playback duration needs to be calculated. Thus, the processing of figuring out the playback duration can be changed according to the value in the OverlappedKPUFlag field 98a. More specifically, as for the last KPU #d in the removable HDD #1, the value in the OverlappedKPUFlag field 98a is 1b. In that case, the sum of the KPUperiods from the top through the KPU #(d-1) may be adopted as the clip playback duration (ClipTimeLineDuration 95e) within the removable HDD #1. In other words, the KPUperiod value of the key picture unit KPU #d is not counted in calculating the clip playback duration by Equation (2) described above. This is because an error corresponding to the playback duration of the last KPU #d (of 0.4 seconds to 1 second) could be produced between the actual playback duration (from the first KPU through KPU #(d-1)) and the one shot playback duration calculated by Equation (2) (from the first KPU through KPU #d). Naturally, devices for business use may not permit the playback duration, presented by the device, to contain such significant errors.


On the other hand, if the value in the OverlappedKPUFlag field 98a associated with the last KPU within the removable HDD #1 is 0b, then the sum of the KPU periods (KPUperiod) of the first through the last key picture units may be adopted as the value of the ClipTimeLineDuration 95e. This is because as all pictures within the last key picture unit KPU can be played back, the KPUperiod of that KPU needs to be calculated as a part of the ClipTimeLineDuration 95e.


As described above, by changing the types of processing of calculating the ClipTimeLineDuration 95e according to the value of the OverlappedKPUFlag field 98e, the playback duration can always be calculated accurately.


Optionally, it may be determined by reference to the value of the OverlappedKPUFlag field 98e whether or not to delete an imperfect key picture unit KPU and if the key picture unit is deleted, the clip time line may be modified for the remaining clips. As used herein, the “imperfect key picture unit” refers to a key picture unit not including the data of every picture. In this example, KPU #d without KPU #d2 is an imperfect key picture unit.


More specifically, if the value of the OverlappedKPUFlag field 98a is 1b, the imperfect key picture unit KPU #d1 may be deleted from the TTS file so as not to be treated as a key picture unit KPU and the clip time line within the removable HDD #1 may be modified. Modification of the clip time line includes decreasing the number of key picture units KPU (i.e., the KPUEntryNumber 95b), deleting the KPUEntry of KPU #d, and deleting the TimeEntry 95g within the key picture unit KPU #d1. As a result of the modification, the last key picture unit of the 00001.TTS file of the removable HDD #1 is KPU #(d-1) and the sum of the playback durations of the first KPU through the last KPU #(d-1) becomes the playback duration of one shot. Consequently, an accurate playback duration can be obtained by applying Equations (1) to (3) uniformly. It should be noted that such a latter half deletion could also be done on a TTS packet (192 bytes) basis even on a FAT32 file system.


There is another advantage. Specifically, if playback is started at a predetermined presentation time, a key picture unit (KPU) to jump to can be specified by reference to a time map ClipTimeLine, which is a table of information showing correspondence between presentation times and storage addresses as shown in FIG. 13. However, if video data is compressed and encoded by a forward coding method and a bidirectional coding method as defined by MPEG standards, for example, pictures that follow the first picture cannot be decoded properly unless decoding is started with an intra-coded picture (I-picture). That is why even if a key picture unit KPU (or more exactly, KPUPeriod) including the picture to start playback with has been specified successfully, the key picture at the top of the key picture unit KPU, to which that picture belongs, should be decoded first in order to start playback with that specified picture. For that reason, the value of the OverlappedKPUFlag field 98a of KPU Entry #d needs to be checked out first to find the file in which the key picture at the top of that KPU is stored.


More specifically, if the value of the OverlappedKPUFlag field 98a is “1b”, then the operation may be controlled so as to read data from the top of the key picture unit KPU #d1 of removable HDD #1 and start decoding with the playback start picture properly. Since no time is wasted by performing the processing of reading data from the top of the removable HDD #2 by mistake to fail to acquire the reference picture and determine that the picture is non-decodable, the read time, the amount of time it takes to determine whether the picture is decodable or not, and their processing loads can be all reduced. Alternatively, it is possible to prevent video that has not been decoded successfully from being presented. On the other hand, if the value is “0b”, data may start being read from the same medium as the removable HDD including the KPU Entry. The OverlappedKPUFlag field contributes greatly to getting high-speed complicated processing (such as the jump playback using a time map, fast forward playback and rewind playback) done, among other things.


Also, the key picture unit KPU #d2 is just a fragment within the removable HDD #2 and video cannot be decoded only with its data. That is why the fragment (data offset) from the beginning of the clip AV stream file (00002.TTS) within the removable HDD #2 through the top of the key picture unit KPU #0 is defined as the ClipTimeLineAddressOffset field 95d. Furthermore, the time offset from the top of that key picture unit KPU #0 through the first TimeEntry #0 is defined as the ClipTimeLineTimeOffset field 95c. It should be noted that unless the value of the ClipTimeLineAddressOffset field 95d is zero, it means that the key picture unit KPU of the previous removable HDD is stored. That is why in performing the rewind playback operation described above, it may be determined by reference to the relation information of the clip meta data 94 whether or not there is the previous clip. If no previous clip is present or accessible, then the rewind playback operation ends. If a previous clip halfway through a shot is accessible, it may be checked whether the value of the ClipTimeLineAddressOffset field 95d is zero or not. If the value is not zero, the value of the OverlappedKPUFlag field 98a of the KPU entry associated with the last key picture unit KPU of the previous removable HDD is further checked to determine whether or not the key picture unit KPU has been split into the two files.


Hereinafter, the processing of recording and playing back a content based on such a data structure will be described first, and then the processing of editing such a content will be described.


First, the (recording) processing that should be done by the camcorder 100 to record a content on a removable HDD will be described with reference to FIGS. 15 and 16.



FIG. 15 shows the procedure of the content recording processing to be done by the camcorder 100. First, in Step S151, the CPU 211 of the camcorder 100 receives a user's instruction to start shooting by way of the instruction receiving section 215. Next, in Step S512, in accordance with the instruction given by the CPU 211, the encoder 203 generates a TS based on the input signal. Alternatively, in recording a digital broadcast, an instruction to record may be received in Step S151 and TS packets representing the program to be recorded may be extracted by using the digital tuner 201c in Step S152.


In Step S153, the media control section 205 sequentially writes the TS (clip AV stream), to which the TTS headers have been added by the TS processing section 204, onto a removable HDD. Then, in Step S154, the media control section 205 determines whether or not to newly generate a clip (TTS file). The clip may or may not be generated arbitrary depending on whether or not the TTS file size of the clip being recorded is greater than a predetermined value or on the remaining space of the removable HDD. If no clips are generated newly, the process advances to Step S155. On the other hand, if a clip needs to be generated newly, the process advances to Step S156.


In Step S155, every time a key picture unit KPU is generated, the TS processing section 204 generates a KPU entry and a time entry. In this processing step, all data of the key picture unit KPU is written on the TTS file of that clip. Thus, the media control section 205 sets 0b in the OverlappedKPUFlag field in the KPU entry. Then, in Step S157, the media control section 205 writes a time-address conversion table (ClipTimeLine) including KPU entries and time entries on the removable medium. Thereafter, in Step S158, the CPU 211 determines whether or not to finish shooting. The shooting ends if an instruction to finish shooting has been received by way of the instruction receiving section 215 or if there is no removable HDD to write the data on. If it is determined that the shooting should end, the recording processing ends. On the other hand, if the shooting should be continued, the process goes back to Step S152 to repeat the same processing steps all over again.


On the other hand, in Step S156, the TS processing section 204 determines whether or not the key picture unit KPU is completed with the data that has been written last time. If the key picture unit KPU were incomplete, the remaining data of the key picture unit KPU would be stored in another removable HDD. For that reason, such a decision should be made to determine whether or not all data of the key picture unit KPU has been written in the removable HDD. If the key picture unit KPU is complete, the process advances to Step S155. Otherwise, the process advances to Step S159.


In Step S159, the TS processing section 204 performs clip switching processing, the details of which are shown in FIG. 16.



FIG. 16 shows the procedure of the clip switching processing, which is the processing of either changing the target media on which the content (clip) should be recorded from one removable HDD into another or generating a new clip on the same removable HDD. In the following example, switching the clips is supposed to be changing the target media on which the content should be recorded for the sake of simplicity. However, this is essentially the same as a situation where the content is recorded in a new clip on the same storage medium. Also, for convenience sake, the removable HDD on which the content has been recorded so far will be referred to herein as a “first removable HDD” and the removable HDD on which that content goes on to be recorded next will be referred to herein as a “second removable HDD”.


First, in Step S161, the CPU 211 gives a clip name to the clip to be generated on the second removable HDD. Next, in Step S162, the camcorder 100 continues to generate the TS until the key picture unit KPU that could not be recorded completely on the first removable HDD is completed. Then, the TS processing section 204 adds a TTS header and the media control section 205 writes that clip AV stream on the second removable HDD.


Next, in Step S163, the media control section 205 generates the KPU entry and time entry of the completed KPU. As the key picture unit KPU is written on the first and second removable HDDs separately in this case, the media control section 205 sets 1b in the OverlappedKPUFlag field in the KPU entry.


Subsequently, in Step S164, the media control section 205 writes a time-address conversion table (ClipTimeLine), including the KPU and time entries generated, on the first removable HDD. Then, in Step S165, the media control section 205 updates the clip meta-data (such as the relation information) on the first removable HDD. For example, the media control section 205 may write a UMID, identifying a clip on the second removable HDD as the next clip, on the clip meta-data of the clip on the first removable HDD. Also, the media control section 205 may write a UMID, identifying a clip on the first removable HDD as the previous clip, on the clip meta-data of the clip on the second removable HDD. Thereafter, in Step S166, the media control section 205 sets the target on which the content will be written as the second removable HDD to end the processing.


Hereinafter, the processing to be done by the camcorder 100 to play back a content from a removable HDD, more specifically, the processing of playing back a content from a location associated with a playback start time specified, will be described with reference to FIG. 17. It should be noted that the processing of playing back a content from the beginning is the same as the conventional processing that uses no KPU entries or time entries and the description thereof will be omitted herein.



FIG. 17 shows the procedure of content playback processing to be done by the camcorder 100. First, in Step S171, the CPU 211 of the camcorder 100 receives a user's specified playback start time by way of the instruction receiving section 215.


Next, in Step S172, the media control section 205 reads a time-address conversion table (ClipTimeLine) and the CPU 211 identifies a key picture unit KPU including a picture at the playback start time. Then, in Step S173, the CPU 211 locates the start point of the KPU associated with the playback start time. This KPU start point represents a decoding start position (address) within the TTS file.


These processing steps may be performed as follows. Specifically, the CPU 211 finds that the playback start time is between the time entries #t and #(t+1) and calculates how many units there are between the processing start time and the time entry #t on the basis of m access unit times (AUTMs).


Specifically, first, by reference to the value of the KPUEntryReferenceID field 97a of TimeEntry #t, a KPU (which will be referred to herein as “KPU #k”) is identified. Then, the time difference between the time specified by the TimeEntry #t and the time when the first key picture of the KPU #k starts to be presented is gotten based on the value of the TimeEntryTimeOffset field 97c. As a result, it turns out in how many AUTMs the picture to start presentation with will come up as counted from the picture that has been presented first in the KPU #k. Then, by adding the KPUperiods every KPU from the KPU #k, a KPU including the picture to start presentation with can be identified. Also, by adding together the KPUSizes from the KPU #k through the KPU that precedes the KPU including the picture to start presentation with at the top address of the KPU as specified by the TimeEntry #t, the start point of the KPU can be located with respect to the playback start time. It should be noted that the top address of the KPU as specified by the TimeEntry #t can be figured out by calculating the sum of the value of the ClipTimeLineAddressOffset field 95d and the value of the KPUEntryStartAddress field 97b of the TimeEntry #t.


In the foregoing description, a closed GOP structure (in which every picture in a GOP refers to only picture(s) within the same GOP) is supposed to be adopted for the sake of simplicity. However, if the closed GOP structure cannot be adopted or guaranteed, decoding may be started from a KPU that precedes the KPU including the specified playback start time.


The media control section 205 reads the flag in the KPUEntry of the key picture unit KPU in the next processing step S174 and then determines, in Step S175, whether or not the value of the OverlappedKPUFlag field 98a is 1b. The value “1b” means that the key picture unit KPU covers both the first and second removable HDDs and the process advances to Step S176 in that case. On the other hand, if the value is 0b, the key picture unit KPU does not cover the two HDDs and the process advances to Step S177.


In Step S176, the media control section 205 reads data from the first picture of the KPU that is stored on the first removable HDD. When the TS processing section 204 removes the TTS header, the decoder 206 starts decoding with that data. In this case, according to the picture specified, the data may be stored on the second removable HDD, not on the first removable HDD on which the data stated to be read. To decode the data properly, decoding is started with the first key picture of the KPU that covers the two clips (or TTS files).


In Step S177, the media control section 205 reads data from the first picture of the KPU. When the TS processing section 204 removes the TTS header, the decoder 206 starts decoding with that data. The data of every picture to be read is stored within the same removable HDD.


Thereafter, in Step S178, after the picture associated with the playback start time has been decoded, the graphic control section 207 starts outputting from that picture. If there is accompanied audio, the loudspeaker 209b also starts outputting it. After that, the content continues to be played back either through the end of the content or until an instruction to end playback is given. Then, the process ends.


Next, the processing of editing the content that has been recorded on a removable HDD will be described with reference to FIGS. 18 and 19. In the following example, this processing is supposed to be performed by the camcorder 100, too. Alternatively, this processing may also be performed by the PC 108 (see FIG. 1) loaded with the removable HDD on which the content has been recorded.


Portions (a) and (b) of FIG. 18 show how the relation between the management information and the clip AV stream changes before and after a top portion of the TTS file has been deleted by editing. The range D shown in portion (a) of FIG. 18 is the portion to be deleted. This range D includes the top portion of the TTS file, of which the address is supposed to be p1 and p1+D=p4 is supposed to be satisfied. As described above, the clip AV stream is sometimes stored after having been split into multiple files. The following processing applies to deleting a top portion and other portions of each TTS file.


Portion (b) of FIG. 18 shows the relation between the management information (ClipTimeLine) and the clip AV stream after the range D has been deleted. In this preferred embodiment, not all of the range D but only a part of the range D, of which the data size is n times as large as 96 kilobytes (where n is an integer), is deleted. Supposing the top data location after the deletion has an address p2, (p2-p1) should be (96 kilobytes)·n and p2≦p4 should be satisfied.


96 kilobytes is the least common multiple of a cluster size of 32 kilobytes and a TTS packet size of 192 bytes as adopted in this preferred embodiment. This unit is adopted for the following reasons. Specifically, if the unit is an integral number of times as large as the cluster size, the data deletion processing on the removable HDD can be carried out on an access unit basis. Also, if the unit is an integral number of times as large as the TTS packet size, the data deletion processing can be carried out on the basis of TTS packets of the clip AV stream. As a result, the processing can get done more quickly and more easily. As the cluster size is 32 kilobytes according to this preferred embodiment, the deletion unit is supposed to be a multiple of 96 kilobytes. However, this value is changeable with the cluster size and the packet size of the clip AV stream adopted.


In the deletion processing, the values of the ClipTimeLineTimeOffset field 95c and the ClipTimeLine AddressOffset field 95d are also changed. These values are zero before the deletion. After the deletion, first, the data size through the key picture unit KPU that appears for the first time is described in the ClipTimeLineAddressOffset field 95d. Supposing the address at which the first key picture unit KPU is stored is p3, a value (p3-p2) is described in the ClipTimeLineAddressOffset field 95d. Also, the time difference between the presentation time of the first key picture and the first time entry in the first key picture unit KPU is described on an AUTM basis on the ClipTimeLineTimeOffset field 95c. There is no guarantee that the packets of the clip AV stream between the addresses p2 and p3 can be decoded by themselves. That is why those packets are treated as a fragment and not supposed to be played back.



FIG. 19 shows the procedure of content partial deletion processing to be done by the camcorder 100. First, in Step S191, the CPU 211 of the camcorder 100 receives a user's instruction to partially delete a TTS file and his or her specified deletion range D by way of the instruction receiving section 215. As used herein, the “instruction to partially delete” is an instruction to delete the top portion and/or the end portion of a TTS file. According to the contents of the instruction, “front portion deletion processing” to delete the top portion or “rear portion deletion processing” to delete the end portion is carried out.


In Step S192, it is determined whether or not this is the front portion deletion processing. If the answer is YES, the process advances to Step S193. Otherwise, the process advances to Step S195. In Step S193, the media control section 205 deletes an amount of data, which is an integral multiple of 96 kilobytes, from the data size D corresponding to the deletion range. Then, in Step S194, the media control section 205 modifies the time offset value for the first time entry (i.e., the value of the ClipTimeLineTimeOffset field 95c) and the address offset value for the first KPU entry (i.e., the value of the ClipTimeLineAddressOffset field 95d) in the time-address conversion table (ClipTimeLine). After that, the process advances to Step S195.


In Step S195, it is determined whether or not this is the rear portion deletion processing. If the answer is YES, the process advances to Step S196. Otherwise, the process advances to Step S197. In Step S196, an amount of data corresponding to the deletion range is deleted on a 192 byte basis such that the end of the TTS file becomes a perfect KPU, which means that an amount of data that is an integral multiple of 192 bytes is deleted. After that, the process advances to Step S197.


In Step S197, the number of time entries and the number of KPU entries that have changed as a result of the partial deletion processing are modified. More specifically, the KPUEntry that has no real data anymore and the TimeEntry that has lost the KPUEntry referred to by the KPUEntryReferenceID are deleted from the time-address conversion table (ClipTimeLine). Also, the values of the TimeEntryNumber field 95a, the KPUEntryNumber field 95b and so on are modified.


It should be noted that even if neither the front portion deletion processing nor the rear portion deletion processing is carried out, the process also goes through Step S197. This means the modification processing is also supposed to be performed even if an intermediate portion of a TTS file has been deleted, for example. However, such intermediate portion deletion processing will not be mentioned particularly herein.


The partial deletion processing does not have to be performed on a top portion of a TTS file as described above but may also be performed on a range including an end portion of the TTS file. The latter type of processing may be applied to deleting the imperfect key picture unit KPU (i.e., KPU #d1 shown in FIG. 14) described above. The imperfect key picture unit KPU is located at the end of one clip, which falls within the “range including an end portion of a TTS file”. In this case, the range to be deleted is from the top of the imperfect key picture unit KPU through the end of the TTS file. The deletion range may be determined on a TTS packet size basis (a 192 byte basis), for example. There is no special need to consider the cluster size. It should be noted that the end portion of a TTS file does not have to be the imperfect key picture unit KPU but may be arbitrarily determined as the user's specified range, for example. The top portion deletion processing and the end portion deletion processing may be carried out back to back or only one of the two types of processing may be carried out selectively.


EMBODIMENT 2

Hereinafter, a second preferred embodiment of a data processor according to the present invention will be described. The data processor of this preferred embodiment is supposed to be a camcorder having the same hardware configuration as the camcorder of the first preferred embodiment (see FIG. 2). Thus, the data processor of this preferred embodiment will also be identified by the reference numeral 100 in the following description. A more detailed configuration will be described later with reference to FIG. 22.


The major differences between this and first preferred embodiments are as follows. Firstly, the camcorder of this preferred embodiment records video at a rate of 24 frames per second by the 3:2 pull-down technology in an MPEG-2 stream that has a rate of 60 frames per second. Secondly, the camcorder of this preferred embodiment writes the time code values, which have been counted at the rate of 24 frames per second, in the stream and in a clip meta-data file.


Portions (a) through (c) of FIG. 20 show the presentation timing relations of respective frames in a situation where video with a rate of 24 frames per second is converted into video with a rate of 60 frames per second by the 3:2 pull-down technology. The video with the rate of 60 frames per second is recorded as a data stream compliant with the MPEG-2 standard on a storage medium (such as a removable HDD). This data stream has 1,280 pixels horizontally and 720 pixels vertically. In the following description, the data stream is supposed to be the clip AV stream that has been already described for the first preferred embodiment.


Portion (a) of FIG. 20 shows the picture structure of a top portion of a clip AV stream and its associated management parameter. The first KPU #0 and the next KPU #1 of the clip AV stream are made up of BBIBBPBB pictures and so on in the order of presentation (or IBBPBB pictures and so on in the order of recording).


Portion (b) of FIG. 20 shows the time codes to be counted at a rate of 24 frames per second. These time codes represent the presentation timings of respective pictures of the video yet to be subjected to the pull-down processing. The video with the rate of 24 frames per second is realized by changing 24 frame pictures to present in a second one after another. Each of those pictures is presented for 1/24 second. In other words, the video has a vertical scanning frequency of 24 Hz.


On the other hand, portion (c) of FIG. 20 shows the time codes to be counted at a rate of 60 frames per second. These time codes represent the presentation timings of respective pictures of the video that has been subjected to the pull-down processing. The video with the rate of 60 frames per second is realized by changing 60 frame pictures to present in a second one after another. Each of those pictures is presented for 1/60 second. In other words, the video has a vertical scanning frequency of 60 Hz.


As shown in portions (b) and (c) of FIG. 20, each of the pictures that has been presented for 1/24 second comes to be presented for either 3/60 second or 2/60 second as a result of the 3:2 pull-down processing. The latter means that two or three frames, each of which should be presented for 1/60 second, are output continuously. After the conversion, the respective frames of the video yet to be converted are alternately presented for either 3/60 second or 2/60 second.


The camcorder of this preferred embodiment is partly characterized by recording time codes to be counted at the rate of 24 frames per second in the data stream that has been subjected to the pull-down processing. More specifically, the conventional clip AV stream includes at least one time code value shown in portion (c) of FIG. 20. On the other hand, in the data stream of this preferred embodiment, the time code value shown in portion (b) of FIG. 20 is described for every picture.


Hereinafter, the data structure of the data stream of this preferred embodiment will be described with reference to FIG. 21. For the sake of simplicity, a transport stream will be taken as an example. If a TTS header is added to the transport stream as shown in FIG. 6, a clip AV stream can be obtained.


Portions (a) to (c) of FIG. 21 show the data structure of the stream of this preferred embodiment. Each of the video TS packets 40a to 40d of the TS 40 shown in portion (a) of FIG. 21 includes the PES 41 shown in portion (b) of FIG. 21. The PES 41 includes PES packets 41a and 41b. In this example, one video frame is supposed to be stored in each PES packet. Alternatively, either one video field or a pair of video fields (i.e., two video fields) may be stored in each PES packet.


In the header of each PES packet, a presentation time stamp (PTS) showing the presentation timing of the picture data stored in the PES payload has been written. For example, in the PES header 41a-1, PTS-1 of the picture data stored in the PES payload 41a-2 is stored. On the time axis after the pull-down shown in FIG. 20, each PTS value represents the time when its associated picture should start to be presented. The difference between the PTS value and the time code value to be counted at a rate of 60 frames per second is that the PTS value should be counted responsive to a 90 kHz clock signal. The timing to present a picture refers to the same point in time no matter whether the timing is represented by a PTS value or a time code value.


Portion (c) of FIG. 21 shows the data structure of the PES payload. In this example, the PES payload 41a-2 includes a GOP header 42e, a picture header 42a and picture data 42b. The GOP header 42e is arranged before the top of the picture data in the first picture of a GOP, not before every picture data.


In the GOP header 42e, recorded is a time code to be counted at the rate of 60 frames per second compliant with the MPEG-2 Video standard. In portion (c) of FIG. 21, the start time code t1 of the picture to be presented first is described.


And in the user data field (i.e., extension_user_data (2) compliant with the MPEG-2 Video standard) of the picture header 42a that follows the GOP header 42e, described is a time code counted at a rate of 24 frames per second. In portion (c) of FIG. 21, the start time code t2 of the picture to be presented first is described. A similar time code t3 is described in the picture header 42c that is added to the top of the next picture data 42d.


Hereinafter, this data structure will be described in association with the example shown in portions (b) and (c) of FIG. 20.


Supposing a single GOP is included in each KPU, 00:00:00:00 associated with the first B picture shown in portion (a) of FIG. 20 is recorded in the GOP header of KPU #0, while 00:00:00:30 associated with the first picture of KPU #1 is recorded in the GOP header of KPU #1. These time codes represent a 0 hr 0 min 0 s 0th frame and a 0 hr 0 min 0 s 30th frame, respectively. The time code of the GOP header makes a carry from 00:00:00:59 to 00:00:01:00. In portion (c) of FIG. 20, only the numerals representing seconds and frames are shown.


As the time codes in picture headers, on the other hand, 00:00:00:00, representing 0 hr 0 min 0 s 0th frame, is recorded in the top B-picture to be presented first, 00:00:00:01, representing 0 hr 0 min 0 s 1st frame, is recorded in the next B-picture, and 00:00:00:02 is recorded in the next I-picture. Times codes will be recorded in this manner in the pictures that follow, too. If the frames are counted at a rate of 24 frames per second, a carry will be made from 00:00:00:23 to 00:00:01:00. In portion (a) of FIG. 20, only the numerals representing seconds and frames are shown.


According to the MPEG-2 Video standard, basically any value may be stored freely in the user data field. However, so as not to coincide with a particular four-byte code (such as 0x000001B3 that is a sequence header code), a particular bit needs to be one at an interval of four bytes, for example.


The data structure of the time codes ordinarily complies with the SMPTE M12 standard. FIG. 34 shows a general data structure of a time code compliant with the SMPTE M12 standard. The time code shown in FIG. 34 is data of four bytes, which is classified into addresses 00 through 03 on a byte-by-byte basis. Each byte is further divided into two fields, each consisting of four bits, and given respective meanings. In FIG. 34, shown are the meanings of the respective fields as defined by the standard and the value ranges of the respective fields. This standard further defines drop frame flag, binary user group bit and so on.


Next, it will be described how the camcorder 100 of this preferred embodiment operates.


The camcorder 100 makes the MPEG-2 encoder 203 generate an MPEG-2 transport stream at a rate of 60 frames per second based on the video supplied from the CCD 201a at a rate of 24 frames per second and gets the transport stream stored as a shot on a removable HDD.


In this case, the MPEG-2 encoder 203 stores time codes, which make a carry at a rate of 24 frames per second, in the user data field of the picture layer. Also, to carry out the 3:2 pull-down recording, the MPEG-2 encoder generates an MPEG-2 video stream such that a single picture is presented alternately in three or two periods consecutively when one period is 1/60 frame. The instruction to present each picture in three or two periods is stored in the picture header compliant with the MPEG standard. Specifically, if the values stored in repeat_first_field and top_field_first are both one, then the picture should be presented in three periods. On the other hand, if the values stored there are one and zero, respectively, then the picture should be presented in two periods.


During playback, the camcorder 100 reads a clip AV stream that is stored on the removable HDD and gets the stream decoded by the decoder 206. At this point in time, the time codes, which are stored in the user data field of the picture layer and counted at a rate of 24 frames per second, are acquired and their values are overlaid (i.e., superimposed) on the video.


Hereinafter, the specific configuration of the camcorder 100 for generating the data stream shown in portions (a) through (d) of FIG. 21 will be described with reference to FIG. 22.



FIG. 22 shows a partially detailed arrangement of functional blocks in the camcorder 100 of this preferred embodiment. Comparing to the hardware configuration shown in FIG. 2, it can be seen that FIG. 22 shows more detailed configurations of the encoder 203, the TS processing section 204, the media control section 205, the decoder 206 and the system control section 250.


In recording a moving picture, under the control of the writing control section 161, the video compression section 203a and audio compression section 203b of the encoder 203 compress the incoming video signal and incoming audio signal, thereby generating picture data and audio data, respectively. The system encoding section 203a of the encoder 203 receives the picture data and the audio data, thereby generating a transport stream.


In this case, the system encoding section 203c generates the respective headers shown in portions (b) and (c) of FIG. 21. Specifically, the system encoding section 203c generates picture headers 42a and 42c in which time codes t2 and t3 are stored, respectively, as shown in portion (c) of FIG. 21. These time codes t2 and t3 are described in the user data (extension#and#user#data(2)) field in the picture header. The system encoding section 203c also generates a GOP header 42e that stores the time code t1 shown in portion (c) of FIG. 21 and a PES header 41a-1 that stores PTS-1 shown in portion (b) of FIG. 21.


In a video stream compliant with the MPEG-4 AVC standard (which will be referred to herein as an “AVC stream”), there is no GOP header. However, the same statement that has been set forth with reference to FIG. 21 is equally applicable to an AVC stream, too.



FIG. 35 shows the data structure of a video stream compliant with the MPEG-4 AVC standard. According to the MPEG-4 AVC standard, a time code can be described as a picture timing SEI message (which is also defined by the same standard) just before a picture consisting of only I-slices. This time code corresponds to the time code that should be counted at a rate of 60 frames per second and stored in the GOP header in the example described above.


On the other hand, the time code that should be counted at a rate of 24 frames per second in the picture header is described as a user data unregistered SEI message according to the MPEG-4 AVC standard. AU delimiter indicates a frame boundary and SPS (sequence parameter set) and PPS (picture parameter set) store the specifications of the video stream. The IDR picture corresponds to an I-picture according to the MPEG-2 Video standard. A frame of an MPEG-4 AVC video stream is recorded in a single PES packet and a PTS is added to its PES header. This PTS is added at the frame rate of 60 frames per second shown in FIG. 21, while a time code to be counted at a rate of 24 frames per second is recorded in the user data unregistered SEI message.


In this case, instead of describing the same number of time codes as that of the GOP headers in the picture timing SEI message, the time code may be described just before every frame. Also, instead of describing the time code to be counted at the rate of 60 frames per second in the picture timing SEI message, that time code may be described along with the time code to be counted at the rate of 24 frames per second in the user data unregistered SEI message. Alternatively, if the time code to be counted at the rate of 60 frames per second is described in the user data unregistered SEI message, the time code to be counted at the rate of 24 frames per second may be described in the binary group area, which is defined by the Time Code standard (SMPTE 12M) as a four-byte area where any value can be set freely. Optionally, no time codes to be counted at the rate of 60 frames per second may be recorded at all in the moving picture stream.


Next, the TS processing section 204 generates a clip AV stream from the transport stream. The transport stream is written on a hard disk 140 by way of a writing section 205a and a magnetic head 141.


Before starting to record the clip AV stream, the writing control section 161 activates a continuous data area detecting section 160 and instructs it to look for an available area. By reference to a space bitmap that has been read in advance from an optical disk and that is managed by a logical block management section 163, the continuous data area detecting section 160 searches for a continuous available area. Then, the clip AV stream starts to be written on the available area that has been detected as a result of the search. And by the time the stream has been written on that area, the continuous data area detecting section 160 continues searching for another available area and continues writing the clip AV stream. When the clip AV stream has been written, UDF file management information will be written to finish writing the clip AV stream (i.e., *.TTS file, which is a file to store a moving picture stream). Next, a stream management data file (*.clpi) associated with the clip AV stream that has just been written is recorded.


On the other hand, during playback, when the user selects a content to play back, a reading control section 162 instructs a reading section 205b to read the management information of the clip AV stream, corresponding to the content, from a management file and then read the clip AV stream by reference to the address information described on the management file. The TS processing section 204 generates a transport stream from this clip AV stream. When a system decoding section 206c separates video data and audio data, a video expanding section 206a and an audio expanding section 206b decode the video data and the audio data, respectively, thereby outputting a video signal and an audio signal.


Also, on receiving an instruction to delete a portion of a recorded content from the user, an editing control section 164 activates the writing section 205a and the reading section 205b, thereby controlling editing processing such as reading the clip AV stream or its management data or writing a modified one. Furthermore, in response to an instruction to delete the recorded content from the user, the editing control section 164 deletes associated clip AV stream and stream management data.


Just like the camcorder of the first preferred embodiment described above, the camcorder of this preferred embodiment also generates a clip meta-data file associated with the clip AV stream file. The clip meta-data file may be generated either by the media control section 205 or by the CPU 211 of the system control section 250.



FIG. 23 shows the data structure of a clip meta-data file 300. The clip meta-data file 300 includes a number of fields called Clip Name 300a, Playback Duration 300b, Edit Unit Length 300c, Relation 300d, and Essence List 300e. The Essence list 300e further includes a number of fields called Format Type 300f, Peak Bit Rate 300g, and Video 300h. The Video field 300h further includes a number of fields called Codec information 300i, Profile/level 300j, Frame Rate Information 300k, Number of Pixels 3001, Drop Frame Flag 300m, Pull-Down Information 300n, Start Time Code 300o, End Time Code 300p, Aspect Ratio 300q, Non-Playback Interval Duration 300r, and Top Three Frame Flag 300s.


The Playback Duration field 300b represents the playback duration of one clip on an Edit Unit basis. The Edit Unit Length field 300c specifies the time length of one Edit Unit. In the example shown in FIG. 23, 1/24 second is specified, which shows that the original video is presented at a rate of 24 frames per second. On the other hand, the video frame rate of the clip AV stream associated with this clip meta-data file 300 is specified in the Frame Rate Information field 300k.


In the Relation Information field 300d, recorded is the TTS file name (MOV00002.TTS) of the following clip in the same shot. In the Format Type field 300f, the format type of the clip AV data is registered as Timed TS. The Peak Bit Rate field 300g says the peak bit rate of the MPEG-2 transport stream is 24 Mbps. In the Codec Information, Profile/Level Information, Frame Rate Information, Pixel Number Information (horizontally×vertically), Drop Frame Flag, Pull-Down Information, and Aspect Ratio fields of the Video field 300h, recorded are MPEG-2 Video, MP@HL, 1/60, 1280×720 non drop, 3:2 pull-down, 16:9 and 0 Edit Unit, respectively.


Also, in the field 300o, the time code of the first picture to be presented in the clip (i.e., start time code) is recorded. In the field 300p, the time code of the picture next to the last picture to present (i.e., end time code) is recorded. These time code values are recorded so as to include hour, minute, second and frame number. The frame identified by this Frame Number is presented at the rate specified in the Frame Rate Information field 300k. That is why the frame number increases to 59 and then returns to zero. In FIG. 23, values 00:00:00:00 and 00:01:00:00 (representing the length of one minute) have been registered. The end time code may be a time code value of the last picture.


The Top Three Frame Flag 300s shows whether the top picture associated with the start time code 300o is included in a three-frame period or in a two-frame period. In the former case, the value is one. In the latter case, the value is zero. In FIG. 23, the value is supposed to be one.


The camcorder 100 of this preferred embodiment generates a clip AV stream file and a clip meta-data file 300 having the data structures described above. By using these data structures, the video editing process can be very much simplified for the user as will be described in detail below.



FIG. 24 shows the procedure of processing of specifying a picture associated with a time code value by that time code value. This processing will be described in detail later.



FIG. 25 shows management parameters in a situation where one shot consists of a single TTS file. In FIG. 25, the arrangement of respective KPUs is shown in the order of presentation times. The start time code 300o and the KPU period 298c are just as shown in FIG. 20. Also, the playback duration, Start STC and ClipTimeLineDuration are the same as those of the first preferred embodiment described above.



FIG. 26 shows the meanings of management parameters when ClipTimeLineAddressOffset is not equal to zero and when one shot consists of one TTS file. Unlike the example shown in FIG. 25, the non-playback interval duration is not equal to zero and the latter half of the last KPU is not played back (specifically, is not regarded as part of the playback duration). p2, p3 and p4 shown in FIG. 26 correspond to p2, p3 and p4 shown in FIG. 18, respectively.


The upper and lower portions of the TTS file shown in FIG. 26 show the same clip AV stream. Specifically, the upper portion shows the arrangement of respective KPUs in the TTS file in the order of presentation times, and its abscissa represents the “time”. On the other hand, the lower portion shows the arrangement of respective KPUs in the TTS file in the order of data sizes, and its abscissa represents the “data size”. The same statement will apply to all of similar drawings to be referred to.



FIG. 27 shows the meanings of management parameters in a situation where one shot is a chain of multiple TTS files. In each of those TTS files, ClipTimeLineDuration is the sum of the KPU periods of respective KPUEntries 296h of a time map file associated with that TTS file.


Hereinafter, it will be described how to perform editing processing using the camcorder 100. As described above, in playing back video, the camcorder 100 acquires the time codes that are recorded in the user data field and that should be counted at a rate of 24 frames per second. The graphic control section 20 overlays that value on the video. Then, by looking at the time code value overlaid (i.e., superimposed) on the video, the user can check the time code value of an IN point, an OUT point or any other point of interest of the video. Also, the camcorder acquires the time code value of that video, and sets the time code value acquired as the IN point or OUT point in a play list, for example.


When the play list is read, the processing of specifying a picture associated with the time code that should be counted at a rate of 24 frames per second is carried out following the procedure shown in FIG. 24.


First, the user enters a time code value in Step S310. Then, by reference to the clip meta-data file 300, the editing control section 164 calculates the sum of the difference between the time code value entered and the start time code value 295f and the non-playback interval duration 300r as a differential time code value in Step S311. It should be noted that the non-playback interval duration 300r is described as a value representing the nth frame on an Edit Unit basis when frames beginning with (n+1)th frame as counted from the top of a GOP are specified as pictures to present, for example.


Next, using that differential time code value, the editing control section 164 calculates a target STC value, which is an STC value associated with the differential time code value. This target STC value is substantially the same as the PTS value of the picture to be specified.


The equation to be used in a situation where the top three frame flag has a value of one is shown in Step S312 of FIG. 24. In Step S312, the Ceil (x) function (where x is a real number) has a function value, which is an integer that is equal to or greater than, and is closest to, the value x. In this case, the differential time code value is multiplied by 5/2 because an MPEG stream subjected to 3:2 pull-down every second has been recorded. It should be noted that if the top three frame flag has a value of zero, then the target STC value can be calculated by the following equation:





Target STC value=Start STC value 295f+floor (differential time code×(5/2)×(27,000,000/60))  (4)


where the floor (x) function (where x is a real number) has a function value, which is an integer that is equal to or smaller than, and is closest to, the value x.


Next, the editing control section 164 sequentially adds together the KPU periods 298c of respective KPUEntries 295h, which begin with KPUEntry of KPU#0, thereby deriving the first KPU number that satisfies:





Target STC value≦Start STC value 295f+ΣKPUPeriod  (5)


in Step S313. That KPU number will be referred to herein as “k”. In this case, the address of the picture associated with the time code value specified is included in KPU #k. Next, the editing control section 164 figures out the storage address of this KPU #k in Step S314 by the following equation:





ClipTimeLineAddressOffset 295d+ΣKPUSize  (6)


where ΣKPUSize is calculated from KPU #0 through KPU #k. The editing control section 164 further calculates the difference STC between the first picture (to present) of KPU #k and the picture associated with the time code value by the following equation (in Step S315):





Differential STC=Target STC value−(Start STC value+ΣKPUPeriod)  (7)


If differential STC>0, the presentation should be skipped for a period of time corresponding to this time difference.


According to the processing method described above, if the user directly specifies one of the pictures to be presented at a rate of 24 frames per second as an IN point, an OUT point or a chapter division point, he or she can carry out virtual editing using a play list or split editing of a clip AV stream by reference to the time code of that frame. As a result, the editing processing can be done efficiently.


According to the second preferred embodiment, if a front portion of a shot should be deleted, not only the same processing steps as those of the first preferred embodiment described above but also additional processing steps of changing the start time code 300o and the non-playback interval duration 300r need to be carried out.


Once the differential STC has been calculated in Step S315, the data in the KPU needs to be searched and the frames corresponding to the differential STC need to be skipped to start playback (output).


EMBODIMENT 3

Hereinafter, a third preferred embodiment of a data processor according to the present invention will be described. The data processor of this preferred embodiment is supposed to be a camcorder having the same hardware configuration as the counterpart of the second preferred embodiment (shown in FIGS. 2 and 22) described above. A major difference between the second and third preferred embodiments lies in the data structure of the KPUEntry field generated by the camcorder. The KPUEntry field is included in the clip time line and is generated by the media control section 205.


Portions (a) to (c) of FIG. 28 show presentation timing relations between respective frames in a situation where video to be presented at a rate of 24 frames per second is converted into video to be presented at a rate of 60 frames per second by the 3:2 pull-down technology. The resultant data stream is supposed to have 1,280 horizontal pixels by 720 vertical pixels.


The example shown in portions (a) through (c) of FIG. 28 is different from that of the second preferred embodiment shown in portions (a) through (c) of FIG. 20 in the following respects. First of all, in the KPUEntry, the KPUPeriod is replaced with a field 398c representing a PTS difference. In the PTS difference field, a value representing a difference in PTS between key pictures, i.e., a KPU and a KPU that follows it (or between adjacent KPUs), on an AUTM basis, is described.


Secondly, StartSTC 295f is replaced with a StartKeySTC field 395f, in which a value, representing the presentation timing of the first I-picture in the top KPU (i.e., KPU #0) in a single TTS file on an AUTM basis, is described.


A third difference is that TimeOffset 395i is newly provided, in which a value, representing a time lag between the picture to be presented earliest in the top KPU and the first I-picture of that KPU on an AUTM basis, is described. In the example shown in FIG. 28, a time lag between the B-picture to be presented earliest in KPU #0 and the first I-picture of the same KPU #0, i.e., a value representing five frame periods out of 60 frames per second, is described in the TimeOffset field.



FIG. 29 shows the data structure of a clip meta-data file 400 according to the third preferred embodiment. This clip meta-data file 400 is provided for the first clip in a situation where one shot consists of three clips. The respective fields 400a through 400s of the clip meta-data file 400 correspond to the counterparts 300a through 300s shown in FIG. 23. These two groups of fields have the same values except for the setting in the field 400b in which the playback duration is described.



FIG. 30 shows the data structure of a ClipTimeLine file 395 according to this preferred embodiment. The difference between the examples shown in FIGS. 28 and 20 is also seen in this ClipTimeLine file 395. Specifically, in the KPUEntry 395h, the KPUPeriod is replaced with a field 398c representing a PTS difference. Also, StartSTC 295f is replaced with a field 395f describing StartKeySTC. And a field 395i describing TimeOffset is newly provided. It should be noted that in the ClipTimeLine file 395, there is no time entry field 95g that has already been described for the first preferred embodiment with reference to FIG. 12.



FIG. 31 shows the procedure of processing of specifying a picture associated with a time code value by that time code value. This processing will be described in detail later.



FIG. 32 shows the meanings of management parameters in a situation where one shot consists of a single TTS file. The start time code 400o has the same meaning as the start time code 300o shown in FIG. 25. Also, the playback duration and ClipTimeLineDuration have the same meanings as those described for the first preferred embodiment. A difference from the example shown in FIG. 25 is that the StartSTC field 295f shown in FIG. 25 is replaced with a StartKeySTC field 395f.



FIG. 33 shows the meanings of management parameters according to the third preferred embodiment in a situation where the ClipTimeLineAddressOffset is not zero and one shot consists of three TTS files. Unlike the example shown in FIG. 32, the non-playback interval duration is not zero and the latter half of the last KPU is not played back (specifically, specified by the end time code and not included in the playback duration). Also, p2, p3 and p4 shown in FIG. 33 correspond to p2, p3 and p4 shown in FIG. 18.


Unlike the second preferred embodiment, the playback duration of a TTS file is counted from a playback start point identified by a start time code through the key picture in the first complete KPU in the next TTS file on an Edit Unit basis. Also, the playback duration of the second TTS file is a time lag to be counted from the key picture in the first complete KPU in the same TTS file through the key picture in the first complete KPU in the next TTS file on an Edit Unit basis. Furthermore, the playback duration of the last TTS file of one shot is counted from the key picture in the first complete KPU in the same TTS file through the last picture to present on an Edit Unit basis.


If one shot consists of four or more TTS files, not three as in FIG. 33, the playback durations of intermediate TTS files, other than the first and last files, may be the same as that of the second TTS file shown in FIG. 32.


A major feature of this preferred embodiment will be described. In this preferred embodiment, TimeOffset 395i is defined for only the first TTS file in a chain of TTS files. By managing TimeOffset and PTS difference in the ClipTimeLine file associated with that file, the playback duration of one shot can be managed on a picture-by-picture basis. In this case, the PTS difference can be figured out just by detecting the I-picture of an MPEG-2 stream. That is why the processing can be simplified compared to a situation where the number of all pictures should be counted. For that reason, even an external circuit for an MPEG encoder can detect the PTS difference easily. In addition, by introducing the concept of PTS difference, even in a situation where a broadcasting wave needs to be recorded through an IEEE 1394 interface or a tuner of the camcorder, the KPU entries can also be generated easily.


Meanwhile, TimeOffset can be set easily by detecting the number of frames that precede the I-picture only in a top portion of a shot. Alternatively, the TimeOffset value can also be set easily by making the MPEG encoder section use a fixed value as the number of frames that precede the I-picture only in the top portion of a shot. Still alternatively, the TimeOffset value can also be set easily by recording once a clip AV stream supplied from an external device, for example, and then analyzing the stream.


TimeOffset is managed only in the top portion of a shot. That is why even if pictures that form a GOP of an MPEG-2 video stream have changed their structures halfway through the stream, the methods of generating TimeOffset and PTS difference are not affected. For example, even if the structures of pictures that form a single GOP have changed from IBBPBB into IPBB or IPIP (in the order of recording) halfway through the stream, the procedure of generating management data is not affected. As a result, the GOP structures of a stream can be changed freely (e.g., a GOP structure of IPBB can be temporarily adopted right after a scene change has been detected), thus improving the image quality.


As described above, the TimeOffset value can be set easily and can be detected by an external circuit for an MPEG encoder. Therefore, there is no need to send the KPU period value to an external device outside of the MPEG encoder every KPU. Consequently, the API (application interface) of an MPEG encoder LSI can be lightened. Besides, since a general-purpose MPEG encoder LSI can be used, the additional cost to introduce the LSI can be minimized.


Hereinafter, it will be described how the camcorder 100 of this preferred embodiment operates. The specific operation of the camcorder 100 to generate a clip AV stream and the processing of playing back the clip AV stream are the same as those carried out by the camcorder of the second preferred embodiment described above, and the description thereof will be omitted herein.


The camcorder 100 of this preferred embodiment generates a clip meta-data file associated with the clip AV stream file. The clip meta-data file may be generated either by the media control section 205 or by the CPU 211 of the system control section 250.


The media control section 205 describes the PTS difference value in the PTS difference field 398c in the KPUEntry 395h, StartKeySTC in the StartKeySTC field 395f, and TimeOffset in the TimeOffset field 395i, respectively.


During editing, by looking at the time code value overlaid (i.e., superimposed) on the video, the user can check the time code value of an IN point, an OUT point or any other point of interest of the video. Also, the camcorder acquires the time code value of that video, and sets the time code value acquired as the IN point or OUT point in a play list, for example.


When the play list described above is read, the processing of specifying a picture associated with the time code value that should be counted at a rate of 24 frames per second is carried out following the procedure shown in FIG. 31. First, the user enters a time code value in Step S410. Then, by reference to the clip meta-data file 400, the editing control section 164 calculates the sum of the difference between the time code value entered and the start time code value 400o and the non-playback interval duration 400r as a differential time code value in Step S411.


Next, using that differential time code value, the editing control section 164 calculates a target STC value, which is an STC value associated with the differential time code value. This target STC value is substantially the same as the PTS value of the picture to be specified as already described for the second preferred embodiment.


The equation to be used in a situation where the top three frame flag has a value of one is shown in Step S412. In Step S412, the Ceil (x) function (where x is a real number) has a function value, which is an integer that is equal to or greater than, and is closest to, the value x. In this case, the differential time code value is multiplied by 5/2 because an MPEG stream subjected to 3:2 pull-down every second has been recorded. It should be noted that if the top three frame flag has a value of zero, then the target STC value can be calculated by the following equation:










Target





S





T





C





value

=


Start





S





T





C





395

f

-

TimeOffset





395

i
×

(

27
,
000
,

000
/
60


)


+

floor






(

differential





time





code
×

(

5
/
2

)

×

(

27
,
000
,

000
/
60


)


)







(
8
)







where the floor (x) function (where x is a real number) has a function value, which is an integer that is equal to or smaller than, and is closest to, the value x.


Next, the editing control section 164 sequentially adds together the PTS differences 398c of respective KPUEntries 395h, which begin with KPUEntry of KPU#0, thereby deriving the first KPU number that satisfies:





Target STC value≦StartKeySTC value 395f+ΣPTS difference  (9)


in Step S413. That KPU number will be referred to herein as “k”. In this case, the address of the picture associated with the time code value specified is included in KPU #k. Next, the editing control section 164 figures out the storage address of this KPU #k in Step S414 by the following equation:





ClipTimeLineAddressOffset 395d+ΣKPUSize  (10)


where ΣKPUSize is calculated from KPU #0 through KPU #k. The editing control section 164 further calculates the difference STC between the first picture (to present) of KPU #k and the picture associated with the time code value by the following equation (in Step S415):





Differential STC=Target STC value−(StartKeySTC value+ΣKPUDifference)  (11)


If differential STC>0, the presentation should be skipped for a period of time corresponding to this time difference.


According to the processing method described above, if the user directly specifies one of the pictures to be presented at a rate of 24 frames per second as an IN point, an OUT point or a chapter division point, he or she can carry out virtual editing using a play list or substantive editing such as split editing of a clip AV stream by reference to the time code of that frame. In addition, he or she can also do play list playback by using the time codes for 24 frames to be presented per second. As a result, the editing processing can be done efficiently.


The media control section 205 of this preferred embodiment can generate the clip meta-data file and the ClipTimeLine file to specify a picture using a time code even without getting information on the arrangement of pictures that form a GOP from the encoder 203. That is why even if the pictures that form a GOP of a clip AV stream have changed their structures, the media control section 205 can also generate the clip meta-data file 400 and the ClipTimeLine file 395. Then, the editing control section 164 can start editing and playback from a frame associated with the time code described.


Particularly, in the ClipTimeLine file 395, not only the PTS difference 398c but also the TimeOffset 395i are managed. That is why the exact number of frames stored in one shot can be calculated easily. As a result, the user can edit the video on a frame-by-frame basis.


According to the third preferred embodiment, if a front portion of a shot should be deleted, not only the same processing steps as those of the first preferred embodiment described above but also additional processing steps of changing the start time code 400o, the non-playback interval duration 400r and TimeOffset 395i need to be carried out.


Preferred embodiments of the present invention are as described above.


In the second and third preferred embodiments described above, video is supposed to be input to the device at a frame rate of 24 frames per second. However, this is just an example. Alternatively, the video may also be input at a rate of 23.97 frames (i.e., 24,000 frames in every 1,001 seconds) per second. Also, the video is supposed to be generated by the device at a frame rate of 60 frames per second. However, the video may also be generated at a rate of 59.94 frames per second (i.e., 60,000 frames in every 1,001 seconds).


Also, in the example described above, video to be presented at a rate of 24 frames per second is subjected to 3:2 pull-down processing to generate an MPEG-2 stream to be presented at a rate of 60 frames per second. Alternatively, video to be presented at a rate of 30 frames per second may be subjected to 2:2 pull-down processing to generate an MPEG-2 stream to be presented at a rate of 60 frames per second.


Furthermore, in the second and third preferred embodiments described above, only when video to be presented at a rate of 24 frames per second is generated and recorded as a moving picture stream to be presented at a rate of 60 frames per second, the time codes to be counted at a rate of 24 frames per second are supposed to be recorded in the stream. However, even when video to be presented at a rate of 60 frames per second is recorded in a moving picture stream to be presented at the rate of 60 frames per second, time codes to be counted at the rate of 60 frames per second may be recorded in a picture header, for example. In that case, the reading control section can always refer to the picture header and overlay it on the video irrespective of the number of frames of the video.


Optionally, the processing may be carried out on a video field basis, not on a frame-by-frame basis. For example, video to be presented at a rate of 24 frames per second may be subjected to 3:2 pull-down processing to generate an MPEG-2 video stream to be presented at a rate of 60 fields (or 59.94 fields) per second. Each field may have either a size of 1,920 horizontal pixels by 1,080 vertical pixels or a size of 720 horizontal pixels by 480 vertical pixels. In that case, the top three frame flag 300s or 400s should be generated following a different rule. For example, if the reference picture for the start time code 300o or 400o is associated with three fields out of 60 fields, the flag may have a value of one. On the other hand, if the reference picture is associated with two fields, then the flag may have a value of zero. It should be noted that these flags should be called “top three FIELD flags” rather than “top three FRAME flags”.


Portions (a) to (c) of FIG. 36 show presentation timing relations between respective frames in a situation where video to be presented at a rate of 24 frames per second is converted into video to be presented at a rate of 60 frames per second by the 3:2 pull-down technology. The video to be presented at a rate of 60 frames per second is recorded as a data stream compliant with the MPEG-2 standard on a storage medium such as a removable HDD. This drawing corresponds to FIG. 20 showing a situation where an MPEG-2 video stream to be presented at a rate of 60 frames per second is generated by the 3:2 pull-down technology.


The respective frames shown in portion (a) of FIG. 36 are recorded by the 3:2 pull-down technology so as to have a three-field period, a two-field period, and a three-field period in this order from the top. For example, in the first three-field period, the first B-picture (frame) is recorded so as to present a top field, a bottom field and the top field in this order. The next B-picture is recorded so as to present a bottom field and a top field in this order.


Another example of the field-based processing is to process and record video to be presented at a rate of 25 frames per second by 2:2 pull-down technology. That is to say, one out of 25 video frames to be presented per second may be encoded and recorded as two fields in an MPEG-2 video stream to be presented at a rate of 50 fields per second.


Still another example of the field-based processing is to process and record a frame of video to be presented at a rate of 30 frames per second by 2:2 pull-down technology. That is to say, one out of 30 video frames to be presented per second may be encoded and recorded as two fields in an MPEG-2 video stream to be presented at a rate of 60 fields per second.


In the second and third preferred embodiments described above, the top three frame flags are supposed to be recorded. Alternatively, the reference picture for the start time code 300o or 400o may be associated with either three-frame presentation or two-frame presentation in advance. In that case, however, attention should be paid to always cope with the three-frame presentation after the MPEG stream has been edited.


In the second and third preferred embodiments described above, the top three frame flags are supposed to be pieces of information on a reference picture for a start time code. Alternatively, those flags may be pieces of information on a picture, with which playback should be started after the pictures in the non-playback interval duration 300r or 400r have been skipped. Furthermore, the playback start time (on a PTM basis) of that playback start picture and the time codes to be counted at a rate of 24 frames per second may be stored as management data. In that case, by reference to the playback start time of the playback start picture and the time code, the storage address of the associated picture can be found by the time code value.


Also, in the second and third preferred embodiments described above, the top KPU of a clip AV stream is supposed to begin with three frames to be presented first in a three-frame presentation period and then two frames to be presented next in a two-frame presentation period in the 60 frames to be presented per second. Conversely, those 60 frames to be presented per second may begin with two frames to be presented first and then three frames to be presented next.


Furthermore, in the second and third preferred embodiments of the present invention described above, the top three frame flags are supposed to be recorded and referred to. Alternatively, by analyzing the top_field_first flag of a picture of the top KPU in a clip AV stream, if the flag is one, the same type of processing may be carried out as in a situation where the top three frame flag is one. On the other hand, if the flag is zero, the same type of processing may be carried out as in a situation where the top three frame flag is zero.


This is because if the 3:2 pull-down recording is carried out, then a picture with top_field_first=1 in the picture header will be presented for three frame periods and a picture with top_field_first=0 in the picture header will be presented for two frame periods. In that case, however, the picture should be subjected to data analysis.


The same statement applies to a situation where video to be presented at a rate of 24 frames per second is subjected to the 3:2 pull-down processing to generate an MPEG-2 stream to be presented at a rate of 60 frames per second.


For example, by analyzing the repeat_first_field flag of a picture of the top KPU in a clip AV stream, if the flag is one, the same type of processing may be carried out as in a situation where the top three field flag is one. On the other hand, if the flag is zero, the same type of processing may be carried out as in a situation where the top three field flag is zero. This is because if the 3:2 pull-down recording is carried out, then a picture with repeat_first_field=1 in the picture header will be presented for three field periods and a picture with repeat_first_field=0 in the picture header will be presented for two field periods. In that case, however, the picture should be subjected to data analysis, too.


Furthermore, in a situation where video to be presented at a rate of 24 frames per second is subjected to the 3:2 pull-down processing to generate a stream to be presented at a rate of 60 frames per second, the relation between the time codes and the frame numbers may be fixed. For example, if the time code has an even frame number, then the three-frame presentation may be carried out. But if the time code has an odd frame number, then the two-frame presentation may be carried out. In that case, the top three frame flag may be omitted.


Alternatively, if the time code has a frame number of 0, 4, 8, 12, 16 or 20, a top field, a bottom field and the top field may be presented in three field periods. On the other hand, if the time code has a frame number of 1, 5, 9, 13, 17 or 21, a bottom field and a top field may be presented in two field periods. If the time code-frame number relation is fixed in this manner, the other frame numbers should also be fixed in the same way.


Furthermore, in the second and third preferred embodiments of the present invention described above, the playback duration 300b, 400b is set on an Edit Unit basis. However, the duration may also be set on an AUTM basis because these two units are convertible one into the other. Likewise, the non-playback interval duration 300r, 400r may also be set on an AUTM basis.


Also, in the second and third preferred embodiments described above, an MPEG-2 transport stream is supposed to be continuous in a clip AV stream. That is to say, the PTS, DTS and PCR are supposed to be assigned responsive to a continuous STC. The time codes to be counted at a rate of 24 frames per second are also supposed to be assigned continuously.


The drop frame flag is supposed to be OFF in the second and third preferred embodiments described above, but may also be ON. This is because even with the drop frame flag turned ON, the ON and OFF states are switchable one into the other since the counts are skipped following a predetermined rule.


Furthermore, in the second and third preferred embodiments described above, the time codes to be counted at a rate of 24 frames per second are supposed to begin with 00:00:00:00. In this case, the first time code counted may represent either a recording start time (i.e., hour/minute/second/frame number) or a serial number assigned to the HDD. Camcorders for business use usually have the function of allowing the user to customize the time code initial value.


In the MPEG-2 video stream of the second and third preferred embodiments described above, two B-pictures are supposed to be presented earlier than an I-picture at the top of a KPU. Alternatively, encoding may also be done such that the I-picture is presented earlier at the top of a KPU.


In the preferred embodiments described above, the media to store a data stream is supposed to be removable HDDs. However, as long as the media can manage files by the file system described above, the media may also be non-removable ones such as HDDs built in data processors.


In the first preferred embodiment, the data structure of the time map (ClipTimeLine) is supposed to include the two layers of TimeEntries and KPUEntries. However, as long as the presentation times are convertible into storage addresses, and vice versa, the data structure does not have to have the two layers but quite the same statement applies to even a time map consisting of the KPUEntry layer alone. Also, in the foregoing description, the OverlappedKPUFlag field is provided and it is determined by the value of that field whether or not a key picture unit KPU covers multiple files. However, even if there is no data corresponding to the time map, it may be determined whether multiple files are covered or not. For example, it may be indicated that the KPU (may) cover multiple files by storing clip meta-data (such as the relation information), the clip file naming rule (such as file name numbers in the ascending order) or all data of one shot within the same folder (at least some of the TTS files for one shot that are stored on the same storage medium).


The respective functional blocks such as those shown in FIGS. 2 and 22, for example, are typically implemented as an LSI (large-scale integrated circuit) chip. These functional blocks may be implemented as respective chips or may also be integrated together into a single chip either fully or just partially.


In FIG. 2, for example, the system control section 250 including the CPU 211 and the media control section 205 are shown as mutually different functional blocks. However, these blocks may be implemented either as two different semiconductor chips or as physically the same chip by incorporating the functions of the media control section 205 into the system control section 205. Optionally, the functions of the media control section 205 and TS processing section 204 may be integrated together into a single chip circuit. Or a chip circuit 217 may be realized by further adding the functions of the encoder 203 and the decoder 206 thereto. However, only the memory that stores the data to be encoded or decoded may be excluded from the blocks to be integrated together. Then, a number of coding methods can be coped with easily.


The system control section 250 can carry out the functions of the media control section 205 that have been described above by executing the computer program stored in the program ROM 210, for example. In that case, the media control section 205 is realized as one of multiple functions of the system control section 250.


It should be noted that the LSI mentioned above is sometimes called an IC, a system LSI, a super LSI or an ultra LSI depending on the number of devices that are integrated together per unit area. The integrated circuit does not have to be an LSI but may also be implemented as a dedicated circuit or a general-purpose processor. Optionally, after an LSI has been fabricated, a programmable FPGA (field programmable gate array) or a reconfigurable processor in which the connection or setting of circuit cells inside the LSI are changeable may be adopted.


As another possibility, a novel integrated circuit technology to replace LSIs might be developed in the near future as a result of advancement of the semiconductor technology or any other related technology. In that case, the functional blocks could be integrated together by that novel technology. For example, the functional blocks could be integrated together as so-called “bio elements” by utilizing some biotechnology.


In the preferred embodiments described above, the storage medium is supposed to be a removable HDD. However, this is just an example. Alternatively, an optical disk such as a DVD-RAM, an MO, a DVD-R, a DVD-RW, a DVD+RW, a CD-R or a CD-RW or a storage medium such as a hard disk may also be used. Still alternatively, a semiconductor memory such as a flash memory, an FeRAM or an MRAM may also be used.


Furthermore, in the preferred embodiments described above, the clip AV stream is supposed to include a transport stream. Alternatively, the clip AV stream may also be a bit stream such as a program stream or a PES stream that includes multimedia information compliant with any other encoding format.


Also, the video is supposed to be represented by an MPEG-2 video stream but may also be an MPEG-4 video stream or an MPEG-4 AVC stream (H.264 stream). Likewise, the audio may also be a linear PCM audio stream or an AC-3 stream.


In the preferred embodiments described above, StartSTC and StartKeySTC are supposed to be recorded in a ClipTimeLine file for a stream. However, those STCs may be omitted. In that case, the time code of the top frame in the presentation order is extracted and handled as StartSTC. Alternatively, the time code may be converted into a PTS as well.


The foregoing description of the second and third preferred embodiments is focused on examples of 3:2 pull-down processing. However, even if the pull-down processing is not carried out (i.e., even if normal 60-field, 50-field, 60-frame or 50-frame recording is performed), the time code values may also be recorded at the same data locations as in the pull-down processing.


Furthermore, in the 3:2 pull-down processing of the second and third preferred embodiments described above, three frames are always followed by two frames and the same combination is repeated numerous times. Alternatively, the order may be appropriately changed like three frames, two frames and then two frames. If such an order is adopted, however, the address cannot be calculated smoothly in jumping to a GOP including a picture associated with the time code specified by the user. For that reason, to identify such an irregular order adopted, pull-down information “unknown” may be written in the clip meta-data file. On the other hand, if the pull-down information is “3:2”, its order of repetition is preferably never changed.


INDUSTRIAL APPLICABILITY

In the video data stream generated by the processing of the present invention, when the IN and OUT points of the video to be presented at a rate of 24 frames per second needs to be set during editing, the user can set those IN and OUT points easily. Also, these points can be set without increasing the rate of communications with the MPEG encoder while a moving picture is being encoded. And there is no need to use any special MPEG encoder, either. That is why the present invention can be used effectively in various devices and units that handle audiovisual data to be presented at a rate of 24 frames per second.

Claims
  • 1. A data processor comprising: a receiving section for receiving a signal representing first video in which a plurality of pictures are presented at a first frequency;an encoder for generating a data stream representing second video, in which the pictures are presented at a second frequency, different from the first frequency, based on the signal; anda writing section for writing the data stream on a storage medium,wherein the encoder generates picture data about the respective pictures, first time information indicating presentation times at the first frequency, and second time information indicating presentation times at the second frequency, and stores the first time information, the second time information and picture data of the respective pictures to be presented based on the first time information in association with each other, thereby generating the data stream.
  • 2. The data processor of claim 1, further comprising a control section for generating management information to play back the video, the control section generating, as the management information, meta-data that includes information on the first frequency and information on the second frequency.
  • 3. The data processor of claim 2, further comprising a control section for generating management information to play back the video, the control section further generating, as the management information, meta-data that includes the first time information.
  • 4. The data processor of claim 1, wherein the encoder generates a playback unit including the picture data, the first time information and the second time information on at least one picture, and wherein the encoder generates the first time information and the second time information for the picture of the playback unit.
  • 5. The data processor of claim 1, wherein the encoder generates a playback unit including data about a base picture that is decodable by itself, data about at least one reference picture that needs to be decoded by reference to the base picture, the first time information and the second time information, and wherein the encoder generates the first time information and the second time information for at least the first base picture of the playback unit.
  • 6. The data processor of claim 1, wherein the receiving section receives the signal representing the first video in which 24 pictures are presented one after another per second, and wherein the encoder generates the data stream representing the second video in which 60 pictures are presented one after another per second.
Priority Claims (2)
Number Date Country Kind
2004-331515 Nov 2004 JP national
2005-149048 May 2005 JP national
PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/JP2005/021025 11/16/2005 WO 00 5/15/2007