1 /*
2 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
3 *
4 * This source code is subject to the terms of the BSD 2 Clause License and
5 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6 * was not distributed with this source code in the LICENSE file, you can
7 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8 * Media Patent License 1.0 was not distributed with this source code in the
9 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10 */
11 #ifndef AOM_AV1_COMMON_CDEF_H_
12 #define AOM_AV1_COMMON_CDEF_H_
13
14 #define CDEF_STRENGTH_BITS 6
15
16 #define CDEF_PRI_STRENGTHS 16
17 #define CDEF_SEC_STRENGTHS 4
18
19 #include "config/aom_config.h"
20
21 #include "aom/aom_integer.h"
22 #include "aom_ports/mem.h"
23 #include "av1/common/cdef_block.h"
24 #include "av1/common/onyxc_int.h"
25
sign(int i)26 static INLINE int sign(int i) { return i < 0 ? -1 : 1; }
27
constrain(int diff,int threshold,int damping)28 static INLINE int constrain(int diff, int threshold, int damping) {
29 if (!threshold) return 0;
30
31 const int shift = AOMMAX(0, damping - get_msb(threshold));
32 return sign(diff) *
33 AOMMIN(abs(diff), AOMMAX(0, threshold - (abs(diff) >> shift)));
34 }
35
36 #ifdef __cplusplus
37 extern "C" {
38 #endif
39
40 int sb_all_skip(const AV1_COMMON *const cm, int mi_row, int mi_col);
41 int sb_compute_cdef_list(const AV1_COMMON *const cm, int mi_row, int mi_col,
42 cdef_list *dlist, BLOCK_SIZE bsize);
43 void av1_cdef_frame(YV12_BUFFER_CONFIG *frame, AV1_COMMON *cm, MACROBLOCKD *xd);
44
45 void av1_cdef_search(YV12_BUFFER_CONFIG *frame, const YV12_BUFFER_CONFIG *ref,
46 AV1_COMMON *cm, MACROBLOCKD *xd, int fast);
47
48 #ifdef __cplusplus
49 } // extern "C"
50 #endif
51 #endif // AOM_AV1_COMMON_CDEF_H_
52