ref: 476d73d2949777f105a346d7141dc1e2b04f6a97
parent: 1f94b976947e573258fdcf6648bdef3498cbd662
author: Jim Bankoski <[email protected]>
date: Thu Jun 20 03:17:01 EDT 2013
partition by variance using var from last frame This uses variance to split partition. Variance is calculated using nearest mv, always from last ref frame. Change-Id: Idd015b4a9aa3bc82591759eac239680c07496896
--- a/vp9/encoder/vp9_encodeframe.c
+++ b/vp9/encoder/vp9_encodeframe.c
@@ -1130,7 +1130,7 @@
setup_pre_planes(xd, ref_fb, second_ref_fb, mi_row, mi_col,
xd->scale_factor, xd->scale_factor_uv);
- m->mbmi.ref_frame[0] = LAST_FRAME;
+ xd->mode_info_context->mbmi.ref_frame[0] = LAST_FRAME;
xd->mode_info_context->mbmi.sb_type = BLOCK_SIZE_SB64X64;
vp9_find_best_ref_mvs(xd, m->mbmi.ref_mvs[m->mbmi.ref_frame[0]], &nearest,
&near);
@@ -1500,28 +1500,33 @@
for (mi_col = cm->cur_tile_mi_col_start; mi_col < cm->cur_tile_mi_col_end;
mi_col += 64 / MI_SIZE) {
int dummy_rate, dummy_dist;
- if (!cpi->sf.use_lastframe_partitioning) {
- rd_pick_partition(cpi, tp, mi_row, mi_col, BLOCK_SIZE_SB64X64,
- &dummy_rate, &dummy_dist);
- } else {
-
+ if (cpi->sf.partition_by_variance || cpi->sf.use_lastframe_partitioning) {
const int idx_str = cm->mode_info_stride * mi_row + mi_col;
MODE_INFO *m = cm->mi + idx_str;
MODE_INFO *p = cm->prev_mi + idx_str;
- if ((cpi->common.current_video_frame & 1) == 0 || cm->prev_mi == 0
- || cpi->common.show_frame == 0 || cpi->common.frame_type == KEY_FRAME
- || cpi->is_src_frame_alt_ref) {
- rd_pick_partition(cpi, tp, mi_row, mi_col, BLOCK_SIZE_SB64X64,
- &dummy_rate, &dummy_dist);
- } else {
- // set_partitioning(cpi, m, BLOCK_SIZE_SB64X64);
- // choose_partitioning(cpi, cm->mi, mi_row, mi_col);
-
- copy_partitioning(cpi, m, p);
+ if (cpi->sf.partition_by_variance) {
+ choose_partitioning(cpi, cm->mi, mi_row, mi_col);
rd_use_partition(cpi, m, tp, mi_row, mi_col, BLOCK_SIZE_SB64X64,
&dummy_rate, &dummy_dist);
+ } else {
+ if ((cpi->common.current_video_frame & 1) == 0 || cm->prev_mi == 0
+ || cpi->common.show_frame == 0
+ || cpi->common.frame_type == KEY_FRAME
+ || cpi->is_src_frame_alt_ref) {
+ rd_pick_partition(cpi, tp, mi_row, mi_col, BLOCK_SIZE_SB64X64,
+ &dummy_rate, &dummy_dist);
+ } else {
+ // set_partitioning(cpi, m, BLOCK_SIZE_SB64X64);
+
+ copy_partitioning(cpi, m, p);
+ rd_use_partition(cpi, m, tp, mi_row, mi_col, BLOCK_SIZE_SB64X64,
+ &dummy_rate, &dummy_dist);
+ }
}
+ } else {
+ rd_pick_partition(cpi, tp, mi_row, mi_col, BLOCK_SIZE_SB64X64,
+ &dummy_rate, &dummy_dist);
}
}
}
--- a/vp9/encoder/vp9_onyx_if.c
+++ b/vp9/encoder/vp9_onyx_if.c
@@ -539,9 +539,6 @@
int speed_multiplier = speed + 1;
int i;
- if (speed == 2)
- speed_multiplier = 1;
-
// Set baseline threshold values
for (i = 0; i < MAX_MODES; ++i)
sf->thresh_mult[i] = mode == 0 ? -500 : 0;
@@ -693,6 +690,7 @@
sf->use_avoid_tested_higherror = 0;
sf->skip_lots_of_modes = 0;
sf->adjust_thresholds_by_speed = 0;
+ sf->partition_by_variance = 0;
#if CONFIG_MULTIPLE_ARF
// Switch segmentation off.
@@ -725,7 +723,11 @@
sf->use_lastframe_partitioning = 1;
sf->first_step = 0;
}
-
+ if (speed == 3) {
+ sf->comp_inter_joint_search_thresh = BLOCK_SIZE_SB8X8;
+ sf->partition_by_variance = 1;
+ sf->first_step = 0;
+ }
break;
}; /* switch */
--- a/vp9/encoder/vp9_onyx_int.h
+++ b/vp9/encoder/vp9_onyx_int.h
@@ -222,6 +222,7 @@
int use_avoid_tested_higherror;
int skip_lots_of_modes;
int adjust_thresholds_by_speed;
+ int partition_by_variance;
} SPEED_FEATURES;
enum BlockSize {