A video data stream is re-encoded using motion vectors from a prior encoding operation. The video data may be enhanced by the system. Information about the enhancement, along with the decoded motion vectors, is sent to encoding circuitry. Information provided to the encoder may be tailored to the type of video data received or to the type of enhancement performed, or based on other criteria. Using the previously derived motion vectors, the encoding circuitry may perform substantially fewer computations than are used to calculate motion vectors from scratch
| 
 | 1.  A method comprising:    
    
     decoding a compressed video stream to generate a decoded content portion and a first motion vector portion;      modifying the decoded content portion; and      encoding the decoded, modified content portion using the first motion vector and information about how the content portion was modified.    11.  A system comprising:    
    
     a decoder to decode a compressed video stream to generate a decoded content portion and a first motion vector portion;      a controller coupled to modify the decoded content portion; and      an encoder coupled to said controller to encode the decoded, modified content portion using the first motion vector and information about how the content portion was modified.    16.  An article comprising a medium storing instructions that when executed caused a processor-based system to:    
    
     decode a compressed video stream to generate a decoded content portion and a first motion vector portion;      modify the decoded content portion; and      encode the decoded, modified content portion using the first motion vector and information about how the content portion was modified.    2.  The method of  3.  The method of  4.  The method of    modifying the first motion vector into a modified motion vector portion based upon the modified, decoded content portion.    5.  The method of    combining the modified, decoded content portion with the modified motion vector portion to form a video stream; and      encoding the video stream.    6.  The method of    receiving a modification operation;      deriving a second operation from the modification operation; and      performing the second operation on the first motion vector portion to arrive at a second motion vector portion.    7.  The method of    testing the modified motion vector portion; and      adjusting the modified motion vector portion as a result of the testing.    10.  The method of    performing a scrolling operation on the decoded content portion.    12.  The system of    a memory storing the first motion vector portion and the information about how the content portion was modified; and      an enhancer to perform enhancement operations on the decoded content portion.    13.  The system of  14.  The system of  15.  The system of  17.  The article of  18.  The article of    receive compressed television content, decompress the compressed television content, enhance the decompressed television content, and encode the enhanced television content using information derived from decoding the information and information about how the content was enhanced.    19.  The article of    modify the first motion vector into a modified motion vector into a modified motion vector portion based upon the modified, decoded content portion.    20.  The article of    combine the modified decoded content portion with the modified motion vector portion to form a video stream; and      encode the video stream.   | |||||||||||||||||||||||
