Professional Documents
Culture Documents
Nokia VP8 Infringement Claim Chart For '211 Patent
Nokia VP8 Infringement Claim Chart For '211 Patent
CLAIM CHART SHOWING INFRINGEMENT OF THE 6,711,211 PATENT BY THE HTC ONE MOBILE PHONE
Exhibit No. 16 Claim Chart Showing Infringement of the 6,711,211 Patent by The HTC One Mobile Phone1 Claims of the 211 Patent
26. A method for decoding encoded video information, including deriving prediction motion coefficients for blocks within a macroblock of a video frame being decoded from motion coefficients of at least one prediction block that is a previously decoded macroblock or block within said video frame, the method comprising:
(Figure 1). All products running Android version 2.3 and above are capable of decoding encoded video information by decoding encoded VP8 videos. See Exhibit 25 (http://developer.android.com/about/versions/android-2.3-highlights.html) (The platform now offers built-in support for the VP8 open video compression format and the WebM open container format). Exhibit 50, titled VP8 Data Format and Decoding Guide describes the method for decoding the encoded VP8 video information.
This claim chart is based on the information currently available to Nokia and is intended to be exemplary in nature. Nokia reserves all rights to update and elaborate its infringement positions, including as Nokia obtains additional information during the course of discovery.
-2-
. . . This document describes the VP8 compressed video data format, together with a discussion of the decoding procedure for the format. It is intended to be used in conjunction with, and as a guide to, the reference decoder source code provided in Attachment One (Section 20). (Exhibit 50 at p. 4).
coefficients of at least one prediction block that is a previously decoded macroblock or block within said video frame.
2. Format Overview
. . . Internally, VP8 decomposes each output frame into an array of macroblocks. A macroblock is a square array of pixels whose Y dimensions are 16x16 and whose U and V dimensions are 8x8. . . . Macroblocks are further decomposed into 4x4 subblocks. Every macroblock has 16 Y subblocks, 4 U subblocks, and 4 V subblocks. (Exhibit 50 at p. 6).
-3-
-4-
. . . After the partition come two (for mv_top_bottom or mv_left_right), four (for mv_quarters), or sixteen (for MV_16) subblock inter-prediction modes. . . .
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e., collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to ensure the correctness of prediction within this macroblock, all subblocks lying in an already-decoded subset of the current macroblock must have their motion vectors set. ZERO4x4 uses a zero motion vector and predicts the current subset using the corresponding subset from the prediction frame. NEW4x4 is exactly like NEWMV except that NEW4x4 is applied only to the current subset. It is followed by a two-dimensional motion vector offset (described in the next section) that is added to the best vector returned by the earlier call to find_near_mvs to form the motion vector in effect for the subset.
-5-
2. Format Overview
. . . Internally, VP8 decomposes each output frame into an array of macroblocks. A macroblock is a square array of pixels whose Y dimensions are 16x16 and whose U and V dimensions are 8x8. . . . Macroblocks are further decomposed into 4x4 subblocks. Every macroblock has 16 Y subblocks, 4 U subblocks, and 4 V subblocks. (Exhibit 50 at p. 6).
(Exhibit 50 at p. 105). (b) defining for each available macroblock segmentation at least one available prediction method, thereby providing a certain finite number of available macroblocksegmentation-prediction-method pairs, The device performs the step of defining for each available macroblock segmentation at least one available prediction method, thereby providing a certain finite number of available macroblock-segmentation--prediction-method pairs, each prediction method defining a method for deriving prediction motion coefficients for blocks within a macroblock using motion coefficients of at least one prediction block.
-6-
-7-
. . . After the partition come two (for mv_top_bottom or mv_left_right),four (for mv_quarters), or sixteen (for MV_16) subblock inter-prediction modes. . . .
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e.,collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to ensure the correctness of prediction within this macroblock, all subblocks lying in an already-decoded subset of the current macroblock must have their motion vectors set. ZERO4x4 uses a zero motion vector and predicts the current subset using the corresponding subset from the prediction frame. NEW4x4 is exactly like NEWMV except that NEW4x4 is applied only to the current subset. It is followed by a two-dimensional motion vector offset (described in the next section) that is added to the best vector returned by the earlier call to find_near_mvs to form the motion vector in effect for the subset.
-8-
. . .
-9-
(Exhibit 50 at pp. 105, 106, 108). (c) receiving information indicating at least the macroblock segmentation selected for a macroblock in said encoded video information; and The device performs the step of receiving information indicating at least the macroblock segmentation selected for a macroblock in said encoded video information.
- 10 -
(Exhibit 50 at p. 105). (d) determining the The device performs the step of determining the prediction method relating to the
- 11 -
(Exhibit 50 at p. 99).
and producing prediction motion coefficients for blocks within said macroblock using the determined prediction method.
The device performs the step of determining the prediction method relating to the macroblock segmentation of said macroblock with reference to the defined macroblocksegmentation--prediction-method pairs and producing prediction motion coefficients for blocks within said macroblock using the determined prediction method.
- 12 -
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to-the-left of the subblock at the upper left corner of the current subset (i.e., collection of subblocks being predicted). (Exhibit 50 at pp. 105, 106, 108).
- 13 -
performing motion compensated decoding of encoded video information, said decoder being arranged to derive prediction motion coefficients for blocks within a macroblock of a video frame being decoded from motion coefficients of at least one prediction block that is a previously decoded macroblock or block within said video frame.
Specifically, all products running Android version 2.3 and above are capable of decoding encoded video information by decoding encoded VP8 videos. See Exhibit 25 (http://developer.android.com/about/versions/android-2.3-highlights.html) (The platform now offers built-in support for the VP8 open video compression format and the WebM open container format). The device runs the Android version 4.1.2 operating system.
(Figure 2). Exhibit 50, titled VP8 Data Format and Decoding Guide describes the decoder used to perform motion compensated decoding of encoded VP8 video information.
1. Introduction
. . . This document describes the VP8 compressed video data format, together with a discussion of the decoding procedure for the format. It is intended to be used in conjunction with, and as a guide to, the reference decoder source code provided in Attachment One (Section 20). (Exhibit 50 at p. 4).
- 14 -
The following excerpts from Exhibit 50 illustrate that the decoder in the device is arranged to derive prediction motion coefficients for blocks within a macroblock of a video frame
being decoded from motion coefficients of at least one prediction block that is a previously decoded macroblock or block within said video frame.
2. Format Overview
. . . Internally, VP8 decomposes each output frame into an array of macroblocks. A macroblock is a square array of pixels whose Y dimensions are 16x16 and whose U and V dimensions are 8x8. . . . Macroblocks are further decomposed into 4x4 subblocks. Every macroblock has 16 Y subblocks, 4 U subblocks, and 4 V subblocks. (Exhibit 50 at p. 6).
- 15 -
- 16 -
. . . After the partition come two (for mv_top_bottom or mv_left_right), four (for mv_quarters), or sixteen (for MV_16) subblock inter-prediction modes. . . .
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e., collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to ensure the correctness of prediction within this macroblock, all subblocks lying in an already-decoded subset of the current macroblock must have their motion vectors set. ZERO4x4 uses a zero motion vector and predicts the current subset using the corresponding subset from the prediction frame. NEW4x4 is exactly like NEWMV except that NEW4x4 is applied only to the current subset. It is followed by a two-dimensional motion vector offset (described in the next section) that is added to the best vector returned by the earlier call to find_near_mvs to form the motion vector in effect for the subset.
(Exhibit 50 at pp. 105, 106, 108). (a) means for defining a certain number of available macroblock The device contains a means for defining a certain number of available macroblock segmentations that specify possible ways in which a macroblock can be segmented into blocks.
- 17 -
2. Format Overview
. . . Internally, VP8 decomposes each output frame into an array of macroblocks. A macroblock is a square array of pixels whose Y dimensions are 16x16 and whose U and V dimensions are 8x8. . . . Macroblocks are further decomposed into 4x4 subblocks. Every macroblock has 16 Y subblocks, 4 U subblocks, and 4 V subblocks. (Exhibit 50 at p. 6).
(Exhibit 50 at p. 105). (b) means for specifying at least one available prediction method for each available macroblock segmentation, thereby providing a certain finite number of available macroblocksegmentation-prediction-method pairs, The device contains a means for specifying at least one available prediction method for each available macroblock segmentation, thereby providing a certain finite number of available macroblock-segmentation--prediction-method pairs, each prediction method defining a method for deriving prediction motion coefficients for blocks within a macroblock using motion coefficients of at least one prediction block.
- 18 -
- 19 -
. . . After the partition come two (for mv_top_bottom or mv_left_right),four (for mv_quarters), or sixteen (for MV_16) subblock inter-prediction modes. . . .
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e.,collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to ensure the correctness of prediction within this macroblock, all subblocks lying in an already-decoded subset of the current macroblock must have their motion vectors set. ZERO4x4 uses a zero motion vector and predicts the current subset using the corresponding subset from the prediction frame. NEW4x4 is exactly like NEWMV except that NEW4x4 is applied only to the current subset. It is followed by a two-dimensional motion vector offset (described in the next section) that is added to the best vector returned by the earlier call to find_near_mvs to form the motion vector in effect for the subset.
(Exhibit 50 at pp. 105, 106, 108). each prediction method defining a method for deriving prediction motion coefficients for The device contains a means for specifying at least one available prediction method for each available macroblock segmentation, thereby providing a certain finite number of available macroblock-segmentation--prediction-method pairs, each prediction method defining a method for deriving prediction motion coefficients for blocks within a
- 20 -
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e.,collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to
- 21 -
(c) input means for receiving information indicating at least the macroblock segmentation selected for a macroblock;
The device contains an input means for receiving information indicating at least the macroblock segmentation selected for a macroblock.
- 22 -
(Exhibit 50 at p. 105). (d) means for determining the prediction method relating to the segmentation of the macroblock with The device contains a means for determining the prediction method relating to the segmentation of the macroblock with reference to the defined macroblocksegmentation--prediction-method pairs.
- 23 -
(Exhibit 50 at p. 99).
(e) means for producing prediction motion coefficients for blocks within said macroblock using the determined prediction method.
The device contains a means for producing prediction motion coefficients for blocks within said macroblock using the determined prediction method.
- 24 -
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to-the-left of the subblock at the upper left corner of the current subset (i.e., collection of subblocks being predicted). (Exhibit 50 at pp. 105, 106, 108).
- 25 -
(Figure 3). Exhibit 50, titled VP8 Data Format and Decoding Guide describes the decoder used to perform motion compensated decoding of encoded VP8 video information.
1. Introduction
. . . This document describes the VP8 compressed video data format, together with a discussion of the decoding procedure for the format. It is intended to be used in conjunction with, and as a guide to, the reference decoder source code provided in Attachment One (Section 20). (Exhibit 50 at p. 4).
- 26 -
The following excerpts from Exhibit 50 illustrate that the decoder in the device is arranged to derive prediction motion coefficients for blocks within a macroblock of a video frame
being decoded from motion coefficients of at least one prediction block that is a previously decoded macroblock or block within said video frame.
2. Format Overview
. . . Internally, VP8 decomposes each output frame into an array of macroblocks. A macroblock is a square array of pixels whose Y dimensions are 16x16 and whose U and V dimensions are 8x8. . . . Macroblocks are further decomposed into 4x4 subblocks. Every macroblock has 16 Y subblocks, 4 U subblocks, and 4 V subblocks. (Exhibit 50 at p. 6).
- 27 -
- 28 -
. . . After the partition come two (for mv_top_bottom or mv_left_right), four (for mv_quarters), or sixteen (for MV_16) subblock inter-prediction modes. . . .
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e., collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to ensure the correctness of prediction within this macroblock, all subblocks lying in an already-decoded subset of the current macroblock must have their motion vectors set. ZERO4x4 uses a zero motion vector and predicts the current subset using the corresponding subset from the prediction frame. NEW4x4 is exactly like NEWMV except that NEW4x4 is applied only to the current subset. It is followed by a two-dimensional motion vector offset (described in the next section) that is added to the best vector returned by the earlier call to find_near_mvs to form the motion vector in effect for the subset.
The device contains a program means for defining a certain number of available macroblock segmentations that specify possible ways in which a macroblock can be
- 29 -
2. Format Overview
. . . Internally, VP8 decomposes each output frame into an array of macroblocks. A macroblock is a square array of pixels whose Y dimensions are 16x16 and whose U and V dimensions are 8x8. . . . Macroblocks are further decomposed into 4x4 subblocks. Every macroblock has 16 Y subblocks, 4 U subblocks, and 4 V subblocks. (Exhibit 50 at p. 6).
(Exhibit 50 at p. 105). (b) program means for specifying at least one available prediction method for each available macroblock segmentation, thereby providing a certain finite number of available macroblock segmentation-predictionmethod pairs, The device contains a program means for specifying at least one available prediction method for each available macroblock segmentation, thereby providing a certain finite number of available macroblock segmentation-prediction-method pairs, each prediction method defining a method for deriving prediction motion coefficients for blocks within a macroblock using motion coefficients of at least one prediction block.
- 30 -
- 31 -
. . . After the partition come two (for mv_top_bottom or mv_left_right),four (for mv_quarters), or sixteen (for MV_16) subblock inter-prediction modes. . . .
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e.,collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be zero, as are subblock motion vectors within an intra-predicted macroblock. Also, to ensure the correctness of prediction within this macroblock, all subblocks lying in an already-decoded subset of the current macroblock must have their motion vectors set. ZERO4x4 uses a zero motion vector and predicts the current subset using the corresponding subset from the prediction frame. NEW4x4 is exactly like NEWMV except that NEW4x4 is applied only to the current subset. It is followed by a two-dimensional motion vector offset (described in the next section) that is added to the best vector returned by the earlier call to find_near_mvs to form the motion vector in effect for the subset.
(Exhibit 50 at pp. 105, 106, 108). each prediction method defining a method for deriving prediction motion coefficients for The device contains a program means for specifying at least one available prediction method for each available macroblock segmentation, thereby providing a certain finite number of available macroblock segmentation-prediction-method pairs, each prediction method defining a method for deriving prediction motion
- 32 -
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to the left of the subblock at the upper left corner of the current subset (i.e.,collection of subblocks being predicted). These prediction blocks need not lie in the current macroblock and, if the current subset lies at the top or left edges of the frame, need not lie in the frame. In this latter case, their motion vectors are taken to be
- 33 -
(c) program means for receiving information indicating at least the macroblocksegmentation selected for a macroblock;
The device contains a program means for receiving information indicating at least the macroblock-segmentation selected for a macroblock.
- 34 -
(Exhibit 50 at p. 105). (d) program means for determining the prediction-method relating to the segmentation of the The device contains a program means for determining the prediction-method relating to the segmentation of the macroblock with reference to the defined macroblocksegmentation-prediction-method pairs.
- 35 -
(Exhibit 50 at p. 99).
(e) program means for producing prediction motion coefficients for blocks within said macroblock using the determined prediction method.
The device contains a program means for producing prediction motion coefficients for blocks within said macroblock using the determined prediction method.
- 36 -
. . . The first two sub-prediction modes simply copy the already-coded motion vectors used by the blocks above and to-the-left of the subblock at the upper left corner of the current subset (i.e., collection of subblocks being predicted). (Exhibit 50 at pp. 105, 106, 108).
- 37 -