ref: 68805583e9544f14ebe72583bcc5b788f8da6c7f
parent: 853165ba3971983cf3b32f909207413a85af39ed
parent: 427de67e631244c2b469e922cef07e1583f4b097
author: Marco Paniconi <marpan@google.com>
date: Tue Aug 8 19:08:10 EDT 2017
Merge "vp9: Partition logic adjustment for speed 6 feature."
--- a/vp9/encoder/vp9_encodeframe.c
+++ b/vp9/encoder/vp9_encodeframe.c
@@ -3650,6 +3650,9 @@
!force_horz_split && xss <= yss && bsize >= BLOCK_8X8;
(void)*tp_orig;
+ // Avoid checking for rectangular partitions for speed >= 6.
+ if (cpi->oxcf.speed >= 6) do_rect = 0;
+
assert(num_8x8_blocks_wide_lookup[bsize] ==
num_8x8_blocks_high_lookup[bsize]);
@@ -3877,6 +3880,8 @@
PARTITION_TYPE partition;
BLOCK_SIZE subsize;
RD_COST this_rdc;
+ BLOCK_SIZE subsize_ref =
+ (cpi->sf.adapt_partition_source_sad) ? BLOCK_8X8 : BLOCK_16X16;
vp9_rd_cost_reset(&this_rdc);
if (mi_row >= cm->mi_rows || mi_col >= cm->mi_cols) return;
@@ -3890,7 +3895,7 @@
nonrd_pick_partition(cpi, td, tile_data, tp, mi_row, mi_col, bsize, rd_cost,
0, INT64_MAX, pc_tree);
} else if (bsize == BLOCK_32X32 && partition != PARTITION_NONE &&
- subsize >= BLOCK_16X16) {
+ subsize >= subsize_ref) {
x->max_partition_size = BLOCK_32X32;
x->min_partition_size = BLOCK_8X8;
nonrd_pick_partition(cpi, td, tile_data, tp, mi_row, mi_col, bsize, rd_cost,