Changes to adaptive inter rd thresholds.
Values now carried over frame to frame. Change to algorithm for decreasing threshold after a hit and to max threshold (now based on speed) Removed some old commented out code relating to VP8 adaptive thresholds. The impact of these changes tested on Akiyo (50 frames) and measured in terms of unit rd hits is as follows: Speed 0 84.36 -> 84.67 Speed 1 29.48 -> 22.22 Speed 2 11.76 -> 8.21 Speed 3 12.32 -> 7.21 Encode speed impact is broadly in line with these. Change-Id: I5b886efee3077a11553fa950d796fd6d00c8cb19
This commit is contained in:
		| @@ -766,7 +766,7 @@ void vp9_set_speed_features(VP9_COMP *cpi) { | |||||||
|       sf->static_segmentation = 0; |       sf->static_segmentation = 0; | ||||||
| #endif | #endif | ||||||
|       sf->use_avoid_tested_higherror = 1; |       sf->use_avoid_tested_higherror = 1; | ||||||
|       sf->adaptive_rd_thresh = 1; |       sf->adaptive_rd_thresh = MIN((speed + 1), 4); | ||||||
|  |  | ||||||
|       if (speed == 1) { |       if (speed == 1) { | ||||||
|         sf->comp_inter_joint_search_thresh = BLOCK_SIZES; |         sf->comp_inter_joint_search_thresh = BLOCK_SIZES; | ||||||
| @@ -1402,7 +1402,7 @@ static void cal_nmvsadcosts_hp(int *mvsadcost[2]) { | |||||||
| } | } | ||||||
|  |  | ||||||
| VP9_PTR vp9_create_compressor(VP9_CONFIG *oxcf) { | VP9_PTR vp9_create_compressor(VP9_CONFIG *oxcf) { | ||||||
|   int i; |   int i, j; | ||||||
|   volatile union { |   volatile union { | ||||||
|     VP9_COMP *cpi; |     VP9_COMP *cpi; | ||||||
|     VP9_PTR   ptr; |     VP9_PTR   ptr; | ||||||
| @@ -1604,9 +1604,10 @@ VP9_PTR vp9_create_compressor(VP9_CONFIG *oxcf) { | |||||||
|  |  | ||||||
|   vp9_set_speed_features(cpi); |   vp9_set_speed_features(cpi); | ||||||
|  |  | ||||||
|   // Set starting values of RD threshold multipliers (128 = *1) |   // Default rd threshold factors for mode selection | ||||||
|   for (i = 0; i < MAX_MODES; i++) |   for (i = 0; i < BLOCK_SIZES; ++i) | ||||||
|     cpi->rd_thresh_mult[i] = 128; |     for (j = 0; j < MAX_MODES; ++j) | ||||||
|  |       cpi->rd_thresh_freq_fact[i][j] = 32; | ||||||
|  |  | ||||||
| #define BFP(BT, SDF, SDAF, VF, SVF, SVAF, SVFHH, SVFHV, SVFHHV, \ | #define BFP(BT, SDF, SDAF, VF, SVF, SVAF, SVFHH, SVFHV, SVFHHV, \ | ||||||
|             SDX3F, SDX8F, SDX4DF)\ |             SDX3F, SDX8F, SDX4DF)\ | ||||||
| @@ -2636,8 +2637,6 @@ static void encode_frame_to_data_rate(VP9_COMP *cpi, | |||||||
|  |  | ||||||
|   // Set various flags etc to special state if it is a key frame |   // Set various flags etc to special state if it is a key frame | ||||||
|   if (cm->frame_type == KEY_FRAME) { |   if (cm->frame_type == KEY_FRAME) { | ||||||
|     int i; |  | ||||||
|  |  | ||||||
|     // Reset the loop filter deltas and segmentation map |     // Reset the loop filter deltas and segmentation map | ||||||
|     setup_features(cm); |     setup_features(cm); | ||||||
|  |  | ||||||
| @@ -2650,10 +2649,6 @@ static void encode_frame_to_data_rate(VP9_COMP *cpi, | |||||||
|     // The alternate reference frame cannot be active for a key frame |     // The alternate reference frame cannot be active for a key frame | ||||||
|     cpi->source_alt_ref_active = 0; |     cpi->source_alt_ref_active = 0; | ||||||
|  |  | ||||||
|     // Reset the RD threshold multipliers to default of * 1 (128) |  | ||||||
|     for (i = 0; i < MAX_MODES; i++) |  | ||||||
|       cpi->rd_thresh_mult[i] = 128; |  | ||||||
|  |  | ||||||
|     cm->error_resilient_mode = (cpi->oxcf.error_resilient_mode != 0); |     cm->error_resilient_mode = (cpi->oxcf.error_resilient_mode != 0); | ||||||
|     cm->frame_parallel_decoding_mode = |     cm->frame_parallel_decoding_mode = | ||||||
|       (cpi->oxcf.frame_parallel_decoding_mode != 0); |       (cpi->oxcf.frame_parallel_decoding_mode != 0); | ||||||
|   | |||||||
| @@ -381,8 +381,6 @@ typedef struct VP9_COMP { | |||||||
|   int ref_frame_mask; |   int ref_frame_mask; | ||||||
|   int set_ref_frame_mask; |   int set_ref_frame_mask; | ||||||
|  |  | ||||||
|   int rd_thresh_mult[MAX_MODES]; |  | ||||||
|   int rd_baseline_thresh[BLOCK_SIZES][MAX_MODES]; |  | ||||||
|   int rd_threshes[BLOCK_SIZES][MAX_MODES]; |   int rd_threshes[BLOCK_SIZES][MAX_MODES]; | ||||||
|   int rd_thresh_freq_fact[BLOCK_SIZES][MAX_MODES]; |   int rd_thresh_freq_fact[BLOCK_SIZES][MAX_MODES]; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -104,9 +104,8 @@ const MODE_DEFINITION vp9_mode_order[MAX_MODES] = { | |||||||
| static int rd_thresh_block_size_factor[BLOCK_SIZES] = | static int rd_thresh_block_size_factor[BLOCK_SIZES] = | ||||||
|   {2, 3, 3, 4, 6, 6, 8, 12, 12, 16, 24, 24, 32}; |   {2, 3, 3, 4, 6, 6, 8, 12, 12, 16, 24, 24, 32}; | ||||||
|  |  | ||||||
| #define BASE_RD_THRESH_FREQ_FACT 16 | #define MAX_RD_THRESH_FACT 64 | ||||||
| #define MAX_RD_THRESH_FREQ_FACT 32 | #define RD_THRESH_INC 1 | ||||||
| #define MAX_RD_THRESH_FREQ_INC 1 |  | ||||||
|  |  | ||||||
| static void fill_token_costs(vp9_coeff_cost *c, | static void fill_token_costs(vp9_coeff_cost *c, | ||||||
|                              vp9_coeff_probs_model (*p)[BLOCK_TYPES]) { |                              vp9_coeff_probs_model (*p)[BLOCK_TYPES]) { | ||||||
| @@ -212,12 +211,6 @@ void vp9_initialize_rd_consts(VP9_COMP *cpi, int qindex) { | |||||||
|         } else { |         } else { | ||||||
|           cpi->rd_threshes[bsize][i] = INT_MAX; |           cpi->rd_threshes[bsize][i] = INT_MAX; | ||||||
|         } |         } | ||||||
|         cpi->rd_baseline_thresh[bsize][i] = cpi->rd_threshes[bsize][i]; |  | ||||||
|  |  | ||||||
|         if (cpi->sf.adaptive_rd_thresh) |  | ||||||
|           cpi->rd_thresh_freq_fact[bsize][i] = MAX_RD_THRESH_FREQ_FACT; |  | ||||||
|         else |  | ||||||
|           cpi->rd_thresh_freq_fact[bsize][i] = BASE_RD_THRESH_FREQ_FACT; |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } else { |   } else { | ||||||
| @@ -236,12 +229,6 @@ void vp9_initialize_rd_consts(VP9_COMP *cpi, int qindex) { | |||||||
|         } else { |         } else { | ||||||
|           cpi->rd_threshes[bsize][i] = INT_MAX; |           cpi->rd_threshes[bsize][i] = INT_MAX; | ||||||
|         } |         } | ||||||
|         cpi->rd_baseline_thresh[bsize][i] = cpi->rd_threshes[bsize][i]; |  | ||||||
|  |  | ||||||
|         if (cpi->sf.adaptive_rd_thresh) |  | ||||||
|           cpi->rd_thresh_freq_fact[bsize][i] = MAX_RD_THRESH_FREQ_FACT; |  | ||||||
|         else |  | ||||||
|           cpi->rd_thresh_freq_fact[bsize][i] = BASE_RD_THRESH_FREQ_FACT; |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -3228,7 +3215,7 @@ int64_t vp9_rd_pick_inter_mode_sb(VP9_COMP *cpi, MACROBLOCK *x, | |||||||
|  |  | ||||||
|     // Test best rd so far against threshold for trying this mode. |     // Test best rd so far against threshold for trying this mode. | ||||||
|     if ((best_rd < ((cpi->rd_threshes[bsize][mode_index] * |     if ((best_rd < ((cpi->rd_threshes[bsize][mode_index] * | ||||||
|                      cpi->rd_thresh_freq_fact[bsize][mode_index]) >> 4)) || |                      cpi->rd_thresh_freq_fact[bsize][mode_index]) >> 5)) || | ||||||
|         cpi->rd_threshes[bsize][mode_index] == INT_MAX) |         cpi->rd_threshes[bsize][mode_index] == INT_MAX) | ||||||
|       continue; |       continue; | ||||||
|  |  | ||||||
| @@ -3789,29 +3776,6 @@ int64_t vp9_rd_pick_inter_mode_sb(VP9_COMP *cpi, MACROBLOCK *x, | |||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| #if 0 |  | ||||||
|       // Testing this mode gave rise to an improvement in best error score. |  | ||||||
|       // Lower threshold a bit for next time |  | ||||||
|       cpi->rd_thresh_mult[mode_index] = |  | ||||||
|           (cpi->rd_thresh_mult[mode_index] >= (MIN_THRESHMULT + 2)) ? |  | ||||||
|               cpi->rd_thresh_mult[mode_index] - 2 : MIN_THRESHMULT; |  | ||||||
|       cpi->rd_threshes[mode_index] = |  | ||||||
|           (cpi->rd_baseline_thresh[mode_index] >> 7) |  | ||||||
|               * cpi->rd_thresh_mult[mode_index]; |  | ||||||
| #endif |  | ||||||
|     } else { |  | ||||||
|       // If the mode did not help improve the best error case then |  | ||||||
|       // raise the threshold for testing that mode next time around. |  | ||||||
| #if 0 |  | ||||||
|       cpi->rd_thresh_mult[mode_index] += 4; |  | ||||||
|  |  | ||||||
|       if (cpi->rd_thresh_mult[mode_index] > MAX_THRESHMULT) |  | ||||||
|         cpi->rd_thresh_mult[mode_index] = MAX_THRESHMULT; |  | ||||||
|  |  | ||||||
|       cpi->rd_threshes[mode_index] = |  | ||||||
|           (cpi->rd_baseline_thresh[mode_index] >> 7) |  | ||||||
|               * cpi->rd_thresh_mult[mode_index]; |  | ||||||
| #endif |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /* keep record of best compound/single-only prediction */ |     /* keep record of best compound/single-only prediction */ | ||||||
| @@ -3954,33 +3918,19 @@ int64_t vp9_rd_pick_inter_mode_sb(VP9_COMP *cpi, MACROBLOCK *x, | |||||||
|   if (cpi->sf.adaptive_rd_thresh) { |   if (cpi->sf.adaptive_rd_thresh) { | ||||||
|     for (mode_index = 0; mode_index < MAX_MODES; ++mode_index) { |     for (mode_index = 0; mode_index < MAX_MODES; ++mode_index) { | ||||||
|       if (mode_index == best_mode_index) { |       if (mode_index == best_mode_index) { | ||||||
|         cpi->rd_thresh_freq_fact[bsize][mode_index] = BASE_RD_THRESH_FREQ_FACT; |         cpi->rd_thresh_freq_fact[bsize][mode_index] -= | ||||||
|  |           (cpi->rd_thresh_freq_fact[bsize][mode_index] >> 3); | ||||||
|       } else { |       } else { | ||||||
|         cpi->rd_thresh_freq_fact[bsize][mode_index] += MAX_RD_THRESH_FREQ_INC; |         cpi->rd_thresh_freq_fact[bsize][mode_index] += RD_THRESH_INC; | ||||||
|         if (cpi->rd_thresh_freq_fact[bsize][mode_index] > |         if (cpi->rd_thresh_freq_fact[bsize][mode_index] > | ||||||
|             (cpi->sf.adaptive_rd_thresh * MAX_RD_THRESH_FREQ_FACT)) { |             (cpi->sf.adaptive_rd_thresh * MAX_RD_THRESH_FACT)) { | ||||||
|           cpi->rd_thresh_freq_fact[bsize][mode_index] = |           cpi->rd_thresh_freq_fact[bsize][mode_index] = | ||||||
|             cpi->sf.adaptive_rd_thresh * MAX_RD_THRESH_FREQ_FACT; |             cpi->sf.adaptive_rd_thresh * MAX_RD_THRESH_FACT; | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // TODO(rbultje) integrate with RD trd_thresh_freq_facthresholding |  | ||||||
| #if 0 |  | ||||||
|   // Reduce the activation RD thresholds for the best choice mode |  | ||||||
|   if ((cpi->rd_baseline_thresh[best_mode_index] > 0) && |  | ||||||
|       (cpi->rd_baseline_thresh[best_mode_index] < (INT_MAX >> 2))) { |  | ||||||
|     int best_adjustment = (cpi->rd_thresh_mult[best_mode_index] >> 2); |  | ||||||
|  |  | ||||||
|     cpi->rd_thresh_mult[best_mode_index] = |  | ||||||
|       (cpi->rd_thresh_mult[best_mode_index] >= (MIN_THRESHMULT + best_adjustment)) ? |  | ||||||
|       cpi->rd_thresh_mult[best_mode_index] - best_adjustment : MIN_THRESHMULT; |  | ||||||
|     cpi->rd_threshes[best_mode_index] = |  | ||||||
|       (cpi->rd_baseline_thresh[best_mode_index] >> 7) * cpi->rd_thresh_mult[best_mode_index]; |  | ||||||
|   } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|   // macroblock modes |   // macroblock modes | ||||||
|   *mbmi = best_mbmode; |   *mbmi = best_mbmode; | ||||||
|   x->skip |= best_skip2; |   x->skip |= best_skip2; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Paul Wilkins
					Paul Wilkins