xref: /aosp_15_r20/external/libvpx/vp9/common/vp9_scale.h (revision fb1b10ab9aebc7c7068eedab379b749d7e3900be)
1*fb1b10abSAndroid Build Coastguard Worker /*
2*fb1b10abSAndroid Build Coastguard Worker  *  Copyright (c) 2013 The WebM project authors. All Rights Reserved.
3*fb1b10abSAndroid Build Coastguard Worker  *
4*fb1b10abSAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*fb1b10abSAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*fb1b10abSAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*fb1b10abSAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*fb1b10abSAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*fb1b10abSAndroid Build Coastguard Worker  */
10*fb1b10abSAndroid Build Coastguard Worker 
11*fb1b10abSAndroid Build Coastguard Worker #ifndef VPX_VP9_COMMON_VP9_SCALE_H_
12*fb1b10abSAndroid Build Coastguard Worker #define VPX_VP9_COMMON_VP9_SCALE_H_
13*fb1b10abSAndroid Build Coastguard Worker 
14*fb1b10abSAndroid Build Coastguard Worker #include "vp9/common/vp9_mv.h"
15*fb1b10abSAndroid Build Coastguard Worker #include "vpx_dsp/vpx_convolve.h"
16*fb1b10abSAndroid Build Coastguard Worker 
17*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
18*fb1b10abSAndroid Build Coastguard Worker extern "C" {
19*fb1b10abSAndroid Build Coastguard Worker #endif
20*fb1b10abSAndroid Build Coastguard Worker 
21*fb1b10abSAndroid Build Coastguard Worker #define REF_SCALE_SHIFT 14
22*fb1b10abSAndroid Build Coastguard Worker #define REF_NO_SCALE (1 << REF_SCALE_SHIFT)
23*fb1b10abSAndroid Build Coastguard Worker #define REF_INVALID_SCALE (-1)
24*fb1b10abSAndroid Build Coastguard Worker 
25*fb1b10abSAndroid Build Coastguard Worker struct scale_factors {
26*fb1b10abSAndroid Build Coastguard Worker   int x_scale_fp;  // horizontal fixed point scale factor
27*fb1b10abSAndroid Build Coastguard Worker   int y_scale_fp;  // vertical fixed point scale factor
28*fb1b10abSAndroid Build Coastguard Worker   int x_step_q4;
29*fb1b10abSAndroid Build Coastguard Worker   int y_step_q4;
30*fb1b10abSAndroid Build Coastguard Worker 
31*fb1b10abSAndroid Build Coastguard Worker   int (*scale_value_x)(int val, const struct scale_factors *sf);
32*fb1b10abSAndroid Build Coastguard Worker   int (*scale_value_y)(int val, const struct scale_factors *sf);
33*fb1b10abSAndroid Build Coastguard Worker 
34*fb1b10abSAndroid Build Coastguard Worker   convolve_fn_t predict[2][2][2];  // horiz, vert, avg
35*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_VP9_HIGHBITDEPTH
36*fb1b10abSAndroid Build Coastguard Worker   highbd_convolve_fn_t highbd_predict[2][2][2];  // horiz, vert, avg
37*fb1b10abSAndroid Build Coastguard Worker #endif
38*fb1b10abSAndroid Build Coastguard Worker };
39*fb1b10abSAndroid Build Coastguard Worker 
40*fb1b10abSAndroid Build Coastguard Worker MV32 vp9_scale_mv(const MV *mv, int x, int y, const struct scale_factors *sf);
41*fb1b10abSAndroid Build Coastguard Worker 
42*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_VP9_HIGHBITDEPTH
43*fb1b10abSAndroid Build Coastguard Worker void vp9_setup_scale_factors_for_frame(struct scale_factors *sf, int other_w,
44*fb1b10abSAndroid Build Coastguard Worker                                        int other_h, int this_w, int this_h,
45*fb1b10abSAndroid Build Coastguard Worker                                        int use_highbd);
46*fb1b10abSAndroid Build Coastguard Worker #else
47*fb1b10abSAndroid Build Coastguard Worker void vp9_setup_scale_factors_for_frame(struct scale_factors *sf, int other_w,
48*fb1b10abSAndroid Build Coastguard Worker                                        int other_h, int this_w, int this_h);
49*fb1b10abSAndroid Build Coastguard Worker #endif
50*fb1b10abSAndroid Build Coastguard Worker 
vp9_is_valid_scale(const struct scale_factors * sf)51*fb1b10abSAndroid Build Coastguard Worker static INLINE int vp9_is_valid_scale(const struct scale_factors *sf) {
52*fb1b10abSAndroid Build Coastguard Worker   return sf->x_scale_fp != REF_INVALID_SCALE &&
53*fb1b10abSAndroid Build Coastguard Worker          sf->y_scale_fp != REF_INVALID_SCALE;
54*fb1b10abSAndroid Build Coastguard Worker }
55*fb1b10abSAndroid Build Coastguard Worker 
vp9_is_scaled(const struct scale_factors * sf)56*fb1b10abSAndroid Build Coastguard Worker static INLINE int vp9_is_scaled(const struct scale_factors *sf) {
57*fb1b10abSAndroid Build Coastguard Worker   return vp9_is_valid_scale(sf) &&
58*fb1b10abSAndroid Build Coastguard Worker          (sf->x_scale_fp != REF_NO_SCALE || sf->y_scale_fp != REF_NO_SCALE);
59*fb1b10abSAndroid Build Coastguard Worker }
60*fb1b10abSAndroid Build Coastguard Worker 
valid_ref_frame_size(int ref_width,int ref_height,int this_width,int this_height)61*fb1b10abSAndroid Build Coastguard Worker static INLINE int valid_ref_frame_size(int ref_width, int ref_height,
62*fb1b10abSAndroid Build Coastguard Worker                                        int this_width, int this_height) {
63*fb1b10abSAndroid Build Coastguard Worker   return 2 * this_width >= ref_width && 2 * this_height >= ref_height &&
64*fb1b10abSAndroid Build Coastguard Worker          this_width <= 16 * ref_width && this_height <= 16 * ref_height;
65*fb1b10abSAndroid Build Coastguard Worker }
66*fb1b10abSAndroid Build Coastguard Worker 
67*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
68*fb1b10abSAndroid Build Coastguard Worker }  // extern "C"
69*fb1b10abSAndroid Build Coastguard Worker #endif
70*fb1b10abSAndroid Build Coastguard Worker 
71*fb1b10abSAndroid Build Coastguard Worker #endif  // VPX_VP9_COMMON_VP9_SCALE_H_
72