This invention relates to compressed data transmissions and, more particularly, to the decoding and encoding of data streams.
Multimedia, a combination of audio, video, still pictures, and text, is increasingly available to consumers worldwide. Multimedia content may be received by a computer connected to a network or by a television set connected to a cable wire, a satellite dish, or an antenna, as just a few examples.
Particularly because of the video content, multimedia data streams are typically compressed (or encoded) prior to transmission, then decompressed (or decoded) at a receiver. By one measure, a single second of uncompressed, broadcast quality video data may be represented using 270 Mbits. Transmission bandwidth and storage limitations make data compression a sensible choice for most applications.
One of the features of video compression is motion estimation. Motion estimation predicts where an object on a video frame will be, based upon the l,position of the object in a prior video frame. This repetition of images between frames "is known as temporal redundancy. Motion estimation exploits temporal redundancy by storing a motion vector to represent the position of an object relative to its position in a prior video frame. Using motion vectors, the bits used to represent the object may, in essence, be reused for each subsequent frame which includes the object.
Although effective in reducing the number of bits to be transmitted or stored, motion estimation is very computationally intensive, and thus, expensive. Although algorithms for "intelligent prediction" may reduce the cost of motion estimation, this aspect of video compression nevertheless remains an expensive part of the encoding process.
Increasingly, data streams such as multimedia content may, be manipulated down the pipeline before being received by the intended site. For example, a set-top box may re-format a data stream in some way before sending the data to a television. In order to "add value" to the multimedia content, the receiver thus may decode the data stream, make the desired changes to the video stream, and re-encode the data stream before sending to the site.
To encode the newly changed video stream, a new set of motion vectors may be calculated. However, particularly for some low-cost receiver/encoders, the capability to perform computationally intensive motion estimation may be limited
Thus, there is a continuing need to provide a low-cost system for decoding and encoding a data stream.
Although television sets and computers may receive multimedia content, set-top boxes are also available as multimedia receivers. Set-top boxes" are processor-based systems that work with a display such as a television set. The set-top box typically includes a decoder to decompress the streamed multimedia content before sending the content to the television display.
In addition to decoding the multimedia, the set-top box may add features to the incoming multimedia stream. For example, set-top box manufacturers may add graphical overlays to the video content, or may re-scale the video content or otherwise re-segment how the original video content is viewed on the television. In this: context, the set-top box may be thought of as an "enhancement receiver."
To add features to an incoming video stream, the enhancement receiver may decode the video stream, reproducing a sequence of video frames. Enhancements such as graphical overlays may then be added to each frame, as one example. Or, the video frames may be down-scaled in size, such that additional information is added to each frame, as another example.
Regardless of the particular enhancements made, the resulting video frames may be transmitted to a display for viewing. When the display device is not connected directly to the enhancement receiver (i.e., the display is remote from the receiver), the video frames may be re-encoded prior to transmission. Accordingly, the enhancement receiver may include both decoding and re-encoding circuitry together.
In 
The decoder 102 may decompress the video data stream 110, resulting in a reproduced image stream 112. The reproduced image 112 may then be sent to the local display 136 connected to the system 100. Because the display 136 is local, the reproduced image stream 112 is not re-encoded before being sent.
The reproduced image 112 may be manipulated in some manner by the system 100. Accordingly, in 
In addition to generating the reproduced image 112, the decoder 102 also extracts a plurality of motion vectors 118. The motion vectors 118, created at the remote transmission site during the encoding process, are embedded into the encoded video data stream 110. The motion vectors 118 include information about the relative positions of image objects between frames of the video image. According to one embodiment of the invention, the motions vectors 118 are sent from the decoder 102 to the encoder 106.
Once the enhanced image 114 is generated, the enhancement block 104 may send the image 114 to the encoder 106. The enhanced image 114 may thus be encoded for receipt by a remote display (not shown). Additionally, the enhanced image 114 may be sent directly to the local display 136 if desired.
For remote transmission of the enhanced image 114, the encoder 106 further receives a plurality of motion vector hints 108 from the enhancement block 104, according to one embodiment of the invention. The motion vector hints 108 are essentially information about the enhancement made to the reproduced image 112. By using the motion vectors 118 with the motion vector hints 108, the encoder 106 is provided with a "starting point" for generating new motion vectors and, thus, compressing the enhanced image 114. Thus, the encoder 106 may produce a compressed enhanced image 116, to be transmitted to a remote display (not shown).
Motion vectors are produced during a compression technique known as motion estimation. Motion estimation is but one of several techniques which may be employed to compress an image. The following discusses several compression techniques which are typically employed under the MPEG-2 compression standard. However, the described embodiments may be practiced under other compression standards without departing from the spiriting of the invention.
The Moving Pictures Experts Group, known as MPEG, was established in 1988 to develop a standard for the compression of both video and audio data streams. The MPEG-2 standard was defined in 1990 to support television applications including broadcast transmissions. MPEG-2 refers to International Organization for Standardization (ISO) and International Electrotechnical Commission (IEC) Standard 13818-1 (systems), 13818-2 (video), 13818-3 (audio) and 13818-4 (compliance) (1994).
Under the guidance of the MPEG-2 standard, several tech piques for performing video compression are widely employed. For each technique used during the encoding process, a corresponding inverse technique may be used during decoding of the image.
One procedure used with image compression is known as discrete cosine transform (DCT). A DCT operation may be performed upon portions, called blocks, of each video frame. Because the human eye is insensitive to high, frequencies in color changes, storing the real color values for each block may be inefficient. Using DCT, a set of frequency coefficients, describing color transitions in the block, replaces the real color values for each block. For each block, the frequency coefficients may be represented using fewer bits than the original image.
Another frequently used compression operation is quantization. The coefficients created during the DCT operation are typically quantized, or converted into values which may be represented using fewer bits. Some loss of information usually occurs during this process, which is why MPEG-2 is known as a "lossy" compression technique. The quantization method may be adjusted, depending on the image, to minimize the amount of information lost during quantization.
Variable length coding is another procedure commonly employed during MPEG compression. Essentially, bit patterns which occur frequently are replaced with codes of shorter length, reducing the total number of bits to be transmitted.
Another compression technique, motion estimation, may be performed to compress video images. By one measure, motion estimation represents about 90% of the cost, both in terms of time and computing power, of the entire compression operation. Motion estimation identifies objects in a video frame which were also present in a prior video frame. This temporal redundancy is exploited by storing, where possible, the relative position of an object in a video frame rather than the bitmap representation of the object itself.
In 
Typically, the video frame 170 is divided into macroblocks 172. Compression operations, including motion estimation, may be performed on each macroblock 172. Each macroblock 172 is typically further subdivided into multiple blocks of eight-by-eight pixels each. The blocks separately specify the luminance and chrominance information about the macroblock 172. The number of blocks in a macroblock 172 may vary, depending on the sampling format used to digitize the video image.
The macroblocks 172 are used to build the video image. Each macroblock 172, including blocks containing luminance and chrominance values, is encoded before being transmitted. In encoding each macroblock 172, any redundancies discovered between macroblocks are exploited. Thus, while the macroblock 172a may be encoded as "all white pixels," for example, the macroblock 172b may be encoded as "identical to macroblock 172a." The redundant macroblock 172b may thus be encoded using substantially fewer pixels. In the frame 170 of 
In addition to identifying identical macroblocks within a frame 170, the redundancy between frames is exploited during compression of a video image. This is where motion estimation may be used. In the frame 170 of 
In contrast, the motorcyclist object 174c is likely to move to a different set of macroblocks in successive frames of the image. Using motion estimation, a macroblock 172 of a video frame 170 may be compared to macroblocks 172 in both previous frames and subsequent frames, looking for a matching image, such as the motorcyclist object 174c. Once found, a representation of the movement of the object, known as motion vector, may be stored in lieu of a complete representation of the motorcyclist object 174c.
In 
One motion estimation technique is known as block matching. In 
Although conceptually simple, an enormous amount of computation power is used during block matching because every possible motion is tested over the assumed range. Thus, for example, if the objection 174 has moved in any direction by sixteen pixels or less, the object 174 may be located in one of sixty-five thousand different locations. At each position, every pixel in the macroblock 182ij is compared with every one of sixty-four thousand pixels in the input frame 190.
Whether by block matching or some other technique, to perform motion estimation, the input frame 190 is searched until the object 174 is found. In 
Because motion estimation is very computationally intensive, the processing power, the clock speed, and the available memory used to conduct motion estimation may be costly for some environments. Conventionally, relatively sophisticated equipment may be used at the data source to encode video data according to the MPEG-2 standard. The data source may include service providers such as studios or other producers that create material including DVD (digital video disc) movies, digital cable programming and programming for terrestrial transmission of HDTV (high definition television). Such sophisticated equipment may provide higher quality video with the relatively high cost effectively spread over viewers and consumers of the produced video data. Consequently, more accurate motion detection may be incorporated into the source video data (such as MPEG-2 data) than may be expected from consumer devices at the receiving end.
Although receivers may typically be more limited in their hardware capability than the transmitters at the data source, some receivers may nevertheless include hardware to encode a video data stream. Applications for re-encoding a data stream are emerging.
For example, some digital televisions may receiver over-the-air MPEG-2 transmissions. The data may be transmitted by digital modulation of standard TV carrier radio waves that were received by an antenna connected to a receiver. The manufacturers of receivers such as set-top boxes may want to re-broadcast cable and satellite MPEG-2 transmissions inside the home to these digital televisions without the need for a cable connection.
Further, some set-top box manufacturers may add graphical overlays to the transport stream or to re-scale or re-segment how the original MPEG-2 content is seen on the remote digital display. Such additions permit value-added services and capabilities to be presented through the digital television.
The system 100 of 
Instead, according to one embodiment of the invention, the system 100 of 
In 
The encoder 106 further includes circuitry for performing m!any of the operations described above. For example, a DCT block 152, a quantizer 162, and a variable length coder 154, are all featured as part of the encoder 106.
The motion vector hints 108 assist the motion estimator 158 in determining how changes may be made to the motion vectors 118. These hints 108 may be derived from the type of operation performed by the enhancement block 104 (
A vector field is a two-dimensional collection of vectors, often shown as a grid of arrows, each arrow having a unique length and direction. Vector, field continuity is the principle that, in some circumstances, a large portion of the two-dimensional array of motion vectors point in the same direction and have the same length as neighboring motion vectors.
Camera panning demonstrates vector field continuity well. When a camera pans, the resulting motion estimation motion vectors are typically all the same length. Further the motion vectors are pointing in a direction opposite to the panning direction of the camera. Thus, where a camera pans, vector field continuity may be used in deriving motion vector hints 108. By contrast, for a video image of people or objects moving about randomly, vector field continuity may not apply, except where a macroblock encloses a single object or person.
Vector field interpolation is another principle from which motion vector hints 108 may be derived. According to vector field interpolation, after creating a "coarse" vector field from a video image, the missing "fine" vectors in between the coarse vectors may be predicted by averaging the neighboring vectors. In one embodiment of the invention, vector field interpolation is used prior to performing exhaustive motion estimation searching.
For example, if a video frame is scaled down, the motion vectors from the unscaled video frame will be wrong. However, the coarse motion vectors may be fitted over the new macroblocks as a starting point for motion estimation. The coarse motion vectors may thus be provided to the motion estimator 158 as motion vector hints 108.
In a video image where simple offsets to the video image are added, the bulk of the motion vectors 118 may remain unaffected. If a video image is translated, such as by adding a graphics overlay to the video image, then, upon creating the enhanced image 114, the enhancement block may produce a two-dimensional vector, Ugraphic, for the graphics overlay as the motion vector hint 108. Thus, for each macroblock of the enhanced image 114, the motion estimator 158 adds the motion vector hint 108, Ugraphic, to the original motion vector 118, Vin, to produce a new motion vector, Vout. This new value, Vout, represents a starting point for performing motion estimation on the enhanced image 114.
Where the video image is scaled up or down in resolution, vector field interpolation may be used to compute new motion vectors so that the motion vectors 118 fit the new resolution of the macroblock. For example, for a video frame 170 which is reduced to 25% of its original size, objects 174 in the reduced video frame may not be located in the macroblocks corresponding with the original frame 170. Further, block matching will fail because the object size is reduced. Vector field interpolation provides a starting point for performing motion estimation.
Using these principles, a successful estimate for the motion vector of one object may simplify the derivation of all other object motion vectors in a frame. Upon arriving at a new motion vector, a local search of the enhanced video frame may be performed to further optimize the motion vectors.
By using the motion vector hints 108 provided by the enhancement circuitry 104, the encoder 106 may therefore calculate new motion vectors 120 without having to "start from scratch." Particularly for systems 100 which perform the same enhancement on a number of video frames, or for systems 100 which provide relatively simple enhancements, the re-encoding of an enhanced video data stream may thus be substantially simplified.
Alternatively, in one embodiment of the invention, the encoder 106 may receive the enhanced image 114 and the reproduced image 112. From the two images, the encoder 106 may derive the motion vector hints 108, based upon a comparison between the images 112 and 114. For example, if the enhanced image 114 includes a graphics overlay image, a subtraction of the reproduced image 112 from the enhanced image 114 will produce the graphics overlay image. From this information, the encoder 106 may derive motion vector hints 108, such that the new motion vectors 120 may be derived.
Video frames which include graphics-only elements May present distinct challenges. Since graphic elements are usually created by means of high-level display lists of commands, the motion vector hints 108 may include data structures for handling movement of the graphics elements. For example, in one embodiment of the invention, text which is scrolled upwards is accompanied by a data structure of motion vector hints 108 containing an upward pointing vector field of the correct magnitude.
In another embodiment of the invention, for three-dimensional graphics, objects are supplemented with motion vectors projected onto the screen coordinate system. Regardless of the particular type of motion vector hints 108 employed, the motion estimator 158 may additionally perform a local search, for "fine tuning" of the motion vector. As with traditional video, the motion vector hints 108 for, graphic-only images provide the motion estimator with a "head start" for determining the correct location of an object in the video frame 170.
In yet another embodiment of the invention, where mixed video and graphics macroblocks 172 are found in the video frame 170, the individually computed new motion vectors 120 for each may be averaged to arrive at a good starting point for guessing a motion vector for the combined image.
A variety of other algorithms may be employed for creating new motion vectors. These algorithms may be derived from the type of video input, the type of operation performed upon the video input and other factors. The encoder 106 is thus able to simplify the motion estimation process by receiving the prior motion vectors 118 and the motion vector hints 108 from the enhancement block 104, to arrive, a new motion vectors 120.
Looking back to 
In 
The system 100 may next create a modified motion vector portion from the first motion vector portion based upon the modification operation. For instance, the system 100 may perform an operation on the plurality of motion vectors 118, based upon the motion vector hints 108 to arrive at a second motion vector portion. A plurality of new motion vectors 120 is thus created (block 208). The new motion vectors 120 may be a "starting point" for determining what the actual motion vectors, or the modified motion vector portion, for the enhanced image 114 should be. Accordingly, to test the new motion vectors 120, a quick local search of the video frame 170 may be conducted, using the new motion vectors 120 (block 210). This operation may be repeated as needed, with the new motion vectors 120 being updated each time the local search is performed.
Upon completion of the local search, a plurality of new motion vectors 120 may be sent to the encoder 106 (block 212). There, the new motion vectors 120 are combined with the enhanced data stream 114 (block 214) to form a third video stream. The encoder 106 may then compress the enhanced data stream 114 as well as the newly created new motion vectors 120 (block 216) to encode the third video stream. The enhanced compressed image 116 may thus be transmitted to a remote display device (block 218). The operation is thus complete.
In 
The north bridge 304 is further coupled to a memory 308. In one embodiment of the invention, the enhancement block 104 is part of a software program 200 (
The PCI bus 310 is coupled to a south bridge 306. The south bridge 306 may provide an interface, such as to a hard disk drive 334, or the south bridge may act as a bridge between the PCI bus 310 and a second bus (not show). The software program 200, as illustrated in 
The PCI bus is further connected to a graphic controller 320. The graphics controller includes a frame buffer 312, which may be used to store video frames, for example. The graphics controller 320 may transmit an incoming data stream through a high quality S-video out port 324 or though a composite video out port 326. These ports 324 or 326 may be used for connecting the system 300 to a display, such as a television set.
The system 300 further includes a tuner 322 and a video capture device 316, according to one embodiment of the invention. The tuner 322 and the video capture card 316 may be combined as a single device in other embodiments.
In one embodiment of the invention, the tuner 322 receives a video signal from a signal in port 328. The signal may then be sent to the video capture module 316. The video capture module 316 sends the signal to the graphic controller 314. A signal out port 332 may be used to connect to a second device, such as a video cassette recorder.
Also connected to the PCI bus 310 is an MPEG encoder/decoder 330. The MPEG encoder/decoder 330 may assist the software program 200 in performing the operations described in the flow diagram of FIG. 5.
Thus, a system for performing re-coding of video data streams uses previously calculated motion vectors as a starting point for calculating new motion vectors. The system, upon enhancing the decoded video image, may pass those enhancements onto the encoder, such that new motion vectors may be derived, based upon the enhancements. In some embodiments, the motion vectors may be created without performing excessive calculations. In some embodiments, the encoder may arrive at a new motion vector based upon the type of image. The system may be used in receivers, such as set-top boxes, without expensive hardware, such that enhancements to a video data stream may be performed and then transmitted remotely from the set-top box in some embodiments. Other embodiments with other advantages may be derived from the embodiments described herein.
While the invention has been disclosed with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of the invention.
| Patent | Priority | Assignee | Title | 
| 10200744, | Jun 06 2013 | ACTIVEVIDEO NETWORKS, INC. | Overlay rendering of user interface onto source video | 
| 10275128, | Mar 15 2013 | ACTIVEVIDEO NETWORKS, INC | Multiple-mode system and method for providing user selectable video content | 
| 10409445, | Jan 09 2012 | ACTIVEVIDEO NETWORKS, INC | Rendering of an interactive lean-backward user interface on a television | 
| 10506298, | Apr 03 2012 | ACTIVEVIDEO NETWORKS, INC. | Class-based intelligent multiplexing over unmanaged networks | 
| 10678747, | Nov 13 2007 | Amazon Technologies, Inc | Video encoding and decoding using parallel processors | 
| 10757481, | Apr 03 2012 | ACTIVEVIDEO NETWORKS, INC. | Class-based intelligent multiplexing over unmanaged networks | 
| 11073969, | Mar 15 2013 | ACTIVEVIDEO NETWORKS, INC. | Multiple-mode system and method for providing user selectable video content | 
| 7269785, | Dec 30 1999 | AIDO LLC | Digital manipulation of video in digital video player | 
| 7522125, | Aug 06 2001 | ATI International SRL | Wireless device method and apparatus with drawing command throttling control | 
| 8155202, | Jan 12 2007 | ACTIVEVIDEO NETWORKS, INC | System and method for encoding scrolling raster images | 
| 8184715, | Aug 09 2007 | Amazon Technologies, Inc | Method for efficiently executing video encoding operations on stream processor architectures | 
| 8250618, | Sep 18 2006 | Amazon Technologies, Inc | Real-time network adaptive digital video encoding/decoding | 
| 8428090, | Apr 03 2002 | TIVO CORPORATION | Transmitting timing information for content in a data stream | 
| 8434101, | Apr 03 2002 | TIVO CORPORATION | Processing applications with multiple privilege levels | 
| 8437373, | Apr 03 2002 | TIVO CORPORATION | Transmitting enhancement data for video | 
| 8437407, | Aug 09 2007 | Amazon Technologies, Inc | Method for efficiently executing video encoding operations on stream processor architectures | 
| 8634469, | Feb 06 2006 | INTERDIGITAL MADISON PATENT HOLDINGS | Method and apparatus for reusing available motion information as a motion estimation predictor for video encoding | 
| 8989223, | Apr 03 2002 | TIVO CORPORATION | Advancing virtual time bases for content | 
| 9021541, | Oct 14 2010 | ACTIVEVIDEO NETWORKS, INC | Streaming digital video between video devices using a cable television system | 
| 9036015, | Nov 23 2005 | Koninklijke Philips Electronics N V | Rendering views for a multi-view display device | 
| 9042454, | Jan 12 2007 | ACTIVEVIDEO NETWORKS, INC | Interactive encoded content system including object models for viewing on a remote device | 
| 9049467, | Apr 03 2002 | TIVO CORPORATION | Method and apparatus for transmitting enhancement data in a data stream | 
| 9077860, | Jul 26 2005 | ACTIVEVIDEO NETWORKS, INC. | System and method for providing video content associated with a source image to a television in a communication network | 
| 9123084, | Apr 12 2012 | ACTIVEVIDEO NETWORKS, INC | Graphical application integration with MPEG objects | 
| 9148677, | Apr 03 2002 | TIVO CORPORATION | Accessing a higher privileged application function from a lower privileged application | 
| 9204203, | Apr 07 2011 | ACTIVEVIDEO NETWORKS, INC | Reduction of latency in video distribution networks using adaptive bit rates | 
| 9219922, | Jun 06 2013 | ACTIVEVIDEO NETWORKS, INC | System and method for exploiting scene graph information in construction of an encoded video sequence | 
| 9294785, | Jun 06 2013 | ACTIVEVIDEO NETWORKS, INC | System and method for exploiting scene graph information in construction of an encoded video sequence | 
| 9326047, | Jun 06 2013 | ACTIVEVIDEO NETWORKS, INC | Overlay rendering of user interface onto source video | 
| 9355681, | Jan 12 2007 | ACTIVEVIDEO NETWORKS, INC | MPEG objects and systems and methods for using MPEG objects | 
| 9451299, | Apr 03 2002 | TIVO CORPORATION | Method and apparatus for transmitting enhancement data in data streams | 
| 9535993, | Jun 11 2008 | Enpulz, LLC | Creative work registry | 
| 9544523, | Aug 06 2001 | ATI Technologies ULC | Wireless display apparatus and method | 
| 9596495, | Apr 03 2002 | TIVO CORPORATION | Method and apparatus for determining data is available using a virtual time base | 
| 9747251, | Nov 13 2007 | Amazon Technologies, Inc | Video encoding and decoding using parallel processors | 
| 9788029, | Apr 25 2014 | ACTIVEVIDEO NETWORKS, INC | Intelligent multiplexing using class-based, multi-dimensioned decision logic for managed networks | 
| 9800945, | Apr 03 2012 | ACTIVEVIDEO NETWORKS, INC | Class-based intelligent multiplexing over unmanaged networks | 
| 9826197, | Jan 12 2007 | ACTIVEVIDEO NETWORKS, INC | Providing television broadcasts over a managed network and interactive content over an unmanaged network to a client device | 
| 9986271, | Apr 03 2002 | TIVO CORPORATION | Method and apparatus for accessing higher privileged functions from lower privileged functions | 
| Patent | Priority | Assignee | Title | 
| 5418571, | Feb 01 1991 | British Telecommunicatons public limited company | Decoding of double layer video signals with interpolation replacement on missing data from enhancement layer | 
| 5742343, | Jul 13 1993 | THE CHASE MANHATTAN BANK, AS COLLATERAL AGENT | Scalable encoding and decoding of high-resolution progressive video | 
| 5988863, | Jan 30 1996 | DOLBY LABORATORIES, INC ; Dolby Laboratories Licensing Corporation | Temporal and resolution layering in advanced television | 
| 6275531, | Jul 07 1998 | OPTIVISION, INC | Scalable video coding method and apparatus | 
| 6292512, | Jul 06 1998 | FUNAI ELECTRIC CO , LTD | Scalable video coding system | 
| 6330280, | Nov 08 1996 | Sony Corporation | Method and apparatus for decoding enhancement and base layer image signals using a predicted image signal | 
| 6339618, | Jan 08 1997 | AT&T Corp. | Mesh node motion coding to enable object based functionalities within a motion compensated transform video coder | 
| 6493390, | Oct 02 1997 | Kokusai Denshin Denwa Kabushiki Kaisha | Motion compensation image encoding device | 
| 6577682, | Jan 22 1998 | British Broadcasting Corporation | Video processing system also compressing coding decision data | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Feb 18 2000 | HANNAH, ERIC C | Intel Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 010644/ | 0510 | |
| Feb 28 2000 | Intel Corporation | (assignment on the face of the patent) | / | 
| Date | Maintenance Fee Events | 
| Sep 14 2005 | ASPN: Payor Number Assigned. | 
| Feb 01 2008 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. | 
| Feb 11 2008 | REM: Maintenance Fee Reminder Mailed. | 
| Sep 21 2011 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. | 
| Jan 20 2016 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. | 
| Date | Maintenance Schedule | 
| Aug 03 2007 | 4 years fee payment window open | 
| Feb 03 2008 | 6 months grace period start (w surcharge) | 
| Aug 03 2008 | patent expiry (for year 4) | 
| Aug 03 2010 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Aug 03 2011 | 8 years fee payment window open | 
| Feb 03 2012 | 6 months grace period start (w surcharge) | 
| Aug 03 2012 | patent expiry (for year 8) | 
| Aug 03 2014 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Aug 03 2015 | 12 years fee payment window open | 
| Feb 03 2016 | 6 months grace period start (w surcharge) | 
| Aug 03 2016 | patent expiry (for year 12) | 
| Aug 03 2018 | 2 years to revive unintentionally abandoned end. (for year 12) |