| /* |
| * 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/cdef_block.h" |
| #include "av1/common/onyxc_int.h" |
| |
| 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 sb_all_skip(const AV1_COMMON *const cm, int mi_row, int mi_col); |
| int sb_compute_cdef_list(const AV1_COMMON *const cm, int mi_row, int mi_col, |
| cdef_list *dlist, BLOCK_SIZE bsize); |
| void av1_cdef_frame(YV12_BUFFER_CONFIG *frame, AV1_COMMON *cm, MACROBLOCKD *xd); |
| |
| void av1_cdef_search(YV12_BUFFER_CONFIG *frame, const YV12_BUFFER_CONFIG *ref, |
| AV1_COMMON *cm, MACROBLOCKD *xd, int fast); |
| |
| #ifdef __cplusplus |
| } // extern "C" |
| #endif |
| #endif // AOM_AV1_COMMON_CDEF_H_ |