summaryrefslogtreecommitdiffstats
path: root/common/ih264_trans_macros.h
diff options
context:
space:
mode:
authorHamsalekha S <hamsalekha.s@ittiam.com>2015-03-13 21:24:58 +0530
committerHamsalekha S <hamsalekha.s@ittiam.com>2015-04-02 15:59:02 +0530
commit8d3d303c7942ced6a987a52db8977d768dc3605f (patch)
treecc806c96794356996b13ba9970941d0aed74a97e /common/ih264_trans_macros.h
parent3956d913d37327dcb340f836e604b04bd478b158 (diff)
downloadandroid_external_libavc-8d3d303c7942ced6a987a52db8977d768dc3605f.tar.gz
android_external_libavc-8d3d303c7942ced6a987a52db8977d768dc3605f.tar.bz2
android_external_libavc-8d3d303c7942ced6a987a52db8977d768dc3605f.zip
Initial version
Change-Id: I7efe9a589cd24edf86e8d086b40c27cbbf8b4017
Diffstat (limited to 'common/ih264_trans_macros.h')
-rwxr-xr-xcommon/ih264_trans_macros.h124
1 files changed, 124 insertions, 0 deletions
diff --git a/common/ih264_trans_macros.h b/common/ih264_trans_macros.h
new file mode 100755
index 0000000..f114d0e
--- /dev/null
+++ b/common/ih264_trans_macros.h
@@ -0,0 +1,124 @@
+/******************************************************************************
+ *
+ * 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_ */