1*77c1e3ccSAndroid Build Coastguard Worker /*
2*77c1e3ccSAndroid Build Coastguard Worker * Copyright (c) 2016, Alliance for Open Media. All rights reserved.
3*77c1e3ccSAndroid Build Coastguard Worker *
4*77c1e3ccSAndroid Build Coastguard Worker * This source code is subject to the terms of the BSD 2 Clause License and
5*77c1e3ccSAndroid Build Coastguard Worker * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6*77c1e3ccSAndroid Build Coastguard Worker * was not distributed with this source code in the LICENSE file, you can
7*77c1e3ccSAndroid Build Coastguard Worker * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8*77c1e3ccSAndroid Build Coastguard Worker * Media Patent License 1.0 was not distributed with this source code in the
9*77c1e3ccSAndroid Build Coastguard Worker * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10*77c1e3ccSAndroid Build Coastguard Worker */
11*77c1e3ccSAndroid Build Coastguard Worker #ifndef AOM_AV1_COMMON_CDEF_H_
12*77c1e3ccSAndroid Build Coastguard Worker #define AOM_AV1_COMMON_CDEF_H_
13*77c1e3ccSAndroid Build Coastguard Worker
14*77c1e3ccSAndroid Build Coastguard Worker #define CDEF_STRENGTH_BITS 6
15*77c1e3ccSAndroid Build Coastguard Worker
16*77c1e3ccSAndroid Build Coastguard Worker #define CDEF_PRI_STRENGTHS 16
17*77c1e3ccSAndroid Build Coastguard Worker #define CDEF_SEC_STRENGTHS 4
18*77c1e3ccSAndroid Build Coastguard Worker
19*77c1e3ccSAndroid Build Coastguard Worker #include "config/aom_config.h"
20*77c1e3ccSAndroid Build Coastguard Worker
21*77c1e3ccSAndroid Build Coastguard Worker #include "aom/aom_integer.h"
22*77c1e3ccSAndroid Build Coastguard Worker #include "aom_ports/mem.h"
23*77c1e3ccSAndroid Build Coastguard Worker #include "av1/common/av1_common_int.h"
24*77c1e3ccSAndroid Build Coastguard Worker #include "av1/common/cdef_block.h"
25*77c1e3ccSAndroid Build Coastguard Worker
26*77c1e3ccSAndroid Build Coastguard Worker enum { TOP, LEFT, BOTTOM, RIGHT, BOUNDARIES } UENUM1BYTE(BOUNDARY);
27*77c1e3ccSAndroid Build Coastguard Worker
28*77c1e3ccSAndroid Build Coastguard Worker struct AV1CdefSyncData;
29*77c1e3ccSAndroid Build Coastguard Worker
30*77c1e3ccSAndroid Build Coastguard Worker /*!\brief Parameters related to CDEF Block */
31*77c1e3ccSAndroid Build Coastguard Worker typedef struct {
32*77c1e3ccSAndroid Build Coastguard Worker uint16_t *src; /*!< CDEF intermediate buffer */
33*77c1e3ccSAndroid Build Coastguard Worker uint16_t *top_linebuf[MAX_MB_PLANE]; /*!< CDEF top line buffer */
34*77c1e3ccSAndroid Build Coastguard Worker uint16_t *bot_linebuf[MAX_MB_PLANE]; /*!< CDEF bottom line buffer */
35*77c1e3ccSAndroid Build Coastguard Worker uint8_t *dst; /*!< CDEF destination buffer */
36*77c1e3ccSAndroid Build Coastguard Worker cdef_list
37*77c1e3ccSAndroid Build Coastguard Worker dlist[MI_SIZE_64X64 * MI_SIZE_64X64]; /*!< CDEF 8x8 block positions */
38*77c1e3ccSAndroid Build Coastguard Worker
39*77c1e3ccSAndroid Build Coastguard Worker int xdec; /*!< Sub-sampling X */
40*77c1e3ccSAndroid Build Coastguard Worker int ydec; /*!< Sub-sampling X */
41*77c1e3ccSAndroid Build Coastguard Worker int mi_wide_l2; /*!< Pixels per mi unit in width */
42*77c1e3ccSAndroid Build Coastguard Worker int mi_high_l2; /*!< Pixels per mi unit in height */
43*77c1e3ccSAndroid Build Coastguard Worker int frame_boundary[BOUNDARIES]; /*!< frame boundaries */
44*77c1e3ccSAndroid Build Coastguard Worker
45*77c1e3ccSAndroid Build Coastguard Worker int damping; /*!< CDEF damping factor */
46*77c1e3ccSAndroid Build Coastguard Worker int coeff_shift; /*!< Bit-depth based shift for calculating filter strength */
47*77c1e3ccSAndroid Build Coastguard Worker int level; /*!< CDEF filtering level */
48*77c1e3ccSAndroid Build Coastguard Worker int sec_strength; /*!< CDEF secondary strength */
49*77c1e3ccSAndroid Build Coastguard Worker int cdef_count; /*!< Number of CDEF sub-blocks in superblock */
50*77c1e3ccSAndroid Build Coastguard Worker int dir[CDEF_NBLOCKS]
51*77c1e3ccSAndroid Build Coastguard Worker [CDEF_NBLOCKS]; /*!< CDEF filter direction for all 8x8 sub-blocks*/
52*77c1e3ccSAndroid Build Coastguard Worker int var[CDEF_NBLOCKS][CDEF_NBLOCKS]; /*!< variance for all 8x8 sub-blocks */
53*77c1e3ccSAndroid Build Coastguard Worker
54*77c1e3ccSAndroid Build Coastguard Worker int dst_stride; /*!< CDEF destination buffer stride */
55*77c1e3ccSAndroid Build Coastguard Worker int coffset; /*!< current superblock offset in a row */
56*77c1e3ccSAndroid Build Coastguard Worker int roffset; /*!< current row offset */
57*77c1e3ccSAndroid Build Coastguard Worker } CdefBlockInfo;
58*77c1e3ccSAndroid Build Coastguard Worker
sign(int i)59*77c1e3ccSAndroid Build Coastguard Worker static inline int sign(int i) { return i < 0 ? -1 : 1; }
60*77c1e3ccSAndroid Build Coastguard Worker
constrain(int diff,int threshold,int damping)61*77c1e3ccSAndroid Build Coastguard Worker static inline int constrain(int diff, int threshold, int damping) {
62*77c1e3ccSAndroid Build Coastguard Worker if (!threshold) return 0;
63*77c1e3ccSAndroid Build Coastguard Worker
64*77c1e3ccSAndroid Build Coastguard Worker const int shift = AOMMAX(0, damping - get_msb(threshold));
65*77c1e3ccSAndroid Build Coastguard Worker return sign(diff) *
66*77c1e3ccSAndroid Build Coastguard Worker AOMMIN(abs(diff), AOMMAX(0, threshold - (abs(diff) >> shift)));
67*77c1e3ccSAndroid Build Coastguard Worker }
68*77c1e3ccSAndroid Build Coastguard Worker
69*77c1e3ccSAndroid Build Coastguard Worker #ifdef __cplusplus
70*77c1e3ccSAndroid Build Coastguard Worker extern "C" {
71*77c1e3ccSAndroid Build Coastguard Worker #endif
72*77c1e3ccSAndroid Build Coastguard Worker
73*77c1e3ccSAndroid Build Coastguard Worker int av1_cdef_compute_sb_list(const CommonModeInfoParams *const mi_params,
74*77c1e3ccSAndroid Build Coastguard Worker int mi_row, int mi_col, cdef_list *dlist,
75*77c1e3ccSAndroid Build Coastguard Worker BLOCK_SIZE bsize);
76*77c1e3ccSAndroid Build Coastguard Worker
77*77c1e3ccSAndroid Build Coastguard Worker typedef void (*cdef_init_fb_row_t)(
78*77c1e3ccSAndroid Build Coastguard Worker const AV1_COMMON *const cm, const MACROBLOCKD *const xd,
79*77c1e3ccSAndroid Build Coastguard Worker CdefBlockInfo *const fb_info, uint16_t **const linebuf, uint16_t *const src,
80*77c1e3ccSAndroid Build Coastguard Worker struct AV1CdefSyncData *const cdef_sync, int fbr);
81*77c1e3ccSAndroid Build Coastguard Worker
82*77c1e3ccSAndroid Build Coastguard Worker /*!\brief Function for applying CDEF to a frame
83*77c1e3ccSAndroid Build Coastguard Worker *
84*77c1e3ccSAndroid Build Coastguard Worker * \ingroup in_loop_cdef
85*77c1e3ccSAndroid Build Coastguard Worker * This function applies CDEF to a frame.
86*77c1e3ccSAndroid Build Coastguard Worker *
87*77c1e3ccSAndroid Build Coastguard Worker * \param[in, out] frame Compressed frame buffer
88*77c1e3ccSAndroid Build Coastguard Worker * \param[in, out] cm Pointer to top level common structure
89*77c1e3ccSAndroid Build Coastguard Worker * \param[in] xd Pointer to common current coding block structure
90*77c1e3ccSAndroid Build Coastguard Worker * \param[in] cdef_init_fb_row_fn Function Pointer
91*77c1e3ccSAndroid Build Coastguard Worker *
92*77c1e3ccSAndroid Build Coastguard Worker * \remark Nothing is returned. Instead, the filtered frame is output in
93*77c1e3ccSAndroid Build Coastguard Worker * \c frame.
94*77c1e3ccSAndroid Build Coastguard Worker */
95*77c1e3ccSAndroid Build Coastguard Worker void av1_cdef_frame(YV12_BUFFER_CONFIG *frame, AV1_COMMON *const cm,
96*77c1e3ccSAndroid Build Coastguard Worker MACROBLOCKD *xd, cdef_init_fb_row_t cdef_init_fb_row_fn);
97*77c1e3ccSAndroid Build Coastguard Worker void av1_cdef_fb_row(const AV1_COMMON *const cm, MACROBLOCKD *xd,
98*77c1e3ccSAndroid Build Coastguard Worker uint16_t **const linebuf, uint16_t **const colbuf,
99*77c1e3ccSAndroid Build Coastguard Worker uint16_t *const src, int fbr,
100*77c1e3ccSAndroid Build Coastguard Worker cdef_init_fb_row_t cdef_init_fb_row_fn,
101*77c1e3ccSAndroid Build Coastguard Worker struct AV1CdefSyncData *const cdef_sync,
102*77c1e3ccSAndroid Build Coastguard Worker struct aom_internal_error_info *error_info);
103*77c1e3ccSAndroid Build Coastguard Worker void av1_cdef_init_fb_row(const AV1_COMMON *const cm,
104*77c1e3ccSAndroid Build Coastguard Worker const MACROBLOCKD *const xd,
105*77c1e3ccSAndroid Build Coastguard Worker CdefBlockInfo *const fb_info,
106*77c1e3ccSAndroid Build Coastguard Worker uint16_t **const linebuf, uint16_t *const src,
107*77c1e3ccSAndroid Build Coastguard Worker struct AV1CdefSyncData *const cdef_sync, int fbr);
108*77c1e3ccSAndroid Build Coastguard Worker
109*77c1e3ccSAndroid Build Coastguard Worker #ifdef __cplusplus
110*77c1e3ccSAndroid Build Coastguard Worker } // extern "C"
111*77c1e3ccSAndroid Build Coastguard Worker #endif
112*77c1e3ccSAndroid Build Coastguard Worker #endif // AOM_AV1_COMMON_CDEF_H_
113