/****************************************************************************** * * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ***************************************************************************** * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore */ /** ******************************************************************************* * @file * ih264_trans_macros.h * * @brief * The file contains definitions of macros that perform forward and inverse * quantization * * @author * Ittiam * * @remark * None * ******************************************************************************* */ #ifndef IH264_TRANS_MACROS_H_ #define IH264_TRANS_MACROS_H_ /*****************************************************************************/ /* Function Macros */ /*****************************************************************************/ /** ****************************************************************************** * @brief Macro to perform forward quantization. * @description The value to be quantized is first compared with a threshold. * If the value is less than the threshold, the quantization value is returned * as zero else the value is quantized traditionally as per the rules of * h264 specification ****************************************************************************** */ #define FWD_QUANT(i4_value, u4_abs_value, i4_sign, threshold, scale, rndfactor, qbits, u4_nnz) \ {\ if (i4_value < 0)\ {\ u4_abs_value = -i4_value;\ i4_sign = -1;\ }\ else\ {\ u4_abs_value = i4_value;\ i4_sign = 1;\ }\ if (u4_abs_value < threshold)\ {\ i4_value = 0;\ }\ else\ {\ u4_abs_value *= scale;\ u4_abs_value += rndfactor;\ u4_abs_value >>= qbits;\ i4_value = u4_abs_value * i4_sign;\ if (i4_value)\ {\ u4_nnz++;\ }\ }\ } /** ****************************************************************************** * @brief Macro to perform inverse quantization. * @remarks The value can also be de-quantized as * if (u4_qp_div_6 < 4) * { * i4_value = (quant_scale * weight_scale * i4_value + (1 << (3-u4_qp_div_6))) * i4_value >>= (4 - u4_qp_div_6) * } * else * { * i4_value = (quant_scale * weight_scale * i4_value) << (u4_qp_div_6 -4) * } ****************************************************************************** */ #define INV_QUANT(i4_value, quant_scale, weight_scale, u4_qp_div_6, rndfactor, qbits)\ {\ i4_value *= quant_scale;\ i4_value *= weight_scale;\ i4_value += rndfactor;\ i4_value <<= u4_qp_div_6;\ i4_value >>= qbits;\ } #define QUANT_H264(x,y,w,z,shft) (shft = ABS(x),\ shft *= y,\ shft += z,\ shft = shft>>w,\ shft = SIGNXY(shft,x)) #define IQUANT_H264(x,y,wscal,w,shft) (shft = x, \ shft *=y, \ shft *=wscal, \ shft = shft<<w) #define IQUANT_lev_H264(x,y,wscal,add_f,w,shft) (shft = x, \ shft *=y, \ shft *=wscal, \ shft+= add_f, \ shft = shft>>w) #endif /* IH264_TRANS_MACROS_H_ */