xref: /aosp_15_r20/external/libhevc/common/ihevc_chroma_recon.c (revision c83a76b084498d55f252f48b2e3786804cdf24b7)
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_chroma_recon.c
22*c83a76b0SSuyog Pawar  *
23*c83a76b0SSuyog Pawar  * @brief
24*c83a76b0SSuyog Pawar  *  Functions definitions reconstruction  of chroma interleaved data.
25*c83a76b0SSuyog Pawar  *
26*c83a76b0SSuyog Pawar  * @author
27*c83a76b0SSuyog Pawar  *  100470
28*c83a76b0SSuyog Pawar  *
29*c83a76b0SSuyog Pawar  * @par List of Functions:
30*c83a76b0SSuyog Pawar  *  - ihevc_chroma_recon_4x4()
31*c83a76b0SSuyog Pawar  *  - ihevc_chroma_recon_8x8()
32*c83a76b0SSuyog Pawar  *  - ihevc_chroma_recon_16x16()
33*c83a76b0SSuyog Pawar  *
34*c83a76b0SSuyog Pawar  * @remarks
35*c83a76b0SSuyog Pawar  *  None
36*c83a76b0SSuyog Pawar  *
37*c83a76b0SSuyog Pawar  *******************************************************************************
38*c83a76b0SSuyog Pawar  */
39*c83a76b0SSuyog Pawar 
40*c83a76b0SSuyog Pawar #include <stdio.h>
41*c83a76b0SSuyog Pawar #include <string.h>
42*c83a76b0SSuyog Pawar #include "ihevc_typedefs.h"
43*c83a76b0SSuyog Pawar #include "ihevc_macros.h"
44*c83a76b0SSuyog Pawar #include "ihevc_platform_macros.h"
45*c83a76b0SSuyog Pawar #include "ihevc_defs.h"
46*c83a76b0SSuyog Pawar #include "ihevc_trans_tables.h"
47*c83a76b0SSuyog Pawar #include "ihevc_chroma_recon.h"
48*c83a76b0SSuyog Pawar #include "ihevc_func_selector.h"
49*c83a76b0SSuyog Pawar #include "ihevc_trans_macros.h"
50*c83a76b0SSuyog Pawar 
51*c83a76b0SSuyog Pawar /* All the functions work one component(U or V) of interleaved data depending upon pointers passed to it */
52*c83a76b0SSuyog Pawar /* Data visualization */
53*c83a76b0SSuyog Pawar /* U V U V U V U V */
54*c83a76b0SSuyog Pawar /* U V U V U V U V */
55*c83a76b0SSuyog Pawar /* U V U V U V U V */
56*c83a76b0SSuyog Pawar /* U V U V U V U V */
57*c83a76b0SSuyog Pawar /* If the pointer points to first byte of above stream (U) , functions will operate on U component */
58*c83a76b0SSuyog Pawar /* If the pointer points to second byte of above stream (V) , functions will operate on V component */
59*c83a76b0SSuyog Pawar 
60*c83a76b0SSuyog Pawar /**
61*c83a76b0SSuyog Pawar  *******************************************************************************
62*c83a76b0SSuyog Pawar  *
63*c83a76b0SSuyog Pawar  * @brief
64*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  4x4 input block
65*c83a76b0SSuyog Pawar  *
66*c83a76b0SSuyog Pawar  * @par Description:
67*c83a76b0SSuyog Pawar  *  Performs reconstruction of 4x4 input block by adding  adding prediction
68*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
69*c83a76b0SSuyog Pawar  *
70*c83a76b0SSuyog Pawar  * @param[in] pi2_src
71*c83a76b0SSuyog Pawar  *  Input 4x4 coefficients
72*c83a76b0SSuyog Pawar  *
73*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
74*c83a76b0SSuyog Pawar  *  Prediction 4x4 block
75*c83a76b0SSuyog Pawar  *
76*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
77*c83a76b0SSuyog Pawar  *  Output 4x4 block
78*c83a76b0SSuyog Pawar  *
79*c83a76b0SSuyog Pawar  * @param[in] src_strd
80*c83a76b0SSuyog Pawar  *  Input stride
81*c83a76b0SSuyog Pawar  *
82*c83a76b0SSuyog Pawar  * @param[in] pred_strd
83*c83a76b0SSuyog Pawar  *  Prediction stride
84*c83a76b0SSuyog Pawar  *
85*c83a76b0SSuyog Pawar  * @param[in] dst_strd
86*c83a76b0SSuyog Pawar  *  Output Stride
87*c83a76b0SSuyog Pawar  *
88*c83a76b0SSuyog Pawar  * @param[in] shift
89*c83a76b0SSuyog Pawar  *  Output shift
90*c83a76b0SSuyog Pawar  *
91*c83a76b0SSuyog Pawar  * @param[in] zero_cols
92*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
93*c83a76b0SSuyog Pawar  *
94*c83a76b0SSuyog Pawar  * @returns  Void
95*c83a76b0SSuyog Pawar  *
96*c83a76b0SSuyog Pawar  * @remarks
97*c83a76b0SSuyog Pawar  *  None
98*c83a76b0SSuyog Pawar  *
99*c83a76b0SSuyog Pawar  *******************************************************************************
100*c83a76b0SSuyog Pawar  */
101*c83a76b0SSuyog Pawar 
102*c83a76b0SSuyog Pawar 
ihevc_chroma_recon_4x4(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)103*c83a76b0SSuyog Pawar void ihevc_chroma_recon_4x4(WORD16 *pi2_src,
104*c83a76b0SSuyog Pawar                             UWORD8 *pu1_pred,
105*c83a76b0SSuyog Pawar                             UWORD8 *pu1_dst,
106*c83a76b0SSuyog Pawar                             WORD32 src_strd,
107*c83a76b0SSuyog Pawar                             WORD32 pred_strd,
108*c83a76b0SSuyog Pawar                             WORD32 dst_strd,
109*c83a76b0SSuyog Pawar                             WORD32 zero_cols)
110*c83a76b0SSuyog Pawar {
111*c83a76b0SSuyog Pawar     WORD32 i, j;
112*c83a76b0SSuyog Pawar     WORD32 trans_size;
113*c83a76b0SSuyog Pawar 
114*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_4;
115*c83a76b0SSuyog Pawar 
116*c83a76b0SSuyog Pawar     /* Reconstruction */
117*c83a76b0SSuyog Pawar 
118*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
119*c83a76b0SSuyog Pawar     {
120*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
121*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
122*c83a76b0SSuyog Pawar         {
123*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
124*c83a76b0SSuyog Pawar             {
125*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
126*c83a76b0SSuyog Pawar             }
127*c83a76b0SSuyog Pawar         }
128*c83a76b0SSuyog Pawar         else
129*c83a76b0SSuyog Pawar         {
130*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
131*c83a76b0SSuyog Pawar             {
132*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
133*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
134*c83a76b0SSuyog Pawar             }
135*c83a76b0SSuyog Pawar         }
136*c83a76b0SSuyog Pawar         pi2_src++;
137*c83a76b0SSuyog Pawar         pu1_dst += 2;
138*c83a76b0SSuyog Pawar         pu1_pred += 2;
139*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
140*c83a76b0SSuyog Pawar     }
141*c83a76b0SSuyog Pawar }
142*c83a76b0SSuyog Pawar 
143*c83a76b0SSuyog Pawar /**
144*c83a76b0SSuyog Pawar  *******************************************************************************
145*c83a76b0SSuyog Pawar  *
146*c83a76b0SSuyog Pawar  * @brief
147*c83a76b0SSuyog Pawar  *  This function performs reconstruction for 8x8 input block
148*c83a76b0SSuyog Pawar  *
149*c83a76b0SSuyog Pawar  * @par Description:
150*c83a76b0SSuyog Pawar  *  Performs reconstruction of 8x8 input block by adding  adding prediction
151*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
152*c83a76b0SSuyog Pawar  *
153*c83a76b0SSuyog Pawar  * @param[in] pi2_src
154*c83a76b0SSuyog Pawar  *  Input 8x8 coefficients
155*c83a76b0SSuyog Pawar  *
156*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
157*c83a76b0SSuyog Pawar  *  Prediction 8x8 block
158*c83a76b0SSuyog Pawar  *
159*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
160*c83a76b0SSuyog Pawar  *  Output 8x8 block
161*c83a76b0SSuyog Pawar  *
162*c83a76b0SSuyog Pawar  * @param[in] src_strd
163*c83a76b0SSuyog Pawar  *  Input stride
164*c83a76b0SSuyog Pawar  *
165*c83a76b0SSuyog Pawar  * @param[in] pred_strd
166*c83a76b0SSuyog Pawar  *  Prediction stride
167*c83a76b0SSuyog Pawar  *
168*c83a76b0SSuyog Pawar  * @param[in] dst_strd
169*c83a76b0SSuyog Pawar  *  Output Stride
170*c83a76b0SSuyog Pawar  *
171*c83a76b0SSuyog Pawar  * @param[in] shift
172*c83a76b0SSuyog Pawar  *  Output shift
173*c83a76b0SSuyog Pawar  *
174*c83a76b0SSuyog Pawar  * @param[in] zero_cols
175*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
176*c83a76b0SSuyog Pawar  *
177*c83a76b0SSuyog Pawar  * @returns  Void
178*c83a76b0SSuyog Pawar  *
179*c83a76b0SSuyog Pawar  * @remarks
180*c83a76b0SSuyog Pawar  *  None
181*c83a76b0SSuyog Pawar  *
182*c83a76b0SSuyog Pawar  *******************************************************************************
183*c83a76b0SSuyog Pawar  */
184*c83a76b0SSuyog Pawar 
185*c83a76b0SSuyog Pawar 
ihevc_chroma_recon_8x8(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)186*c83a76b0SSuyog Pawar void ihevc_chroma_recon_8x8(WORD16 *pi2_src,
187*c83a76b0SSuyog Pawar                             UWORD8 *pu1_pred,
188*c83a76b0SSuyog Pawar                             UWORD8 *pu1_dst,
189*c83a76b0SSuyog Pawar                             WORD32 src_strd,
190*c83a76b0SSuyog Pawar                             WORD32 pred_strd,
191*c83a76b0SSuyog Pawar                             WORD32 dst_strd,
192*c83a76b0SSuyog Pawar                             WORD32 zero_cols)
193*c83a76b0SSuyog Pawar {
194*c83a76b0SSuyog Pawar     WORD32 i, j;
195*c83a76b0SSuyog Pawar     WORD32 trans_size;
196*c83a76b0SSuyog Pawar 
197*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_8;
198*c83a76b0SSuyog Pawar 
199*c83a76b0SSuyog Pawar     /* Reconstruction */
200*c83a76b0SSuyog Pawar 
201*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
202*c83a76b0SSuyog Pawar     {
203*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
204*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
205*c83a76b0SSuyog Pawar         {
206*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
207*c83a76b0SSuyog Pawar             {
208*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
209*c83a76b0SSuyog Pawar             }
210*c83a76b0SSuyog Pawar         }
211*c83a76b0SSuyog Pawar         else
212*c83a76b0SSuyog Pawar         {
213*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
214*c83a76b0SSuyog Pawar             {
215*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
216*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
217*c83a76b0SSuyog Pawar             }
218*c83a76b0SSuyog Pawar         }
219*c83a76b0SSuyog Pawar         pi2_src++;
220*c83a76b0SSuyog Pawar         pu1_dst += 2;
221*c83a76b0SSuyog Pawar         pu1_pred += 2;
222*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
223*c83a76b0SSuyog Pawar     }
224*c83a76b0SSuyog Pawar }
225*c83a76b0SSuyog Pawar 
226*c83a76b0SSuyog Pawar /**
227*c83a76b0SSuyog Pawar  *******************************************************************************
228*c83a76b0SSuyog Pawar  *
229*c83a76b0SSuyog Pawar  * @brief
230*c83a76b0SSuyog Pawar  *  This function performs reconstruction for  16x16 input block
231*c83a76b0SSuyog Pawar  *
232*c83a76b0SSuyog Pawar  * @par Description:
233*c83a76b0SSuyog Pawar  *  Performs reconstruction of 16x16 input block by adding  adding prediction
234*c83a76b0SSuyog Pawar  * data to input and clipping it to 8 bit
235*c83a76b0SSuyog Pawar  *
236*c83a76b0SSuyog Pawar  * @param[in] pi2_src
237*c83a76b0SSuyog Pawar  *  Input 16x16 coefficients
238*c83a76b0SSuyog Pawar  *
239*c83a76b0SSuyog Pawar  * @param[in] pu1_pred
240*c83a76b0SSuyog Pawar  *  Prediction 16x16 block
241*c83a76b0SSuyog Pawar  *
242*c83a76b0SSuyog Pawar  * @param[out] pu1_dst
243*c83a76b0SSuyog Pawar  *  Output 16x16 block
244*c83a76b0SSuyog Pawar  *
245*c83a76b0SSuyog Pawar  * @param[in] src_strd
246*c83a76b0SSuyog Pawar  *  Input stride
247*c83a76b0SSuyog Pawar  *
248*c83a76b0SSuyog Pawar  * @param[in] pred_strd
249*c83a76b0SSuyog Pawar  *  Prediction stride
250*c83a76b0SSuyog Pawar  *
251*c83a76b0SSuyog Pawar  * @param[in] dst_strd
252*c83a76b0SSuyog Pawar  *  Output Stride
253*c83a76b0SSuyog Pawar  *
254*c83a76b0SSuyog Pawar  * @param[in] shift
255*c83a76b0SSuyog Pawar  *  Output shift
256*c83a76b0SSuyog Pawar  *
257*c83a76b0SSuyog Pawar  * @param[in] zero_cols
258*c83a76b0SSuyog Pawar  *  Zero columns in pi2_tmp
259*c83a76b0SSuyog Pawar  *
260*c83a76b0SSuyog Pawar  * @returns  Void
261*c83a76b0SSuyog Pawar  *
262*c83a76b0SSuyog Pawar  * @remarks
263*c83a76b0SSuyog Pawar  *  None
264*c83a76b0SSuyog Pawar  *
265*c83a76b0SSuyog Pawar  *******************************************************************************
266*c83a76b0SSuyog Pawar  */
267*c83a76b0SSuyog Pawar 
268*c83a76b0SSuyog Pawar 
ihevc_chroma_recon_16x16(WORD16 * pi2_src,UWORD8 * pu1_pred,UWORD8 * pu1_dst,WORD32 src_strd,WORD32 pred_strd,WORD32 dst_strd,WORD32 zero_cols)269*c83a76b0SSuyog Pawar void ihevc_chroma_recon_16x16(WORD16 *pi2_src,
270*c83a76b0SSuyog Pawar                               UWORD8 *pu1_pred,
271*c83a76b0SSuyog Pawar                               UWORD8 *pu1_dst,
272*c83a76b0SSuyog Pawar                               WORD32 src_strd,
273*c83a76b0SSuyog Pawar                               WORD32 pred_strd,
274*c83a76b0SSuyog Pawar                               WORD32 dst_strd,
275*c83a76b0SSuyog Pawar                               WORD32 zero_cols)
276*c83a76b0SSuyog Pawar {
277*c83a76b0SSuyog Pawar     WORD32 i, j;
278*c83a76b0SSuyog Pawar     WORD32 trans_size;
279*c83a76b0SSuyog Pawar 
280*c83a76b0SSuyog Pawar     trans_size = TRANS_SIZE_16;
281*c83a76b0SSuyog Pawar 
282*c83a76b0SSuyog Pawar     /* Reconstruction */
283*c83a76b0SSuyog Pawar 
284*c83a76b0SSuyog Pawar     for(i = 0; i < trans_size; i++)
285*c83a76b0SSuyog Pawar     {
286*c83a76b0SSuyog Pawar         /* Checking for Zero Cols */
287*c83a76b0SSuyog Pawar         if((zero_cols & 1) == 1)
288*c83a76b0SSuyog Pawar         {
289*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
290*c83a76b0SSuyog Pawar             {
291*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] = pu1_pred[j * pred_strd];
292*c83a76b0SSuyog Pawar             }
293*c83a76b0SSuyog Pawar         }
294*c83a76b0SSuyog Pawar         else
295*c83a76b0SSuyog Pawar         {
296*c83a76b0SSuyog Pawar             for(j = 0; j < trans_size; j++)
297*c83a76b0SSuyog Pawar             {
298*c83a76b0SSuyog Pawar                 pu1_dst[j * dst_strd] =
299*c83a76b0SSuyog Pawar                                 CLIP_U8(pi2_src[j * src_strd] + pu1_pred[j * pred_strd]);
300*c83a76b0SSuyog Pawar             }
301*c83a76b0SSuyog Pawar         }
302*c83a76b0SSuyog Pawar         pi2_src++;
303*c83a76b0SSuyog Pawar         pu1_dst += 2;
304*c83a76b0SSuyog Pawar         pu1_pred += 2;
305*c83a76b0SSuyog Pawar         zero_cols = zero_cols >> 1;
306*c83a76b0SSuyog Pawar     }
307*c83a76b0SSuyog Pawar }
308*c83a76b0SSuyog Pawar 
309