The present invention relates to a technique of playing back video and/or audio from a data stream. More particularly, the present invention relates to a technique that can be used effectively to play back continuously either multiple portions of the same data stream or a plurality of data streams.
Recently, as digital technologies have been developed, data representing a video or audio content is more and more often encoded according to an MPEG or any other standard and stored as an encoded data stream on a storage medium such as an optical disk or a hard disk. Meanwhile, as the storage technology has been developed, various techniques of playing back an encoded data stream from such a storage medium have been proposed and have just started to be introduced into actual products.
For example, Japanese Patent Application Laid-Open Publication No. 2002-281458 discloses a player for playing back an encoded data stream stored on a storage medium. Hereinafter, the configuration of this player will be described with reference to
The reading section 2 of this player is given a specified address on the storage medium 1 by a microcontroller 3 and reads out a data stream stored at that address. The reading section 2 makes error correction processing on the digital signal read out, thereby obtaining a read data stream. Next, a stream splitting section 4 splits the data stream into a video data stream and an audio data stream. The video data stream separated is input to a video decoder 6 by way of a video signal selecting switch 12a, a video data memory section 5, and another video signal selecting switch 12b. The video data memory section 5 includes two or more independent memory areas that can store data streams independently of each other. The video data stream is input to the video decoder 6 through one of those memory areas. On the other hand, the audio data stream, which has been separated by the stream splitting section 4, is input to an audio decoder 10 by way of an audio data memory section 9.
The video decoder 6 decodes the video data stream, converts it into a video signal, and outputs it through a video output terminal 8, while at the same time storing the decoded video on a frame data memory section 7. Meanwhile, the audio decoder 10 decodes the audio data stream, converts it into an audio signal, and outputs it through an audio output terminal 11.
The player may play back discontinuous data streams. A data stream gets stored on the storage medium 1 as a result of a series of operations that begins with start of write processing and ends with stop of that write processing. Accordingly, if the write processing has been carried out a number of times, at least two data streams are stored on the storage medium 1. In that case, if the user instructs the player to play back these data streams back to back, then the player has to play back the at least two discontinuous data streams continuously. Also, even in playing back multiple ranges of a single data stream continuously, if each of those ranges is regarded as one data stream, then the player also has to play back at least two discontinuous data streams continuously. The situation is typically encountered when the user made a play list to specify arbitrary playback ranges and paths for a single data stream.
Hereinafter, it will be described how the player carries out the processing of playing back discontinuous data streams. First, the player controls the video signal selecting switches 12a and 12b, thereby getting a first data stream transmitted to, and decoded by, the video decoder 6 by way of one of the memory areas of the video data memory section 5. As soon as the video decoder 6 has decoded the first data stream, the microcontroller 3 turns the video signal selecting switches 12a and 12b. Then, a second data stream read out next is transmitted to the video decoder 6 by way of the other memory area of the video data memory section 5. Consequently, the video decoder 6 can start decoding the second data stream on decoding the first data stream, i.e., can decode the two data streams continuously.
A conventional player like this, however, inevitably needs an increased amount of hardware and also requires a complicated control. More specifically, in such a player, at least two independent memory areas need to be provided for the video data memory section to store the data streams separately. The player also needs the input and output video signal selecting switches to switch the memory areas. The microcontroller has to carry out a switching control on those switches.
An object of the present invention is to play back a number of discontinuous data streams continuously using a simple configuration and control without providing any additional memory area or video signal selecting switch. A secondary object of the present invention is to minimize playback disturbance at a discontinuity point.
A data processor according to the present invention plays back a content while acquiring a data stream including content data. The data stream includes a plurality of packets, each packet being consisted of the content data and an identifier to show the type of the content data. A portion of the content data corresponding to the top of a playback unit has a header showing the identity of the playback unit. The data processor includes: a stream extracting section for acquiring a first data stream and then a second data stream; a packet inserting section, which makes a dummy packet, having a dummy identifier that is different from any of the identifiers of the packets, and which inserts the dummy packet between the last packet of the first data stream and the first packet of the second data stream; a splitting section for splitting the content data into respective types according to the identifiers and inserting error data, which is different from the content data, upon the detection of the dummy identifier; and a decoder, which plays back the content data on the basis of the playback unit and, on detecting the error data, discards incomplete content data at the end of the first data stream and a portion of the content data of the second data stream up to the first header thereof such that those content data are not played back.
An error code, representing an error, may be predefined for the data stream, and the splitting section may insert the error code as the error data.
The splitting section may further insert a bit string of zeros having a predetermined length as the error data. When detecting one of the error code and the bit string, the decoder may determine that the error data has been detected.
The data representing the content may have been encoded by a variable length coding technique and may be included in the data stream. The splitting section may insert a bit string, of which the bit length is equal to or greater than a maximum code length used in the variable length coding technique.
The content may at least include video. The splitting section may insert a bit string, of which the bit length is equal to or greater than a maximum code length used in the variable length coding technique for video.
The stream extracting section may acquire the first and second data streams, each being consisted of transport stream packets.
The stream extracting section may acquire mutually different portions of a single data stream, representing the same content, as the first and second data streams, respectively.
The stream extracting section may acquire the first and second data streams from a storage medium.
The stream extracting section may acquire the first and second data streams that have been broadcast.
A data processing method according to the present invention is designed to play back a content while acquiring a data stream including content data. The data stream includes a plurality of packets, each packet being consisted of the content data and an identifier to show the type of the content data. A portion of the content data corresponding to the top of a playback unit has a header showing the identity of the playback unit. The data processing method includes the steps of: acquiring a first data stream and then a second data stream; making a dummy packet, having a dummy identifier that is different from any of the identifiers of the packets; inserting the dummy packet between the last packet of the first data stream and the first packet of the second data stream; splitting the content data into respective types according to the identifiers; inserting error data, which is different from the content data, upon the detection of the dummy identifier; playing back the content data on the basis of the playback unit; and discarding incomplete content data at the end of the first data stream and a portion of the content data of the second data stream up to the first header thereof on detecting the error data.
An error code, representing an error, may be predefined for the data stream, and the step of inserting the error data may include inserting the error code as the error data.
The step of inserting the error data may further include inserting a bit string of zeros having a predetermined length as the error data. The step of discarding may include determining that the error data has been detected on detecting one of the error code and the bit string.
The data representing the content may have been encoded by a variable length coding technique and be included in the data stream. The step of inserting the error data may include inserting a bit string, of which the bit length is equal to or greater than a maximum code length used in the variable length coding technique.
The content may at least include video. The step of inserting the error data may include inserting a bit string, of which the bit length is equal to or greater than a maximum code length used in the variable length coding technique for video.
The step of acquiring may include acquiring the first and second data streams, each being consisted of transport stream packets.
The step of acquiring may include acquiring mutually different portions of a single data stream, representing the same content, as the first and second data streams, respectively.
The step of acquiring may include acquiring the first and second data streams from a storage medium.
The step of acquiring may include acquiring the first and second data streams that have been broadcast.
Portions (a) to (d) of
Portion (a) of
Hereinafter, a player will be described as a preferred embodiment of a data processor according to the present invention with reference to the accompanying drawings.
First of all, the data structure of a data stream to be processed by a player according to this preferred embodiment will be described. After that, the configuration and operation of the player will be described.
Hereinafter, the video TS packets and audio TS packets, which are relevant to the processing of the present invention, will be described.
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 ID (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. It should be noted that the data memory area of a TS packet, following the TS packet header, is called a “payload” when content data such as video data or audio data is stored there and an “adaptation field” when control data is stored there, respectively. The prime feature of the processing of this preferred embodiment lies in the processing that uses the payload of a TS packet.
FIGS. 2, 3(a) and 3(b) show an exemplary data structure of a transport stream. However, this data structure is equally applicable to packs included in a program stream because data also follows a packet header in a pack. A “pack” is known as an exemplary form of a packet. Nevertheless, the pack is different from the packet in that a pack header is additionally provided before the packet header and that the pack has a data size of 2,048 kilobytes.
The following preferred embodiment of the present invention will be described herein as being applied to video processing.
Portions (a) to (d) of
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
The picture data 41a-2 includes the data of respective pictures. An elementary stream is made up of those picture data 41a-2. Portion (c) of
In the picture header 42a shown in portion (c) of
It should be noted that either a sequence header (Seq-H) or a GOP header (GOP-H) may be further described before the picture header. The GOP header (GOP-H) is a header to identify a playback unit consisting of a plurality of pictures that begins with an I-picture (i.e., a group of pictures (GOP)). On the other hand, the sequence header (Seq-H) is a header to identify a playback unit including more than one GOPs (i.e., a sequence).
The frame 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
According to the bidirectional coding method adopted in the main profile of the MPEG-2 standard, video data is classifiable into data that can make one complete picture by itself (i.e., I-picture data) and data that cannot make one complete picture by itself but can make it by reference to the data of another picture (i.e., P-picture data or B-picture data).
More specifically, in some cases, all P- and B-pictures within a GOP may be arranged so as to refer to only I- or P-pictures within the same GOP (a GOP with such a data structure is called a “closed GOP”). In other cases, some of the B-pictures belonging to a GOP may refer to I- or P-pictures within its previous GOP (a GOP with such a data structure is called an “open GOP”).
The arrangement and presentation order of picture data are also defined in various manners. Hereinafter, exemplary data arrangement and presentation order of respective pictures to achieve the presentation order of the latter GOP (i.e., open GOP) will be described with reference to portions (a) and (b) of
Portion (a) of
As can be seen from portions (a) and (b) of
In portion (a) of
Also, the P-picture 57 is encoded based on the difference from the last I-picture 54. The P-picture 58 is encoded based on the difference from the last P-picture 57. In decoding the P-picture 58, the picture data of the P-picture 57, which is its reference picture, is needed.
Hereinafter, the configuration and operation of a player according to this preferred embodiment will be described with reference to
The player acquires the TS packets, carries out system decoding on the acquired TS packets down to the ES 42 (see portion (c) of
Under the control of the microcontroller 63, the player 100 can play back a content such as video or audio while acquiring TS, including content data representing that content, from the hard disk 61. In the following description, just a single TS is supposed to be stored on the hard disk 61 and a method of playing back some range of the TS and then another discontinuous range thereof will be described as an example. This situation is typically encountered when the user made a play list to specify arbitrary playback ranges and paths for a single data stream. Those playback ranges form respective portions of a single TS, strictly speaking, but may be treated as separate TS (which will be referred to herein as “TS-A” and “TS-B”), too.
Hereinafter, the function of this player 100 will be outlined. Specifically, the reading section 62 of the player 100 acquires TS-A and then TS-B from the hard disk 61. Next, the reading section 62 makes a dummy packet, having a dummy identifier that is different from any of the packet identifiers (PIDs) of the respective TS, and inserts it between the last packet of the TS-A and the first packet of the TS-B. The stream splitting section 64 splits the content data into video and audio elementary data by sorting the packets into respective types according to the packet identifiers (PIDS). Also, upon the detection of the dummy identifier, the stream splitting section 64 inserts error data, which is different from the content data. The decoders 66 and 70 play back the content data on the basis of a playback unit. On detecting the error data, the decoders 66 and 70 discard incomplete content data at the end of the TS-A and a portion of the content data of the TS-B up to the first header thereof and never play back those data. In this manner, the boundary point between the two data streams (i.e., TS-A and TS-B) can be conveyed to the decoders 66 and 70, just as intended.
The respective components of the player 100 may function as follows. It should be noted that these components operate in accordance with the instruction given by the microcontroller 63.
The reading section 62 includes a magnetic head, a signal equalizer, an error corrector (none of which is shown) as its hardware components. The reading section 62 includes a stream extracting section 62a and a dummy packet inserting section 62b. The stream extracting section 62a receives a specified address on the hard disk 61 from the microcontroller 3 and reads out data from that address. Thereafter, the stream extracting section 62a makes an error correction on that data, thereby obtaining TS (including TS-A, TS-B and so on).
The dummy packet inserting section 62b makes a dummy packet, having a dummy identifier that is different from the packet identifier (PID) of a video TS packet or an audio TS packet, and inserts the dummy packet between the TS-A and the TS-B.
Hereinafter, the dummy packet will be described with reference to
In the packet header 72a, an identifier (PID) to identify the dummy packet 72 from the other packets is described. This identifier (PID) may be 0x1FFF, for example, which is different from the identifier (PID) of the video or audio TS packet described above. Dummy data, which is a data sequence with a predetermined pattern, is stored in the payload 72b. The dummy data is not a significant data sequence and is not supposed to be played back, either. Accordingly, a NULL packet, which is ordinarily used just for stuffing purposes, may be used as the dummy packet, and the PID of the NULL packet and a particular pattern that follows the PID may be included as the dummy packet.
However, if the dummy packet 72 is inserted between the last packet 75 of the TS-A and the first packet 77 of the TS-B, then the following problem arises. Specifically, as is clear from the illustration in portions (a) through (d) of
In the same way, if the video TS packet of the TS-B, which follows the dummy packet 72 inserted, were one of N video TS packets of the TS-B being transmitted, then a portion of the frame data included in the video TS packets that have already been transmitted could not be acquired and non-playable, either. In the lower portion of
Also, the TS packets have a fixed data length of 188 bytes. Accordingly, if the data required for playing back a single frame were distributed in N video TS packets, then one of the beginning and end of that frame may not match the boundary of the first TS packet or that of the Nth TS packet. For example, even if the last TS packet of the TS-A, which is just before the dummy packet 72 inserted, is the Nth TS packet, a portion of succeeding picture data (such as the I-picture data 76b in the ES shown in
If such non-playable frame data were subjected to playback processing, then the frame picture presented would be disturbed or a decoding error might occur.
Thus, to avoid such a problem, the stream splitting section 64 and video decoder 66 perform processing that is designed so as not to play back the incompletely acquired frame data by mistake.
Hereinafter, the configuration and function of the stream splitting section 64 will be described with reference to
The PID detecting section 81 receives a series of data streams, consisting of the TS-A, the dummy packet 72 and the TS-B as shown in the upper portion of
Next, when the dummy PID is detected, the dummy packet detecting section 82 analyzes the payload of that packet, thereby determining whether or not particular dummy data is present in that payload and whether or not that packet is the dummy packet 72. In this manner, the dummy packet 72 can be detected just as intended. Optionally, no matter whether the dummy PID has been detected or not, the dummy packet detecting section 82 may detect the dummy data. Such processing is particularly effective in a situation where the dummy packet cannot be detected just by the identifier (PID). If the dummy data is present there, the dummy packet detecting section 82 senses having detected the dummy packet 72. The detection of the dummy data 72 shows that the data stream is discontinuous at that packet location. When notified of the detection of the dummy packet 72 by the dummy packet detecting section 82, the microcontroller 63 can sense that the TS-A is switched into the TS-B at that packet location.
Based on the data stored in the payloads of the video, audio and other TS packets, the TS/PES decoder 83 carries out system decoding down to the level of elementary streams and outputs the resultant data. However, the dummy data stored in the dummy packet 72 is not significant data and is not supposed to be played back as mentioned above. That is why the dummy data is output as it is without being decoded.
Next, it will be described how the TS/PES decoder 83 performs its processing on the video shown in portions (a) through (c) of
It should be noted that the processed data output by the TS/PES decoder 83 does not have to be the elementary stream 42 shown in portion (c) of
In accordance with the instruction given by the microcontroller 63, which has been notified of the detection of the identifiers (PIDs) by the PID detecting section 81, the switch 84a turns data transmission paths. Specifically, if the identifier (PID) of the TS packet being processed shows that packet is a video TS packet, then the switch 84a selects a path that passes the data to the switch 84a. On the other hand, if the PID shows that packet is an audio TS packet, then the switch 84a takes a path that passes the data to a terminal 86b. The terminal 86b is connected to the audio data memory section 69. The data is stored as an audio elementary stream on the audio data memory section 69.
The switch 84b also turns data transmission paths in accordance with the instruction given by the microcontroller 63. The switch 84b normally selects a path that passes the elementary data, which has been transmitted from the TS/PES decoder 83 by way of the switch 84a, to a terminal 86a. However, if the dummy packet detecting section 82 has detected the dummy packet, then the switch 84b takes a path that passes the data from the error data generating section 85 to the terminal 86a as long as the dummy data is being input to the switch 84b. The terminal 86a is connected to the video data memory section 65. The data is stored as a video elementary stream on the video data memory section 65.
The error data generating section 85 inserts “0” data, which consists of zeros only and has a predetermined data length, and sequence error data (sequence_error), which has some particular value and another predetermined data length. For example, the data length of the “0” data may be equal to or greater than the maximum length of an possible variable length code (VLC) to be described later. When the switch 84b is turned thereto, the error data generating section 85 outputs the “0” data and the sequence error data in this order.
Next, the elementary stream (ES) obtained by the stream splitting section 64 will be described with reference to FIGS. 7 and 9. The lower portion of
Suppose the ES has been formed by being output from the stream splitting section 64 rightward (i.e., from left to right) in
The I-picture data 76b is arranged next to the various types of headers 76a. However, the I-picture data that has been stored in the video TS packet 75 is part of the data that makes up one complete I-picture, not all of that data. The header and picture data of an I-picture may be stored in 20 video TS packets, for example. Accordingly, it is quite imaginable that the TS-A is switched into the TS-B before the data that makes up a single I-picture is acquired fully.
In the range which follows the I-picture data 76b and in which the dummy packet 72 has been inserted, the “0” data 73 and the sequence error data 74 are now arranged. To sense the presence of the data 73 and/or the data 74 at a location means that the TS-A is switched into the TS-B at this particular location. The location where the data 73 and 74 are present will be referred to herein as a “stream connection point” for convenience sake.
The sequence error data 74 at the stream connection point is followed by incomplete picture data 78 that forms a part of the TS-B. This B-picture data 78 does not always include the picture header of a B-picture. The reason is that since the TS-A may be switched into the TS-B at an arbitrary location thereof, a packet storing only the elementary data may be present.
In the example shown in
The partial I-picture data 76b and partial B-picture data as indicated by the hatching in
Next, the data structure at the stream connection point will be described in detail with reference to
After the variable length code VLC 93, arranged are the “0” data 73 and the sequence error data 74. In
Next, the B-picture data 78 of the TS-B is arranged. The top variable length code VLC 94 never functions as a variable length code actually. This is because the variable length code VKC 94 is only a portion of the variable length code and is non-decodable. The data that should have been present before the variable length code VLC 94 has already been transmitted before the TS-A is switched into this TS-B, and is no longer included in this stream. The variable length code VLC 94 is followed by variable length codes VLC-B2, B3 and B4, which are decodable independently.
The “0” data 73 and the sequence error data 74 are provided for the following reasons. Firstly, were it not for the “0” data 73 and the sequence error data 74, the variable length codes VLC 93 and VLC 94 would be combined together to form continuous data. Then, the combined data could be detected as a single variable length code VLC erroneously and the video decoder 66 as the next stage would cause a decoding error. That is why the sequence error data 74 is provided. The sequence error data 74 may be 0x00001b4, for example. Whenever this data is detected, it means that an error has been detected.
Suppose only the sequence error data 74 is provided with no “0” data 73 included. In some cases, the stream connection point could be located by the sequence error data 74 only. Without the “0” data 73, however, the previous variable length code VLC 93 and the sequence error data 94 would be combined together and might be detected as a single variable length code VLC erroneously. In other words, the sequence error data 74 could not be recognized properly. That is why the “0” data 73 is provided to avoid such an erroneous recognition. Nevertheless, it is also necessary to prevent a similar erroneous recognition from occurring when the variable length code VLC-I3 and the “0” data 73 are combined together. For that purpose, the data length of the “0” data 73 is defined equal to or greater than the maximum length of the possible variable length codes VLC. On receiving the “0” data 73, the video decoder 66 can sense that this is a non-existent variable length code.
By providing the “0” data 73 and the sequence error data 74, the video decoder 66 that follows can detect either a VLC error, caused by combining the variable length code VLC-I3 and the “0” data 73, or an error resulting from the sequence error data 74, at the stream connection point. Also, the video decoder 66 can find the connection point properly.
Next, the processing done by the video decoder 66 (see
The start code detecting section 101 receives a video ES through a video ES input terminal and detects the start code of a sequence header, a GOP header or an I-picture header, for example. Every start code begins with a 24-bit pattern of 0x000001. Accordingly, the start code detecting section 101 recognizes any of these various types of headers by the data that follows, and then decodes the information of the header detected. Also, the start code detecting section 101 is notified of the occurrence of a decoding error by the microcontroller 63. In response to this notice, the start code detecting section 101 searches for a sequence header, a GOP header and/or an I-picture header. On detecting the start code of at least one of these headers, the start code detecting section 101 notifies the microcontroller 63 of the detection of the start code.
The VLC decoding section 102 decodes the VLC data, thereby obtaining macroblock data. In an MPEG image compression method, data is encoded with VLC data to increase the data efficiency. In encoding the data, a decodable variable length code VLC is predefined. When receiving data with a non-defined pattern, the VLC decoding section 102 notifies the microcontroller 63 of the occurrence of a decoding error. The “0” data 73 and the sequence error data 74 described above are examples of such a “non-defined pattern”. The macroblock data is then subjected to inverse quantization processing by the inverse quantizing section 103, IDCT processing by the IDCT section 104, and motion compensation processing with a motion vector by the motion compensating section 105, respectively. Frame data is obtained as a result of these types of processing. The frame data is either stored in the frame data memory section 67 or output as it is through the output terminal if the frame data is I-picture data that needs no other picture data to refer to. The inverse quantization processing, IDCT processing and motion compensation processing are all well-known processes in the art, and detailed description thereof will be omitted herein.
Hereinafter, the processing done by the microcontroller 63 in connection with the start code detecting section 101 and the VLC decoding section 102 will be described. On receiving the notice that a decoding error has occurred, the microcontroller 63 discards the data from the previous picture header on such that the picture will not be presented. If the picture is an I-picture, the microcontroller 63 discards the data that follows its sequence header, i.e., incomplete content data at the end of the data stream. This data includes the picture data that has been decoded until then. Also, once received this notice, the microcontroller 63 will also discard the next data received until the start code detecting section 101 detects the next start code.
For example, in processing the data stream shown in
This example is shown on the supposition that the B-picture is made by reference to the data of an I-picture, for example, which has already been transmitted before the B-picture data and which belongs to the same GOP. In an “open GOP”, however, even a fully transmitted B-picture also has data to be discarded. For instance, if the GOP header arranged just before the I-picture data 79b (see
Hereinafter, it will be described with reference to
First, the normal stream playback process will be described. In Step S110, the stream extracting section 62a reads out Stream A (i.e., TS-A). Next, in Step S111, the microcontroller 63 determines whether or not it has received a request to play back Stream B, which is different from Stream A. In the normal playback process, the microcontroller 63 confirms the receipt of no such requests and the process advances to the next step S113, in which the dummy packet detecting section 82 determines whether or not it has detected any dummy packet. In this case, since there are no dummy packets, the process advances to the next step S114, in which the stream splitting section 64 generates video elementary data and stores its as a video elementary stream in the video data memory section 65. Next, in Step S115, the video decoder 66 decodes and plays back the video elementary stream. Thereafter, the process goes back to Step S110 again.
Next, a stream playback process with stream switching will be described. If the microcontroller 63 has confirmed the receipt of a request to play back Stream B, which is different from Stream A, in Step S111, then the process advances to Step S112, in which the dummy packet inserting section 62b makes a dummy packet and adds it to the end of Stream A. Thereafter, the stream extracting section 62a reads out Stream B and the process advances to the next step S113. Since the dummy packet detecting section 82 detects a dummy packet in Step S113, the process advances to Step S116, in which the TS/PES decoder 83 generates a video elementary stream for Stream A. Then, the error data generating section 85 inserts the “0” data and the sequence error data to the end of the video elementary stream. That data is stored in the video data memory section 65 and then read out by the video decoder 66.
Next, in Step S117, the VLC decoding section 102 determines whether or not it has detected any VLC error. If the answer is NO, the process advances to Step S118. On the other hand, if the answer is YES, the process advances to Step S119. In Step S118, the VLC decoding section 102 determines whether or not it has detected sequence error data. If the answer is YES, the process advances to Step S119. Otherwise, the process jumps to Step S120. By making these decisions a number of times in Steps S117 and S118, the connection point can be detected just as intended.
In Step S119, the microcontroller 63 discards the incomplete data, if any, at the end of Stream A and/or at the beginning of Stream B. As a result, only decodable data of Stream B will be processed after that.
In the next step S120, the stream splitting section 64 generates a video elementary stream for Stream B, and the video decoder 66 decodes and plays back that video elementary stream.
According to this processing procedure, even if one stream has been switched into another, the playback can be continued with the occurrence of decoding errors avoided by locating the connection point accurately and with the disturbance on the screen minimized.
In the preferred embodiment described above, only one TS is supposed to be stored on the hard disk 61 and includes the two ranges of TS-A and TS-B. However, the present invention is applicable in quite the same way to even a situation where a plurality of TS are stored on the hard disk 61 and need to be played back continuously. That is to say, the TS-A and TS-B described above may be two independent data streams. Also, if the TS-A is regarded as a portion of one independent data stream and the TS-B a portion of another independent data stream, then the present invention is also applicable in quite the same way to even a situation where a plurality of TS are stored on the hard disk 61 and respective portions of those TS need to be played back continuously.
Also, in the preferred embodiment described above, the presentation of the TS-B is supposed to start with an I-picture. However, the presentation may also start with any picture other than the I-picture. For example, if the presentation starts with the P-picture 57 shown in
Also, in the preferred embodiment described above, as to a transport stream that has been compressed so as to comply an MPEG standard, dummy packets and sequence error data, compliant with that standard, have been described with their specific values given. However, the present invention is in no way limited to those specific values but any other values may be used as well. Optionally, even a data stream compliant with any other standard may be adopted, too. In that case, the error code and other codes of that standard may be used as the sequence error data value and other values.
Furthermore, the data stream does not have to be stored on a storage medium. The present invention is also applicable to even a situation where a digital broadcast using TS is being received in real time, for example. In that case, the dummy packet may be inserted where the channels of the digital broadcasting are switched.
The playback function of the data processor may be carried out on a computer program that defines the processing procedure shown in
The present invention provides a data processor, which can play back a number of data streams continuously, even when one of them has to be switched into another, with the occurrence of decoding errors avoided by detecting their connection point accurately and with the disturbance on the screen minimized.
Number | Date | Country | Kind |
---|---|---|---|
2003-118249 | Apr 2003 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP04/05831 | 4/22/2004 | WO | 10/14/2005 |