US20090196357A1 - Trick Mode Operations - Google Patents
Trick Mode Operations Download PDFInfo
- Publication number
- US20090196357A1 US20090196357A1 US12/389,588 US38958809A US2009196357A1 US 20090196357 A1 US20090196357 A1 US 20090196357A1 US 38958809 A US38958809 A US 38958809A US 2009196357 A1 US2009196357 A1 US 2009196357A1
- Authority
- US
- United States
- Prior art keywords
- parameters
- trick mode
- picture sets
- decoded
- picture
- Prior art date
- Legal status (The legal status 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 status listed.)
- Abandoned
Links
- 238000000034 method Methods 0.000 claims abstract description 55
- 238000004891 communication Methods 0.000 claims abstract description 21
- 238000012545 processing Methods 0.000 description 24
- 230000006835 compression Effects 0.000 description 13
- 238000007906 compression Methods 0.000 description 13
- 230000002441 reversible effect Effects 0.000 description 9
- 230000005540 biological transmission Effects 0.000 description 7
- 230000008569 process Effects 0.000 description 6
- 230000000694 effects Effects 0.000 description 5
- 238000010586 diagram Methods 0.000 description 4
- 238000004590 computer program Methods 0.000 description 3
- 230000006837 decompression Effects 0.000 description 3
- 230000001419 dependent effect Effects 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000004044 response Effects 0.000 description 3
- 238000012546 transfer Methods 0.000 description 3
- 101001136140 Pinus strobus Putative oxygen-evolving enhancer protein 2 Proteins 0.000 description 2
- 230000008901 benefit Effects 0.000 description 2
- 239000000872 buffer Substances 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000011022 operating instruction Methods 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 101000600488 Pinus strobus Putative phosphoglycerate kinase Proteins 0.000 description 1
- 239000002131 composite material Substances 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 230000009191 jumping Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000010363 phase shift Effects 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 230000002123 temporal effect Effects 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/41—Structure of client; Structure of client peripherals
- H04N21/414—Specialised client platforms, e.g. receiver in car or embedded in a mobile appliance
- H04N21/4147—PVR [Personal Video Recorder]
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B27/00—Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
- G11B27/10—Indexing; Addressing; Timing or synchronising; Measuring tape travel
- G11B27/102—Programmed access in sequence to addressed parts of tracks of operating record carriers
- G11B27/105—Programmed access in sequence to addressed parts of tracks of operating record carriers of operating discs
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/41—Structure of client; Structure of client peripherals
- H04N21/426—Internal components of the client ; Characteristics thereof
- H04N21/42661—Internal components of the client ; Characteristics thereof for reading from or writing on a magnetic storage medium, e.g. hard disk drive
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/432—Content retrieval operation from a local storage medium, e.g. hard-disk
- H04N21/4325—Content retrieval operation from a local storage medium, e.g. hard-disk by playing back content from the storage medium
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/433—Content storage operation, e.g. storage operation in response to a pause request, caching operations
- H04N21/4334—Recording operations
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/78—Television signal recording using magnetic recording
- H04N5/782—Television signal recording using magnetic recording on tape
- H04N5/783—Adaptations for reproducing at a rate different from the recording rate
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/16—Analogue secrecy systems; Analogue subscription systems
- H04N7/173—Analogue secrecy systems; Analogue subscription systems with two-way working, e.g. subscriber sending a programme selection signal
- H04N7/17309—Transmission or handling of upstream communications
- H04N7/17318—Direct or substantially direct transmission and handling of requests
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11B—INFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
- G11B2220/00—Record carriers by type
- G11B2220/20—Disc-shaped record carriers
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/765—Interface circuits between an apparatus for recording and another apparatus
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/765—Interface circuits between an apparatus for recording and another apparatus
- H04N5/775—Interface circuits between an apparatus for recording and another apparatus between a recording apparatus and a television receiver
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/76—Television signal recording
- H04N5/78—Television signal recording using magnetic recording
- H04N5/781—Television signal recording using magnetic recording on disks or drums
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/79—Processing of colour television signals in connection with recording
- H04N9/80—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback
- H04N9/804—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components
- H04N9/8042—Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback involving pulse code modulation of the colour picture signal components involving data reduction
Definitions
- the present invention is generally related to trick modes, and more particularly related to trick modes for compressed video streams.
- Digital video compression methods work by exploiting data redundancy in a video sequence (i.e., a sequence of digitized pictures).
- a video sequence i.e., a sequence of digitized pictures.
- redundancies exploited in a video sequence, namely, spatial and temporal, as is the case in existing video coding standards.
- ISO/IEC International Standard IS11172-2 “Information technology—Coding of moving pictures and associated audio for digital storage media at up to about 1.5 Mbits/s—Part 2: video,” 1993;
- ITU-T Recommendation H-262 (1996): “Generic coding of moving pictures and associated audio information: Video,” (ISO/IEC 13818-2);
- ITU-T Recommendation H.261 (1993): “Video codec for audiovisual services at px64 kbits/s”; (4) Draft ITU-T Recommendation H.263 (1995): “Video codec for low bitrate communications.”
- Compressed video streams typically include independent and dependent frames.
- An independent frame is a frame that is coded using information only from itself whereas a dependent frame is a frame that is coded using information from one or more other frames.
- An example of an independent frame is an Intra frame (I-frame).
- I-frames are compressed by exploiting the internal spatial redundancy of each macroblock independently of reference pictures.
- the first picture of a picture sequence is typically, but not necessarily, an I-frame.
- Examples of dependent frames are Predictive frames (P-frames) and bi-directional frames (B-frames).
- P-frames are pictures in which macroblocks can be compressed by predicting their value from a past reference picture.
- a past reference picture is a picture, either an I or another P-frame that is to be displayed prior to the current picture.
- B-frames are pictures in which macroblocks can be compressed by predicting their value from a past reference picture and a future reference picture.
- a future reference picture is a picture, either an I or another
- a compressed video stream may be used to provide trick modes such as, for example, fast-forward playback and reverse playback.
- Providing trick modes for a compressed video stream has traditionally required the presence of I-frames in the video stream.
- U.S. Pat. No. 6,057,832 discloses one method whereby MPEG-2 stream containing I-frames may be used to provide trick mode functionality.
- some MPEG-2 streams such as for example, HITS (Headend In The Sky) streams, do not contain I-frames or a typical grouping of pictures and are therefore incapable of providing multiple playback modes using traditional methods. Therefore, there exists a need for systems and methods for providing trick mode functionality in connection with compressed video streams that do not include a certain type of frames.
- FIG. 1 is a high-level block diagram depicting a non-limiting example of a subscriber television system.
- FIG. 2 is a block diagram of a DHCT in accordance with one embodiment of the present invention.
- FIG. 3 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted in FIG. 2 .
- FIG. 4 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted in FIG. 2 .
- FIG. 5 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted in FIG. 2 .
- FIG. 6 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted in FIG. 2 .
- FIG. 1 is a block diagram depicting a non-limiting example of a subscriber television system (STS) 100 .
- the STS 100 includes a headend 110 and a DHCT 200 that are coupled via a network 130 .
- the DHCT 200 is typically situated at a user's residence or place of business and may be a stand-alone unit or integrated into another device such as, for example, the display device 140 or a personal computer (not shown).
- the DHCT 200 receives signals (video, audio and/or other data) including, for example, MPEG-2 streams, among others, from the headend 110 through the network 130 and provides any reverse information to the headend 110 through the network 130 .
- the network 130 may be any suitable means for communicating television services data including, for example, a cable television network or a satellite television network, among others.
- the headend 110 may include one or more server devices (not shown) for providing video, audio, and textual data to client devices such as DHCT 200 .
- the headend 110 and the DHCT 200 cooperate to provide a user with television functionality including, for example, television programs, an interactive program guide (IPG), and/or video-on-demand (VOD) presentations.
- the television services are provided via the display device 140 which is typically a television set.
- the display device 140 may also be any other device capable of displaying video images including, for example, a computer monitor.
- FIG. 2 is a block diagram illustrating selected components of a DHCT 200 in accordance with one embodiment of the present invention. It will be understood that the DHCT 200 shown in FIG. 2 is merely illustrative and should not be construed as implying any limitations upon the scope of the preferred embodiments of the invention. For example, in another embodiment, the DHCT 200 may have fewer, additional, and/or different components than illustrated in FIG. 2 .
- a DHCT 200 is typically situated at a user's residence or place of business and may be a stand alone unit or integrated into another device such as, for example, a television set or a personal computer.
- the DHCT 200 preferably includes a communications interface 242 for receiving signals (video, audio and/or other data) from the headend 110 through the network 130 ( FIG. 1 ) and for providing any reverse information to the headend 110 .
- the DHCT 200 further preferably includes at least one processor 244 for controlling operations of the DHCT 200 , an output system 248 for driving the television display 140 , and a tuner system 245 for tuning to a particular television channel or frequency and for sending and receiving various types of data to/from the headend 110 .
- the DHCT 200 may, in another embodiment, include multiple tuners for receiving downloaded (or transmitted) data.
- Tuner system 245 can select from a plurality of transmission signals provided by the subscriber television system 100 .
- Tuner system 245 enables the DHCT 200 to tune to downstream media and data transmissions, thereby allowing a user to receive digital or analog media content via the subscriber television system.
- the tuner system 245 includes, in one implementation, an out-of-band tuner for bi-directional quadrature phase shift keying (QPSK) data communication and a quadrature amplitude modulation (QAM) tuner (in band) for receiving television signals. Additionally, a receiver 246 receives externally-generated user inputs or commands from an input device such as, for example, a remote control.
- QPSK quadrature phase shift keying
- QAM quadrature amplitude modulation
- the DHCT 200 may include one or more wireless or wired interfaces, also called communication ports 274 , for receiving and/or transmitting data to other devices.
- the DHCT 200 may feature USB (Universal Serial Bus), Ethernet, IEEE-1394, serial, and/or parallel ports, etc.
- DHCT 200 may also include an analog video input port for receiving analog video signals.
- User input may be provided via an input device such as, for example, a hand-held remote control device or a keyboard.
- the DHCT 200 includes signal processing system 214 , which comprises a demodulating system 213 and a transport demultiplexing and parsing system 215 (herein demultiplexing system) for processing broadcast media content and/or data.
- signal processing system 214 comprises a demodulating system 213 and a transport demultiplexing and parsing system 215 (herein demultiplexing system) for processing broadcast media content and/or data.
- One or more of the components of the signal processing system 214 can be implemented with software, a combination of software and hardware, or preferably in hardware.
- Demodulating system 213 comprises functionality for demodulating analog or digital transmission signals. For instance, demodulating system 213 can demodulate a digital transmission signal in a carrier frequency that was modulated, among others, as a QAM-modulated signal.
- demultiplexing system 215 When tuned to a carrier frequency corresponding to an analog TV signal, demultiplexing system 215 is bypassed and the demodulated analog TV signal that is output by demodulating system 213 is instead routed to analog video decoder 216 .
- Analog video decoder 216 converts the analog TV signal into a sequence of digitized pictures and their respective digitized audio. Digitized pictures and respective audio output by analog video decoder 216 are presented at the input of compression engine 217 .
- Compression engine 217 processes the sequence of digitized pictures and digitized audio and converts them into compressed video and audio streams, respectively.
- the compressed video and audio streams are produced in accordance with the syntax and semantics of a designated audio and video coding method, such as, for example, MPEG-2, so that they can be interpreted by video decoder 223 and audio decoder 225 for decompression and reconstruction at a future time.
- Each compressed stream consists of a sequence of data packets containing a header and a payload. Each header contains a unique packet identification code, or PID, associated with the respective compressed stream.
- Compression engine 217 multiplexes the audio and video compressed streams into a transport stream, such as an MPEG-2 transport stream. Furthermore, compression engine 217 can preferably compress audio and video corresponding to more than one program in parallel (e.g., two tuned analog TV signals when DHCT 200 has multiple tuners) and to multiplex the respective audio and video compressed streams into a single transport stream. Output of compressed streams and/or transport streams produced by compression engine 217 is input to signal processing system 214 . Parsing capabilities 215 within signal processing 214 allow for interpretation of sequence and picture headers, and in a preferred embodiment, annotating their locations within their respective compressed stream as well as other useful information for future retrieval from storage device 273 , as described below.
- a compressed analog video stream (e.g., corresponding to a TV program episode or show) that is received via a tuned analog transmission channel can be output as a transport stream by signal processing 214 and presented as input for storage in storage device 273 via interface 275 .
- the packetized compressed streams can be also output by signal processing 214 and presented as input to media engine 222 for decompression by video decoder 223 and audio decoder 225 for subsequent output to the display device 140 ( FIG. 1 ).
- Demultiplexing system 215 can include MPEG-2 transport demultiplexing. When tuned to carrier frequencies carrying a digital transmission signal, demultiplexing system 215 enables the separation of packets of data, corresponding to the desired video streams, for further processing. Concurrently, demultiplexing system 215 precludes further processing of packets in the multiplexed transport stream that are irrelevant or not desired such as, for example, packets of data corresponding to other video streams.
- the components of signal processing system 214 are preferably capable of QAM demodulation, forward error correction, demultiplexing MPEG-2 transport streams, and parsing packetized elementary streams and elementary streams.
- the signal processing system 214 further communicates with processor 244 via interrupt and messaging capabilities of DHCT 200 .
- the processor 244 annotates the location of pictures within the compressed stream as well as other pertinent information. The annotations by the processor 244 enable normal playback or other playback modes of the stored compressed stream of the respective compressed stream.
- a compressed video stream corresponding to a tuned carrier frequency carrying a digital transmission signal can be output as a transport stream by signal processing 214 and presented as input for storage in storage device 273 via interface 275 .
- the packetized compressed streams can be also output by signal processing system 214 and presented as input to media engine 222 for decompression by the video decoder 223 and audio decoder 225 .
- signal processing system 214 may include other components not shown, including memory, decryptors, samplers, digitizers (e.g. analog-to-digital converters), and multiplexers, among others. Further, other embodiments will be understood, by those having ordinary skill in the art, to be within the scope of the preferred embodiments of the present invention. For example, analog signals (e.g., NTSC) may bypass one or more elements of the signal processing system 214 and may be forwarded directly to the output system 248 . Outputs presented at corresponding next-stage inputs for the aforementioned signal processing flow may be connected via accessible DRAM 252 in which an outputting device stores the output data and from which an inputting device retrieves it.
- analog signals e.g., NTSC
- Outputs presented at corresponding next-stage inputs for the aforementioned signal processing flow may be connected via accessible DRAM 252 in which an outputting device stores the output data and from which an inputting device retrieves it.
- Outputting and inputting devices may include analog video decoder 216 , compression engine 217 , media engine 222 , signal processing system 214 , and components or sub-components thereof. It will be understood by those having ordinary skill in the art that components of signal processing system 214 can be spatially located in different areas of the DHCT 200 .
- Parser 215 parses (i.e., reads and interprets) compressed streams to interpret sequence headers and picture headers, and deposits a transport stream carrying compressed streams into DRAM 252 .
- Processor 244 causes the transport stream to be transferred from DRAM 252 to the storage device 273 via interface 275 .
- processor 244 interprets the data output by signal processing system 214 and generates ancillary data in the form of a table or data structure comprising the relative or absolute location of the beginning of certain pictures in the compressed video stream. Such ancillary data is used to facilitate the retrieval of desired video data during future operations.
- a plurality of tuners and respective demodulating systems 213 , demultiplexing systems 215 , and signal processing systems 214 may simultaneously receive and process a plurality of respective broadcast digital video streams.
- a single demodulating system 213 , a single demultiplexing system 215 , and a single signal processing system 214 each with sufficient processing capabilities may be used to process a plurality of digital video streams.
- a first tuner in tuning system 245 receives an analog video signal corresponding to a first video stream and a second tuner simultaneously receives a digital compressed stream corresponding to a second video stream.
- the first video stream is converted into a digital format.
- the second video stream and/or a compressed digital version of the first video stream are routed to the hard disk 201 of storage device 273 . Data annotations for each of the two streams are performed to facilitate future retrieval of the video streams from the storage device 273 .
- the first video stream and/or the second video stream may also be routed to media engine 222 for decoding and subsequent presentation via display device 140 ( FIG. 1 ).
- the first video stream may be routed to media engine 222 in either a digital or analog format.
- compression engine 217 can output formatted MPEG-2 or MPEG-1 packetized elementary streams (PES) inside a transport stream, all compliant to the syntax and semantics of the ISO MPEG-2 standard. Alternatively, compression engine 217 can output other digital formats that are compliant to other standards.
- the digital compressed streams output by compression engine 217 corresponding to a first video stream are routed to demultiplexing system 215 .
- Demultiplexing system 215 parses (i.e., reads and interprets) the transport stream generated by compression engine 217 without disturbing its content and deposits the transport stream into DRAM 252 .
- Processor 244 causes transport stream in DRAM 252 to be transferred to the storage device 273 .
- demultiplexing system 215 while parsing the transport stream, demultiplexing system 215 outputs to DRAM 252 ancillary data in the form of a table or data structure comprising the relative or absolute location of the beginning of certain pictures in the compressed media content stream for the first video stream for facilitating retrieval during future operations. In this way, random access operations such as fast forward, rewind, and jumping to a location in the compressed video stream can be attained. Additional pertinent data is also written in the tables, as described below
- a plurality of compression engines 217 may be used to simultaneously compress a plurality of analog video streams.
- a single compression engine 217 with sufficient processing capabilities may be used to compress a plurality of analog video streams.
- Compressed digital versions of respective analog video streams may be routed to the hard disk 201 of storage device 273 .
- Data annotations for each of the video streams may be performed to facilitate future retrieval of the video streams from the storage device 273 .
- only a subset of the total number of compressed digital video signals may be routed to the storage device 273 .
- Any of the received video streams can also be routed simultaneously to media engine 222 for decoding and subsequent presentation via display device 140 .
- the DHCT 200 includes at least one storage device 273 for storing video streams received by the DHCT 200 .
- a PVR application 277 in cooperation with the operating system 253 and the device driver 211 , effects, among other functions, read and/or write operations to the storage device 273 .
- references to write and/or read operations to the storage device 273 will be understood to mean operations to the medium or media of the storage device 273 unless indicated otherwise.
- the device driver 211 is a software module preferably resident in the operating system 253 .
- the device driver 211 under management of the operating system 253 , communicates with the storage device controller 279 to provide the operating instructions for the storage device 273 .
- Storage device 273 is preferably internal to DHCT 200 , coupled to a common bus 205 through a communication interface 275 .
- the communication interface 275 is preferably an integrated drive electronics (IDE) or small computer system interface (SCSI), although another interface such as, for example, IEEE-1394 or USB, among others, may be used.
- IDE integrated drive electronics
- SCSI small computer system interface
- the storage device 273 can be externally connected to the DHCT 200 via a communication port 274 .
- the communication port 274 may be, for example, an IEEE-1394, a USB, a SCSI, or an IDE.
- video streams are received in DHCT 200 via communications interface 242 and stored in a temporary memory cache.
- the temporary memory cache may be a designated section of DRAM 252 or an independent memory attached directly to communication interface 242 .
- the temporary cache is implemented and managed to enable media content transfers to storage device 273 .
- the fast access time and high data transfer rate characteristics of the storage device 273 enable media content to be read from the temporary cache and written to storage device 273 in a sufficiently fast manner. Multiple simultaneous data transfer operations may be implemented so that while data is being transferred from the temporary cache to storage device 273 , additional data may be received and stored in the temporary cache.
- a request for retrieval and playback of a compressed video presentation stored in storage device 273 specifies information that includes the playback mode, direction of playback, entry point of playback with respect to the beginning of the compressed video presentation, and playback speed, if applicable.
- a request for retrieval and playback may also specify the duration of playback.
- the playback mode specified in a request may be normal-playback, fast-reverse-playback, fast-forward-playback, slow-reverse-playback, slow-forward-playback, and pause-display.
- Playback speed is applicable to playback modes other than normal playback and pause display and may be specified as a factor or proportion of the normal playback speed.
- playback speed specification may be 2 ⁇ , 2 ⁇ , 6 ⁇ , 10 ⁇ or 15 ⁇ for fast-forward or fast-reverse playback, where X means “times normal play speed.”
- 1 ⁇ 8 ⁇ , 1 ⁇ 4 ⁇ and 1 ⁇ 2 ⁇ are non-limiting examples for the speed specification in request for slow-forward or slow-reverse playback.
- Direction of playback may be explicit in the playback mode or specified separately as forward or reverse in the specified request according to a predetermined format for a request's specification.
- the entry point for playback is relative to the beginning of the compressed video presentation stored in storage device 273 and may be specified in a number of different ways according to the predetermined format for a request's specification.
- the entry point in the request for which to start playback may be specified in relation to the beginning of the video presentation as elapsed normal playback time, number of pictures, or number of certain types of pictures.
- processor 244 in communication generally with device driver 211 and storage device controller 279 and demultiplexing system 215 effects retrieval of compressed video data, compressed audio data, and data streams from storage device 273 that correspond to one or more video streams specified in request.
- Retrieved streams are deposited in an output cache in storage device 273 , transferred to DRAM 252 , and then processed for playback according to mechanisms that would be understood by those having ordinary skill in the art.
- the video streams are retrieved and routed from the hard disk 201 to the digital video decoder 223 and digital audio decoder 225 simultaneously, and then further processed for subsequent presentation via the display device 140 .
- processor 244 In response to a request for retrieval and playback of a compressed stream stored in storage device 273 for which the playback mode is not “normal playback” or “pause-display,” or for which the entry point is not at the beginning of the compressed video stream, processor 244 in communication generally with device driver 211 and storage device controller 279 reads information in the respective entry in the index table 202 for the requested compressed video stream to retrieve annotation data from storage device 273 that correspond to the requested video streams specified in request. Immediately thereafter under program control, processor 244 retrieves the program information file 203 from storage device 273 and interprets the program information file to compute the entry point location for which to fulfill the specified playback mode in the request.
- information pertaining the characteristics of compressed video stream is contained in program information file 203 and interpreted to fulfill the specified playback mode in the request.
- the requested playback mode is implemented by the processor 244 based on the characteristics of the compressed data, the playback mode specified in the request, and the processing and computing capabilities of DHCT 200 .
- Retrieved streams are deposited in an output cache in storage device 273 , transferred to DRAM 252 , and then processed for playback by processor 244 under program control and in communication with video decoder 223 .
- video streams may retrieved and routed from the hard disk 201 to the digital video decoder 223 and digital audio decoder 225 simultaneously, and then further processed for eventual presentation on a display device 140 .
- Storage device 273 is preferably a hard disk drive but may in an alternative embodiment be any type of magnetic, optical, or semiconductor based storage device.
- the storage device 273 preferably includes at least one hard disk 201 and a controller 279 .
- the controller 279 receives operating instructions from the device driver 211 and implements those instructions to cause read and/or write operations to the hard disk 201 .
- the operating system 253 in cooperation with the device driver 211 , communicates with the storage device controller 279 to format the hard disk 201 .
- the operating system 253 , device driver 211 , and controller 279 cooperate to create a file allocation table (FAT).
- the FAT 204 is where the operating system 253 stores the information about the hard disk clusters and the files associated with those clusters.
- the operating system 253 can determine where a file's data is located by using the directory entry for the file and file allocation table (FAT) 204 entries.
- the directory entry gives information about a directory such as its related files and subdirectories.
- a FAT entry describes the physical locations of data for a video stream file (i.e. the file that the video stream is written to on the hard disk 201 ).
- the FAT 204 also keeps track of which clusters are free, or open, and thus available for use.
- the operating system 253 When an application such as PVR application 277 creates (or extends) a video stream file, the operating system 253 , in cooperation with the device driver 211 , queries the FAT 204 for an available cluster to begin writing the video stream. As a non-limiting example, to buffer a downloaded video stream into the storage device 273 , the PVR application 277 creates a video stream file and video stream file name for the video stream to be downloaded. The operating system 253 , in cooperation with the device driver 211 , checks the FAT 204 for an available, or writable, cluster to write the video stream to.
- the PVR application 277 effects the device driver 211 , through communication with the operating system 253 , to cause the controller 279 to write the downloaded video stream to the available cluster under a particular video stream file name.
- the FAT 204 is then updated with the new video stream file name corresponding to the available cluster. If the video stream requires more data space than what the cluster can offer, the operating system 253 queries the FAT 204 for the location of another available cluster to continue writing the video stream to hard disk space. Upon finding another cluster, the FAT 204 is updated to keep track of which clusters are linked to store a particular video stream under the given video stream file name.
- a multiplicity of clusters may be required to write a file corresponding to a compressed video stream to hard disk 201 .
- the clusters corresponding to one particular video stream file may or may not be adjacent or contiguous clusters.
- the clusters corresponding to a particular video stream file can be fragmented throughout the hard disk space.
- a file allocation table FAT keeps track of which clusters are employed to write a downloaded video stream to the hard disk 201 .
- systems well known to those of ordinary skill in the art, such as defragmentators can be employed to cause the clusters associated with a particular video stream file to be contiguous.
- Input video streams may be received by the DHCT 200 from different sources.
- an input video stream may be any of the following, among others:
- the PVR application 277 provides a user interface that assists the user in navigating to, and between screens for selection and retrieval of previously stored compressed video data.
- the user interface may provide visual status and progress feedback to the user. For instance, during a slow-reverse playback mode, the user interface may display an icon associated with reverse playback along with the speed in effect, and the location of the currently displayed picture in relation to the beginning, end or both of the video presentation.
- the PVR application 277 may also be used to initiate a trick mode operation for a video stream that is stored in storage device 273 .
- the PVR application 277 may be implemented in hardware, software, firmware, or a combination thereof.
- the PVR application 277 is implemented in software or firmware that is stored in a DRAM 52 and that is executed by processor 244 .
- the PVR application 277 which comprises an ordered listing of executable instructions for implementing logical functions, can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions.
- FIG. 3 depicts a non-limiting example of a method 300 in accordance with one embodiment of the present invention.
- the DHCT 200 receives an MPEG-2 stream from the headend 110 ( FIG. 1 ) and then, in step 302 , stores it in hard disk 201 .
- the MPEG-2 stream is made up of multiple picture sequences wherein each picture sequence has a header. The beginning of each picture and picture sequence is determined by a start code.
- the processor 244 creates a corresponding index table 202 as indicated in step 303 .
- the index table 202 consists of elements that point to data in the hard disk 201 that define picture and sequence boundaries in the MPEG-2 stream.
- the index table 202 facilitates the delivery of selected data to the media engine 222 .
- the index table 202 may include the following information about the MPEG-2 stream:
- the processor 244 in step 304 stores program information related to the MPEG-2 stream in a program information file 203 .
- the program information file 203 includes the packet identification codes (PIDs) contained in the MPEG-2 stream as well as a flag that represents whether the stream contains I-frames.
- PIDs packet identification codes
- a determination as to whether the MPEG-2 stream contains I-frames may be made by inspecting a predetermined number of picture sequences; if no I-frame is found within the predetermined number of picture sequences, then the flag is set to false.
- the steps 301 - 304 , or a subset thereof may be performed substantially concurrently or in a different order than shown in FIG. 3 .
- the processor 244 may store data in the index table 202 and the program information file 203 as the MPEG-2 stream is being stored in hard disk 201 .
- FIG. 4 is a flow chart depicting a non-limiting example of a method 400 in accordance with one embodiment of the present invention.
- the method 400 is initiated in step 401 when the DHCT 200 receives user input requesting trick mode functionality.
- the user input may be provided via, for example, a remote control device.
- the processor 244 determines the number of sequential P-frames to be sent to media engine 222 , as indicated in step 402 .
- the number of sequential P-frames to be sent to media engine 222 is determined by the characteristics of the corresponding MPEG-2 stream. As a non-limiting example, the number of sequential P-frames to be sent to media engine 222 may be 10.
- the processor 244 retrieves in step 403 the determined number of sequential P-frames and sends them to media engine 222 .
- the P-frames are retrieved by selecting an element at the current program position from the index table that contains the sequence header information. From the sequence header element, the sequence header location in memory is obtained. From this location in memory, the determined number of sequential P-frames are retrieved and sent to media engine 222 .
- the index table is used to count the number of P-pictures.
- the processor 244 determines in step 404 whether the requested trick mode is still active. If the trick mode is no longer active, then the method 400 terminates in step 405 . However, if the trick mode is still active, then processor 244 repeats step 403 .
- the number of picture sets that are sent to media engine 222 within a given time period is equal to the desired trick mode speed multiplied by the number of picture sets that would need to be decoded in such a time period to achieve a normal play mode. For example, if two picture sets need to be decoded per second to achieve a normal play mode, then to achieve a trick mode speed that is twice as fast as a normal play mode speed, 4 picture sets corresponding to a 2 second normal play period need to be selected and sent to media engine 222 per second. Media engine 222 will then decode and display four picture sets per second to achieve the correct speed. To select the 4 picture sets corresponding to a 2 second normal play period, the time stamp on the picture element is used. In a similar manner as described above 4 ⁇ , 6 ⁇ or n ⁇ speed can be achieved. For rewind mode, the procedure is similar except that the picture sets are selected in the reverse direction.
- the picture sets that are sent to the media engine 222 may overlap. For example, if we assume that each picture set (PS) includes 5 P-frames, that 10 P-frames are decoded for each P-frame that is displayed, then the processor 244 , in response to a request for a fast play mode, may send PS 1 and PS 2 to the media engine 222 , followed by PS 2 and PS 3 , followed by PS 3 and PS 4 , etc (where the numerals refer to the relative sequence of the picture sets in a normal play mode).
- the media engine 222 will output a decoded P-frame from PS 2 after decoding PS 1 and PS 2 and then a decoded P-frame from PS 3 after decoding PS 2 and PS 3 , etc.
- the total number of picture sets that are sent to media engine 222 within a given time period is equal to the desired trick mode speed multiplied by twice the number of picture sets that would need to be decoded in such a time period to achieve a normal play mode.
- the picture sets that are sent to the media engine 222 may not all be contiguous.
- a user requests a fast play speed that is equal to six times (6 ⁇ ) the normal play speed
- the media engine 222 is only capable of decoding 30 frames per second
- the media engine 222 only decodes P-frames during fast play mode
- the corresponding MPEG-2 stream includes 2 B-frames for every P-frame (e.g., B, B, P, B, B, P, B, B, P, B, B, P, etc)
- each picture set is defined as including 5 P-frames among 15 total frames
- the processor 244 may send 2 picture sets to the media engine 222 and then skip 2 picture sets before sending another 2 picture sets.
- the processor 244 may, for example, send the following picture sets to the media engine 222 at the rate of 6 picture sets per second: PS 3 , PS 4 , PS 7 , PS 8 , PS 11 , PS 12 , PS 15 , PS 16 , etc.
- the processor 244 may send 3 picture sets to the media engine 222 and then skip 3 picture sets before sending another 3 picture sets.
- the processor 244 may send the following picture sets to the media engine 222 at the rate of 6 picture sets per second: PS 4 , PS 5 , PS 6 , PS 10 , PS 11 , PS 12 , PS 16 , PS 17 , PS 18 , etc.
- stuffing transport packets may be inserted where a picture set ends and a new picture set starts.
- the stuffing transport packets consist of payload data that are 0xff bytes.
- the discontinuity in the stream is communicated to the decoder by inserting transport packets that have an elementary stream payload consisting of “MPEG-2 user data”.
- a specific byte pattern is sent in the user data to communicate the end of a picture set and the beginning of a new one.
- FIG. 5 depicts a non-limiting example of a decoding method 500 for providing trick mode functionality in accordance with one embodiment of the present invention.
- the method 500 is initiated in step 501 after the media engine 222 receives a series of P-frames to be decoded and a message from the processor 244 instructing the media engine 222 to provide a trick mode operation.
- the media engine 222 decodes in step 502 a first P-frame in the series of P-frames and determines in step 503 if the last P-frame in the series of P-frames has been decoded.
- the media engine 222 decodes the next P-frame in the series of P-frames, as indicated in step 504 , and then returns to step 503 to determine if the last P-frame has been decoded. If the media engine determines in step 503 that the last P-frame in the series of P-frames has been decoded then the media engine outputs the last decoded P-frame a certain number of times, as indicated in step 505 . The media engine 222 then determines in step 506 if the trick mode operation is still active. If the trick mode operation is still active then the media engine returns to step 502 and decodes a first P-frame in another series of P-frames that is received from hard disk 201 .
- step 507 the method 500 terminates as indicated in step 507 . Therefore, although each P-frame is incapable of independently generating a complete picture, by decoding consecutive P-frames each using the previous P-frame as an anchor, a complete picture is eventually created and displayed.
- an MPEG-2 stream includes the following frames: P 1 , B, B, P 2 , B, B, P 3 , B, B, P 4 , B, B, B, P 5 , B, B, P 6 , B, B, P 7 , B, B, P 8 , B, B, B, P 9 , B, B, P 10 , B, B, P 11 , B, B, P 12 , B, B, P 13 , B, B, P 14 , B, B, P 15 , B, B, P 16 , B, B, P 17 , B, B, P 18 , B, B, P 19 , B, B, P 20 , etc., where the numerals designate the relative display order of the P-frames in a normal play mode.
- frames P 121 -P 130 are decoded; frame P 130 is output 10 times, frames P 111 -P 120 are decoded; frame P 120 is output 10 times; frames P 101 -P 110 are decoded; frame P 110 is output 10 times; and so on until the trick mode ends.
- the series of frames that are decoded overlap so as to produce a smoother picture. For example, assuming a 3 ⁇ fast play mode, and assuming an output rate of 30 pictures per second (pps), then frames P 1 -P 10 are decoded; frame P 10 is output 5 times; frames P 6 -P 15 are decoded; frame P 15 is output 5 times; frames P 11 -P 20 are decoded; frame P 20 is output 5 times; frames P 16 -P 25 are decoded; frame P 25 is output 5 times, and so on until the trick mode ends.
- frames P 121 -P 130 are decoded; frame P 130 is output 5 times, frames P 116 -P 125 are decoded; frame P 125 is output 5 times; frames P 111 -P 120 are decoded; frame P 120 is output 5 times; and so on until the trick mode ends.
- the series of frames that are decoded are not contiguous. For example, assuming a 6 ⁇ fast play mode, a 30 pps output rate, and a maximum decoding rate of 30 pps, then frames P 11 -P 20 are decoded; frame P 20 is output 10 times; frames P 31 -P 40 are decoded; frame P 40 is output 10 times; frames P 51 -P 60 are decoded; frame P 60 is output 10 times, and so on until the trick mode is cancelled.
- frames P 121 -P 130 are decoded; frame P 130 is output 10 times; frames P 101 -P 110 are decoded; frame P 110 is output 10 times; frames P 81 -P 90 are decoded; frame P 90 is output 10 times and so on until the trick mode ends.
- FIG. 6 depicts a non-limiting example of a method 600 for providing fast play functionality in accordance with one embodiment of the present invention.
- the method 600 is initiated in step 601 after the media engine 222 receives video data to be decoded and a message from the processor 244 instructing the media engine 222 to provide a fast play operation.
- the media engine 222 decodes in step 602 a certain number of P-frames and then outputs in step 603 the final P-frame among the certain number of P-frames.
- the certain number of P-frames is preferably equal to the number of P-frames that need to be decoded in order to produce a P-frame of a desirable quality.
- the media engine 222 then decodes the next P-frame in step 604 and displays the decoded P-frame in step 605 .
- the media engine 222 determines in step 606 if the trick mode operation is still active. If the trick mode operation is still active then the media engine returns to step 604 and decodes the next P-frame. If the trick mode operation is not longer active, then the method 600 terminates as indicated in step 607 .
- FIGS. 3-6 represent modules, segments, or portions of code which include one or more executable instructions for implementing specific logical functions or steps in a process.
- the functionality provided by each of the methods illustrated in FIGS. 3-6 can also be implemented through hardware (e.g., an application specific integrated circuit (ASIC) and supporting circuitry).
- ASIC application specific integrated circuit
- Each implementation may have a perceived advantage, however. For example, hardware enjoys a speed and, arguably, a reliability advantage over software because hardware testing and verification methods are currently more advanced than software verification methods.
- software can be less expensive than customized hardware and offers greater flexibility in adding or modifying product features.
- a computer-readable medium is an electronic, magnetic, optical, semiconductor, or other physical device or means that can contain or store a computer program or data for use by or in connection with a computer-related system or method.
- the computer program or data may be transferred to another computer-readable medium by any suitable process such as by scanning the computer-readable medium.
- the computer-readable medium could be paper or other suitable medium upon which the computer program can be printed, scanned with an optical scanner, and transferred into the computer's memory or storage.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Databases & Information Systems (AREA)
- Television Signal Processing For Recording (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
Abstract
Description
- This application is a continuation of U.S. application Ser. No. 11/843,711, filed Aug. 23, 2007, which is a continuation of U.S. application Ser. No. 10/038,943, filed Dec. 31, 2001, now U.S. Pat. No. 7,274,857, issued Sep. 25, 2007, which is incorporated herein by reference in its entirety.
- The present invention is generally related to trick modes, and more particularly related to trick modes for compressed video streams.
- Digital video compression methods work by exploiting data redundancy in a video sequence (i.e., a sequence of digitized pictures). There are two types of redundancies exploited in a video sequence, namely, spatial and temporal, as is the case in existing video coding standards. A description of these standards can be found in the following publications, which are hereby incorporated herein by reference: (1) ISO/IEC International Standard IS11172-2, “Information technology—Coding of moving pictures and associated audio for digital storage media at up to about 1.5 Mbits/s—Part 2: video,” 1993; (2) ITU-T Recommendation H-262 (1996): “Generic coding of moving pictures and associated audio information: Video,” (ISO/IEC 13818-2); (3) ITU-T Recommendation H.261 (1993): “Video codec for audiovisual services at px64 kbits/s”; (4) Draft ITU-T Recommendation H.263 (1995): “Video codec for low bitrate communications.”
- Compressed video streams typically include independent and dependent frames. An independent frame is a frame that is coded using information only from itself whereas a dependent frame is a frame that is coded using information from one or more other frames. An example of an independent frame is an Intra frame (I-frame). I-frames are compressed by exploiting the internal spatial redundancy of each macroblock independently of reference pictures. The first picture of a picture sequence is typically, but not necessarily, an I-frame. Examples of dependent frames are Predictive frames (P-frames) and bi-directional frames (B-frames). P-frames are pictures in which macroblocks can be compressed by predicting their value from a past reference picture. A past reference picture is a picture, either an I or another P-frame that is to be displayed prior to the current picture. B-frames are pictures in which macroblocks can be compressed by predicting their value from a past reference picture and a future reference picture. A future reference picture is a picture, either an I or another P-frame that is to be displayed after to the current picture.
- A compressed video stream may be used to provide trick modes such as, for example, fast-forward playback and reverse playback. Providing trick modes for a compressed video stream has traditionally required the presence of I-frames in the video stream. For example, U.S. Pat. No. 6,057,832 (Lev et al.) discloses one method whereby MPEG-2 stream containing I-frames may be used to provide trick mode functionality. However, some MPEG-2 streams such as for example, HITS (Headend In The Sky) streams, do not contain I-frames or a typical grouping of pictures and are therefore incapable of providing multiple playback modes using traditional methods. Therefore, there exists a need for systems and methods for providing trick mode functionality in connection with compressed video streams that do not include a certain type of frames.
- Embodiments of the invention can be better understood with reference to the following drawings. The components in the drawings are not necessarily drawn to scale, emphasis instead being placed upon clearly illustrating the principles of the present invention. In the drawings, like reference numerals designate corresponding parts throughout the several views.
-
FIG. 1 is a high-level block diagram depicting a non-limiting example of a subscriber television system. -
FIG. 2 is a block diagram of a DHCT in accordance with one embodiment of the present invention. -
FIG. 3 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted inFIG. 2 . -
FIG. 4 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted inFIG. 2 . -
FIG. 5 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted inFIG. 2 . -
FIG. 6 is a flow chart depicting a non-limiting example of a method for providing trick mode functionality that is implemented by the DHCT depicted inFIG. 2 . - The present invention now will be described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments, examples and implementations set forth herein. Rather, these non-limiting embodiments, examples and implementations are provided so that this disclosure will include at least some of the large scope of the present invention.
-
FIG. 1 is a block diagram depicting a non-limiting example of a subscriber television system (STS) 100. In this example, the STS 100 includes aheadend 110 and a DHCT 200 that are coupled via anetwork 130. The DHCT 200 is typically situated at a user's residence or place of business and may be a stand-alone unit or integrated into another device such as, for example, thedisplay device 140 or a personal computer (not shown). The DHCT 200 receives signals (video, audio and/or other data) including, for example, MPEG-2 streams, among others, from theheadend 110 through thenetwork 130 and provides any reverse information to theheadend 110 through thenetwork 130. Thenetwork 130 may be any suitable means for communicating television services data including, for example, a cable television network or a satellite television network, among others. Theheadend 110 may include one or more server devices (not shown) for providing video, audio, and textual data to client devices such as DHCT 200. The headend 110 and the DHCT 200 cooperate to provide a user with television functionality including, for example, television programs, an interactive program guide (IPG), and/or video-on-demand (VOD) presentations. The television services are provided via thedisplay device 140 which is typically a television set. However, thedisplay device 140 may also be any other device capable of displaying video images including, for example, a computer monitor. -
FIG. 2 is a block diagram illustrating selected components of aDHCT 200 in accordance with one embodiment of the present invention. It will be understood that the DHCT 200 shown inFIG. 2 is merely illustrative and should not be construed as implying any limitations upon the scope of the preferred embodiments of the invention. For example, in another embodiment, the DHCT 200 may have fewer, additional, and/or different components than illustrated inFIG. 2 . A DHCT 200 is typically situated at a user's residence or place of business and may be a stand alone unit or integrated into another device such as, for example, a television set or a personal computer. The DHCT 200 preferably includes acommunications interface 242 for receiving signals (video, audio and/or other data) from theheadend 110 through the network 130 (FIG. 1 ) and for providing any reverse information to theheadend 110. - The DHCT 200 further preferably includes at least one
processor 244 for controlling operations of the DHCT 200, anoutput system 248 for driving thetelevision display 140, and atuner system 245 for tuning to a particular television channel or frequency and for sending and receiving various types of data to/from theheadend 110. The DHCT 200 may, in another embodiment, include multiple tuners for receiving downloaded (or transmitted) data.Tuner system 245 can select from a plurality of transmission signals provided by thesubscriber television system 100.Tuner system 245 enables the DHCT 200 to tune to downstream media and data transmissions, thereby allowing a user to receive digital or analog media content via the subscriber television system. Thetuner system 245 includes, in one implementation, an out-of-band tuner for bi-directional quadrature phase shift keying (QPSK) data communication and a quadrature amplitude modulation (QAM) tuner (in band) for receiving television signals. Additionally, areceiver 246 receives externally-generated user inputs or commands from an input device such as, for example, a remote control. - The DHCT 200 may include one or more wireless or wired interfaces, also called
communication ports 274, for receiving and/or transmitting data to other devices. For instance, the DHCT 200 may feature USB (Universal Serial Bus), Ethernet, IEEE-1394, serial, and/or parallel ports, etc. DHCT 200 may also include an analog video input port for receiving analog video signals. User input may be provided via an input device such as, for example, a hand-held remote control device or a keyboard. - The
DHCT 200 includessignal processing system 214, which comprises ademodulating system 213 and a transport demultiplexing and parsing system 215 (herein demultiplexing system) for processing broadcast media content and/or data. One or more of the components of thesignal processing system 214 can be implemented with software, a combination of software and hardware, or preferably in hardware.Demodulating system 213 comprises functionality for demodulating analog or digital transmission signals. For instance,demodulating system 213 can demodulate a digital transmission signal in a carrier frequency that was modulated, among others, as a QAM-modulated signal. When tuned to a carrier frequency corresponding to an analog TV signal,demultiplexing system 215 is bypassed and the demodulated analog TV signal that is output by demodulatingsystem 213 is instead routed toanalog video decoder 216.Analog video decoder 216 converts the analog TV signal into a sequence of digitized pictures and their respective digitized audio. Digitized pictures and respective audio output byanalog video decoder 216 are presented at the input ofcompression engine 217. -
Compression engine 217 processes the sequence of digitized pictures and digitized audio and converts them into compressed video and audio streams, respectively. The compressed video and audio streams are produced in accordance with the syntax and semantics of a designated audio and video coding method, such as, for example, MPEG-2, so that they can be interpreted byvideo decoder 223 andaudio decoder 225 for decompression and reconstruction at a future time. Each compressed stream consists of a sequence of data packets containing a header and a payload. Each header contains a unique packet identification code, or PID, associated with the respective compressed stream. -
Compression engine 217 multiplexes the audio and video compressed streams into a transport stream, such as an MPEG-2 transport stream. Furthermore,compression engine 217 can preferably compress audio and video corresponding to more than one program in parallel (e.g., two tuned analog TV signals whenDHCT 200 has multiple tuners) and to multiplex the respective audio and video compressed streams into a single transport stream. Output of compressed streams and/or transport streams produced bycompression engine 217 is input to signalprocessing system 214. Parsingcapabilities 215 withinsignal processing 214 allow for interpretation of sequence and picture headers, and in a preferred embodiment, annotating their locations within their respective compressed stream as well as other useful information for future retrieval fromstorage device 273, as described below. A compressed analog video stream (e.g., corresponding to a TV program episode or show) that is received via a tuned analog transmission channel can be output as a transport stream bysignal processing 214 and presented as input for storage instorage device 273 viainterface 275. The packetized compressed streams can be also output bysignal processing 214 and presented as input tomedia engine 222 for decompression byvideo decoder 223 andaudio decoder 225 for subsequent output to the display device 140 (FIG. 1 ). -
Demultiplexing system 215 can include MPEG-2 transport demultiplexing. When tuned to carrier frequencies carrying a digital transmission signal,demultiplexing system 215 enables the separation of packets of data, corresponding to the desired video streams, for further processing. Concurrently,demultiplexing system 215 precludes further processing of packets in the multiplexed transport stream that are irrelevant or not desired such as, for example, packets of data corresponding to other video streams. - The components of
signal processing system 214 are preferably capable of QAM demodulation, forward error correction, demultiplexing MPEG-2 transport streams, and parsing packetized elementary streams and elementary streams. Thesignal processing system 214 further communicates withprocessor 244 via interrupt and messaging capabilities ofDHCT 200. Theprocessor 244 annotates the location of pictures within the compressed stream as well as other pertinent information. The annotations by theprocessor 244 enable normal playback or other playback modes of the stored compressed stream of the respective compressed stream. - A compressed video stream corresponding to a tuned carrier frequency carrying a digital transmission signal can be output as a transport stream by
signal processing 214 and presented as input for storage instorage device 273 viainterface 275. The packetized compressed streams can be also output bysignal processing system 214 and presented as input tomedia engine 222 for decompression by thevideo decoder 223 andaudio decoder 225. - One having ordinary skill in the art will appreciate that
signal processing system 214 may include other components not shown, including memory, decryptors, samplers, digitizers (e.g. analog-to-digital converters), and multiplexers, among others. Further, other embodiments will be understood, by those having ordinary skill in the art, to be within the scope of the preferred embodiments of the present invention. For example, analog signals (e.g., NTSC) may bypass one or more elements of thesignal processing system 214 and may be forwarded directly to theoutput system 248. Outputs presented at corresponding next-stage inputs for the aforementioned signal processing flow may be connected viaaccessible DRAM 252 in which an outputting device stores the output data and from which an inputting device retrieves it. Outputting and inputting devices may includeanalog video decoder 216,compression engine 217,media engine 222,signal processing system 214, and components or sub-components thereof. It will be understood by those having ordinary skill in the art that components ofsignal processing system 214 can be spatially located in different areas of theDHCT 200. -
Parser 215 parses (i.e., reads and interprets) compressed streams to interpret sequence headers and picture headers, and deposits a transport stream carrying compressed streams intoDRAM 252.Processor 244 causes the transport stream to be transferred fromDRAM 252 to thestorage device 273 viainterface 275. Upon demultiplexing and parsing the transport stream carrying one or more video streams,processor 244 interprets the data output bysignal processing system 214 and generates ancillary data in the form of a table or data structure comprising the relative or absolute location of the beginning of certain pictures in the compressed video stream. Such ancillary data is used to facilitate the retrieval of desired video data during future operations. - In one embodiment of the invention, a plurality of tuners and
respective demodulating systems 213,demultiplexing systems 215, andsignal processing systems 214 may simultaneously receive and process a plurality of respective broadcast digital video streams. Alternatively, asingle demodulating system 213, asingle demultiplexing system 215, and a singlesignal processing system 214, each with sufficient processing capabilities may be used to process a plurality of digital video streams. - In yet another embodiment, a first tuner in
tuning system 245 receives an analog video signal corresponding to a first video stream and a second tuner simultaneously receives a digital compressed stream corresponding to a second video stream. The first video stream is converted into a digital format. The second video stream and/or a compressed digital version of the first video stream are routed to thehard disk 201 ofstorage device 273. Data annotations for each of the two streams are performed to facilitate future retrieval of the video streams from thestorage device 273. The first video stream and/or the second video stream may also be routed tomedia engine 222 for decoding and subsequent presentation via display device 140 (FIG. 1 ). The first video stream may be routed tomedia engine 222 in either a digital or analog format. - In one implementation,
compression engine 217 can output formatted MPEG-2 or MPEG-1 packetized elementary streams (PES) inside a transport stream, all compliant to the syntax and semantics of the ISO MPEG-2 standard. Alternatively,compression engine 217 can output other digital formats that are compliant to other standards. The digital compressed streams output bycompression engine 217 corresponding to a first video stream are routed todemultiplexing system 215.Demultiplexing system 215 parses (i.e., reads and interprets) the transport stream generated bycompression engine 217 without disturbing its content and deposits the transport stream intoDRAM 252.Processor 244 causes transport stream inDRAM 252 to be transferred to thestorage device 273. In a preferred embodiment, while parsing the transport stream,demultiplexing system 215 outputs toDRAM 252 ancillary data in the form of a table or data structure comprising the relative or absolute location of the beginning of certain pictures in the compressed media content stream for the first video stream for facilitating retrieval during future operations. In this way, random access operations such as fast forward, rewind, and jumping to a location in the compressed video stream can be attained. Additional pertinent data is also written in the tables, as described below - A plurality of
compression engines 217 may be used to simultaneously compress a plurality of analog video streams. Alternatively, asingle compression engine 217 with sufficient processing capabilities may be used to compress a plurality of analog video streams. Compressed digital versions of respective analog video streams may be routed to thehard disk 201 ofstorage device 273. Data annotations for each of the video streams may be performed to facilitate future retrieval of the video streams from thestorage device 273. Depending on requirements in effect at an instance of time, only a subset of the total number of compressed digital video signals may be routed to thestorage device 273. Any of the received video streams can also be routed simultaneously tomedia engine 222 for decoding and subsequent presentation viadisplay device 140. - The
DHCT 200 includes at least onestorage device 273 for storing video streams received by theDHCT 200. APVR application 277, in cooperation with theoperating system 253 and thedevice driver 211, effects, among other functions, read and/or write operations to thestorage device 273. Herein, references to write and/or read operations to thestorage device 273 will be understood to mean operations to the medium or media of thestorage device 273 unless indicated otherwise. Thedevice driver 211 is a software module preferably resident in theoperating system 253. Thedevice driver 211, under management of theoperating system 253, communicates with thestorage device controller 279 to provide the operating instructions for thestorage device 273. As conventional device drivers and device controllers are well known to those of ordinary skill in the art, further discussion of the detailed working of each will not be described further here.Storage device 273 is preferably internal to DHCT 200, coupled to acommon bus 205 through acommunication interface 275. Thecommunication interface 275 is preferably an integrated drive electronics (IDE) or small computer system interface (SCSI), although another interface such as, for example, IEEE-1394 or USB, among others, may be used. Alternatively, thestorage device 273 can be externally connected to theDHCT 200 via acommunication port 274. Thecommunication port 274 may be, for example, an IEEE-1394, a USB, a SCSI, or an IDE. In one implementation, video streams are received inDHCT 200 viacommunications interface 242 and stored in a temporary memory cache. The temporary memory cache may be a designated section ofDRAM 252 or an independent memory attached directly tocommunication interface 242. The temporary cache is implemented and managed to enable media content transfers tostorage device 273. In one implementation, the fast access time and high data transfer rate characteristics of thestorage device 273 enable media content to be read from the temporary cache and written tostorage device 273 in a sufficiently fast manner. Multiple simultaneous data transfer operations may be implemented so that while data is being transferred from the temporary cache tostorage device 273, additional data may be received and stored in the temporary cache. - In addition to specifying a video stream and/or its associated compressed streams, a request for retrieval and playback of a compressed video presentation stored in
storage device 273 specifies information that includes the playback mode, direction of playback, entry point of playback with respect to the beginning of the compressed video presentation, and playback speed, if applicable. In addition, a request for retrieval and playback may also specify the duration of playback. As a non-limiting example, the playback mode specified in a request may be normal-playback, fast-reverse-playback, fast-forward-playback, slow-reverse-playback, slow-forward-playback, and pause-display. Playback speed is applicable to playback modes other than normal playback and pause display and may be specified as a factor or proportion of the normal playback speed. As a non-limiting example, playback speed specification may be 2×, 2×, 6×, 10× or 15× for fast-forward or fast-reverse playback, where X means “times normal play speed.” Likewise, ⅛×, ¼× and ½× are non-limiting examples for the speed specification in request for slow-forward or slow-reverse playback. Direction of playback may be explicit in the playback mode or specified separately as forward or reverse in the specified request according to a predetermined format for a request's specification. - The entry point for playback is relative to the beginning of the compressed video presentation stored in
storage device 273 and may be specified in a number of different ways according to the predetermined format for a request's specification. As a non-limiting example, the entry point in the request for which to start playback may be specified in relation to the beginning of the video presentation as elapsed normal playback time, number of pictures, or number of certain types of pictures. - In response to a request for retrieval and playback of a compressed stream for which the playback mode is “normal playback” or “pause-display” and for which the entry point is at the beginning of the compressed video stream,
processor 244 in communication generally withdevice driver 211 andstorage device controller 279 anddemultiplexing system 215 effects retrieval of compressed video data, compressed audio data, and data streams fromstorage device 273 that correspond to one or more video streams specified in request. Retrieved streams are deposited in an output cache instorage device 273, transferred toDRAM 252, and then processed for playback according to mechanisms that would be understood by those having ordinary skill in the art. In some embodiments, the video streams are retrieved and routed from thehard disk 201 to thedigital video decoder 223 and digitalaudio decoder 225 simultaneously, and then further processed for subsequent presentation via thedisplay device 140. - In response to a request for retrieval and playback of a compressed stream stored in
storage device 273 for which the playback mode is not “normal playback” or “pause-display,” or for which the entry point is not at the beginning of the compressed video stream,processor 244 in communication generally withdevice driver 211 andstorage device controller 279 reads information in the respective entry in the index table 202 for the requested compressed video stream to retrieve annotation data fromstorage device 273 that correspond to the requested video streams specified in request. Immediately thereafter under program control,processor 244 retrieves the program information file 203 fromstorage device 273 and interprets the program information file to compute the entry point location for which to fulfill the specified playback mode in the request. In a preferred embodiment of the invention, information pertaining the characteristics of compressed video stream is contained in program information file 203 and interpreted to fulfill the specified playback mode in the request. The requested playback mode is implemented by theprocessor 244 based on the characteristics of the compressed data, the playback mode specified in the request, and the processing and computing capabilities ofDHCT 200. Retrieved streams are deposited in an output cache instorage device 273, transferred toDRAM 252, and then processed for playback byprocessor 244 under program control and in communication withvideo decoder 223. As a non-limiting example, video streams may retrieved and routed from thehard disk 201 to thedigital video decoder 223 and digitalaudio decoder 225 simultaneously, and then further processed for eventual presentation on adisplay device 140. -
Storage device 273 is preferably a hard disk drive but may in an alternative embodiment be any type of magnetic, optical, or semiconductor based storage device. Thestorage device 273 preferably includes at least onehard disk 201 and acontroller 279. Thecontroller 279 receives operating instructions from thedevice driver 211 and implements those instructions to cause read and/or write operations to thehard disk 201. Theoperating system 253, in cooperation with thedevice driver 211, communicates with thestorage device controller 279 to format thehard disk 201. - In one embodiment of the invention, the
operating system 253,device driver 211, andcontroller 279 cooperate to create a file allocation table (FAT). TheFAT 204 is where theoperating system 253 stores the information about the hard disk clusters and the files associated with those clusters. Theoperating system 253 can determine where a file's data is located by using the directory entry for the file and file allocation table (FAT) 204 entries. The directory entry gives information about a directory such as its related files and subdirectories. A FAT entry describes the physical locations of data for a video stream file (i.e. the file that the video stream is written to on the hard disk 201). Similarly, theFAT 204 also keeps track of which clusters are free, or open, and thus available for use. When an application such asPVR application 277 creates (or extends) a video stream file, theoperating system 253, in cooperation with thedevice driver 211, queries theFAT 204 for an available cluster to begin writing the video stream. As a non-limiting example, to buffer a downloaded video stream into thestorage device 273, thePVR application 277 creates a video stream file and video stream file name for the video stream to be downloaded. Theoperating system 253, in cooperation with thedevice driver 211, checks theFAT 204 for an available, or writable, cluster to write the video stream to. ThePVR application 277 effects thedevice driver 211, through communication with theoperating system 253, to cause thecontroller 279 to write the downloaded video stream to the available cluster under a particular video stream file name. TheFAT 204 is then updated with the new video stream file name corresponding to the available cluster. If the video stream requires more data space than what the cluster can offer, theoperating system 253 queries theFAT 204 for the location of another available cluster to continue writing the video stream to hard disk space. Upon finding another cluster, theFAT 204 is updated to keep track of which clusters are linked to store a particular video stream under the given video stream file name. - A multiplicity of clusters may be required to write a file corresponding to a compressed video stream to
hard disk 201. The clusters corresponding to one particular video stream file may or may not be adjacent or contiguous clusters. The clusters corresponding to a particular video stream file can be fragmented throughout the hard disk space. As described earlier, a file allocation table (FAT) keeps track of which clusters are employed to write a downloaded video stream to thehard disk 201. Further, systems well known to those of ordinary skill in the art, such as defragmentators, can be employed to cause the clusters associated with a particular video stream file to be contiguous. - Input video streams may be received by the
DHCT 200 from different sources. For example, an input video stream may be any of the following, among others: -
- 1—Broadcast analog video signals that are received from a
headend 110 via network 130 (FIG. 1 ) andnetwork communication interface 242. - 2—Analog video signals that are received from a consumer electronics device (e.g., an analog video camcorder) via analog audio and video connectors (not shown) such as, for example, S-Video input or composite video input.
- 3—An on-demand digital video stream that is received via network 130 (
FIG. 1 ) andnetwork communication interface 242. - 4—A digital video stream that is received from a digital consumer electronic device (such as a personal computer or a digital video camcorder) via a digital video interface or a home network interface such as USB, IEEE-1394 or Ethernet.
- 5—A digital video stream that is received from an externally connected storage device (e.g., a DVD player) via a digital video interface or a communication interface such as IDE, SCSI, USB, IEEE-1394 or Ethernet.
- 1—Broadcast analog video signals that are received from a
- The
PVR application 277 provides a user interface that assists the user in navigating to, and between screens for selection and retrieval of previously stored compressed video data. The user interface may provide visual status and progress feedback to the user. For instance, during a slow-reverse playback mode, the user interface may display an icon associated with reverse playback along with the speed in effect, and the location of the currently displayed picture in relation to the beginning, end or both of the video presentation. ThePVR application 277 may also be used to initiate a trick mode operation for a video stream that is stored instorage device 273. ThePVR application 277 may be implemented in hardware, software, firmware, or a combination thereof. In a preferred embodiment, thePVR application 277 is implemented in software or firmware that is stored in a DRAM 52 and that is executed byprocessor 244. ThePVR application 277, which comprises an ordered listing of executable instructions for implementing logical functions, can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions. -
FIG. 3 depicts a non-limiting example of amethod 300 in accordance with one embodiment of the present invention. Instep 301, theDHCT 200 receives an MPEG-2 stream from the headend 110 (FIG. 1 ) and then, instep 302, stores it inhard disk 201. The MPEG-2 stream is made up of multiple picture sequences wherein each picture sequence has a header. The beginning of each picture and picture sequence is determined by a start code. As the MPEG-2 stream is being stored inhard disk 201, theprocessor 244 creates a corresponding index table 202 as indicated instep 303. The index table 202 consists of elements that point to data in thehard disk 201 that define picture and sequence boundaries in the MPEG-2 stream. The index table 202 facilitates the delivery of selected data to themedia engine 222. The index table 202 may include the following information about the MPEG-2 stream: - a) The storage location of each of the sequence headers.
- b) The storage location of each picture start code.
- c) The type of each picture (I, P, or B).
- d) The real time of when each picture was stored.
- In addition to creating an index table 202, the
processor 244 instep 304 stores program information related to the MPEG-2 stream in aprogram information file 203. The program information file 203 includes the packet identification codes (PIDs) contained in the MPEG-2 stream as well as a flag that represents whether the stream contains I-frames. A determination as to whether the MPEG-2 stream contains I-frames may be made by inspecting a predetermined number of picture sequences; if no I-frame is found within the predetermined number of picture sequences, then the flag is set to false. It should be noted that the steps 301-304, or a subset thereof, may be performed substantially concurrently or in a different order than shown inFIG. 3 . For example, theprocessor 244 may store data in the index table 202 and the program information file 203 as the MPEG-2 stream is being stored inhard disk 201. -
FIG. 4 is a flow chart depicting a non-limiting example of amethod 400 in accordance with one embodiment of the present invention. Themethod 400 is initiated instep 401 when theDHCT 200 receives user input requesting trick mode functionality. The user input may be provided via, for example, a remote control device. After themethod 400 is initiated, theprocessor 244 determines the number of sequential P-frames to be sent tomedia engine 222, as indicated instep 402. The number of sequential P-frames to be sent tomedia engine 222 is determined by the characteristics of the corresponding MPEG-2 stream. As a non-limiting example, the number of sequential P-frames to be sent tomedia engine 222 may be 10. After the number of sequential P-frames is determined, theprocessor 244 retrieves instep 403 the determined number of sequential P-frames and sends them tomedia engine 222. The P-frames are retrieved by selecting an element at the current program position from the index table that contains the sequence header information. From the sequence header element, the sequence header location in memory is obtained. From this location in memory, the determined number of sequential P-frames are retrieved and sent tomedia engine 222. The index table is used to count the number of P-pictures. Theprocessor 244 then determines instep 404 whether the requested trick mode is still active. If the trick mode is no longer active, then themethod 400 terminates instep 405. However, if the trick mode is still active, thenprocessor 244 repeats step 403. - The number of picture sets that are sent to
media engine 222 within a given time period is equal to the desired trick mode speed multiplied by the number of picture sets that would need to be decoded in such a time period to achieve a normal play mode. For example, if two picture sets need to be decoded per second to achieve a normal play mode, then to achieve a trick mode speed that is twice as fast as a normal play mode speed, 4 picture sets corresponding to a 2 second normal play period need to be selected and sent tomedia engine 222 per second.Media engine 222 will then decode and display four picture sets per second to achieve the correct speed. To select the 4 picture sets corresponding to a 2 second normal play period, the time stamp on the picture element is used. In a similar manner as described above 4×, 6× or n× speed can be achieved. For rewind mode, the procedure is similar except that the picture sets are selected in the reverse direction. - In one possible embodiment of the invention, the picture sets that are sent to the
media engine 222 may overlap. For example, if we assume that each picture set (PS) includes 5 P-frames, that 10 P-frames are decoded for each P-frame that is displayed, then theprocessor 244, in response to a request for a fast play mode, may send PS1 and PS2 to themedia engine 222, followed by PS2 and PS3, followed by PS3 and PS4, etc (where the numerals refer to the relative sequence of the picture sets in a normal play mode). In this manner, themedia engine 222 will output a decoded P-frame from PS2 after decoding PS1 and PS2 and then a decoded P-frame from PS3 after decoding PS2 and PS3, etc. In this example, the total number of picture sets that are sent tomedia engine 222 within a given time period is equal to the desired trick mode speed multiplied by twice the number of picture sets that would need to be decoded in such a time period to achieve a normal play mode. - In another embodiment, the picture sets that are sent to the
media engine 222 may not all be contiguous. As a non-limiting example, assuming the following hypothetical circumstances: a user requests a fast play speed that is equal to six times (6×) the normal play speed, themedia engine 222 is only capable of decoding 30 frames per second, themedia engine 222 only decodes P-frames during fast play mode, the corresponding MPEG-2 stream includes 2 B-frames for every P-frame (e.g., B, B, P, B, B, P, B, B, P, etc), and each picture set is defined as including 5 P-frames among 15 total frames, then theprocessor 244 may send 2 picture sets to themedia engine 222 and then skip 2 picture sets before sending another 2 picture sets. Theprocessor 244 may, for example, send the following picture sets to themedia engine 222 at the rate of 6 picture sets per second: PS3, PS4, PS7, PS8, PS11, PS12, PS15, PS16, etc. Alternatively, theprocessor 244 may send 3 picture sets to themedia engine 222 and then skip 3 picture sets before sending another 3 picture sets. For example, theprocessor 244 may send the following picture sets to themedia engine 222 at the rate of 6 picture sets per second: PS4, PS5, PS6, PS10, PS11, PS12, PS16, PS17, PS18, etc. - When picture sets are created and sent to the decoder the corresponding data may become discontinuous. This discontinuity can confuse the
media engine 222 resulting in erroneous decoding and undesirable artifacts on the screen. To avoid this problem, stuffing transport packets may be inserted where a picture set ends and a new picture set starts. The stuffing transport packets consist of payload data that are 0xff bytes. There may also be a need to inform the decoder of the beginning and end of a picture set because the picture decoding is not synchronous with the data being sent to the decoder. There can be many buffers between the source and destination causing the process to be very asynchronous in nature. The discontinuity in the stream is communicated to the decoder by inserting transport packets that have an elementary stream payload consisting of “MPEG-2 user data”. A specific byte pattern is sent in the user data to communicate the end of a picture set and the beginning of a new one. -
FIG. 5 depicts a non-limiting example of adecoding method 500 for providing trick mode functionality in accordance with one embodiment of the present invention. Themethod 500 is initiated instep 501 after themedia engine 222 receives a series of P-frames to be decoded and a message from theprocessor 244 instructing themedia engine 222 to provide a trick mode operation. After themethod 500 is initiated, themedia engine 222 decodes in step 502 a first P-frame in the series of P-frames and determines instep 503 if the last P-frame in the series of P-frames has been decoded. If the last P-frame has not been decoded, themedia engine 222 decodes the next P-frame in the series of P-frames, as indicated instep 504, and then returns to step 503 to determine if the last P-frame has been decoded. If the media engine determines instep 503 that the last P-frame in the series of P-frames has been decoded then the media engine outputs the last decoded P-frame a certain number of times, as indicated instep 505. Themedia engine 222 then determines instep 506 if the trick mode operation is still active. If the trick mode operation is still active then the media engine returns to step 502 and decodes a first P-frame in another series of P-frames that is received fromhard disk 201. If the trick mode operation is no longer active, then themethod 500 terminates as indicated instep 507. Therefore, although each P-frame is incapable of independently generating a complete picture, by decoding consecutive P-frames each using the previous P-frame as an anchor, a complete picture is eventually created and displayed. - As a non-limiting example of the
decoding method 500, assume that an MPEG-2 stream includes the following frames: P1, B, B, P2, B, B, P3, B, B, P4, B, B, P5, B, B, P6, B, B, P7, B, B, P8, B, B, P9, B, B, P10, B, B, P11, B, B, P12, B, B, P13, B, B, P14, B, B, P15, B, B, P16, B, B, P17, B, B, P18, B, B, P19, B, B, P20, etc., where the numerals designate the relative display order of the P-frames in a normal play mode. Then, as a non-limiting example, if a fast play mode equal to three times (3×) the normal play speed is activated, and if the output rate is 30 pictures per second, then frames P1-P10 are decoded; frame P10 is output 10 times; frames P11-P20 are decoded; frame P20 is output 10 times; frames P21-P30 are decoded; frame P30 is output 10 times, and so on until the trick mode ends. For a fast reverse play speed of 3× that is activated after frame P140 is displayed during normal play mode, then as a non-limiting example, frames P121-P130 are decoded; frame P130 is output 10 times, frames P111-P120 are decoded; frame P120 is output 10 times; frames P101-P110 are decoded; frame P110 is output 10 times; and so on until the trick mode ends. - In an alternative embodiment, the series of frames that are decoded overlap so as to produce a smoother picture. For example, assuming a 3× fast play mode, and assuming an output rate of 30 pictures per second (pps), then frames P1-P10 are decoded; frame P10 is output 5 times; frames P6-P15 are decoded; frame P15 is output 5 times; frames P11-P20 are decoded; frame P20 is output 5 times; frames P16-P25 are decoded; frame P25 is output 5 times, and so on until the trick mode ends. For a fast reverse play speed of 3× that is activated after frame P135 is displayed during normal play mode, then as a non-limiting example, frames P121-P130 are decoded; frame P130 is output 5 times, frames P116-P125 are decoded; frame P125 is output 5 times; frames P111-P120 are decoded; frame P120 is output 5 times; and so on until the trick mode ends.
- In yet another embodiment of the invention, the series of frames that are decoded are not contiguous. For example, assuming a 6× fast play mode, a 30 pps output rate, and a maximum decoding rate of 30 pps, then frames P11-P20 are decoded; frame P20 is output 10 times; frames P31-P40 are decoded; frame P40 is output 10 times; frames P51-P60 are decoded; frame P60 is output 10 times, and so on until the trick mode is cancelled. For a fast reverse play speed of 6× that is activated after frame P150 is displayed during normal play mode, then as a non-limiting example, frames P121-P130 are decoded; frame P130 is output 10 times; frames P101-P110 are decoded; frame P110 is output 10 times; frames P81-P90 are decoded; frame P90 is output 10 times and so on until the trick mode ends.
-
FIG. 6 depicts a non-limiting example of amethod 600 for providing fast play functionality in accordance with one embodiment of the present invention. Themethod 600 is initiated instep 601 after themedia engine 222 receives video data to be decoded and a message from theprocessor 244 instructing themedia engine 222 to provide a fast play operation. After themethod 600 is initiated, themedia engine 222 decodes in step 602 a certain number of P-frames and then outputs instep 603 the final P-frame among the certain number of P-frames. The certain number of P-frames is preferably equal to the number of P-frames that need to be decoded in order to produce a P-frame of a desirable quality. Themedia engine 222 then decodes the next P-frame instep 604 and displays the decoded P-frame instep 605. Themedia engine 222 then determines instep 606 if the trick mode operation is still active. If the trick mode operation is still active then the media engine returns to step 604 and decodes the next P-frame. If the trick mode operation is not longer active, then themethod 600 terminates as indicated instep 607. - The blocks shown in
FIGS. 3-6 represent modules, segments, or portions of code which include one or more executable instructions for implementing specific logical functions or steps in a process. The functionality provided by each of the methods illustrated inFIGS. 3-6 , can also be implemented through hardware (e.g., an application specific integrated circuit (ASIC) and supporting circuitry). Each implementation may have a perceived advantage, however. For example, hardware enjoys a speed and, arguably, a reliability advantage over software because hardware testing and verification methods are currently more advanced than software verification methods. On the other hand, software can be less expensive than customized hardware and offers greater flexibility in adding or modifying product features. - The functionality provided by each of the methods illustrated in
FIGS. 3-6 , can be embodied in any computer-readable medium for use by or in connection with a computer-related system or method. In this context of this document, a computer-readable medium is an electronic, magnetic, optical, semiconductor, or other physical device or means that can contain or store a computer program or data for use by or in connection with a computer-related system or method. Also, the computer program or data may be transferred to another computer-readable medium by any suitable process such as by scanning the computer-readable medium. Thus, the computer-readable medium could be paper or other suitable medium upon which the computer program can be printed, scanned with an optical scanner, and transferred into the computer's memory or storage. - It should be emphasized that the above-described embodiments of the present invention, particularly any “preferred embodiments”, are merely possible examples, among others, of the implementations, setting forth a clear understanding of the principles of the invention. Many variations and modifications may be made to the above-described embodiments of the invention without departing substantially from the principles of the invention. All such modifications and variations are intended to be included herein within the scope of the disclosure and present invention and protected by the following claims.
Claims (10)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/389,588 US20090196357A1 (en) | 2001-12-31 | 2009-02-20 | Trick Mode Operations |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/038,943 US7274857B2 (en) | 2001-12-31 | 2001-12-31 | Trick modes for compressed video streams |
US11/843,711 US8301016B2 (en) | 2001-12-31 | 2007-08-23 | Decoding and output of frames for video trick modes |
US12/389,588 US20090196357A1 (en) | 2001-12-31 | 2009-02-20 | Trick Mode Operations |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/843,711 Continuation US8301016B2 (en) | 2001-12-31 | 2007-08-23 | Decoding and output of frames for video trick modes |
Publications (1)
Publication Number | Publication Date |
---|---|
US20090196357A1 true US20090196357A1 (en) | 2009-08-06 |
Family
ID=21902801
Family Applications (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/038,943 Active 2025-09-24 US7274857B2 (en) | 2001-12-31 | 2001-12-31 | Trick modes for compressed video streams |
US11/832,391 Active 2026-02-28 US8358916B2 (en) | 2001-12-31 | 2007-08-01 | Annotations for trick modes of video streams with simultaneous processing and display |
US11/843,711 Active 2025-11-25 US8301016B2 (en) | 2001-12-31 | 2007-08-23 | Decoding and output of frames for video trick modes |
US12/389,453 Abandoned US20090196341A1 (en) | 2001-12-31 | 2009-02-20 | Annotations for Supporting Trick Mode Operations |
US12/389,458 Abandoned US20100074591A1 (en) | 2001-12-31 | 2009-02-20 | Determining Parameters for Trick Modes of Video Programs |
US12/389,588 Abandoned US20090196357A1 (en) | 2001-12-31 | 2009-02-20 | Trick Mode Operations |
Family Applications Before (5)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/038,943 Active 2025-09-24 US7274857B2 (en) | 2001-12-31 | 2001-12-31 | Trick modes for compressed video streams |
US11/832,391 Active 2026-02-28 US8358916B2 (en) | 2001-12-31 | 2007-08-01 | Annotations for trick modes of video streams with simultaneous processing and display |
US11/843,711 Active 2025-11-25 US8301016B2 (en) | 2001-12-31 | 2007-08-23 | Decoding and output of frames for video trick modes |
US12/389,453 Abandoned US20090196341A1 (en) | 2001-12-31 | 2009-02-20 | Annotations for Supporting Trick Mode Operations |
US12/389,458 Abandoned US20100074591A1 (en) | 2001-12-31 | 2009-02-20 | Determining Parameters for Trick Modes of Video Programs |
Country Status (4)
Country | Link |
---|---|
US (6) | US7274857B2 (en) |
EP (1) | EP1470709B1 (en) |
CA (1) | CA2472244C (en) |
WO (1) | WO2003058955A1 (en) |
Families Citing this family (120)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6020189A (en) * | 1996-08-30 | 2000-02-01 | The Johns Hopkins University School Of Medicine | Fibroblast growth factor homologous factors (FHFs) and methods of use |
US6697489B1 (en) | 1999-03-30 | 2004-02-24 | Sony Corporation | Method and apparatus for securing control words |
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 |
US8429699B2 (en) * | 1999-12-14 | 2013-04-23 | Arturo A. Rodriguez | Systems and methods for resource-adaptive processing of scaled video and graphics |
KR100394974B1 (en) * | 2000-05-23 | 2003-08-19 | 엘지전자 주식회사 | Method for making multi-path data stream acceptable in a high-density recording medium |
KR20140126420A (en) | 2001-02-21 | 2014-10-30 | 유나이티드 비디오 프로퍼티즈, 인크. | Systems and methods for interactive program guides with personal video recording features |
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 |
US7127619B2 (en) | 2001-06-06 | 2006-10-24 | Sony Corporation | Decoding and decryption of partially encrypted information |
KR20020097454A (en) * | 2001-06-21 | 2002-12-31 | 엘지전자 주식회사 | Apparatus and method for recording a multichannel stream and, medium thereof |
KR100598285B1 (en) * | 2001-06-21 | 2006-07-07 | 엘지전자 주식회사 | Apparatus and method for recording a multichannel stream and, medium thereof |
KR100752480B1 (en) | 2001-06-21 | 2007-08-28 | 엘지전자 주식회사 | Apparatus and method for recording a multichannel stream and, medium thereof |
US7643727B2 (en) * | 2001-07-24 | 2010-01-05 | Lg Electronics Inc. | Method and apparatus of recording a multi-channel stream, and a recording medium containing a multi-channel stream recorded by said method |
US8238725B2 (en) * | 2001-08-20 | 2012-08-07 | Broadcom Corporation | System and method for providing personal video recording trick modes |
US8923688B2 (en) * | 2001-09-12 | 2014-12-30 | Broadcom Corporation | Performing personal video recording (PVR) functions on digital video streams |
US7274857B2 (en) * | 2001-12-31 | 2007-09-25 | Scientific-Atlanta, Inc. | Trick modes for compressed video streams |
US7823174B2 (en) | 2002-01-02 | 2010-10-26 | Sony Corporation | Macro-block based content replacement by PID mapping |
US7218738B2 (en) * | 2002-01-02 | 2007-05-15 | Sony Corporation | Encryption and content control in a digital broadcast system |
US7765567B2 (en) | 2002-01-02 | 2010-07-27 | Sony Corporation | Content replacement by PID mapping |
US8302144B2 (en) * | 2002-03-13 | 2012-10-30 | Cox Communications, Inc. | Distribution of content in an information distribution system |
US7889968B2 (en) * | 2002-06-24 | 2011-02-15 | Lg Electronics Inc. | Recording medium having data structure for managing reproduction of multiple reproduction path video data for at least a segment of a title recorded thereon and recording and reproducing methods and apparatuses |
US7606465B2 (en) * | 2002-06-24 | 2009-10-20 | Lg Electronics Inc. | Recording medium having data structure for managing reproduction of multiple title video data recorded thereon and recording and reproducing methods and apparatuses |
CN100380496C (en) | 2002-06-24 | 2008-04-09 | Lg电子株式会社 | Recording medium having data structure including navigation control information for managing reproduction of video data recorded thereon and recording and reproducing methods and apparatuses |
KR20040000290A (en) | 2002-06-24 | 2004-01-03 | 엘지전자 주식회사 | Method for managing multi-path data stream of high density optical disc |
EP1518239A4 (en) * | 2002-06-28 | 2010-03-10 | Lg Electronics Inc | Recording medium having data structure for managing reproduction of multiple playback path video data recorded thereon and recording and reproducing methods and apparatuses |
EP1518240B1 (en) * | 2002-06-28 | 2014-05-07 | LG Electronics, Inc. | Recording medium having data structure for managing recording and reproduction of multiple path data recorded thereon and recording and reproducing methods and apparatus |
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 |
US8818896B2 (en) | 2002-09-09 | 2014-08-26 | Sony Corporation | Selective encryption with coverage encryption |
US8572408B2 (en) | 2002-11-05 | 2013-10-29 | Sony Corporation | Digital rights management of a digital device |
US7724907B2 (en) | 2002-11-05 | 2010-05-25 | Sony Corporation | Mechanism for protecting the transfer of digital content |
US8064755B2 (en) * | 2002-11-08 | 2011-11-22 | Lg Electronics Inc. | Method and apparatus for recording a multi-component stream and a high-density recording medium having a multi-component stream recorded thereon and reproducing method and apparatus of said recording medium |
ES2541122T3 (en) * | 2002-11-12 | 2015-07-16 | Lg Electronics Inc. | Recording medium that has a data structure to manage the reproduction of video data from multiple playback paths recorded therein and recording and playback methods and apparatus |
US7720356B2 (en) | 2002-11-12 | 2010-05-18 | Lg Electronics Inc | Recording medium having data structure for managing reproduction of multiple reproduction path video data recorded thereon and recording and reproducing methods and apparatuses |
US7577204B2 (en) * | 2002-11-15 | 2009-08-18 | Broadcom Corporation | Hits stream rewind |
US7664372B2 (en) * | 2002-11-20 | 2010-02-16 | Lg Electronics Inc. | Recording medium having data structure for managing reproduction of multiple component data recorded thereon and recording and reproducing methods and apparatuses |
US7783160B2 (en) * | 2002-11-20 | 2010-08-24 | Lg Electronics Inc. | Recording medium having data structure for managing reproduction of interleaved multiple reproduction path video data recorded thereon and recording and reproducing methods and apparatuses |
US8645988B2 (en) | 2002-12-13 | 2014-02-04 | Sony Corporation | Content personalization for digital content |
US8667525B2 (en) | 2002-12-13 | 2014-03-04 | Sony Corporation | Targeted advertisement selection from a digital stream |
US7606463B2 (en) * | 2003-02-24 | 2009-10-20 | Lg Electronics, Inc. | Recording medium having data structure for managing playback control and recording and reproducing methods and apparatuses |
US7809775B2 (en) | 2003-02-27 | 2010-10-05 | Lg Electronics, Inc. | Recording medium having data structure for managing playback control recorded thereon and recording and reproducing methods and apparatuses |
CN100397882C (en) | 2003-02-28 | 2008-06-25 | Lg电子株式会社 | Recording medium having data structure for managing random/shuffle reproduction of video data recorded thereon and recording and reproducing methods and apparatuses |
US7224664B2 (en) * | 2003-03-25 | 2007-05-29 | Lg Electronics Inc. | Recording medium having data structure for managing reproduction of data streams recorded thereon and recording and reproducing methods and apparatuses |
US20050022245A1 (en) | 2003-07-21 | 2005-01-27 | Ramesh Nallur | Seamless transition between video play-back modes |
US7966642B2 (en) * | 2003-09-15 | 2011-06-21 | Nair Ajith N | Resource-adaptive management of video storage |
WO2005038781A1 (en) * | 2003-10-16 | 2005-04-28 | Sae Magnetics (H.K.) Ltd. | Method and mechanism of the suspension resonance optimization for the hard disk driver |
US7853980B2 (en) | 2003-10-31 | 2010-12-14 | Sony Corporation | Bi-directional indices for trick mode video-on-demand |
US7900140B2 (en) * | 2003-12-08 | 2011-03-01 | Microsoft Corporation | Media processing methods, systems and application program interfaces |
US7712108B2 (en) * | 2003-12-08 | 2010-05-04 | Microsoft Corporation | Media processing methods, systems and application program interfaces |
US7733962B2 (en) * | 2003-12-08 | 2010-06-08 | Microsoft Corporation | Reconstructed frame caching |
US7735096B2 (en) | 2003-12-11 | 2010-06-08 | Microsoft Corporation | Destination application program interfaces |
US7934159B1 (en) | 2004-02-19 | 2011-04-26 | Microsoft Corporation | Media timeline |
US7941739B1 (en) | 2004-02-19 | 2011-05-10 | Microsoft Corporation | Timeline source |
US7664882B2 (en) * | 2004-02-21 | 2010-02-16 | Microsoft Corporation | System and method for accessing multimedia content |
EP1726163B1 (en) * | 2004-03-03 | 2014-12-24 | Callahan Cellular L.L.C. | Video processing circuit and method of video processing |
TWI276970B (en) * | 2004-03-09 | 2007-03-21 | Intervideo Digital Technology | Computer system for storing remote video, and method thereof |
US7669206B2 (en) * | 2004-04-20 | 2010-02-23 | Microsoft Corporation | Dynamic redirection of streaming media between computing devices |
JP2005339721A (en) * | 2004-05-28 | 2005-12-08 | Sony Corp | Recording device and method, recording medium, and program |
TWI258676B (en) * | 2004-05-28 | 2006-07-21 | Intervideo Digital Technology | Architecture of auto-playback for storage device and method thereof |
US20060013557A1 (en) * | 2004-07-01 | 2006-01-19 | Thomas Poslinski | Suppression of trick modes in commercial playback |
US20060013556A1 (en) * | 2004-07-01 | 2006-01-19 | Thomas Poslinski | Commercial information and guide |
US20060013555A1 (en) * | 2004-07-01 | 2006-01-19 | Thomas Poslinski | Commercial progress bar |
US20060013554A1 (en) * | 2004-07-01 | 2006-01-19 | Thomas Poslinski | Commercial storage and retrieval |
US8600217B2 (en) * | 2004-07-14 | 2013-12-03 | Arturo A. Rodriguez | System and method for improving quality of displayed picture during trick modes |
JP3919115B2 (en) | 2004-08-18 | 2007-05-23 | ソニー株式会社 | DECODING DEVICE, DECODING METHOD, DECODING PROGRAM, RECORDING MEDIUM CONTAINING DECODING PROGRAM, AND REVERSE REPRODUCTION DEVICE, REVERSE REPRODUCTION METHOD, REVERSE REPRODUCTION PROGRAM, AND RECORDING MEDIUM CONTAINING REVERSE REPRODUCTION PROGRAM |
US20080035176A1 (en) * | 2004-08-25 | 2008-02-14 | Byers Ernest F | Automated Cart and Container Cleaning System |
CN101027909B (en) * | 2004-09-23 | 2013-03-13 | 汤姆森许可公司 | Inserting metadata for trick play in video transport stream |
US7895617B2 (en) | 2004-12-15 | 2011-02-22 | Sony Corporation | Content substitution editor |
US8041190B2 (en) | 2004-12-15 | 2011-10-18 | Sony Corporation | System and method for the creation, synchronization and delivery of alternate content |
US8321439B2 (en) * | 2004-12-17 | 2012-11-27 | Microsoft Corporation | Quick filename lookup using name hash |
US7873596B2 (en) * | 2006-05-23 | 2011-01-18 | Microsoft Corporation | Extending cluster allocations in an extensible file system |
US8606830B2 (en) | 2004-12-17 | 2013-12-10 | Microsoft Corporation | Contiguous file allocation in an extensible file system |
US9639554B2 (en) * | 2004-12-17 | 2017-05-02 | Microsoft Technology Licensing, Llc | Extensible file system |
US20070166000A1 (en) * | 2005-03-01 | 2007-07-19 | Ramesh Nallur | System and method for generating trick mode streams |
JP2006345098A (en) * | 2005-06-07 | 2006-12-21 | Canon Inc | Receiver and its control method, computer program and storage medium |
US8185921B2 (en) * | 2006-02-28 | 2012-05-22 | Sony Corporation | Parental control of displayed content using closed captioning |
US20070292108A1 (en) * | 2006-06-15 | 2007-12-20 | Thales Avionics, Inc. | Method and system for processing digital video |
US8875199B2 (en) | 2006-11-13 | 2014-10-28 | Cisco Technology, Inc. | Indicating picture usefulness for playback optimization |
US20090180546A1 (en) | 2008-01-09 | 2009-07-16 | Rodriguez Arturo A | Assistance for processing pictures in concatenated video streams |
US8873932B2 (en) | 2007-12-11 | 2014-10-28 | Cisco Technology, Inc. | Inferential processing to ascertain plural levels of picture interdependencies |
US20080115175A1 (en) * | 2006-11-13 | 2008-05-15 | Rodriguez Arturo A | System and method for signaling characteristics of pictures' interdependencies |
US8416859B2 (en) | 2006-11-13 | 2013-04-09 | Cisco Technology, Inc. | Signalling and extraction in compressed video of pictures belonging to interdependency tiers |
JP5136546B2 (en) * | 2007-02-21 | 2013-02-06 | 日本電気株式会社 | Moving picture stream processing apparatus, moving picture reproducing apparatus and method and program provided with the apparatus |
CN101321265B (en) * | 2007-06-07 | 2011-03-16 | 中兴通讯股份有限公司 | Method and system for implementing peer-to-peer network media order frame-across broadcast mode |
US8804845B2 (en) | 2007-07-31 | 2014-08-12 | Cisco Technology, Inc. | Non-enhancing media redundancy coding for mitigating transmission impairments |
US20090033791A1 (en) * | 2007-07-31 | 2009-02-05 | Scientific-Atlanta, Inc. | Video processing systems and methods |
US8958486B2 (en) | 2007-07-31 | 2015-02-17 | Cisco Technology, Inc. | Simultaneous processing of media and redundancy streams for mitigating impairments |
EP2213097A2 (en) * | 2007-10-16 | 2010-08-04 | Cisco Technology, Inc. | Conveyance of concatenation properties and picture orderness in a video stream |
US8416858B2 (en) | 2008-02-29 | 2013-04-09 | Cisco Technology, Inc. | Signalling picture encoding schemes and associated picture properties |
WO2009152450A1 (en) | 2008-06-12 | 2009-12-17 | Cisco Technology, Inc. | Picture interdependencies signals in context of mmco to assist stream manipulation |
US8472779B2 (en) * | 2008-06-17 | 2013-06-25 | Microsoft Corporation | Concurrently displaying multiple trick streams for video |
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 |
US8705631B2 (en) | 2008-06-17 | 2014-04-22 | Cisco Technology, Inc. | Time-shifted transport of multi-latticed video for resiliency from burst-error effects |
US20090323822A1 (en) * | 2008-06-25 | 2009-12-31 | Rodriguez Arturo A | Support for blocking trick mode operations |
US8300696B2 (en) * | 2008-07-25 | 2012-10-30 | Cisco Technology, Inc. | Transcoding for systems operating under plural video coding specifications |
US20100061709A1 (en) * | 2008-09-05 | 2010-03-11 | Davender Agnihotri | Ad Menu for skipped advertisements |
US8761266B2 (en) | 2008-11-12 | 2014-06-24 | Cisco Technology, Inc. | Processing latticed and non-latticed pictures of a video program |
US8326131B2 (en) | 2009-02-20 | 2012-12-04 | Cisco Technology, Inc. | Signalling of decodable sub-sequences |
US8307390B2 (en) | 2009-02-26 | 2012-11-06 | Comcast Cable Communications, Llc | Re-addressable alternate content |
US20100218208A1 (en) * | 2009-02-26 | 2010-08-26 | Comcast Cable Communications, Llc | Method and Apparatus for Generating Alternative Commercials |
US8782261B1 (en) | 2009-04-03 | 2014-07-15 | Cisco Technology, Inc. | System and method for authorization of segment boundary notifications |
US8949883B2 (en) | 2009-05-12 | 2015-02-03 | Cisco Technology, Inc. | Signalling buffer characteristics for splicing operations of video streams |
US8782267B2 (en) | 2009-05-29 | 2014-07-15 | Comcast Cable Communications, Llc | Methods, systems, devices, and computer-readable media for delivering additional content using a multicast streaming |
US8279926B2 (en) * | 2009-06-18 | 2012-10-02 | Cisco Technology, Inc. | Dynamic streaming with latticed representations of video |
US8539535B2 (en) * | 2009-11-30 | 2013-09-17 | Time Warner Cable Enterprises Llc | Methods and apparatus for supporting VOD requests in a system with hierarchical content stores |
US20110222837A1 (en) * | 2010-03-11 | 2011-09-15 | Cisco Technology, Inc. | Management of picture referencing in video streams for plural playback modes |
US9237363B2 (en) * | 2011-02-12 | 2016-01-12 | Openwave Mobility, Inc. | Dynamic injection of metadata into flash video |
US20120281065A1 (en) * | 2011-05-06 | 2012-11-08 | Licht Benjamin P | System & method for rendering & transmission of three dimensional video and audio to a user |
US20140109162A1 (en) * | 2011-05-06 | 2014-04-17 | Benjamin Paul Licht | System and method of providing and distributing three dimensional video productions from digitally recorded personal event files |
JP5617781B2 (en) * | 2011-07-13 | 2014-11-05 | パナソニック株式会社 | Control device, control system, and control method |
EP2737695A4 (en) * | 2011-07-25 | 2015-03-04 | Thomson Licensing | Metadata assisted trick mode intervention method and system |
US9998750B2 (en) | 2013-03-15 | 2018-06-12 | Cisco Technology, Inc. | Systems and methods for guided conversion of video from a first to a second compression format |
US10891428B2 (en) * | 2013-07-25 | 2021-01-12 | Autodesk, Inc. | Adapting video annotations to playback speed |
WO2016018077A1 (en) * | 2014-07-30 | 2016-02-04 | 엘지전자 주식회사 | Broadcast transmission device, broadcast reception device, method for operating broadcast transmission device, and method for operating broadcast reception device |
US11818203B2 (en) | 2015-02-05 | 2023-11-14 | Comcast Cable Communications, Llc | Methods for determining second screen content based on data events at primary content output device |
US10178196B2 (en) | 2015-08-21 | 2019-01-08 | Comcast Cable Communications, Llc | Local cache maintenance for media content |
CN105681893B (en) * | 2015-12-31 | 2019-02-12 | 传线网络科技(上海)有限公司 | The coding/decoding method and device of streaming media video data |
CN105791952B (en) * | 2016-03-02 | 2019-03-12 | 传线网络科技(上海)有限公司 | The screenshot method and device and electronic equipment of streaming media video data |
CN111432260A (en) * | 2020-03-31 | 2020-07-17 | 腾讯科技(深圳)有限公司 | Method, device and equipment for synchronizing multiple paths of video pictures and storage medium |
Family Cites Families (127)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US684778A (en) * | 1901-02-19 | 1901-10-22 | William M Barnes | Clothes-drying machine. |
US4216504A (en) * | 1978-04-07 | 1980-08-05 | Arvin Industries, Inc. | Slow motion color video recording and playback system |
US4504852A (en) * | 1982-09-10 | 1985-03-12 | Beehler, Pavitt, Siegemund, Jagger & Martella | Method and apparatus for video standard conversion |
US4881125A (en) * | 1988-10-14 | 1989-11-14 | General Instrument Corporation | Progressive scan display of video derived from film |
US5187575A (en) * | 1989-12-29 | 1993-02-16 | Massachusetts Institute Of Technology | Source adaptive television system |
US5353119A (en) * | 1990-11-15 | 1994-10-04 | Sony United Kingdom Limited | Format conversion of digital video signals, integration of digital video signals into photographic film material and the like, associated signal processing, and motion compensated interpolation of images |
US5218435A (en) * | 1991-02-20 | 1993-06-08 | Massachusetts Institute Of Technology | Digital advanced television systems |
JPH06153069A (en) | 1992-10-30 | 1994-05-31 | Sony Corp | Converter, duplicating device, reproduction device and display device of image |
US5262854A (en) * | 1992-02-21 | 1993-11-16 | Rca Thomson Licensing Corporation | Lower resolution HDTV receivers |
US5836003A (en) * | 1993-08-26 | 1998-11-10 | Visnet Ltd. | Methods and means for image and voice compression |
US5377051A (en) | 1993-01-13 | 1994-12-27 | Hitachi America, Ltd. | Digital video recorder compatible receiver with trick play image enhancement |
US5778143A (en) * | 1993-01-13 | 1998-07-07 | Hitachi America, Ltd. | Method and apparatus for the selection of data for use in VTR trick playback operation in a system using progressive picture refresh |
US5614952A (en) * | 1994-10-11 | 1997-03-25 | Hitachi America, Ltd. | Digital video decoder for decoding digital high definition and/or digital standard definition television signals |
US5491516A (en) * | 1993-01-14 | 1996-02-13 | Rca Thomson Licensing Corporation | Field elimination apparatus for a video compression/decompression system |
US5444491A (en) * | 1993-02-26 | 1995-08-22 | Massachusetts Institute Of Technology | Television system with multiple transmission formats |
US5459528A (en) | 1994-03-31 | 1995-10-17 | Texas Instruments Incorporated | Video signal processor and method for secondary images |
US5606359A (en) * | 1994-06-30 | 1997-02-25 | Hewlett-Packard Company | Video on demand system with multiple data sources configured to provide vcr-like services |
US6009231A (en) * | 1994-09-05 | 1999-12-28 | Sony Corporation | Reproduction of information using a ring buffer with read and write pointers separated from each other by substantially half of the total ring buffer capacity |
US5646693A (en) * | 1994-11-04 | 1997-07-08 | Cismas; Sorin | Memory utilization for video decoding and display with 3:2 pull-down |
US5742829A (en) * | 1995-03-10 | 1998-04-21 | Microsoft Corporation | Automatic software installation on heterogeneous networked client computer systems |
US5724446A (en) | 1995-04-18 | 1998-03-03 | Advanced Micro Devices, Inc. | Video decoder apparatus using non-reference frame as an additional prediction source and method therefor |
US5835149A (en) * | 1995-06-06 | 1998-11-10 | Intel Corporation | Bit allocation in a coded video sequence |
US5764992A (en) * | 1995-06-06 | 1998-06-09 | Apple Computer, Inc. | Method and apparatus for automatic software replacement |
US5703966A (en) | 1995-06-27 | 1997-12-30 | Intel Corporation | Block selection using motion estimation error |
US5812787A (en) * | 1995-06-30 | 1998-09-22 | Intel Corporation | Video coding scheme with foreground/background separation |
FR2736783B1 (en) * | 1995-07-13 | 1997-08-14 | Thomson Multimedia Sa | METHOD AND APPARATUS FOR RECORDING AND PLAYBACK WITH LARGE CAPACITY RECORDING MEDIUM |
US5864342A (en) | 1995-08-04 | 1999-01-26 | Microsoft Corporation | Method and system for rendering graphical objects to image chunks |
US5801753A (en) | 1995-08-11 | 1998-09-01 | General Instrument Corporation Of Delaware | Method and apparatus for providing an interactive guide to events available on an information network |
EP0762756B1 (en) | 1995-09-11 | 2002-03-06 | Matsushita Electric Industrial Co., Ltd. | Video signal recording and reproducing apparatus |
US6084908A (en) * | 1995-10-25 | 2000-07-04 | Sarnoff Corporation | Apparatus and method for quadtree based variable block size motion estimation |
US5835151A (en) * | 1996-05-15 | 1998-11-10 | Mitsubishi Electric Information Technology Center America | Method and apparatus for down-converting a digital signal |
US6065050A (en) | 1996-06-05 | 2000-05-16 | Sun Microsystems, Inc. | System and method for indexing between trick play and normal play video streams in a video delivery system |
US5828370A (en) * | 1996-07-01 | 1998-10-27 | Thompson Consumer Electronics Inc. | Video delivery system and method for displaying indexing slider bar on the subscriber video screen |
US6006034A (en) | 1996-09-05 | 1999-12-21 | Open Software Associates, Ltd. | Systems and methods for automatic application version upgrading and maintenance |
US5748789A (en) * | 1996-10-31 | 1998-05-05 | Microsoft Corporation | Transparent block skipping in object-based video coding systems |
US5953506A (en) * | 1996-12-17 | 1999-09-14 | Adaptive Media Technologies | Method and apparatus that provides a scalable media delivery system |
KR100239349B1 (en) * | 1996-12-20 | 2000-01-15 | 구자홍 | Data format transformation circuit |
US6072532A (en) * | 1997-02-18 | 2000-06-06 | Scientific-Atlanta, Inc. | Method and apparatus for generic insertion of data in vertical blanking intervals |
US6222979B1 (en) * | 1997-02-18 | 2001-04-24 | Thomson Consumer Electronics | Memory control in trick play mode |
US6201927B1 (en) * | 1997-02-18 | 2001-03-13 | Mary Lafuze Comer | Trick play reproduction of MPEG encoded signals |
CN1186944C (en) * | 1997-04-01 | 2005-01-26 | 索尼公司 | Picture coding device, picture coding method, picture decoding device and its method, and providing medium |
US6735253B1 (en) * | 1997-05-16 | 2004-05-11 | The Trustees Of Columbia University In The City Of New York | Methods and architecture for indexing and editing compressed video over the world wide web |
US6233253B1 (en) * | 1997-05-23 | 2001-05-15 | Thomson Licensing S.A. | System for digital data format conversion and bit stream generation |
KR100563552B1 (en) * | 1997-05-30 | 2006-03-27 | 미디어텍 인크. | Method and apparatus for performing hierarchical motion estimation using nonlinear pyramid |
TW338132B (en) * | 1997-06-28 | 1998-08-11 | United Microelectronics Corp | The adaptive selecting method for memory access priority control in MPEG processor |
US5959684A (en) * | 1997-07-28 | 1999-09-28 | Sony Corporation | Method and apparatus for audio-video synchronizing |
US5936677A (en) | 1997-09-12 | 1999-08-10 | Microsoft Corporation | Microbuffer used in synchronization of image data |
US7154560B1 (en) | 1997-10-27 | 2006-12-26 | Shih-Fu Chang | Watermarking of digital image data |
JP3860323B2 (en) | 1997-10-27 | 2006-12-20 | 三菱電機株式会社 | Image decoding apparatus and image decoding method |
US5929911A (en) * | 1997-10-27 | 1999-07-27 | International Business Machines Corporation | Multiformat reduced memory MPEG-2 compliant decoder |
KR100251456B1 (en) * | 1997-11-04 | 2000-04-15 | 윤종용 | Screen device for low speed reproducing a moving picture |
US6043838A (en) * | 1997-11-07 | 2000-03-28 | General Instrument Corporation | View offset estimation for stereoscopic video coding |
JP3360586B2 (en) * | 1997-11-21 | 2002-12-24 | 日本電気株式会社 | Scan conversion apparatus and method |
US6057832A (en) | 1997-12-02 | 2000-05-02 | V Soft Ltd. | Method and apparatus for video-on-demand with fast play capability |
US5956026A (en) * | 1997-12-19 | 1999-09-21 | Sharp Laboratories Of America, Inc. | Method for hierarchical summarization and browsing of digital video |
US6560371B1 (en) * | 1997-12-31 | 2003-05-06 | Sarnoff Corporation | Apparatus and method for employing M-ary pyramids with N-scale tiling |
US6408101B1 (en) * | 1997-12-31 | 2002-06-18 | Sarnoff Corporation | Apparatus and method for employing M-ary pyramids to enhance feature-based classification and motion estimation |
US6430317B1 (en) * | 1997-12-31 | 2002-08-06 | Sarnoff Corporation | Method and apparatus for estimating motion using block features obtained from an M-ary pyramid |
US6208692B1 (en) * | 1997-12-31 | 2001-03-27 | Sarnoff Corporation | Apparatus and method for performing scalable hierarchical motion estimation |
DE19810814B4 (en) | 1998-03-12 | 2004-10-28 | Telefonaktiebolaget Lm Ericsson (Publ) | Computer system and status copying process for scalable software updates |
US6434196B1 (en) * | 1998-04-03 | 2002-08-13 | Sarnoff Corporation | Method and apparatus for encoding video information |
US6360053B1 (en) | 1998-08-07 | 2002-03-19 | Replaytv, Inc. | Method and apparatus for fast forwarding and rewinding in a video recording device |
US6157396A (en) | 1999-02-16 | 2000-12-05 | Pixonics Llc | System and method for using bitstream information to process images for use in digital display systems |
EP0982950A3 (en) * | 1998-08-24 | 2004-09-29 | Sony Corporation | Electronic video camera comprising an MPEG encoder |
US6700622B2 (en) * | 1998-10-02 | 2004-03-02 | Dvdo, Inc. | Method and apparatus for detecting the source format of video images |
US6608625B1 (en) * | 1998-10-14 | 2003-08-19 | Hitachi, Ltd. | Three dimensional graphic processor |
US6654539B1 (en) * | 1998-10-26 | 2003-11-25 | Sony Corporation | Trick playback of digital video data |
US6501480B1 (en) * | 1998-11-09 | 2002-12-31 | Broadcom Corporation | Graphics accelerator |
US6768774B1 (en) * | 1998-11-09 | 2004-07-27 | Broadcom Corporation | Video and graphics system with video scaling |
US6671454B1 (en) | 1998-11-19 | 2003-12-30 | Nec Corporation | Program information providing apparatus and record/playback control apparatus |
US7046910B2 (en) * | 1998-11-20 | 2006-05-16 | General Instrument Corporation | Methods and apparatus for transcoding progressive I-slice refreshed MPEG data streams to enable trick play mode features on a television appliance |
US6066034A (en) * | 1998-12-11 | 2000-05-23 | Weiler Corporation | V-shaped flap disc abrasive tool |
US6477562B2 (en) * | 1998-12-16 | 2002-11-05 | Clearwater Networks, Inc. | Prioritized instruction scheduling for multi-streaming processors |
US6434197B1 (en) * | 1999-01-07 | 2002-08-13 | General Instrument Corporation | Multi-functional transcoder for compressed bit streams |
US6618507B1 (en) * | 1999-01-25 | 2003-09-09 | Mitsubishi Electric Research Laboratories, Inc | Methods of feature extraction of video sequences |
US6847778B1 (en) * | 1999-03-30 | 2005-01-25 | Tivo, Inc. | Multimedia visual progress indication system |
US6360015B1 (en) * | 1999-04-06 | 2002-03-19 | Philips Electronics North America Corp. | RAM-based search engine for orthogonal-sum block match motion estimation system |
US6400764B1 (en) * | 1999-04-06 | 2002-06-04 | Koninklijke Philips Electronics N. V. | Motion estimation method featuring orthogonal-sum concurrent multi matching |
US6658157B1 (en) | 1999-06-29 | 2003-12-02 | Sony Corporation | Method and apparatus for converting image information |
US6532593B1 (en) * | 1999-08-17 | 2003-03-11 | General Instrument Corporation | Transcoding for consumer set-top storage application |
US6441754B1 (en) * | 1999-08-17 | 2002-08-27 | General Instrument Corporation | Apparatus and methods for transcoder-based adaptive quantization |
US7020892B2 (en) * | 1999-09-03 | 2006-03-28 | Lsi Logic Corporation | Time-shifted video signal processing |
KR100673282B1 (en) * | 1999-11-29 | 2007-01-24 | 소니 가부시끼 가이샤 | Video/audio signal processing method and video/audio signal processing apparatus |
US7027713B1 (en) * | 1999-11-30 | 2006-04-11 | Sharp Laboratories Of America, Inc. | Method for efficient MPEG-2 transport stream frame re-sequencing |
US8429699B2 (en) * | 1999-12-14 | 2013-04-23 | Arturo A. Rodriguez | Systems and methods for resource-adaptive processing of scaled video and graphics |
US6658199B1 (en) | 1999-12-16 | 2003-12-02 | Sharp Laboratories Of America, Inc. | Method for temporally smooth, minimal memory MPEG-2 trick play transport stream construction |
US7738550B2 (en) | 2000-03-13 | 2010-06-15 | Sony Corporation | Method and apparatus for generating compact transcoding hints metadata |
EP1280348A4 (en) * | 2000-04-21 | 2004-10-06 | Sony Corp | Information processing apparatus and method, program, and recorded medium |
MXPA01013110A (en) * | 2000-04-21 | 2002-06-04 | Sony Corp | Encoding device and method, recorded medium, and program. |
US6876703B2 (en) * | 2000-05-11 | 2005-04-05 | Ub Video Inc. | Method and apparatus for video coding |
US6438168B2 (en) | 2000-06-27 | 2002-08-20 | Bamboo Media Casting, Inc. | Bandwidth scaling of a compressed video stream |
GB0024114D0 (en) * | 2000-10-03 | 2000-11-15 | Pace Micro Tech Plc | Recompression of data for PVRs (Personal Video Recorders) |
AU2002239237A1 (en) * | 2000-10-10 | 2002-06-03 | Broadcom Corporation | System and method for special reproduction modes of a digitally encoded video data stream |
KR100386583B1 (en) | 2000-11-30 | 2003-06-02 | 엘지전자 주식회사 | Apparatus and method for transcoding video |
US20020071663A1 (en) * | 2000-12-07 | 2002-06-13 | O'donnel John Setel | Digital video recording system having multi-pass video processing |
US6766407B1 (en) * | 2001-03-27 | 2004-07-20 | Microsoft Corporation | Intelligent streaming framework |
US6671322B2 (en) | 2001-05-11 | 2003-12-30 | Mitsubishi Electric Research Laboratories, Inc. | Video transcoder with spatial resolution reduction |
US6996838B2 (en) * | 2001-06-12 | 2006-02-07 | Scientific Atlanta, Inc. | System and method for media processing with adaptive resource access priority assignment |
JP2003087785A (en) * | 2001-06-29 | 2003-03-20 | Toshiba Corp | Method of converting format of encoded video data and apparatus therefor |
US20030093800A1 (en) * | 2001-09-12 | 2003-05-15 | Jason Demas | Command packets for personal video recorder |
JP4574090B2 (en) * | 2001-09-21 | 2010-11-04 | 三菱電機株式会社 | Movie data converter and movie data conversion program |
US20030066084A1 (en) * | 2001-09-28 | 2003-04-03 | Koninklijke Philips Electronics N. V. | Apparatus and method for transcoding data received by a recording device |
KR100415109B1 (en) | 2001-10-23 | 2004-01-13 | 삼성전자주식회사 | Method and apparatus for serving commercial broadcasting service in cellular wireless telecommunication system |
US7398005B2 (en) * | 2001-12-19 | 2008-07-08 | Thomson Licensing | Trick mode playback of recorded video |
US7274857B2 (en) | 2001-12-31 | 2007-09-25 | Scientific-Atlanta, Inc. | Trick modes for compressed video streams |
US7221857B2 (en) * | 2002-01-31 | 2007-05-22 | Sony Corporation | System and method for efficiently performing a storage management procedure |
US7190723B2 (en) | 2002-03-27 | 2007-03-13 | Scientific-Atlanta, Inc. | Digital stream transcoder with a hybrid-rate controller |
US6937168B2 (en) | 2002-06-14 | 2005-08-30 | Intel Corporation | Transcoding media content from a personal video recorder for a portable device |
US7295753B2 (en) | 2002-06-25 | 2007-11-13 | International Business Machines Corporation | Personal video recording with further compression of recorded shows |
US6909749B2 (en) * | 2002-07-15 | 2005-06-21 | Pts Corporation | Hierarchical segment-based motion vector encoding and decoding |
US7418037B1 (en) * | 2002-07-15 | 2008-08-26 | Apple Inc. | Method of performing rate control for a compression system |
US20040055020A1 (en) * | 2002-08-29 | 2004-03-18 | Opentv, Inc. | Method and apparatus for selecting compression for an incoming video signal in an interactive television system |
JP4007594B2 (en) * | 2002-09-26 | 2007-11-14 | 株式会社東芝 | Moving picture coding apparatus and method, moving picture coding system conversion apparatus and method |
US7079578B2 (en) * | 2002-10-28 | 2006-07-18 | Scopus Network Technologies Ltd. | Partial bitstream transcoder system for compressed digital video bitstreams |
US20040194134A1 (en) | 2003-03-25 | 2004-09-30 | Gunatilake Priyan Deveka | Method and system for rapid channel change providing stored images of current channel programs |
US7327786B2 (en) | 2003-06-02 | 2008-02-05 | Lsi Logic Corporation | Method for improving rate-distortion performance of a video compression system through parallel coefficient cancellation in the transform |
US20050022245A1 (en) * | 2003-07-21 | 2005-01-27 | Ramesh Nallur | Seamless transition between video play-back modes |
US7233622B2 (en) * | 2003-08-12 | 2007-06-19 | Lsi Corporation | Reduced complexity efficient binarization method and/or circuit for motion vector residuals |
US7966642B2 (en) * | 2003-09-15 | 2011-06-21 | Nair Ajith N | Resource-adaptive management of video storage |
US7324595B2 (en) * | 2003-09-22 | 2008-01-29 | Lsi Logic Corporation | Method and/or apparatus for reducing the complexity of non-reference frame encoding using selective reconstruction |
US7391809B2 (en) * | 2003-12-30 | 2008-06-24 | Microsoft Corporation | Scalable video transcoding |
US8600217B2 (en) * | 2004-07-14 | 2013-12-03 | Arturo A. Rodriguez | System and method for improving quality of displayed picture during trick modes |
US20060093320A1 (en) * | 2004-10-29 | 2006-05-04 | Hallberg Bryan S | Operation modes for a personal video recorder using dynamically generated time stamps |
JP4624321B2 (en) | 2006-08-04 | 2011-02-02 | 株式会社メガチップス | Transcoder and coded image conversion method |
US20080260024A1 (en) | 2006-10-03 | 2008-10-23 | Matsushita Electric Industrial Co., Ltd. | Method, device, integrated circuit, and transcoder for selectively reducing quantization levels |
US20090033791A1 (en) * | 2007-07-31 | 2009-02-05 | Scientific-Atlanta, Inc. | Video processing systems and methods |
US8300696B2 (en) | 2008-07-25 | 2012-10-30 | Cisco Technology, Inc. | Transcoding for systems operating under plural video coding specifications |
-
2001
- 2001-12-31 US US10/038,943 patent/US7274857B2/en active Active
-
2002
- 2002-12-20 CA CA2472244A patent/CA2472244C/en not_active Expired - Fee Related
- 2002-12-20 WO PCT/US2002/040828 patent/WO2003058955A1/en not_active Application Discontinuation
- 2002-12-20 EP EP02794331.5A patent/EP1470709B1/en not_active Expired - Lifetime
-
2007
- 2007-08-01 US US11/832,391 patent/US8358916B2/en active Active
- 2007-08-23 US US11/843,711 patent/US8301016B2/en active Active
-
2009
- 2009-02-20 US US12/389,453 patent/US20090196341A1/en not_active Abandoned
- 2009-02-20 US US12/389,458 patent/US20100074591A1/en not_active Abandoned
- 2009-02-20 US US12/389,588 patent/US20090196357A1/en not_active Abandoned
Also Published As
Publication number | Publication date |
---|---|
EP1470709A1 (en) | 2004-10-27 |
EP1470709A4 (en) | 2008-02-27 |
EP1470709B1 (en) | 2019-05-01 |
CA2472244A1 (en) | 2003-07-17 |
US20080037957A1 (en) | 2008-02-14 |
US20080037952A1 (en) | 2008-02-14 |
WO2003058955A1 (en) | 2003-07-17 |
US8301016B2 (en) | 2012-10-30 |
US20030123849A1 (en) | 2003-07-03 |
CA2472244C (en) | 2010-06-01 |
US20090196341A1 (en) | 2009-08-06 |
US7274857B2 (en) | 2007-09-25 |
US8358916B2 (en) | 2013-01-22 |
US20100074591A1 (en) | 2010-03-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8301016B2 (en) | Decoding and output of frames for video trick modes | |
CA2533169C (en) | Seamless transition between video play-back modes | |
CA2669552C (en) | System and method for signaling characteristics of pictures' interdependencies | |
CA2573906C (en) | System and method for playback of digital video pictures in compressed streams | |
CA2599803C (en) | System and method for generating trick mode streams | |
US20090205010A1 (en) | Switched Decoding and Output of a Video Program from an Encoder to Decoder | |
US20090196345A1 (en) | Format Adaptable Video Transcoding | |
US20080115176A1 (en) | Indicating picture usefulness for playback optimization | |
US20060277581A1 (en) | Local entity and a method for providing media streams | |
US20140178036A1 (en) | Method of timebase management for mpeg decoding with personal video recording functionality | |
US20070201819A1 (en) | Apparatus and method for variable speed playback of digital broadcasting stream |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: SCIENTIFIC-ATLANTA, LLC, GEORGIA Free format text: CHANGE OF NAME;ASSIGNOR:SCIENTIFIC-ATLANTA, INC.;REEL/FRAME:023201/0201 Effective date: 20081205 |
|
STCB | Information on status: application discontinuation |
Free format text: EXPRESSLY ABANDONED -- DURING EXAMINATION |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NEW YORK Free format text: SECURITY AGREEMENT (FIRST LIEN);ASSIGNOR:TRITON US VP ACQUISITION CO.;REEL/FRAME:047364/0034 Effective date: 20181029 Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NEW YO Free format text: SECURITY AGREEMENT (FIRST LIEN);ASSIGNOR:TRITON US VP ACQUISITION CO.;REEL/FRAME:047364/0034 Effective date: 20181029 |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NEW YORK Free format text: SECURITY AGREEMENT (SECOND LIEN);ASSIGNOR:TRITON US VP ACQUISITION CO.;REEL/FRAME:047376/0449 Effective date: 20181029 Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NEW YO Free format text: SECURITY AGREEMENT (SECOND LIEN);ASSIGNOR:TRITON US VP ACQUISITION CO.;REEL/FRAME:047376/0449 Effective date: 20181029 |
|
AS | Assignment |
Owner name: TRITON US VP ACQUISITION CO., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CISCO TECHNOLOGY, INC.;REEL/FRAME:047419/0001 Effective date: 20181028 |
|
AS | Assignment |
Owner name: SYNAMEDIA VIVIDTEC HOLDINGS, INC, ENGLAND Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N. A.;REEL/FRAME:065766/0064 Effective date: 20231205 Owner name: SYNAMEDIA VIVIDTEC HOLDINGS, INC, ENGLAND Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N. A.;REEL/FRAME:065765/0928 Effective date: 20231205 |