• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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_VAR_BASED_PART_H_
13 #define AOM_AV1_ENCODER_VAR_BASED_PART_H_
14 
15 #include <stdio.h>
16 
17 #include "config/aom_config.h"
18 #include "config/aom_dsp_rtcd.h"
19 #include "config/av1_rtcd.h"
20 
21 #include "av1/encoder/encoder.h"
22 
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
26 
27 #define QINDEX_LARGE_BLOCK_THR \
28   100  // Use increased thresholds for midres for speed 9 when qindex is above
29        // this threshold
30 
31 #define CALC_CHROMA_THRESH_FOR_ZEROMV_SKIP(thresh_exit_part) \
32   ((3 * (thresh_exit_part)) >> 2)
33 /*!\brief Set the thresholds for variance based partition.
34  *
35  * Set the variance split thresholds for following the block sizes:
36  * 0 - threshold_128x128, 1 - threshold_64x64, 2 - threshold_32x32,
37  * 3 - vbp_threshold_16x16. 4 - vbp_threshold_8x8 (to split to 4x4 partition) is
38  * currently only used on key frame. The thresholds are based om Q, resolution,
39  * noise level, and content state.
40  *
41  * \ingroup variance_partition
42  * \callgraph
43  * \callergraph
44  *
45  * \param[in]      cpi                Top level encoder structure
46  * \param[in]      q                  q index
47  * \param[in]      content_lowsumdiff Low sumdiff flag for superblock
48  *
49  * \remark Returns the set of thresholds in \c cpi->vbp_info.thresholds.
50  */
51 void av1_set_variance_partition_thresholds(AV1_COMP *cpi, int q,
52                                            int content_lowsumdiff);
53 
54 /*!\brief Variance based partition selection.
55  *
56  * Select the partitioning based on the variance of the residual signal,
57  * residual generated as the difference between the source and prediction.
58  * The prediction is the reconstructed LAST or reconstructed GOLDEN, whichever
59  * has lower y sad. For LAST, option exists (speed feature) to use motion
60  * compensation based on superblock motion via int_pro_motion_estimation. For
61  * key frames reference is fixed 128 level, so variance is the source variance.
62  * The variance is computed for downsampled inputs (8x8 or 4x4 downsampled),
63  * and selection is done top-down via as set of partition thresholds. defined
64  * for each block level, and set based on Q, resolution, noise level, and
65  * content state.
66  *
67  * \ingroup variance_partition
68  * \callgraph
69  * \callergraph
70  *
71  * \param[in]       cpi          Top level encoder structure
72  * \param[in]       tile         Pointer to TileInfo
73  * \param[in]       td           Pointer to ThreadData
74  * \param[in]       x            Pointer to MACROBLOCK
75  * \param[in]       mi_row       Row coordinate of the superblock in a step
76  size of MI_SIZE
77  * \param[in]       mi_col       Column coordinate of the super block in a step
78  size of MI_SIZE
79  *
80  * \return Returns the partition in \c xd->mi[0]->sb_type. Also sets the low
81  * temporal variance flag and the color sensitivity flag (both used in
82  * nonrd_pickmode).
83  */
84 int av1_choose_var_based_partitioning(AV1_COMP *cpi, const TileInfo *const tile,
85                                       ThreadData *td, MACROBLOCK *x, int mi_row,
86                                       int mi_col);
87 
88 // Read out the block's temporal variance for 64x64 SB case.
89 int av1_get_force_skip_low_temp_var_small_sb(const uint8_t *variance_low,
90                                              int mi_row, int mi_col,
91                                              BLOCK_SIZE bsize);
92 // Read out the block's temporal variance for 128x128 SB case.
93 int av1_get_force_skip_low_temp_var(const uint8_t *variance_low, int mi_row,
94                                     int mi_col, BLOCK_SIZE bsize);
95 
96 #ifdef __cplusplus
97 }  // extern "C"
98 #endif
99 
100 #endif  // AOM_AV1_ENCODER_VAR_BASED_PART_H_
101