WO2002019690A2 - Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode - Google Patents

Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode Download PDF

Info

Publication number
WO2002019690A2
WO2002019690A2 PCT/US2001/027411 US0127411W WO0219690A2 WO 2002019690 A2 WO2002019690 A2 WO 2002019690A2 US 0127411 W US0127411 W US 0127411W WO 0219690 A2 WO0219690 A2 WO 0219690A2
Authority
WO
WIPO (PCT)
Prior art keywords
frame
data structure
video stream
intra
coded reference
Prior art date
Application number
PCT/US2001/027411
Other languages
French (fr)
Other versions
WO2002019690A3 (en
Inventor
William B. Boyle
Original Assignee
Keen Personal Media, Inc.
Keen Personal Technologies, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Keen Personal Media, Inc., Keen Personal Technologies, Inc. filed Critical Keen Personal Media, Inc.
Priority to AU2001288693A priority Critical patent/AU2001288693A1/en
Publication of WO2002019690A2 publication Critical patent/WO2002019690A2/en
Publication of WO2002019690A3 publication Critical patent/WO2002019690A3/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/76Television signal recording
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B20/00Signal processing not specific to the method of recording or reproducing; Circuits therefor
    • G11B20/10Digital recording or reproducing
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/10Indexing; Addressing; Timing or synchronising; Measuring tape travel
    • G11B27/102Programmed access in sequence to addressed parts of tracks of operating record carriers
    • G11B27/105Programmed access in sequence to addressed parts of tracks of operating record carriers of operating discs
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/10Indexing; Addressing; Timing or synchronising; Measuring tape travel
    • G11B27/19Indexing; Addressing; Timing or synchronising; Measuring tape travel by using information detectable on the record carrier
    • G11B27/28Indexing; Addressing; Timing or synchronising; Measuring tape travel by using information detectable on the record carrier by using information signals recorded by the same method as the main recording
    • G11B27/32Indexing; Addressing; Timing or synchronising; Measuring tape travel by using information detectable on the record carrier by using information signals recorded by the same method as the main recording on separate auxiliary tracks of the same or an auxiliary record carrier
    • G11B27/327Table of contents
    • G11B27/329Table of contents on a disc [VTOC]
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B2220/00Record carriers by type
    • G11B2220/20Disc-shaped record carriers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/76Television signal recording
    • H04N5/78Television signal recording using magnetic recording
    • H04N5/782Television signal recording using magnetic recording on tape
    • H04N5/783Adaptations for reproducing at a rate different from the recording rate

Definitions

  • This invention relates to the field of encoding and storing moving pictures and audio signals and, in particular, a system for digitally encoding, storing, and displaying a video stream in MPEG format on a personal video recorder (PVR) hard drive in a manner that facilitates play modes other than standard speed, sequential play.
  • PVR personal video recorder
  • PVRs Personal Video Recorders
  • DVRs Digital Video Recorders
  • PVRs enable a viewer to record defined categories of live television programming over the course of days. The viewer may stipulate that they want to record a series of tennis matches, all nature shows, or all episodes of a particular show over the course of a season.
  • PVRs also enable a person viewing a "live" television broadcast to pause viewing and, at a later time, resume viewing the broadcast from the point at which live viewing was paused.
  • a viewer also has the option to skip portions of a broadcast, such as for example commercials, upon reviewing a broadcast by employing a PVR.
  • the recording features of PVRs can be performed when the viewer is away from the PVR so that the viewer can view preferred programs at a time that is convenient.
  • PVRs can receive either a streaming analog signal in an uncompressed format or a digitally encoded signal, such as an MPEG signal, from a transmission source. If the PVR receives an analog signal such as a television signal in an uncompressed format, the PVR typically digitally encodes the signal, stores the digitally encoded signal in a compressed format, and decodes and presents the signal for subsequent viewing. Similarly, if the PVR receives an already digitally encoded signal, the PVR then stores the signal and decodes and presents the signal for subsequent viewing. PVRs currently typically include 13.6-gigabyte hard disks that offer up to 14 hours of video programming or 27.2-gigabyte disks that offer up to 30 hours of programmable viewing.
  • MPEG is a standard for digitally encoding moving pictures and interleaved audio signals. MPEG facilitates compressing a video stream to reduce the storage capacity and transmission bandwidth required for an MPEG stream as compared to an uncompressed video stream.
  • adjacent individual video frames will have much in common with the preceding and subsequent frames. For example, from one individual still frame of a scene to the next, much of the background, the colors, and the luminous intensity will usually remain the same. A relatively small amount of the overall scene will typically change from frame to frame.
  • the compression technique used with MPEG leverages this redundancy of video in both the spatial and temporal dimensions in order to define certain frames with respect to other frames in a dependent or anticipatory manner and thereby reduce the amount of information required to accurately define a video stream.
  • I frames Intra-coded reference frames (I), Predictive-coded frames (P), and Bi-directionally predictive-coded frames (B).
  • I frames contain all of the information required for a single video frame and are thus independent frames that need no information from other frames either before or after for decoding.
  • P frames are defined with respect to preceding I frames or other P frames.
  • B frames are bi-directionally defined with respect to both preceding and subsequent frames in the MPEG stream.
  • both P and B frames need information from surrounding frames for decoding; a P or B frame by itself cannot be decoded into a viewable image.
  • P-, and B- frames are organized into at least one sequence defined by a sequence header and a set of subsequent I, P, and B frames.
  • the sequence header contains display initialization information defining picture size and aspect ratio, frames and bit rate, decoder buffer size, and chroma pixel structure and may contain optional quantizer matrices and/or user data.
  • digital video compression schemes such as MPEG
  • viewers of video images like to be able to use TrickPlay modes of viewing including by way of example: fast forward, reverse play, skip ahead, skip back, etc.
  • compressed video streams that have inter-frame dependencies such as MPEG streams, are not readily suited to random access of different frames within the stream as is often required for TrickPlay modes of viewing.
  • the compressed video streams are pre-recorded onto high-density recording media in a manner that facilitates TrickPlay.
  • One example of this is disclosed in
  • Video signals are typically provided to PVRs as either uncompressed analog signals or digitally compressed signals such as the signals received via cable or satellite television systems. While some streaming systems have been disclosed that provide video streams with redundant streams to facilitate TrickPlay (See, e.g., U.S. Patent No. 6,065,050 to De Money), many video streams are provided as analog signals or simple MPEG files that do not have any pre-recorded files or formats for facilitating TrickPlay.
  • the invention comprises a digital video recording system for storing, retrieving and displaying compressed digital video data.
  • the system comprises a video stream buffer system that receives a stream of digital video data comprising intra-coded reference frames and predictive coded reference frames.
  • the system also comprises a storage subsystem and a storage controller that stores the stream of digital video data into the storage subsystem.
  • the storage controller identifies a start of the intra-coded reference frames and generates an index data structure in the storage subsystem that provides data indicative of the location of at least some of the intra-coded reference frames stored in the storage subsystem.
  • the system also includes a display controller that accesses the index data structure and the video stream in the storage subsystem to display the video stream in a TrickPlay mode.
  • the storage subsystem is integrated into the system such that the storage subsystem is simultaneously logically coupled to both the storage controller and the display controller.
  • the storage controller also identifies the start of the predictive coded reference frames and further generates the index data structure so that the index data structure provides data indicative of the location of at least some of the predictive coded reference frames stored in the storage subsystem. Also, in one embodiment, the storage controller further stores in the index data structure data corresponding to the extent of each frame.
  • a method of storing, retrieving and displaying compressed digital video data using a personal video recording having an integrated memory storage subsystem and a display comprises receiving a video stream comprising intra- coded reference frames and predictive-coded reference frames and identifying the intra-coded reference frames upon receipt of the video stream.
  • the method further comprises generating an index data structure from the identified intra-coded reference frames and storing the index data structure in the integrated storage subsystem of the personal video recorder.
  • the method further comprises using the index data structure in the integrated storage subsystem of the personal video recorder to cause delivery of selected frames of the stored video stream to the display of the personal video recorder to thereby display the video stream in a TrickPlay mode.
  • generating the index data structure further comprises storing an extent value indicative of the extent of the data corresponding to the intra-coded reference frames.
  • the present invention comprises a system for storing, retrieving and displaying digital video data.
  • the system comprises a video stream buffer system that receives a stream of digital video data comprising sequence header data, intra-coded reference frames and predictive-coded reference frames and a storage system.
  • the system also includes a storage controller that stores the stream of digital video data into the storage system, wherein the storage controller generates an index data structure in the storage system as the stream of digital video data is being stored in the storage system, and wherein the index data structure includes data indicative of the location where the intra- coded reference frames are stored in the storage system and the extent of the intra-coded reference frames.
  • the system also includes a display controller that accesses the index data structure and the video stream stored in the storage system to display the video stream in a TrickPlay mode, wherein the display controller uses the extend of the frame to limit access of a selected frame to only the data corresponding to the selected frame to thereby more efficiently access the selected frame and wherein the storage system is integrated into the system such that the storage system is simultaneously logically coupled to both the storage controller and the display controller.
  • Figure 1 is a block diagram illustrating a digital video storage and display system of the preferred embodiment
  • Figure 2 is a block diagram illustrating the video stream buffer system of the digital video storage and display system of Figure 1;
  • Figure 3 is a table illustrating the logical structure of the MPEG frame header information that is received by the digital video storage and display system of Figure 1;
  • Figure 4 is a block diagram illustrating the components and operation of the programmable start code detector of the video stream storage subsystem of Figure 2;
  • Figure 5 is a flow chart illustrating the creation of a frame index data structure by the system of Figure 1 as the digital video data stream is being stored in the video stream storage subsystem of Figure 1;
  • Figure 6 is a diagram which illustrate the data structures of the digital video stream and the frame index data structure as it is stored in the storage subsystem of the system of Figure 1;
  • Figure 7 is a flow chart illustrating the operation of the digital video storage and display system of Figure 1 as the stored data is retrieved and displayed in either a normal or
  • FIG. 1 is a block diagram illustrating the basic logical and physical components of a digital video storage and display system 100 of the preferred embodiment.
  • the system 100 receives a video stream 102.
  • the video stream 102 provides compressed digital video data to the system 100 via any of a number of known interfaces and sources, such as cable or satellite television networks or the Internet.
  • the video stream 102 is already digitally encoded in the MPEG format.
  • the video stream 102 is initially provided as an analog signal and is digitized and encoded in MPEG format by an MPEG encoder of a type well known in the art prior to reception by the digital video storage and display system 100.
  • the system 100 is suitable for implementation on a
  • the system 100 is capable of receiving the video stream 102 comprising compressed digital frames corresponding to visual frames via a communications network, such as a cable or satellite television network.
  • the video stream 102 preferably comprises a series of digital frames that include intra-coded reference frames which contain sufficient data to allow for reproduction of the image embodied in the frame without requiring data from other frames.
  • the video stream 102 also includes predictive-coded reference frames, which contain digital data but require data from other frames to permit reproduction of the image embodied in the predictive-coded frame, and sequence header data to define the display formatting information for the stream.
  • the MPEG video stream 102 uses a known standard for encoding video and audio signals so as to facilitate compression.
  • the MPEG video stream 102 comprises a plurality of I-frames 103, P-frames 105, and B-frames 107 ( Figure 3) sequentially arranged in a well- known manner.
  • the I-frames 103 are known intra-coded reference independent frames.
  • the P-frames 105 are known predictive-coded reference frames that depend upon preceding I- frames 103 or other P-frames 105.
  • the B-frames 107 are known bi-directionally dependent frames that reference preceding and subsequent frames in the MPEG stream 102.
  • the structures of the I-frames 103, P-frames 105, and B-frames 107 are well known, but will be described in greater detail below in reference to the table of Figure 3.
  • the MPEG video stream 102 is organized into at least one sequence 400 indicated by a sequence header 402 ( Figure 6).
  • the sequence 400 begins with the sequence header 402 followed by a plurality of frames 103, 105, and 107.
  • the sequence header 402 is identified by a unique sequence header start code 403 of 00 00 01 B3 (hex) and comprises subsequent sequence header 402 information pertaining to the horizontal and vertical size of the pictures, aspect ratio information, and the frame and bit rate codes.
  • the sequence header 402 provides the initial formatting information to a video stream decoder 116 required to initiate display of the MPEG video stream 102 and to change channels to thereby enable the video stream decoder 116 to properly display the MPEG stream 102.
  • the system 100 is functionally depicted in Figure 1, and it will be appreciated that the logical blocks of Figure 1 comprise functional blocks that can be implemented in hardware, software, or in both. Moreover, it will be appreciated that the exact implementation of the logical blocks of the digital video storage and display system 100 as illustrated in Figure 1 can be implemented in any of a number of well-known manners.
  • the digital video storage and display system 100 includes a video stream buffer system 104 that receives the video stream 102 via an interface.
  • the video stream buffer system 104 buffers the incoming digital video stream 102 and provides the video stream 102 to a storage subsystem 110 such that the video stream 102 can be stored in a video stream data structure 112.
  • the video stream buffer system 104 also determines the start of sequence headers 402 and the start of each frame 103, 105, 107 and provides a start detected signal 118 indicative thereof to a storage controller 106 to allow the storage controller 106 to develop a frame index data structure 114 in the storage subsystem 110 in a manner that will be described in greater detail below.
  • the storage controller 106 develops an index of the logical memory address of the start of the frames 103, 105, 107 within the video stream 102 to permit subsequent display of
  • the index developed by the storage controller 106 contains the locations of the I-frames 103 only.
  • the frame index data structure 114 comprises an index of the locations of all of the frames 103, 105, 107 of the MPEG video stream 102.
  • the digital video storage and retrieval system 100 also includes a storage subsystem 110 which, in this embodiment, preferably comprises a hard drive of a type known in the art.
  • Various data structures can be assembled in the storage subsystem 110 including the video stream data structure 112 and the frame index data structure 114. The configuration of these structures will be described below in reference to Figure 6.
  • the digital video storage and display system 100 includes an output section that includes a video stream decoder 116, a display controller 120, and a display 122.
  • the display controller 120 can either be implemented in software or in hardware, and it selects data from the video stream data structure 112 to be provided to the video stream decoder 116 such that the data can be decoded and provided to the display 122 to permit display of the stored video data.
  • the video stream data structure 112 includes the MPEG video stream 102 that is provided to the video stream decoder 116 and decoded according to well-known MPEG decoding protocols. The decoded images can then be provided to the display 122 such that the stored image can be displayed in a known manner, such as in the PAL or NTSC television formats.
  • the display controller 120 also has access to the frame index data structure 114 created by the storage controller 106 such that the display controller 120 can use the frame index data structure 114 to access particular frames 103, 105, 107 within the video stream data structure 112 so as to implement TrickPlay.
  • TrickPlay can include any of a number of techniques of displaying the video stream 102, including fast forward, reverse play, skip ahead and skip back.
  • One exemplary manner in which the display controller 120 implements TrickPlay on the video stream 102 stored in the video stream data structure 112 will be described below in reference to Figure 7.
  • the system 100 is capable of receiving a video stream 102, such as an MPEG stream or file, and storing this stream or file into the storage subsystem 110 such as a hard drive of a PVR.
  • the video stream 102 is stored along with the frame index data structure 114 that is created simultaneously with the storing of the video stream 102 such that the frame
  • the video stream buffer system 104 is illustrated in greater detail in conjunction with Figure 2.
  • the video stream buffer system 104 further includes a memory controller 124 that analyzes the incoming MPEG video stream 102 and controls writing to the storage subsystem 110. In response to a scan buffer input, the memory controller 124 writes video stream 102 data to the video stream data structure 112.
  • the video stream data structure 112 comprises a hard drive memory, and the memory controller 124 is writing the video stream 102 data to the sectors of the hard drive.
  • Each of the sectors of the hard drive has a corresponding logical block address (LB A) 130 that can be readily determined.
  • LB A logical block address
  • the system 100 can also optionally determine an offset 144 ( Figure 6) between the start of a particular sector of the hard drive and the actual place within the sector in which data from a frame 103, 105, 107 is recorded by determining the number of usable bytes between the start of a sector and the actual byte location at which the frame 103, 105, 107 begins.
  • the system 100 can also determine an extent 142 of the frame 103, 105, 107. Both the offset 144 and extent 142 can be subsequently used by the display controller 120 to improve the efficiency of decoding the stored MPEG video stream 102.
  • the MPEG video stream 102 is analyzed by a programmable start code detector 126.
  • the programmable start code detector 126 of this embodiment is a hardware comparator circuit that is adapted to identify start codes for frames 103, 105, 107 and the sequence header 402.
  • the system 100 will store in the frame index data structure 114 an indication of the start of particular frames 103, 105, 107 of the MPEG video stream 102.
  • the system 100 will also store the sequence header 402 information as to how the frames 103, 105, 107 are to be displayed. In order to store both of these types of information, the start codes of the sequence header 402 and the frames 103, 105, 107 must be
  • the start code detector 126 is programmable such that it can be used to detect either the start of the sequence header 402 or the start of individual frames 103, 105, 107 of the video stream 102.
  • a start detected signal 118 is provided to the storage controller 106, and the storage controller 106 can then determine whether the frame 103, 105, 107 comprises a frame 103, 105, 107 for which an index marker should be stored in the frame index data structure 114 to facilitate subsequent use for TrickPlay display of the stored video stream 102.
  • the memory controller 124 controls the storage of the video stream 102 data into the video stream data structure 112 and sequentially provides the data comprising the MPEG video stream 102 to the storage subsystem 110 and the programmable start code detector 126 so as to permit identification of the beginning of picture frames 103, 105, 107.
  • the MPEG video stream 102 includes a header 132 for each frame 103, 105 and 107 as shown in Figure 3.
  • the header 132 comprises a picture start code 135, a temporal reference 136 and a picture coding type 140.
  • the picture start code 135 is a unique 32-bit word that identifies the start of the frame 103, 105 or 107.
  • the picture start code 135 of this embodiment for the start of each frame 103, 105, or 107 is 0x00000100 where "Ox" indicates that the subsequent digits are presented in a hexadecimal format.
  • the temporal reference 136 is a 10-bit code providing temporal information for the following frames 103, 105 or 107 and, in this embodiment, is a "don't care" value.
  • the picture coding type 140 is a 3-bit code for the type of frame 103, 105, or 107 to follow. A picture coding type 140 of "001" indicates that an I-frame 103 is to follow, a "010” indicates that a P-frame 105 is to follow, and a "011" indicates a B-frame 107 is to follow.
  • the MPEG video stream 102 includes compressed image and interleaved audio signal data appropriate to the particular frame 103, 105, 107 encoded in a well-known manner.
  • the video stream buffer system 104 sequentially receives data that indicates both the start of a particular frame 103, 105, 107 and that also indicates the type of frame 103, 105, 107.
  • This information is provided to the programmable start code detector 126 which provides the start detected signal 118 to the storage controller 106 indicative of the start of a frame 103, 105, 107.
  • the frame-type information as
  • the storage controller 106 is also provided to the storage controller 106 such that the storage controller 106 can determine the particular start of the frame 103, 105, 107 and also the type of the frame 103, 105, 107.
  • Figure 4 illustrates one embodiment of the programmable start code detector 126 which, in this embodiment, includes a 32-bit hardware comparator 602 and a programmable start code register 134.
  • the incoming MPEG stream 102 is sequentially provided to the comparator 602 and the digital data contained therein is first compared to a programmed sequence header start code 403 contained within the start code register 134.
  • the detection of the sequence header start code 403 in the incoming MPEG stream 102 sends the start detected 118 interrupt to a memory address latch 606 to cause the memory address latch 606 to store a corresponding buffer memory address 127 of the start of the sequence header 402 in the storage subsystem 110 so that the corresponding LBA 130 can be determined and stored in the storage subsystem 110 in a manner that will be described in greater detail below.
  • the system 100 then reprograms the start code register 134 of the programmable start code detector 126 with the picture start code 135 of 0x00000100.
  • the comparator 602 When the incoming MPEG stream 102 matches the picture start code 135 contained within the start code register 134 for the start of a particular frame 103, 105, 107, the comparator 602 outputs the start detected 118 signal to the storage controller 106 indicating that the start of a frame 103, 105, 107 has been detected. In this embodiment, the detection of a picture start code 135 in the incoming MPEG stream 102 sends the start detected interrupt
  • the start detected 118 signal also causes a frame type latch 604 to latch the 3 -bit picture coding type 140 so that the corresponding LBA 130 and the frame type 103, 105, 107 can be stored in the frame index data structure 114 in the manner that will be described in greater detail hereinbelow.
  • start codes 135, 403 are detected with the dedicated hardware comparator 602 instead of using software to facilitate a more rapid identification of the sequence header 402 and the start of a frame 103, 105, 107 in the MPEG video stream 102. It will be appreciated that the hardware comparator 602 of the programmable start code detector
  • -11- 126 can further be implemented to evaluate the bits indicating the picture coding type 140 to determine whether the frame is an I-frame 103, a P-frame 105, or a B-frame 107.
  • the storage controller 106 and the memory controller 124 can determine the logical block address (LBA) 130 of the frames 103, 105, 107 being stored in the video stream data structure 112 such that these LB As 130 can be stored in the frame index data structure 114 in the manner that will be described in greater detail below.
  • LBA logical block address
  • Figure 5 illustrates the process by which the video stream buffer system 104 and the storage controller 106 store the video stream 102 in the video stream data structure 112 and produce the frame index data structure 114.
  • the programmable start code detector 126 is first programmed to detect the sequence header start code 403 in state 252.
  • the system 100 then in state 254 detects a sequence header 402, saves the corresponding buffer memory address 127, and interrupts the software in the manner previously described.
  • the software then reads the buffer memory address 127 in state 256 and derives the LBA 130 for the start of the sequence header 402 in state 260.
  • the start location LBA 130 of the sequence header 402 as stored in the storage subsystem 110 is stored in the storage subsystem 110 in state 262 so as to be associated with the video stream data structure 112.
  • the start code register 134 of the programmable start code detector 126 is reprogrammed in state 236 to detect the picture start code 135.
  • the programmable start code detector 126 in state 240 detects the picture start code 135, saves the buffer memory address
  • the software comprising the storage controller 106 then reads the frame type 140 information and the buffer memory address 127 in state 242 and derives the storage subsystem location for the start of the frame 103, 105, 107 in state 244.
  • the buffer memory address 127 is the address in the buffer 123 of the picture start code 135 as it is being stored in the video stream data structure 112 by the memory controller 124 ( Figure 4).
  • the storage controller 106 by knowing the buffer memory address 127 can thus determine the sector of the hard drive in which the picture start code 135 is being stored.
  • the sector is, in this embodiment, identified as a logical block address (LBA) 130.
  • LBA logical block address
  • the storage controller 106 periodically adds the LBA 130 of the start location of the frames 103, 105,107 to the frame index data structure 114 in the storage subsystem 110.
  • the video stream buffer system 104 and the storage controller 106 can both simultaneously store the video stream data structure 112 in the storage subsystem 110 and also generate the frame index data structure 114 indicative of the sectors on the hard drive where the frame 103, 105, 107 starts can be found.
  • the system 100 can also determine and store in state 248 an extent 142 of the frame 103, 105, 107.
  • the extent 142 in one embodiment, is the number of sectors of the storage subsystem 110 that the frame 103, 105, 107 at least partially occupies.
  • the extent 142 of the succeeding frames 103, 105, 107 can thus be determined as the starting LBAs 130 of each frame 103, 105, 107 are known as well as the ending LBA 130 of each frame 103, 105, 107 as the ending LBA 130 corresponds to the starting LBA 130 of the next sequential frame 103, 105, 107.
  • the system 100 can also optionally determine in state 248 an offset 144 between the start of the data corresponding to the frames 103, 105, 107 and the start of the sector corresponding to the LBA 130.
  • the offset 144 information can also be provided to the storage controller 106 such that the storage controller 106 can also store this offset 144 information in the frame index data structure 114 as is indicated in Figure 6.
  • the offset 144 information can be used to more efficiently access and decode the frames 103, 105,
  • the memory controller 124 is sequentially storing the data corresponding to each frame 103, 105, 107 in the video stream data structure 112
  • the programmable start code detector 126 is detecting the start of each frame 103, 105, 107
  • the extent 142 of each of the frames 103, 105, 107 can be determined as the byte length as opposed to the number of LBAs 130 occupied by the data of the frame 103, 105, 107.
  • the process of states 240 - 249 is repeated until it is determined in decision state 249 that each of the frames 103, 105, 107 has been stored in the video stream data structure 112 and the corresponding index marker has been generated in the index data structure 114.
  • the LBAs 130 of the start of each frame 103, 105, 107 can also be
  • the frame index data structure 114 comprises a series of entries that includes the LBAs 130 of the start of the frames 103, 105, 107 of the MPEG video stream 102 stored in the storage subsystem 110.
  • the storage subsystem 110 comprises a hard drive incorporating one or more magnetic disks.
  • the video stream data structure 112 includes a series of sectors identified by LBAs 130 corresponding to each of the frames 103, 105, 107, which provides logical addresses corresponding to the physical location of the digital data corresponding to the particular frame 103, 105, 107 as stored on the storage subsystem 110. The storage of this data onto the hard drive is accomplished in a manner that is known in the art.
  • the hard drive has a plurality of tracks that are divided into a plurality of sectors on the disk that are digitally encoded.
  • Each block stores approximately 512 bytes of information that can be accessed in a known manner provided the LBA 130 of the particular sector is known.
  • the data is sequentially written onto the tracks of the hard drive. Since an LBA 130 identifies a unique sector, the LBAs 130 can thus be used to access desired data such as the start of the sequence 400 or the frames 103, 105, 107.
  • the frame index data structure 114 includes a frame type field 131 that indicates the type of frame 103, 105, 107 for which the index data is stored.
  • the start locations of each of the frames 103, 105, 107 of the video stream is stored in the frame index data structure 114.
  • only the start locations of the I-frames 103 is stored in the frame index data structure 114.
  • the frame index data structure 114 includes the starting LBA 130 which is stored in a starting LBA field 130.
  • the extent 142 of the frame data is also stored in a frame extent field 142. As discussed above, the extent 142 can
  • the extent field 142 can thus be expressed as the number of LBAs 130, the LBA 130 in which the frame 103, 105, 107 data ends, which will typically correspond to the next subsequent starting LBA 130, or the byte length of the frame 103, 105, 107.
  • an optional sector offset data field 144 can also be included in the frame index data structure 114.
  • the sector offset data field 144 comprises the offset 144 in the starting sector between the start of the sector and the actual start of the data corresponding to the particular frame 103, 105, 107.
  • the extent 142 and the offset 144 are provided to the display controller 120 to improve the efficiency with which the digital video storage and display system 100 can access frames 103, 105, 107 within the video stream data structure 112.
  • the system 100 preferably creates the frame index data structure 114 that has the LBA 130, offset 144, and extent 142 corresponding to each of the frames 103, 105, 107. This information can then be used to more efficiently decode and display the frames 103, 105, 107 for TrickPlay implementations.
  • the storage subsystem also includes a data structure 403 which has a reference to the LBA 130 of the sequence header 402.
  • the sequence header 402 includes information which is needed by the display controller to be able to display the frames 103, 105, 107 of the video stream 102.
  • the sequence header 402 information is thus stored in the storage subsystem 110 in a location that is associated with the frame index data structure 114 such that the sequence header 402 in the hard drive can be more readily accessed.
  • Figure 7 is a flow chart that illustrates exemplary modes of operation of the display controller 120 as it displays the video stream 102 stored in the video stream data structure 112. It will be appreciated that the flow chart of Figure 7 illustrates one advantageous implementation and that other implementations may also be used.
  • the display controller 120 has access to the video stream data structure 112 such that the display controller 120 can provide the data contained therein to a video stream decoder 116.
  • the video stream decoder 116 decodes the video stream 102 information and provides the decoded information to the display 122 in a known manner.
  • the display controller 120 also has access to the frame index data structure 114 such
  • the display controller 120 can use this information to facilitate implementation of TrickPlay of the video stream 102 data contained within the video stream data structure 112.
  • the display controller 120 determines the mode of display of the video stream 102 in decision state 302. If the display controller 120 determines in the decision state 302 that the mode of display is normal play, the display controller 120 then determines, in a state 340, the LBA 130 of the start of the sequence header 402. Then, in a state 342, the display controller 120 retrieves the sequence header 402 from the storage subsystem 110 and sends the sequence header 402 to the video stream decoder 116. Then, in a state 304, the display controller 120 determines the LBA 130 of the start of the video stream 102 stored within the video stream data structure 112 in a known manner.
  • the data is retrieved from the corresponding memory location within the storage subsystem 110 and is provided to the video stream decoder 116.
  • the video stream decoder 116 then decodes and displays the initial frame 103 and subsequent frames 103, 105, 107 in state 310 according to the known decoding and display protocols of the MPEG standard.
  • the display controller 120 determines, in a decision state 312, whether the display of the video stream 102 is completed. It will be appreciated that the video stream 102 display is completed when either the entire sequence has been displayed or when the display controller 120 receives an interrupt signal from a user input in a well-known manner.
  • the display controller 120 in normal play mode repeats steps 306 - 310 for each of the frames 103, 105, 107 stored within the video stream data structure 112. In this manner, the video stream 102 can be displayed to a user in a known manner.
  • the display controller 120 determines, in the decision state 302, that a TrickPlay mode of operation has been selected, the display controller 120 then accesses the data in the frame index data structure 114 that is stored in the storage subsystem 110 as previously described. It will be appreciated that the display controller 120 may receive input signals from a user via an input, such as a keyboard or a graphical user interface (GUI), so as to identify when TrickPlay has been activated by the user. It will also be appreciated that the exact implementation of TrickPlay by the display controller 120 can comprise a number of different implementations of which only a skip implementation and a fast forward/reverse implementation are illustrated in Figure 7.
  • GUI graphical user interface
  • the display controller 120 determines in a state 320 that a skip TrickPlay has been implemented!, the display controller 120 then determines, in state 340, the LBA 130 of the start of the sequence header 402. Then, in state 342, the display controller 120 retrieves the sequence header 402 from the storage subsystem 110 and sends the sequence header 402 to the video stream decoder 116. The display controller 120 then determines the I- frame 103 that corresponds to the skip location selected by the user in a state 322. Basically, in skip play, the user can indicate the portion of the video stream 102 that the user would like to see displayed using an input device in a known manner. The display controller 120 then determines in state 322 the most adjacent I-frame 103 corresponding to the desired temporal location within the video stream 102.
  • the frame index data structure 114 provides the LBA 130 corresponding to the selected I-frame 103 corresponding to the desired skip location such that the I-frame 103 data can then be provided to the video stream decoder 116 and displayed from that point in a normal play mode in states 306-310 in the manner previously described.
  • the display controller 120 can display this I-frame 103 to the user as a still shot. Hence, the display controller 120 is able to determine an I-frame 103 which corresponds to a skip location that the user has selected and then initiate the decoding and the display of the video stream 102 stored in the video stream data structure 112 from that I-frame 103.
  • the index data structure 106 in one embodiment includes not only the LBA 130 at which the start of the frames 103, 105, 107 are located but also the offset 144 and the extent 142.
  • the decoding of the frames 103, 105, 107 by the display controller 120 and the video stream decoder 116 can thus be performed more efficiently.
  • knowing the offset 144 permits decoding of the data corresponding to the frames 103, 105, 107 to begin with the actual data as opposed to the data occurring at the beginning of the sector that corresponds to the LBA 130, but which may not be related to the frame 103, 105,
  • knowing the extent 142 of the frames 103, 105, 107 allows the display controller 120 to activate the video stream decoder 116 so as to decode only the data that correspond to the frames 103, 105, 107 that are being provided out of the video stream data structure 112. It will be appreciated that the data is being provided sequentially and the typical way of dete ⁇ nining the end of the frames 103, 105, 107 is to begin to decode the next frame 103, 105, 107 and identify the next 32-bit picture start code 135. By knowing the length of the
  • the display controller 120 can also implement a fast forward/reverse TrickPlay mode of display of the video stream 102 if the display controller 120 determines, in a decision state 330, that such a TrickPlay mode of display has been selected by the user. In this embodiment, the display controller 120 determines, in state 340, the LBA 130 of the start of the sequence header 402.
  • the display controller 120 retrieves the sequence header 402 from the storage subsystem 110 and sends the sequence header 402 to the video stream decoder 116. Then, in a state 332, the display controller 120 sequentially retrieves, the data corresponding to the indexed frames 103, 105, 107 1 through n, as listed in the frame index data structure 114 and decodes and displays each of these I-frames 103 in a state 334 until the fast forward is determined to be completed in decision state 336. In one embodiment, each of the I-frames 103 is decoded and displayed to the user in the same manner as described above, which results in a fast forward that is significantly faster than the normal decoding and display rate of the MPEG video stream 102.
  • the I-frames 103 alone may be displayed or, in an alternative embodiment, the I-frames 103 and selected following P-frames 105 may be displayed so as to provide more refined visual data to the user but will still result in faster display of the video data. It will be further appreciated that fast forward and fast reverse can be easily implemented by incrementing or decrementing a counter corresponding to the particular I-frame 103 that is to be retrieved from the video stream data structure 112 and decoded by the video stream decoder 116.
  • the start locations of the frames 103, 105, 107 can then be used to access particular frames 103, 105, 107 within the video stream 102.
  • the index frames are preferably the I-frames 103 which allow for TrickPlay, such as fast forward, fast reverse and skipping to a particular start location.
  • the system 100 allows for both storage and display of digital video data such as
  • the system 100 has an integrated storage subsystem 110 that is logically coupled to both the storage controller 106 and the display controller 120.
  • -18- storage controller 106 is capable of developing the frame index data structure 114 that is stored in the storage subsystem 110 that is accessible by the display controller 120 so as to allow the display controller 120 to implement more efficient flexible display of the stored video stream 102.
  • the TrickPlay modes of display described here illustrate several of the different types of TrickPlay displays that can be implemented using the frame index data structure 114 and should not be viewed as limiting the implementation of this invention.
  • the preferred embodiment can thus be implemented on existing personal video recorders (PVRs) allowing for TrickPlay display of streaming video by causing the PVR to develop the frame index data structure 114 from a simple MPEG video stream 102 as the video stream 102 is received.
  • PVRs personal video recorders
  • the video stream 102 include previously encoded TrickPlay tables which increases the efficiency of transmission of the video stream 102 while still permitting display that is more flexible.

Abstract

A system stores an incoming video stream (102) in an MPEG format while simultaneously creating a look-up table of the logical block addresses (LBAs) of the memory locations at which frames of the video stream (102) is stored. The system stores the look-up table and the associated MPEG stream on a personal video recorder (PVR) hard drive. The system uses the look-up table to rapidly access the starting points of the individual frames of the MPEG stream to enable rapid random access into the MPEG stream at logical start locations. The system provides the contents of the MPEG frames to an MPEG decompressor to thereby provide TrickPlay of the MPEG stream. The system employs a hardware comparator to rapidly flag the frame start locations within the MPEG stream and to thereby create the look-up table.

Description

Published: For two-letter codes and other abbreviations, refer to the "Guid¬
— without international search report and to be republished ance Notes on Codes and Abbreviations " appearing at the beginupon receipt of that report ning of each regular issue of the PCT Gazette
DIGITAL VIDEO RECORDING SYSTEM WHICH GENERATES AN INDEX DATA STRUCTURE FOR DISPLAYING A VIDEO STREAM IN TRICKPLAY MODE
Background of the Invention Field of the Invention
This invention relates to the field of encoding and storing moving pictures and audio signals and, in particular, a system for digitally encoding, storing, and displaying a video stream in MPEG format on a personal video recorder (PVR) hard drive in a manner that facilitates play modes other than standard speed, sequential play. Description of the Related Art
Personal Video Recorders (PVRs), also sometimes called Digital Video Recorders (DVRs), are digitally based devices that enable a viewer of television to receive and digitally record video programming, such as TV broadcasts, movie downloads, and the like, for more flexible viewing. For example, PVRs enable a viewer to record defined categories of live television programming over the course of days. The viewer may stipulate that they want to record a series of tennis matches, all nature shows, or all episodes of a particular show over the course of a season. PVRs also enable a person viewing a "live" television broadcast to pause viewing and, at a later time, resume viewing the broadcast from the point at which live viewing was paused. A viewer also has the option to skip portions of a broadcast, such as for example commercials, upon reviewing a broadcast by employing a PVR. The recording features of PVRs can be performed when the viewer is away from the PVR so that the viewer can view preferred programs at a time that is convenient.
PVRs can receive either a streaming analog signal in an uncompressed format or a digitally encoded signal, such as an MPEG signal, from a transmission source. If the PVR receives an analog signal such as a television signal in an uncompressed format, the PVR typically digitally encodes the signal, stores the digitally encoded signal in a compressed format, and decodes and presents the signal for subsequent viewing. Similarly, if the PVR receives an already digitally encoded signal, the PVR then stores the signal and decodes and presents the signal for subsequent viewing. PVRs currently typically include 13.6-gigabyte hard disks that offer up to 14 hours of video programming or 27.2-gigabyte disks that offer up to 30 hours of programmable viewing.
-1- One common compression standard used for video streams currently used today is known as MPEG. MPEG is a standard for digitally encoding moving pictures and interleaved audio signals. MPEG facilitates compressing a video stream to reduce the storage capacity and transmission bandwidth required for an MPEG stream as compared to an uncompressed video stream. In a typical video stream, adjacent individual video frames will have much in common with the preceding and subsequent frames. For example, from one individual still frame of a scene to the next, much of the background, the colors, and the luminous intensity will usually remain the same. A relatively small amount of the overall scene will typically change from frame to frame. The compression technique used with MPEG leverages this redundancy of video in both the spatial and temporal dimensions in order to define certain frames with respect to other frames in a dependent or anticipatory manner and thereby reduce the amount of information required to accurately define a video stream.
In particular, the MPEG standard defines three types of frame formats: Intra-coded reference frames (I), Predictive-coded frames (P), and Bi-directionally predictive-coded frames (B). I frames contain all of the information required for a single video frame and are thus independent frames that need no information from other frames either before or after for decoding. On the other hand, P frames are defined with respect to preceding I frames or other P frames. B frames are bi-directionally defined with respect to both preceding and subsequent frames in the MPEG stream. Thus, both P and B frames need information from surrounding frames for decoding; a P or B frame by itself cannot be decoded into a viewable image. The I-
, P-, and B- frames are organized into at least one sequence defined by a sequence header and a set of subsequent I, P, and B frames. The sequence header contains display initialization information defining picture size and aspect ratio, frames and bit rate, decoder buffer size, and chroma pixel structure and may contain optional quantizer matrices and/or user data. While digital video compression schemes, such as MPEG, reduce the storage and transmission bandwidth required for these digital video streams, these compression schemes result in video data that is not readily adaptable to non-standard modes of display. For example, viewers of video images like to be able to use TrickPlay modes of viewing including by way of example: fast forward, reverse play, skip ahead, skip back, etc. Generally, compressed video streams that have inter-frame dependencies, such as MPEG streams, are not readily suited to random access of different frames within the stream as is often required for TrickPlay modes of viewing.
-2- For example, with an MPEG file, fast forward or fast reverse viewing of the full stream is not efficient because such modes of operation would still require the decoding of each of the P and B frames, which, in turn, may require decoding of multiple other frames. Hence, fast forward and fast reverse manners of display are not easily achievable due to the memory and processing required for the decoding of multiple frames that must be accomplished to reassemble the compressed data. Moreover, skipping to a particular segment within a video stream is also complicated by the fact that the particular segment desired may correspond to an interdependent frame which requires the decoding of multiple other frames before the desired frame can be viewed. Hence, the MPEG compression standard as used to facilitate efficient transfer and storage of digital video data inhibits subsequent flexible viewing of the digital video data. As more flexible viewing of digital video data is highly desirable, several mechanisms for implementing TrickPlay type viewing of compressed video data have been developed.
In one example, the compressed video streams are pre-recorded onto high-density recording media in a manner that facilitates TrickPlay. One example of this is disclosed in
U.S. Patent No. 6,002,834 to Hirabayashi, et al. In Hirabayashi, MPEG files are recorded onto optical disks along with an index table indicating the memory locations of the intra-coded reference (I) frames. The index table can then be subsequently used to implement TrickPlay. While Hirabayashi facilitates the use of TrickPlay with compressed video data, Hirabayashi provides the video data on a fixed recording medium, i.e., an optical disk, wherein the data necessary to implement TrickPlay has been previously recorded.
Video signals are typically provided to PVRs as either uncompressed analog signals or digitally compressed signals such as the signals received via cable or satellite television systems. While some streaming systems have been disclosed that provide video streams with redundant streams to facilitate TrickPlay (See, e.g., U.S. Patent No. 6,065,050 to De Money), many video streams are provided as analog signals or simple MPEG files that do not have any pre-recorded files or formats for facilitating TrickPlay.
Hence, there is a need for a system for recording compressed video data in a manner that facilitates flexible display of the compressed video data. To this end, there is a need for a system that can receive a stream of video data, such as a cable or satellite television broadcast, via an interface and compress and store the signals so as to be able to implement TrickPlay of
-3- the compressed video data without requiring that the compressed video data include pre- encoded data for TrickPlay.
Summary of the Invention In one aspect, the invention comprises a digital video recording system for storing, retrieving and displaying compressed digital video data. The system comprises a video stream buffer system that receives a stream of digital video data comprising intra-coded reference frames and predictive coded reference frames. The system also comprises a storage subsystem and a storage controller that stores the stream of digital video data into the storage subsystem. The storage controller identifies a start of the intra-coded reference frames and generates an index data structure in the storage subsystem that provides data indicative of the location of at least some of the intra-coded reference frames stored in the storage subsystem. The system also includes a display controller that accesses the index data structure and the video stream in the storage subsystem to display the video stream in a TrickPlay mode. The storage subsystem is integrated into the system such that the storage subsystem is simultaneously logically coupled to both the storage controller and the display controller.
Preferably, the storage controller also identifies the start of the predictive coded reference frames and further generates the index data structure so that the index data structure provides data indicative of the location of at least some of the predictive coded reference frames stored in the storage subsystem. Also, in one embodiment, the storage controller further stores in the index data structure data corresponding to the extent of each frame.
In another aspect, a method of storing, retrieving and displaying compressed digital video data using a personal video recording having an integrated memory storage subsystem and a display is provided. The method comprises receiving a video stream comprising intra- coded reference frames and predictive-coded reference frames and identifying the intra-coded reference frames upon receipt of the video stream. The method further comprises generating an index data structure from the identified intra-coded reference frames and storing the index data structure in the integrated storage subsystem of the personal video recorder. The method further comprises using the index data structure in the integrated storage subsystem of the personal video recorder to cause delivery of selected frames of the stored video stream to the display of the personal video recorder to thereby display the video stream in a TrickPlay mode. In one embodiment, generating the index data structure further comprises storing an extent value indicative of the extent of the data corresponding to the intra-coded reference frames.
In yet another aspect of the invention, the present invention comprises a system for storing, retrieving and displaying digital video data. In this aspect, the system comprises a video stream buffer system that receives a stream of digital video data comprising sequence header data, intra-coded reference frames and predictive-coded reference frames and a storage system. The system also includes a storage controller that stores the stream of digital video data into the storage system, wherein the storage controller generates an index data structure in the storage system as the stream of digital video data is being stored in the storage system, and wherein the index data structure includes data indicative of the location where the intra- coded reference frames are stored in the storage system and the extent of the intra-coded reference frames.
The system also includes a display controller that accesses the index data structure and the video stream stored in the storage system to display the video stream in a TrickPlay mode, wherein the display controller uses the extend of the frame to limit access of a selected frame to only the data corresponding to the selected frame to thereby more efficiently access the selected frame and wherein the storage system is integrated into the system such that the storage system is simultaneously logically coupled to both the storage controller and the display controller. Brief Description of the Drawings
Figure 1 is a block diagram illustrating a digital video storage and display system of the preferred embodiment;
Figure 2 is a block diagram illustrating the video stream buffer system of the digital video storage and display system of Figure 1; Figure 3 is a table illustrating the logical structure of the MPEG frame header information that is received by the digital video storage and display system of Figure 1;
Figure 4 is a block diagram illustrating the components and operation of the programmable start code detector of the video stream storage subsystem of Figure 2;
Figure 5 is a flow chart illustrating the creation of a frame index data structure by the system of Figure 1 as the digital video data stream is being stored in the video stream storage subsystem of Figure 1; Figure 6 is a diagram which illustrate the data structures of the digital video stream and the frame index data structure as it is stored in the storage subsystem of the system of Figure 1; and
Figure 7 is a flow chart illustrating the operation of the digital video storage and display system of Figure 1 as the stored data is retrieved and displayed in either a normal or
TrickPlay mode.
Detailed Description of the Preferred Embodiment
Reference will now be made to the drawings wherein like numerals refer to like parts throughout. Figure 1 is a block diagram illustrating the basic logical and physical components of a digital video storage and display system 100 of the preferred embodiment. In this particular embodiment, the system 100 receives a video stream 102. The video stream 102 provides compressed digital video data to the system 100 via any of a number of known interfaces and sources, such as cable or satellite television networks or the Internet. In one embodiment of the invention, the video stream 102 is already digitally encoded in the MPEG format. In an alternative embodiment, the video stream 102 is initially provided as an analog signal and is digitized and encoded in MPEG format by an MPEG encoder of a type well known in the art prior to reception by the digital video storage and display system 100. As will be described in greater detail below, the system 100 is suitable for implementation on a
PVR such that MPEG data can be received from external sources and stored in such a fashion that the data can be subsequently retrieved by the system 100 in a manner that facilitates
TrickPlay.
In particular, the system 100 is capable of receiving the video stream 102 comprising compressed digital frames corresponding to visual frames via a communications network, such as a cable or satellite television network. The video stream 102 preferably comprises a series of digital frames that include intra-coded reference frames which contain sufficient data to allow for reproduction of the image embodied in the frame without requiring data from other frames. Moreover, the video stream 102 also includes predictive-coded reference frames, which contain digital data but require data from other frames to permit reproduction of the image embodied in the predictive-coded frame, and sequence header data to define the display formatting information for the stream.
The MPEG video stream 102 uses a known standard for encoding video and audio signals so as to facilitate compression. The MPEG video stream 102 comprises a plurality of I-frames 103, P-frames 105, and B-frames 107 (Figure 3) sequentially arranged in a well- known manner. The I-frames 103 are known intra-coded reference independent frames. The P-frames 105 are known predictive-coded reference frames that depend upon preceding I- frames 103 or other P-frames 105. The B-frames 107 are known bi-directionally dependent frames that reference preceding and subsequent frames in the MPEG stream 102. The structures of the I-frames 103, P-frames 105, and B-frames 107 are well known, but will be described in greater detail below in reference to the table of Figure 3.
The MPEG video stream 102 is organized into at least one sequence 400 indicated by a sequence header 402 (Figure 6). The sequence 400 begins with the sequence header 402 followed by a plurality of frames 103, 105, and 107. The sequence header 402 is identified by a unique sequence header start code 403 of 00 00 01 B3 (hex) and comprises subsequent sequence header 402 information pertaining to the horizontal and vertical size of the pictures, aspect ratio information, and the frame and bit rate codes. The sequence header 402 provides the initial formatting information to a video stream decoder 116 required to initiate display of the MPEG video stream 102 and to change channels to thereby enable the video stream decoder 116 to properly display the MPEG stream 102.
The system 100 is functionally depicted in Figure 1, and it will be appreciated that the logical blocks of Figure 1 comprise functional blocks that can be implemented in hardware, software, or in both. Moreover, it will be appreciated that the exact implementation of the logical blocks of the digital video storage and display system 100 as illustrated in Figure 1 can be implemented in any of a number of well-known manners. As is illustrated in Figure 1, the digital video storage and display system 100 includes a video stream buffer system 104 that receives the video stream 102 via an interface. The video stream buffer system 104 buffers the incoming digital video stream 102 and provides the video stream 102 to a storage subsystem 110 such that the video stream 102 can be stored in a video stream data structure 112. The video stream buffer system 104 also determines the start of sequence headers 402 and the start of each frame 103, 105, 107 and provides a start detected signal 118 indicative thereof to a storage controller 106 to allow the storage controller 106 to develop a frame index data structure 114 in the storage subsystem 110 in a manner that will be described in greater detail below.
The storage controller 106 develops an index of the logical memory address of the start of the frames 103, 105, 107 within the video stream 102 to permit subsequent display of
-7- the video stream 102 in a TrickPlay mode in a manner that will be described in greater detail below in reference to Figure 7. In one embodiment, the index developed by the storage controller 106 contains the locations of the I-frames 103 only. Alternatively, the frame index data structure 114 comprises an index of the locations of all of the frames 103, 105, 107 of the MPEG video stream 102.
As discussed above, the digital video storage and retrieval system 100 also includes a storage subsystem 110 which, in this embodiment, preferably comprises a hard drive of a type known in the art. Various data structures can be assembled in the storage subsystem 110 including the video stream data structure 112 and the frame index data structure 114. The configuration of these structures will be described below in reference to Figure 6.
As is further illustrated in Figure 1, the digital video storage and display system 100 includes an output section that includes a video stream decoder 116, a display controller 120, and a display 122. The display controller 120 can either be implemented in software or in hardware, and it selects data from the video stream data structure 112 to be provided to the video stream decoder 116 such that the data can be decoded and provided to the display 122 to permit display of the stored video data. In the preferred embodiment, the video stream data structure 112 includes the MPEG video stream 102 that is provided to the video stream decoder 116 and decoded according to well-known MPEG decoding protocols. The decoded images can then be provided to the display 122 such that the stored image can be displayed in a known manner, such as in the PAL or NTSC television formats.
The display controller 120 also has access to the frame index data structure 114 created by the storage controller 106 such that the display controller 120 can use the frame index data structure 114 to access particular frames 103, 105, 107 within the video stream data structure 112 so as to implement TrickPlay. In this particular embodiment, TrickPlay can include any of a number of techniques of displaying the video stream 102, including fast forward, reverse play, skip ahead and skip back. One exemplary manner in which the display controller 120 implements TrickPlay on the video stream 102 stored in the video stream data structure 112 will be described below in reference to Figure 7.
Hence, the system 100 is capable of receiving a video stream 102, such as an MPEG stream or file, and storing this stream or file into the storage subsystem 110 such as a hard drive of a PVR. The video stream 102 is stored along with the frame index data structure 114 that is created simultaneously with the storing of the video stream 102 such that the frame
-8- index data structure 114 can be subsequently used to facilitate TrickPlay modes of display of the stored video data. The video stream buffer system 104 is illustrated in greater detail in conjunction with Figure 2.
As shown in Figure 2, as the video stream 102 is received by the system 100, the video stream 102 is first stored in a buffer 123. The buffer 123, in this embodiment, is a random access memory (RAM) array that temporarily stores the MPEG stream 102 signals in a known manner. The video stream buffer system 104 further includes a memory controller 124 that analyzes the incoming MPEG video stream 102 and controls writing to the storage subsystem 110. In response to a scan buffer input, the memory controller 124 writes video stream 102 data to the video stream data structure 112. The video stream data structure 112 comprises a hard drive memory, and the memory controller 124 is writing the video stream 102 data to the sectors of the hard drive. Each of the sectors of the hard drive has a corresponding logical block address (LB A) 130 that can be readily determined. As will be discussed in greater detail below, once the start of a frame 103, 105, 107 is identified, the corresponding LB A 130 of the sector of the hard drive can also be determined and stored in the frame index data structure 114. Moreover, the system 100 can also optionally determine an offset 144 (Figure 6) between the start of a particular sector of the hard drive and the actual place within the sector in which data from a frame 103, 105, 107 is recorded by determining the number of usable bytes between the start of a sector and the actual byte location at which the frame 103, 105, 107 begins. Similarly, the system 100 can also determine an extent 142 of the frame 103, 105, 107. Both the offset 144 and extent 142 can be subsequently used by the display controller 120 to improve the efficiency of decoding the stored MPEG video stream 102.
As shown on Figure 2, as the MPEG video stream 102 is received, the MPEG video stream 102 is analyzed by a programmable start code detector 126. The programmable start code detector 126 of this embodiment is a hardware comparator circuit that is adapted to identify start codes for frames 103, 105, 107 and the sequence header 402. As will be discussed in greater detail hereinbelow, the system 100 will store in the frame index data structure 114 an indication of the start of particular frames 103, 105, 107 of the MPEG video stream 102. Moreover, the system 100 will also store the sequence header 402 information as to how the frames 103, 105, 107 are to be displayed. In order to store both of these types of information, the start codes of the sequence header 402 and the frames 103, 105, 107 must be
-9- identified. In this embodiment, the start code detector 126 is programmable such that it can be used to detect either the start of the sequence header 402 or the start of individual frames 103, 105, 107 of the video stream 102.
With respect to deteπnining the start of a frame 103, 105, 107, once the start of a frame 103, 105, 107 has been detected by the programmable start code detector 126, a start detected signal 118 is provided to the storage controller 106, and the storage controller 106 can then determine whether the frame 103, 105, 107 comprises a frame 103, 105, 107 for which an index marker should be stored in the frame index data structure 114 to facilitate subsequent use for TrickPlay display of the stored video stream 102. The memory controller 124 controls the storage of the video stream 102 data into the video stream data structure 112 and sequentially provides the data comprising the MPEG video stream 102 to the storage subsystem 110 and the programmable start code detector 126 so as to permit identification of the beginning of picture frames 103, 105, 107.
In particular, in this embodiment, the MPEG video stream 102 includes a header 132 for each frame 103, 105 and 107 as shown in Figure 3. The header 132 comprises a picture start code 135, a temporal reference 136 and a picture coding type 140. The picture start code 135 is a unique 32-bit word that identifies the start of the frame 103, 105 or 107. The picture start code 135 of this embodiment for the start of each frame 103, 105, or 107 is 0x00000100 where "Ox" indicates that the subsequent digits are presented in a hexadecimal format. The temporal reference 136 is a 10-bit code providing temporal information for the following frames 103, 105 or 107 and, in this embodiment, is a "don't care" value. The picture coding type 140 is a 3-bit code for the type of frame 103, 105, or 107 to follow. A picture coding type 140 of "001" indicates that an I-frame 103 is to follow, a "010" indicates that a P-frame 105 is to follow, and a "011" indicates a B-frame 107 is to follow. Following the picture coding type 140, the MPEG video stream 102 includes compressed image and interleaved audio signal data appropriate to the particular frame 103, 105, 107 encoded in a well-known manner.
Hence, as shown in Figure 2, the video stream buffer system 104 sequentially receives data that indicates both the start of a particular frame 103, 105, 107 and that also indicates the type of frame 103, 105, 107. This information is provided to the programmable start code detector 126 which provides the start detected signal 118 to the storage controller 106 indicative of the start of a frame 103, 105, 107. Moreover, the frame-type information, as
-10- indicated by the picture coding type 140, is also provided to the storage controller 106 such that the storage controller 106 can determine the particular start of the frame 103, 105, 107 and also the type of the frame 103, 105, 107.
Figure 4 illustrates one embodiment of the programmable start code detector 126 which, in this embodiment, includes a 32-bit hardware comparator 602 and a programmable start code register 134. The incoming MPEG stream 102 is sequentially provided to the comparator 602 and the digital data contained therein is first compared to a programmed sequence header start code 403 contained within the start code register 134. In this embodiment, the detection of the sequence header start code 403 in the incoming MPEG stream 102 sends the start detected 118 interrupt to a memory address latch 606 to cause the memory address latch 606 to store a corresponding buffer memory address 127 of the start of the sequence header 402 in the storage subsystem 110 so that the corresponding LBA 130 can be determined and stored in the storage subsystem 110 in a manner that will be described in greater detail below. The system 100 then reprograms the start code register 134 of the programmable start code detector 126 with the picture start code 135 of 0x00000100.
When the incoming MPEG stream 102 matches the picture start code 135 contained within the start code register 134 for the start of a particular frame 103, 105, 107, the comparator 602 outputs the start detected 118 signal to the storage controller 106 indicating that the start of a frame 103, 105, 107 has been detected. In this embodiment, the detection of a picture start code 135 in the incoming MPEG stream 102 sends the start detected interrupt
118 to the memory address latch 606 to cause the memory address latch 606 to store the corresponding buffer memory address 127 of the start of the frame 103, 105, 107 so that the corresponding LBA 130 can be determined from a latched memory address 129 and stored in the index data structure 114 in a manner that will be described in greater detail below. The start detected 118 signal also causes a frame type latch 604 to latch the 3 -bit picture coding type 140 so that the corresponding LBA 130 and the frame type 103, 105, 107 can be stored in the frame index data structure 114 in the manner that will be described in greater detail hereinbelow.
In this embodiment, the start codes 135, 403 are detected with the dedicated hardware comparator 602 instead of using software to facilitate a more rapid identification of the sequence header 402 and the start of a frame 103, 105, 107 in the MPEG video stream 102. It will be appreciated that the hardware comparator 602 of the programmable start code detector
-11- 126 can further be implemented to evaluate the bits indicating the picture coding type 140 to determine whether the frame is an I-frame 103, a P-frame 105, or a B-frame 107.
Using the buffer memory addresses 127, the storage controller 106 and the memory controller 124 can determine the logical block address (LBA) 130 of the frames 103, 105, 107 being stored in the video stream data structure 112 such that these LB As 130 can be stored in the frame index data structure 114 in the manner that will be described in greater detail below. In particular, Figure 5 illustrates the process by which the video stream buffer system 104 and the storage controller 106 store the video stream 102 in the video stream data structure 112 and produce the frame index data structure 114.
1. As indicated in Figure 5, the programmable start code detector 126 is first programmed to detect the sequence header start code 403 in state 252. The system 100 then in state 254 detects a sequence header 402, saves the corresponding buffer memory address 127, and interrupts the software in the manner previously described. The software then reads the buffer memory address 127 in state 256 and derives the LBA 130 for the start of the sequence header 402 in state 260. Then, the start location LBA 130 of the sequence header 402 as stored in the storage subsystem 110 is stored in the storage subsystem 110 in state 262 so as to be associated with the video stream data structure 112.
Then the start code register 134 of the programmable start code detector 126 is reprogrammed in state 236 to detect the picture start code 135. The programmable start code detector 126 in state 240 detects the picture start code 135, saves the buffer memory address
127, the frame type 140 information, and sends the interrupt to the software comprising the storage controller 106 in the manner described above in connection with Figure 4.
The software comprising the storage controller 106 then reads the frame type 140 information and the buffer memory address 127 in state 242 and derives the storage subsystem location for the start of the frame 103, 105, 107 in state 244. The buffer memory address 127 is the address in the buffer 123 of the picture start code 135 as it is being stored in the video stream data structure 112 by the memory controller 124 (Figure 4). Hence, the storage controller 106, by knowing the buffer memory address 127 can thus determine the sector of the hard drive in which the picture start code 135 is being stored. The sector is, in this embodiment, identified as a logical block address (LBA) 130.
-12- 2. Then, in a state 246, the storage controller 106 periodically adds the LBA 130 of the start location of the frames 103, 105,107 to the frame index data structure 114 in the storage subsystem 110. In this way, the video stream buffer system 104 and the storage controller 106 can both simultaneously store the video stream data structure 112 in the storage subsystem 110 and also generate the frame index data structure 114 indicative of the sectors on the hard drive where the frame 103, 105, 107 starts can be found.
The system 100 can also determine and store in state 248 an extent 142 of the frame 103, 105, 107. The extent 142, in one embodiment, is the number of sectors of the storage subsystem 110 that the frame 103, 105, 107 at least partially occupies. As the LBAs 130 of the start location of succeeding frames 103, 105, 107 are being determined in state 244, the extent 142 of the succeeding frames 103, 105, 107 can thus be determined as the starting LBAs 130 of each frame 103, 105, 107 are known as well as the ending LBA 130 of each frame 103, 105, 107 as the ending LBA 130 corresponds to the starting LBA 130 of the next sequential frame 103, 105, 107. As discussed above, the system 100 can also optionally determine in state 248 an offset 144 between the start of the data corresponding to the frames 103, 105, 107 and the start of the sector corresponding to the LBA 130. The offset 144 information can also be provided to the storage controller 106 such that the storage controller 106 can also store this offset 144 information in the frame index data structure 114 as is indicated in Figure 6. The offset 144 information can be used to more efficiently access and decode the frames 103, 105,
107 during TrickPlay display of the stored MPEG video stream 102. Similarly, since the memory controller 124 is sequentially storing the data corresponding to each frame 103, 105, 107 in the video stream data structure 112, and since the programmable start code detector 126 is detecting the start of each frame 103, 105, 107, the extent 142 of each of the frames 103, 105, 107 can be determined as the byte length as opposed to the number of LBAs 130 occupied by the data of the frame 103, 105, 107.
As is indicated in Figure 5, the process of states 240 - 249 is repeated until it is determined in decision state 249 that each of the frames 103, 105, 107 has been stored in the video stream data structure 112 and the corresponding index marker has been generated in the index data structure 114. In this way, as the frames 103, 105, 107 are being stored in the video stream data structure 112, the LBAs 130 of the start of each frame 103, 105, 107 can also be
-13- stored in the storage subsystem 110 and organized into the frame index data structure 114 for future access for TrickPlay applications.
The preferred manners in which the video stream 102 is stored in the video stream data structure 112 and in which the frame index data structure 114 and the video stream data structure 112 are stored within the storage subsystem 110 are schematically illustrated in
Figure 6. The frame index data structure 114 comprises a series of entries that includes the LBAs 130 of the start of the frames 103, 105, 107 of the MPEG video stream 102 stored in the storage subsystem 110. In this particular embodiment, the storage subsystem 110 comprises a hard drive incorporating one or more magnetic disks. The video stream data structure 112 includes a series of sectors identified by LBAs 130 corresponding to each of the frames 103, 105, 107, which provides logical addresses corresponding to the physical location of the digital data corresponding to the particular frame 103, 105, 107 as stored on the storage subsystem 110. The storage of this data onto the hard drive is accomplished in a manner that is known in the art. In particular, the hard drive has a plurality of tracks that are divided into a plurality of sectors on the disk that are digitally encoded. Each block stores approximately 512 bytes of information that can be accessed in a known manner provided the LBA 130 of the particular sector is known. The data is sequentially written onto the tracks of the hard drive. Since an LBA 130 identifies a unique sector, the LBAs 130 can thus be used to access desired data such as the start of the sequence 400 or the frames 103, 105, 107.
As is illustrated in Figure 6, the frame index data structure 114 includes a frame type field 131 that indicates the type of frame 103, 105, 107 for which the index data is stored. As discussed above, in one embodiment, the start locations of each of the frames 103, 105, 107 of the video stream is stored in the frame index data structure 114. In another embodiment, only the start locations of the I-frames 103 is stored in the frame index data structure 114. By storing the start locations of either only the I-frames 103 or the start locations of all of the frames 103, 105, 107, selected frames 103, 105, 107 can be accessed more readily for display purposes. Hence, storing the start locations of either selected frames 103, 105, 107 or of all the frames 103, 105, 107 greatly facilitates TrickPlay. As is also illustrated in Figure 6, the frame index data structure 114 includes the starting LBA 130 which is stored in a starting LBA field 130. Similarly, the extent 142 of the frame data is also stored in a frame extent field 142. As discussed above, the extent 142 can
-14- either be the number of sectors that are occupied by the frame 103, 105, 107 data or the actual number of bytes the frame 103, 105, 107 data comprises. The extent field 142 can thus be expressed as the number of LBAs 130, the LBA 130 in which the frame 103, 105, 107 data ends, which will typically correspond to the next subsequent starting LBA 130, or the byte length of the frame 103, 105, 107.
As is also illustrated in Figure 6, an optional sector offset data field 144 can also be included in the frame index data structure 114. The sector offset data field 144 comprises the offset 144 in the starting sector between the start of the sector and the actual start of the data corresponding to the particular frame 103, 105, 107. The extent 142 and the offset 144 are provided to the display controller 120 to improve the efficiency with which the digital video storage and display system 100 can access frames 103, 105, 107 within the video stream data structure 112. Hence, the system 100 preferably creates the frame index data structure 114 that has the LBA 130, offset 144, and extent 142 corresponding to each of the frames 103, 105, 107. This information can then be used to more efficiently decode and display the frames 103, 105, 107 for TrickPlay implementations.
The storage subsystem also includes a data structure 403 which has a reference to the LBA 130 of the sequence header 402. As discussed above, the sequence header 402 includes information which is needed by the display controller to be able to display the frames 103, 105, 107 of the video stream 102. The sequence header 402 information is thus stored in the storage subsystem 110 in a location that is associated with the frame index data structure 114 such that the sequence header 402 in the hard drive can be more readily accessed.
Figure 7 is a flow chart that illustrates exemplary modes of operation of the display controller 120 as it displays the video stream 102 stored in the video stream data structure 112. It will be appreciated that the flow chart of Figure 7 illustrates one advantageous implementation and that other implementations may also be used.
As discussed above, the display controller 120 has access to the video stream data structure 112 such that the display controller 120 can provide the data contained therein to a video stream decoder 116. The video stream decoder 116 decodes the video stream 102 information and provides the decoded information to the display 122 in a known manner.
Similarly, the display controller 120 also has access to the frame index data structure 114 such
-15- that the display controller 120 can use this information to facilitate implementation of TrickPlay of the video stream 102 data contained within the video stream data structure 112.
After a start state 300, the display controller 120 determines the mode of display of the video stream 102 in decision state 302. If the display controller 120 determines in the decision state 302 that the mode of display is normal play, the display controller 120 then determines, in a state 340, the LBA 130 of the start of the sequence header 402. Then, in a state 342, the display controller 120 retrieves the sequence header 402 from the storage subsystem 110 and sends the sequence header 402 to the video stream decoder 116. Then, in a state 304, the display controller 120 determines the LBA 130 of the start of the video stream 102 stored within the video stream data structure 112 in a known manner.
Then, in a state 306, the data is retrieved from the corresponding memory location within the storage subsystem 110 and is provided to the video stream decoder 116. The video stream decoder 116 then decodes and displays the initial frame 103 and subsequent frames 103, 105, 107 in state 310 according to the known decoding and display protocols of the MPEG standard. After the display of each frame 103, 105, 107, the display controller 120 determines, in a decision state 312, whether the display of the video stream 102 is completed. It will be appreciated that the video stream 102 display is completed when either the entire sequence has been displayed or when the display controller 120 receives an interrupt signal from a user input in a well-known manner. The display controller 120 in normal play mode repeats steps 306 - 310 for each of the frames 103, 105, 107 stored within the video stream data structure 112. In this manner, the video stream 102 can be displayed to a user in a known manner.
If the display controller 120 determines, in the decision state 302, that a TrickPlay mode of operation has been selected, the display controller 120 then accesses the data in the frame index data structure 114 that is stored in the storage subsystem 110 as previously described. It will be appreciated that the display controller 120 may receive input signals from a user via an input, such as a keyboard or a graphical user interface (GUI), so as to identify when TrickPlay has been activated by the user. It will also be appreciated that the exact implementation of TrickPlay by the display controller 120 can comprise a number of different implementations of which only a skip implementation and a fast forward/reverse implementation are illustrated in Figure 7.
-16- In particular, if the display controller 120 determines in a state 320 that a skip TrickPlay has been implemented!, the display controller 120 then determines, in state 340, the LBA 130 of the start of the sequence header 402. Then, in state 342, the display controller 120 retrieves the sequence header 402 from the storage subsystem 110 and sends the sequence header 402 to the video stream decoder 116. The display controller 120 then determines the I- frame 103 that corresponds to the skip location selected by the user in a state 322. Basically, in skip play, the user can indicate the portion of the video stream 102 that the user would like to see displayed using an input device in a known manner. The display controller 120 then determines in state 322 the most adjacent I-frame 103 corresponding to the desired temporal location within the video stream 102.
The frame index data structure 114 provides the LBA 130 corresponding to the selected I-frame 103 corresponding to the desired skip location such that the I-frame 103 data can then be provided to the video stream decoder 116 and displayed from that point in a normal play mode in states 306-310 in the manner previously described. In one embodiment, the display controller 120 can display this I-frame 103 to the user as a still shot. Hence, the display controller 120 is able to determine an I-frame 103 which corresponds to a skip location that the user has selected and then initiate the decoding and the display of the video stream 102 stored in the video stream data structure 112 from that I-frame 103.
As discussed above, the index data structure 106 in one embodiment includes not only the LBA 130 at which the start of the frames 103, 105, 107 are located but also the offset 144 and the extent 142. The decoding of the frames 103, 105, 107 by the display controller 120 and the video stream decoder 116 can thus be performed more efficiently. In particular, knowing the offset 144 permits decoding of the data corresponding to the frames 103, 105, 107 to begin with the actual data as opposed to the data occurring at the beginning of the sector that corresponds to the LBA 130, but which may not be related to the frame 103, 105,
107.
Similarly, knowing the extent 142 of the frames 103, 105, 107 allows the display controller 120 to activate the video stream decoder 116 so as to decode only the data that correspond to the frames 103, 105, 107 that are being provided out of the video stream data structure 112. It will be appreciated that the data is being provided sequentially and the typical way of deteπnining the end of the frames 103, 105, 107 is to begin to decode the next frame 103, 105, 107 and identify the next 32-bit picture start code 135. By knowing the length of the
-17- usable data corresponding to the frames 103, 105, 107, the efficiency of decoding the frames 103, 105, 107 can be enhanced as the end point of the frames 103, 105, 107 will already be known without having to process additional bytes of data to determine the start of the next frame 103, 105, 107. The display controller 120 can also implement a fast forward/reverse TrickPlay mode of display of the video stream 102 if the display controller 120 determines, in a decision state 330, that such a TrickPlay mode of display has been selected by the user. In this embodiment, the display controller 120 determines, in state 340, the LBA 130 of the start of the sequence header 402. Then, in state 342, the display controller 120 retrieves the sequence header 402 from the storage subsystem 110 and sends the sequence header 402 to the video stream decoder 116. Then, in a state 332, the display controller 120 sequentially retrieves, the data corresponding to the indexed frames 103, 105, 107 1 through n, as listed in the frame index data structure 114 and decodes and displays each of these I-frames 103 in a state 334 until the fast forward is determined to be completed in decision state 336. In one embodiment, each of the I-frames 103 is decoded and displayed to the user in the same manner as described above, which results in a fast forward that is significantly faster than the normal decoding and display rate of the MPEG video stream 102. It will be appreciated that the I-frames 103 alone may be displayed or, in an alternative embodiment, the I-frames 103 and selected following P-frames 105 may be displayed so as to provide more refined visual data to the user but will still result in faster display of the video data. It will be further appreciated that fast forward and fast reverse can be easily implemented by incrementing or decrementing a counter corresponding to the particular I-frame 103 that is to be retrieved from the video stream data structure 112 and decoded by the video stream decoder 116.
From the foregoing, it will be appreciated that because an index of the start locations of the frames 103, 105, 107 has been compiled into the storage subsystem 110 during the storage of the video stream 102, the start locations can then be used to access particular frames 103, 105, 107 within the video stream 102. As discussed above, the index frames are preferably the I-frames 103 which allow for TrickPlay, such as fast forward, fast reverse and skipping to a particular start location. Hence, the system 100 allows for both storage and display of digital video data such as
MPEG files and streams. The system 100 has an integrated storage subsystem 110 that is logically coupled to both the storage controller 106 and the display controller 120. Thus, the
-18- storage controller 106 is capable of developing the frame index data structure 114 that is stored in the storage subsystem 110 that is accessible by the display controller 120 so as to allow the display controller 120 to implement more efficient flexible display of the stored video stream 102. The TrickPlay modes of display described here illustrate several of the different types of TrickPlay displays that can be implemented using the frame index data structure 114 and should not be viewed as limiting the implementation of this invention.
The preferred embodiment can thus be implemented on existing personal video recorders (PVRs) allowing for TrickPlay display of streaming video by causing the PVR to develop the frame index data structure 114 from a simple MPEG video stream 102 as the video stream 102 is received. Hence, there is no requirement that the video stream 102 include previously encoded TrickPlay tables which increases the efficiency of transmission of the video stream 102 while still permitting display that is more flexible.
-19-

Claims

WHAT IS CLAIMED IS
1. A digital video recording system for storing, retrieving, and displaying compressed digital video data, comprising: a video stream buffer system that receives a stream of digital video data comprising intra-coded reference frames and predictive-coded reference frames; a storage subsystem; a storage controller that stores the stream of digital video data into the storage subsystem, wherein the storage controller identifies a start of the intra-coded reference frames and generates an index data structure in the storage subsystem that provides data indicative of the location of at least some of the intra-coded reference frames stored in the storage subsystem; and a display controller that accesses the index data structure and the video stream in the storage subsystem to display the video stream in a TrickPlay mode, wherein the storage subsystem is integrated into the system such that the storage subsystem is simultaneously logically coupled to both the storage controller and the display controller.
2. The system of Claim 1, wherein the storage controller identifies the start of the predictive coded reference frames and further generates the index data structure so that the index data structure provides data indicative of the location of at least some of the predictive coded reference frames stored in the storage subsystem.
3. The system of Claim 1, wherein the storage subsystem comprises a personal video recorder hard drive.
4. The system of Claim 3, further comprising a start code detector that receives the stream of digital video data further comprising sequence and frame header information and that provides a signal to the storage controller when the start code detector identifies the start of a frame.
5. The system of Claim 4, wherein the start code detector comprises a comparator that compares header information contained within the digital video data to a code that corresponds to the start of a sequence or a frame to identify the start of a sequence or a frame.
-20-
6. The system of Claim 4, wherein the storage controller stores in the index data structure data corresponding to the logical block address of the start of each frame identified by the start code detector thereby identifying where the start of each frame is stored on the hard drive.
7. The system of Claim 4, wherein the storage controller, upon receiving a signal indicative of the start of a frame, analyzes the header information of the digital video data corresponding to the frame and determines whether the frame is an intra-coded reference frame.
8. The system of Claim 7, wherein the storage controller stores in the index data structure an identifier corresponding to the logical block address of the start of each frame that is determined to be an intra-coded reference frame, thereby identifying the location where the start of each intra-coded reference frame is stored on the hard drive.
9. The system of Claim 8, wherein the storage controller further stores in the index data structure data corresponding to the offset of the beginning of each frame from the beginning of the corresponding logical block address in which the frame is stored.
10. The system of Claim 8, wherein the storage controller further stores in the index data structure data corresponding to the extent of each frame.
11. The system of Claim 1, wherein the display controller accesses the index data structure to identify the start of each frame to thereby implement TrickPlay display of the stored video stream.
12. The system of Claim 11, wherein the display controller, in response to an input from a user, uses the index data structure to access a selected intra-coded reference frame stored on the hard drive corresponding to a skip location selected by the user to cause the decoding and display of the selected intra-coded reference frame.
13. The system of Claim 11, wherein the display controller, in response to an input from a user, uses the index data structure to access a plurality of intra-coded reference frames to cause the decoding and display of the plurality of intra-coded reference frames to thereby implement a fast forward display of the video stream.
-21-
14. The system of Claim 11, wherein the display controller, in response to an input from a user, uses the index data structure to access a plurality of intra-coded reference frames to cause the decoding and display of the plurality of intra-coded reference frames to thereby implement a fast reverse display of the video stream.
-22-
15. A method of storing, retrieving, and displaying compressed digital video data using a personal video recorder having an integrated memory storage subsystem and a display, the method comprising: receiving a video stream comprising intra-coded reference frames and predictive-coded reference frames; identifying the intra-coded reference frames upon receipt of the video stream; generating an index data structure from the identified intra-coded reference frames and storing the index data structure in the integrated storage subsystem of the personal video recorder; storing the video stream in the integrated storage subsystem of the personal video recorder; and using the index data structure in the integrated storage subsystem of the personal video recorder to cause delivery of selected frames of the stored video stream to the display of the personal video recorder to thereby display the video stream in a TrickPlay mode.
16. The method of Claim 15, wherein receiving a video stream comprises receiving a MPEG video stream that is not modified to implement TrickPlay display of the MPEG stream.
17. The method of Claim 16, wherein receiving a video stream comprises receiving an MPEG video stream on a personal video recorder via a cable television network.
18. The method of Claim 15, wherein generating the index data structure comprises storing a logical block address (LBA) indicative of the location of the start of the intra-coded reference frames.
19. The method of Claim 18, wherein using data from the index data structure to cause delivery of selected frames to the display comprises using the LBA to access the start of the intra-coded reference frames.
20. The method of Claim 18, wherein generating the index data structure further comprises storing an offset value indicative of the offset between the data corresponding to
-23- the logical block address and the data corresponding to the start of the intra-coded reference frames.
21. The method of Claim 18, wherein generating the index data structure further comprises storing an extent value indicative of the extent of the data corresponding to the intra-coded reference frames.
22. The method of Claim 21, wherein using data from the index data structure to cause delivery of selected frames to the display comprises using the length data to cause delivery of a data string having a length that corresponds to the length of the data corresponding to the intra-coded reference frames.
23. The method of Claim 15, wherein TrickPlay comprises displaying the images of the video stream at a rate accelerated above the normal play rate.
24. The method of Claim 15, wherein TrickPlay comprises displaying the video stream beginning at a location within the video stream other than at the beginning of the video stream.
25. The method of Claim 15, wherein TrickPlay comprises displaying the images of the video stream in reverse order.
26. The method of Claim 15, further comprising identifying the predictive-coded reference frames.
27. The method of Claim 26, wherein generating the index data structure further comprises generating the index data structure from the identified predictive coded references frames.
-24-
28. A system for storing, retrieving and displaying digital video data, the system comprising: a video stream buffer system that receives a stream of digital video data comprising sequence header data, intra-coded reference frames, and predictive-coded reference frames; a storage system; a storage controller that stores the stream of digital video data into the storage system, wherein the storage controller generates an index data structure in the storage system as the stream of digital video data is being stored in the storage system, and wherein the index data structure includes data indicative of the location where the intra-coded reference frames are stored in the storage system and the extent of the stored intra-coded reference frames; and a display controller that accesses the index data structure and the video stream stored in the storage system to display the video stream in a TricikPlay mode, wherein the display controller uses the extent of the frame to limit access of a selected frame to only the data corresponding to the selected frame to thereby more efficiently access the selected frame and wherein the storage system is integrated into the system such that the storage system is simultaneously logically coupled to both the storage controller and the display controller.
29. The system of Claim 28, wherein the storage system comprises a hard drive of a personal video recorder (PVR).
30. The system of Claim 29, further comprising a start code detector that receives the digital video data received by the input buffer, wherein the digital video data includes header information, and wherein the start code detector evaluates the header information to identify the sequence header and intra-coded reference frames.
31. The system of Claim 30, wherein the digital video data is stored in the hard drive of the storage system in sectors identifiable by logical block addresses.
32. The system of Claim 31, wherein the storage controller stores the logical block addresses of the sectors in which the intra-coded reference frames are located.
33. The system of Claim 32, wherein, for each intra-coded reference frame, the storage controller determines the offset between the start of the sector and the actual location
-25- where the data corresponding to the start of the intra-coded reference frame is stored in the sector, and wherein the storage controller further stores an offset value indicative of this offset.
34. The system of Claim 32, wherein, for each intra-coded in the index data structure to thereby access the selected intra-coded reference frame for subsequent decoding display of the selected intra-coded reference frame.
35. The system of Claim 35, wherein the display controller further accesses the offset value for the selected intra-coded reference frame in the index data structure so that only the data in the sector corresponding to the selected intra-coded reference frame is accessed for subsequent decoding and display of the selected intra-coded reference frame.
36. The system of Claim 36, wherein the display controller further accesses the extent value in the index data structure so that the display controller accesses only the data in the sectors of the hard drive that correspond to the selected intra-coded reference frames.
37. The system of Claim 30, wherein the storage controller generates the index data structure so that the index data structure also includes data indicative of the location of at least some of the predictive coded reference frames stored in the storage subsystem.
-26-
PCT/US2001/027411 2000-08-31 2001-08-31 Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode WO2002019690A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU2001288693A AU2001288693A1 (en) 2000-08-31 2001-08-31 Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/652,729 2000-08-31
US09/652,729 US6453115B1 (en) 2000-08-31 2000-08-31 Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode

Publications (2)

Publication Number Publication Date
WO2002019690A2 true WO2002019690A2 (en) 2002-03-07
WO2002019690A3 WO2002019690A3 (en) 2002-06-13

Family

ID=24617924

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2001/027411 WO2002019690A2 (en) 2000-08-31 2001-08-31 Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode

Country Status (3)

Country Link
US (1) US6453115B1 (en)
AU (1) AU2001288693A1 (en)
WO (1) WO2002019690A2 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1388862A1 (en) * 2002-08-09 2004-02-11 Broadcom Corporation Method and apparatus to facilitate the implementation of trick modes in a personal video recording system
WO2004014073A2 (en) * 2002-07-30 2004-02-12 Koninklijke Philips Electronics N.V. Trick play behavior controlled by a user
EP1445947A1 (en) * 2003-02-06 2004-08-11 Thomson Licensing S.A. Recording restart when changing video standard
EP1445948A1 (en) * 2003-02-06 2004-08-11 Thomson Licensing S.A. Video recorder and process for recording a digital stream
WO2005116905A2 (en) * 2004-05-20 2005-12-08 Intel Corporation Method, apparatus and system for remote real-time access of multimedia content
WO2007011725A2 (en) * 2005-07-15 2007-01-25 Streaming Networks (Pvt) Ltd. Method and system for providing instant reverse play
EP2164073A1 (en) * 2008-09-12 2010-03-17 Kabushiki Kaisha Toshiba Video data processing apparatus and video data processing method
EP1536648A3 (en) * 2003-11-24 2011-05-11 LG Electronics, Inc. Streaming contents recording method of mobile communication terminal

Families Citing this family (250)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7730300B2 (en) 1999-03-30 2010-06-01 Sony Corporation Method and apparatus for protecting the transfer of data
US7039614B1 (en) 1999-11-09 2006-05-02 Sony Corporation Method for simulcrypting scrambled data to a plurality of conditional access devices
IL132859A (en) * 1999-11-10 2008-07-08 Nds Ltd System for data stream processing
KR100810288B1 (en) * 1999-12-17 2008-03-06 소니 가부시끼 가이샤 Device and method for processing information and recorded medium
US7242719B2 (en) * 2000-12-06 2007-07-10 Koninklijke Philips Electronics N.V. Method and apparatus for space-saving-variable length encoding and decoding
ITMO20010038A1 (en) * 2001-03-06 2002-09-06 Elopak Systems APPARATUS AND METHOD FOR THE PROCESSING OF PLASTIC MATERIAL AND CONTAINER OF FLUID PRODUCT
US7428023B2 (en) 2001-04-19 2008-09-23 Digeo, Inc. Remote control device with integrated display screen for controlling a digital video recorder
US20020149705A1 (en) * 2001-04-12 2002-10-17 Allen Paul G. Contact list for a hybrid communicator/remote control
US7895616B2 (en) 2001-06-06 2011-02-22 Sony Corporation Reconstitution of program streams split across multiple packet identifiers
US7747853B2 (en) 2001-06-06 2010-06-29 Sony Corporation IP delivery of secure digital content
US7124303B2 (en) 2001-06-06 2006-10-17 Sony Corporation Elementary stream partial encryption
GB0117926D0 (en) * 2001-07-23 2001-09-12 Nds Ltd Method for random access to encrypted content
US7218635B2 (en) * 2001-08-31 2007-05-15 Stmicroelectronics, Inc. Apparatus and method for indexing MPEG video data to perform special mode playback in a digital video recorder and indexed signal associated therewith
US8079045B2 (en) 2001-10-17 2011-12-13 Keen Personal Media, Inc. Personal video recorder and method for inserting a stored advertisement into a displayed broadcast stream
JP2003132621A (en) * 2001-10-26 2003-05-09 Matsushita Electric Ind Co Ltd Information recording/reproducing method
US20090282444A1 (en) * 2001-12-04 2009-11-12 Vixs Systems, Inc. System and method for managing the presentation of video
US7292691B2 (en) * 2002-01-02 2007-11-06 Sony Corporation Progressive video refresh slice detection
US7823174B2 (en) 2002-01-02 2010-10-26 Sony Corporation Macro-block based content replacement by PID mapping
US7765567B2 (en) 2002-01-02 2010-07-27 Sony Corporation Content replacement by PID mapping
US7292690B2 (en) * 2002-01-02 2007-11-06 Sony Corporation Video scene change detection
US7242773B2 (en) * 2002-09-09 2007-07-10 Sony Corporation Multiple partial encryption using retuning
KR100983832B1 (en) * 2002-04-26 2010-09-27 소니 주식회사 Encoding device and method, and recording medium
US9161078B2 (en) * 2002-08-14 2015-10-13 Arris Technology, Inc. Methods and apparatus for reducing tune-time delay in a television appliance with personal versatile recorder capabilities
US8818896B2 (en) 2002-09-09 2014-08-26 Sony Corporation Selective encryption with coverage encryption
US7724907B2 (en) 2002-11-05 2010-05-25 Sony Corporation Mechanism for protecting the transfer of digital content
US8572408B2 (en) 2002-11-05 2013-10-29 Sony Corporation Digital rights management of a digital device
US8667525B2 (en) 2002-12-13 2014-03-04 Sony Corporation Targeted advertisement selection from a digital stream
US8645988B2 (en) 2002-12-13 2014-02-04 Sony Corporation Content personalization for digital content
KR100693669B1 (en) * 2003-03-03 2007-03-09 엘지전자 주식회사 Determination of a reference picture for processing a field macroblock
EP1609150A1 (en) * 2003-03-20 2005-12-28 Koninklijke Philips Electronics N.V. Cpi data for steam buffer channels
US6874160B1 (en) 2003-05-01 2005-03-29 Nvidia Corporation Digital video recorder and method of operating the same
US20040258390A1 (en) * 2003-06-20 2004-12-23 Olson Anthony M. Systems and methods for PVR real time distributed storage, playback, and archival of programs on a network
KR100585094B1 (en) * 2003-06-26 2006-05-30 삼성전자주식회사 Method and apparatus for effective writing/reading data in multimedia system
US20040267388A1 (en) * 2003-06-26 2004-12-30 Predictive Media Corporation Method and system for recording and processing of broadcast signals
US7609762B2 (en) * 2003-09-07 2009-10-27 Microsoft Corporation Signaling for entry point frames with predicted first field
US7839930B2 (en) * 2003-11-13 2010-11-23 Microsoft Corporation Signaling valid entry points in a video stream
US7924921B2 (en) * 2003-09-07 2011-04-12 Microsoft Corporation Signaling coding and display options in entry point headers
US8213779B2 (en) * 2003-09-07 2012-07-03 Microsoft Corporation Trick mode elementary stream and receiver system
US7852919B2 (en) 2003-09-07 2010-12-14 Microsoft Corporation Field start code for entry point frames with predicted first field
US7853980B2 (en) * 2003-10-31 2010-12-14 Sony Corporation Bi-directional indices for trick mode video-on-demand
US7519274B2 (en) 2003-12-08 2009-04-14 Divx, Inc. File format for multiple track digital data
US8472792B2 (en) 2003-12-08 2013-06-25 Divx, Llc Multimedia distribution system
US20050138672A1 (en) * 2003-12-22 2005-06-23 Stone Christopher J. Digital video recorder recognizing end of program metadata incorporated in a transport packet stream
CN1284380C (en) * 2003-12-31 2006-11-08 中国科学院计算技术研究所 Reference image buffer region management method
KR20060130096A (en) * 2004-01-08 2006-12-18 코닌클리케 필립스 일렉트로닉스 엔.브이. Marking program boundaries in a personal video recording device
US20050166012A1 (en) * 2004-01-26 2005-07-28 Yong Liu Method and system for cognitive pre-fetching
TWI276979B (en) * 2004-06-09 2007-03-21 Asustek Comp Inc Method and system for downloading data from networks using a network device
US20060093320A1 (en) * 2004-10-29 2006-05-04 Hallberg Bryan S Operation modes for a personal video recorder using dynamically generated time stamps
US8041190B2 (en) 2004-12-15 2011-10-18 Sony Corporation System and method for the creation, synchronization and delivery of alternate content
US7895617B2 (en) 2004-12-15 2011-02-22 Sony Corporation Content substitution editor
KR20060088303A (en) * 2005-02-01 2006-08-04 엘지전자 주식회사 Apparatus and method recording/playing moving picture in digital broadcasting receiver
US20080273698A1 (en) * 2005-04-26 2008-11-06 Koninklijke Philips Electronics, N.V. Device for and a Method of Processing a Data Stream Having a Sequence of Packets and Timing Information Related to the Packets
US8098657B2 (en) * 2005-05-31 2012-01-17 Broadcom Corporation System and method for providing data commonality in a programmable transport demultiplexer engine
US8341527B2 (en) * 2005-06-10 2012-12-25 Aniruddha Gupte File format method and apparatus for use in digital distribution system
KR100716291B1 (en) * 2005-07-27 2007-05-09 삼성전자주식회사 Video Playback Apparatus, Control Method Thereof And Private Video Recorder
US7792144B2 (en) * 2005-11-14 2010-09-07 Broadcom Corporation Processing data packets using navigational hardware assist
US8259789B2 (en) * 2006-02-08 2012-09-04 Adtech Global Solutions, Inc. Methods and systems for picture rate reduction of stored video while under continuous record load
US8185921B2 (en) 2006-02-28 2012-05-22 Sony Corporation Parental control of displayed content using closed captioning
US7515710B2 (en) 2006-03-14 2009-04-07 Divx, Inc. Federated digital rights management scheme including trusted systems
US20070248318A1 (en) * 2006-03-31 2007-10-25 Rodgers Stephane W System and method for flexible mapping of AV vs record channels in a programmable transport demultiplexer/PVR engine
US9679602B2 (en) 2006-06-14 2017-06-13 Seagate Technology Llc Disc drive circuitry swap
US8155207B2 (en) 2008-01-09 2012-04-10 Cisco Technology, Inc. Processing and managing pictures at the concatenation of two video streams
US8873932B2 (en) 2007-12-11 2014-10-28 Cisco Technology, Inc. Inferential processing to ascertain plural levels of picture interdependencies
US20080141091A1 (en) * 2006-12-06 2008-06-12 General Instrument Corporation Method and Apparatus for Recovering From Errors in Transmission of Encoded Video Over a Local Area Network
KR20080062708A (en) * 2006-12-29 2008-07-03 삼성전자주식회사 Digital image reproducing apparatus and method of forward/reverse searching method in digital images
CN103561278B (en) 2007-01-05 2017-04-12 索尼克知识产权股份有限公司 Video distribution system including progressive playback
US7929698B2 (en) * 2007-06-15 2011-04-19 Sony Corporation Selective encryption to enable trick play with enhanced security
US8804845B2 (en) 2007-07-31 2014-08-12 Cisco Technology, Inc. Non-enhancing media redundancy coding for mitigating transmission impairments
US8958486B2 (en) * 2007-07-31 2015-02-17 Cisco Technology, Inc. Simultaneous processing of media and redundancy streams for mitigating impairments
US9305590B2 (en) 2007-10-16 2016-04-05 Seagate Technology Llc Prevent data storage device circuitry swap
US20090113702A1 (en) * 2007-11-01 2009-05-07 Western Digital Technologies, Inc. Disk drive comprising a double sided flex circuit wherein a first side lead provides an etching mask for a second side lead
WO2009065144A1 (en) 2007-11-16 2009-05-22 Divx, Inc. Chunk header incorporating binary flags and correlated variable-length fields
WO2009065137A1 (en) 2007-11-16 2009-05-22 Divx, Inc. Hierarchical and reduced index structures for multimedia files
KR20090072510A (en) * 2007-12-28 2009-07-02 삼성전자주식회사 Display apparatus and control method thereof
US8543230B2 (en) * 2008-05-30 2013-09-24 Nokia Corporation Optimizing seek functionality in media content
US8886022B2 (en) 2008-06-12 2014-11-11 Cisco Technology, Inc. Picture interdependencies signals in context of MMCO to assist stream manipulation
US8699578B2 (en) 2008-06-17 2014-04-15 Cisco Technology, Inc. Methods and systems for processing multi-latticed video streams
US8971402B2 (en) 2008-06-17 2015-03-03 Cisco Technology, Inc. Processing of impaired and incomplete multi-latticed video streams
US9009358B1 (en) 2008-09-23 2015-04-14 Western Digital Technologies, Inc. Configuring a data storage device with a parameter file interlocked with configuration code
US8631145B2 (en) * 2008-10-31 2014-01-14 Sonic Ip, Inc. System and method for playing content on certified devices
US8949883B2 (en) 2009-05-12 2015-02-03 Cisco Technology, Inc. Signalling buffer characteristics for splicing operations of video streams
US8279926B2 (en) 2009-06-18 2012-10-02 Cisco Technology, Inc. Dynamic streaming with latticed representations of video
US8914625B1 (en) 2009-07-31 2014-12-16 Western Digital Technologies, Inc. Automatically configuring a web browser file when booting an operating system from a data storage device
EP2507995A4 (en) 2009-12-04 2014-07-09 Sonic Ip Inc Elementary bitstream cryptographic material transport systems and methods
US9330715B1 (en) 2010-03-22 2016-05-03 Western Digital Technologies, Inc. Mapping of shingled magnetic recording media
US8687306B1 (en) 2010-03-22 2014-04-01 Western Digital Technologies, Inc. Systems and methods for improving sequential data rate performance using sorted data zones
US20110271001A1 (en) * 2010-04-30 2011-11-03 Herve Brelay Methods & apparatuses for a projected pvr experience
US9268499B1 (en) 2010-08-13 2016-02-23 Western Digital Technologies, Inc. Hybrid drive migrating high workload data from disk to non-volatile semiconductor memory
US8879188B1 (en) 2010-08-23 2014-11-04 Western Digital Technologies, Inc. Disk drive employing fly height calibration tracks to account for magnetic entropy and thermal decay
US8954664B1 (en) 2010-10-01 2015-02-10 Western Digital Technologies, Inc. Writing metadata files on a disk
US8930996B2 (en) * 2010-11-05 2015-01-06 Echostar Technologies L.L.C. Apparatus, systems and methods for automatically presenting stored media content at its beginning
US8914534B2 (en) 2011-01-05 2014-12-16 Sonic Ip, Inc. Systems and methods for adaptive bitrate streaming of media stored in matroska container files using hypertext transfer protocol
US9268649B1 (en) 2011-06-23 2016-02-23 Western Digital Technologies, Inc. Disk drive with recent write streams list for data refresh determination
US8812662B2 (en) 2011-06-29 2014-08-19 Sonic Ip, Inc. Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US9189392B1 (en) 2011-06-30 2015-11-17 Western Digital Technologies, Inc. Opportunistic defragmentation during garbage collection
US8990493B1 (en) 2011-06-30 2015-03-24 Western Digital Technologies, Inc. Method and apparatus for performing force unit access writes on a disk
US8447170B2 (en) 2011-08-23 2013-05-21 Echostar Technologies L.L.C. Automatically recording supplemental content
US8660412B2 (en) 2011-08-23 2014-02-25 Echostar Technologies L.L.C. System and method for dynamically adjusting recording parameters
US8627349B2 (en) 2011-08-23 2014-01-07 Echostar Technologies L.L.C. User interface
US9185331B2 (en) 2011-08-23 2015-11-10 Echostar Technologies L.L.C. Storing multiple instances of content
US8437622B2 (en) 2011-08-23 2013-05-07 Echostar Technologies L.L.C. Altering presentation of received content based on use of closed captioning elements as reference locations
US9357159B2 (en) 2011-08-23 2016-05-31 Echostar Technologies L.L.C. Grouping and presenting content
US9621946B2 (en) 2011-08-23 2017-04-11 Echostar Technologies L.L.C. Frequency content sort
US9467708B2 (en) 2011-08-30 2016-10-11 Sonic Ip, Inc. Selection of resolutions for seamless resolution switching of multimedia content
CN108989847B (en) 2011-08-30 2021-03-09 帝威视有限公司 System and method for encoding and streaming video
US8799647B2 (en) 2011-08-31 2014-08-05 Sonic Ip, Inc. Systems and methods for application identification
US8806188B2 (en) 2011-08-31 2014-08-12 Sonic Ip, Inc. Systems and methods for performing adaptive bitrate streaming using automatically generated top level index files
US8964977B2 (en) 2011-09-01 2015-02-24 Sonic Ip, Inc. Systems and methods for saving encoded media streamed using adaptive bitrate streaming
US8909922B2 (en) 2011-09-01 2014-12-09 Sonic Ip, Inc. Systems and methods for playing back alternative streams of protected content protected using common cryptographic information
US8909889B1 (en) 2011-10-10 2014-12-09 Western Digital Technologies, Inc. Method and apparatus for servicing host commands by a disk drive
US9158722B1 (en) 2011-11-02 2015-10-13 Western Digital Technologies, Inc. Data storage device to communicate with a host in a SATA or a USB mode
US9100683B2 (en) * 2011-11-22 2015-08-04 International Business Machines Corporation Optimizing video recorder power usage for DVR network
US9213493B1 (en) 2011-12-16 2015-12-15 Western Digital Technologies, Inc. Sorted serpentine mapping for storage drives
US20130179199A1 (en) 2012-01-06 2013-07-11 Rovi Corp. Systems and methods for granting access to digital content using electronic tickets and ticket tokens
US8996839B1 (en) 2012-01-23 2015-03-31 Western Digital Technologies, Inc. Data storage device aligning partition to boundary of sector when partition offset correlates with offset of write commands
US9063838B1 (en) 2012-01-23 2015-06-23 Western Digital Technologies, Inc. Data storage device shifting data chunks of alignment zone relative to sector boundaries
US8819722B2 (en) 2012-03-15 2014-08-26 Echostar Technologies L.L.C. Smartcard encryption cycling
US9489981B2 (en) 2012-03-15 2016-11-08 Echostar Technologies L.L.C. Successive initialization of television channel recording
US8749910B1 (en) 2012-05-07 2014-06-10 Western Digital Technologies, Inc. Hard disk drive assembly including a NVSM to store configuration data for controlling disk drive operations
US8681442B2 (en) 2012-05-11 2014-03-25 Western Digital Technologies, Inc. Disk drive comprising extended range head proximity sensor
US9128820B1 (en) 2012-06-18 2015-09-08 Western Digital Technologies, Inc. File management among different zones of storage media
US9936267B2 (en) 2012-08-31 2018-04-03 Divx Cf Holdings Llc System and method for decreasing an initial buffering period of an adaptive streaming system
US9383923B1 (en) 2012-10-18 2016-07-05 Western Digital Technologies, Inc. Write pointer management for a disk drive
US8970978B1 (en) 2012-10-22 2015-03-03 Western Digital Technologies, Inc. Disk drive detecting head touchdown by applying DC+AC control signal to fly height actuator
US8793724B2 (en) 2012-11-08 2014-07-29 Eldon Technology Limited Image domain compliance
US8959281B1 (en) 2012-11-09 2015-02-17 Western Digital Technologies, Inc. Data management for a storage device
US8902529B1 (en) 2012-11-20 2014-12-02 Western Digital Technologies, Inc. Dual frequency crystal oscillator
US20140189766A1 (en) * 2012-12-28 2014-07-03 Sling Media Inc. Methods and apparatus for seeking within recorded media stored on a set-top box
US9191457B2 (en) 2012-12-31 2015-11-17 Sonic Ip, Inc. Systems, methods, and media for controlling delivery of content
US9313510B2 (en) 2012-12-31 2016-04-12 Sonic Ip, Inc. Use of objective quality measures of streamed content to reduce streaming bandwidth
US8941941B1 (en) 2013-02-28 2015-01-27 Western Digital Technologies, Inc. Disk drive calibrating touchdown sensor
US8891341B1 (en) 2013-03-11 2014-11-18 Western Digital Technologies, Inc. Energy assisted magnetic recording disk drive using modulated laser light
US9417628B2 (en) 2013-03-13 2016-08-16 Western Digital Technologies, Inc. Production failure analysis system
US9074941B1 (en) 2013-03-14 2015-07-07 Western Digital Technologies, Inc. Systems and methods for measuring ambient and laser temperature in heat assisted magnetic recording
US9053749B1 (en) 2013-03-15 2015-06-09 Western Digital Technologies, Inc. Disk drive comprising a per-drive and per-head fly height filter
US10397292B2 (en) 2013-03-15 2019-08-27 Divx, Llc Systems, methods, and media for delivery of content
US9906785B2 (en) 2013-03-15 2018-02-27 Sonic Ip, Inc. Systems, methods, and media for transcoding video data according to encoding parameters indicated by received metadata
US8922939B1 (en) 2013-04-02 2014-12-30 Western Digital Technologies, Inc. Disk drive generating feed-forward fly height control based on temperature sensitive fly height sensor
US9064542B1 (en) 2013-04-08 2015-06-23 Western Digital Technologies, Inc. Scheduled load of heads to reduce lubricant migration on pole tip and decrease time to ready
US8949521B1 (en) 2013-04-10 2015-02-03 Western Digital Technologies, Inc. Actuator prepositioning for disk drive
US8947816B1 (en) 2013-05-01 2015-02-03 Western Digital Technologies, Inc. Data storage assembly for archive cold storage
US8891193B1 (en) 2013-05-09 2014-11-18 Western Digital Technologies, Inc. Disk drive calibrating threshold and gain of touchdown sensor
US9153287B1 (en) 2013-05-13 2015-10-06 Western Digital Technologies, Inc. Data access for shingled magnetic recording media
US9094737B2 (en) 2013-05-30 2015-07-28 Sonic Ip, Inc. Network video streaming with trick play based on separate trick play files
US9380099B2 (en) 2013-05-31 2016-06-28 Sonic Ip, Inc. Synchronizing multiple over the top streaming clients
US9100687B2 (en) 2013-05-31 2015-08-04 Sonic Ip, Inc. Playback synchronization across playback devices
US9183864B1 (en) 2013-06-13 2015-11-10 Western Digital Technologies, Inc. Disk drive adjusting closed-loop fly height target based on change in open-loop fly height control signal
US9164694B1 (en) 2013-06-19 2015-10-20 Western Digital Technologies, Inc. Data storage device detecting read-before-write conditions and returning configurable return data
US9025270B1 (en) 2013-09-17 2015-05-05 Western Digital Technologies, Inc. Electronic system with current conservation mechanism and method of operation thereof
US9355666B1 (en) 2013-09-30 2016-05-31 Western Digital Technologies, Inc. Disk drive measuring stroke difference between heads by detecting a difference between ramp contact
US9628838B2 (en) 2013-10-01 2017-04-18 Echostar Technologies L.L.C. Satellite-based content targeting
US9099144B1 (en) 2013-10-11 2015-08-04 Western Digital Technologies, Inc. Disk drive evaluating laser performance for heat assisted magnetic recording
US9064525B2 (en) 2013-11-26 2015-06-23 Western Digital Technologies, Inc. Disk drive comprising laser transmission line optimized for heat assisted magnetic recording
US9047917B1 (en) 2013-11-26 2015-06-02 Western Digital Technologies, Inc. Disk drive slider with sense amplifier for coupling to a preamp through a supply/bias line and a read signal line
US9257145B1 (en) 2013-11-27 2016-02-09 Western Digital Technologies, Inc. Disk drive measuring down-track spacing of read sensors
US9013818B1 (en) 2013-12-06 2015-04-21 Western Digital Technologies, Inc. Disk drive measuring reader/writer gap by measuring fractional clock cycle over disk radius
US9021410B1 (en) 2013-12-10 2015-04-28 Western Technologies, Inc. Electronic system with multi-cycle simulation coverage mechanism and method of operation thereof
US8958167B1 (en) 2013-12-23 2015-02-17 Western Digital Technologies, Inc. Detection of disk surface irregularities in data storage devices
US9386067B2 (en) 2013-12-30 2016-07-05 Sonic Ip, Inc. Systems and methods for playing adaptive bitrate streaming content by multicast
US9501393B2 (en) 2014-01-27 2016-11-22 Western Digital Technologies, Inc. Data storage system garbage collection based on at least one attribute
US8908311B1 (en) 2014-01-27 2014-12-09 Western Digital Technologies, Inc. Data storage device writing a multi-sector codeword in segments over multiple disk revolutions
US9864529B1 (en) 2014-01-27 2018-01-09 Western Digital Technologies, Inc. Host compatibility for host managed storage media
US9064504B1 (en) 2014-01-29 2015-06-23 Western Digital Technologies, Inc. Electronic system with media recovery mechanism and method of operation thereof
US9230585B1 (en) 2014-01-31 2016-01-05 Western Digital Technologies, Inc. Per wedge preheat DFH to improve data storage device performance
US9257146B1 (en) 2014-02-11 2016-02-09 Western Digital Technologies, Inc. Data storage device comprising sequence detector compensating for inter-track interference
US8988809B1 (en) 2014-02-18 2015-03-24 Western Digital (Fremont), Llc Disk recording device for writing a radially coherent reference band by measuring relative timing offsets of reference bursts
US9117489B1 (en) 2014-02-18 2015-08-25 Western Digital Technologies, Inc. Data storage device screening heads by verifying defects after defect scan
US9245556B2 (en) 2014-03-10 2016-01-26 Western Digital Technologies, Inc. Disk drive employing multiple read elements to increase radial band for two-dimensional magnetic recording
US9082458B1 (en) 2014-03-10 2015-07-14 Western Digital Technologies, Inc. Data storage device balancing and maximizing quality metric when configuring arial density of each disk surface
US9070406B1 (en) 2014-03-10 2015-06-30 Western Digital Technologies, Inc. Disk drive configuring one-dimensional and two-dimensional recording areas based on read element spacing
US9263088B2 (en) 2014-03-21 2016-02-16 Western Digital Technologies, Inc. Data management for a data storage device using a last resort zone
US8947812B1 (en) 2014-03-27 2015-02-03 Western Digital Technologies, Inc. Data storage device comprising equalizer filter and inter-track interference filter
US9916616B2 (en) 2014-03-31 2018-03-13 Western Digital Technologies, Inc. Inventory management system using incremental capacity formats
US9866878B2 (en) 2014-04-05 2018-01-09 Sonic Ip, Inc. Systems and methods for encoding and playing back video at different frame rates using enhancement layers
US9645752B1 (en) 2014-04-07 2017-05-09 Western Digital Technologies, Inc. Identification of data committed to non-volatile memory by use of notification commands
US9632711B1 (en) 2014-04-07 2017-04-25 Western Digital Technologies, Inc. Processing flush requests by utilizing storage system write notifications
US8976633B1 (en) 2014-04-15 2015-03-10 Western Digital Technologies, Inc. Data storage device calibrating fly height actuator based on laser power for heat assisted magnetic recording
US9123370B1 (en) 2014-04-15 2015-09-01 Western Digital Technologies, Inc. Data storage device calibrating fly height actuator based on laser power for heat assisted magnetic recording
US8988810B1 (en) 2014-04-16 2015-03-24 Western Digital Technologies, Inc. Track measurement for data storage device
US9401165B1 (en) 2014-05-05 2016-07-26 Western Digital Technologies, Inc. Method and system to monitor magnetic head loading and unloading stability for a data storage system
US9245558B1 (en) 2014-05-09 2016-01-26 Western Digital Technologies, Inc. Electronic system with data management mechanism and method of operation thereof
US9075714B1 (en) 2014-05-13 2015-07-07 Western Digital Technologies, Inc. Electronic system with data management mechanism and method of operation thereof
US9251856B1 (en) 2014-05-30 2016-02-02 Western Digial Technologies, Inc. Read failover method and apparatus for a data storage system
US9251844B1 (en) 2014-06-02 2016-02-02 Western Digital Technologies, Inc. Waterfall method and apparatus for a data storage device read system
US9025267B1 (en) 2014-06-09 2015-05-05 Western Digital Technologies, Inc. Data storage device using branch metric from adjacent track to compensate for inter-track interference
US9013821B1 (en) 2014-06-10 2015-04-21 Western Digital Technologies, Inc. Data storage device employing one-dimensional and two-dimensional channels
US8953277B1 (en) 2014-06-16 2015-02-10 Western Digital Technologies, Inc. Data storage device writing tracks on a disk with equal spacing
US9117463B1 (en) 2014-06-23 2015-08-25 Western Digital Technologies, Inc. Data storage device erasing multiple adjacent data tracks to recover from inter-track interference
US9171575B1 (en) 2014-06-23 2015-10-27 Western Digital Technologies, Inc. Data storage device detecting media defects by writing opposite polarity test pattern
US9424864B2 (en) 2014-07-02 2016-08-23 Western Digital Technologies, Inc. Data management for a data storage device with zone relocation
US9001453B1 (en) 2014-07-18 2015-04-07 Western Digital Technologies, Inc. Data storage device calibrating fly height actuator based on read mode touchdown resistance of touchdown sensor
US8953269B1 (en) 2014-07-18 2015-02-10 Western Digital Technologies, Inc. Management of data objects in a data object zone
US9875055B1 (en) 2014-08-04 2018-01-23 Western Digital Technologies, Inc. Check-pointing of metadata
WO2016022979A1 (en) 2014-08-07 2016-02-11 Sonic IP. Inc. Systems and methods for protecting elementary bitstreams incorporating independently encoded tiles
US10572358B1 (en) 2014-09-08 2020-02-25 Western Digital Technologies, Inc. Data management in RAID environment
US9153266B1 (en) 2014-09-11 2015-10-06 Western Digital Technologies, Inc. Data storage device measuring laser protrusion fly height profile
US9600205B1 (en) 2014-09-22 2017-03-21 Western Digital Technologies, Inc. Power aware power safe write buffer
US9117479B1 (en) 2014-09-24 2015-08-25 Western Digital Technologies, Inc. Data storage device calibrating laser write power for heat assisted magnetic recording
US9747928B1 (en) 2014-09-25 2017-08-29 Western Digital Technologies, Inc. Data storage device modifying write operation when a laser mode hop is detected
US9025421B1 (en) 2014-10-08 2015-05-05 Western Digital Technologies, Inc. Data storage device adjusting laser input power to compensate for temperature variations
US9236086B1 (en) 2014-10-15 2016-01-12 Western Digital Technologies, Inc. Methods for reducing operational latency of data storage systems
US9099103B1 (en) 2014-10-21 2015-08-04 Western Digital Technologies, Inc. Heat assisted magnetic recording withinterlaced high-power heated and low-power heated tracks
US9129628B1 (en) 2014-10-23 2015-09-08 Western Digital Technologies, Inc. Data management for data storage device with different track density regions
US9123382B1 (en) 2014-10-28 2015-09-01 Western Digital Technologies, Inc. Non-volatile caching for sequence of data
US9230605B1 (en) 2014-12-01 2016-01-05 Western Digital Technologies, Inc. Data storage device maximizing areal density based on a target quality metric
US10282371B1 (en) 2014-12-02 2019-05-07 Western Digital Technologies, Inc. Object storage device with probabilistic data structure
US9269393B1 (en) 2014-12-08 2016-02-23 Western Digital Technologies, Inc. Electronic system with data refresh mechanism and method of operation thereof
US10282096B1 (en) 2014-12-17 2019-05-07 Western Digital Technologies, Inc. Identification of data with predetermined data pattern
US9281009B1 (en) 2014-12-18 2016-03-08 Western Digital Technologies, Inc. Data storage device employing variable size interleave written track segments
US9842622B1 (en) 2014-12-23 2017-12-12 Western Digital Technologies, Inc. Data storage device having improved read failure tolerance
US9257143B1 (en) 2014-12-23 2016-02-09 Western Digital Technologies, Inc. Precautionary measures for data storage device environmental conditions
US9076474B1 (en) 2014-12-23 2015-07-07 Western Digital Technologies, Inc. Data storage device attenuating thermal decay effect on fly height measurement
US9311939B1 (en) 2014-12-23 2016-04-12 Western Digital Technologies, Inc. Write-through media caching
US9257134B1 (en) 2014-12-24 2016-02-09 Western Digital Technologies, Inc. Allowing fast data zone switches on data storage devices
EP3910904A1 (en) 2015-01-06 2021-11-17 DivX, LLC Systems and methods for encoding and sharing content between devices
US9756378B2 (en) 2015-01-07 2017-09-05 Echostar Technologies L.L.C. Single file PVR per service ID
CN105847825A (en) * 2015-01-16 2016-08-10 杭州海康威视数字技术股份有限公司 Encoding, index storage and access methods for video encoding code stream and corresponding apparatus
US9099134B1 (en) 2015-01-27 2015-08-04 Western Digital Technologies, Inc. Data storage device employing multiple jog profiles for a butterfly written disk surface
US10365836B1 (en) 2015-01-27 2019-07-30 Western Digital Technologies, Inc. Electronic system with declustered data protection by parity based on reliability and method of operation thereof
US9672107B1 (en) 2015-02-11 2017-06-06 Western Digital Technologies, Inc. Data protection for a data storage device
SG11201706160UA (en) 2015-02-27 2017-09-28 Sonic Ip Inc Systems and methods for frame duplication and frame extension in live video encoding and streaming
US9933955B1 (en) 2015-03-05 2018-04-03 Western Digital Technologies, Inc. Power safe write buffer for data storage device
US9318137B1 (en) 2015-03-13 2016-04-19 Western Digital Technologies, Inc. Data storage device executing retry operation by buffering signal samples at different radial offsets
US9196302B1 (en) 2015-03-18 2015-11-24 Western Digital Technologies, Inc. Electronic system with media maintenance mechanism and method of operation thereof
US9870281B1 (en) 2015-03-20 2018-01-16 Western Digital Technologies, Inc. Power loss mitigation for data storage device
US9183877B1 (en) 2015-03-20 2015-11-10 Western Digital Technologies, Inc. Data storage device comprising two-dimensional data dependent noise whitening filters for two-dimensional recording
US9214186B1 (en) 2015-03-23 2015-12-15 Western Digital Technologies, Inc. Data storage device measuring radial offset between read element and write element
US9368131B1 (en) 2015-04-03 2016-06-14 Western Digital (Fremont), Llc Data storage device employing mirrored cross-track profiles for top and bottom disk surfaces
US9502068B1 (en) 2015-04-08 2016-11-22 Western Digital Technologies, Inc. Data storage device updating laser power during non-write mode for heat assisted magnetic recording
US9361938B1 (en) 2015-04-16 2016-06-07 Western Digital Technologies, Inc. Disk defect management for a data storage device
US9472219B1 (en) 2015-05-01 2016-10-18 Western Digital Technologies, Inc. Data storage device calibrating parameter for heat assisted magnetic recording
US9588898B1 (en) 2015-06-02 2017-03-07 Western Digital Technologies, Inc. Fullness control for media-based cache operating in a steady state
US9466321B1 (en) 2015-06-05 2016-10-11 Western Digital Technologies, Inc. Angular position tracking of data accesses to mitigate risk of data loss
US9639287B1 (en) 2015-06-29 2017-05-02 Western Digital Technologies, Inc. Write command reporting
US9842617B1 (en) 2015-06-29 2017-12-12 Western Digital Technologies, Inc. Electronic system with head management mechanism and method of operation thereof
US9368132B1 (en) 2015-09-04 2016-06-14 Western Digital Technologies, Inc. Data storage device employing differential write data signal and differential write pattern signal
US9437242B1 (en) 2015-09-14 2016-09-06 Western Digital Technologies, Inc. Data storage device employing different frequency preambles in adjacent data tracks
US9959052B1 (en) 2015-09-17 2018-05-01 Western Digital Technologies, Inc. Media based cache for data storage device
US9761273B1 (en) 2015-11-03 2017-09-12 Western Digital Technologies, Inc. Data storage device encoding and interleaving codewords to improve trellis sequence detection
US10063257B1 (en) 2015-11-03 2018-08-28 Western Digital Technologies, Inc. Data storage device encoding and interleaving codewords to improve trellis sequence detection
US10056920B1 (en) 2015-11-03 2018-08-21 Western Digital Technologies, Inc. Data storage device encoding and interleaving codewords to improve trellis sequence detection
US10075292B2 (en) 2016-03-30 2018-09-11 Divx, Llc Systems and methods for quick start-up of playback
US10231001B2 (en) 2016-05-24 2019-03-12 Divx, Llc Systems and methods for providing audio content during trick-play playback
US10129574B2 (en) 2016-05-24 2018-11-13 Divx, Llc Systems and methods for providing variable speeds in a trick-play mode
US10148989B2 (en) 2016-06-15 2018-12-04 Divx, Llc Systems and methods for encoding video content
US10498795B2 (en) 2017-02-17 2019-12-03 Divx, Llc Systems and methods for adaptive switching between multiple content delivery networks during adaptive bitrate streaming
WO2019084972A1 (en) * 2017-11-06 2019-05-09 深圳市大疆创新科技有限公司 Streaming media live broadcast method and system
CA3134561A1 (en) 2019-03-21 2020-09-24 Divx, Llc Systems and methods for multimedia swarms
US11036435B2 (en) * 2019-08-30 2021-06-15 Western Digital Technologies, Inc. Search time optimization in solid-state devices
US11375286B1 (en) * 2020-12-30 2022-06-28 Western Digital Technologies, Inc. Pre-fetch of data using seek intervals

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5949948A (en) * 1995-11-20 1999-09-07 Imedia Corporation Method and apparatus for implementing playback features for compressed video data
US5959690A (en) * 1996-02-20 1999-09-28 Sas Institute, Inc. Method and apparatus for transitions and other special effects in digital motion video
US6021250A (en) * 1994-07-29 2000-02-01 Sharp Kabushiki Kaisha Coded data control device
US6141486A (en) * 1993-01-13 2000-10-31 Hitachi America, Ltd. Methods and apparatus for recording digital data including sync block and track number information for use during trick play operation

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5377051A (en) * 1993-01-13 1994-12-27 Hitachi America, Ltd. Digital video recorder compatible receiver with trick play image enhancement

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6141486A (en) * 1993-01-13 2000-10-31 Hitachi America, Ltd. Methods and apparatus for recording digital data including sync block and track number information for use during trick play operation
US6021250A (en) * 1994-07-29 2000-02-01 Sharp Kabushiki Kaisha Coded data control device
US5949948A (en) * 1995-11-20 1999-09-07 Imedia Corporation Method and apparatus for implementing playback features for compressed video data
US5959690A (en) * 1996-02-20 1999-09-28 Sas Institute, Inc. Method and apparatus for transitions and other special effects in digital motion video

Cited By (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004014073A2 (en) * 2002-07-30 2004-02-12 Koninklijke Philips Electronics N.V. Trick play behavior controlled by a user
WO2004014073A3 (en) * 2002-07-30 2004-06-03 Koninkl Philips Electronics Nv Trick play behavior controlled by a user
US7826718B2 (en) 2002-08-09 2010-11-02 Broadcom Corporation Method and apparatus to facilitate the efficient implementation of trick modes in a personal video recording system
US8879896B2 (en) 2002-08-09 2014-11-04 Broadcom Corporation Method and apparatus to facilitate the efficient implementation of trick modes in a personal video recording system
EP1388862A1 (en) * 2002-08-09 2004-02-11 Broadcom Corporation Method and apparatus to facilitate the implementation of trick modes in a personal video recording system
EP1445947A1 (en) * 2003-02-06 2004-08-11 Thomson Licensing S.A. Recording restart when changing video standard
EP1445948A1 (en) * 2003-02-06 2004-08-11 Thomson Licensing S.A. Video recorder and process for recording a digital stream
EP1536648A3 (en) * 2003-11-24 2011-05-11 LG Electronics, Inc. Streaming contents recording method of mobile communication terminal
WO2005116905A3 (en) * 2004-05-20 2006-01-19 Intel Corp Method, apparatus and system for remote real-time access of multimedia content
WO2005116905A2 (en) * 2004-05-20 2005-12-08 Intel Corporation Method, apparatus and system for remote real-time access of multimedia content
WO2007011725A3 (en) * 2005-07-15 2007-05-03 Streaming Networks Pvt Ltd Method and system for providing instant reverse play
US7471875B2 (en) 2005-07-15 2008-12-30 Streaming Networks (Pvt.) Ltd. Method and system for providing instant reverse play
WO2007011725A2 (en) * 2005-07-15 2007-01-25 Streaming Networks (Pvt) Ltd. Method and system for providing instant reverse play
EP2164073A1 (en) * 2008-09-12 2010-03-17 Kabushiki Kaisha Toshiba Video data processing apparatus and video data processing method
CN101673573B (en) * 2008-09-12 2013-01-02 株式会社东芝 Video data processing apparatus and video data processing method
US8977103B2 (en) 2008-09-12 2015-03-10 Kabushiki Kaisha Toshiba Video data processing apparatus and video data processing method

Also Published As

Publication number Publication date
WO2002019690A3 (en) 2002-06-13
US6453115B1 (en) 2002-09-17
AU2001288693A1 (en) 2002-03-13

Similar Documents

Publication Publication Date Title
US6453115B1 (en) Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode
KR100958325B1 (en) Method and apparatus for trick mode playback of an mpeg video presentation recorded on a storage medium
US5768466A (en) Method of and apparatus for reverse playback of a time-division -multiplexed signal
CA2432170C (en) Method and apparatus for storing a stream of video data on a storage medium
US7177522B2 (en) System and method for personal video recording
US6775461B2 (en) Data management method for recorded programs stored on a digital recording device
KR100318590B1 (en) Digital recording/reproduction apparatus
EP0971543B1 (en) Image data processing method
US7342967B2 (en) System and method for enhancing performance of personal video recording (PVR) functions on hits digital video streams
JP2003158724A (en) System and method for indexing mpeg video data in order to perform special mode reproduction in digital video recorder
KR20080044828A (en) Method and system for providing instant replay
JPH08506229A (en) Digital video tape recorder for digital HDTV
US8953930B2 (en) System and method for personal video recording
JP4726267B2 (en) Encoded video signal format
US20030219235A1 (en) Recording device, recording method, and computer-readable program
JP3156597B2 (en) Image information decoding and reproducing apparatus and image information decoding and reproducing method
JP4468497B2 (en) Method and apparatus for reproducing original data of digitally encoded video film
JP3132479B2 (en) Compressed stream decoding method and compressed stream decoding device
JP5099958B2 (en) Trick mode for bidirectional prediction frames
US20070150440A1 (en) Method and circuit for retrieving data
JP2002218396A (en) Information playback apparatus, information playback method, recording medium and program
JP2001128120A (en) Encoded bit stream recording and/or reproducing device, and recording disk medium

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PH PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: A3

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PH PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

32PN Ep: public notification in the ep bulletin as address of the adressee cannot be established

Free format text: NOTING OF LOSS OF RIGHTS PURSUANT TO RULE 69(1) EPC, EPO FORM 1205A DATED 16/06/03

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: JP