xref: /aosp_15_r20/external/libhevc/encoder/hme_common_utils.h (revision c83a76b084498d55f252f48b2e3786804cdf24b7)
1*c83a76b0SSuyog Pawar /******************************************************************************
2*c83a76b0SSuyog Pawar  *
3*c83a76b0SSuyog Pawar  * Copyright (C) 2018 The Android Open Source Project
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  * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*c83a76b0SSuyog Pawar */
20*c83a76b0SSuyog Pawar 
21*c83a76b0SSuyog Pawar /*!
22*c83a76b0SSuyog Pawar ******************************************************************************
23*c83a76b0SSuyog Pawar * \file hme_common_utils.h
24*c83a76b0SSuyog Pawar *
25*c83a76b0SSuyog Pawar * \brief
26*c83a76b0SSuyog Pawar *    Common utility functions used by ME
27*c83a76b0SSuyog Pawar *
28*c83a76b0SSuyog Pawar * \date
29*c83a76b0SSuyog Pawar *    18/09/2012
30*c83a76b0SSuyog Pawar *
31*c83a76b0SSuyog Pawar * \author
32*c83a76b0SSuyog Pawar *    Ittiam
33*c83a76b0SSuyog Pawar *
34*c83a76b0SSuyog Pawar ******************************************************************************
35*c83a76b0SSuyog Pawar */
36*c83a76b0SSuyog Pawar 
37*c83a76b0SSuyog Pawar #ifndef _HME_COMMON_UTILS_H_
38*c83a76b0SSuyog Pawar #define _HME_COMMON_UTILS_H_
39*c83a76b0SSuyog Pawar 
40*c83a76b0SSuyog Pawar #include "ihevc_platform_macros.h"
41*c83a76b0SSuyog Pawar 
42*c83a76b0SSuyog Pawar /*****************************************************************************/
43*c83a76b0SSuyog Pawar /* Macros                                                                    */
44*c83a76b0SSuyog Pawar /*****************************************************************************/
45*c83a76b0SSuyog Pawar 
46*c83a76b0SSuyog Pawar #define MEDIAN4(a, b, c, d, e) (median4_##e(a, b, c, d))
47*c83a76b0SSuyog Pawar 
48*c83a76b0SSuyog Pawar /*****************************************************************************/
49*c83a76b0SSuyog Pawar /* Functions                                                                 */
50*c83a76b0SSuyog Pawar /*****************************************************************************/
51*c83a76b0SSuyog Pawar /**
52*c83a76b0SSuyog Pawar ********************************************************************************
53*c83a76b0SSuyog Pawar *  @fn     S32 median4_s16(S16 i2_n1, S16 i2_n2, S16 i2_n3, S16 i2_n4);
54*c83a76b0SSuyog Pawar *
55*c83a76b0SSuyog Pawar *  @brief  Returns median4 of 4 16 bits signed nubers
56*c83a76b0SSuyog Pawar *
57*c83a76b0SSuyog Pawar *  @param[in] i2_n1 : first number
58*c83a76b0SSuyog Pawar *
59*c83a76b0SSuyog Pawar *  @param[in] i2_n2 : 2nd number
60*c83a76b0SSuyog Pawar *
61*c83a76b0SSuyog Pawar *  @param[in] i2_n3 : 3rd number
62*c83a76b0SSuyog Pawar *
63*c83a76b0SSuyog Pawar *  @param[in] i2_n4 : 4th number (order does not matter)
64*c83a76b0SSuyog Pawar *
65*c83a76b0SSuyog Pawar *  @return range of the number
66*c83a76b0SSuyog Pawar ********************************************************************************
67*c83a76b0SSuyog Pawar */
68*c83a76b0SSuyog Pawar S16 median4_s16(S16 i2_n1, S16 i2_n2, S16 i2_n3, S16 i2_n4);
69*c83a76b0SSuyog Pawar 
70*c83a76b0SSuyog Pawar /**
71*c83a76b0SSuyog Pawar ********************************************************************************
72*c83a76b0SSuyog Pawar *  @fn     S32 hme_get_range(U32 u4_num);
73*c83a76b0SSuyog Pawar *
74*c83a76b0SSuyog Pawar *  @brief  Returns the range of the number
75*c83a76b0SSuyog Pawar *
76*c83a76b0SSuyog Pawar *  @param[in] u4_num : number whose range is to be found
77*c83a76b0SSuyog Pawar *
78*c83a76b0SSuyog Pawar *  @return range of the number
79*c83a76b0SSuyog Pawar ********************************************************************************
80*c83a76b0SSuyog Pawar */
81*c83a76b0SSuyog Pawar 
hme_get_range(U32 u4_num)82*c83a76b0SSuyog Pawar static INLINE S32 hme_get_range(U32 u4_num)
83*c83a76b0SSuyog Pawar {
84*c83a76b0SSuyog Pawar     S32 r;
85*c83a76b0SSuyog Pawar 
86*c83a76b0SSuyog Pawar     GETRANGE(r, u4_num);
87*c83a76b0SSuyog Pawar     return (r);
88*c83a76b0SSuyog Pawar }
89*c83a76b0SSuyog Pawar 
90*c83a76b0SSuyog Pawar /**
91*c83a76b0SSuyog Pawar ********************************************************************************
92*c83a76b0SSuyog Pawar *  @fn     S32 hme_compute_2d_sum_unsigned(void *pv_inp,
93*c83a76b0SSuyog Pawar *                                       S32 i4_blk_wd,
94*c83a76b0SSuyog Pawar *                                       S32 i4_blk_ht,
95*c83a76b0SSuyog Pawar *                                   S32 i4_stride,
96*c83a76b0SSuyog Pawar *                                   S32 i4_datatype)
97*c83a76b0SSuyog Pawar *
98*c83a76b0SSuyog Pawar *  @brief  Computes and returns 2D sum of a unsigned 2d buffer, with datatype
99*c83a76b0SSuyog Pawar *          equal to 8/16/32 bit.
100*c83a76b0SSuyog Pawar *
101*c83a76b0SSuyog Pawar *  @param[in] pv_inp : input pointer
102*c83a76b0SSuyog Pawar *
103*c83a76b0SSuyog Pawar *  @param[in] i4_blk_wd : block width
104*c83a76b0SSuyog Pawar *
105*c83a76b0SSuyog Pawar *  @param[in] i4_blk_ht : block ht
106*c83a76b0SSuyog Pawar *
107*c83a76b0SSuyog Pawar *  @param[in] i4_stride : stride
108*c83a76b0SSuyog Pawar *
109*c83a76b0SSuyog Pawar *  @param[in] i4_datatype : datatype 1 - 8 bit, 2 - 16 bit, 4 - 32 bit
110*c83a76b0SSuyog Pawar *
111*c83a76b0SSuyog Pawar *  @return sum of i4_blk_wd * i4_blk_ht number of entries starting at pv_inp
112*c83a76b0SSuyog Pawar ********************************************************************************
113*c83a76b0SSuyog Pawar */
114*c83a76b0SSuyog Pawar 
115*c83a76b0SSuyog Pawar U32 hme_compute_2d_sum_unsigned(
116*c83a76b0SSuyog Pawar     void *pv_inp, S32 i4_blk_wd, S32 i4_blk_ht, S32 i4_stride, S32 i4_datatype);
117*c83a76b0SSuyog Pawar 
118*c83a76b0SSuyog Pawar /**
119*c83a76b0SSuyog Pawar ********************************************************************************
120*c83a76b0SSuyog Pawar *  @fn     S32 get_rand_num(S32 low, S32 high)
121*c83a76b0SSuyog Pawar *
122*c83a76b0SSuyog Pawar *  @brief  returns a radom integer in the closed interval [low, high - 1]
123*c83a76b0SSuyog Pawar *
124*c83a76b0SSuyog Pawar *  @param[in] low : lower limit
125*c83a76b0SSuyog Pawar *
126*c83a76b0SSuyog Pawar *  @param[in] high : higher limit
127*c83a76b0SSuyog Pawar *
128*c83a76b0SSuyog Pawar *  @return S32 result: the random number
129*c83a76b0SSuyog Pawar ********************************************************************************
130*c83a76b0SSuyog Pawar */
131*c83a76b0SSuyog Pawar S32 get_rand_num(S32 low, S32 high);
132*c83a76b0SSuyog Pawar 
133*c83a76b0SSuyog Pawar #endif /* #ifndef _HME_COMMON_UTILS_H_ */
134