1*09537850SAkhilesh Sanikop /*
2*09537850SAkhilesh Sanikop * Copyright 2019 The libgav1 Authors
3*09537850SAkhilesh Sanikop *
4*09537850SAkhilesh Sanikop * Licensed under the Apache License, Version 2.0 (the "License");
5*09537850SAkhilesh Sanikop * you may not use this file except in compliance with the License.
6*09537850SAkhilesh Sanikop * You may obtain a copy of the License at
7*09537850SAkhilesh Sanikop *
8*09537850SAkhilesh Sanikop * http://www.apache.org/licenses/LICENSE-2.0
9*09537850SAkhilesh Sanikop *
10*09537850SAkhilesh Sanikop * Unless required by applicable law or agreed to in writing, software
11*09537850SAkhilesh Sanikop * distributed under the License is distributed on an "AS IS" BASIS,
12*09537850SAkhilesh Sanikop * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*09537850SAkhilesh Sanikop * See the License for the specific language governing permissions and
14*09537850SAkhilesh Sanikop * limitations under the License.
15*09537850SAkhilesh Sanikop */
16*09537850SAkhilesh Sanikop
17*09537850SAkhilesh Sanikop #ifndef LIBGAV1_SRC_DSP_WARP_H_
18*09537850SAkhilesh Sanikop #define LIBGAV1_SRC_DSP_WARP_H_
19*09537850SAkhilesh Sanikop
20*09537850SAkhilesh Sanikop // Pull in LIBGAV1_DspXXX defines representing the implementation status
21*09537850SAkhilesh Sanikop // of each function. The resulting value of each can be used by each module to
22*09537850SAkhilesh Sanikop // determine whether an implementation is needed at compile time.
23*09537850SAkhilesh Sanikop // IWYU pragma: begin_exports
24*09537850SAkhilesh Sanikop
25*09537850SAkhilesh Sanikop // ARM:
26*09537850SAkhilesh Sanikop #include "src/dsp/arm/warp_neon.h"
27*09537850SAkhilesh Sanikop
28*09537850SAkhilesh Sanikop // x86:
29*09537850SAkhilesh Sanikop // Note includes should be sorted in logical order avx2/avx/sse4, etc.
30*09537850SAkhilesh Sanikop // The order of includes is important as each tests for a superior version
31*09537850SAkhilesh Sanikop // before setting the base.
32*09537850SAkhilesh Sanikop // clang-format off
33*09537850SAkhilesh Sanikop #include "src/dsp/x86/warp_sse4.h"
34*09537850SAkhilesh Sanikop // clang-format on
35*09537850SAkhilesh Sanikop
36*09537850SAkhilesh Sanikop // IWYU pragma: end_exports
37*09537850SAkhilesh Sanikop
38*09537850SAkhilesh Sanikop namespace libgav1 {
39*09537850SAkhilesh Sanikop namespace dsp {
40*09537850SAkhilesh Sanikop
41*09537850SAkhilesh Sanikop // Section 7.11.3.5.
42*09537850SAkhilesh Sanikop struct WarpFilterParams {
43*09537850SAkhilesh Sanikop int64_t x4;
44*09537850SAkhilesh Sanikop int64_t y4;
45*09537850SAkhilesh Sanikop int ix4;
46*09537850SAkhilesh Sanikop int iy4;
47*09537850SAkhilesh Sanikop };
48*09537850SAkhilesh Sanikop
49*09537850SAkhilesh Sanikop // Initializes Dsp::warp. This function is not thread-safe.
50*09537850SAkhilesh Sanikop void WarpInit_C();
51*09537850SAkhilesh Sanikop
52*09537850SAkhilesh Sanikop // Section 7.11.3.5.
GetWarpFilterParams(int src_x,int src_y,int subsampling_x,int subsampling_y,const int * warp_params)53*09537850SAkhilesh Sanikop inline WarpFilterParams GetWarpFilterParams(int src_x, int src_y,
54*09537850SAkhilesh Sanikop int subsampling_x,
55*09537850SAkhilesh Sanikop int subsampling_y,
56*09537850SAkhilesh Sanikop const int* warp_params) {
57*09537850SAkhilesh Sanikop WarpFilterParams filter_params;
58*09537850SAkhilesh Sanikop // warp_params[2]/[5] require 17 bits (the others 14). With large resolutions
59*09537850SAkhilesh Sanikop // the result of the multiplication will require 33.
60*09537850SAkhilesh Sanikop const int64_t dst_x = static_cast<int64_t>(src_x) * warp_params[2] +
61*09537850SAkhilesh Sanikop src_y * warp_params[3] + warp_params[0];
62*09537850SAkhilesh Sanikop const int64_t dst_y = src_x * warp_params[4] +
63*09537850SAkhilesh Sanikop static_cast<int64_t>(src_y) * warp_params[5] +
64*09537850SAkhilesh Sanikop warp_params[1];
65*09537850SAkhilesh Sanikop filter_params.x4 = dst_x >> subsampling_x;
66*09537850SAkhilesh Sanikop filter_params.y4 = dst_y >> subsampling_y;
67*09537850SAkhilesh Sanikop filter_params.ix4 =
68*09537850SAkhilesh Sanikop static_cast<int>(filter_params.x4 >> kWarpedModelPrecisionBits);
69*09537850SAkhilesh Sanikop filter_params.iy4 =
70*09537850SAkhilesh Sanikop static_cast<int>(filter_params.y4 >> kWarpedModelPrecisionBits);
71*09537850SAkhilesh Sanikop return filter_params;
72*09537850SAkhilesh Sanikop }
73*09537850SAkhilesh Sanikop
74*09537850SAkhilesh Sanikop } // namespace dsp
75*09537850SAkhilesh Sanikop } // namespace libgav1
76*09537850SAkhilesh Sanikop
77*09537850SAkhilesh Sanikop #endif // LIBGAV1_SRC_DSP_WARP_H_
78