Home | History | Annotate | Download | only in encoder
      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 
     12 #ifndef AOM_AV1_ENCODER_MCOMP_H_
     13 #define AOM_AV1_ENCODER_MCOMP_H_
     14 
     15 #include "av1/encoder/block.h"
     16 
     17 #include "aom_dsp/variance.h"
     18 
     19 #ifdef __cplusplus
     20 extern "C" {
     21 #endif
     22 
     23 // The maximum number of steps in a step search given the largest
     24 // allowed initial step
     25 #define MAX_MVSEARCH_STEPS 11
     26 // Max full pel mv specified in the unit of full pixel
     27 // Enable the use of motion vector in range [-1023, 1023].
     28 #define MAX_FULL_PEL_VAL ((1 << (MAX_MVSEARCH_STEPS - 1)) - 1)
     29 // Maximum size of the first step in full pel units
     30 #define MAX_FIRST_STEP (1 << (MAX_MVSEARCH_STEPS - 1))
     31 // Allowed motion vector pixel distance outside image border
     32 // for Block_16x16
     33 #define BORDER_MV_PIXELS_B16 (16 + AOM_INTERP_EXTEND)
     34 
     35 #define SEARCH_RANGE_8P 3
     36 #define SEARCH_GRID_STRIDE_8P (2 * SEARCH_RANGE_8P + 1)
     37 #define SEARCH_GRID_CENTER_8P \
     38   (SEARCH_RANGE_8P * SEARCH_GRID_STRIDE_8P + SEARCH_RANGE_8P)
     39 
     40 // motion search site
     41 typedef struct search_site {
     42   MV mv;
     43   int offset;
     44 } search_site;
     45 
     46 typedef struct search_site_config {
     47   search_site ss[8 * MAX_MVSEARCH_STEPS + 1];
     48   int ss_count;
     49   int searches_per_step;
     50 } search_site_config;
     51 
     52 typedef struct {
     53   MV coord;
     54   int coord_offset;
     55 } search_neighbors;
     56 
     57 void av1_init_dsmotion_compensation(search_site_config *cfg, int stride);
     58 void av1_init3smotion_compensation(search_site_config *cfg, int stride);
     59 
     60 void av1_set_mv_search_range(MvLimits *mv_limits, const MV *mv);
     61 
     62 int av1_mv_bit_cost(const MV *mv, const MV *ref, const int *mvjcost,
     63                     int *mvcost[2], int weight);
     64 
     65 // Utility to compute variance + MV rate cost for a given MV
     66 int av1_get_mvpred_var(const MACROBLOCK *x, const MV *best_mv,
     67                        const MV *center_mv, const aom_variance_fn_ptr_t *vfp,
     68                        int use_mvcost);
     69 int av1_get_mvpred_av_var(const MACROBLOCK *x, const MV *best_mv,
     70                           const MV *center_mv, const uint8_t *second_pred,
     71                           const aom_variance_fn_ptr_t *vfp, int use_mvcost);
     72 int av1_get_mvpred_mask_var(const MACROBLOCK *x, const MV *best_mv,
     73                             const MV *center_mv, const uint8_t *second_pred,
     74                             const uint8_t *mask, int mask_stride,
     75                             int invert_mask, const aom_variance_fn_ptr_t *vfp,
     76                             int use_mvcost);
     77 
     78 struct AV1_COMP;
     79 struct SPEED_FEATURES;
     80 
     81 int av1_init_search_range(int size);
     82 
     83 int av1_refining_search_sad(struct macroblock *x, MV *ref_mv, int sad_per_bit,
     84                             int distance, const aom_variance_fn_ptr_t *fn_ptr,
     85                             const MV *center_mv);
     86 
     87 unsigned int av1_int_pro_motion_estimation(const struct AV1_COMP *cpi,
     88                                            MACROBLOCK *x, BLOCK_SIZE bsize,
     89                                            int mi_row, int mi_col,
     90                                            const MV *ref_mv);
     91 
     92 // Runs sequence of diamond searches in smaller steps for RD.
     93 int av1_full_pixel_diamond(const struct AV1_COMP *cpi, MACROBLOCK *x,
     94                            MV *mvp_full, int step_param, int sadpb,
     95                            int further_steps, int do_refine, int *cost_list,
     96                            const aom_variance_fn_ptr_t *fn_ptr,
     97                            const MV *ref_mv, MV *dst_mv);
     98 
     99 int av1_hex_search(MACROBLOCK *x, MV *start_mv, int search_param,
    100                    int sad_per_bit, int do_init_search, int *cost_list,
    101                    const aom_variance_fn_ptr_t *vfp, int use_mvcost,
    102                    const MV *center_mv);
    103 
    104 typedef int(fractional_mv_step_fp)(
    105     MACROBLOCK *x, const AV1_COMMON *const cm, int mi_row, int mi_col,
    106     const MV *ref_mv, int allow_hp, int error_per_bit,
    107     const aom_variance_fn_ptr_t *vfp,
    108     int forced_stop,  // 0 - full, 1 - qtr only, 2 - half only
    109     int iters_per_step, int *cost_list, int *mvjcost, int *mvcost[2],
    110     int *distortion, unsigned int *sse1, const uint8_t *second_pred,
    111     const uint8_t *mask, int mask_stride, int invert_mask, int w, int h,
    112     int use_accurate_subpel_search, const int do_reset_fractional_mv);
    113 
    114 extern fractional_mv_step_fp av1_find_best_sub_pixel_tree;
    115 extern fractional_mv_step_fp av1_find_best_sub_pixel_tree_pruned;
    116 extern fractional_mv_step_fp av1_find_best_sub_pixel_tree_pruned_more;
    117 extern fractional_mv_step_fp av1_find_best_sub_pixel_tree_pruned_evenmore;
    118 extern fractional_mv_step_fp av1_return_max_sub_pixel_mv;
    119 extern fractional_mv_step_fp av1_return_min_sub_pixel_mv;
    120 
    121 typedef int (*av1_full_search_fn_t)(const MACROBLOCK *x, const MV *ref_mv,
    122                                     int sad_per_bit, int distance,
    123                                     const aom_variance_fn_ptr_t *fn_ptr,
    124                                     const MV *center_mv, MV *best_mv);
    125 
    126 typedef int (*av1_diamond_search_fn_t)(
    127     MACROBLOCK *x, const search_site_config *cfg, MV *ref_mv, MV *best_mv,
    128     int search_param, int sad_per_bit, int *num00,
    129     const aom_variance_fn_ptr_t *fn_ptr, const MV *center_mv);
    130 
    131 int av1_refining_search_8p_c(MACROBLOCK *x, int error_per_bit, int search_range,
    132                              const aom_variance_fn_ptr_t *fn_ptr,
    133                              const uint8_t *mask, int mask_stride,
    134                              int invert_mask, const MV *center_mv,
    135                              const uint8_t *second_pred);
    136 
    137 int av1_full_pixel_search(const struct AV1_COMP *cpi, MACROBLOCK *x,
    138                           BLOCK_SIZE bsize, MV *mvp_full, int step_param,
    139                           int method, int run_mesh_search, int error_per_bit,
    140                           int *cost_list, const MV *ref_mv, int var_max, int rd,
    141                           int x_pos, int y_pos, int intra,
    142                           const search_site_config *cfg);
    143 
    144 int av1_obmc_full_pixel_search(const struct AV1_COMP *cpi, MACROBLOCK *x,
    145                                MV *mvp_full, int step_param, int sadpb,
    146                                int further_steps, int do_refine,
    147                                const aom_variance_fn_ptr_t *fn_ptr,
    148                                const MV *ref_mv, MV *dst_mv, int is_second,
    149                                const search_site_config *cfg);
    150 int av1_find_best_obmc_sub_pixel_tree_up(
    151     MACROBLOCK *x, const AV1_COMMON *const cm, int mi_row, int mi_col,
    152     MV *bestmv, const MV *ref_mv, int allow_hp, int error_per_bit,
    153     const aom_variance_fn_ptr_t *vfp, int forced_stop, int iters_per_step,
    154     int *mvjcost, int *mvcost[2], int *distortion, unsigned int *sse1,
    155     int is_second, int use_accurate_subpel_search);
    156 
    157 unsigned int av1_compute_motion_cost(const struct AV1_COMP *cpi,
    158                                      MACROBLOCK *const x, BLOCK_SIZE bsize,
    159                                      int mi_row, int mi_col, const MV *this_mv);
    160 unsigned int av1_refine_warped_mv(const struct AV1_COMP *cpi,
    161                                   MACROBLOCK *const x, BLOCK_SIZE bsize,
    162                                   int mi_row, int mi_col, int *pts0,
    163                                   int *pts_inref0, int total_samples);
    164 
    165 // Performs a motion search in SIMPLE_TRANSLATION mode using reference frame
    166 // ref. Note that this sets the offset of mbmi, so we will need to reset it
    167 // after calling this function.
    168 void av1_simple_motion_search(struct AV1_COMP *const cpi, MACROBLOCK *x,
    169                               int mi_row, int mi_col, BLOCK_SIZE bsize, int ref,
    170                               MV ref_mv_full, int num_planes, int use_subpixel);
    171 
    172 // Performs a simple motion search to calculate the sse and var of the residue
    173 void av1_simple_motion_sse_var(struct AV1_COMP *cpi, MACROBLOCK *x, int mi_row,
    174                                int mi_col, BLOCK_SIZE bsize,
    175                                const MV ref_mv_full, int use_subpixel,
    176                                unsigned int *sse, unsigned int *var);
    177 
    178 static INLINE void av1_set_fractional_mv(int_mv *fractional_best_mv) {
    179   for (int z = 0; z < 3; z++) {
    180     fractional_best_mv[z].as_int = INVALID_MV;
    181   }
    182 }
    183 
    184 #ifdef __cplusplus
    185 }  // extern "C"
    186 #endif
    187 
    188 #endif  // AOM_AV1_ENCODER_MCOMP_H_
    189