diff options
author | Paul Wilkins <paulwilkins@google.com> | 2011-11-11 10:10:06 +0000 |
---|---|---|
committer | Paul Wilkins <paulwilkins@google.com> | 2011-11-11 18:31:21 +0000 |
commit | bf25d4ad7f5f9c7b11894be140783da8ee640494 (patch) | |
tree | 187c1337db487b987bf9dd6ad8e81fadab4fdd8f /vp8/encoder/segmentation.c | |
parent | e01b39254b7289f124b2ba2b0fcdfb1e64aadd0c (diff) | |
download | libvpx-bf25d4ad7f5f9c7b11894be140783da8ee640494.tar libvpx-bf25d4ad7f5f9c7b11894be140783da8ee640494.tar.gz libvpx-bf25d4ad7f5f9c7b11894be140783da8ee640494.tar.bz2 libvpx-bf25d4ad7f5f9c7b11894be140783da8ee640494.zip |
SEGMENTATION experiment:
Some initial cleanup to aid testing and debug.
Pull code to choose temporal or spatial encoding
out of encodeframe.c into a dedicated function
in segmentation.c.
For now disable broken temporal mode.
Move the coding of "temporal_update" flag and
only transmit if segment map update is indicated.
Rename the functions read_mb_features() and
write_mb_features() to read_mb_segid() and
read_mb_segid() as they only read and write
the macroblock segment id not any of the
features.
Change-Id: Ib75118520b1144c24d35fdfc6ce46106803cabcf
Diffstat (limited to 'vp8/encoder/segmentation.c')
-rw-r--r-- | vp8/encoder/segmentation.c | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/vp8/encoder/segmentation.c b/vp8/encoder/segmentation.c index 752053dd9..ac8611ef6 100644 --- a/vp8/encoder/segmentation.c +++ b/vp8/encoder/segmentation.c @@ -114,3 +114,129 @@ void vp8_set_segment_data(VP8_PTR ptr, // vpx_memcpy(cpi->mb.e_mbd.segment_feature_mask, 0, // sizeof(cpi->mb.e_mbd.segment_feature_mask)); } + +#if CONFIG_SEGMENTATION +void choose_segmap_coding_method( VP8_COMP *cpi, + int * segment_counts ) +{ + VP8_COMMON *const cm = & cpi->common; + MACROBLOCKD *const xd = & cpi->mb.e_mbd; + + int tot_count; + int i; + int count1,count2,count3,count4; + int prob[3]; + int new_cost, original_cost; + + // Select the coding strategy for the segment map (temporal or spatial) + tot_count = segment_counts[12] + segment_counts[13] + + segment_counts[14] + segment_counts[15]; + count1 = segment_counts[12] + segment_counts[13]; + count2 = segment_counts[14] + segment_counts[15]; + + if (tot_count) + prob[0] = (count1 * 255) / tot_count; + + if (count1 > 0) + prob[1] = (segment_counts[12] * 255) /count1; + + if (count2 > 0) + prob[2] = (segment_counts[14] * 255) /count2; + + if (cm->frame_type != KEY_FRAME) + { + tot_count = segment_counts[4] + segment_counts[7]; + if (tot_count) + xd->mb_segment_tree_probs[3] = (segment_counts[4] * 255)/tot_count; + + tot_count = segment_counts[5] + segment_counts[8]; + if (tot_count) + xd->mb_segment_tree_probs[4] = (segment_counts[5] * 255)/tot_count; + + tot_count = segment_counts[6] + segment_counts[9]; + if (tot_count) + xd->mb_segment_tree_probs[5] = (segment_counts[6] * 255)/tot_count; + } + + tot_count = segment_counts[0] + segment_counts[1] + + segment_counts[2] + segment_counts[3]; + count3 = segment_counts[0] + segment_counts[1]; + count4 = segment_counts[2] + segment_counts[3]; + + if (tot_count) + xd->mb_segment_tree_probs[0] = (count3 * 255) / tot_count; + + if (count3 > 0) + xd->mb_segment_tree_probs[1] = (segment_counts[0] * 255) /count3; + + if (count4 > 0) + xd->mb_segment_tree_probs[2] = (segment_counts[2] * 255) /count4; + + for (i = 0; i < MB_FEATURE_TREE_PROBS+3; i++) + { + if (xd->mb_segment_tree_probs[i] == 0) + xd->mb_segment_tree_probs[i] = 1; + } + + original_cost = count1 * vp8_cost_zero(prob[0]) + + count2 * vp8_cost_one(prob[0]); + + if (count1 > 0) + original_cost += segment_counts[12] * vp8_cost_zero(prob[1]) + + segment_counts[13] * vp8_cost_one(prob[1]); + + if (count2 > 0) + original_cost += segment_counts[14] * vp8_cost_zero(prob[2]) + + segment_counts[15] * vp8_cost_one(prob[2]) ; + + new_cost = 0; + + if (cm->frame_type != KEY_FRAME) + { + new_cost = segment_counts[4] * + vp8_cost_zero(xd->mb_segment_tree_probs[3]) + + segment_counts[7] * + vp8_cost_one(xd->mb_segment_tree_probs[3]); + + new_cost += segment_counts[5] * + vp8_cost_zero(xd->mb_segment_tree_probs[4]) + + segment_counts[8] * + vp8_cost_one(xd->mb_segment_tree_probs[4]); + + new_cost += segment_counts[6] * + vp8_cost_zero(xd->mb_segment_tree_probs[5]) + + segment_counts[9] * + vp8_cost_one (xd->mb_segment_tree_probs[5]); + } + + if (tot_count > 0) + new_cost += count3 * vp8_cost_zero(xd->mb_segment_tree_probs[0]) + + count4 * vp8_cost_one(xd->mb_segment_tree_probs[0]); + + if (count3 > 0) + new_cost += segment_counts[0] * + vp8_cost_zero(xd->mb_segment_tree_probs[1]) + + segment_counts[1] * + vp8_cost_one(xd->mb_segment_tree_probs[1]); + + if (count4 > 0) + new_cost += segment_counts[2] * + vp8_cost_zero(xd->mb_segment_tree_probs[2]) + + segment_counts[3] * + vp8_cost_one(xd->mb_segment_tree_probs[2]) ; + + if (new_cost < original_cost) + xd->temporal_update = 1; + else + { + xd->temporal_update = 0; + xd->mb_segment_tree_probs[0] = prob[0]; + xd->mb_segment_tree_probs[1] = prob[1]; + xd->mb_segment_tree_probs[2] = prob[2]; + } + + // ***** TODO + // PGW temp test code fix value as spatial + xd->temporal_update = 0; +} +#endif |