| /* | 
 |  *  Copyright (c) 2016 The WebM project authors. All Rights Reserved. | 
 |  * | 
 |  *  Use of this source code is governed by a BSD-style license | 
 |  *  that can be found in the LICENSE file in the root of the source | 
 |  *  tree. An additional intellectual property rights grant can be | 
 |  *  found  in the file PATENTS.  All contributing project authors may | 
 |  *  be found in the AUTHORS file in the root of the source tree. | 
 |  */ | 
 |  | 
 | #ifndef AV1_COMMON_WARPED_MOTION_H_ | 
 | #define AV1_COMMON_WARPED_MOTION_H_ | 
 |  | 
 | #include <stdio.h> | 
 | #include <stdlib.h> | 
 | #include <memory.h> | 
 | #include <math.h> | 
 | #include <assert.h> | 
 |  | 
 | #include "./aom_config.h" | 
 | #include "aom_ports/mem.h" | 
 | #include "aom_dsp/aom_dsp_common.h" | 
 | #include "av1/common/mv.h" | 
 |  | 
 | #define MAX_PARAMDIM 9 | 
 |  | 
 | typedef void (*ProjectPointsFunc)(int16_t *mat, int *points, int *proj, | 
 |                                   const int n, const int stride_points, | 
 |                                   const int stride_proj, | 
 |                                   const int subsampling_x, | 
 |                                   const int subsampling_y); | 
 |  | 
 | void project_points_translation(int16_t *mat, int *points, int *proj, | 
 |                                 const int n, const int stride_points, | 
 |                                 const int stride_proj, const int subsampling_x, | 
 |                                 const int subsampling_y); | 
 |  | 
 | void project_points_rotzoom(int16_t *mat, int *points, int *proj, const int n, | 
 |                             const int stride_points, const int stride_proj, | 
 |                             const int subsampling_x, const int subsampling_y); | 
 |  | 
 | void project_points_affine(int16_t *mat, int *points, int *proj, const int n, | 
 |                            const int stride_points, const int stride_proj, | 
 |                            const int subsampling_x, const int subsampling_y); | 
 |  | 
 | void project_points_homography(int16_t *mat, int *points, int *proj, | 
 |                                const int n, const int stride_points, | 
 |                                const int stride_proj, const int subsampling_x, | 
 |                                const int subsampling_y); | 
 |  | 
 | double av1_warp_erroradv(WarpedMotionParams *wm, | 
 | #if CONFIG_AOM_HIGHBITDEPTH | 
 |                          int use_hbd, int bd, | 
 | #endif  // CONFIG_AOM_HIGHBITDEPTH | 
 |                          uint8_t *ref, int width, int height, int stride, | 
 |                          uint8_t *dst, int p_col, int p_row, int p_width, | 
 |                          int p_height, int p_stride, int subsampling_x, | 
 |                          int subsampling_y, int x_scale, int y_scale); | 
 |  | 
 | void av1_warp_plane(WarpedMotionParams *wm, | 
 | #if CONFIG_AOM_HIGHBITDEPTH | 
 |                     int use_hbd, int bd, | 
 | #endif  // CONFIG_AOM_HIGHBITDEPTH | 
 |                     uint8_t *ref, int width, int height, int stride, | 
 |                     uint8_t *pred, int p_col, int p_row, int p_width, | 
 |                     int p_height, int p_stride, int subsampling_x, | 
 |                     int subsampling_y, int x_scale, int y_scale); | 
 |  | 
 | // Integerize model into the WarpedMotionParams structure | 
 | void av1_integerize_model(const double *model, TransformationType wmtype, | 
 |                           WarpedMotionParams *wm); | 
 |  | 
 | int find_translation(const int np, double *pts1, double *pts2, double *mat); | 
 | int find_rotzoom(const int np, double *pts1, double *pts2, double *mat); | 
 | int find_affine(const int np, double *pts1, double *pts2, double *mat); | 
 | int find_homography(const int np, double *pts1, double *pts2, double *mat); | 
 | #endif  // AV1_COMMON_WARPED_MOTION_H_ |