1*c83a76b0SSuyog Pawar /******************************************************************************
2*c83a76b0SSuyog Pawar *
3*c83a76b0SSuyog Pawar * Copyright (C) 2012 Ittiam Systems Pvt Ltd, Bangalore
4*c83a76b0SSuyog Pawar *
5*c83a76b0SSuyog Pawar * Licensed under the Apache License, Version 2.0 (the "License");
6*c83a76b0SSuyog Pawar * you may not use this file except in compliance with the License.
7*c83a76b0SSuyog Pawar * You may obtain a copy of the License at:
8*c83a76b0SSuyog Pawar *
9*c83a76b0SSuyog Pawar * http://www.apache.org/licenses/LICENSE-2.0
10*c83a76b0SSuyog Pawar *
11*c83a76b0SSuyog Pawar * Unless required by applicable law or agreed to in writing, software
12*c83a76b0SSuyog Pawar * distributed under the License is distributed on an "AS IS" BASIS,
13*c83a76b0SSuyog Pawar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*c83a76b0SSuyog Pawar * See the License for the specific language governing permissions and
15*c83a76b0SSuyog Pawar * limitations under the License.
16*c83a76b0SSuyog Pawar *
17*c83a76b0SSuyog Pawar ******************************************************************************/
18*c83a76b0SSuyog Pawar /**
19*c83a76b0SSuyog Pawar *******************************************************************************
20*c83a76b0SSuyog Pawar * @file
21*c83a76b0SSuyog Pawar * ihevc_iquant_recon.c
22*c83a76b0SSuyog Pawar *
23*c83a76b0SSuyog Pawar * @brief
24*c83a76b0SSuyog Pawar * Contains function definitions for inverse quantization and
25*c83a76b0SSuyog Pawar * reconstruction
26*c83a76b0SSuyog Pawar *
27*c83a76b0SSuyog Pawar * @author
28*c83a76b0SSuyog Pawar * 100470
29*c83a76b0SSuyog Pawar *
30*c83a76b0SSuyog Pawar * @par List of Functions:
31*c83a76b0SSuyog Pawar * - ihevc_iquant_recon_4x4_ttype1()
32*c83a76b0SSuyog Pawar * - ihevc_iquant_recon_4x4()
33*c83a76b0SSuyog Pawar * - ihevc_iquant_recon_8x8()
34*c83a76b0SSuyog Pawar * - ihevc_iquant_recon_16x16()
35*c83a76b0SSuyog Pawar * - ihevc_iquant_recon_32x32()
36*c83a76b0SSuyog Pawar *
37*c83a76b0SSuyog Pawar * @remarks
38*c83a76b0SSuyog Pawar * None
39*c83a76b0SSuyog Pawar *
40*c83a76b0SSuyog Pawar *******************************************************************************
41*c83a76b0SSuyog Pawar */
42*c83a76b0SSuyog Pawar #include <stdio.h>
43*c83a76b0SSuyog Pawar #include <string.h>
44*c83a76b0SSuyog Pawar #include "ihevc_typedefs.h"
45*c83a76b0SSuyog Pawar #include "ihevc_macros.h"
46*c83a76b0SSuyog Pawar #include "ihevc_platform_macros.h"
47*c83a76b0SSuyog Pawar #include "ihevc_defs.h"
48*c83a76b0SSuyog Pawar #include "ihevc_trans_tables.h"
49*c83a76b0SSuyog Pawar #include "ihevc_iquant_recon.h"
50*c83a76b0SSuyog Pawar #include "ihevc_func_selector.h"
51*c83a76b0SSuyog Pawar #include "ihevc_trans_macros.h"
52*c83a76b0SSuyog Pawar
53*c83a76b0SSuyog Pawar /* All the functions here are replicated from ihevc_iquant_itrans_recon.c and modified to */
54*c83a76b0SSuyog Pawar /* include reconstruction */
55*c83a76b0SSuyog Pawar
56*c83a76b0SSuyog Pawar /**
57*c83a76b0SSuyog Pawar *******************************************************************************
58*c83a76b0SSuyog Pawar *
59*c83a76b0SSuyog Pawar * @brief
60*c83a76b0SSuyog Pawar * This function performs inverse quantization type 1 and reconstruction
61*c83a76b0SSuyog Pawar * for 4x4 input block
62*c83a76b0SSuyog Pawar *
63*c83a76b0SSuyog Pawar * @par Description:
64*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 4x4
65*c83a76b0SSuyog Pawar * input block
66*c83a76b0SSuyog Pawar *
67*c83a76b0SSuyog Pawar * @param[in] pi2_src
68*c83a76b0SSuyog Pawar * Input 4x4 coefficients
69*c83a76b0SSuyog Pawar *
70*c83a76b0SSuyog Pawar * @param[in] pu1_pred
71*c83a76b0SSuyog Pawar * Prediction 4x4 block
72*c83a76b0SSuyog Pawar *
73*c83a76b0SSuyog Pawar * @param[in] pi2_dequant_coeff
74*c83a76b0SSuyog Pawar * Dequant Coeffs
75*c83a76b0SSuyog Pawar *
76*c83a76b0SSuyog Pawar * @param[out] pu1_dst
77*c83a76b0SSuyog Pawar * Output 4x4 block
78*c83a76b0SSuyog Pawar *
79*c83a76b0SSuyog Pawar * @param[in] qp_div
80*c83a76b0SSuyog Pawar * Quantization parameter / 6
81*c83a76b0SSuyog Pawar *
82*c83a76b0SSuyog Pawar * @param[in] qp_rem
83*c83a76b0SSuyog Pawar * Quantization parameter % 6
84*c83a76b0SSuyog Pawar *
85*c83a76b0SSuyog Pawar * @param[in] src_strd
86*c83a76b0SSuyog Pawar * Input stride
87*c83a76b0SSuyog Pawar *
88*c83a76b0SSuyog Pawar * @param[in] pred_strd
89*c83a76b0SSuyog Pawar * Prediction stride
90*c83a76b0SSuyog Pawar *
91*c83a76b0SSuyog Pawar * @param[in] dst_strd
92*c83a76b0SSuyog Pawar * Output Stride
93*c83a76b0SSuyog Pawar *
94*c83a76b0SSuyog Pawar * @param[in] zero_cols
95*c83a76b0SSuyog Pawar * Zero columns in pi2_src
96*c83a76b0SSuyog Pawar *
97*c83a76b0SSuyog Pawar * @returns Void
98*c83a76b0SSuyog Pawar *
99*c83a76b0SSuyog Pawar * @remarks
100*c83a76b0SSuyog Pawar * None
101*c83a76b0SSuyog Pawar *
102*c83a76b0SSuyog Pawar *******************************************************************************
103*c83a76b0SSuyog Pawar */
104*c83a76b0SSuyog Pawar
ihevc_iquant_recon_4x4_ttype1(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)105*c83a76b0SSuyog Pawar void ihevc_iquant_recon_4x4_ttype1(WORD16 *pi2_src,
106*c83a76b0SSuyog Pawar UWORD8 *pu1_pred,
107*c83a76b0SSuyog Pawar WORD16 *pi2_dequant_coeff,
108*c83a76b0SSuyog Pawar UWORD8 *pu1_dst,
109*c83a76b0SSuyog Pawar WORD32 qp_div, /* qpscaled / 6 */
110*c83a76b0SSuyog Pawar WORD32 qp_rem, /* qpscaled % 6 */
111*c83a76b0SSuyog Pawar WORD32 src_strd,
112*c83a76b0SSuyog Pawar WORD32 pred_strd,
113*c83a76b0SSuyog Pawar WORD32 dst_strd,
114*c83a76b0SSuyog Pawar WORD32 zero_cols)
115*c83a76b0SSuyog Pawar {
116*c83a76b0SSuyog Pawar
117*c83a76b0SSuyog Pawar {
118*c83a76b0SSuyog Pawar /* Inverse Quant and recon */
119*c83a76b0SSuyog Pawar {
120*c83a76b0SSuyog Pawar WORD32 i, j;
121*c83a76b0SSuyog Pawar WORD32 shift_iq;
122*c83a76b0SSuyog Pawar WORD32 trans_size;
123*c83a76b0SSuyog Pawar /* Inverse Quantization constants */
124*c83a76b0SSuyog Pawar {
125*c83a76b0SSuyog Pawar WORD32 log2_trans_size, bit_depth;
126*c83a76b0SSuyog Pawar
127*c83a76b0SSuyog Pawar log2_trans_size = 2;
128*c83a76b0SSuyog Pawar bit_depth = 8 + 0;
129*c83a76b0SSuyog Pawar shift_iq = bit_depth + log2_trans_size - 5;
130*c83a76b0SSuyog Pawar }
131*c83a76b0SSuyog Pawar
132*c83a76b0SSuyog Pawar trans_size = TRANS_SIZE_4;
133*c83a76b0SSuyog Pawar
134*c83a76b0SSuyog Pawar for(i = 0; i < trans_size; i++)
135*c83a76b0SSuyog Pawar {
136*c83a76b0SSuyog Pawar /* Checking for Zero Cols */
137*c83a76b0SSuyog Pawar if((zero_cols & 1) == 1)
138*c83a76b0SSuyog Pawar {
139*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
140*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
141*c83a76b0SSuyog Pawar }
142*c83a76b0SSuyog Pawar else
143*c83a76b0SSuyog Pawar {
144*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
145*c83a76b0SSuyog Pawar {
146*c83a76b0SSuyog Pawar WORD32 iquant_out;
147*c83a76b0SSuyog Pawar IQUANT_4x4(iquant_out,
148*c83a76b0SSuyog Pawar pi2_src[j * src_strd],
149*c83a76b0SSuyog Pawar pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
150*c83a76b0SSuyog Pawar shift_iq, qp_div);
151*c83a76b0SSuyog Pawar
152*c83a76b0SSuyog Pawar iquant_out = (iquant_out + 16) >> 5;
153*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] =
154*c83a76b0SSuyog Pawar CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
155*c83a76b0SSuyog Pawar }
156*c83a76b0SSuyog Pawar }
157*c83a76b0SSuyog Pawar pi2_src++;
158*c83a76b0SSuyog Pawar pi2_dequant_coeff++;
159*c83a76b0SSuyog Pawar pu1_pred++;
160*c83a76b0SSuyog Pawar pu1_dst++;
161*c83a76b0SSuyog Pawar
162*c83a76b0SSuyog Pawar zero_cols = zero_cols >> 1;
163*c83a76b0SSuyog Pawar }
164*c83a76b0SSuyog Pawar }
165*c83a76b0SSuyog Pawar }
166*c83a76b0SSuyog Pawar }
167*c83a76b0SSuyog Pawar
168*c83a76b0SSuyog Pawar /**
169*c83a76b0SSuyog Pawar *******************************************************************************
170*c83a76b0SSuyog Pawar *
171*c83a76b0SSuyog Pawar * @brief
172*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 4x4
173*c83a76b0SSuyog Pawar * input block
174*c83a76b0SSuyog Pawar *
175*c83a76b0SSuyog Pawar * @par Description:
176*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 4x4
177*c83a76b0SSuyog Pawar * input block
178*c83a76b0SSuyog Pawar *
179*c83a76b0SSuyog Pawar * @param[in] pi2_src
180*c83a76b0SSuyog Pawar * Input 4x4 coefficients
181*c83a76b0SSuyog Pawar *
182*c83a76b0SSuyog Pawar * @param[in] pu1_pred
183*c83a76b0SSuyog Pawar * Prediction 4x4 block
184*c83a76b0SSuyog Pawar *
185*c83a76b0SSuyog Pawar * @param[in] pi2_dequant_coeff
186*c83a76b0SSuyog Pawar * Dequant Coeffs
187*c83a76b0SSuyog Pawar *
188*c83a76b0SSuyog Pawar * @param[out] pu1_dst
189*c83a76b0SSuyog Pawar * Output 4x4 block
190*c83a76b0SSuyog Pawar *
191*c83a76b0SSuyog Pawar * @param[in] qp_div
192*c83a76b0SSuyog Pawar * Quantization parameter / 6
193*c83a76b0SSuyog Pawar *
194*c83a76b0SSuyog Pawar * @param[in] qp_rem
195*c83a76b0SSuyog Pawar * Quantization parameter % 6
196*c83a76b0SSuyog Pawar *
197*c83a76b0SSuyog Pawar * @param[in] src_strd
198*c83a76b0SSuyog Pawar * Input stride
199*c83a76b0SSuyog Pawar *
200*c83a76b0SSuyog Pawar * @param[in] pred_strd
201*c83a76b0SSuyog Pawar * Prediction stride
202*c83a76b0SSuyog Pawar *
203*c83a76b0SSuyog Pawar * @param[in] dst_strd
204*c83a76b0SSuyog Pawar * Output Stride
205*c83a76b0SSuyog Pawar *
206*c83a76b0SSuyog Pawar * @param[in] zero_cols
207*c83a76b0SSuyog Pawar * Zero columns in pi2_src
208*c83a76b0SSuyog Pawar *
209*c83a76b0SSuyog Pawar * @returns Void
210*c83a76b0SSuyog Pawar *
211*c83a76b0SSuyog Pawar * @remarks
212*c83a76b0SSuyog Pawar * None
213*c83a76b0SSuyog Pawar *
214*c83a76b0SSuyog Pawar *******************************************************************************
215*c83a76b0SSuyog Pawar */
216*c83a76b0SSuyog Pawar
ihevc_iquant_recon_4x4(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)217*c83a76b0SSuyog Pawar void ihevc_iquant_recon_4x4(WORD16 *pi2_src,
218*c83a76b0SSuyog Pawar UWORD8 *pu1_pred,
219*c83a76b0SSuyog Pawar WORD16 *pi2_dequant_coeff,
220*c83a76b0SSuyog Pawar UWORD8 *pu1_dst,
221*c83a76b0SSuyog Pawar WORD32 qp_div, /* qpscaled / 6 */
222*c83a76b0SSuyog Pawar WORD32 qp_rem, /* qpscaled % 6 */
223*c83a76b0SSuyog Pawar WORD32 src_strd,
224*c83a76b0SSuyog Pawar WORD32 pred_strd,
225*c83a76b0SSuyog Pawar WORD32 dst_strd,
226*c83a76b0SSuyog Pawar WORD32 zero_cols)
227*c83a76b0SSuyog Pawar {
228*c83a76b0SSuyog Pawar
229*c83a76b0SSuyog Pawar {
230*c83a76b0SSuyog Pawar /* Inverse Quant and recon */
231*c83a76b0SSuyog Pawar {
232*c83a76b0SSuyog Pawar WORD32 i, j;
233*c83a76b0SSuyog Pawar WORD32 shift_iq;
234*c83a76b0SSuyog Pawar WORD32 trans_size;
235*c83a76b0SSuyog Pawar /* Inverse Quantization constants */
236*c83a76b0SSuyog Pawar {
237*c83a76b0SSuyog Pawar WORD32 log2_trans_size, bit_depth;
238*c83a76b0SSuyog Pawar
239*c83a76b0SSuyog Pawar log2_trans_size = 2;
240*c83a76b0SSuyog Pawar bit_depth = 8 + 0;
241*c83a76b0SSuyog Pawar shift_iq = bit_depth + log2_trans_size - 5;
242*c83a76b0SSuyog Pawar }
243*c83a76b0SSuyog Pawar
244*c83a76b0SSuyog Pawar trans_size = TRANS_SIZE_4;
245*c83a76b0SSuyog Pawar
246*c83a76b0SSuyog Pawar for(i = 0; i < trans_size; i++)
247*c83a76b0SSuyog Pawar {
248*c83a76b0SSuyog Pawar /* Checking for Zero Cols */
249*c83a76b0SSuyog Pawar if((zero_cols & 1) == 1)
250*c83a76b0SSuyog Pawar {
251*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
252*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
253*c83a76b0SSuyog Pawar }
254*c83a76b0SSuyog Pawar else
255*c83a76b0SSuyog Pawar {
256*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
257*c83a76b0SSuyog Pawar {
258*c83a76b0SSuyog Pawar WORD32 iquant_out;
259*c83a76b0SSuyog Pawar IQUANT_4x4(iquant_out,
260*c83a76b0SSuyog Pawar pi2_src[j * src_strd],
261*c83a76b0SSuyog Pawar pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
262*c83a76b0SSuyog Pawar shift_iq, qp_div);
263*c83a76b0SSuyog Pawar iquant_out = (iquant_out + 16) >> 5;
264*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] =
265*c83a76b0SSuyog Pawar CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
266*c83a76b0SSuyog Pawar }
267*c83a76b0SSuyog Pawar }
268*c83a76b0SSuyog Pawar pi2_src++;
269*c83a76b0SSuyog Pawar pi2_dequant_coeff++;
270*c83a76b0SSuyog Pawar pu1_pred++;
271*c83a76b0SSuyog Pawar pu1_dst++;
272*c83a76b0SSuyog Pawar
273*c83a76b0SSuyog Pawar zero_cols = zero_cols >> 1;
274*c83a76b0SSuyog Pawar }
275*c83a76b0SSuyog Pawar }
276*c83a76b0SSuyog Pawar }
277*c83a76b0SSuyog Pawar }
278*c83a76b0SSuyog Pawar
279*c83a76b0SSuyog Pawar /**
280*c83a76b0SSuyog Pawar *******************************************************************************
281*c83a76b0SSuyog Pawar *
282*c83a76b0SSuyog Pawar * @brief
283*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 8x8
284*c83a76b0SSuyog Pawar * input block
285*c83a76b0SSuyog Pawar *
286*c83a76b0SSuyog Pawar * @par Description:
287*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 8x8
288*c83a76b0SSuyog Pawar * input block
289*c83a76b0SSuyog Pawar *
290*c83a76b0SSuyog Pawar * @param[in] pi2_src
291*c83a76b0SSuyog Pawar * Input 8x8 coefficients
292*c83a76b0SSuyog Pawar *
293*c83a76b0SSuyog Pawar * @param[in] pu1_pred
294*c83a76b0SSuyog Pawar * Prediction 8x8 block
295*c83a76b0SSuyog Pawar *
296*c83a76b0SSuyog Pawar * @param[in] pi2_dequant_coeff
297*c83a76b0SSuyog Pawar * Dequant Coeffs
298*c83a76b0SSuyog Pawar *
299*c83a76b0SSuyog Pawar * @param[out] pu1_dst
300*c83a76b0SSuyog Pawar * Output 8x8 block
301*c83a76b0SSuyog Pawar *
302*c83a76b0SSuyog Pawar * @param[in] qp_div
303*c83a76b0SSuyog Pawar * Quantization parameter / 6
304*c83a76b0SSuyog Pawar *
305*c83a76b0SSuyog Pawar * @param[in] qp_rem
306*c83a76b0SSuyog Pawar * Quantization parameter % 6
307*c83a76b0SSuyog Pawar *
308*c83a76b0SSuyog Pawar * @param[in] src_strd
309*c83a76b0SSuyog Pawar * Input stride
310*c83a76b0SSuyog Pawar *
311*c83a76b0SSuyog Pawar * @param[in] pred_strd
312*c83a76b0SSuyog Pawar * Prediction stride
313*c83a76b0SSuyog Pawar *
314*c83a76b0SSuyog Pawar * @param[in] dst_strd
315*c83a76b0SSuyog Pawar * Output Stride
316*c83a76b0SSuyog Pawar *
317*c83a76b0SSuyog Pawar * @param[in] zero_cols
318*c83a76b0SSuyog Pawar * Zero columns in pi2_src
319*c83a76b0SSuyog Pawar *
320*c83a76b0SSuyog Pawar * @returns Void
321*c83a76b0SSuyog Pawar *
322*c83a76b0SSuyog Pawar * @remarks
323*c83a76b0SSuyog Pawar * None
324*c83a76b0SSuyog Pawar *
325*c83a76b0SSuyog Pawar *******************************************************************************
326*c83a76b0SSuyog Pawar */
327*c83a76b0SSuyog Pawar
ihevc_iquant_recon_8x8(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)328*c83a76b0SSuyog Pawar void ihevc_iquant_recon_8x8(WORD16 *pi2_src,
329*c83a76b0SSuyog Pawar UWORD8 *pu1_pred,
330*c83a76b0SSuyog Pawar WORD16 *pi2_dequant_coeff,
331*c83a76b0SSuyog Pawar UWORD8 *pu1_dst,
332*c83a76b0SSuyog Pawar WORD32 qp_div, /* qpscaled / 6 */
333*c83a76b0SSuyog Pawar WORD32 qp_rem, /* qpscaled % 6 */
334*c83a76b0SSuyog Pawar WORD32 src_strd,
335*c83a76b0SSuyog Pawar WORD32 pred_strd,
336*c83a76b0SSuyog Pawar WORD32 dst_strd,
337*c83a76b0SSuyog Pawar WORD32 zero_cols)
338*c83a76b0SSuyog Pawar {
339*c83a76b0SSuyog Pawar
340*c83a76b0SSuyog Pawar {
341*c83a76b0SSuyog Pawar /* Inverse Quant and recon */
342*c83a76b0SSuyog Pawar {
343*c83a76b0SSuyog Pawar WORD32 i, j;
344*c83a76b0SSuyog Pawar WORD32 shift_iq;
345*c83a76b0SSuyog Pawar WORD32 trans_size;
346*c83a76b0SSuyog Pawar /* Inverse Quantization constants */
347*c83a76b0SSuyog Pawar {
348*c83a76b0SSuyog Pawar WORD32 log2_trans_size, bit_depth;
349*c83a76b0SSuyog Pawar
350*c83a76b0SSuyog Pawar log2_trans_size = 3;
351*c83a76b0SSuyog Pawar bit_depth = 8 + 0;
352*c83a76b0SSuyog Pawar shift_iq = bit_depth + log2_trans_size - 5;
353*c83a76b0SSuyog Pawar }
354*c83a76b0SSuyog Pawar
355*c83a76b0SSuyog Pawar trans_size = TRANS_SIZE_8;
356*c83a76b0SSuyog Pawar
357*c83a76b0SSuyog Pawar for(i = 0; i < trans_size; i++)
358*c83a76b0SSuyog Pawar {
359*c83a76b0SSuyog Pawar /* Checking for Zero Cols */
360*c83a76b0SSuyog Pawar if((zero_cols & 1) == 1)
361*c83a76b0SSuyog Pawar {
362*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
363*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
364*c83a76b0SSuyog Pawar }
365*c83a76b0SSuyog Pawar else
366*c83a76b0SSuyog Pawar {
367*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
368*c83a76b0SSuyog Pawar {
369*c83a76b0SSuyog Pawar WORD32 iquant_out;
370*c83a76b0SSuyog Pawar IQUANT(iquant_out,
371*c83a76b0SSuyog Pawar pi2_src[j * src_strd],
372*c83a76b0SSuyog Pawar pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
373*c83a76b0SSuyog Pawar shift_iq, qp_div);
374*c83a76b0SSuyog Pawar iquant_out = (iquant_out + 16) >> 5;
375*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] =
376*c83a76b0SSuyog Pawar CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
377*c83a76b0SSuyog Pawar }
378*c83a76b0SSuyog Pawar }
379*c83a76b0SSuyog Pawar pi2_src++;
380*c83a76b0SSuyog Pawar pi2_dequant_coeff++;
381*c83a76b0SSuyog Pawar pu1_pred++;
382*c83a76b0SSuyog Pawar pu1_dst++;
383*c83a76b0SSuyog Pawar
384*c83a76b0SSuyog Pawar zero_cols = zero_cols >> 1;
385*c83a76b0SSuyog Pawar }
386*c83a76b0SSuyog Pawar }
387*c83a76b0SSuyog Pawar }
388*c83a76b0SSuyog Pawar }
389*c83a76b0SSuyog Pawar
390*c83a76b0SSuyog Pawar /**
391*c83a76b0SSuyog Pawar *******************************************************************************
392*c83a76b0SSuyog Pawar *
393*c83a76b0SSuyog Pawar * @brief
394*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 16x16
395*c83a76b0SSuyog Pawar * input block
396*c83a76b0SSuyog Pawar *
397*c83a76b0SSuyog Pawar * @par Description:
398*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 16x16
399*c83a76b0SSuyog Pawar * input block
400*c83a76b0SSuyog Pawar *
401*c83a76b0SSuyog Pawar * @param[in] pi2_src
402*c83a76b0SSuyog Pawar * Input 16x16 coefficients
403*c83a76b0SSuyog Pawar *
404*c83a76b0SSuyog Pawar * @param[in] pu1_pred
405*c83a76b0SSuyog Pawar * Prediction 16x16 block
406*c83a76b0SSuyog Pawar *
407*c83a76b0SSuyog Pawar * @param[in] pi2_dequant_coeff
408*c83a76b0SSuyog Pawar * Dequant Coeffs
409*c83a76b0SSuyog Pawar *
410*c83a76b0SSuyog Pawar * @param[out] pu1_dst
411*c83a76b0SSuyog Pawar * Output 16x16 block
412*c83a76b0SSuyog Pawar *
413*c83a76b0SSuyog Pawar * @param[in] qp_div
414*c83a76b0SSuyog Pawar * Quantization parameter / 6
415*c83a76b0SSuyog Pawar *
416*c83a76b0SSuyog Pawar * @param[in] qp_rem
417*c83a76b0SSuyog Pawar * Quantization parameter % 6
418*c83a76b0SSuyog Pawar *
419*c83a76b0SSuyog Pawar * @param[in] src_strd
420*c83a76b0SSuyog Pawar * Input stride
421*c83a76b0SSuyog Pawar *
422*c83a76b0SSuyog Pawar * @param[in] pred_strd
423*c83a76b0SSuyog Pawar * Prediction stride
424*c83a76b0SSuyog Pawar *
425*c83a76b0SSuyog Pawar * @param[in] dst_strd
426*c83a76b0SSuyog Pawar * Output Stride
427*c83a76b0SSuyog Pawar *
428*c83a76b0SSuyog Pawar * @param[in] zero_cols
429*c83a76b0SSuyog Pawar * Zero columns in pi2_src
430*c83a76b0SSuyog Pawar *
431*c83a76b0SSuyog Pawar * @returns Void
432*c83a76b0SSuyog Pawar *
433*c83a76b0SSuyog Pawar * @remarks
434*c83a76b0SSuyog Pawar * None
435*c83a76b0SSuyog Pawar *
436*c83a76b0SSuyog Pawar *******************************************************************************
437*c83a76b0SSuyog Pawar */
438*c83a76b0SSuyog Pawar
ihevc_iquant_recon_16x16(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)439*c83a76b0SSuyog Pawar void ihevc_iquant_recon_16x16(WORD16 *pi2_src,
440*c83a76b0SSuyog Pawar UWORD8 *pu1_pred,
441*c83a76b0SSuyog Pawar WORD16 *pi2_dequant_coeff,
442*c83a76b0SSuyog Pawar UWORD8 *pu1_dst,
443*c83a76b0SSuyog Pawar WORD32 qp_div, /* qpscaled / 6 */
444*c83a76b0SSuyog Pawar WORD32 qp_rem, /* qpscaled % 6 */
445*c83a76b0SSuyog Pawar WORD32 src_strd,
446*c83a76b0SSuyog Pawar WORD32 pred_strd,
447*c83a76b0SSuyog Pawar WORD32 dst_strd,
448*c83a76b0SSuyog Pawar WORD32 zero_cols)
449*c83a76b0SSuyog Pawar
450*c83a76b0SSuyog Pawar {
451*c83a76b0SSuyog Pawar
452*c83a76b0SSuyog Pawar {
453*c83a76b0SSuyog Pawar /* Inverse Quant and recon */
454*c83a76b0SSuyog Pawar {
455*c83a76b0SSuyog Pawar WORD32 i, j;
456*c83a76b0SSuyog Pawar WORD32 shift_iq;
457*c83a76b0SSuyog Pawar WORD32 trans_size;
458*c83a76b0SSuyog Pawar /* Inverse Quantization constants */
459*c83a76b0SSuyog Pawar {
460*c83a76b0SSuyog Pawar WORD32 log2_trans_size, bit_depth;
461*c83a76b0SSuyog Pawar
462*c83a76b0SSuyog Pawar log2_trans_size = 4;
463*c83a76b0SSuyog Pawar bit_depth = 8 + 0;
464*c83a76b0SSuyog Pawar shift_iq = bit_depth + log2_trans_size - 5;
465*c83a76b0SSuyog Pawar }
466*c83a76b0SSuyog Pawar
467*c83a76b0SSuyog Pawar trans_size = TRANS_SIZE_16;
468*c83a76b0SSuyog Pawar
469*c83a76b0SSuyog Pawar for(i = 0; i < trans_size; i++)
470*c83a76b0SSuyog Pawar {
471*c83a76b0SSuyog Pawar /* Checking for Zero Cols */
472*c83a76b0SSuyog Pawar if((zero_cols & 1) == 1)
473*c83a76b0SSuyog Pawar {
474*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
475*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
476*c83a76b0SSuyog Pawar }
477*c83a76b0SSuyog Pawar else
478*c83a76b0SSuyog Pawar {
479*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
480*c83a76b0SSuyog Pawar {
481*c83a76b0SSuyog Pawar WORD32 iquant_out;
482*c83a76b0SSuyog Pawar IQUANT(iquant_out,
483*c83a76b0SSuyog Pawar pi2_src[j * src_strd],
484*c83a76b0SSuyog Pawar pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
485*c83a76b0SSuyog Pawar shift_iq, qp_div);
486*c83a76b0SSuyog Pawar iquant_out = (iquant_out + 16) >> 5;
487*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] =
488*c83a76b0SSuyog Pawar CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
489*c83a76b0SSuyog Pawar }
490*c83a76b0SSuyog Pawar }
491*c83a76b0SSuyog Pawar pi2_src++;
492*c83a76b0SSuyog Pawar pi2_dequant_coeff++;
493*c83a76b0SSuyog Pawar pu1_pred++;
494*c83a76b0SSuyog Pawar pu1_dst++;
495*c83a76b0SSuyog Pawar
496*c83a76b0SSuyog Pawar zero_cols = zero_cols >> 1;
497*c83a76b0SSuyog Pawar }
498*c83a76b0SSuyog Pawar }
499*c83a76b0SSuyog Pawar }
500*c83a76b0SSuyog Pawar }
501*c83a76b0SSuyog Pawar
502*c83a76b0SSuyog Pawar /**
503*c83a76b0SSuyog Pawar *******************************************************************************
504*c83a76b0SSuyog Pawar *
505*c83a76b0SSuyog Pawar * @brief
506*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 32x32
507*c83a76b0SSuyog Pawar * input block
508*c83a76b0SSuyog Pawar *
509*c83a76b0SSuyog Pawar * @par Description:
510*c83a76b0SSuyog Pawar * This function performs inverse quantization and reconstruction for 32x32
511*c83a76b0SSuyog Pawar * input block
512*c83a76b0SSuyog Pawar *
513*c83a76b0SSuyog Pawar * @param[in] pi2_src
514*c83a76b0SSuyog Pawar * Input 32x32 coefficients
515*c83a76b0SSuyog Pawar *
516*c83a76b0SSuyog Pawar * @param[in] pu1_pred
517*c83a76b0SSuyog Pawar * Prediction 32x32 block
518*c83a76b0SSuyog Pawar *
519*c83a76b0SSuyog Pawar * @param[in] pi2_dequant_coeff
520*c83a76b0SSuyog Pawar * Dequant Coeffs
521*c83a76b0SSuyog Pawar *
522*c83a76b0SSuyog Pawar * @param[out] pu1_dst
523*c83a76b0SSuyog Pawar * Output 32x32 block
524*c83a76b0SSuyog Pawar *
525*c83a76b0SSuyog Pawar * @param[in] qp_div
526*c83a76b0SSuyog Pawar * Quantization parameter / 6
527*c83a76b0SSuyog Pawar *
528*c83a76b0SSuyog Pawar * @param[in] qp_rem
529*c83a76b0SSuyog Pawar * Quantization parameter % 6
530*c83a76b0SSuyog Pawar *
531*c83a76b0SSuyog Pawar * @param[in] src_strd
532*c83a76b0SSuyog Pawar * Input stride
533*c83a76b0SSuyog Pawar *
534*c83a76b0SSuyog Pawar * @param[in] pred_strd
535*c83a76b0SSuyog Pawar * Prediction stride
536*c83a76b0SSuyog Pawar *
537*c83a76b0SSuyog Pawar * @param[in] dst_strd
538*c83a76b0SSuyog Pawar * Output Stride
539*c83a76b0SSuyog Pawar *
540*c83a76b0SSuyog Pawar * @param[in] zero_cols
541*c83a76b0SSuyog Pawar * Zero columns in pi2_src
542*c83a76b0SSuyog Pawar *
543*c83a76b0SSuyog Pawar * @returns Void
544*c83a76b0SSuyog Pawar *
545*c83a76b0SSuyog Pawar * @remarks
546*c83a76b0SSuyog Pawar * None
547*c83a76b0SSuyog Pawar *
548*c83a76b0SSuyog Pawar *******************************************************************************
549*c83a76b0SSuyog Pawar */
550*c83a76b0SSuyog Pawar
ihevc_iquant_recon_32x32(WORD16 * pi2_src,UWORD8 * pu1_pred,WORD16 * pi2_dequant_coeff,UWORD8 * pu1_dst,WORD32 qp_div,WORD32 qp_rem,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)551*c83a76b0SSuyog Pawar void ihevc_iquant_recon_32x32(WORD16 *pi2_src,
552*c83a76b0SSuyog Pawar UWORD8 *pu1_pred,
553*c83a76b0SSuyog Pawar WORD16 *pi2_dequant_coeff,
554*c83a76b0SSuyog Pawar UWORD8 *pu1_dst,
555*c83a76b0SSuyog Pawar WORD32 qp_div, /* qpscaled / 6 */
556*c83a76b0SSuyog Pawar WORD32 qp_rem, /* qpscaled % 6 */
557*c83a76b0SSuyog Pawar WORD32 src_strd,
558*c83a76b0SSuyog Pawar WORD32 pred_strd,
559*c83a76b0SSuyog Pawar WORD32 dst_strd,
560*c83a76b0SSuyog Pawar WORD32 zero_cols)
561*c83a76b0SSuyog Pawar {
562*c83a76b0SSuyog Pawar
563*c83a76b0SSuyog Pawar {
564*c83a76b0SSuyog Pawar /* Inverse Quant and recon */
565*c83a76b0SSuyog Pawar {
566*c83a76b0SSuyog Pawar WORD32 i, j;
567*c83a76b0SSuyog Pawar WORD32 shift_iq;
568*c83a76b0SSuyog Pawar WORD32 trans_size;
569*c83a76b0SSuyog Pawar /* Inverse Quantization constants */
570*c83a76b0SSuyog Pawar {
571*c83a76b0SSuyog Pawar WORD32 log2_trans_size, bit_depth;
572*c83a76b0SSuyog Pawar
573*c83a76b0SSuyog Pawar log2_trans_size = 5;
574*c83a76b0SSuyog Pawar bit_depth = 8 + 0;
575*c83a76b0SSuyog Pawar shift_iq = bit_depth + log2_trans_size - 5;
576*c83a76b0SSuyog Pawar }
577*c83a76b0SSuyog Pawar
578*c83a76b0SSuyog Pawar trans_size = TRANS_SIZE_32;
579*c83a76b0SSuyog Pawar
580*c83a76b0SSuyog Pawar for(i = 0; i < trans_size; i++)
581*c83a76b0SSuyog Pawar {
582*c83a76b0SSuyog Pawar /* Checking for Zero Cols */
583*c83a76b0SSuyog Pawar if((zero_cols & 1) == 1)
584*c83a76b0SSuyog Pawar {
585*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
586*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
587*c83a76b0SSuyog Pawar }
588*c83a76b0SSuyog Pawar else
589*c83a76b0SSuyog Pawar {
590*c83a76b0SSuyog Pawar for(j = 0; j < trans_size; j++)
591*c83a76b0SSuyog Pawar {
592*c83a76b0SSuyog Pawar WORD32 iquant_out;
593*c83a76b0SSuyog Pawar IQUANT(iquant_out,
594*c83a76b0SSuyog Pawar pi2_src[j * src_strd],
595*c83a76b0SSuyog Pawar pi2_dequant_coeff[j * trans_size] * g_ihevc_iquant_scales[qp_rem],
596*c83a76b0SSuyog Pawar shift_iq, qp_div);
597*c83a76b0SSuyog Pawar iquant_out = (iquant_out + 16) >> 5;
598*c83a76b0SSuyog Pawar pu1_dst[j * dst_strd] =
599*c83a76b0SSuyog Pawar CLIP_U8(iquant_out + pu1_pred[j * pred_strd]);
600*c83a76b0SSuyog Pawar }
601*c83a76b0SSuyog Pawar }
602*c83a76b0SSuyog Pawar pi2_src++;
603*c83a76b0SSuyog Pawar pi2_dequant_coeff++;
604*c83a76b0SSuyog Pawar pu1_pred++;
605*c83a76b0SSuyog Pawar pu1_dst++;
606*c83a76b0SSuyog Pawar
607*c83a76b0SSuyog Pawar zero_cols = zero_cols >> 1;
608*c83a76b0SSuyog Pawar }
609*c83a76b0SSuyog Pawar }
610*c83a76b0SSuyog Pawar }
611*c83a76b0SSuyog Pawar }
612*c83a76b0SSuyog Pawar
613