1*3e3b1fb0SAndrzej Pietrasiewicz // SPDX-License-Identifier: GPL-2.0
2*3e3b1fb0SAndrzej Pietrasiewicz /*
3*3e3b1fb0SAndrzej Pietrasiewicz * V4L2 VP9 helpers.
4*3e3b1fb0SAndrzej Pietrasiewicz *
5*3e3b1fb0SAndrzej Pietrasiewicz * Copyright (C) 2021 Collabora, Ltd.
6*3e3b1fb0SAndrzej Pietrasiewicz *
7*3e3b1fb0SAndrzej Pietrasiewicz * Author: Andrzej Pietrasiewicz <andrzej.p@collabora.com>
8*3e3b1fb0SAndrzej Pietrasiewicz */
9*3e3b1fb0SAndrzej Pietrasiewicz
10*3e3b1fb0SAndrzej Pietrasiewicz #include <linux/module.h>
11*3e3b1fb0SAndrzej Pietrasiewicz
12*3e3b1fb0SAndrzej Pietrasiewicz #include <media/v4l2-vp9.h>
13*3e3b1fb0SAndrzej Pietrasiewicz
14*3e3b1fb0SAndrzej Pietrasiewicz const u8 v4l2_vp9_kf_y_mode_prob[10][10][9] = {
15*3e3b1fb0SAndrzej Pietrasiewicz {
16*3e3b1fb0SAndrzej Pietrasiewicz /* above = dc */
17*3e3b1fb0SAndrzej Pietrasiewicz { 137, 30, 42, 148, 151, 207, 70, 52, 91 }, /*left = dc */
18*3e3b1fb0SAndrzej Pietrasiewicz { 92, 45, 102, 136, 116, 180, 74, 90, 100 }, /*left = v */
19*3e3b1fb0SAndrzej Pietrasiewicz { 73, 32, 19, 187, 222, 215, 46, 34, 100 }, /*left = h */
20*3e3b1fb0SAndrzej Pietrasiewicz { 91, 30, 32, 116, 121, 186, 93, 86, 94 }, /*left = d45 */
21*3e3b1fb0SAndrzej Pietrasiewicz { 72, 35, 36, 149, 68, 206, 68, 63, 105 }, /*left = d135*/
22*3e3b1fb0SAndrzej Pietrasiewicz { 73, 31, 28, 138, 57, 124, 55, 122, 151 }, /*left = d117*/
23*3e3b1fb0SAndrzej Pietrasiewicz { 67, 23, 21, 140, 126, 197, 40, 37, 171 }, /*left = d153*/
24*3e3b1fb0SAndrzej Pietrasiewicz { 86, 27, 28, 128, 154, 212, 45, 43, 53 }, /*left = d207*/
25*3e3b1fb0SAndrzej Pietrasiewicz { 74, 32, 27, 107, 86, 160, 63, 134, 102 }, /*left = d63 */
26*3e3b1fb0SAndrzej Pietrasiewicz { 59, 67, 44, 140, 161, 202, 78, 67, 119 }, /*left = tm */
27*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = v */
28*3e3b1fb0SAndrzej Pietrasiewicz { 63, 36, 126, 146, 123, 158, 60, 90, 96 }, /*left = dc */
29*3e3b1fb0SAndrzej Pietrasiewicz { 43, 46, 168, 134, 107, 128, 69, 142, 92 }, /*left = v */
30*3e3b1fb0SAndrzej Pietrasiewicz { 44, 29, 68, 159, 201, 177, 50, 57, 77 }, /*left = h */
31*3e3b1fb0SAndrzej Pietrasiewicz { 58, 38, 76, 114, 97, 172, 78, 133, 92 }, /*left = d45 */
32*3e3b1fb0SAndrzej Pietrasiewicz { 46, 41, 76, 140, 63, 184, 69, 112, 57 }, /*left = d135*/
33*3e3b1fb0SAndrzej Pietrasiewicz { 38, 32, 85, 140, 46, 112, 54, 151, 133 }, /*left = d117*/
34*3e3b1fb0SAndrzej Pietrasiewicz { 39, 27, 61, 131, 110, 175, 44, 75, 136 }, /*left = d153*/
35*3e3b1fb0SAndrzej Pietrasiewicz { 52, 30, 74, 113, 130, 175, 51, 64, 58 }, /*left = d207*/
36*3e3b1fb0SAndrzej Pietrasiewicz { 47, 35, 80, 100, 74, 143, 64, 163, 74 }, /*left = d63 */
37*3e3b1fb0SAndrzej Pietrasiewicz { 36, 61, 116, 114, 128, 162, 80, 125, 82 }, /*left = tm */
38*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = h */
39*3e3b1fb0SAndrzej Pietrasiewicz { 82, 26, 26, 171, 208, 204, 44, 32, 105 }, /*left = dc */
40*3e3b1fb0SAndrzej Pietrasiewicz { 55, 44, 68, 166, 179, 192, 57, 57, 108 }, /*left = v */
41*3e3b1fb0SAndrzej Pietrasiewicz { 42, 26, 11, 199, 241, 228, 23, 15, 85 }, /*left = h */
42*3e3b1fb0SAndrzej Pietrasiewicz { 68, 42, 19, 131, 160, 199, 55, 52, 83 }, /*left = d45 */
43*3e3b1fb0SAndrzej Pietrasiewicz { 58, 50, 25, 139, 115, 232, 39, 52, 118 }, /*left = d135*/
44*3e3b1fb0SAndrzej Pietrasiewicz { 50, 35, 33, 153, 104, 162, 64, 59, 131 }, /*left = d117*/
45*3e3b1fb0SAndrzej Pietrasiewicz { 44, 24, 16, 150, 177, 202, 33, 19, 156 }, /*left = d153*/
46*3e3b1fb0SAndrzej Pietrasiewicz { 55, 27, 12, 153, 203, 218, 26, 27, 49 }, /*left = d207*/
47*3e3b1fb0SAndrzej Pietrasiewicz { 53, 49, 21, 110, 116, 168, 59, 80, 76 }, /*left = d63 */
48*3e3b1fb0SAndrzej Pietrasiewicz { 38, 72, 19, 168, 203, 212, 50, 50, 107 }, /*left = tm */
49*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = d45 */
50*3e3b1fb0SAndrzej Pietrasiewicz { 103, 26, 36, 129, 132, 201, 83, 80, 93 }, /*left = dc */
51*3e3b1fb0SAndrzej Pietrasiewicz { 59, 38, 83, 112, 103, 162, 98, 136, 90 }, /*left = v */
52*3e3b1fb0SAndrzej Pietrasiewicz { 62, 30, 23, 158, 200, 207, 59, 57, 50 }, /*left = h */
53*3e3b1fb0SAndrzej Pietrasiewicz { 67, 30, 29, 84, 86, 191, 102, 91, 59 }, /*left = d45 */
54*3e3b1fb0SAndrzej Pietrasiewicz { 60, 32, 33, 112, 71, 220, 64, 89, 104 }, /*left = d135*/
55*3e3b1fb0SAndrzej Pietrasiewicz { 53, 26, 34, 130, 56, 149, 84, 120, 103 }, /*left = d117*/
56*3e3b1fb0SAndrzej Pietrasiewicz { 53, 21, 23, 133, 109, 210, 56, 77, 172 }, /*left = d153*/
57*3e3b1fb0SAndrzej Pietrasiewicz { 77, 19, 29, 112, 142, 228, 55, 66, 36 }, /*left = d207*/
58*3e3b1fb0SAndrzej Pietrasiewicz { 61, 29, 29, 93, 97, 165, 83, 175, 162 }, /*left = d63 */
59*3e3b1fb0SAndrzej Pietrasiewicz { 47, 47, 43, 114, 137, 181, 100, 99, 95 }, /*left = tm */
60*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = d135 */
61*3e3b1fb0SAndrzej Pietrasiewicz { 69, 23, 29, 128, 83, 199, 46, 44, 101 }, /*left = dc */
62*3e3b1fb0SAndrzej Pietrasiewicz { 53, 40, 55, 139, 69, 183, 61, 80, 110 }, /*left = v */
63*3e3b1fb0SAndrzej Pietrasiewicz { 40, 29, 19, 161, 180, 207, 43, 24, 91 }, /*left = h */
64*3e3b1fb0SAndrzej Pietrasiewicz { 60, 34, 19, 105, 61, 198, 53, 64, 89 }, /*left = d45 */
65*3e3b1fb0SAndrzej Pietrasiewicz { 52, 31, 22, 158, 40, 209, 58, 62, 89 }, /*left = d135*/
66*3e3b1fb0SAndrzej Pietrasiewicz { 44, 31, 29, 147, 46, 158, 56, 102, 198 }, /*left = d117*/
67*3e3b1fb0SAndrzej Pietrasiewicz { 35, 19, 12, 135, 87, 209, 41, 45, 167 }, /*left = d153*/
68*3e3b1fb0SAndrzej Pietrasiewicz { 55, 25, 21, 118, 95, 215, 38, 39, 66 }, /*left = d207*/
69*3e3b1fb0SAndrzej Pietrasiewicz { 51, 38, 25, 113, 58, 164, 70, 93, 97 }, /*left = d63 */
70*3e3b1fb0SAndrzej Pietrasiewicz { 47, 54, 34, 146, 108, 203, 72, 103, 151 }, /*left = tm */
71*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = d117 */
72*3e3b1fb0SAndrzej Pietrasiewicz { 64, 19, 37, 156, 66, 138, 49, 95, 133 }, /*left = dc */
73*3e3b1fb0SAndrzej Pietrasiewicz { 46, 27, 80, 150, 55, 124, 55, 121, 135 }, /*left = v */
74*3e3b1fb0SAndrzej Pietrasiewicz { 36, 23, 27, 165, 149, 166, 54, 64, 118 }, /*left = h */
75*3e3b1fb0SAndrzej Pietrasiewicz { 53, 21, 36, 131, 63, 163, 60, 109, 81 }, /*left = d45 */
76*3e3b1fb0SAndrzej Pietrasiewicz { 40, 26, 35, 154, 40, 185, 51, 97, 123 }, /*left = d135*/
77*3e3b1fb0SAndrzej Pietrasiewicz { 35, 19, 34, 179, 19, 97, 48, 129, 124 }, /*left = d117*/
78*3e3b1fb0SAndrzej Pietrasiewicz { 36, 20, 26, 136, 62, 164, 33, 77, 154 }, /*left = d153*/
79*3e3b1fb0SAndrzej Pietrasiewicz { 45, 18, 32, 130, 90, 157, 40, 79, 91 }, /*left = d207*/
80*3e3b1fb0SAndrzej Pietrasiewicz { 45, 26, 28, 129, 45, 129, 49, 147, 123 }, /*left = d63 */
81*3e3b1fb0SAndrzej Pietrasiewicz { 38, 44, 51, 136, 74, 162, 57, 97, 121 }, /*left = tm */
82*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = d153 */
83*3e3b1fb0SAndrzej Pietrasiewicz { 75, 17, 22, 136, 138, 185, 32, 34, 166 }, /*left = dc */
84*3e3b1fb0SAndrzej Pietrasiewicz { 56, 39, 58, 133, 117, 173, 48, 53, 187 }, /*left = v */
85*3e3b1fb0SAndrzej Pietrasiewicz { 35, 21, 12, 161, 212, 207, 20, 23, 145 }, /*left = h */
86*3e3b1fb0SAndrzej Pietrasiewicz { 56, 29, 19, 117, 109, 181, 55, 68, 112 }, /*left = d45 */
87*3e3b1fb0SAndrzej Pietrasiewicz { 47, 29, 17, 153, 64, 220, 59, 51, 114 }, /*left = d135*/
88*3e3b1fb0SAndrzej Pietrasiewicz { 46, 16, 24, 136, 76, 147, 41, 64, 172 }, /*left = d117*/
89*3e3b1fb0SAndrzej Pietrasiewicz { 34, 17, 11, 108, 152, 187, 13, 15, 209 }, /*left = d153*/
90*3e3b1fb0SAndrzej Pietrasiewicz { 51, 24, 14, 115, 133, 209, 32, 26, 104 }, /*left = d207*/
91*3e3b1fb0SAndrzej Pietrasiewicz { 55, 30, 18, 122, 79, 179, 44, 88, 116 }, /*left = d63 */
92*3e3b1fb0SAndrzej Pietrasiewicz { 37, 49, 25, 129, 168, 164, 41, 54, 148 }, /*left = tm */
93*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = d207 */
94*3e3b1fb0SAndrzej Pietrasiewicz { 82, 22, 32, 127, 143, 213, 39, 41, 70 }, /*left = dc */
95*3e3b1fb0SAndrzej Pietrasiewicz { 62, 44, 61, 123, 105, 189, 48, 57, 64 }, /*left = v */
96*3e3b1fb0SAndrzej Pietrasiewicz { 47, 25, 17, 175, 222, 220, 24, 30, 86 }, /*left = h */
97*3e3b1fb0SAndrzej Pietrasiewicz { 68, 36, 17, 106, 102, 206, 59, 74, 74 }, /*left = d45 */
98*3e3b1fb0SAndrzej Pietrasiewicz { 57, 39, 23, 151, 68, 216, 55, 63, 58 }, /*left = d135*/
99*3e3b1fb0SAndrzej Pietrasiewicz { 49, 30, 35, 141, 70, 168, 82, 40, 115 }, /*left = d117*/
100*3e3b1fb0SAndrzej Pietrasiewicz { 51, 25, 15, 136, 129, 202, 38, 35, 139 }, /*left = d153*/
101*3e3b1fb0SAndrzej Pietrasiewicz { 68, 26, 16, 111, 141, 215, 29, 28, 28 }, /*left = d207*/
102*3e3b1fb0SAndrzej Pietrasiewicz { 59, 39, 19, 114, 75, 180, 77, 104, 42 }, /*left = d63 */
103*3e3b1fb0SAndrzej Pietrasiewicz { 40, 61, 26, 126, 152, 206, 61, 59, 93 }, /*left = tm */
104*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = d63 */
105*3e3b1fb0SAndrzej Pietrasiewicz { 78, 23, 39, 111, 117, 170, 74, 124, 94 }, /*left = dc */
106*3e3b1fb0SAndrzej Pietrasiewicz { 48, 34, 86, 101, 92, 146, 78, 179, 134 }, /*left = v */
107*3e3b1fb0SAndrzej Pietrasiewicz { 47, 22, 24, 138, 187, 178, 68, 69, 59 }, /*left = h */
108*3e3b1fb0SAndrzej Pietrasiewicz { 56, 25, 33, 105, 112, 187, 95, 177, 129 }, /*left = d45 */
109*3e3b1fb0SAndrzej Pietrasiewicz { 48, 31, 27, 114, 63, 183, 82, 116, 56 }, /*left = d135*/
110*3e3b1fb0SAndrzej Pietrasiewicz { 43, 28, 37, 121, 63, 123, 61, 192, 169 }, /*left = d117*/
111*3e3b1fb0SAndrzej Pietrasiewicz { 42, 17, 24, 109, 97, 177, 56, 76, 122 }, /*left = d153*/
112*3e3b1fb0SAndrzej Pietrasiewicz { 58, 18, 28, 105, 139, 182, 70, 92, 63 }, /*left = d207*/
113*3e3b1fb0SAndrzej Pietrasiewicz { 46, 23, 32, 74, 86, 150, 67, 183, 88 }, /*left = d63 */
114*3e3b1fb0SAndrzej Pietrasiewicz { 36, 38, 48, 92, 122, 165, 88, 137, 91 }, /*left = tm */
115*3e3b1fb0SAndrzej Pietrasiewicz }, { /* above = tm */
116*3e3b1fb0SAndrzej Pietrasiewicz { 65, 70, 60, 155, 159, 199, 61, 60, 81 }, /*left = dc */
117*3e3b1fb0SAndrzej Pietrasiewicz { 44, 78, 115, 132, 119, 173, 71, 112, 93 }, /*left = v */
118*3e3b1fb0SAndrzej Pietrasiewicz { 39, 38, 21, 184, 227, 206, 42, 32, 64 }, /*left = h */
119*3e3b1fb0SAndrzej Pietrasiewicz { 58, 47, 36, 124, 137, 193, 80, 82, 78 }, /*left = d45 */
120*3e3b1fb0SAndrzej Pietrasiewicz { 49, 50, 35, 144, 95, 205, 63, 78, 59 }, /*left = d135*/
121*3e3b1fb0SAndrzej Pietrasiewicz { 41, 53, 52, 148, 71, 142, 65, 128, 51 }, /*left = d117*/
122*3e3b1fb0SAndrzej Pietrasiewicz { 40, 36, 28, 143, 143, 202, 40, 55, 137 }, /*left = d153*/
123*3e3b1fb0SAndrzej Pietrasiewicz { 52, 34, 29, 129, 183, 227, 42, 35, 43 }, /*left = d207*/
124*3e3b1fb0SAndrzej Pietrasiewicz { 42, 44, 44, 104, 105, 164, 64, 130, 80 }, /*left = d63 */
125*3e3b1fb0SAndrzej Pietrasiewicz { 43, 81, 53, 140, 169, 204, 68, 84, 72 }, /*left = tm */
126*3e3b1fb0SAndrzej Pietrasiewicz }
127*3e3b1fb0SAndrzej Pietrasiewicz };
128*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_kf_y_mode_prob);
129*3e3b1fb0SAndrzej Pietrasiewicz
130*3e3b1fb0SAndrzej Pietrasiewicz const u8 v4l2_vp9_kf_partition_probs[16][3] = {
131*3e3b1fb0SAndrzej Pietrasiewicz /* 8x8 -> 4x4 */
132*3e3b1fb0SAndrzej Pietrasiewicz { 158, 97, 94 }, /* a/l both not split */
133*3e3b1fb0SAndrzej Pietrasiewicz { 93, 24, 99 }, /* a split, l not split */
134*3e3b1fb0SAndrzej Pietrasiewicz { 85, 119, 44 }, /* l split, a not split */
135*3e3b1fb0SAndrzej Pietrasiewicz { 62, 59, 67 }, /* a/l both split */
136*3e3b1fb0SAndrzej Pietrasiewicz /* 16x16 -> 8x8 */
137*3e3b1fb0SAndrzej Pietrasiewicz { 149, 53, 53 }, /* a/l both not split */
138*3e3b1fb0SAndrzej Pietrasiewicz { 94, 20, 48 }, /* a split, l not split */
139*3e3b1fb0SAndrzej Pietrasiewicz { 83, 53, 24 }, /* l split, a not split */
140*3e3b1fb0SAndrzej Pietrasiewicz { 52, 18, 18 }, /* a/l both split */
141*3e3b1fb0SAndrzej Pietrasiewicz /* 32x32 -> 16x16 */
142*3e3b1fb0SAndrzej Pietrasiewicz { 150, 40, 39 }, /* a/l both not split */
143*3e3b1fb0SAndrzej Pietrasiewicz { 78, 12, 26 }, /* a split, l not split */
144*3e3b1fb0SAndrzej Pietrasiewicz { 67, 33, 11 }, /* l split, a not split */
145*3e3b1fb0SAndrzej Pietrasiewicz { 24, 7, 5 }, /* a/l both split */
146*3e3b1fb0SAndrzej Pietrasiewicz /* 64x64 -> 32x32 */
147*3e3b1fb0SAndrzej Pietrasiewicz { 174, 35, 49 }, /* a/l both not split */
148*3e3b1fb0SAndrzej Pietrasiewicz { 68, 11, 27 }, /* a split, l not split */
149*3e3b1fb0SAndrzej Pietrasiewicz { 57, 15, 9 }, /* l split, a not split */
150*3e3b1fb0SAndrzej Pietrasiewicz { 12, 3, 3 }, /* a/l both split */
151*3e3b1fb0SAndrzej Pietrasiewicz };
152*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_kf_partition_probs);
153*3e3b1fb0SAndrzej Pietrasiewicz
154*3e3b1fb0SAndrzej Pietrasiewicz const u8 v4l2_vp9_kf_uv_mode_prob[10][9] = {
155*3e3b1fb0SAndrzej Pietrasiewicz { 144, 11, 54, 157, 195, 130, 46, 58, 108 }, /* y = dc */
156*3e3b1fb0SAndrzej Pietrasiewicz { 118, 15, 123, 148, 131, 101, 44, 93, 131 }, /* y = v */
157*3e3b1fb0SAndrzej Pietrasiewicz { 113, 12, 23, 188, 226, 142, 26, 32, 125 }, /* y = h */
158*3e3b1fb0SAndrzej Pietrasiewicz { 120, 11, 50, 123, 163, 135, 64, 77, 103 }, /* y = d45 */
159*3e3b1fb0SAndrzej Pietrasiewicz { 113, 9, 36, 155, 111, 157, 32, 44, 161 }, /* y = d135 */
160*3e3b1fb0SAndrzej Pietrasiewicz { 116, 9, 55, 176, 76, 96, 37, 61, 149 }, /* y = d117 */
161*3e3b1fb0SAndrzej Pietrasiewicz { 115, 9, 28, 141, 161, 167, 21, 25, 193 }, /* y = d153 */
162*3e3b1fb0SAndrzej Pietrasiewicz { 120, 12, 32, 145, 195, 142, 32, 38, 86 }, /* y = d207 */
163*3e3b1fb0SAndrzej Pietrasiewicz { 116, 12, 64, 120, 140, 125, 49, 115, 121 }, /* y = d63 */
164*3e3b1fb0SAndrzej Pietrasiewicz { 102, 19, 66, 162, 182, 122, 35, 59, 128 } /* y = tm */
165*3e3b1fb0SAndrzej Pietrasiewicz };
166*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_kf_uv_mode_prob);
167*3e3b1fb0SAndrzej Pietrasiewicz
168*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_vp9_frame_context v4l2_vp9_default_probs = {
169*3e3b1fb0SAndrzej Pietrasiewicz .tx8 = {
170*3e3b1fb0SAndrzej Pietrasiewicz { 100 },
171*3e3b1fb0SAndrzej Pietrasiewicz { 66 },
172*3e3b1fb0SAndrzej Pietrasiewicz },
173*3e3b1fb0SAndrzej Pietrasiewicz .tx16 = {
174*3e3b1fb0SAndrzej Pietrasiewicz { 20, 152 },
175*3e3b1fb0SAndrzej Pietrasiewicz { 15, 101 },
176*3e3b1fb0SAndrzej Pietrasiewicz },
177*3e3b1fb0SAndrzej Pietrasiewicz .tx32 = {
178*3e3b1fb0SAndrzej Pietrasiewicz { 3, 136, 37 },
179*3e3b1fb0SAndrzej Pietrasiewicz { 5, 52, 13 },
180*3e3b1fb0SAndrzej Pietrasiewicz },
181*3e3b1fb0SAndrzej Pietrasiewicz .coef = {
182*3e3b1fb0SAndrzej Pietrasiewicz { /* tx = 4x4 */
183*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 0 */
184*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
185*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
186*3e3b1fb0SAndrzej Pietrasiewicz { 195, 29, 183 },
187*3e3b1fb0SAndrzej Pietrasiewicz { 84, 49, 136 },
188*3e3b1fb0SAndrzej Pietrasiewicz { 8, 42, 71 },
189*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
190*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
191*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
192*3e3b1fb0SAndrzej Pietrasiewicz },
193*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
194*3e3b1fb0SAndrzej Pietrasiewicz { 31, 107, 169 },
195*3e3b1fb0SAndrzej Pietrasiewicz { 35, 99, 159 },
196*3e3b1fb0SAndrzej Pietrasiewicz { 17, 82, 140 },
197*3e3b1fb0SAndrzej Pietrasiewicz { 8, 66, 114 },
198*3e3b1fb0SAndrzej Pietrasiewicz { 2, 44, 76 },
199*3e3b1fb0SAndrzej Pietrasiewicz { 1, 19, 32 },
200*3e3b1fb0SAndrzej Pietrasiewicz },
201*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
202*3e3b1fb0SAndrzej Pietrasiewicz { 40, 132, 201 },
203*3e3b1fb0SAndrzej Pietrasiewicz { 29, 114, 187 },
204*3e3b1fb0SAndrzej Pietrasiewicz { 13, 91, 157 },
205*3e3b1fb0SAndrzej Pietrasiewicz { 7, 75, 127 },
206*3e3b1fb0SAndrzej Pietrasiewicz { 3, 58, 95 },
207*3e3b1fb0SAndrzej Pietrasiewicz { 1, 28, 47 },
208*3e3b1fb0SAndrzej Pietrasiewicz },
209*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
210*3e3b1fb0SAndrzej Pietrasiewicz { 69, 142, 221 },
211*3e3b1fb0SAndrzej Pietrasiewicz { 42, 122, 201 },
212*3e3b1fb0SAndrzej Pietrasiewicz { 15, 91, 159 },
213*3e3b1fb0SAndrzej Pietrasiewicz { 6, 67, 121 },
214*3e3b1fb0SAndrzej Pietrasiewicz { 1, 42, 77 },
215*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 31 },
216*3e3b1fb0SAndrzej Pietrasiewicz },
217*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
218*3e3b1fb0SAndrzej Pietrasiewicz { 102, 148, 228 },
219*3e3b1fb0SAndrzej Pietrasiewicz { 67, 117, 204 },
220*3e3b1fb0SAndrzej Pietrasiewicz { 17, 82, 154 },
221*3e3b1fb0SAndrzej Pietrasiewicz { 6, 59, 114 },
222*3e3b1fb0SAndrzej Pietrasiewicz { 2, 39, 75 },
223*3e3b1fb0SAndrzej Pietrasiewicz { 1, 15, 29 },
224*3e3b1fb0SAndrzej Pietrasiewicz },
225*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
226*3e3b1fb0SAndrzej Pietrasiewicz { 156, 57, 233 },
227*3e3b1fb0SAndrzej Pietrasiewicz { 119, 57, 212 },
228*3e3b1fb0SAndrzej Pietrasiewicz { 58, 48, 163 },
229*3e3b1fb0SAndrzej Pietrasiewicz { 29, 40, 124 },
230*3e3b1fb0SAndrzej Pietrasiewicz { 12, 30, 81 },
231*3e3b1fb0SAndrzej Pietrasiewicz { 3, 12, 31 }
232*3e3b1fb0SAndrzej Pietrasiewicz },
233*3e3b1fb0SAndrzej Pietrasiewicz },
234*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
235*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
236*3e3b1fb0SAndrzej Pietrasiewicz { 191, 107, 226 },
237*3e3b1fb0SAndrzej Pietrasiewicz { 124, 117, 204 },
238*3e3b1fb0SAndrzej Pietrasiewicz { 25, 99, 155 },
239*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
240*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
241*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
242*3e3b1fb0SAndrzej Pietrasiewicz },
243*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
244*3e3b1fb0SAndrzej Pietrasiewicz { 29, 148, 210 },
245*3e3b1fb0SAndrzej Pietrasiewicz { 37, 126, 194 },
246*3e3b1fb0SAndrzej Pietrasiewicz { 8, 93, 157 },
247*3e3b1fb0SAndrzej Pietrasiewicz { 2, 68, 118 },
248*3e3b1fb0SAndrzej Pietrasiewicz { 1, 39, 69 },
249*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 33 },
250*3e3b1fb0SAndrzej Pietrasiewicz },
251*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
252*3e3b1fb0SAndrzej Pietrasiewicz { 41, 151, 213 },
253*3e3b1fb0SAndrzej Pietrasiewicz { 27, 123, 193 },
254*3e3b1fb0SAndrzej Pietrasiewicz { 3, 82, 144 },
255*3e3b1fb0SAndrzej Pietrasiewicz { 1, 58, 105 },
256*3e3b1fb0SAndrzej Pietrasiewicz { 1, 32, 60 },
257*3e3b1fb0SAndrzej Pietrasiewicz { 1, 13, 26 },
258*3e3b1fb0SAndrzej Pietrasiewicz },
259*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
260*3e3b1fb0SAndrzej Pietrasiewicz { 59, 159, 220 },
261*3e3b1fb0SAndrzej Pietrasiewicz { 23, 126, 198 },
262*3e3b1fb0SAndrzej Pietrasiewicz { 4, 88, 151 },
263*3e3b1fb0SAndrzej Pietrasiewicz { 1, 66, 114 },
264*3e3b1fb0SAndrzej Pietrasiewicz { 1, 38, 71 },
265*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 34 },
266*3e3b1fb0SAndrzej Pietrasiewicz },
267*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
268*3e3b1fb0SAndrzej Pietrasiewicz { 114, 136, 232 },
269*3e3b1fb0SAndrzej Pietrasiewicz { 51, 114, 207 },
270*3e3b1fb0SAndrzej Pietrasiewicz { 11, 83, 155 },
271*3e3b1fb0SAndrzej Pietrasiewicz { 3, 56, 105 },
272*3e3b1fb0SAndrzej Pietrasiewicz { 1, 33, 65 },
273*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 34 },
274*3e3b1fb0SAndrzej Pietrasiewicz },
275*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
276*3e3b1fb0SAndrzej Pietrasiewicz { 149, 65, 234 },
277*3e3b1fb0SAndrzej Pietrasiewicz { 121, 57, 215 },
278*3e3b1fb0SAndrzej Pietrasiewicz { 61, 49, 166 },
279*3e3b1fb0SAndrzej Pietrasiewicz { 28, 36, 114 },
280*3e3b1fb0SAndrzej Pietrasiewicz { 12, 25, 76 },
281*3e3b1fb0SAndrzej Pietrasiewicz { 3, 16, 42 },
282*3e3b1fb0SAndrzej Pietrasiewicz },
283*3e3b1fb0SAndrzej Pietrasiewicz },
284*3e3b1fb0SAndrzej Pietrasiewicz },
285*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 1 */
286*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
287*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
288*3e3b1fb0SAndrzej Pietrasiewicz { 214, 49, 220 },
289*3e3b1fb0SAndrzej Pietrasiewicz { 132, 63, 188 },
290*3e3b1fb0SAndrzej Pietrasiewicz { 42, 65, 137 },
291*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
292*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
293*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
294*3e3b1fb0SAndrzej Pietrasiewicz },
295*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
296*3e3b1fb0SAndrzej Pietrasiewicz { 85, 137, 221 },
297*3e3b1fb0SAndrzej Pietrasiewicz { 104, 131, 216 },
298*3e3b1fb0SAndrzej Pietrasiewicz { 49, 111, 192 },
299*3e3b1fb0SAndrzej Pietrasiewicz { 21, 87, 155 },
300*3e3b1fb0SAndrzej Pietrasiewicz { 2, 49, 87 },
301*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 28 },
302*3e3b1fb0SAndrzej Pietrasiewicz },
303*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
304*3e3b1fb0SAndrzej Pietrasiewicz { 89, 163, 230 },
305*3e3b1fb0SAndrzej Pietrasiewicz { 90, 137, 220 },
306*3e3b1fb0SAndrzej Pietrasiewicz { 29, 100, 183 },
307*3e3b1fb0SAndrzej Pietrasiewicz { 10, 70, 135 },
308*3e3b1fb0SAndrzej Pietrasiewicz { 2, 42, 81 },
309*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 33 },
310*3e3b1fb0SAndrzej Pietrasiewicz },
311*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
312*3e3b1fb0SAndrzej Pietrasiewicz { 108, 167, 237 },
313*3e3b1fb0SAndrzej Pietrasiewicz { 55, 133, 222 },
314*3e3b1fb0SAndrzej Pietrasiewicz { 15, 97, 179 },
315*3e3b1fb0SAndrzej Pietrasiewicz { 4, 72, 135 },
316*3e3b1fb0SAndrzej Pietrasiewicz { 1, 45, 85 },
317*3e3b1fb0SAndrzej Pietrasiewicz { 1, 19, 38 },
318*3e3b1fb0SAndrzej Pietrasiewicz },
319*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
320*3e3b1fb0SAndrzej Pietrasiewicz { 124, 146, 240 },
321*3e3b1fb0SAndrzej Pietrasiewicz { 66, 124, 224 },
322*3e3b1fb0SAndrzej Pietrasiewicz { 17, 88, 175 },
323*3e3b1fb0SAndrzej Pietrasiewicz { 4, 58, 122 },
324*3e3b1fb0SAndrzej Pietrasiewicz { 1, 36, 75 },
325*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 37 },
326*3e3b1fb0SAndrzej Pietrasiewicz },
327*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
328*3e3b1fb0SAndrzej Pietrasiewicz { 141, 79, 241 },
329*3e3b1fb0SAndrzej Pietrasiewicz { 126, 70, 227 },
330*3e3b1fb0SAndrzej Pietrasiewicz { 66, 58, 182 },
331*3e3b1fb0SAndrzej Pietrasiewicz { 30, 44, 136 },
332*3e3b1fb0SAndrzej Pietrasiewicz { 12, 34, 96 },
333*3e3b1fb0SAndrzej Pietrasiewicz { 2, 20, 47 },
334*3e3b1fb0SAndrzej Pietrasiewicz },
335*3e3b1fb0SAndrzej Pietrasiewicz },
336*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
337*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
338*3e3b1fb0SAndrzej Pietrasiewicz { 229, 99, 249 },
339*3e3b1fb0SAndrzej Pietrasiewicz { 143, 111, 235 },
340*3e3b1fb0SAndrzej Pietrasiewicz { 46, 109, 192 },
341*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
342*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
343*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
344*3e3b1fb0SAndrzej Pietrasiewicz },
345*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
346*3e3b1fb0SAndrzej Pietrasiewicz { 82, 158, 236 },
347*3e3b1fb0SAndrzej Pietrasiewicz { 94, 146, 224 },
348*3e3b1fb0SAndrzej Pietrasiewicz { 25, 117, 191 },
349*3e3b1fb0SAndrzej Pietrasiewicz { 9, 87, 149 },
350*3e3b1fb0SAndrzej Pietrasiewicz { 3, 56, 99 },
351*3e3b1fb0SAndrzej Pietrasiewicz { 1, 33, 57 },
352*3e3b1fb0SAndrzej Pietrasiewicz },
353*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
354*3e3b1fb0SAndrzej Pietrasiewicz { 83, 167, 237 },
355*3e3b1fb0SAndrzej Pietrasiewicz { 68, 145, 222 },
356*3e3b1fb0SAndrzej Pietrasiewicz { 10, 103, 177 },
357*3e3b1fb0SAndrzej Pietrasiewicz { 2, 72, 131 },
358*3e3b1fb0SAndrzej Pietrasiewicz { 1, 41, 79 },
359*3e3b1fb0SAndrzej Pietrasiewicz { 1, 20, 39 },
360*3e3b1fb0SAndrzej Pietrasiewicz },
361*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
362*3e3b1fb0SAndrzej Pietrasiewicz { 99, 167, 239 },
363*3e3b1fb0SAndrzej Pietrasiewicz { 47, 141, 224 },
364*3e3b1fb0SAndrzej Pietrasiewicz { 10, 104, 178 },
365*3e3b1fb0SAndrzej Pietrasiewicz { 2, 73, 133 },
366*3e3b1fb0SAndrzej Pietrasiewicz { 1, 44, 85 },
367*3e3b1fb0SAndrzej Pietrasiewicz { 1, 22, 47 },
368*3e3b1fb0SAndrzej Pietrasiewicz },
369*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
370*3e3b1fb0SAndrzej Pietrasiewicz { 127, 145, 243 },
371*3e3b1fb0SAndrzej Pietrasiewicz { 71, 129, 228 },
372*3e3b1fb0SAndrzej Pietrasiewicz { 17, 93, 177 },
373*3e3b1fb0SAndrzej Pietrasiewicz { 3, 61, 124 },
374*3e3b1fb0SAndrzej Pietrasiewicz { 1, 41, 84 },
375*3e3b1fb0SAndrzej Pietrasiewicz { 1, 21, 52 },
376*3e3b1fb0SAndrzej Pietrasiewicz },
377*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
378*3e3b1fb0SAndrzej Pietrasiewicz { 157, 78, 244 },
379*3e3b1fb0SAndrzej Pietrasiewicz { 140, 72, 231 },
380*3e3b1fb0SAndrzej Pietrasiewicz { 69, 58, 184 },
381*3e3b1fb0SAndrzej Pietrasiewicz { 31, 44, 137 },
382*3e3b1fb0SAndrzej Pietrasiewicz { 14, 38, 105 },
383*3e3b1fb0SAndrzej Pietrasiewicz { 8, 23, 61 },
384*3e3b1fb0SAndrzej Pietrasiewicz },
385*3e3b1fb0SAndrzej Pietrasiewicz },
386*3e3b1fb0SAndrzej Pietrasiewicz },
387*3e3b1fb0SAndrzej Pietrasiewicz },
388*3e3b1fb0SAndrzej Pietrasiewicz { /* tx = 8x8 */
389*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 0 */
390*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
391*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
392*3e3b1fb0SAndrzej Pietrasiewicz { 125, 34, 187 },
393*3e3b1fb0SAndrzej Pietrasiewicz { 52, 41, 133 },
394*3e3b1fb0SAndrzej Pietrasiewicz { 6, 31, 56 },
395*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
396*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
397*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
398*3e3b1fb0SAndrzej Pietrasiewicz },
399*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
400*3e3b1fb0SAndrzej Pietrasiewicz { 37, 109, 153 },
401*3e3b1fb0SAndrzej Pietrasiewicz { 51, 102, 147 },
402*3e3b1fb0SAndrzej Pietrasiewicz { 23, 87, 128 },
403*3e3b1fb0SAndrzej Pietrasiewicz { 8, 67, 101 },
404*3e3b1fb0SAndrzej Pietrasiewicz { 1, 41, 63 },
405*3e3b1fb0SAndrzej Pietrasiewicz { 1, 19, 29 },
406*3e3b1fb0SAndrzej Pietrasiewicz },
407*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
408*3e3b1fb0SAndrzej Pietrasiewicz { 31, 154, 185 },
409*3e3b1fb0SAndrzej Pietrasiewicz { 17, 127, 175 },
410*3e3b1fb0SAndrzej Pietrasiewicz { 6, 96, 145 },
411*3e3b1fb0SAndrzej Pietrasiewicz { 2, 73, 114 },
412*3e3b1fb0SAndrzej Pietrasiewicz { 1, 51, 82 },
413*3e3b1fb0SAndrzej Pietrasiewicz { 1, 28, 45 },
414*3e3b1fb0SAndrzej Pietrasiewicz },
415*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
416*3e3b1fb0SAndrzej Pietrasiewicz { 23, 163, 200 },
417*3e3b1fb0SAndrzej Pietrasiewicz { 10, 131, 185 },
418*3e3b1fb0SAndrzej Pietrasiewicz { 2, 93, 148 },
419*3e3b1fb0SAndrzej Pietrasiewicz { 1, 67, 111 },
420*3e3b1fb0SAndrzej Pietrasiewicz { 1, 41, 69 },
421*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 24 },
422*3e3b1fb0SAndrzej Pietrasiewicz },
423*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
424*3e3b1fb0SAndrzej Pietrasiewicz { 29, 176, 217 },
425*3e3b1fb0SAndrzej Pietrasiewicz { 12, 145, 201 },
426*3e3b1fb0SAndrzej Pietrasiewicz { 3, 101, 156 },
427*3e3b1fb0SAndrzej Pietrasiewicz { 1, 69, 111 },
428*3e3b1fb0SAndrzej Pietrasiewicz { 1, 39, 63 },
429*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 23 },
430*3e3b1fb0SAndrzej Pietrasiewicz },
431*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
432*3e3b1fb0SAndrzej Pietrasiewicz { 57, 192, 233 },
433*3e3b1fb0SAndrzej Pietrasiewicz { 25, 154, 215 },
434*3e3b1fb0SAndrzej Pietrasiewicz { 6, 109, 167 },
435*3e3b1fb0SAndrzej Pietrasiewicz { 3, 78, 118 },
436*3e3b1fb0SAndrzej Pietrasiewicz { 1, 48, 69 },
437*3e3b1fb0SAndrzej Pietrasiewicz { 1, 21, 29 },
438*3e3b1fb0SAndrzej Pietrasiewicz },
439*3e3b1fb0SAndrzej Pietrasiewicz },
440*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
441*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
442*3e3b1fb0SAndrzej Pietrasiewicz { 202, 105, 245 },
443*3e3b1fb0SAndrzej Pietrasiewicz { 108, 106, 216 },
444*3e3b1fb0SAndrzej Pietrasiewicz { 18, 90, 144 },
445*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
446*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
447*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
448*3e3b1fb0SAndrzej Pietrasiewicz },
449*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
450*3e3b1fb0SAndrzej Pietrasiewicz { 33, 172, 219 },
451*3e3b1fb0SAndrzej Pietrasiewicz { 64, 149, 206 },
452*3e3b1fb0SAndrzej Pietrasiewicz { 14, 117, 177 },
453*3e3b1fb0SAndrzej Pietrasiewicz { 5, 90, 141 },
454*3e3b1fb0SAndrzej Pietrasiewicz { 2, 61, 95 },
455*3e3b1fb0SAndrzej Pietrasiewicz { 1, 37, 57 },
456*3e3b1fb0SAndrzej Pietrasiewicz },
457*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
458*3e3b1fb0SAndrzej Pietrasiewicz { 33, 179, 220 },
459*3e3b1fb0SAndrzej Pietrasiewicz { 11, 140, 198 },
460*3e3b1fb0SAndrzej Pietrasiewicz { 1, 89, 148 },
461*3e3b1fb0SAndrzej Pietrasiewicz { 1, 60, 104 },
462*3e3b1fb0SAndrzej Pietrasiewicz { 1, 33, 57 },
463*3e3b1fb0SAndrzej Pietrasiewicz { 1, 12, 21 },
464*3e3b1fb0SAndrzej Pietrasiewicz },
465*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
466*3e3b1fb0SAndrzej Pietrasiewicz { 30, 181, 221 },
467*3e3b1fb0SAndrzej Pietrasiewicz { 8, 141, 198 },
468*3e3b1fb0SAndrzej Pietrasiewicz { 1, 87, 145 },
469*3e3b1fb0SAndrzej Pietrasiewicz { 1, 58, 100 },
470*3e3b1fb0SAndrzej Pietrasiewicz { 1, 31, 55 },
471*3e3b1fb0SAndrzej Pietrasiewicz { 1, 12, 20 },
472*3e3b1fb0SAndrzej Pietrasiewicz },
473*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
474*3e3b1fb0SAndrzej Pietrasiewicz { 32, 186, 224 },
475*3e3b1fb0SAndrzej Pietrasiewicz { 7, 142, 198 },
476*3e3b1fb0SAndrzej Pietrasiewicz { 1, 86, 143 },
477*3e3b1fb0SAndrzej Pietrasiewicz { 1, 58, 100 },
478*3e3b1fb0SAndrzej Pietrasiewicz { 1, 31, 55 },
479*3e3b1fb0SAndrzej Pietrasiewicz { 1, 12, 22 },
480*3e3b1fb0SAndrzej Pietrasiewicz },
481*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
482*3e3b1fb0SAndrzej Pietrasiewicz { 57, 192, 227 },
483*3e3b1fb0SAndrzej Pietrasiewicz { 20, 143, 204 },
484*3e3b1fb0SAndrzej Pietrasiewicz { 3, 96, 154 },
485*3e3b1fb0SAndrzej Pietrasiewicz { 1, 68, 112 },
486*3e3b1fb0SAndrzej Pietrasiewicz { 1, 42, 69 },
487*3e3b1fb0SAndrzej Pietrasiewicz { 1, 19, 32 },
488*3e3b1fb0SAndrzej Pietrasiewicz },
489*3e3b1fb0SAndrzej Pietrasiewicz },
490*3e3b1fb0SAndrzej Pietrasiewicz },
491*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 1 */
492*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
493*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
494*3e3b1fb0SAndrzej Pietrasiewicz { 212, 35, 215 },
495*3e3b1fb0SAndrzej Pietrasiewicz { 113, 47, 169 },
496*3e3b1fb0SAndrzej Pietrasiewicz { 29, 48, 105 },
497*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
498*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
499*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
500*3e3b1fb0SAndrzej Pietrasiewicz },
501*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
502*3e3b1fb0SAndrzej Pietrasiewicz { 74, 129, 203 },
503*3e3b1fb0SAndrzej Pietrasiewicz { 106, 120, 203 },
504*3e3b1fb0SAndrzej Pietrasiewicz { 49, 107, 178 },
505*3e3b1fb0SAndrzej Pietrasiewicz { 19, 84, 144 },
506*3e3b1fb0SAndrzej Pietrasiewicz { 4, 50, 84 },
507*3e3b1fb0SAndrzej Pietrasiewicz { 1, 15, 25 },
508*3e3b1fb0SAndrzej Pietrasiewicz },
509*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
510*3e3b1fb0SAndrzej Pietrasiewicz { 71, 172, 217 },
511*3e3b1fb0SAndrzej Pietrasiewicz { 44, 141, 209 },
512*3e3b1fb0SAndrzej Pietrasiewicz { 15, 102, 173 },
513*3e3b1fb0SAndrzej Pietrasiewicz { 6, 76, 133 },
514*3e3b1fb0SAndrzej Pietrasiewicz { 2, 51, 89 },
515*3e3b1fb0SAndrzej Pietrasiewicz { 1, 24, 42 },
516*3e3b1fb0SAndrzej Pietrasiewicz },
517*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
518*3e3b1fb0SAndrzej Pietrasiewicz { 64, 185, 231 },
519*3e3b1fb0SAndrzej Pietrasiewicz { 31, 148, 216 },
520*3e3b1fb0SAndrzej Pietrasiewicz { 8, 103, 175 },
521*3e3b1fb0SAndrzej Pietrasiewicz { 3, 74, 131 },
522*3e3b1fb0SAndrzej Pietrasiewicz { 1, 46, 81 },
523*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 30 },
524*3e3b1fb0SAndrzej Pietrasiewicz },
525*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
526*3e3b1fb0SAndrzej Pietrasiewicz { 65, 196, 235 },
527*3e3b1fb0SAndrzej Pietrasiewicz { 25, 157, 221 },
528*3e3b1fb0SAndrzej Pietrasiewicz { 5, 105, 174 },
529*3e3b1fb0SAndrzej Pietrasiewicz { 1, 67, 120 },
530*3e3b1fb0SAndrzej Pietrasiewicz { 1, 38, 69 },
531*3e3b1fb0SAndrzej Pietrasiewicz { 1, 15, 30 },
532*3e3b1fb0SAndrzej Pietrasiewicz },
533*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
534*3e3b1fb0SAndrzej Pietrasiewicz { 65, 204, 238 },
535*3e3b1fb0SAndrzej Pietrasiewicz { 30, 156, 224 },
536*3e3b1fb0SAndrzej Pietrasiewicz { 7, 107, 177 },
537*3e3b1fb0SAndrzej Pietrasiewicz { 2, 70, 124 },
538*3e3b1fb0SAndrzej Pietrasiewicz { 1, 42, 73 },
539*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 34 },
540*3e3b1fb0SAndrzej Pietrasiewicz },
541*3e3b1fb0SAndrzej Pietrasiewicz },
542*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
543*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
544*3e3b1fb0SAndrzej Pietrasiewicz { 225, 86, 251 },
545*3e3b1fb0SAndrzej Pietrasiewicz { 144, 104, 235 },
546*3e3b1fb0SAndrzej Pietrasiewicz { 42, 99, 181 },
547*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
548*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
549*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
550*3e3b1fb0SAndrzej Pietrasiewicz },
551*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
552*3e3b1fb0SAndrzej Pietrasiewicz { 85, 175, 239 },
553*3e3b1fb0SAndrzej Pietrasiewicz { 112, 165, 229 },
554*3e3b1fb0SAndrzej Pietrasiewicz { 29, 136, 200 },
555*3e3b1fb0SAndrzej Pietrasiewicz { 12, 103, 162 },
556*3e3b1fb0SAndrzej Pietrasiewicz { 6, 77, 123 },
557*3e3b1fb0SAndrzej Pietrasiewicz { 2, 53, 84 },
558*3e3b1fb0SAndrzej Pietrasiewicz },
559*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
560*3e3b1fb0SAndrzej Pietrasiewicz { 75, 183, 239 },
561*3e3b1fb0SAndrzej Pietrasiewicz { 30, 155, 221 },
562*3e3b1fb0SAndrzej Pietrasiewicz { 3, 106, 171 },
563*3e3b1fb0SAndrzej Pietrasiewicz { 1, 74, 128 },
564*3e3b1fb0SAndrzej Pietrasiewicz { 1, 44, 76 },
565*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 28 },
566*3e3b1fb0SAndrzej Pietrasiewicz },
567*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
568*3e3b1fb0SAndrzej Pietrasiewicz { 73, 185, 240 },
569*3e3b1fb0SAndrzej Pietrasiewicz { 27, 159, 222 },
570*3e3b1fb0SAndrzej Pietrasiewicz { 2, 107, 172 },
571*3e3b1fb0SAndrzej Pietrasiewicz { 1, 75, 127 },
572*3e3b1fb0SAndrzej Pietrasiewicz { 1, 42, 73 },
573*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 29 },
574*3e3b1fb0SAndrzej Pietrasiewicz },
575*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
576*3e3b1fb0SAndrzej Pietrasiewicz { 62, 190, 238 },
577*3e3b1fb0SAndrzej Pietrasiewicz { 21, 159, 222 },
578*3e3b1fb0SAndrzej Pietrasiewicz { 2, 107, 172 },
579*3e3b1fb0SAndrzej Pietrasiewicz { 1, 72, 122 },
580*3e3b1fb0SAndrzej Pietrasiewicz { 1, 40, 71 },
581*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 32 },
582*3e3b1fb0SAndrzej Pietrasiewicz },
583*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
584*3e3b1fb0SAndrzej Pietrasiewicz { 61, 199, 240 },
585*3e3b1fb0SAndrzej Pietrasiewicz { 27, 161, 226 },
586*3e3b1fb0SAndrzej Pietrasiewicz { 4, 113, 180 },
587*3e3b1fb0SAndrzej Pietrasiewicz { 1, 76, 129 },
588*3e3b1fb0SAndrzej Pietrasiewicz { 1, 46, 80 },
589*3e3b1fb0SAndrzej Pietrasiewicz { 1, 23, 41 },
590*3e3b1fb0SAndrzej Pietrasiewicz },
591*3e3b1fb0SAndrzej Pietrasiewicz },
592*3e3b1fb0SAndrzej Pietrasiewicz },
593*3e3b1fb0SAndrzej Pietrasiewicz },
594*3e3b1fb0SAndrzej Pietrasiewicz { /* tx = 16x16 */
595*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 0 */
596*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
597*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
598*3e3b1fb0SAndrzej Pietrasiewicz { 7, 27, 153 },
599*3e3b1fb0SAndrzej Pietrasiewicz { 5, 30, 95 },
600*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 30 },
601*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
602*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
603*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
604*3e3b1fb0SAndrzej Pietrasiewicz },
605*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
606*3e3b1fb0SAndrzej Pietrasiewicz { 50, 75, 127 },
607*3e3b1fb0SAndrzej Pietrasiewicz { 57, 75, 124 },
608*3e3b1fb0SAndrzej Pietrasiewicz { 27, 67, 108 },
609*3e3b1fb0SAndrzej Pietrasiewicz { 10, 54, 86 },
610*3e3b1fb0SAndrzej Pietrasiewicz { 1, 33, 52 },
611*3e3b1fb0SAndrzej Pietrasiewicz { 1, 12, 18 },
612*3e3b1fb0SAndrzej Pietrasiewicz },
613*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
614*3e3b1fb0SAndrzej Pietrasiewicz { 43, 125, 151 },
615*3e3b1fb0SAndrzej Pietrasiewicz { 26, 108, 148 },
616*3e3b1fb0SAndrzej Pietrasiewicz { 7, 83, 122 },
617*3e3b1fb0SAndrzej Pietrasiewicz { 2, 59, 89 },
618*3e3b1fb0SAndrzej Pietrasiewicz { 1, 38, 60 },
619*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 27 },
620*3e3b1fb0SAndrzej Pietrasiewicz },
621*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
622*3e3b1fb0SAndrzej Pietrasiewicz { 23, 144, 163 },
623*3e3b1fb0SAndrzej Pietrasiewicz { 13, 112, 154 },
624*3e3b1fb0SAndrzej Pietrasiewicz { 2, 75, 117 },
625*3e3b1fb0SAndrzej Pietrasiewicz { 1, 50, 81 },
626*3e3b1fb0SAndrzej Pietrasiewicz { 1, 31, 51 },
627*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 23 },
628*3e3b1fb0SAndrzej Pietrasiewicz },
629*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
630*3e3b1fb0SAndrzej Pietrasiewicz { 18, 162, 185 },
631*3e3b1fb0SAndrzej Pietrasiewicz { 6, 123, 171 },
632*3e3b1fb0SAndrzej Pietrasiewicz { 1, 78, 125 },
633*3e3b1fb0SAndrzej Pietrasiewicz { 1, 51, 86 },
634*3e3b1fb0SAndrzej Pietrasiewicz { 1, 31, 54 },
635*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 23 },
636*3e3b1fb0SAndrzej Pietrasiewicz },
637*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
638*3e3b1fb0SAndrzej Pietrasiewicz { 15, 199, 227 },
639*3e3b1fb0SAndrzej Pietrasiewicz { 3, 150, 204 },
640*3e3b1fb0SAndrzej Pietrasiewicz { 1, 91, 146 },
641*3e3b1fb0SAndrzej Pietrasiewicz { 1, 55, 95 },
642*3e3b1fb0SAndrzej Pietrasiewicz { 1, 30, 53 },
643*3e3b1fb0SAndrzej Pietrasiewicz { 1, 11, 20 },
644*3e3b1fb0SAndrzej Pietrasiewicz }
645*3e3b1fb0SAndrzej Pietrasiewicz },
646*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
647*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
648*3e3b1fb0SAndrzej Pietrasiewicz { 19, 55, 240 },
649*3e3b1fb0SAndrzej Pietrasiewicz { 19, 59, 196 },
650*3e3b1fb0SAndrzej Pietrasiewicz { 3, 52, 105 },
651*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
652*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
653*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
654*3e3b1fb0SAndrzej Pietrasiewicz },
655*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
656*3e3b1fb0SAndrzej Pietrasiewicz { 41, 166, 207 },
657*3e3b1fb0SAndrzej Pietrasiewicz { 104, 153, 199 },
658*3e3b1fb0SAndrzej Pietrasiewicz { 31, 123, 181 },
659*3e3b1fb0SAndrzej Pietrasiewicz { 14, 101, 152 },
660*3e3b1fb0SAndrzej Pietrasiewicz { 5, 72, 106 },
661*3e3b1fb0SAndrzej Pietrasiewicz { 1, 36, 52 },
662*3e3b1fb0SAndrzej Pietrasiewicz },
663*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
664*3e3b1fb0SAndrzej Pietrasiewicz { 35, 176, 211 },
665*3e3b1fb0SAndrzej Pietrasiewicz { 12, 131, 190 },
666*3e3b1fb0SAndrzej Pietrasiewicz { 2, 88, 144 },
667*3e3b1fb0SAndrzej Pietrasiewicz { 1, 60, 101 },
668*3e3b1fb0SAndrzej Pietrasiewicz { 1, 36, 60 },
669*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 28 },
670*3e3b1fb0SAndrzej Pietrasiewicz },
671*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
672*3e3b1fb0SAndrzej Pietrasiewicz { 28, 183, 213 },
673*3e3b1fb0SAndrzej Pietrasiewicz { 8, 134, 191 },
674*3e3b1fb0SAndrzej Pietrasiewicz { 1, 86, 142 },
675*3e3b1fb0SAndrzej Pietrasiewicz { 1, 56, 96 },
676*3e3b1fb0SAndrzej Pietrasiewicz { 1, 30, 53 },
677*3e3b1fb0SAndrzej Pietrasiewicz { 1, 12, 20 },
678*3e3b1fb0SAndrzej Pietrasiewicz },
679*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
680*3e3b1fb0SAndrzej Pietrasiewicz { 20, 190, 215 },
681*3e3b1fb0SAndrzej Pietrasiewicz { 4, 135, 192 },
682*3e3b1fb0SAndrzej Pietrasiewicz { 1, 84, 139 },
683*3e3b1fb0SAndrzej Pietrasiewicz { 1, 53, 91 },
684*3e3b1fb0SAndrzej Pietrasiewicz { 1, 28, 49 },
685*3e3b1fb0SAndrzej Pietrasiewicz { 1, 11, 20 },
686*3e3b1fb0SAndrzej Pietrasiewicz },
687*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
688*3e3b1fb0SAndrzej Pietrasiewicz { 13, 196, 216 },
689*3e3b1fb0SAndrzej Pietrasiewicz { 2, 137, 192 },
690*3e3b1fb0SAndrzej Pietrasiewicz { 1, 86, 143 },
691*3e3b1fb0SAndrzej Pietrasiewicz { 1, 57, 99 },
692*3e3b1fb0SAndrzej Pietrasiewicz { 1, 32, 56 },
693*3e3b1fb0SAndrzej Pietrasiewicz { 1, 13, 24 },
694*3e3b1fb0SAndrzej Pietrasiewicz },
695*3e3b1fb0SAndrzej Pietrasiewicz },
696*3e3b1fb0SAndrzej Pietrasiewicz },
697*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 1 */
698*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
699*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
700*3e3b1fb0SAndrzej Pietrasiewicz { 211, 29, 217 },
701*3e3b1fb0SAndrzej Pietrasiewicz { 96, 47, 156 },
702*3e3b1fb0SAndrzej Pietrasiewicz { 22, 43, 87 },
703*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
704*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
705*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
706*3e3b1fb0SAndrzej Pietrasiewicz },
707*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
708*3e3b1fb0SAndrzej Pietrasiewicz { 78, 120, 193 },
709*3e3b1fb0SAndrzej Pietrasiewicz { 111, 116, 186 },
710*3e3b1fb0SAndrzej Pietrasiewicz { 46, 102, 164 },
711*3e3b1fb0SAndrzej Pietrasiewicz { 15, 80, 128 },
712*3e3b1fb0SAndrzej Pietrasiewicz { 2, 49, 76 },
713*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 28 },
714*3e3b1fb0SAndrzej Pietrasiewicz },
715*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
716*3e3b1fb0SAndrzej Pietrasiewicz { 71, 161, 203 },
717*3e3b1fb0SAndrzej Pietrasiewicz { 42, 132, 192 },
718*3e3b1fb0SAndrzej Pietrasiewicz { 10, 98, 150 },
719*3e3b1fb0SAndrzej Pietrasiewicz { 3, 69, 109 },
720*3e3b1fb0SAndrzej Pietrasiewicz { 1, 44, 70 },
721*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 29 },
722*3e3b1fb0SAndrzej Pietrasiewicz },
723*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
724*3e3b1fb0SAndrzej Pietrasiewicz { 57, 186, 211 },
725*3e3b1fb0SAndrzej Pietrasiewicz { 30, 140, 196 },
726*3e3b1fb0SAndrzej Pietrasiewicz { 4, 93, 146 },
727*3e3b1fb0SAndrzej Pietrasiewicz { 1, 62, 102 },
728*3e3b1fb0SAndrzej Pietrasiewicz { 1, 38, 65 },
729*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 27 },
730*3e3b1fb0SAndrzej Pietrasiewicz },
731*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
732*3e3b1fb0SAndrzej Pietrasiewicz { 47, 199, 217 },
733*3e3b1fb0SAndrzej Pietrasiewicz { 14, 145, 196 },
734*3e3b1fb0SAndrzej Pietrasiewicz { 1, 88, 142 },
735*3e3b1fb0SAndrzej Pietrasiewicz { 1, 57, 98 },
736*3e3b1fb0SAndrzej Pietrasiewicz { 1, 36, 62 },
737*3e3b1fb0SAndrzej Pietrasiewicz { 1, 15, 26 },
738*3e3b1fb0SAndrzej Pietrasiewicz },
739*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
740*3e3b1fb0SAndrzej Pietrasiewicz { 26, 219, 229 },
741*3e3b1fb0SAndrzej Pietrasiewicz { 5, 155, 207 },
742*3e3b1fb0SAndrzej Pietrasiewicz { 1, 94, 151 },
743*3e3b1fb0SAndrzej Pietrasiewicz { 1, 60, 104 },
744*3e3b1fb0SAndrzej Pietrasiewicz { 1, 36, 62 },
745*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 28 },
746*3e3b1fb0SAndrzej Pietrasiewicz }
747*3e3b1fb0SAndrzej Pietrasiewicz },
748*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
749*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
750*3e3b1fb0SAndrzej Pietrasiewicz { 233, 29, 248 },
751*3e3b1fb0SAndrzej Pietrasiewicz { 146, 47, 220 },
752*3e3b1fb0SAndrzej Pietrasiewicz { 43, 52, 140 },
753*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
754*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
755*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
756*3e3b1fb0SAndrzej Pietrasiewicz },
757*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
758*3e3b1fb0SAndrzej Pietrasiewicz { 100, 163, 232 },
759*3e3b1fb0SAndrzej Pietrasiewicz { 179, 161, 222 },
760*3e3b1fb0SAndrzej Pietrasiewicz { 63, 142, 204 },
761*3e3b1fb0SAndrzej Pietrasiewicz { 37, 113, 174 },
762*3e3b1fb0SAndrzej Pietrasiewicz { 26, 89, 137 },
763*3e3b1fb0SAndrzej Pietrasiewicz { 18, 68, 97 },
764*3e3b1fb0SAndrzej Pietrasiewicz },
765*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
766*3e3b1fb0SAndrzej Pietrasiewicz { 85, 181, 230 },
767*3e3b1fb0SAndrzej Pietrasiewicz { 32, 146, 209 },
768*3e3b1fb0SAndrzej Pietrasiewicz { 7, 100, 164 },
769*3e3b1fb0SAndrzej Pietrasiewicz { 3, 71, 121 },
770*3e3b1fb0SAndrzej Pietrasiewicz { 1, 45, 77 },
771*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 30 },
772*3e3b1fb0SAndrzej Pietrasiewicz },
773*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
774*3e3b1fb0SAndrzej Pietrasiewicz { 65, 187, 230 },
775*3e3b1fb0SAndrzej Pietrasiewicz { 20, 148, 207 },
776*3e3b1fb0SAndrzej Pietrasiewicz { 2, 97, 159 },
777*3e3b1fb0SAndrzej Pietrasiewicz { 1, 68, 116 },
778*3e3b1fb0SAndrzej Pietrasiewicz { 1, 40, 70 },
779*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 29 },
780*3e3b1fb0SAndrzej Pietrasiewicz },
781*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
782*3e3b1fb0SAndrzej Pietrasiewicz { 40, 194, 227 },
783*3e3b1fb0SAndrzej Pietrasiewicz { 8, 147, 204 },
784*3e3b1fb0SAndrzej Pietrasiewicz { 1, 94, 155 },
785*3e3b1fb0SAndrzej Pietrasiewicz { 1, 65, 112 },
786*3e3b1fb0SAndrzej Pietrasiewicz { 1, 39, 66 },
787*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 26 },
788*3e3b1fb0SAndrzej Pietrasiewicz },
789*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
790*3e3b1fb0SAndrzej Pietrasiewicz { 16, 208, 228 },
791*3e3b1fb0SAndrzej Pietrasiewicz { 3, 151, 207 },
792*3e3b1fb0SAndrzej Pietrasiewicz { 1, 98, 160 },
793*3e3b1fb0SAndrzej Pietrasiewicz { 1, 67, 117 },
794*3e3b1fb0SAndrzej Pietrasiewicz { 1, 41, 74 },
795*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 31 },
796*3e3b1fb0SAndrzej Pietrasiewicz },
797*3e3b1fb0SAndrzej Pietrasiewicz },
798*3e3b1fb0SAndrzej Pietrasiewicz },
799*3e3b1fb0SAndrzej Pietrasiewicz },
800*3e3b1fb0SAndrzej Pietrasiewicz { /* tx = 32x32 */
801*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 0 */
802*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
803*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
804*3e3b1fb0SAndrzej Pietrasiewicz { 17, 38, 140 },
805*3e3b1fb0SAndrzej Pietrasiewicz { 7, 34, 80 },
806*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 29 },
807*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
808*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
809*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
810*3e3b1fb0SAndrzej Pietrasiewicz },
811*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
812*3e3b1fb0SAndrzej Pietrasiewicz { 37, 75, 128 },
813*3e3b1fb0SAndrzej Pietrasiewicz { 41, 76, 128 },
814*3e3b1fb0SAndrzej Pietrasiewicz { 26, 66, 116 },
815*3e3b1fb0SAndrzej Pietrasiewicz { 12, 52, 94 },
816*3e3b1fb0SAndrzej Pietrasiewicz { 2, 32, 55 },
817*3e3b1fb0SAndrzej Pietrasiewicz { 1, 10, 16 },
818*3e3b1fb0SAndrzej Pietrasiewicz },
819*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
820*3e3b1fb0SAndrzej Pietrasiewicz { 50, 127, 154 },
821*3e3b1fb0SAndrzej Pietrasiewicz { 37, 109, 152 },
822*3e3b1fb0SAndrzej Pietrasiewicz { 16, 82, 121 },
823*3e3b1fb0SAndrzej Pietrasiewicz { 5, 59, 85 },
824*3e3b1fb0SAndrzej Pietrasiewicz { 1, 35, 54 },
825*3e3b1fb0SAndrzej Pietrasiewicz { 1, 13, 20 },
826*3e3b1fb0SAndrzej Pietrasiewicz },
827*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
828*3e3b1fb0SAndrzej Pietrasiewicz { 40, 142, 167 },
829*3e3b1fb0SAndrzej Pietrasiewicz { 17, 110, 157 },
830*3e3b1fb0SAndrzej Pietrasiewicz { 2, 71, 112 },
831*3e3b1fb0SAndrzej Pietrasiewicz { 1, 44, 72 },
832*3e3b1fb0SAndrzej Pietrasiewicz { 1, 27, 45 },
833*3e3b1fb0SAndrzej Pietrasiewicz { 1, 11, 17 },
834*3e3b1fb0SAndrzej Pietrasiewicz },
835*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
836*3e3b1fb0SAndrzej Pietrasiewicz { 30, 175, 188 },
837*3e3b1fb0SAndrzej Pietrasiewicz { 9, 124, 169 },
838*3e3b1fb0SAndrzej Pietrasiewicz { 1, 74, 116 },
839*3e3b1fb0SAndrzej Pietrasiewicz { 1, 48, 78 },
840*3e3b1fb0SAndrzej Pietrasiewicz { 1, 30, 49 },
841*3e3b1fb0SAndrzej Pietrasiewicz { 1, 11, 18 },
842*3e3b1fb0SAndrzej Pietrasiewicz },
843*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
844*3e3b1fb0SAndrzej Pietrasiewicz { 10, 222, 223 },
845*3e3b1fb0SAndrzej Pietrasiewicz { 2, 150, 194 },
846*3e3b1fb0SAndrzej Pietrasiewicz { 1, 83, 128 },
847*3e3b1fb0SAndrzej Pietrasiewicz { 1, 48, 79 },
848*3e3b1fb0SAndrzej Pietrasiewicz { 1, 27, 45 },
849*3e3b1fb0SAndrzej Pietrasiewicz { 1, 11, 17 },
850*3e3b1fb0SAndrzej Pietrasiewicz },
851*3e3b1fb0SAndrzej Pietrasiewicz },
852*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
853*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
854*3e3b1fb0SAndrzej Pietrasiewicz { 36, 41, 235 },
855*3e3b1fb0SAndrzej Pietrasiewicz { 29, 36, 193 },
856*3e3b1fb0SAndrzej Pietrasiewicz { 10, 27, 111 },
857*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
858*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
859*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
860*3e3b1fb0SAndrzej Pietrasiewicz },
861*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
862*3e3b1fb0SAndrzej Pietrasiewicz { 85, 165, 222 },
863*3e3b1fb0SAndrzej Pietrasiewicz { 177, 162, 215 },
864*3e3b1fb0SAndrzej Pietrasiewicz { 110, 135, 195 },
865*3e3b1fb0SAndrzej Pietrasiewicz { 57, 113, 168 },
866*3e3b1fb0SAndrzej Pietrasiewicz { 23, 83, 120 },
867*3e3b1fb0SAndrzej Pietrasiewicz { 10, 49, 61 },
868*3e3b1fb0SAndrzej Pietrasiewicz },
869*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
870*3e3b1fb0SAndrzej Pietrasiewicz { 85, 190, 223 },
871*3e3b1fb0SAndrzej Pietrasiewicz { 36, 139, 200 },
872*3e3b1fb0SAndrzej Pietrasiewicz { 5, 90, 146 },
873*3e3b1fb0SAndrzej Pietrasiewicz { 1, 60, 103 },
874*3e3b1fb0SAndrzej Pietrasiewicz { 1, 38, 65 },
875*3e3b1fb0SAndrzej Pietrasiewicz { 1, 18, 30 },
876*3e3b1fb0SAndrzej Pietrasiewicz },
877*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
878*3e3b1fb0SAndrzej Pietrasiewicz { 72, 202, 223 },
879*3e3b1fb0SAndrzej Pietrasiewicz { 23, 141, 199 },
880*3e3b1fb0SAndrzej Pietrasiewicz { 2, 86, 140 },
881*3e3b1fb0SAndrzej Pietrasiewicz { 1, 56, 97 },
882*3e3b1fb0SAndrzej Pietrasiewicz { 1, 36, 61 },
883*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 27 },
884*3e3b1fb0SAndrzej Pietrasiewicz },
885*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
886*3e3b1fb0SAndrzej Pietrasiewicz { 55, 218, 225 },
887*3e3b1fb0SAndrzej Pietrasiewicz { 13, 145, 200 },
888*3e3b1fb0SAndrzej Pietrasiewicz { 1, 86, 141 },
889*3e3b1fb0SAndrzej Pietrasiewicz { 1, 57, 99 },
890*3e3b1fb0SAndrzej Pietrasiewicz { 1, 35, 61 },
891*3e3b1fb0SAndrzej Pietrasiewicz { 1, 13, 22 },
892*3e3b1fb0SAndrzej Pietrasiewicz },
893*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
894*3e3b1fb0SAndrzej Pietrasiewicz { 15, 235, 212 },
895*3e3b1fb0SAndrzej Pietrasiewicz { 1, 132, 184 },
896*3e3b1fb0SAndrzej Pietrasiewicz { 1, 84, 139 },
897*3e3b1fb0SAndrzej Pietrasiewicz { 1, 57, 97 },
898*3e3b1fb0SAndrzej Pietrasiewicz { 1, 34, 56 },
899*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 23 },
900*3e3b1fb0SAndrzej Pietrasiewicz },
901*3e3b1fb0SAndrzej Pietrasiewicz },
902*3e3b1fb0SAndrzej Pietrasiewicz },
903*3e3b1fb0SAndrzej Pietrasiewicz { /* block Type 1 */
904*3e3b1fb0SAndrzej Pietrasiewicz { /* Intra */
905*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
906*3e3b1fb0SAndrzej Pietrasiewicz { 181, 21, 201 },
907*3e3b1fb0SAndrzej Pietrasiewicz { 61, 37, 123 },
908*3e3b1fb0SAndrzej Pietrasiewicz { 10, 38, 71 },
909*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
910*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
911*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
912*3e3b1fb0SAndrzej Pietrasiewicz },
913*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
914*3e3b1fb0SAndrzej Pietrasiewicz { 47, 106, 172 },
915*3e3b1fb0SAndrzej Pietrasiewicz { 95, 104, 173 },
916*3e3b1fb0SAndrzej Pietrasiewicz { 42, 93, 159 },
917*3e3b1fb0SAndrzej Pietrasiewicz { 18, 77, 131 },
918*3e3b1fb0SAndrzej Pietrasiewicz { 4, 50, 81 },
919*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 23 },
920*3e3b1fb0SAndrzej Pietrasiewicz },
921*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
922*3e3b1fb0SAndrzej Pietrasiewicz { 62, 147, 199 },
923*3e3b1fb0SAndrzej Pietrasiewicz { 44, 130, 189 },
924*3e3b1fb0SAndrzej Pietrasiewicz { 28, 102, 154 },
925*3e3b1fb0SAndrzej Pietrasiewicz { 18, 75, 115 },
926*3e3b1fb0SAndrzej Pietrasiewicz { 2, 44, 65 },
927*3e3b1fb0SAndrzej Pietrasiewicz { 1, 12, 19 },
928*3e3b1fb0SAndrzej Pietrasiewicz },
929*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
930*3e3b1fb0SAndrzej Pietrasiewicz { 55, 153, 210 },
931*3e3b1fb0SAndrzej Pietrasiewicz { 24, 130, 194 },
932*3e3b1fb0SAndrzej Pietrasiewicz { 3, 93, 146 },
933*3e3b1fb0SAndrzej Pietrasiewicz { 1, 61, 97 },
934*3e3b1fb0SAndrzej Pietrasiewicz { 1, 31, 50 },
935*3e3b1fb0SAndrzej Pietrasiewicz { 1, 10, 16 },
936*3e3b1fb0SAndrzej Pietrasiewicz },
937*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
938*3e3b1fb0SAndrzej Pietrasiewicz { 49, 186, 223 },
939*3e3b1fb0SAndrzej Pietrasiewicz { 17, 148, 204 },
940*3e3b1fb0SAndrzej Pietrasiewicz { 1, 96, 142 },
941*3e3b1fb0SAndrzej Pietrasiewicz { 1, 53, 83 },
942*3e3b1fb0SAndrzej Pietrasiewicz { 1, 26, 44 },
943*3e3b1fb0SAndrzej Pietrasiewicz { 1, 11, 17 },
944*3e3b1fb0SAndrzej Pietrasiewicz },
945*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
946*3e3b1fb0SAndrzej Pietrasiewicz { 13, 217, 212 },
947*3e3b1fb0SAndrzej Pietrasiewicz { 2, 136, 180 },
948*3e3b1fb0SAndrzej Pietrasiewicz { 1, 78, 124 },
949*3e3b1fb0SAndrzej Pietrasiewicz { 1, 50, 83 },
950*3e3b1fb0SAndrzej Pietrasiewicz { 1, 29, 49 },
951*3e3b1fb0SAndrzej Pietrasiewicz { 1, 14, 23 },
952*3e3b1fb0SAndrzej Pietrasiewicz },
953*3e3b1fb0SAndrzej Pietrasiewicz },
954*3e3b1fb0SAndrzej Pietrasiewicz { /* Inter */
955*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 0 */
956*3e3b1fb0SAndrzej Pietrasiewicz { 197, 13, 247 },
957*3e3b1fb0SAndrzej Pietrasiewicz { 82, 17, 222 },
958*3e3b1fb0SAndrzej Pietrasiewicz { 25, 17, 162 },
959*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
960*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
961*3e3b1fb0SAndrzej Pietrasiewicz { 0, 0, 0 },
962*3e3b1fb0SAndrzej Pietrasiewicz },
963*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 1 */
964*3e3b1fb0SAndrzej Pietrasiewicz { 126, 186, 247 },
965*3e3b1fb0SAndrzej Pietrasiewicz { 234, 191, 243 },
966*3e3b1fb0SAndrzej Pietrasiewicz { 176, 177, 234 },
967*3e3b1fb0SAndrzej Pietrasiewicz { 104, 158, 220 },
968*3e3b1fb0SAndrzej Pietrasiewicz { 66, 128, 186 },
969*3e3b1fb0SAndrzej Pietrasiewicz { 55, 90, 137 },
970*3e3b1fb0SAndrzej Pietrasiewicz },
971*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 2 */
972*3e3b1fb0SAndrzej Pietrasiewicz { 111, 197, 242 },
973*3e3b1fb0SAndrzej Pietrasiewicz { 46, 158, 219 },
974*3e3b1fb0SAndrzej Pietrasiewicz { 9, 104, 171 },
975*3e3b1fb0SAndrzej Pietrasiewicz { 2, 65, 125 },
976*3e3b1fb0SAndrzej Pietrasiewicz { 1, 44, 80 },
977*3e3b1fb0SAndrzej Pietrasiewicz { 1, 17, 91 },
978*3e3b1fb0SAndrzej Pietrasiewicz },
979*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 3 */
980*3e3b1fb0SAndrzej Pietrasiewicz { 104, 208, 245 },
981*3e3b1fb0SAndrzej Pietrasiewicz { 39, 168, 224 },
982*3e3b1fb0SAndrzej Pietrasiewicz { 3, 109, 162 },
983*3e3b1fb0SAndrzej Pietrasiewicz { 1, 79, 124 },
984*3e3b1fb0SAndrzej Pietrasiewicz { 1, 50, 102 },
985*3e3b1fb0SAndrzej Pietrasiewicz { 1, 43, 102 },
986*3e3b1fb0SAndrzej Pietrasiewicz },
987*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 4 */
988*3e3b1fb0SAndrzej Pietrasiewicz { 84, 220, 246 },
989*3e3b1fb0SAndrzej Pietrasiewicz { 31, 177, 231 },
990*3e3b1fb0SAndrzej Pietrasiewicz { 2, 115, 180 },
991*3e3b1fb0SAndrzej Pietrasiewicz { 1, 79, 134 },
992*3e3b1fb0SAndrzej Pietrasiewicz { 1, 55, 77 },
993*3e3b1fb0SAndrzej Pietrasiewicz { 1, 60, 79 },
994*3e3b1fb0SAndrzej Pietrasiewicz },
995*3e3b1fb0SAndrzej Pietrasiewicz { /* Coeff Band 5 */
996*3e3b1fb0SAndrzej Pietrasiewicz { 43, 243, 240 },
997*3e3b1fb0SAndrzej Pietrasiewicz { 8, 180, 217 },
998*3e3b1fb0SAndrzej Pietrasiewicz { 1, 115, 166 },
999*3e3b1fb0SAndrzej Pietrasiewicz { 1, 84, 121 },
1000*3e3b1fb0SAndrzej Pietrasiewicz { 1, 51, 67 },
1001*3e3b1fb0SAndrzej Pietrasiewicz { 1, 16, 6 },
1002*3e3b1fb0SAndrzej Pietrasiewicz },
1003*3e3b1fb0SAndrzej Pietrasiewicz },
1004*3e3b1fb0SAndrzej Pietrasiewicz },
1005*3e3b1fb0SAndrzej Pietrasiewicz },
1006*3e3b1fb0SAndrzej Pietrasiewicz },
1007*3e3b1fb0SAndrzej Pietrasiewicz
1008*3e3b1fb0SAndrzej Pietrasiewicz .skip = { 192, 128, 64 },
1009*3e3b1fb0SAndrzej Pietrasiewicz .inter_mode = {
1010*3e3b1fb0SAndrzej Pietrasiewicz { 2, 173, 34 },
1011*3e3b1fb0SAndrzej Pietrasiewicz { 7, 145, 85 },
1012*3e3b1fb0SAndrzej Pietrasiewicz { 7, 166, 63 },
1013*3e3b1fb0SAndrzej Pietrasiewicz { 7, 94, 66 },
1014*3e3b1fb0SAndrzej Pietrasiewicz { 8, 64, 46 },
1015*3e3b1fb0SAndrzej Pietrasiewicz { 17, 81, 31 },
1016*3e3b1fb0SAndrzej Pietrasiewicz { 25, 29, 30 },
1017*3e3b1fb0SAndrzej Pietrasiewicz },
1018*3e3b1fb0SAndrzej Pietrasiewicz .interp_filter = {
1019*3e3b1fb0SAndrzej Pietrasiewicz { 235, 162 },
1020*3e3b1fb0SAndrzej Pietrasiewicz { 36, 255 },
1021*3e3b1fb0SAndrzej Pietrasiewicz { 34, 3 },
1022*3e3b1fb0SAndrzej Pietrasiewicz { 149, 144 },
1023*3e3b1fb0SAndrzej Pietrasiewicz },
1024*3e3b1fb0SAndrzej Pietrasiewicz .is_inter = { 9, 102, 187, 225 },
1025*3e3b1fb0SAndrzej Pietrasiewicz .comp_mode = { 239, 183, 119, 96, 41 },
1026*3e3b1fb0SAndrzej Pietrasiewicz .single_ref = {
1027*3e3b1fb0SAndrzej Pietrasiewicz { 33, 16 },
1028*3e3b1fb0SAndrzej Pietrasiewicz { 77, 74 },
1029*3e3b1fb0SAndrzej Pietrasiewicz { 142, 142 },
1030*3e3b1fb0SAndrzej Pietrasiewicz { 172, 170 },
1031*3e3b1fb0SAndrzej Pietrasiewicz { 238, 247 },
1032*3e3b1fb0SAndrzej Pietrasiewicz },
1033*3e3b1fb0SAndrzej Pietrasiewicz .comp_ref = { 50, 126, 123, 221, 226 },
1034*3e3b1fb0SAndrzej Pietrasiewicz .y_mode = {
1035*3e3b1fb0SAndrzej Pietrasiewicz { 65, 32, 18, 144, 162, 194, 41, 51, 98 },
1036*3e3b1fb0SAndrzej Pietrasiewicz { 132, 68, 18, 165, 217, 196, 45, 40, 78 },
1037*3e3b1fb0SAndrzej Pietrasiewicz { 173, 80, 19, 176, 240, 193, 64, 35, 46 },
1038*3e3b1fb0SAndrzej Pietrasiewicz { 221, 135, 38, 194, 248, 121, 96, 85, 29 },
1039*3e3b1fb0SAndrzej Pietrasiewicz },
1040*3e3b1fb0SAndrzej Pietrasiewicz .uv_mode = {
1041*3e3b1fb0SAndrzej Pietrasiewicz { 120, 7, 76, 176, 208, 126, 28, 54, 103 } /* y = dc */,
1042*3e3b1fb0SAndrzej Pietrasiewicz { 48, 12, 154, 155, 139, 90, 34, 117, 119 } /* y = v */,
1043*3e3b1fb0SAndrzej Pietrasiewicz { 67, 6, 25, 204, 243, 158, 13, 21, 96 } /* y = h */,
1044*3e3b1fb0SAndrzej Pietrasiewicz { 97, 5, 44, 131, 176, 139, 48, 68, 97 } /* y = d45 */,
1045*3e3b1fb0SAndrzej Pietrasiewicz { 83, 5, 42, 156, 111, 152, 26, 49, 152 } /* y = d135 */,
1046*3e3b1fb0SAndrzej Pietrasiewicz { 80, 5, 58, 178, 74, 83, 33, 62, 145 } /* y = d117 */,
1047*3e3b1fb0SAndrzej Pietrasiewicz { 86, 5, 32, 154, 192, 168, 14, 22, 163 } /* y = d153 */,
1048*3e3b1fb0SAndrzej Pietrasiewicz { 85, 5, 32, 156, 216, 148, 19, 29, 73 } /* y = d207 */,
1049*3e3b1fb0SAndrzej Pietrasiewicz { 77, 7, 64, 116, 132, 122, 37, 126, 120 } /* y = d63 */,
1050*3e3b1fb0SAndrzej Pietrasiewicz { 101, 21, 107, 181, 192, 103, 19, 67, 125 } /* y = tm */
1051*3e3b1fb0SAndrzej Pietrasiewicz },
1052*3e3b1fb0SAndrzej Pietrasiewicz .partition = {
1053*3e3b1fb0SAndrzej Pietrasiewicz /* 8x8 -> 4x4 */
1054*3e3b1fb0SAndrzej Pietrasiewicz { 199, 122, 141 } /* a/l both not split */,
1055*3e3b1fb0SAndrzej Pietrasiewicz { 147, 63, 159 } /* a split, l not split */,
1056*3e3b1fb0SAndrzej Pietrasiewicz { 148, 133, 118 } /* l split, a not split */,
1057*3e3b1fb0SAndrzej Pietrasiewicz { 121, 104, 114 } /* a/l both split */,
1058*3e3b1fb0SAndrzej Pietrasiewicz /* 16x16 -> 8x8 */
1059*3e3b1fb0SAndrzej Pietrasiewicz { 174, 73, 87 } /* a/l both not split */,
1060*3e3b1fb0SAndrzej Pietrasiewicz { 92, 41, 83 } /* a split, l not split */,
1061*3e3b1fb0SAndrzej Pietrasiewicz { 82, 99, 50 } /* l split, a not split */,
1062*3e3b1fb0SAndrzej Pietrasiewicz { 53, 39, 39 } /* a/l both split */,
1063*3e3b1fb0SAndrzej Pietrasiewicz /* 32x32 -> 16x16 */
1064*3e3b1fb0SAndrzej Pietrasiewicz { 177, 58, 59 } /* a/l both not split */,
1065*3e3b1fb0SAndrzej Pietrasiewicz { 68, 26, 63 } /* a split, l not split */,
1066*3e3b1fb0SAndrzej Pietrasiewicz { 52, 79, 25 } /* l split, a not split */,
1067*3e3b1fb0SAndrzej Pietrasiewicz { 17, 14, 12 } /* a/l both split */,
1068*3e3b1fb0SAndrzej Pietrasiewicz /* 64x64 -> 32x32 */
1069*3e3b1fb0SAndrzej Pietrasiewicz { 222, 34, 30 } /* a/l both not split */,
1070*3e3b1fb0SAndrzej Pietrasiewicz { 72, 16, 44 } /* a split, l not split */,
1071*3e3b1fb0SAndrzej Pietrasiewicz { 58, 32, 12 } /* l split, a not split */,
1072*3e3b1fb0SAndrzej Pietrasiewicz { 10, 7, 6 } /* a/l both split */,
1073*3e3b1fb0SAndrzej Pietrasiewicz },
1074*3e3b1fb0SAndrzej Pietrasiewicz
1075*3e3b1fb0SAndrzej Pietrasiewicz .mv = {
1076*3e3b1fb0SAndrzej Pietrasiewicz .joint = { 32, 64, 96 },
1077*3e3b1fb0SAndrzej Pietrasiewicz .sign = { 128, 128 },
1078*3e3b1fb0SAndrzej Pietrasiewicz .classes = {
1079*3e3b1fb0SAndrzej Pietrasiewicz { 224, 144, 192, 168, 192, 176, 192, 198, 198, 245 },
1080*3e3b1fb0SAndrzej Pietrasiewicz { 216, 128, 176, 160, 176, 176, 192, 198, 198, 208 },
1081*3e3b1fb0SAndrzej Pietrasiewicz },
1082*3e3b1fb0SAndrzej Pietrasiewicz .class0_bit = { 216, 208 },
1083*3e3b1fb0SAndrzej Pietrasiewicz .bits = {
1084*3e3b1fb0SAndrzej Pietrasiewicz { 136, 140, 148, 160, 176, 192, 224, 234, 234, 240},
1085*3e3b1fb0SAndrzej Pietrasiewicz { 136, 140, 148, 160, 176, 192, 224, 234, 234, 240},
1086*3e3b1fb0SAndrzej Pietrasiewicz },
1087*3e3b1fb0SAndrzej Pietrasiewicz .class0_fr = {
1088*3e3b1fb0SAndrzej Pietrasiewicz {
1089*3e3b1fb0SAndrzej Pietrasiewicz { 128, 128, 64 },
1090*3e3b1fb0SAndrzej Pietrasiewicz { 96, 112, 64 },
1091*3e3b1fb0SAndrzej Pietrasiewicz },
1092*3e3b1fb0SAndrzej Pietrasiewicz {
1093*3e3b1fb0SAndrzej Pietrasiewicz { 128, 128, 64 },
1094*3e3b1fb0SAndrzej Pietrasiewicz { 96, 112, 64 },
1095*3e3b1fb0SAndrzej Pietrasiewicz },
1096*3e3b1fb0SAndrzej Pietrasiewicz },
1097*3e3b1fb0SAndrzej Pietrasiewicz .fr = {
1098*3e3b1fb0SAndrzej Pietrasiewicz { 64, 96, 64 },
1099*3e3b1fb0SAndrzej Pietrasiewicz { 64, 96, 64 },
1100*3e3b1fb0SAndrzej Pietrasiewicz },
1101*3e3b1fb0SAndrzej Pietrasiewicz .class0_hp = { 160, 160 },
1102*3e3b1fb0SAndrzej Pietrasiewicz .hp = { 128, 128 },
1103*3e3b1fb0SAndrzej Pietrasiewicz },
1104*3e3b1fb0SAndrzej Pietrasiewicz };
1105*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_default_probs);
1106*3e3b1fb0SAndrzej Pietrasiewicz
fastdiv(u32 dividend,u16 divisor)1107*3e3b1fb0SAndrzej Pietrasiewicz static u32 fastdiv(u32 dividend, u16 divisor)
1108*3e3b1fb0SAndrzej Pietrasiewicz {
1109*3e3b1fb0SAndrzej Pietrasiewicz #define DIV_INV(d) ((u32)(((1ULL << 32) + ((d) - 1)) / (d)))
1110*3e3b1fb0SAndrzej Pietrasiewicz #define DIVS_INV(d0, d1, d2, d3, d4, d5, d6, d7, d8, d9) \
1111*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(d0), DIV_INV(d1), DIV_INV(d2), DIV_INV(d3), \
1112*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(d4), DIV_INV(d5), DIV_INV(d6), DIV_INV(d7), \
1113*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(d8), DIV_INV(d9)
1114*3e3b1fb0SAndrzej Pietrasiewicz
1115*3e3b1fb0SAndrzej Pietrasiewicz static const u32 inv[] = {
1116*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(2), DIV_INV(3), DIV_INV(4), DIV_INV(5),
1117*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(6), DIV_INV(7), DIV_INV(8), DIV_INV(9),
1118*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(10, 11, 12, 13, 14, 15, 16, 17, 18, 19),
1119*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(20, 21, 22, 23, 24, 25, 26, 27, 28, 29),
1120*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(30, 31, 32, 33, 34, 35, 36, 37, 38, 39),
1121*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(40, 41, 42, 43, 44, 45, 46, 47, 48, 49),
1122*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(50, 51, 52, 53, 54, 55, 56, 57, 58, 59),
1123*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(60, 61, 62, 63, 64, 65, 66, 67, 68, 69),
1124*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(70, 71, 72, 73, 74, 75, 76, 77, 78, 79),
1125*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(80, 81, 82, 83, 84, 85, 86, 87, 88, 89),
1126*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(90, 91, 92, 93, 94, 95, 96, 97, 98, 99),
1127*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(100, 101, 102, 103, 104, 105, 106, 107, 108, 109),
1128*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(110, 111, 112, 113, 114, 115, 116, 117, 118, 119),
1129*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(120, 121, 122, 123, 124, 125, 126, 127, 128, 129),
1130*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(130, 131, 132, 133, 134, 135, 136, 137, 138, 139),
1131*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(140, 141, 142, 143, 144, 145, 146, 147, 148, 149),
1132*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(150, 151, 152, 153, 154, 155, 156, 157, 158, 159),
1133*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(160, 161, 162, 163, 164, 165, 166, 167, 168, 169),
1134*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(170, 171, 172, 173, 174, 175, 176, 177, 178, 179),
1135*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(180, 181, 182, 183, 184, 185, 186, 187, 188, 189),
1136*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(190, 191, 192, 193, 194, 195, 196, 197, 198, 199),
1137*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(200, 201, 202, 203, 204, 205, 206, 207, 208, 209),
1138*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(210, 211, 212, 213, 214, 215, 216, 217, 218, 219),
1139*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(220, 221, 222, 223, 224, 225, 226, 227, 228, 229),
1140*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(230, 231, 232, 233, 234, 235, 236, 237, 238, 239),
1141*3e3b1fb0SAndrzej Pietrasiewicz DIVS_INV(240, 241, 242, 243, 244, 245, 246, 247, 248, 249),
1142*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(250), DIV_INV(251), DIV_INV(252), DIV_INV(253),
1143*3e3b1fb0SAndrzej Pietrasiewicz DIV_INV(254), DIV_INV(255), DIV_INV(256),
1144*3e3b1fb0SAndrzej Pietrasiewicz };
1145*3e3b1fb0SAndrzej Pietrasiewicz
1146*3e3b1fb0SAndrzej Pietrasiewicz if (divisor == 0)
1147*3e3b1fb0SAndrzej Pietrasiewicz return 0;
1148*3e3b1fb0SAndrzej Pietrasiewicz else if (divisor == 1)
1149*3e3b1fb0SAndrzej Pietrasiewicz return dividend;
1150*3e3b1fb0SAndrzej Pietrasiewicz
1151*3e3b1fb0SAndrzej Pietrasiewicz if (WARN_ON(divisor - 2 >= ARRAY_SIZE(inv)))
1152*3e3b1fb0SAndrzej Pietrasiewicz return dividend;
1153*3e3b1fb0SAndrzej Pietrasiewicz
1154*3e3b1fb0SAndrzej Pietrasiewicz return ((u64)dividend * inv[divisor - 2]) >> 32;
1155*3e3b1fb0SAndrzej Pietrasiewicz }
1156*3e3b1fb0SAndrzej Pietrasiewicz
1157*3e3b1fb0SAndrzej Pietrasiewicz /* 6.3.6 inv_recenter_nonneg(v, m) */
inv_recenter_nonneg(int v,int m)1158*3e3b1fb0SAndrzej Pietrasiewicz static int inv_recenter_nonneg(int v, int m)
1159*3e3b1fb0SAndrzej Pietrasiewicz {
1160*3e3b1fb0SAndrzej Pietrasiewicz if (v > 2 * m)
1161*3e3b1fb0SAndrzej Pietrasiewicz return v;
1162*3e3b1fb0SAndrzej Pietrasiewicz
1163*3e3b1fb0SAndrzej Pietrasiewicz if (v & 1)
1164*3e3b1fb0SAndrzej Pietrasiewicz return m - ((v + 1) >> 1);
1165*3e3b1fb0SAndrzej Pietrasiewicz
1166*3e3b1fb0SAndrzej Pietrasiewicz return m + (v >> 1);
1167*3e3b1fb0SAndrzej Pietrasiewicz }
1168*3e3b1fb0SAndrzej Pietrasiewicz
1169*3e3b1fb0SAndrzej Pietrasiewicz /*
1170*3e3b1fb0SAndrzej Pietrasiewicz * part of 6.3.5 inv_remap_prob(deltaProb, prob)
1171*3e3b1fb0SAndrzej Pietrasiewicz * delta = inv_map_table[deltaProb] done by userspace
1172*3e3b1fb0SAndrzej Pietrasiewicz */
update_prob(int delta,int prob)1173*3e3b1fb0SAndrzej Pietrasiewicz static int update_prob(int delta, int prob)
1174*3e3b1fb0SAndrzej Pietrasiewicz {
1175*3e3b1fb0SAndrzej Pietrasiewicz if (!delta)
1176*3e3b1fb0SAndrzej Pietrasiewicz return prob;
1177*3e3b1fb0SAndrzej Pietrasiewicz
1178*3e3b1fb0SAndrzej Pietrasiewicz return prob <= 128 ?
1179*3e3b1fb0SAndrzej Pietrasiewicz 1 + inv_recenter_nonneg(delta, prob - 1) :
1180*3e3b1fb0SAndrzej Pietrasiewicz 255 - inv_recenter_nonneg(delta, 255 - prob);
1181*3e3b1fb0SAndrzej Pietrasiewicz }
1182*3e3b1fb0SAndrzej Pietrasiewicz
1183*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.2 tx_mode_probs() */
update_tx_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1184*3e3b1fb0SAndrzej Pietrasiewicz static void update_tx_probs(struct v4l2_vp9_frame_context *probs,
1185*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1186*3e3b1fb0SAndrzej Pietrasiewicz {
1187*3e3b1fb0SAndrzej Pietrasiewicz int i;
1188*3e3b1fb0SAndrzej Pietrasiewicz
1189*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->tx8); i++) {
1190*3e3b1fb0SAndrzej Pietrasiewicz u8 *p8x8 = probs->tx8[i];
1191*3e3b1fb0SAndrzej Pietrasiewicz u8 *p16x16 = probs->tx16[i];
1192*3e3b1fb0SAndrzej Pietrasiewicz u8 *p32x32 = probs->tx32[i];
1193*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d8x8 = deltas->tx8[i];
1194*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d16x16 = deltas->tx16[i];
1195*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d32x32 = deltas->tx32[i];
1196*3e3b1fb0SAndrzej Pietrasiewicz
1197*3e3b1fb0SAndrzej Pietrasiewicz p8x8[0] = update_prob(d8x8[0], p8x8[0]);
1198*3e3b1fb0SAndrzej Pietrasiewicz p16x16[0] = update_prob(d16x16[0], p16x16[0]);
1199*3e3b1fb0SAndrzej Pietrasiewicz p16x16[1] = update_prob(d16x16[1], p16x16[1]);
1200*3e3b1fb0SAndrzej Pietrasiewicz p32x32[0] = update_prob(d32x32[0], p32x32[0]);
1201*3e3b1fb0SAndrzej Pietrasiewicz p32x32[1] = update_prob(d32x32[1], p32x32[1]);
1202*3e3b1fb0SAndrzej Pietrasiewicz p32x32[2] = update_prob(d32x32[2], p32x32[2]);
1203*3e3b1fb0SAndrzej Pietrasiewicz }
1204*3e3b1fb0SAndrzej Pietrasiewicz }
1205*3e3b1fb0SAndrzej Pietrasiewicz
1206*3e3b1fb0SAndrzej Pietrasiewicz #define BAND_6(band) ((band) == 0 ? 3 : 6)
1207*3e3b1fb0SAndrzej Pietrasiewicz
update_coeff(const u8 deltas[6][6][3],u8 probs[6][6][3])1208*3e3b1fb0SAndrzej Pietrasiewicz static void update_coeff(const u8 deltas[6][6][3], u8 probs[6][6][3])
1209*3e3b1fb0SAndrzej Pietrasiewicz {
1210*3e3b1fb0SAndrzej Pietrasiewicz int l, m, n;
1211*3e3b1fb0SAndrzej Pietrasiewicz
1212*3e3b1fb0SAndrzej Pietrasiewicz for (l = 0; l < 6; l++)
1213*3e3b1fb0SAndrzej Pietrasiewicz for (m = 0; m < BAND_6(l); m++) {
1214*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs[l][m];
1215*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d = deltas[l][m];
1216*3e3b1fb0SAndrzej Pietrasiewicz
1217*3e3b1fb0SAndrzej Pietrasiewicz for (n = 0; n < 3; n++)
1218*3e3b1fb0SAndrzej Pietrasiewicz p[n] = update_prob(d[n], p[n]);
1219*3e3b1fb0SAndrzej Pietrasiewicz }
1220*3e3b1fb0SAndrzej Pietrasiewicz }
1221*3e3b1fb0SAndrzej Pietrasiewicz
1222*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.7 read_coef_probs() */
update_coef_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas,const struct v4l2_ctrl_vp9_frame * dec_params)1223*3e3b1fb0SAndrzej Pietrasiewicz static void update_coef_probs(struct v4l2_vp9_frame_context *probs,
1224*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas,
1225*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_frame *dec_params)
1226*3e3b1fb0SAndrzej Pietrasiewicz {
1227*3e3b1fb0SAndrzej Pietrasiewicz int i, j, k;
1228*3e3b1fb0SAndrzej Pietrasiewicz
1229*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->coef); i++) {
1230*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->coef[0]); j++)
1231*3e3b1fb0SAndrzej Pietrasiewicz for (k = 0; k < ARRAY_SIZE(probs->coef[0][0]); k++)
1232*3e3b1fb0SAndrzej Pietrasiewicz update_coeff(deltas->coef[i][j][k], probs->coef[i][j][k]);
1233*3e3b1fb0SAndrzej Pietrasiewicz
1234*3e3b1fb0SAndrzej Pietrasiewicz if (deltas->tx_mode == i)
1235*3e3b1fb0SAndrzej Pietrasiewicz break;
1236*3e3b1fb0SAndrzej Pietrasiewicz }
1237*3e3b1fb0SAndrzej Pietrasiewicz }
1238*3e3b1fb0SAndrzej Pietrasiewicz
1239*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.8 read_skip_prob() */
update_skip_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1240*3e3b1fb0SAndrzej Pietrasiewicz static void update_skip_probs(struct v4l2_vp9_frame_context *probs,
1241*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1242*3e3b1fb0SAndrzej Pietrasiewicz {
1243*3e3b1fb0SAndrzej Pietrasiewicz int i;
1244*3e3b1fb0SAndrzej Pietrasiewicz
1245*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->skip); i++)
1246*3e3b1fb0SAndrzej Pietrasiewicz probs->skip[i] = update_prob(deltas->skip[i], probs->skip[i]);
1247*3e3b1fb0SAndrzej Pietrasiewicz }
1248*3e3b1fb0SAndrzej Pietrasiewicz
1249*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.9 read_inter_mode_probs() */
update_inter_mode_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1250*3e3b1fb0SAndrzej Pietrasiewicz static void update_inter_mode_probs(struct v4l2_vp9_frame_context *probs,
1251*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1252*3e3b1fb0SAndrzej Pietrasiewicz {
1253*3e3b1fb0SAndrzej Pietrasiewicz int i;
1254*3e3b1fb0SAndrzej Pietrasiewicz
1255*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->inter_mode); i++) {
1256*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs->inter_mode[i];
1257*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d = deltas->inter_mode[i];
1258*3e3b1fb0SAndrzej Pietrasiewicz
1259*3e3b1fb0SAndrzej Pietrasiewicz p[0] = update_prob(d[0], p[0]);
1260*3e3b1fb0SAndrzej Pietrasiewicz p[1] = update_prob(d[1], p[1]);
1261*3e3b1fb0SAndrzej Pietrasiewicz p[2] = update_prob(d[2], p[2]);
1262*3e3b1fb0SAndrzej Pietrasiewicz }
1263*3e3b1fb0SAndrzej Pietrasiewicz }
1264*3e3b1fb0SAndrzej Pietrasiewicz
1265*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.10 read_interp_filter_probs() */
update_interp_filter_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1266*3e3b1fb0SAndrzej Pietrasiewicz static void update_interp_filter_probs(struct v4l2_vp9_frame_context *probs,
1267*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1268*3e3b1fb0SAndrzej Pietrasiewicz {
1269*3e3b1fb0SAndrzej Pietrasiewicz int i;
1270*3e3b1fb0SAndrzej Pietrasiewicz
1271*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->interp_filter); i++) {
1272*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs->interp_filter[i];
1273*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d = deltas->interp_filter[i];
1274*3e3b1fb0SAndrzej Pietrasiewicz
1275*3e3b1fb0SAndrzej Pietrasiewicz p[0] = update_prob(d[0], p[0]);
1276*3e3b1fb0SAndrzej Pietrasiewicz p[1] = update_prob(d[1], p[1]);
1277*3e3b1fb0SAndrzej Pietrasiewicz }
1278*3e3b1fb0SAndrzej Pietrasiewicz }
1279*3e3b1fb0SAndrzej Pietrasiewicz
1280*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.11 read_is_inter_probs() */
update_is_inter_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1281*3e3b1fb0SAndrzej Pietrasiewicz static void update_is_inter_probs(struct v4l2_vp9_frame_context *probs,
1282*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1283*3e3b1fb0SAndrzej Pietrasiewicz {
1284*3e3b1fb0SAndrzej Pietrasiewicz int i;
1285*3e3b1fb0SAndrzej Pietrasiewicz
1286*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->is_inter); i++)
1287*3e3b1fb0SAndrzej Pietrasiewicz probs->is_inter[i] = update_prob(deltas->is_inter[i], probs->is_inter[i]);
1288*3e3b1fb0SAndrzej Pietrasiewicz }
1289*3e3b1fb0SAndrzej Pietrasiewicz
1290*3e3b1fb0SAndrzej Pietrasiewicz /* 6.3.12 frame_reference_mode() done entirely in userspace */
1291*3e3b1fb0SAndrzej Pietrasiewicz
1292*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.13 frame_reference_mode_probs() */
1293*3e3b1fb0SAndrzej Pietrasiewicz static void
update_frame_reference_mode_probs(unsigned int reference_mode,struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1294*3e3b1fb0SAndrzej Pietrasiewicz update_frame_reference_mode_probs(unsigned int reference_mode,
1295*3e3b1fb0SAndrzej Pietrasiewicz struct v4l2_vp9_frame_context *probs,
1296*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1297*3e3b1fb0SAndrzej Pietrasiewicz {
1298*3e3b1fb0SAndrzej Pietrasiewicz int i;
1299*3e3b1fb0SAndrzej Pietrasiewicz
1300*3e3b1fb0SAndrzej Pietrasiewicz if (reference_mode == V4L2_VP9_REFERENCE_MODE_SELECT)
1301*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->comp_mode); i++)
1302*3e3b1fb0SAndrzej Pietrasiewicz probs->comp_mode[i] = update_prob(deltas->comp_mode[i],
1303*3e3b1fb0SAndrzej Pietrasiewicz probs->comp_mode[i]);
1304*3e3b1fb0SAndrzej Pietrasiewicz
1305*3e3b1fb0SAndrzej Pietrasiewicz if (reference_mode != V4L2_VP9_REFERENCE_MODE_COMPOUND_REFERENCE)
1306*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->single_ref); i++) {
1307*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs->single_ref[i];
1308*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d = deltas->single_ref[i];
1309*3e3b1fb0SAndrzej Pietrasiewicz
1310*3e3b1fb0SAndrzej Pietrasiewicz p[0] = update_prob(d[0], p[0]);
1311*3e3b1fb0SAndrzej Pietrasiewicz p[1] = update_prob(d[1], p[1]);
1312*3e3b1fb0SAndrzej Pietrasiewicz }
1313*3e3b1fb0SAndrzej Pietrasiewicz
1314*3e3b1fb0SAndrzej Pietrasiewicz if (reference_mode != V4L2_VP9_REFERENCE_MODE_SINGLE_REFERENCE)
1315*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->comp_ref); i++)
1316*3e3b1fb0SAndrzej Pietrasiewicz probs->comp_ref[i] = update_prob(deltas->comp_ref[i], probs->comp_ref[i]);
1317*3e3b1fb0SAndrzej Pietrasiewicz }
1318*3e3b1fb0SAndrzej Pietrasiewicz
1319*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.14 read_y_mode_probs() */
update_y_mode_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1320*3e3b1fb0SAndrzej Pietrasiewicz static void update_y_mode_probs(struct v4l2_vp9_frame_context *probs,
1321*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1322*3e3b1fb0SAndrzej Pietrasiewicz {
1323*3e3b1fb0SAndrzej Pietrasiewicz int i, j;
1324*3e3b1fb0SAndrzej Pietrasiewicz
1325*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->y_mode); i++)
1326*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->y_mode[0]); ++j)
1327*3e3b1fb0SAndrzej Pietrasiewicz probs->y_mode[i][j] =
1328*3e3b1fb0SAndrzej Pietrasiewicz update_prob(deltas->y_mode[i][j], probs->y_mode[i][j]);
1329*3e3b1fb0SAndrzej Pietrasiewicz }
1330*3e3b1fb0SAndrzej Pietrasiewicz
1331*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.15 read_partition_probs() */
update_partition_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas)1332*3e3b1fb0SAndrzej Pietrasiewicz static void update_partition_probs(struct v4l2_vp9_frame_context *probs,
1333*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas)
1334*3e3b1fb0SAndrzej Pietrasiewicz {
1335*3e3b1fb0SAndrzej Pietrasiewicz int i, j;
1336*3e3b1fb0SAndrzej Pietrasiewicz
1337*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < 4; i++)
1338*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < 4; j++) {
1339*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs->partition[i * 4 + j];
1340*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d = deltas->partition[i * 4 + j];
1341*3e3b1fb0SAndrzej Pietrasiewicz
1342*3e3b1fb0SAndrzej Pietrasiewicz p[0] = update_prob(d[0], p[0]);
1343*3e3b1fb0SAndrzej Pietrasiewicz p[1] = update_prob(d[1], p[1]);
1344*3e3b1fb0SAndrzej Pietrasiewicz p[2] = update_prob(d[2], p[2]);
1345*3e3b1fb0SAndrzej Pietrasiewicz }
1346*3e3b1fb0SAndrzej Pietrasiewicz }
1347*3e3b1fb0SAndrzej Pietrasiewicz
update_mv_prob(int delta,int prob)1348*3e3b1fb0SAndrzej Pietrasiewicz static inline int update_mv_prob(int delta, int prob)
1349*3e3b1fb0SAndrzej Pietrasiewicz {
1350*3e3b1fb0SAndrzej Pietrasiewicz if (!delta)
1351*3e3b1fb0SAndrzej Pietrasiewicz return prob;
1352*3e3b1fb0SAndrzej Pietrasiewicz
1353*3e3b1fb0SAndrzej Pietrasiewicz return delta;
1354*3e3b1fb0SAndrzej Pietrasiewicz }
1355*3e3b1fb0SAndrzej Pietrasiewicz
1356*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3.16 mv_probs() */
update_mv_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas,const struct v4l2_ctrl_vp9_frame * dec_params)1357*3e3b1fb0SAndrzej Pietrasiewicz static void update_mv_probs(struct v4l2_vp9_frame_context *probs,
1358*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas,
1359*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_frame *dec_params)
1360*3e3b1fb0SAndrzej Pietrasiewicz {
1361*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs->mv.joint;
1362*3e3b1fb0SAndrzej Pietrasiewicz const u8 *d = deltas->mv.joint;
1363*3e3b1fb0SAndrzej Pietrasiewicz unsigned int i, j;
1364*3e3b1fb0SAndrzej Pietrasiewicz
1365*3e3b1fb0SAndrzej Pietrasiewicz p[0] = update_mv_prob(d[0], p[0]);
1366*3e3b1fb0SAndrzej Pietrasiewicz p[1] = update_mv_prob(d[1], p[1]);
1367*3e3b1fb0SAndrzej Pietrasiewicz p[2] = update_mv_prob(d[2], p[2]);
1368*3e3b1fb0SAndrzej Pietrasiewicz
1369*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->mv.sign); i++) {
1370*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.sign;
1371*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.sign;
1372*3e3b1fb0SAndrzej Pietrasiewicz p[i] = update_mv_prob(d[i], p[i]);
1373*3e3b1fb0SAndrzej Pietrasiewicz
1374*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.classes[i];
1375*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.classes[i];
1376*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->mv.classes[0]); j++)
1377*3e3b1fb0SAndrzej Pietrasiewicz p[j] = update_mv_prob(d[j], p[j]);
1378*3e3b1fb0SAndrzej Pietrasiewicz
1379*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.class0_bit;
1380*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.class0_bit;
1381*3e3b1fb0SAndrzej Pietrasiewicz p[i] = update_mv_prob(d[i], p[i]);
1382*3e3b1fb0SAndrzej Pietrasiewicz
1383*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.bits[i];
1384*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.bits[i];
1385*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->mv.bits[0]); j++)
1386*3e3b1fb0SAndrzej Pietrasiewicz p[j] = update_mv_prob(d[j], p[j]);
1387*3e3b1fb0SAndrzej Pietrasiewicz
1388*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->mv.class0_fr[0]); j++) {
1389*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.class0_fr[i][j];
1390*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.class0_fr[i][j];
1391*3e3b1fb0SAndrzej Pietrasiewicz
1392*3e3b1fb0SAndrzej Pietrasiewicz p[0] = update_mv_prob(d[0], p[0]);
1393*3e3b1fb0SAndrzej Pietrasiewicz p[1] = update_mv_prob(d[1], p[1]);
1394*3e3b1fb0SAndrzej Pietrasiewicz p[2] = update_mv_prob(d[2], p[2]);
1395*3e3b1fb0SAndrzej Pietrasiewicz }
1396*3e3b1fb0SAndrzej Pietrasiewicz
1397*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.fr[i];
1398*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.fr[i];
1399*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->mv.fr[i]); j++)
1400*3e3b1fb0SAndrzej Pietrasiewicz p[j] = update_mv_prob(d[j], p[j]);
1401*3e3b1fb0SAndrzej Pietrasiewicz
1402*3e3b1fb0SAndrzej Pietrasiewicz if (dec_params->flags & V4L2_VP9_FRAME_FLAG_ALLOW_HIGH_PREC_MV) {
1403*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.class0_hp;
1404*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.class0_hp;
1405*3e3b1fb0SAndrzej Pietrasiewicz p[i] = update_mv_prob(d[i], p[i]);
1406*3e3b1fb0SAndrzej Pietrasiewicz
1407*3e3b1fb0SAndrzej Pietrasiewicz p = probs->mv.hp;
1408*3e3b1fb0SAndrzej Pietrasiewicz d = deltas->mv.hp;
1409*3e3b1fb0SAndrzej Pietrasiewicz p[i] = update_mv_prob(d[i], p[i]);
1410*3e3b1fb0SAndrzej Pietrasiewicz }
1411*3e3b1fb0SAndrzej Pietrasiewicz }
1412*3e3b1fb0SAndrzej Pietrasiewicz }
1413*3e3b1fb0SAndrzej Pietrasiewicz
1414*3e3b1fb0SAndrzej Pietrasiewicz /* Counterpart to 6.3 compressed_header(), but parsing has been done in userspace. */
v4l2_vp9_fw_update_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_ctrl_vp9_compressed_hdr * deltas,const struct v4l2_ctrl_vp9_frame * dec_params)1415*3e3b1fb0SAndrzej Pietrasiewicz void v4l2_vp9_fw_update_probs(struct v4l2_vp9_frame_context *probs,
1416*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_compressed_hdr *deltas,
1417*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_ctrl_vp9_frame *dec_params)
1418*3e3b1fb0SAndrzej Pietrasiewicz {
1419*3e3b1fb0SAndrzej Pietrasiewicz if (deltas->tx_mode == V4L2_VP9_TX_MODE_SELECT)
1420*3e3b1fb0SAndrzej Pietrasiewicz update_tx_probs(probs, deltas);
1421*3e3b1fb0SAndrzej Pietrasiewicz
1422*3e3b1fb0SAndrzej Pietrasiewicz update_coef_probs(probs, deltas, dec_params);
1423*3e3b1fb0SAndrzej Pietrasiewicz
1424*3e3b1fb0SAndrzej Pietrasiewicz update_skip_probs(probs, deltas);
1425*3e3b1fb0SAndrzej Pietrasiewicz
1426*3e3b1fb0SAndrzej Pietrasiewicz if (dec_params->flags & V4L2_VP9_FRAME_FLAG_KEY_FRAME ||
1427*3e3b1fb0SAndrzej Pietrasiewicz dec_params->flags & V4L2_VP9_FRAME_FLAG_INTRA_ONLY)
1428*3e3b1fb0SAndrzej Pietrasiewicz return;
1429*3e3b1fb0SAndrzej Pietrasiewicz
1430*3e3b1fb0SAndrzej Pietrasiewicz update_inter_mode_probs(probs, deltas);
1431*3e3b1fb0SAndrzej Pietrasiewicz
1432*3e3b1fb0SAndrzej Pietrasiewicz if (dec_params->interpolation_filter == V4L2_VP9_INTERP_FILTER_SWITCHABLE)
1433*3e3b1fb0SAndrzej Pietrasiewicz update_interp_filter_probs(probs, deltas);
1434*3e3b1fb0SAndrzej Pietrasiewicz
1435*3e3b1fb0SAndrzej Pietrasiewicz update_is_inter_probs(probs, deltas);
1436*3e3b1fb0SAndrzej Pietrasiewicz
1437*3e3b1fb0SAndrzej Pietrasiewicz update_frame_reference_mode_probs(dec_params->reference_mode, probs, deltas);
1438*3e3b1fb0SAndrzej Pietrasiewicz
1439*3e3b1fb0SAndrzej Pietrasiewicz update_y_mode_probs(probs, deltas);
1440*3e3b1fb0SAndrzej Pietrasiewicz
1441*3e3b1fb0SAndrzej Pietrasiewicz update_partition_probs(probs, deltas);
1442*3e3b1fb0SAndrzej Pietrasiewicz
1443*3e3b1fb0SAndrzej Pietrasiewicz update_mv_probs(probs, deltas, dec_params);
1444*3e3b1fb0SAndrzej Pietrasiewicz }
1445*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_fw_update_probs);
1446*3e3b1fb0SAndrzej Pietrasiewicz
v4l2_vp9_reset_frame_ctx(const struct v4l2_ctrl_vp9_frame * dec_params,struct v4l2_vp9_frame_context * frame_context)1447*3e3b1fb0SAndrzej Pietrasiewicz u8 v4l2_vp9_reset_frame_ctx(const struct v4l2_ctrl_vp9_frame *dec_params,
1448*3e3b1fb0SAndrzej Pietrasiewicz struct v4l2_vp9_frame_context *frame_context)
1449*3e3b1fb0SAndrzej Pietrasiewicz {
1450*3e3b1fb0SAndrzej Pietrasiewicz int i;
1451*3e3b1fb0SAndrzej Pietrasiewicz
1452*3e3b1fb0SAndrzej Pietrasiewicz u8 fctx_idx = dec_params->frame_context_idx;
1453*3e3b1fb0SAndrzej Pietrasiewicz
1454*3e3b1fb0SAndrzej Pietrasiewicz if (dec_params->flags & V4L2_VP9_FRAME_FLAG_KEY_FRAME ||
1455*3e3b1fb0SAndrzej Pietrasiewicz dec_params->flags & V4L2_VP9_FRAME_FLAG_INTRA_ONLY ||
1456*3e3b1fb0SAndrzej Pietrasiewicz dec_params->flags & V4L2_VP9_FRAME_FLAG_ERROR_RESILIENT) {
1457*3e3b1fb0SAndrzej Pietrasiewicz /*
1458*3e3b1fb0SAndrzej Pietrasiewicz * setup_past_independence()
1459*3e3b1fb0SAndrzej Pietrasiewicz * We do nothing here. Instead of storing default probs in some intermediate
1460*3e3b1fb0SAndrzej Pietrasiewicz * location and then copying from that location to appropriate contexts
1461*3e3b1fb0SAndrzej Pietrasiewicz * in save_probs() below, we skip that step and save default probs directly
1462*3e3b1fb0SAndrzej Pietrasiewicz * to appropriate contexts.
1463*3e3b1fb0SAndrzej Pietrasiewicz */
1464*3e3b1fb0SAndrzej Pietrasiewicz if (dec_params->flags & V4L2_VP9_FRAME_FLAG_KEY_FRAME ||
1465*3e3b1fb0SAndrzej Pietrasiewicz dec_params->flags & V4L2_VP9_FRAME_FLAG_ERROR_RESILIENT ||
1466*3e3b1fb0SAndrzej Pietrasiewicz dec_params->reset_frame_context == V4L2_VP9_RESET_FRAME_CTX_ALL)
1467*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < 4; ++i)
1468*3e3b1fb0SAndrzej Pietrasiewicz /* save_probs(i) */
1469*3e3b1fb0SAndrzej Pietrasiewicz memcpy(&frame_context[i], &v4l2_vp9_default_probs,
1470*3e3b1fb0SAndrzej Pietrasiewicz sizeof(v4l2_vp9_default_probs));
1471*3e3b1fb0SAndrzej Pietrasiewicz else if (dec_params->reset_frame_context == V4L2_VP9_RESET_FRAME_CTX_SPEC)
1472*3e3b1fb0SAndrzej Pietrasiewicz /* save_probs(fctx_idx) */
1473*3e3b1fb0SAndrzej Pietrasiewicz memcpy(&frame_context[fctx_idx], &v4l2_vp9_default_probs,
1474*3e3b1fb0SAndrzej Pietrasiewicz sizeof(v4l2_vp9_default_probs));
1475*3e3b1fb0SAndrzej Pietrasiewicz fctx_idx = 0;
1476*3e3b1fb0SAndrzej Pietrasiewicz }
1477*3e3b1fb0SAndrzej Pietrasiewicz
1478*3e3b1fb0SAndrzej Pietrasiewicz return fctx_idx;
1479*3e3b1fb0SAndrzej Pietrasiewicz }
1480*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_reset_frame_ctx);
1481*3e3b1fb0SAndrzej Pietrasiewicz
1482*3e3b1fb0SAndrzej Pietrasiewicz /* 8.4.1 Merge prob process */
merge_prob(u8 pre_prob,u32 ct0,u32 ct1,u16 count_sat,u32 max_update_factor)1483*3e3b1fb0SAndrzej Pietrasiewicz static u8 merge_prob(u8 pre_prob, u32 ct0, u32 ct1, u16 count_sat, u32 max_update_factor)
1484*3e3b1fb0SAndrzej Pietrasiewicz {
1485*3e3b1fb0SAndrzej Pietrasiewicz u32 den, prob, count, factor;
1486*3e3b1fb0SAndrzej Pietrasiewicz
1487*3e3b1fb0SAndrzej Pietrasiewicz den = ct0 + ct1;
1488*3e3b1fb0SAndrzej Pietrasiewicz if (!den) {
1489*3e3b1fb0SAndrzej Pietrasiewicz /*
1490*3e3b1fb0SAndrzej Pietrasiewicz * prob = 128, count = 0, update_factor = 0
1491*3e3b1fb0SAndrzej Pietrasiewicz * Round2's argument: pre_prob * 256
1492*3e3b1fb0SAndrzej Pietrasiewicz * (pre_prob * 256 + 128) >> 8 == pre_prob
1493*3e3b1fb0SAndrzej Pietrasiewicz */
1494*3e3b1fb0SAndrzej Pietrasiewicz return pre_prob;
1495*3e3b1fb0SAndrzej Pietrasiewicz }
1496*3e3b1fb0SAndrzej Pietrasiewicz
1497*3e3b1fb0SAndrzej Pietrasiewicz prob = clamp(((ct0 << 8) + (den >> 1)) / den, (u32)1, (u32)255);
1498*3e3b1fb0SAndrzej Pietrasiewicz count = min_t(u32, den, count_sat);
1499*3e3b1fb0SAndrzej Pietrasiewicz factor = fastdiv(max_update_factor * count, count_sat);
1500*3e3b1fb0SAndrzej Pietrasiewicz
1501*3e3b1fb0SAndrzej Pietrasiewicz /*
1502*3e3b1fb0SAndrzej Pietrasiewicz * Round2(pre_prob * (256 - factor) + prob * factor, 8)
1503*3e3b1fb0SAndrzej Pietrasiewicz * Round2(pre_prob * 256 + (prob - pre_prob) * factor, 8)
1504*3e3b1fb0SAndrzej Pietrasiewicz * (pre_prob * 256 >> 8) + (((prob - pre_prob) * factor + 128) >> 8)
1505*3e3b1fb0SAndrzej Pietrasiewicz */
1506*3e3b1fb0SAndrzej Pietrasiewicz return pre_prob + (((prob - pre_prob) * factor + 128) >> 8);
1507*3e3b1fb0SAndrzej Pietrasiewicz }
1508*3e3b1fb0SAndrzej Pietrasiewicz
noncoef_merge_prob(u8 pre_prob,u32 ct0,u32 ct1)1509*3e3b1fb0SAndrzej Pietrasiewicz static inline u8 noncoef_merge_prob(u8 pre_prob, u32 ct0, u32 ct1)
1510*3e3b1fb0SAndrzej Pietrasiewicz {
1511*3e3b1fb0SAndrzej Pietrasiewicz return merge_prob(pre_prob, ct0, ct1, 20, 128);
1512*3e3b1fb0SAndrzej Pietrasiewicz }
1513*3e3b1fb0SAndrzej Pietrasiewicz
1514*3e3b1fb0SAndrzej Pietrasiewicz /* 8.4.2 Merge probs process */
1515*3e3b1fb0SAndrzej Pietrasiewicz /*
1516*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs() is a recursive function in the spec. We avoid recursion in the kernel.
1517*3e3b1fb0SAndrzej Pietrasiewicz * That said, the "tree" parameter of merge_probs() controls how deep the recursion goes.
1518*3e3b1fb0SAndrzej Pietrasiewicz * It turns out that in all cases the recursive calls boil down to a short-ish series
1519*3e3b1fb0SAndrzej Pietrasiewicz * of merge_prob() invocations (note no "s").
1520*3e3b1fb0SAndrzej Pietrasiewicz *
1521*3e3b1fb0SAndrzej Pietrasiewicz * Variant A
1522*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1523*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(small_token_tree, 2):
1524*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[1], c[0], c[1] + c[2])
1525*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[2], c[1], c[2])
1526*3e3b1fb0SAndrzej Pietrasiewicz *
1527*3e3b1fb0SAndrzej Pietrasiewicz * Variant B
1528*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1529*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(binary_tree, 0) or
1530*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(tx_size_8_tree, 0):
1531*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[0], c[0], c[1])
1532*3e3b1fb0SAndrzej Pietrasiewicz *
1533*3e3b1fb0SAndrzej Pietrasiewicz * Variant C
1534*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1535*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(inter_mode_tree, 0):
1536*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[0], c[2], c[1] + c[0] + c[3])
1537*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[1], c[0], c[1] + c[3])
1538*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[2], c[1], c[3])
1539*3e3b1fb0SAndrzej Pietrasiewicz *
1540*3e3b1fb0SAndrzej Pietrasiewicz * Variant D
1541*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1542*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(intra_mode_tree, 0):
1543*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[0], c[0], c[1] + ... + c[9])
1544*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[1], c[9], c[1] + ... + c[8])
1545*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[2], c[1], c[2] + ... + c[8])
1546*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[3], c[2] + c[4] + c[5], c[3] + c[8] + c[6] + c[7])
1547*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[4], c[2], c[4] + c[5])
1548*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[5], c[4], c[5])
1549*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[6], c[3], c[8] + c[6] + c[7])
1550*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[7], c[8], c[6] + c[7])
1551*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[8], c[6], c[7])
1552*3e3b1fb0SAndrzej Pietrasiewicz *
1553*3e3b1fb0SAndrzej Pietrasiewicz * Variant E
1554*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1555*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(partition_tree, 0) or
1556*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(tx_size_32_tree, 0) or
1557*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(mv_joint_tree, 0) or
1558*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(mv_fr_tree, 0):
1559*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[0], c[0], c[1] + c[2] + c[3])
1560*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[1], c[1], c[2] + c[3])
1561*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[2], c[2], c[3])
1562*3e3b1fb0SAndrzej Pietrasiewicz *
1563*3e3b1fb0SAndrzej Pietrasiewicz * Variant F
1564*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1565*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(interp_filter_tree, 0) or
1566*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(tx_size_16_tree, 0):
1567*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[0], c[0], c[1] + c[2])
1568*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[1], c[1], c[2])
1569*3e3b1fb0SAndrzej Pietrasiewicz *
1570*3e3b1fb0SAndrzej Pietrasiewicz * Variant G
1571*3e3b1fb0SAndrzej Pietrasiewicz * ---------
1572*3e3b1fb0SAndrzej Pietrasiewicz * merge_probs(mv_class_tree, 0):
1573*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[0], c[0], c[1] + ... + c[10])
1574*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[1], c[1], c[2] + ... + c[10])
1575*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[2], c[2] + c[3], c[4] + ... + c[10])
1576*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[3], c[2], c[3])
1577*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[4], c[4] + c[5], c[6] + ... + c[10])
1578*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[5], c[4], c[5])
1579*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[6], c[6], c[7] + ... + c[10])
1580*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[7], c[7] + c[8], c[9] + c[10])
1581*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[8], c[7], c[8])
1582*3e3b1fb0SAndrzej Pietrasiewicz * merge_prob(p[9], c[9], [10])
1583*3e3b1fb0SAndrzej Pietrasiewicz */
1584*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_a(u8 * p,const u32 * c,u16 count_sat,u32 update_factor)1585*3e3b1fb0SAndrzej Pietrasiewicz static inline void merge_probs_variant_a(u8 *p, const u32 *c, u16 count_sat, u32 update_factor)
1586*3e3b1fb0SAndrzej Pietrasiewicz {
1587*3e3b1fb0SAndrzej Pietrasiewicz p[1] = merge_prob(p[1], c[0], c[1] + c[2], count_sat, update_factor);
1588*3e3b1fb0SAndrzej Pietrasiewicz p[2] = merge_prob(p[2], c[1], c[2], count_sat, update_factor);
1589*3e3b1fb0SAndrzej Pietrasiewicz }
1590*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_b(u8 * p,const u32 * c,u16 count_sat,u32 update_factor)1591*3e3b1fb0SAndrzej Pietrasiewicz static inline void merge_probs_variant_b(u8 *p, const u32 *c, u16 count_sat, u32 update_factor)
1592*3e3b1fb0SAndrzej Pietrasiewicz {
1593*3e3b1fb0SAndrzej Pietrasiewicz p[0] = merge_prob(p[0], c[0], c[1], count_sat, update_factor);
1594*3e3b1fb0SAndrzej Pietrasiewicz }
1595*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_c(u8 * p,const u32 * c)1596*3e3b1fb0SAndrzej Pietrasiewicz static inline void merge_probs_variant_c(u8 *p, const u32 *c)
1597*3e3b1fb0SAndrzej Pietrasiewicz {
1598*3e3b1fb0SAndrzej Pietrasiewicz p[0] = noncoef_merge_prob(p[0], c[2], c[1] + c[0] + c[3]);
1599*3e3b1fb0SAndrzej Pietrasiewicz p[1] = noncoef_merge_prob(p[1], c[0], c[1] + c[3]);
1600*3e3b1fb0SAndrzej Pietrasiewicz p[2] = noncoef_merge_prob(p[2], c[1], c[3]);
1601*3e3b1fb0SAndrzej Pietrasiewicz }
1602*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_d(u8 * p,const u32 * c)1603*3e3b1fb0SAndrzej Pietrasiewicz static void merge_probs_variant_d(u8 *p, const u32 *c)
1604*3e3b1fb0SAndrzej Pietrasiewicz {
1605*3e3b1fb0SAndrzej Pietrasiewicz u32 sum = 0, s2;
1606*3e3b1fb0SAndrzej Pietrasiewicz
1607*3e3b1fb0SAndrzej Pietrasiewicz sum = c[1] + c[2] + c[3] + c[4] + c[5] + c[6] + c[7] + c[8] + c[9];
1608*3e3b1fb0SAndrzej Pietrasiewicz
1609*3e3b1fb0SAndrzej Pietrasiewicz p[0] = noncoef_merge_prob(p[0], c[0], sum);
1610*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[9];
1611*3e3b1fb0SAndrzej Pietrasiewicz p[1] = noncoef_merge_prob(p[1], c[9], sum);
1612*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[1];
1613*3e3b1fb0SAndrzej Pietrasiewicz p[2] = noncoef_merge_prob(p[2], c[1], sum);
1614*3e3b1fb0SAndrzej Pietrasiewicz s2 = c[2] + c[4] + c[5];
1615*3e3b1fb0SAndrzej Pietrasiewicz sum -= s2;
1616*3e3b1fb0SAndrzej Pietrasiewicz p[3] = noncoef_merge_prob(p[3], s2, sum);
1617*3e3b1fb0SAndrzej Pietrasiewicz s2 -= c[2];
1618*3e3b1fb0SAndrzej Pietrasiewicz p[4] = noncoef_merge_prob(p[4], c[2], s2);
1619*3e3b1fb0SAndrzej Pietrasiewicz p[5] = noncoef_merge_prob(p[5], c[4], c[5]);
1620*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[3];
1621*3e3b1fb0SAndrzej Pietrasiewicz p[6] = noncoef_merge_prob(p[6], c[3], sum);
1622*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[8];
1623*3e3b1fb0SAndrzej Pietrasiewicz p[7] = noncoef_merge_prob(p[7], c[8], sum);
1624*3e3b1fb0SAndrzej Pietrasiewicz p[8] = noncoef_merge_prob(p[8], c[6], c[7]);
1625*3e3b1fb0SAndrzej Pietrasiewicz }
1626*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_e(u8 * p,const u32 * c)1627*3e3b1fb0SAndrzej Pietrasiewicz static inline void merge_probs_variant_e(u8 *p, const u32 *c)
1628*3e3b1fb0SAndrzej Pietrasiewicz {
1629*3e3b1fb0SAndrzej Pietrasiewicz p[0] = noncoef_merge_prob(p[0], c[0], c[1] + c[2] + c[3]);
1630*3e3b1fb0SAndrzej Pietrasiewicz p[1] = noncoef_merge_prob(p[1], c[1], c[2] + c[3]);
1631*3e3b1fb0SAndrzej Pietrasiewicz p[2] = noncoef_merge_prob(p[2], c[2], c[3]);
1632*3e3b1fb0SAndrzej Pietrasiewicz }
1633*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_f(u8 * p,const u32 * c)1634*3e3b1fb0SAndrzej Pietrasiewicz static inline void merge_probs_variant_f(u8 *p, const u32 *c)
1635*3e3b1fb0SAndrzej Pietrasiewicz {
1636*3e3b1fb0SAndrzej Pietrasiewicz p[0] = noncoef_merge_prob(p[0], c[0], c[1] + c[2]);
1637*3e3b1fb0SAndrzej Pietrasiewicz p[1] = noncoef_merge_prob(p[1], c[1], c[2]);
1638*3e3b1fb0SAndrzej Pietrasiewicz }
1639*3e3b1fb0SAndrzej Pietrasiewicz
merge_probs_variant_g(u8 * p,const u32 * c)1640*3e3b1fb0SAndrzej Pietrasiewicz static void merge_probs_variant_g(u8 *p, const u32 *c)
1641*3e3b1fb0SAndrzej Pietrasiewicz {
1642*3e3b1fb0SAndrzej Pietrasiewicz u32 sum;
1643*3e3b1fb0SAndrzej Pietrasiewicz
1644*3e3b1fb0SAndrzej Pietrasiewicz sum = c[1] + c[2] + c[3] + c[4] + c[5] + c[6] + c[7] + c[8] + c[9] + c[10];
1645*3e3b1fb0SAndrzej Pietrasiewicz p[0] = noncoef_merge_prob(p[0], c[0], sum);
1646*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[1];
1647*3e3b1fb0SAndrzej Pietrasiewicz p[1] = noncoef_merge_prob(p[1], c[1], sum);
1648*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[2] + c[3];
1649*3e3b1fb0SAndrzej Pietrasiewicz p[2] = noncoef_merge_prob(p[2], c[2] + c[3], sum);
1650*3e3b1fb0SAndrzej Pietrasiewicz p[3] = noncoef_merge_prob(p[3], c[2], c[3]);
1651*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[4] + c[5];
1652*3e3b1fb0SAndrzej Pietrasiewicz p[4] = noncoef_merge_prob(p[4], c[4] + c[5], sum);
1653*3e3b1fb0SAndrzej Pietrasiewicz p[5] = noncoef_merge_prob(p[5], c[4], c[5]);
1654*3e3b1fb0SAndrzej Pietrasiewicz sum -= c[6];
1655*3e3b1fb0SAndrzej Pietrasiewicz p[6] = noncoef_merge_prob(p[6], c[6], sum);
1656*3e3b1fb0SAndrzej Pietrasiewicz p[7] = noncoef_merge_prob(p[7], c[7] + c[8], c[9] + c[10]);
1657*3e3b1fb0SAndrzej Pietrasiewicz p[8] = noncoef_merge_prob(p[8], c[7], c[8]);
1658*3e3b1fb0SAndrzej Pietrasiewicz p[9] = noncoef_merge_prob(p[9], c[9], c[10]);
1659*3e3b1fb0SAndrzej Pietrasiewicz }
1660*3e3b1fb0SAndrzej Pietrasiewicz
1661*3e3b1fb0SAndrzej Pietrasiewicz /* 8.4.3 Coefficient probability adaptation process */
adapt_probs_variant_a_coef(u8 * p,const u32 * c,u32 update_factor)1662*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_a_coef(u8 *p, const u32 *c, u32 update_factor)
1663*3e3b1fb0SAndrzej Pietrasiewicz {
1664*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_a(p, c, 24, update_factor);
1665*3e3b1fb0SAndrzej Pietrasiewicz }
1666*3e3b1fb0SAndrzej Pietrasiewicz
adapt_probs_variant_b_coef(u8 * p,const u32 * c,u32 update_factor)1667*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_b_coef(u8 *p, const u32 *c, u32 update_factor)
1668*3e3b1fb0SAndrzej Pietrasiewicz {
1669*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_b(p, c, 24, update_factor);
1670*3e3b1fb0SAndrzej Pietrasiewicz }
1671*3e3b1fb0SAndrzej Pietrasiewicz
_adapt_coeff(unsigned int i,unsigned int j,unsigned int k,struct v4l2_vp9_frame_context * probs,const struct v4l2_vp9_frame_symbol_counts * counts,u32 uf)1672*3e3b1fb0SAndrzej Pietrasiewicz static void _adapt_coeff(unsigned int i, unsigned int j, unsigned int k,
1673*3e3b1fb0SAndrzej Pietrasiewicz struct v4l2_vp9_frame_context *probs,
1674*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_vp9_frame_symbol_counts *counts,
1675*3e3b1fb0SAndrzej Pietrasiewicz u32 uf)
1676*3e3b1fb0SAndrzej Pietrasiewicz {
1677*3e3b1fb0SAndrzej Pietrasiewicz s32 l, m;
1678*3e3b1fb0SAndrzej Pietrasiewicz
1679*3e3b1fb0SAndrzej Pietrasiewicz for (l = 0; l < ARRAY_SIZE(probs->coef[0][0][0]); l++) {
1680*3e3b1fb0SAndrzej Pietrasiewicz for (m = 0; m < BAND_6(l); m++) {
1681*3e3b1fb0SAndrzej Pietrasiewicz u8 *p = probs->coef[i][j][k][l][m];
1682*3e3b1fb0SAndrzej Pietrasiewicz const u32 counts_more_coefs[2] = {
1683*3e3b1fb0SAndrzej Pietrasiewicz *counts->eob[i][j][k][l][m][1],
1684*3e3b1fb0SAndrzej Pietrasiewicz *counts->eob[i][j][k][l][m][0] - *counts->eob[i][j][k][l][m][1],
1685*3e3b1fb0SAndrzej Pietrasiewicz };
1686*3e3b1fb0SAndrzej Pietrasiewicz
1687*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_a_coef(p, *counts->coeff[i][j][k][l][m], uf);
1688*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_b_coef(p, counts_more_coefs, uf);
1689*3e3b1fb0SAndrzej Pietrasiewicz }
1690*3e3b1fb0SAndrzej Pietrasiewicz }
1691*3e3b1fb0SAndrzej Pietrasiewicz }
1692*3e3b1fb0SAndrzej Pietrasiewicz
_adapt_coef_probs(struct v4l2_vp9_frame_context * probs,const struct v4l2_vp9_frame_symbol_counts * counts,unsigned int uf)1693*3e3b1fb0SAndrzej Pietrasiewicz static void _adapt_coef_probs(struct v4l2_vp9_frame_context *probs,
1694*3e3b1fb0SAndrzej Pietrasiewicz const struct v4l2_vp9_frame_symbol_counts *counts,
1695*3e3b1fb0SAndrzej Pietrasiewicz unsigned int uf)
1696*3e3b1fb0SAndrzej Pietrasiewicz {
1697*3e3b1fb0SAndrzej Pietrasiewicz unsigned int i, j, k;
1698*3e3b1fb0SAndrzej Pietrasiewicz
1699*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->coef); i++)
1700*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->coef[0]); j++)
1701*3e3b1fb0SAndrzej Pietrasiewicz for (k = 0; k < ARRAY_SIZE(probs->coef[0][0]); k++)
1702*3e3b1fb0SAndrzej Pietrasiewicz _adapt_coeff(i, j, k, probs, counts, uf);
1703*3e3b1fb0SAndrzej Pietrasiewicz }
1704*3e3b1fb0SAndrzej Pietrasiewicz
v4l2_vp9_adapt_coef_probs(struct v4l2_vp9_frame_context * probs,struct v4l2_vp9_frame_symbol_counts * counts,bool use_128,bool frame_is_intra)1705*3e3b1fb0SAndrzej Pietrasiewicz void v4l2_vp9_adapt_coef_probs(struct v4l2_vp9_frame_context *probs,
1706*3e3b1fb0SAndrzej Pietrasiewicz struct v4l2_vp9_frame_symbol_counts *counts,
1707*3e3b1fb0SAndrzej Pietrasiewicz bool use_128,
1708*3e3b1fb0SAndrzej Pietrasiewicz bool frame_is_intra)
1709*3e3b1fb0SAndrzej Pietrasiewicz {
1710*3e3b1fb0SAndrzej Pietrasiewicz if (frame_is_intra) {
1711*3e3b1fb0SAndrzej Pietrasiewicz _adapt_coef_probs(probs, counts, 112);
1712*3e3b1fb0SAndrzej Pietrasiewicz } else {
1713*3e3b1fb0SAndrzej Pietrasiewicz if (use_128)
1714*3e3b1fb0SAndrzej Pietrasiewicz _adapt_coef_probs(probs, counts, 128);
1715*3e3b1fb0SAndrzej Pietrasiewicz else
1716*3e3b1fb0SAndrzej Pietrasiewicz _adapt_coef_probs(probs, counts, 112);
1717*3e3b1fb0SAndrzej Pietrasiewicz }
1718*3e3b1fb0SAndrzej Pietrasiewicz }
1719*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_adapt_coef_probs);
1720*3e3b1fb0SAndrzej Pietrasiewicz
1721*3e3b1fb0SAndrzej Pietrasiewicz /* 8.4.4 Non coefficient probability adaptation process, adapt_probs() */
adapt_probs_variant_b(u8 * p,const u32 * c)1722*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_b(u8 *p, const u32 *c)
1723*3e3b1fb0SAndrzej Pietrasiewicz {
1724*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_b(p, c, 20, 128);
1725*3e3b1fb0SAndrzej Pietrasiewicz }
1726*3e3b1fb0SAndrzej Pietrasiewicz
adapt_probs_variant_c(u8 * p,const u32 * c)1727*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_c(u8 *p, const u32 *c)
1728*3e3b1fb0SAndrzej Pietrasiewicz {
1729*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_c(p, c);
1730*3e3b1fb0SAndrzej Pietrasiewicz }
1731*3e3b1fb0SAndrzej Pietrasiewicz
adapt_probs_variant_d(u8 * p,const u32 * c)1732*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_d(u8 *p, const u32 *c)
1733*3e3b1fb0SAndrzej Pietrasiewicz {
1734*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_d(p, c);
1735*3e3b1fb0SAndrzej Pietrasiewicz }
1736*3e3b1fb0SAndrzej Pietrasiewicz
adapt_probs_variant_e(u8 * p,const u32 * c)1737*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_e(u8 *p, const u32 *c)
1738*3e3b1fb0SAndrzej Pietrasiewicz {
1739*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_e(p, c);
1740*3e3b1fb0SAndrzej Pietrasiewicz }
1741*3e3b1fb0SAndrzej Pietrasiewicz
adapt_probs_variant_f(u8 * p,const u32 * c)1742*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_f(u8 *p, const u32 *c)
1743*3e3b1fb0SAndrzej Pietrasiewicz {
1744*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_f(p, c);
1745*3e3b1fb0SAndrzej Pietrasiewicz }
1746*3e3b1fb0SAndrzej Pietrasiewicz
adapt_probs_variant_g(u8 * p,const u32 * c)1747*3e3b1fb0SAndrzej Pietrasiewicz static inline void adapt_probs_variant_g(u8 *p, const u32 *c)
1748*3e3b1fb0SAndrzej Pietrasiewicz {
1749*3e3b1fb0SAndrzej Pietrasiewicz merge_probs_variant_g(p, c);
1750*3e3b1fb0SAndrzej Pietrasiewicz }
1751*3e3b1fb0SAndrzej Pietrasiewicz
1752*3e3b1fb0SAndrzej Pietrasiewicz /* 8.4.4 Non coefficient probability adaptation process, adapt_prob() */
adapt_prob(u8 prob,const u32 counts[2])1753*3e3b1fb0SAndrzej Pietrasiewicz static inline u8 adapt_prob(u8 prob, const u32 counts[2])
1754*3e3b1fb0SAndrzej Pietrasiewicz {
1755*3e3b1fb0SAndrzej Pietrasiewicz return noncoef_merge_prob(prob, counts[0], counts[1]);
1756*3e3b1fb0SAndrzej Pietrasiewicz }
1757*3e3b1fb0SAndrzej Pietrasiewicz
1758*3e3b1fb0SAndrzej Pietrasiewicz /* 8.4.4 Non coefficient probability adaptation process */
v4l2_vp9_adapt_noncoef_probs(struct v4l2_vp9_frame_context * probs,struct v4l2_vp9_frame_symbol_counts * counts,u8 reference_mode,u8 interpolation_filter,u8 tx_mode,u32 flags)1759*3e3b1fb0SAndrzej Pietrasiewicz void v4l2_vp9_adapt_noncoef_probs(struct v4l2_vp9_frame_context *probs,
1760*3e3b1fb0SAndrzej Pietrasiewicz struct v4l2_vp9_frame_symbol_counts *counts,
1761*3e3b1fb0SAndrzej Pietrasiewicz u8 reference_mode, u8 interpolation_filter, u8 tx_mode,
1762*3e3b1fb0SAndrzej Pietrasiewicz u32 flags)
1763*3e3b1fb0SAndrzej Pietrasiewicz {
1764*3e3b1fb0SAndrzej Pietrasiewicz unsigned int i, j;
1765*3e3b1fb0SAndrzej Pietrasiewicz
1766*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->is_inter); i++)
1767*3e3b1fb0SAndrzej Pietrasiewicz probs->is_inter[i] = adapt_prob(probs->is_inter[i], (*counts->intra_inter)[i]);
1768*3e3b1fb0SAndrzej Pietrasiewicz
1769*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->comp_mode); i++)
1770*3e3b1fb0SAndrzej Pietrasiewicz probs->comp_mode[i] = adapt_prob(probs->comp_mode[i], (*counts->comp)[i]);
1771*3e3b1fb0SAndrzej Pietrasiewicz
1772*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->comp_ref); i++)
1773*3e3b1fb0SAndrzej Pietrasiewicz probs->comp_ref[i] = adapt_prob(probs->comp_ref[i], (*counts->comp_ref)[i]);
1774*3e3b1fb0SAndrzej Pietrasiewicz
1775*3e3b1fb0SAndrzej Pietrasiewicz if (reference_mode != V4L2_VP9_REFERENCE_MODE_COMPOUND_REFERENCE)
1776*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->single_ref); i++)
1777*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->single_ref[0]); j++)
1778*3e3b1fb0SAndrzej Pietrasiewicz probs->single_ref[i][j] = adapt_prob(probs->single_ref[i][j],
1779*3e3b1fb0SAndrzej Pietrasiewicz (*counts->single_ref)[i][j]);
1780*3e3b1fb0SAndrzej Pietrasiewicz
1781*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->inter_mode); i++)
1782*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_c(probs->inter_mode[i], (*counts->mv_mode)[i]);
1783*3e3b1fb0SAndrzej Pietrasiewicz
1784*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->y_mode); i++)
1785*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_d(probs->y_mode[i], (*counts->y_mode)[i]);
1786*3e3b1fb0SAndrzej Pietrasiewicz
1787*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->uv_mode); i++)
1788*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_d(probs->uv_mode[i], (*counts->uv_mode)[i]);
1789*3e3b1fb0SAndrzej Pietrasiewicz
1790*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->partition); i++)
1791*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_e(probs->partition[i], (*counts->partition)[i]);
1792*3e3b1fb0SAndrzej Pietrasiewicz
1793*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->skip); i++)
1794*3e3b1fb0SAndrzej Pietrasiewicz probs->skip[i] = adapt_prob(probs->skip[i], (*counts->skip)[i]);
1795*3e3b1fb0SAndrzej Pietrasiewicz
1796*3e3b1fb0SAndrzej Pietrasiewicz if (interpolation_filter == V4L2_VP9_INTERP_FILTER_SWITCHABLE)
1797*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->interp_filter); i++)
1798*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_f(probs->interp_filter[i], (*counts->filter)[i]);
1799*3e3b1fb0SAndrzej Pietrasiewicz
1800*3e3b1fb0SAndrzej Pietrasiewicz if (tx_mode == V4L2_VP9_TX_MODE_SELECT)
1801*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->tx8); i++) {
1802*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_b(probs->tx8[i], (*counts->tx8p)[i]);
1803*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_f(probs->tx16[i], (*counts->tx16p)[i]);
1804*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_e(probs->tx32[i], (*counts->tx32p)[i]);
1805*3e3b1fb0SAndrzej Pietrasiewicz }
1806*3e3b1fb0SAndrzej Pietrasiewicz
1807*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_e(probs->mv.joint, *counts->mv_joint);
1808*3e3b1fb0SAndrzej Pietrasiewicz
1809*3e3b1fb0SAndrzej Pietrasiewicz for (i = 0; i < ARRAY_SIZE(probs->mv.sign); i++) {
1810*3e3b1fb0SAndrzej Pietrasiewicz probs->mv.sign[i] = adapt_prob(probs->mv.sign[i], (*counts->sign)[i]);
1811*3e3b1fb0SAndrzej Pietrasiewicz
1812*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_g(probs->mv.classes[i], (*counts->classes)[i]);
1813*3e3b1fb0SAndrzej Pietrasiewicz
1814*3e3b1fb0SAndrzej Pietrasiewicz probs->mv.class0_bit[i] = adapt_prob(probs->mv.class0_bit[i], (*counts->class0)[i]);
1815*3e3b1fb0SAndrzej Pietrasiewicz
1816*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->mv.bits[0]); j++)
1817*3e3b1fb0SAndrzej Pietrasiewicz probs->mv.bits[i][j] = adapt_prob(probs->mv.bits[i][j],
1818*3e3b1fb0SAndrzej Pietrasiewicz (*counts->bits)[i][j]);
1819*3e3b1fb0SAndrzej Pietrasiewicz
1820*3e3b1fb0SAndrzej Pietrasiewicz for (j = 0; j < ARRAY_SIZE(probs->mv.class0_fr[0]); j++)
1821*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_e(probs->mv.class0_fr[i][j],
1822*3e3b1fb0SAndrzej Pietrasiewicz (*counts->class0_fp)[i][j]);
1823*3e3b1fb0SAndrzej Pietrasiewicz
1824*3e3b1fb0SAndrzej Pietrasiewicz adapt_probs_variant_e(probs->mv.fr[i], (*counts->fp)[i]);
1825*3e3b1fb0SAndrzej Pietrasiewicz
1826*3e3b1fb0SAndrzej Pietrasiewicz if (!(flags & V4L2_VP9_FRAME_FLAG_ALLOW_HIGH_PREC_MV))
1827*3e3b1fb0SAndrzej Pietrasiewicz continue;
1828*3e3b1fb0SAndrzej Pietrasiewicz
1829*3e3b1fb0SAndrzej Pietrasiewicz probs->mv.class0_hp[i] = adapt_prob(probs->mv.class0_hp[i],
1830*3e3b1fb0SAndrzej Pietrasiewicz (*counts->class0_hp)[i]);
1831*3e3b1fb0SAndrzej Pietrasiewicz
1832*3e3b1fb0SAndrzej Pietrasiewicz probs->mv.hp[i] = adapt_prob(probs->mv.hp[i], (*counts->hp)[i]);
1833*3e3b1fb0SAndrzej Pietrasiewicz }
1834*3e3b1fb0SAndrzej Pietrasiewicz }
1835*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_adapt_noncoef_probs);
1836*3e3b1fb0SAndrzej Pietrasiewicz
1837*3e3b1fb0SAndrzej Pietrasiewicz bool
v4l2_vp9_seg_feat_enabled(const u8 * feature_enabled,unsigned int feature,unsigned int segid)1838*3e3b1fb0SAndrzej Pietrasiewicz v4l2_vp9_seg_feat_enabled(const u8 *feature_enabled,
1839*3e3b1fb0SAndrzej Pietrasiewicz unsigned int feature,
1840*3e3b1fb0SAndrzej Pietrasiewicz unsigned int segid)
1841*3e3b1fb0SAndrzej Pietrasiewicz {
1842*3e3b1fb0SAndrzej Pietrasiewicz u8 mask = V4L2_VP9_SEGMENT_FEATURE_ENABLED(feature);
1843*3e3b1fb0SAndrzej Pietrasiewicz
1844*3e3b1fb0SAndrzej Pietrasiewicz return !!(feature_enabled[segid] & mask);
1845*3e3b1fb0SAndrzej Pietrasiewicz }
1846*3e3b1fb0SAndrzej Pietrasiewicz EXPORT_SYMBOL_GPL(v4l2_vp9_seg_feat_enabled);
1847*3e3b1fb0SAndrzej Pietrasiewicz
1848*3e3b1fb0SAndrzej Pietrasiewicz MODULE_LICENSE("GPL");
1849*3e3b1fb0SAndrzej Pietrasiewicz MODULE_DESCRIPTION("V4L2 VP9 Helpers");
1850*3e3b1fb0SAndrzej Pietrasiewicz MODULE_AUTHOR("Andrzej Pietrasiewicz <andrzej.p@collabora.com>");
1851