blob: 661ad8ec3dacdce9789f409d9dec6763fba39681 [file] [log] [blame]
Yaowu Xuc27fc142016-08-22 16:08:15 -07001/*
Yaowu Xu2ab7ff02016-09-02 12:04:54 -07002 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
Yaowu Xuc27fc142016-08-22 16:08:15 -07003 *
Yaowu Xu2ab7ff02016-09-02 12:04:54 -07004 * 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.
Yaowu Xuc27fc142016-08-22 16:08:15 -070010 */
11
Yaowu Xuf883b422016-08-30 14:01:10 -070012#ifndef AV1_COMMON_FILTER_H_
13#define AV1_COMMON_FILTER_H_
Yaowu Xuc27fc142016-08-22 16:08:15 -070014
Rupert Swarbrick27e90292017-09-28 17:46:50 +010015#include <assert.h>
16
Yaowu Xuf883b422016-08-30 14:01:10 -070017#include "./aom_config.h"
18#include "aom/aom_integer.h"
19#include "aom_dsp/aom_filter.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070020#include "aom_ports/mem.h"
21
22#ifdef __cplusplus
23extern "C" {
24#endif
25
Yunqing Wang3ec11d12018-01-05 12:45:08 -080026#define MAX_FILTER_TAP 8
Jingning Hanb14c1792017-04-20 15:10:29 -070027
Urvang Joshif5f5c842017-10-19 16:17:54 -070028typedef enum ATTRIBUTE_PACKED {
Urvang Joshia9b174b2017-02-17 11:50:12 -080029 EIGHTTAP_REGULAR,
30 EIGHTTAP_SMOOTH,
Thomas Daviesec92c112017-09-25 11:03:58 +010031 MULTITAP_SHARP,
Urvang Joshia9b174b2017-02-17 11:50:12 -080032 BILINEAR,
Urvang Joshia9b174b2017-02-17 11:50:12 -080033 INTERP_FILTERS_ALL,
34 SWITCHABLE_FILTERS = BILINEAR,
35 SWITCHABLE = SWITCHABLE_FILTERS + 1, /* the last switchable one */
36 EXTRA_FILTERS = INTERP_FILTERS_ALL - SWITCHABLE_FILTERS,
Urvang Joshia9b174b2017-02-17 11:50:12 -080037} InterpFilter;
Yaowu Xuc27fc142016-08-22 16:08:15 -070038
Rupert Swarbrick27e90292017-09-28 17:46:50 +010039// With CONFIG_DUAL_FILTER, pack two InterpFilter's into a uint32_t: since
40// there are at most 10 filters, we can use 16 bits for each and have more than
41// enough space. This reduces argument passing and unifies the operation of
42// setting a (pair of) filters.
43//
44// Without CONFIG_DUAL_FILTER,
Rupert Swarbrick27e90292017-09-28 17:46:50 +010045typedef uint32_t InterpFilters;
46static INLINE InterpFilter av1_extract_interp_filter(InterpFilters filters,
47 int x_filter) {
48 return (InterpFilter)((filters >> (x_filter ? 16 : 0)) & 0xffff);
49}
50
51static INLINE InterpFilters av1_make_interp_filters(InterpFilter y_filter,
52 InterpFilter x_filter) {
53 uint16_t y16 = y_filter & 0xffff;
54 uint16_t x16 = x_filter & 0xffff;
55 return y16 | ((uint32_t)x16 << 16);
56}
57
58static INLINE InterpFilters av1_broadcast_interp_filter(InterpFilter filter) {
59 return av1_make_interp_filters(filter, filter);
60}
Rupert Swarbrick27e90292017-09-28 17:46:50 +010061
62static INLINE InterpFilter av1_unswitchable_filter(InterpFilter filter) {
63 return filter == SWITCHABLE ? EIGHTTAP_REGULAR : filter;
64}
65
Frederic Barbier7b35d733e2017-07-11 17:32:39 +020066#define LOG_SWITCHABLE_FILTERS \
67 2 /* (1 << LOG_SWITCHABLE_FILTERS) > SWITCHABLE_FILTERS */
Frederic Barbier7b35d733e2017-07-11 17:32:39 +020068
Frederic Barbier7b35d733e2017-07-11 17:32:39 +020069#define MAX_SUBPEL_TAPS 12
Angie Chiang1733f6b2017-01-05 09:52:20 -080070#define SWITCHABLE_FILTER_CONTEXTS ((SWITCHABLE_FILTERS + 1) * 4)
71#define INTER_FILTER_COMP_OFFSET (SWITCHABLE_FILTERS + 1)
72#define INTER_FILTER_DIR_OFFSET ((SWITCHABLE_FILTERS + 1) * 2)
Yaowu Xuc27fc142016-08-22 16:08:15 -070073
Yaowu Xuc27fc142016-08-22 16:08:15 -070074typedef struct InterpFilterParams {
75 const int16_t *filter_ptr;
76 uint16_t taps;
77 uint16_t subpel_shifts;
Angie Chiangb9ba5c22016-10-03 16:39:27 -070078 InterpFilter interp_filter;
Yaowu Xuc27fc142016-08-22 16:08:15 -070079} InterpFilterParams;
80
Yaowu Xuf883b422016-08-30 14:01:10 -070081InterpFilterParams av1_get_interp_filter_params(
James Zern7b9407a2016-05-18 23:48:05 -070082 const InterpFilter interp_filter);
Yaowu Xuc27fc142016-08-22 16:08:15 -070083
James Zern7b9407a2016-05-18 23:48:05 -070084const int16_t *av1_get_interp_filter_kernel(const InterpFilter interp_filter);
Yaowu Xuc27fc142016-08-22 16:08:15 -070085
Zhijie Yangf02f8ae2017-10-26 17:58:29 -070086InterpFilterParams av1_get_interp_filter_params_with_block_size(
87 const InterpFilter interp_filter, const int w);
Zhijie Yangf02f8ae2017-10-26 17:58:29 -070088
Yaowu Xuf883b422016-08-30 14:01:10 -070089static INLINE const int16_t *av1_get_interp_filter_subpel_kernel(
Yaowu Xuc27fc142016-08-22 16:08:15 -070090 const InterpFilterParams filter_params, const int subpel) {
91 return filter_params.filter_ptr + filter_params.taps * subpel;
92}
93
Yaowu Xuf883b422016-08-30 14:01:10 -070094static INLINE int av1_is_interpolating_filter(
James Zern7b9407a2016-05-18 23:48:05 -070095 const InterpFilter interp_filter) {
Yaowu Xuf883b422016-08-30 14:01:10 -070096 const InterpFilterParams ip = av1_get_interp_filter_params(interp_filter);
Yaowu Xuc27fc142016-08-22 16:08:15 -070097 return (ip.filter_ptr[ip.taps / 2 - 1] == 128);
98}
99
Yaowu Xuc27fc142016-08-22 16:08:15 -0700100#ifdef __cplusplus
101} // extern "C"
102#endif
103
Yaowu Xuf883b422016-08-30 14:01:10 -0700104#endif // AV1_COMMON_FILTER_H_