| /* |
| * Copyright (c) 2016, Alliance for Open Media. All rights reserved |
| * |
| * This source code is subject to the terms of the BSD 2 Clause License and |
| * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License |
| * was not distributed with this source code in the LICENSE file, you can |
| * obtain it at www.aomedia.org/license/software. If the Alliance for Open |
| * Media Patent License 1.0 was not distributed with this source code in the |
| * PATENTS file, you can obtain it at www.aomedia.org/license/patent. |
| */ |
| #ifndef AOM_AV1_COMMON_CDEF_H_ |
| #define AOM_AV1_COMMON_CDEF_H_ |
| |
| #define CDEF_STRENGTH_BITS 6 |
| |
| #define CDEF_PRI_STRENGTHS 16 |
| #define CDEF_SEC_STRENGTHS 4 |
| |
| #include "config/aom_config.h" |
| |
| #include "aom/aom_integer.h" |
| #include "aom_ports/mem.h" |
| #include "av1/common/av1_common_int.h" |
| #include "av1/common/cdef_block.h" |
| |
| enum { TOP, LEFT, BOTTOM, RIGHT, BOUNDARIES } UENUM1BYTE(BOUNDARY); |
| |
| struct AV1CdefSyncData; |
| |
| /*!\brief Parameters related to CDEF Block */ |
| typedef struct { |
| uint16_t *src; /*!< CDEF intermediate buffer */ |
| uint16_t *top_linebuf[MAX_MB_PLANE]; /*!< CDEF top line buffer */ |
| uint16_t *bot_linebuf[MAX_MB_PLANE]; /*!< CDEF bottom line buffer */ |
| uint8_t *dst; /*!< CDEF destination buffer */ |
| cdef_list |
| dlist[MI_SIZE_64X64 * MI_SIZE_64X64]; /*!< CDEF 8x8 block positions */ |
| |
| int xdec; /*!< Sub-sampling X */ |
| int ydec; /*!< Sub-sampling X */ |
| int mi_wide_l2; /*!< Pixels per mi unit in width */ |
| int mi_high_l2; /*!< Pixels per mi unit in height */ |
| int frame_boundary[BOUNDARIES]; /*!< frame boundaries */ |
| |
| int damping; /*!< CDEF damping factor */ |
| int coeff_shift; /*!< Bit-depth based shift for calculating filter strength */ |
| int level; /*!< CDEF filtering level */ |
| int sec_strength; /*!< CDEF secondary strength */ |
| int cdef_count; /*!< Number of CDEF sub-blocks in superblock */ |
| int dir[CDEF_NBLOCKS] |
| [CDEF_NBLOCKS]; /*!< CDEF filter direction for all 8x8 sub-blocks*/ |
| int var[CDEF_NBLOCKS][CDEF_NBLOCKS]; /*!< variance for all 8x8 sub-blocks */ |
| |
| int dst_stride; /*!< CDEF destination buffer stride */ |
| int coffset; /*!< current superblock offset in a row */ |
| int roffset; /*!< current row offset */ |
| } CdefBlockInfo; |
| |
| static INLINE int sign(int i) { return i < 0 ? -1 : 1; } |
| |
| static INLINE int constrain(int diff, int threshold, int damping) { |
| if (!threshold) return 0; |
| |
| const int shift = AOMMAX(0, damping - get_msb(threshold)); |
| return sign(diff) * |
| AOMMIN(abs(diff), AOMMAX(0, threshold - (abs(diff) >> shift))); |
| } |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| int av1_cdef_compute_sb_list(const CommonModeInfoParams *const mi_params, |
| int mi_row, int mi_col, cdef_list *dlist, |
| BLOCK_SIZE bsize); |
| |
| typedef void (*cdef_init_fb_row_t)( |
| const AV1_COMMON *const cm, const MACROBLOCKD *const xd, |
| CdefBlockInfo *const fb_info, uint16_t **const linebuf, uint16_t *const src, |
| struct AV1CdefSyncData *const cdef_sync, int fbr); |
| |
| /*!\brief Function for applying CDEF to a frame |
| * |
| * \ingroup in_loop_cdef |
| * This function applies CDEF to a frame. |
| * |
| * \param[in, out] frame Compressed frame buffer |
| * \param[in, out] cm Pointer to top level common structure |
| * \param[in] xd Pointer to common current coding block structure |
| * \param[in] cdef_init_fb_row_fn Function Pointer |
| * |
| * \remark Nothing is returned. Instead, the filtered frame is output in |
| * \c frame. |
| */ |
| void av1_cdef_frame(YV12_BUFFER_CONFIG *frame, AV1_COMMON *const cm, |
| MACROBLOCKD *xd, cdef_init_fb_row_t cdef_init_fb_row_fn); |
| void av1_cdef_fb_row(const AV1_COMMON *const cm, MACROBLOCKD *xd, |
| uint16_t **const linebuf, uint16_t **const colbuf, |
| uint16_t *const src, int fbr, |
| cdef_init_fb_row_t cdef_init_fb_row_fn, |
| struct AV1CdefSyncData *const cdef_sync); |
| void av1_cdef_init_fb_row(const AV1_COMMON *const cm, |
| const MACROBLOCKD *const xd, |
| CdefBlockInfo *const fb_info, |
| uint16_t **const linebuf, uint16_t *const src, |
| struct AV1CdefSyncData *const cdef_sync, int fbr); |
| |
| #ifdef __cplusplus |
| } // extern "C" |
| #endif |
| #endif // AOM_AV1_COMMON_CDEF_H_ |