1 /*
2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11
12 #include "vpx_config.h"
13 #include "./vpx_scale_rtcd.h"
14 #include "vp8/common/onyxc_int.h"
15 #include "vp8/common/blockd.h"
16 #include "onyx_int.h"
17 #include "vp8/common/systemdependent.h"
18 #include "quantize.h"
19 #include "vp8/common/alloccommon.h"
20 #include "mcomp.h"
21 #include "firstpass.h"
22 #include "vpx/internal/vpx_psnr.h"
23 #include "vpx_scale/vpx_scale.h"
24 #include "vp8/common/extend.h"
25 #include "ratectrl.h"
26 #include "vp8/common/quant_common.h"
27 #include "segmentation.h"
28 #if CONFIG_POSTPROC
29 #include "vp8/common/postproc.h"
30 #endif
31 #include "vpx_mem/vpx_mem.h"
32 #include "vp8/common/swapyv12buffer.h"
33 #include "vp8/common/threading.h"
34 #include "vpx_ports/vpx_timer.h"
35 #if ARCH_ARM
36 #include "vpx_ports/arm.h"
37 #endif
38 #if CONFIG_MULTI_RES_ENCODING
39 #include "mr_dissim.h"
40 #endif
41 #include "encodeframe.h"
42
43 #include <math.h>
44 #include <stdio.h>
45 #include <limits.h>
46
47 #if CONFIG_REALTIME_ONLY & CONFIG_ONTHEFLY_BITPACKING
48 extern int vp8_update_coef_context(VP8_COMP *cpi);
49 extern void vp8_update_coef_probs(VP8_COMP *cpi);
50 #endif
51
52 extern void vp8cx_pick_filter_level_fast(YV12_BUFFER_CONFIG *sd, VP8_COMP *cpi);
53 extern void vp8cx_set_alt_lf_level(VP8_COMP *cpi, int filt_val);
54 extern void vp8cx_pick_filter_level(YV12_BUFFER_CONFIG *sd, VP8_COMP *cpi);
55
56 extern void vp8_deblock_frame(YV12_BUFFER_CONFIG *source, YV12_BUFFER_CONFIG *post, int filt_lvl, int low_var_thresh, int flag);
57 extern void print_parms(VP8_CONFIG *ocf, char *filenam);
58 extern unsigned int vp8_get_processor_freq();
59 extern void print_tree_update_probs();
60 extern int vp8cx_create_encoder_threads(VP8_COMP *cpi);
61 extern void vp8cx_remove_encoder_threads(VP8_COMP *cpi);
62
63 int vp8_estimate_entropy_savings(VP8_COMP *cpi);
64
65 int vp8_calc_ss_err(YV12_BUFFER_CONFIG *source, YV12_BUFFER_CONFIG *dest);
66
67 extern void vp8_temporal_filter_prepare_c(VP8_COMP *cpi, int distance);
68
69 static void set_default_lf_deltas(VP8_COMP *cpi);
70
71 extern const int vp8_gf_interval_table[101];
72
73 #if CONFIG_INTERNAL_STATS
74 #include "math.h"
75
76 extern double vp8_calc_ssim
77 (
78 YV12_BUFFER_CONFIG *source,
79 YV12_BUFFER_CONFIG *dest,
80 int lumamask,
81 double *weight
82 );
83
84
85 extern double vp8_calc_ssimg
86 (
87 YV12_BUFFER_CONFIG *source,
88 YV12_BUFFER_CONFIG *dest,
89 double *ssim_y,
90 double *ssim_u,
91 double *ssim_v
92 );
93
94
95 #endif
96
97
98 #ifdef OUTPUT_YUV_SRC
99 FILE *yuv_file;
100 #endif
101
102 #if 0
103 FILE *framepsnr;
104 FILE *kf_list;
105 FILE *keyfile;
106 #endif
107
108 #if 0
109 extern int skip_true_count;
110 extern int skip_false_count;
111 #endif
112
113
114 #ifdef VP8_ENTROPY_STATS
115 extern int intra_mode_stats[10][10][10];
116 #endif
117
118 #ifdef SPEEDSTATS
119 unsigned int frames_at_speed[16] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
120 unsigned int tot_pm = 0;
121 unsigned int cnt_pm = 0;
122 unsigned int tot_ef = 0;
123 unsigned int cnt_ef = 0;
124 #endif
125
126 #ifdef MODE_STATS
127 extern unsigned __int64 Sectionbits[50];
128 extern int y_modes[5] ;
129 extern int uv_modes[4] ;
130 extern int b_modes[10] ;
131
132 extern int inter_y_modes[10] ;
133 extern int inter_uv_modes[4] ;
134 extern unsigned int inter_b_modes[15];
135 #endif
136
137 extern const int vp8_bits_per_mb[2][QINDEX_RANGE];
138
139 extern const int qrounding_factors[129];
140 extern const int qzbin_factors[129];
141 extern void vp8cx_init_quantizer(VP8_COMP *cpi);
142 extern const int vp8cx_base_skip_false_prob[128];
143
144 /* Tables relating active max Q to active min Q */
145 static const unsigned char kf_low_motion_minq[QINDEX_RANGE] =
146 {
147 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
148 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
149 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
150 0,0,0,0,1,1,1,1,1,1,1,1,2,2,2,2,
151 3,3,3,3,3,3,4,4,4,5,5,5,5,5,6,6,
152 6,6,7,7,8,8,8,8,9,9,10,10,10,10,11,11,
153 11,11,12,12,13,13,13,13,14,14,15,15,15,15,16,16,
154 16,16,17,17,18,18,18,18,19,20,20,21,21,22,23,23
155 };
156 static const unsigned char kf_high_motion_minq[QINDEX_RANGE] =
157 {
158 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
159 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
160 1,1,1,1,1,1,1,1,2,2,2,2,3,3,3,3,
161 3,3,3,3,4,4,4,4,5,5,5,5,5,5,6,6,
162 6,6,7,7,8,8,8,8,9,9,10,10,10,10,11,11,
163 11,11,12,12,13,13,13,13,14,14,15,15,15,15,16,16,
164 16,16,17,17,18,18,18,18,19,19,20,20,20,20,21,21,
165 21,21,22,22,23,23,24,25,25,26,26,27,28,28,29,30
166 };
167 static const unsigned char gf_low_motion_minq[QINDEX_RANGE] =
168 {
169 0,0,0,0,1,1,1,1,1,1,1,1,2,2,2,2,
170 3,3,3,3,4,4,4,4,5,5,5,5,6,6,6,6,
171 7,7,7,7,8,8,8,8,9,9,9,9,10,10,10,10,
172 11,11,12,12,13,13,14,14,15,15,16,16,17,17,18,18,
173 19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,
174 27,27,28,28,29,29,30,30,31,31,32,32,33,33,34,34,
175 35,35,36,36,37,37,38,38,39,39,40,40,41,41,42,42,
176 43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58
177 };
178 static const unsigned char gf_mid_motion_minq[QINDEX_RANGE] =
179 {
180 0,0,0,0,1,1,1,1,1,1,2,2,3,3,3,4,
181 4,4,5,5,5,6,6,6,7,7,7,8,8,8,9,9,
182 9,10,10,10,10,11,11,11,12,12,12,12,13,13,13,14,
183 14,14,15,15,16,16,17,17,18,18,19,19,20,20,21,21,
184 22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,
185 30,30,31,31,32,32,33,33,34,34,35,35,36,36,37,37,
186 38,39,39,40,40,41,41,42,42,43,43,44,45,46,47,48,
187 49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64
188 };
189 static const unsigned char gf_high_motion_minq[QINDEX_RANGE] =
190 {
191 0,0,0,0,1,1,1,1,1,2,2,2,3,3,3,4,
192 4,4,5,5,5,6,6,6,7,7,7,8,8,8,9,9,
193 9,10,10,10,11,11,12,12,13,13,14,14,15,15,16,16,
194 17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,
195 25,25,26,26,27,27,28,28,29,29,30,30,31,31,32,32,
196 33,33,34,34,35,35,36,36,37,37,38,38,39,39,40,40,
197 41,41,42,42,43,44,45,46,47,48,49,50,51,52,53,54,
198 55,56,57,58,59,60,62,64,66,68,70,72,74,76,78,80
199 };
200 static const unsigned char inter_minq[QINDEX_RANGE] =
201 {
202 0,0,1,1,2,3,3,4,4,5,6,6,7,8,8,9,
203 9,10,11,11,12,13,13,14,15,15,16,17,17,18,19,20,
204 20,21,22,22,23,24,24,25,26,27,27,28,29,30,30,31,
205 32,33,33,34,35,36,36,37,38,39,39,40,41,42,42,43,
206 44,45,46,46,47,48,49,50,50,51,52,53,54,55,55,56,
207 57,58,59,60,60,61,62,63,64,65,66,67,67,68,69,70,
208 71,72,73,74,75,75,76,77,78,79,80,81,82,83,84,85,
209 86,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100
210 };
211
212 #ifdef PACKET_TESTING
213 extern FILE *vpxlogc;
214 #endif
215
save_layer_context(VP8_COMP * cpi)216 static void save_layer_context(VP8_COMP *cpi)
217 {
218 LAYER_CONTEXT *lc = &cpi->layer_context[cpi->current_layer];
219
220 /* Save layer dependent coding state */
221 lc->target_bandwidth = cpi->target_bandwidth;
222 lc->starting_buffer_level = cpi->oxcf.starting_buffer_level;
223 lc->optimal_buffer_level = cpi->oxcf.optimal_buffer_level;
224 lc->maximum_buffer_size = cpi->oxcf.maximum_buffer_size;
225 lc->starting_buffer_level_in_ms = cpi->oxcf.starting_buffer_level_in_ms;
226 lc->optimal_buffer_level_in_ms = cpi->oxcf.optimal_buffer_level_in_ms;
227 lc->maximum_buffer_size_in_ms = cpi->oxcf.maximum_buffer_size_in_ms;
228 lc->buffer_level = cpi->buffer_level;
229 lc->bits_off_target = cpi->bits_off_target;
230 lc->total_actual_bits = cpi->total_actual_bits;
231 lc->worst_quality = cpi->worst_quality;
232 lc->active_worst_quality = cpi->active_worst_quality;
233 lc->best_quality = cpi->best_quality;
234 lc->active_best_quality = cpi->active_best_quality;
235 lc->ni_av_qi = cpi->ni_av_qi;
236 lc->ni_tot_qi = cpi->ni_tot_qi;
237 lc->ni_frames = cpi->ni_frames;
238 lc->avg_frame_qindex = cpi->avg_frame_qindex;
239 lc->rate_correction_factor = cpi->rate_correction_factor;
240 lc->key_frame_rate_correction_factor = cpi->key_frame_rate_correction_factor;
241 lc->gf_rate_correction_factor = cpi->gf_rate_correction_factor;
242 lc->zbin_over_quant = cpi->mb.zbin_over_quant;
243 lc->inter_frame_target = cpi->inter_frame_target;
244 lc->total_byte_count = cpi->total_byte_count;
245 lc->filter_level = cpi->common.filter_level;
246
247 lc->last_frame_percent_intra = cpi->last_frame_percent_intra;
248
249 memcpy (lc->count_mb_ref_frame_usage,
250 cpi->mb.count_mb_ref_frame_usage,
251 sizeof(cpi->mb.count_mb_ref_frame_usage));
252 }
253
restore_layer_context(VP8_COMP * cpi,const int layer)254 static void restore_layer_context(VP8_COMP *cpi, const int layer)
255 {
256 LAYER_CONTEXT *lc = &cpi->layer_context[layer];
257
258 /* Restore layer dependent coding state */
259 cpi->current_layer = layer;
260 cpi->target_bandwidth = lc->target_bandwidth;
261 cpi->oxcf.target_bandwidth = lc->target_bandwidth;
262 cpi->oxcf.starting_buffer_level = lc->starting_buffer_level;
263 cpi->oxcf.optimal_buffer_level = lc->optimal_buffer_level;
264 cpi->oxcf.maximum_buffer_size = lc->maximum_buffer_size;
265 cpi->oxcf.starting_buffer_level_in_ms = lc->starting_buffer_level_in_ms;
266 cpi->oxcf.optimal_buffer_level_in_ms = lc->optimal_buffer_level_in_ms;
267 cpi->oxcf.maximum_buffer_size_in_ms = lc->maximum_buffer_size_in_ms;
268 cpi->buffer_level = lc->buffer_level;
269 cpi->bits_off_target = lc->bits_off_target;
270 cpi->total_actual_bits = lc->total_actual_bits;
271 cpi->active_worst_quality = lc->active_worst_quality;
272 cpi->active_best_quality = lc->active_best_quality;
273 cpi->ni_av_qi = lc->ni_av_qi;
274 cpi->ni_tot_qi = lc->ni_tot_qi;
275 cpi->ni_frames = lc->ni_frames;
276 cpi->avg_frame_qindex = lc->avg_frame_qindex;
277 cpi->rate_correction_factor = lc->rate_correction_factor;
278 cpi->key_frame_rate_correction_factor = lc->key_frame_rate_correction_factor;
279 cpi->gf_rate_correction_factor = lc->gf_rate_correction_factor;
280 cpi->mb.zbin_over_quant = lc->zbin_over_quant;
281 cpi->inter_frame_target = lc->inter_frame_target;
282 cpi->total_byte_count = lc->total_byte_count;
283 cpi->common.filter_level = lc->filter_level;
284
285 cpi->last_frame_percent_intra = lc->last_frame_percent_intra;
286
287 memcpy (cpi->mb.count_mb_ref_frame_usage,
288 lc->count_mb_ref_frame_usage,
289 sizeof(cpi->mb.count_mb_ref_frame_usage));
290 }
291
rescale(int val,int num,int denom)292 static int rescale(int val, int num, int denom)
293 {
294 int64_t llnum = num;
295 int64_t llden = denom;
296 int64_t llval = val;
297
298 return (int)(llval * llnum / llden);
299 }
300
init_temporal_layer_context(VP8_COMP * cpi,VP8_CONFIG * oxcf,const int layer,double prev_layer_framerate)301 static void init_temporal_layer_context(VP8_COMP *cpi,
302 VP8_CONFIG *oxcf,
303 const int layer,
304 double prev_layer_framerate)
305 {
306 LAYER_CONTEXT *lc = &cpi->layer_context[layer];
307
308 lc->framerate = cpi->output_framerate / cpi->oxcf.rate_decimator[layer];
309 lc->target_bandwidth = cpi->oxcf.target_bitrate[layer] * 1000;
310
311 lc->starting_buffer_level_in_ms = oxcf->starting_buffer_level;
312 lc->optimal_buffer_level_in_ms = oxcf->optimal_buffer_level;
313 lc->maximum_buffer_size_in_ms = oxcf->maximum_buffer_size;
314
315 lc->starting_buffer_level =
316 rescale((int)(oxcf->starting_buffer_level),
317 lc->target_bandwidth, 1000);
318
319 if (oxcf->optimal_buffer_level == 0)
320 lc->optimal_buffer_level = lc->target_bandwidth / 8;
321 else
322 lc->optimal_buffer_level =
323 rescale((int)(oxcf->optimal_buffer_level),
324 lc->target_bandwidth, 1000);
325
326 if (oxcf->maximum_buffer_size == 0)
327 lc->maximum_buffer_size = lc->target_bandwidth / 8;
328 else
329 lc->maximum_buffer_size =
330 rescale((int)(oxcf->maximum_buffer_size),
331 lc->target_bandwidth, 1000);
332
333 /* Work out the average size of a frame within this layer */
334 if (layer > 0)
335 lc->avg_frame_size_for_layer =
336 (int)((cpi->oxcf.target_bitrate[layer] -
337 cpi->oxcf.target_bitrate[layer-1]) * 1000 /
338 (lc->framerate - prev_layer_framerate));
339
340 lc->active_worst_quality = cpi->oxcf.worst_allowed_q;
341 lc->active_best_quality = cpi->oxcf.best_allowed_q;
342 lc->avg_frame_qindex = cpi->oxcf.worst_allowed_q;
343
344 lc->buffer_level = lc->starting_buffer_level;
345 lc->bits_off_target = lc->starting_buffer_level;
346
347 lc->total_actual_bits = 0;
348 lc->ni_av_qi = 0;
349 lc->ni_tot_qi = 0;
350 lc->ni_frames = 0;
351 lc->rate_correction_factor = 1.0;
352 lc->key_frame_rate_correction_factor = 1.0;
353 lc->gf_rate_correction_factor = 1.0;
354 lc->inter_frame_target = 0;
355 }
356
357 // Upon a run-time change in temporal layers, reset the layer context parameters
358 // for any "new" layers. For "existing" layers, let them inherit the parameters
359 // from the previous layer state (at the same layer #). In future we may want
360 // to better map the previous layer state(s) to the "new" ones.
reset_temporal_layer_change(VP8_COMP * cpi,VP8_CONFIG * oxcf,const int prev_num_layers)361 static void reset_temporal_layer_change(VP8_COMP *cpi,
362 VP8_CONFIG *oxcf,
363 const int prev_num_layers)
364 {
365 int i;
366 double prev_layer_framerate = 0;
367 const int curr_num_layers = cpi->oxcf.number_of_layers;
368 // If the previous state was 1 layer, get current layer context from cpi.
369 // We need this to set the layer context for the new layers below.
370 if (prev_num_layers == 1)
371 {
372 cpi->current_layer = 0;
373 save_layer_context(cpi);
374 }
375 for (i = 0; i < curr_num_layers; i++)
376 {
377 LAYER_CONTEXT *lc = &cpi->layer_context[i];
378 if (i >= prev_num_layers)
379 {
380 init_temporal_layer_context(cpi, oxcf, i, prev_layer_framerate);
381 }
382 // The initial buffer levels are set based on their starting levels.
383 // We could set the buffer levels based on the previous state (normalized
384 // properly by the layer bandwidths) but we would need to keep track of
385 // the previous set of layer bandwidths (i.e., target_bitrate[i])
386 // before the layer change. For now, reset to the starting levels.
387 lc->buffer_level = cpi->oxcf.starting_buffer_level_in_ms *
388 cpi->oxcf.target_bitrate[i];
389 lc->bits_off_target = lc->buffer_level;
390 // TDOD(marpan): Should we set the rate_correction_factor and
391 // active_worst/best_quality to values derived from the previous layer
392 // state (to smooth-out quality dips/rate fluctuation at transition)?
393
394 // We need to treat the 1 layer case separately: oxcf.target_bitrate[i]
395 // is not set for 1 layer, and the restore_layer_context/save_context()
396 // are not called in the encoding loop, so we need to call it here to
397 // pass the layer context state to |cpi|.
398 if (curr_num_layers == 1)
399 {
400 lc->target_bandwidth = cpi->oxcf.target_bandwidth;
401 lc->buffer_level = cpi->oxcf.starting_buffer_level_in_ms *
402 lc->target_bandwidth / 1000;
403 lc->bits_off_target = lc->buffer_level;
404 restore_layer_context(cpi, 0);
405 }
406 prev_layer_framerate = cpi->output_framerate /
407 cpi->oxcf.rate_decimator[i];
408 }
409 }
410
setup_features(VP8_COMP * cpi)411 static void setup_features(VP8_COMP *cpi)
412 {
413 // If segmentation enabled set the update flags
414 if ( cpi->mb.e_mbd.segmentation_enabled )
415 {
416 cpi->mb.e_mbd.update_mb_segmentation_map = 1;
417 cpi->mb.e_mbd.update_mb_segmentation_data = 1;
418 }
419 else
420 {
421 cpi->mb.e_mbd.update_mb_segmentation_map = 0;
422 cpi->mb.e_mbd.update_mb_segmentation_data = 0;
423 }
424
425 cpi->mb.e_mbd.mode_ref_lf_delta_enabled = 0;
426 cpi->mb.e_mbd.mode_ref_lf_delta_update = 0;
427 vpx_memset(cpi->mb.e_mbd.ref_lf_deltas, 0, sizeof(cpi->mb.e_mbd.ref_lf_deltas));
428 vpx_memset(cpi->mb.e_mbd.mode_lf_deltas, 0, sizeof(cpi->mb.e_mbd.mode_lf_deltas));
429 vpx_memset(cpi->mb.e_mbd.last_ref_lf_deltas, 0, sizeof(cpi->mb.e_mbd.ref_lf_deltas));
430 vpx_memset(cpi->mb.e_mbd.last_mode_lf_deltas, 0, sizeof(cpi->mb.e_mbd.mode_lf_deltas));
431
432 set_default_lf_deltas(cpi);
433
434 }
435
436
437 static void dealloc_raw_frame_buffers(VP8_COMP *cpi);
438
439
dealloc_compressor_data(VP8_COMP * cpi)440 static void dealloc_compressor_data(VP8_COMP *cpi)
441 {
442 vpx_free(cpi->tplist);
443 cpi->tplist = NULL;
444
445 /* Delete last frame MV storage buffers */
446 vpx_free(cpi->lfmv);
447 cpi->lfmv = 0;
448
449 vpx_free(cpi->lf_ref_frame_sign_bias);
450 cpi->lf_ref_frame_sign_bias = 0;
451
452 vpx_free(cpi->lf_ref_frame);
453 cpi->lf_ref_frame = 0;
454
455 /* Delete sementation map */
456 vpx_free(cpi->segmentation_map);
457 cpi->segmentation_map = 0;
458
459 vpx_free(cpi->active_map);
460 cpi->active_map = 0;
461
462 vp8_de_alloc_frame_buffers(&cpi->common);
463
464 vp8_yv12_de_alloc_frame_buffer(&cpi->pick_lf_lvl_frame);
465 vp8_yv12_de_alloc_frame_buffer(&cpi->scaled_source);
466 dealloc_raw_frame_buffers(cpi);
467
468 vpx_free(cpi->tok);
469 cpi->tok = 0;
470
471 /* Structure used to monitor GF usage */
472 vpx_free(cpi->gf_active_flags);
473 cpi->gf_active_flags = 0;
474
475 /* Activity mask based per mb zbin adjustments */
476 vpx_free(cpi->mb_activity_map);
477 cpi->mb_activity_map = 0;
478
479 vpx_free(cpi->mb.pip);
480 cpi->mb.pip = 0;
481
482 #if CONFIG_MULTITHREAD
483 vpx_free(cpi->mt_current_mb_col);
484 cpi->mt_current_mb_col = NULL;
485 #endif
486 }
487
enable_segmentation(VP8_COMP * cpi)488 static void enable_segmentation(VP8_COMP *cpi)
489 {
490 /* Set the appropriate feature bit */
491 cpi->mb.e_mbd.segmentation_enabled = 1;
492 cpi->mb.e_mbd.update_mb_segmentation_map = 1;
493 cpi->mb.e_mbd.update_mb_segmentation_data = 1;
494 }
disable_segmentation(VP8_COMP * cpi)495 static void disable_segmentation(VP8_COMP *cpi)
496 {
497 /* Clear the appropriate feature bit */
498 cpi->mb.e_mbd.segmentation_enabled = 0;
499 }
500
501 /* Valid values for a segment are 0 to 3
502 * Segmentation map is arrange as [Rows][Columns]
503 */
set_segmentation_map(VP8_COMP * cpi,unsigned char * segmentation_map)504 static void set_segmentation_map(VP8_COMP *cpi, unsigned char *segmentation_map)
505 {
506 /* Copy in the new segmentation map */
507 vpx_memcpy(cpi->segmentation_map, segmentation_map, (cpi->common.mb_rows * cpi->common.mb_cols));
508
509 /* Signal that the map should be updated. */
510 cpi->mb.e_mbd.update_mb_segmentation_map = 1;
511 cpi->mb.e_mbd.update_mb_segmentation_data = 1;
512 }
513
514 /* The values given for each segment can be either deltas (from the default
515 * value chosen for the frame) or absolute values.
516 *
517 * Valid range for abs values is:
518 * (0-127 for MB_LVL_ALT_Q), (0-63 for SEGMENT_ALT_LF)
519 * Valid range for delta values are:
520 * (+/-127 for MB_LVL_ALT_Q), (+/-63 for SEGMENT_ALT_LF)
521 *
522 * abs_delta = SEGMENT_DELTADATA (deltas)
523 * abs_delta = SEGMENT_ABSDATA (use the absolute values given).
524 *
525 */
set_segment_data(VP8_COMP * cpi,signed char * feature_data,unsigned char abs_delta)526 static void set_segment_data(VP8_COMP *cpi, signed char *feature_data, unsigned char abs_delta)
527 {
528 cpi->mb.e_mbd.mb_segement_abs_delta = abs_delta;
529 vpx_memcpy(cpi->segment_feature_data, feature_data, sizeof(cpi->segment_feature_data));
530 }
531
532
segmentation_test_function(VP8_COMP * cpi)533 static void segmentation_test_function(VP8_COMP *cpi)
534 {
535 unsigned char *seg_map;
536 signed char feature_data[MB_LVL_MAX][MAX_MB_SEGMENTS];
537
538 // Create a temporary map for segmentation data.
539 CHECK_MEM_ERROR(seg_map, vpx_calloc(cpi->common.mb_rows * cpi->common.mb_cols, 1));
540
541 // Set the segmentation Map
542 set_segmentation_map(cpi, seg_map);
543
544 // Activate segmentation.
545 enable_segmentation(cpi);
546
547 // Set up the quant segment data
548 feature_data[MB_LVL_ALT_Q][0] = 0;
549 feature_data[MB_LVL_ALT_Q][1] = 4;
550 feature_data[MB_LVL_ALT_Q][2] = 0;
551 feature_data[MB_LVL_ALT_Q][3] = 0;
552 // Set up the loop segment data
553 feature_data[MB_LVL_ALT_LF][0] = 0;
554 feature_data[MB_LVL_ALT_LF][1] = 0;
555 feature_data[MB_LVL_ALT_LF][2] = 0;
556 feature_data[MB_LVL_ALT_LF][3] = 0;
557
558 // Initialise the feature data structure
559 // SEGMENT_DELTADATA 0, SEGMENT_ABSDATA 1
560 set_segment_data(cpi, &feature_data[0][0], SEGMENT_DELTADATA);
561
562 // Delete sementation map
563 vpx_free(seg_map);
564
565 seg_map = 0;
566 }
567
568 /* A simple function to cyclically refresh the background at a lower Q */
cyclic_background_refresh(VP8_COMP * cpi,int Q,int lf_adjustment)569 static void cyclic_background_refresh(VP8_COMP *cpi, int Q, int lf_adjustment)
570 {
571 unsigned char *seg_map = cpi->segmentation_map;
572 signed char feature_data[MB_LVL_MAX][MAX_MB_SEGMENTS];
573 int i;
574 int block_count = cpi->cyclic_refresh_mode_max_mbs_perframe;
575 int mbs_in_frame = cpi->common.mb_rows * cpi->common.mb_cols;
576
577 cpi->cyclic_refresh_q = Q / 2;
578
579 // Set every macroblock to be eligible for update.
580 // For key frame this will reset seg map to 0.
581 vpx_memset(cpi->segmentation_map, 0, mbs_in_frame);
582
583 if (cpi->common.frame_type != KEY_FRAME)
584 {
585 /* Cycle through the macro_block rows */
586 /* MB loop to set local segmentation map */
587 i = cpi->cyclic_refresh_mode_index;
588 assert(i < mbs_in_frame);
589 do
590 {
591 /* If the MB is as a candidate for clean up then mark it for
592 * possible boost/refresh (segment 1) The segment id may get
593 * reset to 0 later if the MB gets coded anything other than
594 * last frame 0,0 as only (last frame 0,0) MBs are eligable for
595 * refresh : that is to say Mbs likely to be background blocks.
596 */
597 if (cpi->cyclic_refresh_map[i] == 0)
598 {
599 seg_map[i] = 1;
600 block_count --;
601 }
602 else if (cpi->cyclic_refresh_map[i] < 0)
603 cpi->cyclic_refresh_map[i]++;
604
605 i++;
606 if (i == mbs_in_frame)
607 i = 0;
608
609 }
610 while(block_count && i != cpi->cyclic_refresh_mode_index);
611
612 cpi->cyclic_refresh_mode_index = i;
613 }
614
615 /* Activate segmentation. */
616 cpi->mb.e_mbd.update_mb_segmentation_map = 1;
617 cpi->mb.e_mbd.update_mb_segmentation_data = 1;
618 enable_segmentation(cpi);
619
620 /* Set up the quant segment data */
621 feature_data[MB_LVL_ALT_Q][0] = 0;
622 feature_data[MB_LVL_ALT_Q][1] = (cpi->cyclic_refresh_q - Q);
623 feature_data[MB_LVL_ALT_Q][2] = 0;
624 feature_data[MB_LVL_ALT_Q][3] = 0;
625
626 /* Set up the loop segment data */
627 feature_data[MB_LVL_ALT_LF][0] = 0;
628 feature_data[MB_LVL_ALT_LF][1] = lf_adjustment;
629 feature_data[MB_LVL_ALT_LF][2] = 0;
630 feature_data[MB_LVL_ALT_LF][3] = 0;
631
632 /* Initialise the feature data structure */
633 set_segment_data(cpi, &feature_data[0][0], SEGMENT_DELTADATA);
634
635 }
636
set_default_lf_deltas(VP8_COMP * cpi)637 static void set_default_lf_deltas(VP8_COMP *cpi)
638 {
639 cpi->mb.e_mbd.mode_ref_lf_delta_enabled = 1;
640 cpi->mb.e_mbd.mode_ref_lf_delta_update = 1;
641
642 vpx_memset(cpi->mb.e_mbd.ref_lf_deltas, 0, sizeof(cpi->mb.e_mbd.ref_lf_deltas));
643 vpx_memset(cpi->mb.e_mbd.mode_lf_deltas, 0, sizeof(cpi->mb.e_mbd.mode_lf_deltas));
644
645 /* Test of ref frame deltas */
646 cpi->mb.e_mbd.ref_lf_deltas[INTRA_FRAME] = 2;
647 cpi->mb.e_mbd.ref_lf_deltas[LAST_FRAME] = 0;
648 cpi->mb.e_mbd.ref_lf_deltas[GOLDEN_FRAME] = -2;
649 cpi->mb.e_mbd.ref_lf_deltas[ALTREF_FRAME] = -2;
650
651 cpi->mb.e_mbd.mode_lf_deltas[0] = 4; /* BPRED */
652
653 if(cpi->oxcf.Mode == MODE_REALTIME)
654 cpi->mb.e_mbd.mode_lf_deltas[1] = -12; /* Zero */
655 else
656 cpi->mb.e_mbd.mode_lf_deltas[1] = -2; /* Zero */
657
658 cpi->mb.e_mbd.mode_lf_deltas[2] = 2; /* New mv */
659 cpi->mb.e_mbd.mode_lf_deltas[3] = 4; /* Split mv */
660 }
661
662 /* Convenience macros for mapping speed and mode into a continuous
663 * range
664 */
665 #define GOOD(x) (x+1)
666 #define RT(x) (x+7)
667
speed_map(int speed,const int * map)668 static int speed_map(int speed, const int *map)
669 {
670 int res;
671
672 do
673 {
674 res = *map++;
675 } while(speed >= *map++);
676 return res;
677 }
678
679 static const int thresh_mult_map_znn[] = {
680 /* map common to zero, nearest, and near */
681 0, GOOD(2), 1500, GOOD(3), 2000, RT(0), 1000, RT(2), 2000, INT_MAX
682 };
683
684 static const int thresh_mult_map_vhpred[] = {
685 1000, GOOD(2), 1500, GOOD(3), 2000, RT(0), 1000, RT(1), 2000,
686 RT(7), INT_MAX, INT_MAX
687 };
688
689 static const int thresh_mult_map_bpred[] = {
690 2000, GOOD(0), 2500, GOOD(2), 5000, GOOD(3), 7500, RT(0), 2500, RT(1), 5000,
691 RT(6), INT_MAX, INT_MAX
692 };
693
694 static const int thresh_mult_map_tm[] = {
695 1000, GOOD(2), 1500, GOOD(3), 2000, RT(0), 0, RT(1), 1000, RT(2), 2000,
696 RT(7), INT_MAX, INT_MAX
697 };
698
699 static const int thresh_mult_map_new1[] = {
700 1000, GOOD(2), 2000, RT(0), 2000, INT_MAX
701 };
702
703 static const int thresh_mult_map_new2[] = {
704 1000, GOOD(2), 2000, GOOD(3), 2500, GOOD(5), 4000, RT(0), 2000, RT(2), 2500,
705 RT(5), 4000, INT_MAX
706 };
707
708 static const int thresh_mult_map_split1[] = {
709 2500, GOOD(0), 1700, GOOD(2), 10000, GOOD(3), 25000, GOOD(4), INT_MAX,
710 RT(0), 5000, RT(1), 10000, RT(2), 25000, RT(3), INT_MAX, INT_MAX
711 };
712
713 static const int thresh_mult_map_split2[] = {
714 5000, GOOD(0), 4500, GOOD(2), 20000, GOOD(3), 50000, GOOD(4), INT_MAX,
715 RT(0), 10000, RT(1), 20000, RT(2), 50000, RT(3), INT_MAX, INT_MAX
716 };
717
718 static const int mode_check_freq_map_zn2[] = {
719 /* {zero,nearest}{2,3} */
720 0, RT(10), 1<<1, RT(11), 1<<2, RT(12), 1<<3, INT_MAX
721 };
722
723 static const int mode_check_freq_map_vhbpred[] = {
724 0, GOOD(5), 2, RT(0), 0, RT(3), 2, RT(5), 4, INT_MAX
725 };
726
727 static const int mode_check_freq_map_near2[] = {
728 0, GOOD(5), 2, RT(0), 0, RT(3), 2, RT(10), 1<<2, RT(11), 1<<3, RT(12), 1<<4,
729 INT_MAX
730 };
731
732 static const int mode_check_freq_map_new1[] = {
733 0, RT(10), 1<<1, RT(11), 1<<2, RT(12), 1<<3, INT_MAX
734 };
735
736 static const int mode_check_freq_map_new2[] = {
737 0, GOOD(5), 4, RT(0), 0, RT(3), 4, RT(10), 1<<3, RT(11), 1<<4, RT(12), 1<<5,
738 INT_MAX
739 };
740
741 static const int mode_check_freq_map_split1[] = {
742 0, GOOD(2), 2, GOOD(3), 7, RT(1), 2, RT(2), 7, INT_MAX
743 };
744
745 static const int mode_check_freq_map_split2[] = {
746 0, GOOD(1), 2, GOOD(2), 4, GOOD(3), 15, RT(1), 4, RT(2), 15, INT_MAX
747 };
748
vp8_set_speed_features(VP8_COMP * cpi)749 void vp8_set_speed_features(VP8_COMP *cpi)
750 {
751 SPEED_FEATURES *sf = &cpi->sf;
752 int Mode = cpi->compressor_speed;
753 int Speed = cpi->Speed;
754 int i;
755 VP8_COMMON *cm = &cpi->common;
756 int last_improved_quant = sf->improved_quant;
757 int ref_frames;
758
759 /* Initialise default mode frequency sampling variables */
760 for (i = 0; i < MAX_MODES; i ++)
761 {
762 cpi->mode_check_freq[i] = 0;
763 }
764
765 cpi->mb.mbs_tested_so_far = 0;
766
767 /* best quality defaults */
768 sf->RD = 1;
769 sf->search_method = NSTEP;
770 sf->improved_quant = 1;
771 sf->improved_dct = 1;
772 sf->auto_filter = 1;
773 sf->recode_loop = 1;
774 sf->quarter_pixel_search = 1;
775 sf->half_pixel_search = 1;
776 sf->iterative_sub_pixel = 1;
777 sf->optimize_coefficients = 1;
778 sf->use_fastquant_for_pick = 0;
779 sf->no_skip_block4x4_search = 1;
780
781 sf->first_step = 0;
782 sf->max_step_search_steps = MAX_MVSEARCH_STEPS;
783 sf->improved_mv_pred = 1;
784
785 /* default thresholds to 0 */
786 for (i = 0; i < MAX_MODES; i++)
787 sf->thresh_mult[i] = 0;
788
789 /* Count enabled references */
790 ref_frames = 1;
791 if (cpi->ref_frame_flags & VP8_LAST_FRAME)
792 ref_frames++;
793 if (cpi->ref_frame_flags & VP8_GOLD_FRAME)
794 ref_frames++;
795 if (cpi->ref_frame_flags & VP8_ALTR_FRAME)
796 ref_frames++;
797
798 /* Convert speed to continuous range, with clamping */
799 if (Mode == 0)
800 Speed = 0;
801 else if (Mode == 2)
802 Speed = RT(Speed);
803 else
804 {
805 if (Speed > 5)
806 Speed = 5;
807 Speed = GOOD(Speed);
808 }
809
810 sf->thresh_mult[THR_ZERO1] =
811 sf->thresh_mult[THR_NEAREST1] =
812 sf->thresh_mult[THR_NEAR1] =
813 sf->thresh_mult[THR_DC] = 0; /* always */
814
815 sf->thresh_mult[THR_ZERO2] =
816 sf->thresh_mult[THR_ZERO3] =
817 sf->thresh_mult[THR_NEAREST2] =
818 sf->thresh_mult[THR_NEAREST3] =
819 sf->thresh_mult[THR_NEAR2] =
820 sf->thresh_mult[THR_NEAR3] = speed_map(Speed, thresh_mult_map_znn);
821
822 sf->thresh_mult[THR_V_PRED] =
823 sf->thresh_mult[THR_H_PRED] = speed_map(Speed, thresh_mult_map_vhpred);
824 sf->thresh_mult[THR_B_PRED] = speed_map(Speed, thresh_mult_map_bpred);
825 sf->thresh_mult[THR_TM] = speed_map(Speed, thresh_mult_map_tm);
826 sf->thresh_mult[THR_NEW1] = speed_map(Speed, thresh_mult_map_new1);
827 sf->thresh_mult[THR_NEW2] =
828 sf->thresh_mult[THR_NEW3] = speed_map(Speed, thresh_mult_map_new2);
829 sf->thresh_mult[THR_SPLIT1] = speed_map(Speed, thresh_mult_map_split1);
830 sf->thresh_mult[THR_SPLIT2] =
831 sf->thresh_mult[THR_SPLIT3] = speed_map(Speed, thresh_mult_map_split2);
832
833 cpi->mode_check_freq[THR_ZERO1] =
834 cpi->mode_check_freq[THR_NEAREST1] =
835 cpi->mode_check_freq[THR_NEAR1] =
836 cpi->mode_check_freq[THR_TM] =
837 cpi->mode_check_freq[THR_DC] = 0; /* always */
838
839 cpi->mode_check_freq[THR_ZERO2] =
840 cpi->mode_check_freq[THR_ZERO3] =
841 cpi->mode_check_freq[THR_NEAREST2] =
842 cpi->mode_check_freq[THR_NEAREST3] = speed_map(Speed,
843 mode_check_freq_map_zn2);
844
845 cpi->mode_check_freq[THR_NEAR2] =
846 cpi->mode_check_freq[THR_NEAR3] = speed_map(Speed,
847 mode_check_freq_map_near2);
848
849 cpi->mode_check_freq[THR_V_PRED] =
850 cpi->mode_check_freq[THR_H_PRED] =
851 cpi->mode_check_freq[THR_B_PRED] = speed_map(Speed,
852 mode_check_freq_map_vhbpred);
853 cpi->mode_check_freq[THR_NEW1] = speed_map(Speed,
854 mode_check_freq_map_new1);
855 cpi->mode_check_freq[THR_NEW2] =
856 cpi->mode_check_freq[THR_NEW3] = speed_map(Speed,
857 mode_check_freq_map_new2);
858 cpi->mode_check_freq[THR_SPLIT1] = speed_map(Speed,
859 mode_check_freq_map_split1);
860 cpi->mode_check_freq[THR_SPLIT2] =
861 cpi->mode_check_freq[THR_SPLIT3] = speed_map(Speed,
862 mode_check_freq_map_split2);
863 Speed = cpi->Speed;
864 switch (Mode)
865 {
866 #if !(CONFIG_REALTIME_ONLY)
867 case 0: /* best quality mode */
868 sf->first_step = 0;
869 sf->max_step_search_steps = MAX_MVSEARCH_STEPS;
870 break;
871 case 1:
872 case 3:
873 if (Speed > 0)
874 {
875 /* Disable coefficient optimization above speed 0 */
876 sf->optimize_coefficients = 0;
877 sf->use_fastquant_for_pick = 1;
878 sf->no_skip_block4x4_search = 0;
879
880 sf->first_step = 1;
881 }
882
883 if (Speed > 2)
884 {
885 sf->improved_quant = 0;
886 sf->improved_dct = 0;
887
888 /* Only do recode loop on key frames, golden frames and
889 * alt ref frames
890 */
891 sf->recode_loop = 2;
892
893 }
894
895 if (Speed > 3)
896 {
897 sf->auto_filter = 1;
898 sf->recode_loop = 0; /* recode loop off */
899 sf->RD = 0; /* Turn rd off */
900
901 }
902
903 if (Speed > 4)
904 {
905 sf->auto_filter = 0; /* Faster selection of loop filter */
906 }
907
908 break;
909 #endif
910 case 2:
911 sf->optimize_coefficients = 0;
912 sf->recode_loop = 0;
913 sf->auto_filter = 1;
914 sf->iterative_sub_pixel = 1;
915 sf->search_method = NSTEP;
916
917 if (Speed > 0)
918 {
919 sf->improved_quant = 0;
920 sf->improved_dct = 0;
921
922 sf->use_fastquant_for_pick = 1;
923 sf->no_skip_block4x4_search = 0;
924 sf->first_step = 1;
925 }
926
927 if (Speed > 2)
928 sf->auto_filter = 0; /* Faster selection of loop filter */
929
930 if (Speed > 3)
931 {
932 sf->RD = 0;
933 sf->auto_filter = 1;
934 }
935
936 if (Speed > 4)
937 {
938 sf->auto_filter = 0; /* Faster selection of loop filter */
939 sf->search_method = HEX;
940 sf->iterative_sub_pixel = 0;
941 }
942
943 if (Speed > 6)
944 {
945 unsigned int sum = 0;
946 unsigned int total_mbs = cm->MBs;
947 int thresh;
948 unsigned int total_skip;
949
950 int min = 2000;
951
952 if (cpi->oxcf.encode_breakout > 2000)
953 min = cpi->oxcf.encode_breakout;
954
955 min >>= 7;
956
957 for (i = 0; i < min; i++)
958 {
959 sum += cpi->mb.error_bins[i];
960 }
961
962 total_skip = sum;
963 sum = 0;
964
965 /* i starts from 2 to make sure thresh started from 2048 */
966 for (; i < 1024; i++)
967 {
968 sum += cpi->mb.error_bins[i];
969
970 if (10 * sum >= (unsigned int)(cpi->Speed - 6)*(total_mbs - total_skip))
971 break;
972 }
973
974 i--;
975 thresh = (i << 7);
976
977 if (thresh < 2000)
978 thresh = 2000;
979
980 if (ref_frames > 1)
981 {
982 sf->thresh_mult[THR_NEW1 ] = thresh;
983 sf->thresh_mult[THR_NEAREST1 ] = thresh >> 1;
984 sf->thresh_mult[THR_NEAR1 ] = thresh >> 1;
985 }
986
987 if (ref_frames > 2)
988 {
989 sf->thresh_mult[THR_NEW2] = thresh << 1;
990 sf->thresh_mult[THR_NEAREST2 ] = thresh;
991 sf->thresh_mult[THR_NEAR2 ] = thresh;
992 }
993
994 if (ref_frames > 3)
995 {
996 sf->thresh_mult[THR_NEW3] = thresh << 1;
997 sf->thresh_mult[THR_NEAREST3 ] = thresh;
998 sf->thresh_mult[THR_NEAR3 ] = thresh;
999 }
1000
1001 sf->improved_mv_pred = 0;
1002 }
1003
1004 if (Speed > 8)
1005 sf->quarter_pixel_search = 0;
1006
1007 if(cm->version == 0)
1008 {
1009 cm->filter_type = NORMAL_LOOPFILTER;
1010
1011 if (Speed >= 14)
1012 cm->filter_type = SIMPLE_LOOPFILTER;
1013 }
1014 else
1015 {
1016 cm->filter_type = SIMPLE_LOOPFILTER;
1017 }
1018
1019 /* This has a big hit on quality. Last resort */
1020 if (Speed >= 15)
1021 sf->half_pixel_search = 0;
1022
1023 vpx_memset(cpi->mb.error_bins, 0, sizeof(cpi->mb.error_bins));
1024
1025 }; /* switch */
1026
1027 /* Slow quant, dct and trellis not worthwhile for first pass
1028 * so make sure they are always turned off.
1029 */
1030 if ( cpi->pass == 1 )
1031 {
1032 sf->improved_quant = 0;
1033 sf->optimize_coefficients = 0;
1034 sf->improved_dct = 0;
1035 }
1036
1037 if (cpi->sf.search_method == NSTEP)
1038 {
1039 vp8_init3smotion_compensation(&cpi->mb, cm->yv12_fb[cm->lst_fb_idx].y_stride);
1040 }
1041 else if (cpi->sf.search_method == DIAMOND)
1042 {
1043 vp8_init_dsmotion_compensation(&cpi->mb, cm->yv12_fb[cm->lst_fb_idx].y_stride);
1044 }
1045
1046 if (cpi->sf.improved_dct)
1047 {
1048 cpi->mb.short_fdct8x4 = vp8_short_fdct8x4;
1049 cpi->mb.short_fdct4x4 = vp8_short_fdct4x4;
1050 }
1051 else
1052 {
1053 /* No fast FDCT defined for any platform at this time. */
1054 cpi->mb.short_fdct8x4 = vp8_short_fdct8x4;
1055 cpi->mb.short_fdct4x4 = vp8_short_fdct4x4;
1056 }
1057
1058 cpi->mb.short_walsh4x4 = vp8_short_walsh4x4;
1059
1060 if (cpi->sf.improved_quant)
1061 {
1062 cpi->mb.quantize_b = vp8_regular_quantize_b;
1063 cpi->mb.quantize_b_pair = vp8_regular_quantize_b_pair;
1064 }
1065 else
1066 {
1067 cpi->mb.quantize_b = vp8_fast_quantize_b;
1068 cpi->mb.quantize_b_pair = vp8_fast_quantize_b_pair;
1069 }
1070 if (cpi->sf.improved_quant != last_improved_quant)
1071 vp8cx_init_quantizer(cpi);
1072
1073 if (cpi->sf.iterative_sub_pixel == 1)
1074 {
1075 cpi->find_fractional_mv_step = vp8_find_best_sub_pixel_step_iteratively;
1076 }
1077 else if (cpi->sf.quarter_pixel_search)
1078 {
1079 cpi->find_fractional_mv_step = vp8_find_best_sub_pixel_step;
1080 }
1081 else if (cpi->sf.half_pixel_search)
1082 {
1083 cpi->find_fractional_mv_step = vp8_find_best_half_pixel_step;
1084 }
1085 else
1086 {
1087 cpi->find_fractional_mv_step = vp8_skip_fractional_mv_step;
1088 }
1089
1090 if (cpi->sf.optimize_coefficients == 1 && cpi->pass!=1)
1091 cpi->mb.optimize = 1;
1092 else
1093 cpi->mb.optimize = 0;
1094
1095 if (cpi->common.full_pixel)
1096 cpi->find_fractional_mv_step = vp8_skip_fractional_mv_step;
1097
1098 #ifdef SPEEDSTATS
1099 frames_at_speed[cpi->Speed]++;
1100 #endif
1101 }
1102 #undef GOOD
1103 #undef RT
1104
alloc_raw_frame_buffers(VP8_COMP * cpi)1105 static void alloc_raw_frame_buffers(VP8_COMP *cpi)
1106 {
1107 #if VP8_TEMPORAL_ALT_REF
1108 int width = (cpi->oxcf.Width + 15) & ~15;
1109 int height = (cpi->oxcf.Height + 15) & ~15;
1110 #endif
1111
1112 cpi->lookahead = vp8_lookahead_init(cpi->oxcf.Width, cpi->oxcf.Height,
1113 cpi->oxcf.lag_in_frames);
1114 if(!cpi->lookahead)
1115 vpx_internal_error(&cpi->common.error, VPX_CODEC_MEM_ERROR,
1116 "Failed to allocate lag buffers");
1117
1118 #if VP8_TEMPORAL_ALT_REF
1119
1120 if (vp8_yv12_alloc_frame_buffer(&cpi->alt_ref_buffer,
1121 width, height, VP8BORDERINPIXELS))
1122 vpx_internal_error(&cpi->common.error, VPX_CODEC_MEM_ERROR,
1123 "Failed to allocate altref buffer");
1124
1125 #endif
1126 }
1127
1128
dealloc_raw_frame_buffers(VP8_COMP * cpi)1129 static void dealloc_raw_frame_buffers(VP8_COMP *cpi)
1130 {
1131 #if VP8_TEMPORAL_ALT_REF
1132 vp8_yv12_de_alloc_frame_buffer(&cpi->alt_ref_buffer);
1133 #endif
1134 vp8_lookahead_destroy(cpi->lookahead);
1135 }
1136
1137
vp8_alloc_partition_data(VP8_COMP * cpi)1138 static int vp8_alloc_partition_data(VP8_COMP *cpi)
1139 {
1140 vpx_free(cpi->mb.pip);
1141
1142 cpi->mb.pip = vpx_calloc((cpi->common.mb_cols + 1) *
1143 (cpi->common.mb_rows + 1),
1144 sizeof(PARTITION_INFO));
1145 if(!cpi->mb.pip)
1146 return 1;
1147
1148 cpi->mb.pi = cpi->mb.pip + cpi->common.mode_info_stride + 1;
1149
1150 return 0;
1151 }
1152
vp8_alloc_compressor_data(VP8_COMP * cpi)1153 void vp8_alloc_compressor_data(VP8_COMP *cpi)
1154 {
1155 VP8_COMMON *cm = & cpi->common;
1156
1157 int width = cm->Width;
1158 int height = cm->Height;
1159
1160 if (vp8_alloc_frame_buffers(cm, width, height))
1161 vpx_internal_error(&cpi->common.error, VPX_CODEC_MEM_ERROR,
1162 "Failed to allocate frame buffers");
1163
1164 if (vp8_alloc_partition_data(cpi))
1165 vpx_internal_error(&cpi->common.error, VPX_CODEC_MEM_ERROR,
1166 "Failed to allocate partition data");
1167
1168
1169 if ((width & 0xf) != 0)
1170 width += 16 - (width & 0xf);
1171
1172 if ((height & 0xf) != 0)
1173 height += 16 - (height & 0xf);
1174
1175
1176 if (vp8_yv12_alloc_frame_buffer(&cpi->pick_lf_lvl_frame,
1177 width, height, VP8BORDERINPIXELS))
1178 vpx_internal_error(&cpi->common.error, VPX_CODEC_MEM_ERROR,
1179 "Failed to allocate last frame buffer");
1180
1181 if (vp8_yv12_alloc_frame_buffer(&cpi->scaled_source,
1182 width, height, VP8BORDERINPIXELS))
1183 vpx_internal_error(&cpi->common.error, VPX_CODEC_MEM_ERROR,
1184 "Failed to allocate scaled source buffer");
1185
1186 vpx_free(cpi->tok);
1187
1188 {
1189 #if CONFIG_REALTIME_ONLY & CONFIG_ONTHEFLY_BITPACKING
1190 unsigned int tokens = 8 * 24 * 16; /* one MB for each thread */
1191 #else
1192 unsigned int tokens = cm->mb_rows * cm->mb_cols * 24 * 16;
1193 #endif
1194 CHECK_MEM_ERROR(cpi->tok, vpx_calloc(tokens, sizeof(*cpi->tok)));
1195 }
1196
1197 /* Data used for real time vc mode to see if gf needs refreshing */
1198 cpi->zeromv_count = 0;
1199
1200
1201 /* Structures used to monitor GF usage */
1202 vpx_free(cpi->gf_active_flags);
1203 CHECK_MEM_ERROR(cpi->gf_active_flags,
1204 vpx_calloc(sizeof(*cpi->gf_active_flags),
1205 cm->mb_rows * cm->mb_cols));
1206 cpi->gf_active_count = cm->mb_rows * cm->mb_cols;
1207
1208 vpx_free(cpi->mb_activity_map);
1209 CHECK_MEM_ERROR(cpi->mb_activity_map,
1210 vpx_calloc(sizeof(*cpi->mb_activity_map),
1211 cm->mb_rows * cm->mb_cols));
1212
1213 /* allocate memory for storing last frame's MVs for MV prediction. */
1214 vpx_free(cpi->lfmv);
1215 CHECK_MEM_ERROR(cpi->lfmv, vpx_calloc((cm->mb_rows+2) * (cm->mb_cols+2),
1216 sizeof(*cpi->lfmv)));
1217 vpx_free(cpi->lf_ref_frame_sign_bias);
1218 CHECK_MEM_ERROR(cpi->lf_ref_frame_sign_bias,
1219 vpx_calloc((cm->mb_rows+2) * (cm->mb_cols+2),
1220 sizeof(*cpi->lf_ref_frame_sign_bias)));
1221 vpx_free(cpi->lf_ref_frame);
1222 CHECK_MEM_ERROR(cpi->lf_ref_frame,
1223 vpx_calloc((cm->mb_rows+2) * (cm->mb_cols+2),
1224 sizeof(*cpi->lf_ref_frame)));
1225
1226 /* Create the encoder segmentation map and set all entries to 0 */
1227 vpx_free(cpi->segmentation_map);
1228 CHECK_MEM_ERROR(cpi->segmentation_map,
1229 vpx_calloc(cm->mb_rows * cm->mb_cols,
1230 sizeof(*cpi->segmentation_map)));
1231 cpi->cyclic_refresh_mode_index = 0;
1232 vpx_free(cpi->active_map);
1233 CHECK_MEM_ERROR(cpi->active_map,
1234 vpx_calloc(cm->mb_rows * cm->mb_cols,
1235 sizeof(*cpi->active_map)));
1236 vpx_memset(cpi->active_map , 1, (cm->mb_rows * cm->mb_cols));
1237
1238 #if CONFIG_MULTITHREAD
1239 if (width < 640)
1240 cpi->mt_sync_range = 1;
1241 else if (width <= 1280)
1242 cpi->mt_sync_range = 4;
1243 else if (width <= 2560)
1244 cpi->mt_sync_range = 8;
1245 else
1246 cpi->mt_sync_range = 16;
1247
1248 if (cpi->oxcf.multi_threaded > 1)
1249 {
1250 vpx_free(cpi->mt_current_mb_col);
1251 CHECK_MEM_ERROR(cpi->mt_current_mb_col,
1252 vpx_malloc(sizeof(*cpi->mt_current_mb_col) * cm->mb_rows));
1253 }
1254
1255 #endif
1256
1257 vpx_free(cpi->tplist);
1258 CHECK_MEM_ERROR(cpi->tplist, vpx_malloc(sizeof(TOKENLIST) * cm->mb_rows));
1259 }
1260
1261
1262 /* Quant MOD */
1263 static const int q_trans[] =
1264 {
1265 0, 1, 2, 3, 4, 5, 7, 8,
1266 9, 10, 12, 13, 15, 17, 18, 19,
1267 20, 21, 23, 24, 25, 26, 27, 28,
1268 29, 30, 31, 33, 35, 37, 39, 41,
1269 43, 45, 47, 49, 51, 53, 55, 57,
1270 59, 61, 64, 67, 70, 73, 76, 79,
1271 82, 85, 88, 91, 94, 97, 100, 103,
1272 106, 109, 112, 115, 118, 121, 124, 127,
1273 };
1274
vp8_reverse_trans(int x)1275 int vp8_reverse_trans(int x)
1276 {
1277 int i;
1278
1279 for (i = 0; i < 64; i++)
1280 if (q_trans[i] >= x)
1281 return i;
1282
1283 return 63;
1284 }
vp8_new_framerate(VP8_COMP * cpi,double framerate)1285 void vp8_new_framerate(VP8_COMP *cpi, double framerate)
1286 {
1287 if(framerate < .1)
1288 framerate = 30;
1289
1290 cpi->framerate = framerate;
1291 cpi->output_framerate = framerate;
1292 cpi->per_frame_bandwidth = (int)(cpi->oxcf.target_bandwidth /
1293 cpi->output_framerate);
1294 cpi->av_per_frame_bandwidth = cpi->per_frame_bandwidth;
1295 cpi->min_frame_bandwidth = (int)(cpi->av_per_frame_bandwidth *
1296 cpi->oxcf.two_pass_vbrmin_section / 100);
1297
1298 /* Set Maximum gf/arf interval */
1299 cpi->max_gf_interval = ((int)(cpi->output_framerate / 2.0) + 2);
1300
1301 if(cpi->max_gf_interval < 12)
1302 cpi->max_gf_interval = 12;
1303
1304 /* Extended interval for genuinely static scenes */
1305 cpi->twopass.static_scene_max_gf_interval = cpi->key_frame_frequency >> 1;
1306
1307 /* Special conditions when altr ref frame enabled in lagged compress mode */
1308 if (cpi->oxcf.play_alternate && cpi->oxcf.lag_in_frames)
1309 {
1310 if (cpi->max_gf_interval > cpi->oxcf.lag_in_frames - 1)
1311 cpi->max_gf_interval = cpi->oxcf.lag_in_frames - 1;
1312
1313 if (cpi->twopass.static_scene_max_gf_interval > cpi->oxcf.lag_in_frames - 1)
1314 cpi->twopass.static_scene_max_gf_interval = cpi->oxcf.lag_in_frames - 1;
1315 }
1316
1317 if ( cpi->max_gf_interval > cpi->twopass.static_scene_max_gf_interval )
1318 cpi->max_gf_interval = cpi->twopass.static_scene_max_gf_interval;
1319 }
1320
1321
init_config(VP8_COMP * cpi,VP8_CONFIG * oxcf)1322 static void init_config(VP8_COMP *cpi, VP8_CONFIG *oxcf)
1323 {
1324 VP8_COMMON *cm = &cpi->common;
1325
1326 cpi->oxcf = *oxcf;
1327
1328 cpi->auto_gold = 1;
1329 cpi->auto_adjust_gold_quantizer = 1;
1330
1331 cm->version = oxcf->Version;
1332 vp8_setup_version(cm);
1333
1334 /* frame rate is not available on the first frame, as it's derived from
1335 * the observed timestamps. The actual value used here doesn't matter
1336 * too much, as it will adapt quickly. If the reciprocal of the timebase
1337 * seems like a reasonable framerate, then use that as a guess, otherwise
1338 * use 30.
1339 */
1340 cpi->framerate = (double)(oxcf->timebase.den) /
1341 (double)(oxcf->timebase.num);
1342
1343 if (cpi->framerate > 180)
1344 cpi->framerate = 30;
1345
1346 cpi->ref_framerate = cpi->framerate;
1347
1348 /* change includes all joint functionality */
1349 vp8_change_config(cpi, oxcf);
1350
1351 /* Initialize active best and worst q and average q values. */
1352 cpi->active_worst_quality = cpi->oxcf.worst_allowed_q;
1353 cpi->active_best_quality = cpi->oxcf.best_allowed_q;
1354 cpi->avg_frame_qindex = cpi->oxcf.worst_allowed_q;
1355
1356 /* Initialise the starting buffer levels */
1357 cpi->buffer_level = cpi->oxcf.starting_buffer_level;
1358 cpi->bits_off_target = cpi->oxcf.starting_buffer_level;
1359
1360 cpi->rolling_target_bits = cpi->av_per_frame_bandwidth;
1361 cpi->rolling_actual_bits = cpi->av_per_frame_bandwidth;
1362 cpi->long_rolling_target_bits = cpi->av_per_frame_bandwidth;
1363 cpi->long_rolling_actual_bits = cpi->av_per_frame_bandwidth;
1364
1365 cpi->total_actual_bits = 0;
1366 cpi->total_target_vs_actual = 0;
1367
1368 /* Temporal scalabilty */
1369 if (cpi->oxcf.number_of_layers > 1)
1370 {
1371 unsigned int i;
1372 double prev_layer_framerate=0;
1373
1374 for (i=0; i<cpi->oxcf.number_of_layers; i++)
1375 {
1376 init_temporal_layer_context(cpi, oxcf, i, prev_layer_framerate);
1377 prev_layer_framerate = cpi->output_framerate /
1378 cpi->oxcf.rate_decimator[i];
1379 }
1380 }
1381
1382 #if VP8_TEMPORAL_ALT_REF
1383 {
1384 int i;
1385
1386 cpi->fixed_divide[0] = 0;
1387
1388 for (i = 1; i < 512; i++)
1389 cpi->fixed_divide[i] = 0x80000 / i;
1390 }
1391 #endif
1392 }
1393
update_layer_contexts(VP8_COMP * cpi)1394 static void update_layer_contexts (VP8_COMP *cpi)
1395 {
1396 VP8_CONFIG *oxcf = &cpi->oxcf;
1397
1398 /* Update snapshots of the layer contexts to reflect new parameters */
1399 if (oxcf->number_of_layers > 1)
1400 {
1401 unsigned int i;
1402 double prev_layer_framerate=0;
1403
1404 assert(oxcf->number_of_layers <= VPX_TS_MAX_LAYERS);
1405 for (i=0; i<oxcf->number_of_layers; i++)
1406 {
1407 LAYER_CONTEXT *lc = &cpi->layer_context[i];
1408
1409 lc->framerate =
1410 cpi->ref_framerate / oxcf->rate_decimator[i];
1411 lc->target_bandwidth = oxcf->target_bitrate[i] * 1000;
1412
1413 lc->starting_buffer_level = rescale(
1414 (int)oxcf->starting_buffer_level_in_ms,
1415 lc->target_bandwidth, 1000);
1416
1417 if (oxcf->optimal_buffer_level == 0)
1418 lc->optimal_buffer_level = lc->target_bandwidth / 8;
1419 else
1420 lc->optimal_buffer_level = rescale(
1421 (int)oxcf->optimal_buffer_level_in_ms,
1422 lc->target_bandwidth, 1000);
1423
1424 if (oxcf->maximum_buffer_size == 0)
1425 lc->maximum_buffer_size = lc->target_bandwidth / 8;
1426 else
1427 lc->maximum_buffer_size = rescale(
1428 (int)oxcf->maximum_buffer_size_in_ms,
1429 lc->target_bandwidth, 1000);
1430
1431 /* Work out the average size of a frame within this layer */
1432 if (i > 0)
1433 lc->avg_frame_size_for_layer =
1434 (int)((oxcf->target_bitrate[i] -
1435 oxcf->target_bitrate[i-1]) * 1000 /
1436 (lc->framerate - prev_layer_framerate));
1437
1438 prev_layer_framerate = lc->framerate;
1439 }
1440 }
1441 }
1442
vp8_change_config(VP8_COMP * cpi,VP8_CONFIG * oxcf)1443 void vp8_change_config(VP8_COMP *cpi, VP8_CONFIG *oxcf)
1444 {
1445 VP8_COMMON *cm = &cpi->common;
1446 int last_w, last_h;
1447 uint32_t prev_number_of_layers;
1448
1449 if (!cpi)
1450 return;
1451
1452 if (!oxcf)
1453 return;
1454
1455 #if CONFIG_MULTITHREAD
1456 /* wait for the last picture loopfilter thread done */
1457 if (cpi->b_lpf_running)
1458 {
1459 sem_wait(&cpi->h_event_end_lpf);
1460 cpi->b_lpf_running = 0;
1461 }
1462 #endif
1463
1464 if (cm->version != oxcf->Version)
1465 {
1466 cm->version = oxcf->Version;
1467 vp8_setup_version(cm);
1468 }
1469
1470 last_w = cpi->oxcf.Width;
1471 last_h = cpi->oxcf.Height;
1472 prev_number_of_layers = cpi->oxcf.number_of_layers;
1473
1474 cpi->oxcf = *oxcf;
1475
1476 switch (cpi->oxcf.Mode)
1477 {
1478
1479 case MODE_REALTIME:
1480 cpi->pass = 0;
1481 cpi->compressor_speed = 2;
1482
1483 if (cpi->oxcf.cpu_used < -16)
1484 {
1485 cpi->oxcf.cpu_used = -16;
1486 }
1487
1488 if (cpi->oxcf.cpu_used > 16)
1489 cpi->oxcf.cpu_used = 16;
1490
1491 break;
1492
1493 case MODE_GOODQUALITY:
1494 cpi->pass = 0;
1495 cpi->compressor_speed = 1;
1496
1497 if (cpi->oxcf.cpu_used < -5)
1498 {
1499 cpi->oxcf.cpu_used = -5;
1500 }
1501
1502 if (cpi->oxcf.cpu_used > 5)
1503 cpi->oxcf.cpu_used = 5;
1504
1505 break;
1506
1507 case MODE_BESTQUALITY:
1508 cpi->pass = 0;
1509 cpi->compressor_speed = 0;
1510 break;
1511
1512 case MODE_FIRSTPASS:
1513 cpi->pass = 1;
1514 cpi->compressor_speed = 1;
1515 break;
1516 case MODE_SECONDPASS:
1517 cpi->pass = 2;
1518 cpi->compressor_speed = 1;
1519
1520 if (cpi->oxcf.cpu_used < -5)
1521 {
1522 cpi->oxcf.cpu_used = -5;
1523 }
1524
1525 if (cpi->oxcf.cpu_used > 5)
1526 cpi->oxcf.cpu_used = 5;
1527
1528 break;
1529 case MODE_SECONDPASS_BEST:
1530 cpi->pass = 2;
1531 cpi->compressor_speed = 0;
1532 break;
1533 }
1534
1535 if (cpi->pass == 0)
1536 cpi->auto_worst_q = 1;
1537
1538 cpi->oxcf.worst_allowed_q = q_trans[oxcf->worst_allowed_q];
1539 cpi->oxcf.best_allowed_q = q_trans[oxcf->best_allowed_q];
1540 cpi->oxcf.cq_level = q_trans[cpi->oxcf.cq_level];
1541
1542 if (oxcf->fixed_q >= 0)
1543 {
1544 if (oxcf->worst_allowed_q < 0)
1545 cpi->oxcf.fixed_q = q_trans[0];
1546 else
1547 cpi->oxcf.fixed_q = q_trans[oxcf->worst_allowed_q];
1548
1549 if (oxcf->alt_q < 0)
1550 cpi->oxcf.alt_q = q_trans[0];
1551 else
1552 cpi->oxcf.alt_q = q_trans[oxcf->alt_q];
1553
1554 if (oxcf->key_q < 0)
1555 cpi->oxcf.key_q = q_trans[0];
1556 else
1557 cpi->oxcf.key_q = q_trans[oxcf->key_q];
1558
1559 if (oxcf->gold_q < 0)
1560 cpi->oxcf.gold_q = q_trans[0];
1561 else
1562 cpi->oxcf.gold_q = q_trans[oxcf->gold_q];
1563
1564 }
1565
1566 cpi->baseline_gf_interval =
1567 cpi->oxcf.alt_freq ? cpi->oxcf.alt_freq : DEFAULT_GF_INTERVAL;
1568
1569 cpi->ref_frame_flags = VP8_ALTR_FRAME | VP8_GOLD_FRAME | VP8_LAST_FRAME;
1570
1571 cm->refresh_golden_frame = 0;
1572 cm->refresh_last_frame = 1;
1573 cm->refresh_entropy_probs = 1;
1574
1575 #if (CONFIG_REALTIME_ONLY & CONFIG_ONTHEFLY_BITPACKING)
1576 cpi->oxcf.token_partitions = 3;
1577 #endif
1578
1579 if (cpi->oxcf.token_partitions >= 0 && cpi->oxcf.token_partitions <= 3)
1580 cm->multi_token_partition =
1581 (TOKEN_PARTITION) cpi->oxcf.token_partitions;
1582
1583 setup_features(cpi);
1584
1585 {
1586 int i;
1587
1588 for (i = 0; i < MAX_MB_SEGMENTS; i++)
1589 cpi->segment_encode_breakout[i] = cpi->oxcf.encode_breakout;
1590 }
1591
1592 /* At the moment the first order values may not be > MAXQ */
1593 if (cpi->oxcf.fixed_q > MAXQ)
1594 cpi->oxcf.fixed_q = MAXQ;
1595
1596 /* local file playback mode == really big buffer */
1597 if (cpi->oxcf.end_usage == USAGE_LOCAL_FILE_PLAYBACK)
1598 {
1599 cpi->oxcf.starting_buffer_level = 60000;
1600 cpi->oxcf.optimal_buffer_level = 60000;
1601 cpi->oxcf.maximum_buffer_size = 240000;
1602 cpi->oxcf.starting_buffer_level_in_ms = 60000;
1603 cpi->oxcf.optimal_buffer_level_in_ms = 60000;
1604 cpi->oxcf.maximum_buffer_size_in_ms = 240000;
1605 }
1606
1607 /* Convert target bandwidth from Kbit/s to Bit/s */
1608 cpi->oxcf.target_bandwidth *= 1000;
1609
1610 cpi->oxcf.starting_buffer_level =
1611 rescale((int)cpi->oxcf.starting_buffer_level,
1612 cpi->oxcf.target_bandwidth, 1000);
1613
1614 /* Set or reset optimal and maximum buffer levels. */
1615 if (cpi->oxcf.optimal_buffer_level == 0)
1616 cpi->oxcf.optimal_buffer_level = cpi->oxcf.target_bandwidth / 8;
1617 else
1618 cpi->oxcf.optimal_buffer_level =
1619 rescale((int)cpi->oxcf.optimal_buffer_level,
1620 cpi->oxcf.target_bandwidth, 1000);
1621
1622 if (cpi->oxcf.maximum_buffer_size == 0)
1623 cpi->oxcf.maximum_buffer_size = cpi->oxcf.target_bandwidth / 8;
1624 else
1625 cpi->oxcf.maximum_buffer_size =
1626 rescale((int)cpi->oxcf.maximum_buffer_size,
1627 cpi->oxcf.target_bandwidth, 1000);
1628 // Under a configuration change, where maximum_buffer_size may change,
1629 // keep buffer level clipped to the maximum allowed buffer size.
1630 if (cpi->bits_off_target > cpi->oxcf.maximum_buffer_size) {
1631 cpi->bits_off_target = cpi->oxcf.maximum_buffer_size;
1632 cpi->buffer_level = cpi->bits_off_target;
1633 }
1634
1635 /* Set up frame rate and related parameters rate control values. */
1636 vp8_new_framerate(cpi, cpi->framerate);
1637
1638 /* Set absolute upper and lower quality limits */
1639 cpi->worst_quality = cpi->oxcf.worst_allowed_q;
1640 cpi->best_quality = cpi->oxcf.best_allowed_q;
1641
1642 /* active values should only be modified if out of new range */
1643 if (cpi->active_worst_quality > cpi->oxcf.worst_allowed_q)
1644 {
1645 cpi->active_worst_quality = cpi->oxcf.worst_allowed_q;
1646 }
1647 /* less likely */
1648 else if (cpi->active_worst_quality < cpi->oxcf.best_allowed_q)
1649 {
1650 cpi->active_worst_quality = cpi->oxcf.best_allowed_q;
1651 }
1652 if (cpi->active_best_quality < cpi->oxcf.best_allowed_q)
1653 {
1654 cpi->active_best_quality = cpi->oxcf.best_allowed_q;
1655 }
1656 /* less likely */
1657 else if (cpi->active_best_quality > cpi->oxcf.worst_allowed_q)
1658 {
1659 cpi->active_best_quality = cpi->oxcf.worst_allowed_q;
1660 }
1661
1662 cpi->buffered_mode = cpi->oxcf.optimal_buffer_level > 0;
1663
1664 cpi->cq_target_quality = cpi->oxcf.cq_level;
1665
1666 /* Only allow dropped frames in buffered mode */
1667 cpi->drop_frames_allowed = cpi->oxcf.allow_df && cpi->buffered_mode;
1668
1669 cpi->target_bandwidth = cpi->oxcf.target_bandwidth;
1670
1671 // Check if the number of temporal layers has changed, and if so reset the
1672 // pattern counter and set/initialize the temporal layer context for the
1673 // new layer configuration.
1674 if (cpi->oxcf.number_of_layers != prev_number_of_layers)
1675 {
1676 // If the number of temporal layers are changed we must start at the
1677 // base of the pattern cycle, so reset temporal_pattern_counter.
1678 cpi->temporal_pattern_counter = 0;
1679 reset_temporal_layer_change(cpi, oxcf, prev_number_of_layers);
1680 }
1681
1682 cm->Width = cpi->oxcf.Width;
1683 cm->Height = cpi->oxcf.Height;
1684
1685 /* TODO(jkoleszar): if an internal spatial resampling is active,
1686 * and we downsize the input image, maybe we should clear the
1687 * internal scale immediately rather than waiting for it to
1688 * correct.
1689 */
1690
1691 /* VP8 sharpness level mapping 0-7 (vs 0-10 in general VPx dialogs) */
1692 if (cpi->oxcf.Sharpness > 7)
1693 cpi->oxcf.Sharpness = 7;
1694
1695 cm->sharpness_level = cpi->oxcf.Sharpness;
1696
1697 if (cm->horiz_scale != NORMAL || cm->vert_scale != NORMAL)
1698 {
1699 int UNINITIALIZED_IS_SAFE(hr), UNINITIALIZED_IS_SAFE(hs);
1700 int UNINITIALIZED_IS_SAFE(vr), UNINITIALIZED_IS_SAFE(vs);
1701
1702 Scale2Ratio(cm->horiz_scale, &hr, &hs);
1703 Scale2Ratio(cm->vert_scale, &vr, &vs);
1704
1705 /* always go to the next whole number */
1706 cm->Width = (hs - 1 + cpi->oxcf.Width * hr) / hs;
1707 cm->Height = (vs - 1 + cpi->oxcf.Height * vr) / vs;
1708 }
1709
1710 if (last_w != cpi->oxcf.Width || last_h != cpi->oxcf.Height)
1711 cpi->force_next_frame_intra = 1;
1712
1713 if (((cm->Width + 15) & 0xfffffff0) !=
1714 (uint32_t)(cm->yv12_fb[cm->lst_fb_idx].y_width) ||
1715 ((cm->Height + 15) & 0xfffffff0) !=
1716 (uint32_t)(cm->yv12_fb[cm->lst_fb_idx].y_height) ||
1717 cm->yv12_fb[cm->lst_fb_idx].y_width == 0)
1718 {
1719 dealloc_raw_frame_buffers(cpi);
1720 alloc_raw_frame_buffers(cpi);
1721 vp8_alloc_compressor_data(cpi);
1722 }
1723
1724 if (cpi->oxcf.fixed_q >= 0)
1725 {
1726 cpi->last_q[0] = cpi->oxcf.fixed_q;
1727 cpi->last_q[1] = cpi->oxcf.fixed_q;
1728 }
1729
1730 cpi->Speed = cpi->oxcf.cpu_used;
1731
1732 /* force to allowlag to 0 if lag_in_frames is 0; */
1733 if (cpi->oxcf.lag_in_frames == 0)
1734 {
1735 cpi->oxcf.allow_lag = 0;
1736 }
1737 /* Limit on lag buffers as these are not currently dynamically allocated */
1738 else if (cpi->oxcf.lag_in_frames > MAX_LAG_BUFFERS)
1739 cpi->oxcf.lag_in_frames = MAX_LAG_BUFFERS;
1740
1741 /* YX Temp */
1742 cpi->alt_ref_source = NULL;
1743 cpi->is_src_frame_alt_ref = 0;
1744
1745 #if CONFIG_TEMPORAL_DENOISING
1746 if (cpi->oxcf.noise_sensitivity)
1747 {
1748 if (!cpi->denoiser.yv12_mc_running_avg.buffer_alloc)
1749 {
1750 int width = (cpi->oxcf.Width + 15) & ~15;
1751 int height = (cpi->oxcf.Height + 15) & ~15;
1752 vp8_denoiser_allocate(&cpi->denoiser, width, height);
1753 }
1754 }
1755 #endif
1756
1757 #if 0
1758 /* Experimental RD Code */
1759 cpi->frame_distortion = 0;
1760 cpi->last_frame_distortion = 0;
1761 #endif
1762
1763 }
1764
1765 #define M_LOG2_E 0.693147180559945309417
1766 #define log2f(x) (log (x) / (float) M_LOG2_E)
cal_mvsadcosts(int * mvsadcost[2])1767 static void cal_mvsadcosts(int *mvsadcost[2])
1768 {
1769 int i = 1;
1770
1771 mvsadcost [0] [0] = 300;
1772 mvsadcost [1] [0] = 300;
1773
1774 do
1775 {
1776 double z = 256 * (2 * (log2f(8 * i) + .6));
1777 mvsadcost [0][i] = (int) z;
1778 mvsadcost [1][i] = (int) z;
1779 mvsadcost [0][-i] = (int) z;
1780 mvsadcost [1][-i] = (int) z;
1781 }
1782 while (++i <= mvfp_max);
1783 }
1784
vp8_create_compressor(VP8_CONFIG * oxcf)1785 struct VP8_COMP* vp8_create_compressor(VP8_CONFIG *oxcf)
1786 {
1787 int i;
1788
1789 VP8_COMP *cpi;
1790 VP8_COMMON *cm;
1791
1792 cpi = vpx_memalign(32, sizeof(VP8_COMP));
1793 /* Check that the CPI instance is valid */
1794 if (!cpi)
1795 return 0;
1796
1797 cm = &cpi->common;
1798
1799 vpx_memset(cpi, 0, sizeof(VP8_COMP));
1800
1801 if (setjmp(cm->error.jmp))
1802 {
1803 cpi->common.error.setjmp = 0;
1804 vp8_remove_compressor(&cpi);
1805 return 0;
1806 }
1807
1808 cpi->common.error.setjmp = 1;
1809
1810 CHECK_MEM_ERROR(cpi->mb.ss, vpx_calloc(sizeof(search_site), (MAX_MVSEARCH_STEPS * 8) + 1));
1811
1812 vp8_create_common(&cpi->common);
1813
1814 init_config(cpi, oxcf);
1815
1816 memcpy(cpi->base_skip_false_prob, vp8cx_base_skip_false_prob, sizeof(vp8cx_base_skip_false_prob));
1817 cpi->common.current_video_frame = 0;
1818 cpi->temporal_pattern_counter = 0;
1819 cpi->kf_overspend_bits = 0;
1820 cpi->kf_bitrate_adjustment = 0;
1821 cpi->frames_till_gf_update_due = 0;
1822 cpi->gf_overspend_bits = 0;
1823 cpi->non_gf_bitrate_adjustment = 0;
1824 cpi->prob_last_coded = 128;
1825 cpi->prob_gf_coded = 128;
1826 cpi->prob_intra_coded = 63;
1827
1828 /* Prime the recent reference frame usage counters.
1829 * Hereafter they will be maintained as a sort of moving average
1830 */
1831 cpi->recent_ref_frame_usage[INTRA_FRAME] = 1;
1832 cpi->recent_ref_frame_usage[LAST_FRAME] = 1;
1833 cpi->recent_ref_frame_usage[GOLDEN_FRAME] = 1;
1834 cpi->recent_ref_frame_usage[ALTREF_FRAME] = 1;
1835
1836 /* Set reference frame sign bias for ALTREF frame to 1 (for now) */
1837 cpi->common.ref_frame_sign_bias[ALTREF_FRAME] = 1;
1838
1839 cpi->twopass.gf_decay_rate = 0;
1840 cpi->baseline_gf_interval = DEFAULT_GF_INTERVAL;
1841
1842 cpi->gold_is_last = 0 ;
1843 cpi->alt_is_last = 0 ;
1844 cpi->gold_is_alt = 0 ;
1845
1846 cpi->active_map_enabled = 0;
1847
1848 #if 0
1849 /* Experimental code for lagged and one pass */
1850 /* Initialise one_pass GF frames stats */
1851 /* Update stats used for GF selection */
1852 if (cpi->pass == 0)
1853 {
1854 cpi->one_pass_frame_index = 0;
1855
1856 for (i = 0; i < MAX_LAG_BUFFERS; i++)
1857 {
1858 cpi->one_pass_frame_stats[i].frames_so_far = 0;
1859 cpi->one_pass_frame_stats[i].frame_intra_error = 0.0;
1860 cpi->one_pass_frame_stats[i].frame_coded_error = 0.0;
1861 cpi->one_pass_frame_stats[i].frame_pcnt_inter = 0.0;
1862 cpi->one_pass_frame_stats[i].frame_pcnt_motion = 0.0;
1863 cpi->one_pass_frame_stats[i].frame_mvr = 0.0;
1864 cpi->one_pass_frame_stats[i].frame_mvr_abs = 0.0;
1865 cpi->one_pass_frame_stats[i].frame_mvc = 0.0;
1866 cpi->one_pass_frame_stats[i].frame_mvc_abs = 0.0;
1867 }
1868 }
1869 #endif
1870
1871 /* Should we use the cyclic refresh method.
1872 * Currently this is tied to error resilliant mode
1873 */
1874 cpi->cyclic_refresh_mode_enabled = cpi->oxcf.error_resilient_mode;
1875 cpi->cyclic_refresh_mode_max_mbs_perframe = (cpi->common.mb_rows * cpi->common.mb_cols) / 5;
1876 cpi->cyclic_refresh_mode_index = 0;
1877 cpi->cyclic_refresh_q = 32;
1878
1879 if (cpi->cyclic_refresh_mode_enabled)
1880 {
1881 CHECK_MEM_ERROR(cpi->cyclic_refresh_map, vpx_calloc((cpi->common.mb_rows * cpi->common.mb_cols), 1));
1882 }
1883 else
1884 cpi->cyclic_refresh_map = (signed char *) NULL;
1885
1886 #ifdef VP8_ENTROPY_STATS
1887 init_context_counters();
1888 #endif
1889
1890 /*Initialize the feed-forward activity masking.*/
1891 cpi->activity_avg = 90<<12;
1892
1893 /* Give a sensible default for the first frame. */
1894 cpi->frames_since_key = 8;
1895 cpi->key_frame_frequency = cpi->oxcf.key_freq;
1896 cpi->this_key_frame_forced = 0;
1897 cpi->next_key_frame_forced = 0;
1898
1899 cpi->source_alt_ref_pending = 0;
1900 cpi->source_alt_ref_active = 0;
1901 cpi->common.refresh_alt_ref_frame = 0;
1902
1903 cpi->b_calculate_psnr = CONFIG_INTERNAL_STATS;
1904 #if CONFIG_INTERNAL_STATS
1905 cpi->b_calculate_ssimg = 0;
1906
1907 cpi->count = 0;
1908 cpi->bytes = 0;
1909
1910 if (cpi->b_calculate_psnr)
1911 {
1912 cpi->total_sq_error = 0.0;
1913 cpi->total_sq_error2 = 0.0;
1914 cpi->total_y = 0.0;
1915 cpi->total_u = 0.0;
1916 cpi->total_v = 0.0;
1917 cpi->total = 0.0;
1918 cpi->totalp_y = 0.0;
1919 cpi->totalp_u = 0.0;
1920 cpi->totalp_v = 0.0;
1921 cpi->totalp = 0.0;
1922 cpi->tot_recode_hits = 0;
1923 cpi->summed_quality = 0;
1924 cpi->summed_weights = 0;
1925 }
1926
1927 if (cpi->b_calculate_ssimg)
1928 {
1929 cpi->total_ssimg_y = 0;
1930 cpi->total_ssimg_u = 0;
1931 cpi->total_ssimg_v = 0;
1932 cpi->total_ssimg_all = 0;
1933 }
1934
1935 #endif
1936
1937 cpi->first_time_stamp_ever = 0x7FFFFFFF;
1938
1939 cpi->frames_till_gf_update_due = 0;
1940 cpi->key_frame_count = 1;
1941
1942 cpi->ni_av_qi = cpi->oxcf.worst_allowed_q;
1943 cpi->ni_tot_qi = 0;
1944 cpi->ni_frames = 0;
1945 cpi->total_byte_count = 0;
1946
1947 cpi->drop_frame = 0;
1948
1949 cpi->rate_correction_factor = 1.0;
1950 cpi->key_frame_rate_correction_factor = 1.0;
1951 cpi->gf_rate_correction_factor = 1.0;
1952 cpi->twopass.est_max_qcorrection_factor = 1.0;
1953
1954 for (i = 0; i < KEY_FRAME_CONTEXT; i++)
1955 {
1956 cpi->prior_key_frame_distance[i] = (int)cpi->output_framerate;
1957 }
1958
1959 #ifdef OUTPUT_YUV_SRC
1960 yuv_file = fopen("bd.yuv", "ab");
1961 #endif
1962
1963 #if 0
1964 framepsnr = fopen("framepsnr.stt", "a");
1965 kf_list = fopen("kf_list.stt", "w");
1966 #endif
1967
1968 cpi->output_pkt_list = oxcf->output_pkt_list;
1969
1970 #if !(CONFIG_REALTIME_ONLY)
1971
1972 if (cpi->pass == 1)
1973 {
1974 vp8_init_first_pass(cpi);
1975 }
1976 else if (cpi->pass == 2)
1977 {
1978 size_t packet_sz = sizeof(FIRSTPASS_STATS);
1979 int packets = (int)(oxcf->two_pass_stats_in.sz / packet_sz);
1980
1981 cpi->twopass.stats_in_start = oxcf->two_pass_stats_in.buf;
1982 cpi->twopass.stats_in = cpi->twopass.stats_in_start;
1983 cpi->twopass.stats_in_end = (void*)((char *)cpi->twopass.stats_in
1984 + (packets - 1) * packet_sz);
1985 vp8_init_second_pass(cpi);
1986 }
1987
1988 #endif
1989
1990 if (cpi->compressor_speed == 2)
1991 {
1992 cpi->avg_encode_time = 0;
1993 cpi->avg_pick_mode_time = 0;
1994 }
1995
1996 vp8_set_speed_features(cpi);
1997
1998 /* Set starting values of RD threshold multipliers (128 = *1) */
1999 for (i = 0; i < MAX_MODES; i++)
2000 {
2001 cpi->mb.rd_thresh_mult[i] = 128;
2002 }
2003
2004 #ifdef VP8_ENTROPY_STATS
2005 init_mv_ref_counts();
2006 #endif
2007
2008 #if CONFIG_MULTITHREAD
2009 if(vp8cx_create_encoder_threads(cpi))
2010 {
2011 vp8_remove_compressor(&cpi);
2012 return 0;
2013 }
2014 #endif
2015
2016 cpi->fn_ptr[BLOCK_16X16].sdf = vp8_sad16x16;
2017 cpi->fn_ptr[BLOCK_16X16].vf = vp8_variance16x16;
2018 cpi->fn_ptr[BLOCK_16X16].svf = vp8_sub_pixel_variance16x16;
2019 cpi->fn_ptr[BLOCK_16X16].svf_halfpix_h = vp8_variance_halfpixvar16x16_h;
2020 cpi->fn_ptr[BLOCK_16X16].svf_halfpix_v = vp8_variance_halfpixvar16x16_v;
2021 cpi->fn_ptr[BLOCK_16X16].svf_halfpix_hv = vp8_variance_halfpixvar16x16_hv;
2022 cpi->fn_ptr[BLOCK_16X16].sdx3f = vp8_sad16x16x3;
2023 cpi->fn_ptr[BLOCK_16X16].sdx8f = vp8_sad16x16x8;
2024 cpi->fn_ptr[BLOCK_16X16].sdx4df = vp8_sad16x16x4d;
2025
2026 cpi->fn_ptr[BLOCK_16X8].sdf = vp8_sad16x8;
2027 cpi->fn_ptr[BLOCK_16X8].vf = vp8_variance16x8;
2028 cpi->fn_ptr[BLOCK_16X8].svf = vp8_sub_pixel_variance16x8;
2029 cpi->fn_ptr[BLOCK_16X8].svf_halfpix_h = NULL;
2030 cpi->fn_ptr[BLOCK_16X8].svf_halfpix_v = NULL;
2031 cpi->fn_ptr[BLOCK_16X8].svf_halfpix_hv = NULL;
2032 cpi->fn_ptr[BLOCK_16X8].sdx3f = vp8_sad16x8x3;
2033 cpi->fn_ptr[BLOCK_16X8].sdx8f = vp8_sad16x8x8;
2034 cpi->fn_ptr[BLOCK_16X8].sdx4df = vp8_sad16x8x4d;
2035
2036 cpi->fn_ptr[BLOCK_8X16].sdf = vp8_sad8x16;
2037 cpi->fn_ptr[BLOCK_8X16].vf = vp8_variance8x16;
2038 cpi->fn_ptr[BLOCK_8X16].svf = vp8_sub_pixel_variance8x16;
2039 cpi->fn_ptr[BLOCK_8X16].svf_halfpix_h = NULL;
2040 cpi->fn_ptr[BLOCK_8X16].svf_halfpix_v = NULL;
2041 cpi->fn_ptr[BLOCK_8X16].svf_halfpix_hv = NULL;
2042 cpi->fn_ptr[BLOCK_8X16].sdx3f = vp8_sad8x16x3;
2043 cpi->fn_ptr[BLOCK_8X16].sdx8f = vp8_sad8x16x8;
2044 cpi->fn_ptr[BLOCK_8X16].sdx4df = vp8_sad8x16x4d;
2045
2046 cpi->fn_ptr[BLOCK_8X8].sdf = vp8_sad8x8;
2047 cpi->fn_ptr[BLOCK_8X8].vf = vp8_variance8x8;
2048 cpi->fn_ptr[BLOCK_8X8].svf = vp8_sub_pixel_variance8x8;
2049 cpi->fn_ptr[BLOCK_8X8].svf_halfpix_h = NULL;
2050 cpi->fn_ptr[BLOCK_8X8].svf_halfpix_v = NULL;
2051 cpi->fn_ptr[BLOCK_8X8].svf_halfpix_hv = NULL;
2052 cpi->fn_ptr[BLOCK_8X8].sdx3f = vp8_sad8x8x3;
2053 cpi->fn_ptr[BLOCK_8X8].sdx8f = vp8_sad8x8x8;
2054 cpi->fn_ptr[BLOCK_8X8].sdx4df = vp8_sad8x8x4d;
2055
2056 cpi->fn_ptr[BLOCK_4X4].sdf = vp8_sad4x4;
2057 cpi->fn_ptr[BLOCK_4X4].vf = vp8_variance4x4;
2058 cpi->fn_ptr[BLOCK_4X4].svf = vp8_sub_pixel_variance4x4;
2059 cpi->fn_ptr[BLOCK_4X4].svf_halfpix_h = NULL;
2060 cpi->fn_ptr[BLOCK_4X4].svf_halfpix_v = NULL;
2061 cpi->fn_ptr[BLOCK_4X4].svf_halfpix_hv = NULL;
2062 cpi->fn_ptr[BLOCK_4X4].sdx3f = vp8_sad4x4x3;
2063 cpi->fn_ptr[BLOCK_4X4].sdx8f = vp8_sad4x4x8;
2064 cpi->fn_ptr[BLOCK_4X4].sdx4df = vp8_sad4x4x4d;
2065
2066 #if ARCH_X86_32 || ARCH_X86_64
2067 cpi->fn_ptr[BLOCK_16X16].copymem = vp8_copy32xn;
2068 cpi->fn_ptr[BLOCK_16X8].copymem = vp8_copy32xn;
2069 cpi->fn_ptr[BLOCK_8X16].copymem = vp8_copy32xn;
2070 cpi->fn_ptr[BLOCK_8X8].copymem = vp8_copy32xn;
2071 cpi->fn_ptr[BLOCK_4X4].copymem = vp8_copy32xn;
2072 #endif
2073
2074 cpi->full_search_sad = vp8_full_search_sad;
2075 cpi->diamond_search_sad = vp8_diamond_search_sad;
2076 cpi->refining_search_sad = vp8_refining_search_sad;
2077
2078 /* make sure frame 1 is okay */
2079 cpi->mb.error_bins[0] = cpi->common.MBs;
2080
2081 /* vp8cx_init_quantizer() is first called here. Add check in
2082 * vp8cx_frame_init_quantizer() so that vp8cx_init_quantizer is only
2083 * called later when needed. This will avoid unnecessary calls of
2084 * vp8cx_init_quantizer() for every frame.
2085 */
2086 vp8cx_init_quantizer(cpi);
2087
2088 vp8_loop_filter_init(cm);
2089
2090 cpi->common.error.setjmp = 0;
2091
2092 #if CONFIG_MULTI_RES_ENCODING
2093
2094 /* Calculate # of MBs in a row in lower-resolution level image. */
2095 if (cpi->oxcf.mr_encoder_id > 0)
2096 vp8_cal_low_res_mb_cols(cpi);
2097
2098 #endif
2099
2100 /* setup RD costs to MACROBLOCK struct */
2101
2102 cpi->mb.mvcost[0] = &cpi->rd_costs.mvcosts[0][mv_max+1];
2103 cpi->mb.mvcost[1] = &cpi->rd_costs.mvcosts[1][mv_max+1];
2104 cpi->mb.mvsadcost[0] = &cpi->rd_costs.mvsadcosts[0][mvfp_max+1];
2105 cpi->mb.mvsadcost[1] = &cpi->rd_costs.mvsadcosts[1][mvfp_max+1];
2106
2107 cal_mvsadcosts(cpi->mb.mvsadcost);
2108
2109 cpi->mb.mbmode_cost = cpi->rd_costs.mbmode_cost;
2110 cpi->mb.intra_uv_mode_cost = cpi->rd_costs.intra_uv_mode_cost;
2111 cpi->mb.bmode_costs = cpi->rd_costs.bmode_costs;
2112 cpi->mb.inter_bmode_costs = cpi->rd_costs.inter_bmode_costs;
2113 cpi->mb.token_costs = cpi->rd_costs.token_costs;
2114
2115 /* setup block ptrs & offsets */
2116 vp8_setup_block_ptrs(&cpi->mb);
2117 vp8_setup_block_dptrs(&cpi->mb.e_mbd);
2118
2119 return cpi;
2120 }
2121
2122
vp8_remove_compressor(VP8_COMP ** ptr)2123 void vp8_remove_compressor(VP8_COMP **ptr)
2124 {
2125 VP8_COMP *cpi = *ptr;
2126
2127 if (!cpi)
2128 return;
2129
2130 if (cpi && (cpi->common.current_video_frame > 0))
2131 {
2132 #if !(CONFIG_REALTIME_ONLY)
2133
2134 if (cpi->pass == 2)
2135 {
2136 vp8_end_second_pass(cpi);
2137 }
2138
2139 #endif
2140
2141 #ifdef VP8_ENTROPY_STATS
2142 print_context_counters();
2143 print_tree_update_probs();
2144 print_mode_context();
2145 #endif
2146
2147 #if CONFIG_INTERNAL_STATS
2148
2149 if (cpi->pass != 1)
2150 {
2151 FILE *f = fopen("opsnr.stt", "a");
2152 double time_encoded = (cpi->last_end_time_stamp_seen
2153 - cpi->first_time_stamp_ever) / 10000000.000;
2154 double total_encode_time = (cpi->time_receive_data +
2155 cpi->time_compress_data) / 1000.000;
2156 double dr = (double)cpi->bytes * 8.0 / 1000.0 / time_encoded;
2157
2158 if (cpi->b_calculate_psnr)
2159 {
2160 YV12_BUFFER_CONFIG *lst_yv12 =
2161 &cpi->common.yv12_fb[cpi->common.lst_fb_idx];
2162
2163 if (cpi->oxcf.number_of_layers > 1)
2164 {
2165 int i;
2166
2167 fprintf(f, "Layer\tBitrate\tAVGPsnr\tGLBPsnr\tAVPsnrP\t"
2168 "GLPsnrP\tVPXSSIM\t\n");
2169 for (i=0; i<(int)cpi->oxcf.number_of_layers; i++)
2170 {
2171 double dr = (double)cpi->bytes_in_layer[i] *
2172 8.0 / 1000.0 / time_encoded;
2173 double samples = 3.0 / 2 * cpi->frames_in_layer[i] *
2174 lst_yv12->y_width * lst_yv12->y_height;
2175 double total_psnr =
2176 vpx_sse_to_psnr(samples, 255.0,
2177 cpi->total_error2[i]);
2178 double total_psnr2 =
2179 vpx_sse_to_psnr(samples, 255.0,
2180 cpi->total_error2_p[i]);
2181 double total_ssim = 100 * pow(cpi->sum_ssim[i] /
2182 cpi->sum_weights[i], 8.0);
2183
2184 fprintf(f, "%5d\t%7.3f\t%7.3f\t%7.3f\t%7.3f\t"
2185 "%7.3f\t%7.3f\n",
2186 i, dr,
2187 cpi->sum_psnr[i] / cpi->frames_in_layer[i],
2188 total_psnr,
2189 cpi->sum_psnr_p[i] / cpi->frames_in_layer[i],
2190 total_psnr2, total_ssim);
2191 }
2192 }
2193 else
2194 {
2195 double samples = 3.0 / 2 * cpi->count *
2196 lst_yv12->y_width * lst_yv12->y_height;
2197 double total_psnr = vpx_sse_to_psnr(samples, 255.0,
2198 cpi->total_sq_error);
2199 double total_psnr2 = vpx_sse_to_psnr(samples, 255.0,
2200 cpi->total_sq_error2);
2201 double total_ssim = 100 * pow(cpi->summed_quality /
2202 cpi->summed_weights, 8.0);
2203
2204 fprintf(f, "Bitrate\tAVGPsnr\tGLBPsnr\tAVPsnrP\t"
2205 "GLPsnrP\tVPXSSIM\t Time(us)\n");
2206 fprintf(f, "%7.3f\t%7.3f\t%7.3f\t%7.3f\t%7.3f\t"
2207 "%7.3f\t%8.0f\n",
2208 dr, cpi->total / cpi->count, total_psnr,
2209 cpi->totalp / cpi->count, total_psnr2,
2210 total_ssim, total_encode_time);
2211 }
2212 }
2213
2214 if (cpi->b_calculate_ssimg)
2215 {
2216 if (cpi->oxcf.number_of_layers > 1)
2217 {
2218 int i;
2219
2220 fprintf(f, "Layer\tBitRate\tSSIM_Y\tSSIM_U\tSSIM_V\tSSIM_A\t"
2221 "Time(us)\n");
2222 for (i=0; i<(int)cpi->oxcf.number_of_layers; i++)
2223 {
2224 double dr = (double)cpi->bytes_in_layer[i] *
2225 8.0 / 1000.0 / time_encoded;
2226 fprintf(f, "%5d\t%7.3f\t%6.4f\t"
2227 "%6.4f\t%6.4f\t%6.4f\t%8.0f\n",
2228 i, dr,
2229 cpi->total_ssimg_y_in_layer[i] /
2230 cpi->frames_in_layer[i],
2231 cpi->total_ssimg_u_in_layer[i] /
2232 cpi->frames_in_layer[i],
2233 cpi->total_ssimg_v_in_layer[i] /
2234 cpi->frames_in_layer[i],
2235 cpi->total_ssimg_all_in_layer[i] /
2236 cpi->frames_in_layer[i],
2237 total_encode_time);
2238 }
2239 }
2240 else
2241 {
2242 fprintf(f, "BitRate\tSSIM_Y\tSSIM_U\tSSIM_V\tSSIM_A\t"
2243 "Time(us)\n");
2244 fprintf(f, "%7.3f\t%6.4f\t%6.4f\t%6.4f\t%6.4f\t%8.0f\n", dr,
2245 cpi->total_ssimg_y / cpi->count,
2246 cpi->total_ssimg_u / cpi->count,
2247 cpi->total_ssimg_v / cpi->count,
2248 cpi->total_ssimg_all / cpi->count, total_encode_time);
2249 }
2250 }
2251
2252 fclose(f);
2253 #if 0
2254 f = fopen("qskip.stt", "a");
2255 fprintf(f, "minq:%d -maxq:%d skiptrue:skipfalse = %d:%d\n", cpi->oxcf.best_allowed_q, cpi->oxcf.worst_allowed_q, skiptruecount, skipfalsecount);
2256 fclose(f);
2257 #endif
2258
2259 }
2260
2261 #endif
2262
2263
2264 #ifdef SPEEDSTATS
2265
2266 if (cpi->compressor_speed == 2)
2267 {
2268 int i;
2269 FILE *f = fopen("cxspeed.stt", "a");
2270 cnt_pm /= cpi->common.MBs;
2271
2272 for (i = 0; i < 16; i++)
2273 fprintf(f, "%5d", frames_at_speed[i]);
2274
2275 fprintf(f, "\n");
2276 fclose(f);
2277 }
2278
2279 #endif
2280
2281
2282 #ifdef MODE_STATS
2283 {
2284 extern int count_mb_seg[4];
2285 FILE *f = fopen("modes.stt", "a");
2286 double dr = (double)cpi->framerate * (double)bytes * (double)8 / (double)count / (double)1000 ;
2287 fprintf(f, "intra_mode in Intra Frames:\n");
2288 fprintf(f, "Y: %8d, %8d, %8d, %8d, %8d\n", y_modes[0], y_modes[1], y_modes[2], y_modes[3], y_modes[4]);
2289 fprintf(f, "UV:%8d, %8d, %8d, %8d\n", uv_modes[0], uv_modes[1], uv_modes[2], uv_modes[3]);
2290 fprintf(f, "B: ");
2291 {
2292 int i;
2293
2294 for (i = 0; i < 10; i++)
2295 fprintf(f, "%8d, ", b_modes[i]);
2296
2297 fprintf(f, "\n");
2298
2299 }
2300
2301 fprintf(f, "Modes in Inter Frames:\n");
2302 fprintf(f, "Y: %8d, %8d, %8d, %8d, %8d, %8d, %8d, %8d, %8d, %8d\n",
2303 inter_y_modes[0], inter_y_modes[1], inter_y_modes[2], inter_y_modes[3], inter_y_modes[4],
2304 inter_y_modes[5], inter_y_modes[6], inter_y_modes[7], inter_y_modes[8], inter_y_modes[9]);
2305 fprintf(f, "UV:%8d, %8d, %8d, %8d\n", inter_uv_modes[0], inter_uv_modes[1], inter_uv_modes[2], inter_uv_modes[3]);
2306 fprintf(f, "B: ");
2307 {
2308 int i;
2309
2310 for (i = 0; i < 15; i++)
2311 fprintf(f, "%8d, ", inter_b_modes[i]);
2312
2313 fprintf(f, "\n");
2314
2315 }
2316 fprintf(f, "P:%8d, %8d, %8d, %8d\n", count_mb_seg[0], count_mb_seg[1], count_mb_seg[2], count_mb_seg[3]);
2317 fprintf(f, "PB:%8d, %8d, %8d, %8d\n", inter_b_modes[LEFT4X4], inter_b_modes[ABOVE4X4], inter_b_modes[ZERO4X4], inter_b_modes[NEW4X4]);
2318
2319
2320
2321 fclose(f);
2322 }
2323 #endif
2324
2325 #ifdef VP8_ENTROPY_STATS
2326 {
2327 int i, j, k;
2328 FILE *fmode = fopen("modecontext.c", "w");
2329
2330 fprintf(fmode, "\n#include \"entropymode.h\"\n\n");
2331 fprintf(fmode, "const unsigned int vp8_kf_default_bmode_counts ");
2332 fprintf(fmode, "[VP8_BINTRAMODES] [VP8_BINTRAMODES] [VP8_BINTRAMODES] =\n{\n");
2333
2334 for (i = 0; i < 10; i++)
2335 {
2336
2337 fprintf(fmode, " { /* Above Mode : %d */\n", i);
2338
2339 for (j = 0; j < 10; j++)
2340 {
2341
2342 fprintf(fmode, " {");
2343
2344 for (k = 0; k < 10; k++)
2345 {
2346 if (!intra_mode_stats[i][j][k])
2347 fprintf(fmode, " %5d, ", 1);
2348 else
2349 fprintf(fmode, " %5d, ", intra_mode_stats[i][j][k]);
2350 }
2351
2352 fprintf(fmode, "}, /* left_mode %d */\n", j);
2353
2354 }
2355
2356 fprintf(fmode, " },\n");
2357
2358 }
2359
2360 fprintf(fmode, "};\n");
2361 fclose(fmode);
2362 }
2363 #endif
2364
2365
2366 #if defined(SECTIONBITS_OUTPUT)
2367
2368 if (0)
2369 {
2370 int i;
2371 FILE *f = fopen("tokenbits.stt", "a");
2372
2373 for (i = 0; i < 28; i++)
2374 fprintf(f, "%8d", (int)(Sectionbits[i] / 256));
2375
2376 fprintf(f, "\n");
2377 fclose(f);
2378 }
2379
2380 #endif
2381
2382 #if 0
2383 {
2384 printf("\n_pick_loop_filter_level:%d\n", cpi->time_pick_lpf / 1000);
2385 printf("\n_frames recive_data encod_mb_row compress_frame Total\n");
2386 printf("%6d %10ld %10ld %10ld %10ld\n", cpi->common.current_video_frame, cpi->time_receive_data / 1000, cpi->time_encode_mb_row / 1000, cpi->time_compress_data / 1000, (cpi->time_receive_data + cpi->time_compress_data) / 1000);
2387 }
2388 #endif
2389
2390 }
2391
2392 #if CONFIG_MULTITHREAD
2393 vp8cx_remove_encoder_threads(cpi);
2394 #endif
2395
2396 #if CONFIG_TEMPORAL_DENOISING
2397 vp8_denoiser_free(&cpi->denoiser);
2398 #endif
2399 dealloc_compressor_data(cpi);
2400 vpx_free(cpi->mb.ss);
2401 vpx_free(cpi->tok);
2402 vpx_free(cpi->cyclic_refresh_map);
2403
2404 vp8_remove_common(&cpi->common);
2405 vpx_free(cpi);
2406 *ptr = 0;
2407
2408 #ifdef OUTPUT_YUV_SRC
2409 fclose(yuv_file);
2410 #endif
2411
2412 #if 0
2413
2414 if (keyfile)
2415 fclose(keyfile);
2416
2417 if (framepsnr)
2418 fclose(framepsnr);
2419
2420 if (kf_list)
2421 fclose(kf_list);
2422
2423 #endif
2424
2425 }
2426
2427
calc_plane_error(unsigned char * orig,int orig_stride,unsigned char * recon,int recon_stride,unsigned int cols,unsigned int rows)2428 static uint64_t calc_plane_error(unsigned char *orig, int orig_stride,
2429 unsigned char *recon, int recon_stride,
2430 unsigned int cols, unsigned int rows)
2431 {
2432 unsigned int row, col;
2433 uint64_t total_sse = 0;
2434 int diff;
2435
2436 for (row = 0; row + 16 <= rows; row += 16)
2437 {
2438 for (col = 0; col + 16 <= cols; col += 16)
2439 {
2440 unsigned int sse;
2441
2442 vp8_mse16x16(orig + col, orig_stride,
2443 recon + col, recon_stride,
2444 &sse);
2445 total_sse += sse;
2446 }
2447
2448 /* Handle odd-sized width */
2449 if (col < cols)
2450 {
2451 unsigned int border_row, border_col;
2452 unsigned char *border_orig = orig;
2453 unsigned char *border_recon = recon;
2454
2455 for (border_row = 0; border_row < 16; border_row++)
2456 {
2457 for (border_col = col; border_col < cols; border_col++)
2458 {
2459 diff = border_orig[border_col] - border_recon[border_col];
2460 total_sse += diff * diff;
2461 }
2462
2463 border_orig += orig_stride;
2464 border_recon += recon_stride;
2465 }
2466 }
2467
2468 orig += orig_stride * 16;
2469 recon += recon_stride * 16;
2470 }
2471
2472 /* Handle odd-sized height */
2473 for (; row < rows; row++)
2474 {
2475 for (col = 0; col < cols; col++)
2476 {
2477 diff = orig[col] - recon[col];
2478 total_sse += diff * diff;
2479 }
2480
2481 orig += orig_stride;
2482 recon += recon_stride;
2483 }
2484
2485 vp8_clear_system_state();
2486 return total_sse;
2487 }
2488
2489
generate_psnr_packet(VP8_COMP * cpi)2490 static void generate_psnr_packet(VP8_COMP *cpi)
2491 {
2492 YV12_BUFFER_CONFIG *orig = cpi->Source;
2493 YV12_BUFFER_CONFIG *recon = cpi->common.frame_to_show;
2494 struct vpx_codec_cx_pkt pkt;
2495 uint64_t sse;
2496 int i;
2497 unsigned int width = cpi->common.Width;
2498 unsigned int height = cpi->common.Height;
2499
2500 pkt.kind = VPX_CODEC_PSNR_PKT;
2501 sse = calc_plane_error(orig->y_buffer, orig->y_stride,
2502 recon->y_buffer, recon->y_stride,
2503 width, height);
2504 pkt.data.psnr.sse[0] = sse;
2505 pkt.data.psnr.sse[1] = sse;
2506 pkt.data.psnr.samples[0] = width * height;
2507 pkt.data.psnr.samples[1] = width * height;
2508
2509 width = (width + 1) / 2;
2510 height = (height + 1) / 2;
2511
2512 sse = calc_plane_error(orig->u_buffer, orig->uv_stride,
2513 recon->u_buffer, recon->uv_stride,
2514 width, height);
2515 pkt.data.psnr.sse[0] += sse;
2516 pkt.data.psnr.sse[2] = sse;
2517 pkt.data.psnr.samples[0] += width * height;
2518 pkt.data.psnr.samples[2] = width * height;
2519
2520 sse = calc_plane_error(orig->v_buffer, orig->uv_stride,
2521 recon->v_buffer, recon->uv_stride,
2522 width, height);
2523 pkt.data.psnr.sse[0] += sse;
2524 pkt.data.psnr.sse[3] = sse;
2525 pkt.data.psnr.samples[0] += width * height;
2526 pkt.data.psnr.samples[3] = width * height;
2527
2528 for (i = 0; i < 4; i++)
2529 pkt.data.psnr.psnr[i] = vpx_sse_to_psnr(pkt.data.psnr.samples[i], 255.0,
2530 (double)(pkt.data.psnr.sse[i]));
2531
2532 vpx_codec_pkt_list_add(cpi->output_pkt_list, &pkt);
2533 }
2534
2535
vp8_use_as_reference(VP8_COMP * cpi,int ref_frame_flags)2536 int vp8_use_as_reference(VP8_COMP *cpi, int ref_frame_flags)
2537 {
2538 if (ref_frame_flags > 7)
2539 return -1 ;
2540
2541 cpi->ref_frame_flags = ref_frame_flags;
2542 return 0;
2543 }
vp8_update_reference(VP8_COMP * cpi,int ref_frame_flags)2544 int vp8_update_reference(VP8_COMP *cpi, int ref_frame_flags)
2545 {
2546 if (ref_frame_flags > 7)
2547 return -1 ;
2548
2549 cpi->common.refresh_golden_frame = 0;
2550 cpi->common.refresh_alt_ref_frame = 0;
2551 cpi->common.refresh_last_frame = 0;
2552
2553 if (ref_frame_flags & VP8_LAST_FRAME)
2554 cpi->common.refresh_last_frame = 1;
2555
2556 if (ref_frame_flags & VP8_GOLD_FRAME)
2557 cpi->common.refresh_golden_frame = 1;
2558
2559 if (ref_frame_flags & VP8_ALTR_FRAME)
2560 cpi->common.refresh_alt_ref_frame = 1;
2561
2562 return 0;
2563 }
2564
vp8_get_reference(VP8_COMP * cpi,enum vpx_ref_frame_type ref_frame_flag,YV12_BUFFER_CONFIG * sd)2565 int vp8_get_reference(VP8_COMP *cpi, enum vpx_ref_frame_type ref_frame_flag, YV12_BUFFER_CONFIG *sd)
2566 {
2567 VP8_COMMON *cm = &cpi->common;
2568 int ref_fb_idx;
2569
2570 if (ref_frame_flag == VP8_LAST_FRAME)
2571 ref_fb_idx = cm->lst_fb_idx;
2572 else if (ref_frame_flag == VP8_GOLD_FRAME)
2573 ref_fb_idx = cm->gld_fb_idx;
2574 else if (ref_frame_flag == VP8_ALTR_FRAME)
2575 ref_fb_idx = cm->alt_fb_idx;
2576 else
2577 return -1;
2578
2579 vp8_yv12_copy_frame(&cm->yv12_fb[ref_fb_idx], sd);
2580
2581 return 0;
2582 }
vp8_set_reference(VP8_COMP * cpi,enum vpx_ref_frame_type ref_frame_flag,YV12_BUFFER_CONFIG * sd)2583 int vp8_set_reference(VP8_COMP *cpi, enum vpx_ref_frame_type ref_frame_flag, YV12_BUFFER_CONFIG *sd)
2584 {
2585 VP8_COMMON *cm = &cpi->common;
2586
2587 int ref_fb_idx;
2588
2589 if (ref_frame_flag == VP8_LAST_FRAME)
2590 ref_fb_idx = cm->lst_fb_idx;
2591 else if (ref_frame_flag == VP8_GOLD_FRAME)
2592 ref_fb_idx = cm->gld_fb_idx;
2593 else if (ref_frame_flag == VP8_ALTR_FRAME)
2594 ref_fb_idx = cm->alt_fb_idx;
2595 else
2596 return -1;
2597
2598 vp8_yv12_copy_frame(sd, &cm->yv12_fb[ref_fb_idx]);
2599
2600 return 0;
2601 }
vp8_update_entropy(VP8_COMP * cpi,int update)2602 int vp8_update_entropy(VP8_COMP *cpi, int update)
2603 {
2604 VP8_COMMON *cm = &cpi->common;
2605 cm->refresh_entropy_probs = update;
2606
2607 return 0;
2608 }
2609
2610
2611 #if OUTPUT_YUV_SRC
vp8_write_yuv_frame(const char * name,YV12_BUFFER_CONFIG * s)2612 void vp8_write_yuv_frame(const char *name, YV12_BUFFER_CONFIG *s)
2613 {
2614 FILE *yuv_file = fopen(name, "ab");
2615 unsigned char *src = s->y_buffer;
2616 int h = s->y_height;
2617
2618 do
2619 {
2620 fwrite(src, s->y_width, 1, yuv_file);
2621 src += s->y_stride;
2622 }
2623 while (--h);
2624
2625 src = s->u_buffer;
2626 h = s->uv_height;
2627
2628 do
2629 {
2630 fwrite(src, s->uv_width, 1, yuv_file);
2631 src += s->uv_stride;
2632 }
2633 while (--h);
2634
2635 src = s->v_buffer;
2636 h = s->uv_height;
2637
2638 do
2639 {
2640 fwrite(src, s->uv_width, 1, yuv_file);
2641 src += s->uv_stride;
2642 }
2643 while (--h);
2644
2645 fclose(yuv_file);
2646 }
2647 #endif
2648
2649
scale_and_extend_source(YV12_BUFFER_CONFIG * sd,VP8_COMP * cpi)2650 static void scale_and_extend_source(YV12_BUFFER_CONFIG *sd, VP8_COMP *cpi)
2651 {
2652 VP8_COMMON *cm = &cpi->common;
2653
2654 /* are we resizing the image */
2655 if (cm->horiz_scale != 0 || cm->vert_scale != 0)
2656 {
2657 #if CONFIG_SPATIAL_RESAMPLING
2658 int UNINITIALIZED_IS_SAFE(hr), UNINITIALIZED_IS_SAFE(hs);
2659 int UNINITIALIZED_IS_SAFE(vr), UNINITIALIZED_IS_SAFE(vs);
2660 int tmp_height;
2661
2662 if (cm->vert_scale == 3)
2663 tmp_height = 9;
2664 else
2665 tmp_height = 11;
2666
2667 Scale2Ratio(cm->horiz_scale, &hr, &hs);
2668 Scale2Ratio(cm->vert_scale, &vr, &vs);
2669
2670 vpx_scale_frame(sd, &cpi->scaled_source, cm->temp_scale_frame.y_buffer,
2671 tmp_height, hs, hr, vs, vr, 0);
2672
2673 vp8_yv12_extend_frame_borders(&cpi->scaled_source);
2674 cpi->Source = &cpi->scaled_source;
2675 #endif
2676 }
2677 else
2678 cpi->Source = sd;
2679 }
2680
2681
resize_key_frame(VP8_COMP * cpi)2682 static int resize_key_frame(VP8_COMP *cpi)
2683 {
2684 #if CONFIG_SPATIAL_RESAMPLING
2685 VP8_COMMON *cm = &cpi->common;
2686
2687 /* Do we need to apply resampling for one pass cbr.
2688 * In one pass this is more limited than in two pass cbr.
2689 * The test and any change is only made once per key frame sequence.
2690 */
2691 if (cpi->oxcf.allow_spatial_resampling && (cpi->oxcf.end_usage == USAGE_STREAM_FROM_SERVER))
2692 {
2693 int UNINITIALIZED_IS_SAFE(hr), UNINITIALIZED_IS_SAFE(hs);
2694 int UNINITIALIZED_IS_SAFE(vr), UNINITIALIZED_IS_SAFE(vs);
2695 int new_width, new_height;
2696
2697 /* If we are below the resample DOWN watermark then scale down a
2698 * notch.
2699 */
2700 if (cpi->buffer_level < (cpi->oxcf.resample_down_water_mark * cpi->oxcf.optimal_buffer_level / 100))
2701 {
2702 cm->horiz_scale = (cm->horiz_scale < ONETWO) ? cm->horiz_scale + 1 : ONETWO;
2703 cm->vert_scale = (cm->vert_scale < ONETWO) ? cm->vert_scale + 1 : ONETWO;
2704 }
2705 /* Should we now start scaling back up */
2706 else if (cpi->buffer_level > (cpi->oxcf.resample_up_water_mark * cpi->oxcf.optimal_buffer_level / 100))
2707 {
2708 cm->horiz_scale = (cm->horiz_scale > NORMAL) ? cm->horiz_scale - 1 : NORMAL;
2709 cm->vert_scale = (cm->vert_scale > NORMAL) ? cm->vert_scale - 1 : NORMAL;
2710 }
2711
2712 /* Get the new height and width */
2713 Scale2Ratio(cm->horiz_scale, &hr, &hs);
2714 Scale2Ratio(cm->vert_scale, &vr, &vs);
2715 new_width = ((hs - 1) + (cpi->oxcf.Width * hr)) / hs;
2716 new_height = ((vs - 1) + (cpi->oxcf.Height * vr)) / vs;
2717
2718 /* If the image size has changed we need to reallocate the buffers
2719 * and resample the source image
2720 */
2721 if ((cm->Width != new_width) || (cm->Height != new_height))
2722 {
2723 cm->Width = new_width;
2724 cm->Height = new_height;
2725 vp8_alloc_compressor_data(cpi);
2726 scale_and_extend_source(cpi->un_scaled_source, cpi);
2727 return 1;
2728 }
2729 }
2730
2731 #endif
2732 return 0;
2733 }
2734
2735
update_alt_ref_frame_stats(VP8_COMP * cpi)2736 static void update_alt_ref_frame_stats(VP8_COMP *cpi)
2737 {
2738 VP8_COMMON *cm = &cpi->common;
2739
2740 /* Select an interval before next GF or altref */
2741 if (!cpi->auto_gold)
2742 cpi->frames_till_gf_update_due = DEFAULT_GF_INTERVAL;
2743
2744 if ((cpi->pass != 2) && cpi->frames_till_gf_update_due)
2745 {
2746 cpi->current_gf_interval = cpi->frames_till_gf_update_due;
2747
2748 /* Set the bits per frame that we should try and recover in
2749 * subsequent inter frames to account for the extra GF spend...
2750 * note that his does not apply for GF updates that occur
2751 * coincident with a key frame as the extra cost of key frames is
2752 * dealt with elsewhere.
2753 */
2754 cpi->gf_overspend_bits += cpi->projected_frame_size;
2755 cpi->non_gf_bitrate_adjustment = cpi->gf_overspend_bits / cpi->frames_till_gf_update_due;
2756 }
2757
2758 /* Update data structure that monitors level of reference to last GF */
2759 vpx_memset(cpi->gf_active_flags, 1, (cm->mb_rows * cm->mb_cols));
2760 cpi->gf_active_count = cm->mb_rows * cm->mb_cols;
2761
2762 /* this frame refreshes means next frames don't unless specified by user */
2763 cpi->frames_since_golden = 0;
2764
2765 /* Clear the alternate reference update pending flag. */
2766 cpi->source_alt_ref_pending = 0;
2767
2768 /* Set the alternate reference frame active flag */
2769 cpi->source_alt_ref_active = 1;
2770
2771
2772 }
update_golden_frame_stats(VP8_COMP * cpi)2773 static void update_golden_frame_stats(VP8_COMP *cpi)
2774 {
2775 VP8_COMMON *cm = &cpi->common;
2776
2777 /* Update the Golden frame usage counts. */
2778 if (cm->refresh_golden_frame)
2779 {
2780 /* Select an interval before next GF */
2781 if (!cpi->auto_gold)
2782 cpi->frames_till_gf_update_due = DEFAULT_GF_INTERVAL;
2783
2784 if ((cpi->pass != 2) && (cpi->frames_till_gf_update_due > 0))
2785 {
2786 cpi->current_gf_interval = cpi->frames_till_gf_update_due;
2787
2788 /* Set the bits per frame that we should try and recover in
2789 * subsequent inter frames to account for the extra GF spend...
2790 * note that his does not apply for GF updates that occur
2791 * coincident with a key frame as the extra cost of key frames
2792 * is dealt with elsewhere.
2793 */
2794 if ((cm->frame_type != KEY_FRAME) && !cpi->source_alt_ref_active)
2795 {
2796 /* Calcluate GF bits to be recovered
2797 * Projected size - av frame bits available for inter
2798 * frames for clip as a whole
2799 */
2800 cpi->gf_overspend_bits += (cpi->projected_frame_size - cpi->inter_frame_target);
2801 }
2802
2803 cpi->non_gf_bitrate_adjustment = cpi->gf_overspend_bits / cpi->frames_till_gf_update_due;
2804
2805 }
2806
2807 /* Update data structure that monitors level of reference to last GF */
2808 vpx_memset(cpi->gf_active_flags, 1, (cm->mb_rows * cm->mb_cols));
2809 cpi->gf_active_count = cm->mb_rows * cm->mb_cols;
2810
2811 /* this frame refreshes means next frames don't unless specified by
2812 * user
2813 */
2814 cm->refresh_golden_frame = 0;
2815 cpi->frames_since_golden = 0;
2816
2817 cpi->recent_ref_frame_usage[INTRA_FRAME] = 1;
2818 cpi->recent_ref_frame_usage[LAST_FRAME] = 1;
2819 cpi->recent_ref_frame_usage[GOLDEN_FRAME] = 1;
2820 cpi->recent_ref_frame_usage[ALTREF_FRAME] = 1;
2821
2822 /* ******** Fixed Q test code only ************ */
2823 /* If we are going to use the ALT reference for the next group of
2824 * frames set a flag to say so.
2825 */
2826 if (cpi->oxcf.fixed_q >= 0 &&
2827 cpi->oxcf.play_alternate && !cpi->common.refresh_alt_ref_frame)
2828 {
2829 cpi->source_alt_ref_pending = 1;
2830 cpi->frames_till_gf_update_due = cpi->baseline_gf_interval;
2831 }
2832
2833 if (!cpi->source_alt_ref_pending)
2834 cpi->source_alt_ref_active = 0;
2835
2836 /* Decrement count down till next gf */
2837 if (cpi->frames_till_gf_update_due > 0)
2838 cpi->frames_till_gf_update_due--;
2839
2840 }
2841 else if (!cpi->common.refresh_alt_ref_frame)
2842 {
2843 /* Decrement count down till next gf */
2844 if (cpi->frames_till_gf_update_due > 0)
2845 cpi->frames_till_gf_update_due--;
2846
2847 if (cpi->frames_till_alt_ref_frame)
2848 cpi->frames_till_alt_ref_frame --;
2849
2850 cpi->frames_since_golden ++;
2851
2852 if (cpi->frames_since_golden > 1)
2853 {
2854 cpi->recent_ref_frame_usage[INTRA_FRAME] +=
2855 cpi->mb.count_mb_ref_frame_usage[INTRA_FRAME];
2856 cpi->recent_ref_frame_usage[LAST_FRAME] +=
2857 cpi->mb.count_mb_ref_frame_usage[LAST_FRAME];
2858 cpi->recent_ref_frame_usage[GOLDEN_FRAME] +=
2859 cpi->mb.count_mb_ref_frame_usage[GOLDEN_FRAME];
2860 cpi->recent_ref_frame_usage[ALTREF_FRAME] +=
2861 cpi->mb.count_mb_ref_frame_usage[ALTREF_FRAME];
2862 }
2863 }
2864 }
2865
2866 /* This function updates the reference frame probability estimates that
2867 * will be used during mode selection
2868 */
update_rd_ref_frame_probs(VP8_COMP * cpi)2869 static void update_rd_ref_frame_probs(VP8_COMP *cpi)
2870 {
2871 VP8_COMMON *cm = &cpi->common;
2872
2873 const int *const rfct = cpi->mb.count_mb_ref_frame_usage;
2874 const int rf_intra = rfct[INTRA_FRAME];
2875 const int rf_inter = rfct[LAST_FRAME] + rfct[GOLDEN_FRAME] + rfct[ALTREF_FRAME];
2876
2877 if (cm->frame_type == KEY_FRAME)
2878 {
2879 cpi->prob_intra_coded = 255;
2880 cpi->prob_last_coded = 128;
2881 cpi->prob_gf_coded = 128;
2882 }
2883 else if (!(rf_intra + rf_inter))
2884 {
2885 cpi->prob_intra_coded = 63;
2886 cpi->prob_last_coded = 128;
2887 cpi->prob_gf_coded = 128;
2888 }
2889
2890 /* update reference frame costs since we can do better than what we got
2891 * last frame.
2892 */
2893 if (cpi->oxcf.number_of_layers == 1)
2894 {
2895 if (cpi->common.refresh_alt_ref_frame)
2896 {
2897 cpi->prob_intra_coded += 40;
2898 if (cpi->prob_intra_coded > 255)
2899 cpi->prob_intra_coded = 255;
2900 cpi->prob_last_coded = 200;
2901 cpi->prob_gf_coded = 1;
2902 }
2903 else if (cpi->frames_since_golden == 0)
2904 {
2905 cpi->prob_last_coded = 214;
2906 }
2907 else if (cpi->frames_since_golden == 1)
2908 {
2909 cpi->prob_last_coded = 192;
2910 cpi->prob_gf_coded = 220;
2911 }
2912 else if (cpi->source_alt_ref_active)
2913 {
2914 cpi->prob_gf_coded -= 20;
2915
2916 if (cpi->prob_gf_coded < 10)
2917 cpi->prob_gf_coded = 10;
2918 }
2919 if (!cpi->source_alt_ref_active)
2920 cpi->prob_gf_coded = 255;
2921 }
2922 }
2923
2924
2925 /* 1 = key, 0 = inter */
decide_key_frame(VP8_COMP * cpi)2926 static int decide_key_frame(VP8_COMP *cpi)
2927 {
2928 VP8_COMMON *cm = &cpi->common;
2929
2930 int code_key_frame = 0;
2931
2932 cpi->kf_boost = 0;
2933
2934 if (cpi->Speed > 11)
2935 return 0;
2936
2937 /* Clear down mmx registers */
2938 vp8_clear_system_state();
2939
2940 if ((cpi->compressor_speed == 2) && (cpi->Speed >= 5) && (cpi->sf.RD == 0))
2941 {
2942 double change = 1.0 * abs((int)(cpi->mb.intra_error -
2943 cpi->last_intra_error)) / (1 + cpi->last_intra_error);
2944 double change2 = 1.0 * abs((int)(cpi->mb.prediction_error -
2945 cpi->last_prediction_error)) / (1 + cpi->last_prediction_error);
2946 double minerror = cm->MBs * 256;
2947
2948 cpi->last_intra_error = cpi->mb.intra_error;
2949 cpi->last_prediction_error = cpi->mb.prediction_error;
2950
2951 if (10 * cpi->mb.intra_error / (1 + cpi->mb.prediction_error) < 15
2952 && cpi->mb.prediction_error > minerror
2953 && (change > .25 || change2 > .25))
2954 {
2955 /*(change > 1.4 || change < .75)&& cpi->this_frame_percent_intra > cpi->last_frame_percent_intra + 3*/
2956 return 1;
2957 }
2958
2959 return 0;
2960
2961 }
2962
2963 /* If the following are true we might as well code a key frame */
2964 if (((cpi->this_frame_percent_intra == 100) &&
2965 (cpi->this_frame_percent_intra > (cpi->last_frame_percent_intra + 2))) ||
2966 ((cpi->this_frame_percent_intra > 95) &&
2967 (cpi->this_frame_percent_intra >= (cpi->last_frame_percent_intra + 5))))
2968 {
2969 code_key_frame = 1;
2970 }
2971 /* in addition if the following are true and this is not a golden frame
2972 * then code a key frame Note that on golden frames there often seems
2973 * to be a pop in intra useage anyway hence this restriction is
2974 * designed to prevent spurious key frames. The Intra pop needs to be
2975 * investigated.
2976 */
2977 else if (((cpi->this_frame_percent_intra > 60) &&
2978 (cpi->this_frame_percent_intra > (cpi->last_frame_percent_intra * 2))) ||
2979 ((cpi->this_frame_percent_intra > 75) &&
2980 (cpi->this_frame_percent_intra > (cpi->last_frame_percent_intra * 3 / 2))) ||
2981 ((cpi->this_frame_percent_intra > 90) &&
2982 (cpi->this_frame_percent_intra > (cpi->last_frame_percent_intra + 10))))
2983 {
2984 if (!cm->refresh_golden_frame)
2985 code_key_frame = 1;
2986 }
2987
2988 return code_key_frame;
2989
2990 }
2991
2992 #if !(CONFIG_REALTIME_ONLY)
Pass1Encode(VP8_COMP * cpi,unsigned long * size,unsigned char * dest,unsigned int * frame_flags)2993 static void Pass1Encode(VP8_COMP *cpi, unsigned long *size, unsigned char *dest, unsigned int *frame_flags)
2994 {
2995 (void) size;
2996 (void) dest;
2997 (void) frame_flags;
2998 vp8_set_quantizer(cpi, 26);
2999
3000 vp8_first_pass(cpi);
3001 }
3002 #endif
3003
3004 #if 0
3005 void write_cx_frame_to_file(YV12_BUFFER_CONFIG *frame, int this_frame)
3006 {
3007
3008 /* write the frame */
3009 FILE *yframe;
3010 int i;
3011 char filename[255];
3012
3013 sprintf(filename, "cx\\y%04d.raw", this_frame);
3014 yframe = fopen(filename, "wb");
3015
3016 for (i = 0; i < frame->y_height; i++)
3017 fwrite(frame->y_buffer + i * frame->y_stride, frame->y_width, 1, yframe);
3018
3019 fclose(yframe);
3020 sprintf(filename, "cx\\u%04d.raw", this_frame);
3021 yframe = fopen(filename, "wb");
3022
3023 for (i = 0; i < frame->uv_height; i++)
3024 fwrite(frame->u_buffer + i * frame->uv_stride, frame->uv_width, 1, yframe);
3025
3026 fclose(yframe);
3027 sprintf(filename, "cx\\v%04d.raw", this_frame);
3028 yframe = fopen(filename, "wb");
3029
3030 for (i = 0; i < frame->uv_height; i++)
3031 fwrite(frame->v_buffer + i * frame->uv_stride, frame->uv_width, 1, yframe);
3032
3033 fclose(yframe);
3034 }
3035 #endif
3036 /* return of 0 means drop frame */
3037
3038 /* Function to test for conditions that indeicate we should loop
3039 * back and recode a frame.
3040 */
recode_loop_test(VP8_COMP * cpi,int high_limit,int low_limit,int q,int maxq,int minq)3041 static int recode_loop_test( VP8_COMP *cpi,
3042 int high_limit, int low_limit,
3043 int q, int maxq, int minq )
3044 {
3045 int force_recode = 0;
3046 VP8_COMMON *cm = &cpi->common;
3047
3048 /* Is frame recode allowed at all
3049 * Yes if either recode mode 1 is selected or mode two is selcted
3050 * and the frame is a key frame. golden frame or alt_ref_frame
3051 */
3052 if ( (cpi->sf.recode_loop == 1) ||
3053 ( (cpi->sf.recode_loop == 2) &&
3054 ( (cm->frame_type == KEY_FRAME) ||
3055 cm->refresh_golden_frame ||
3056 cm->refresh_alt_ref_frame ) ) )
3057 {
3058 /* General over and under shoot tests */
3059 if ( ((cpi->projected_frame_size > high_limit) && (q < maxq)) ||
3060 ((cpi->projected_frame_size < low_limit) && (q > minq)) )
3061 {
3062 force_recode = 1;
3063 }
3064 /* Special Constrained quality tests */
3065 else if (cpi->oxcf.end_usage == USAGE_CONSTRAINED_QUALITY)
3066 {
3067 /* Undershoot and below auto cq level */
3068 if ( (q > cpi->cq_target_quality) &&
3069 (cpi->projected_frame_size <
3070 ((cpi->this_frame_target * 7) >> 3)))
3071 {
3072 force_recode = 1;
3073 }
3074 /* Severe undershoot and between auto and user cq level */
3075 else if ( (q > cpi->oxcf.cq_level) &&
3076 (cpi->projected_frame_size < cpi->min_frame_bandwidth) &&
3077 (cpi->active_best_quality > cpi->oxcf.cq_level))
3078 {
3079 force_recode = 1;
3080 cpi->active_best_quality = cpi->oxcf.cq_level;
3081 }
3082 }
3083 }
3084
3085 return force_recode;
3086 }
3087
update_reference_frames(VP8_COMP * cpi)3088 static void update_reference_frames(VP8_COMP *cpi)
3089 {
3090 VP8_COMMON *cm = &cpi->common;
3091 YV12_BUFFER_CONFIG *yv12_fb = cm->yv12_fb;
3092
3093 /* At this point the new frame has been encoded.
3094 * If any buffer copy / swapping is signaled it should be done here.
3095 */
3096
3097 if (cm->frame_type == KEY_FRAME)
3098 {
3099 yv12_fb[cm->new_fb_idx].flags |= VP8_GOLD_FRAME | VP8_ALTR_FRAME ;
3100
3101 yv12_fb[cm->gld_fb_idx].flags &= ~VP8_GOLD_FRAME;
3102 yv12_fb[cm->alt_fb_idx].flags &= ~VP8_ALTR_FRAME;
3103
3104 cm->alt_fb_idx = cm->gld_fb_idx = cm->new_fb_idx;
3105
3106 #if CONFIG_MULTI_RES_ENCODING
3107 cpi->current_ref_frames[GOLDEN_FRAME] = cm->current_video_frame;
3108 cpi->current_ref_frames[ALTREF_FRAME] = cm->current_video_frame;
3109 #endif
3110 }
3111 else /* For non key frames */
3112 {
3113 if (cm->refresh_alt_ref_frame)
3114 {
3115 assert(!cm->copy_buffer_to_arf);
3116
3117 cm->yv12_fb[cm->new_fb_idx].flags |= VP8_ALTR_FRAME;
3118 cm->yv12_fb[cm->alt_fb_idx].flags &= ~VP8_ALTR_FRAME;
3119 cm->alt_fb_idx = cm->new_fb_idx;
3120
3121 #if CONFIG_MULTI_RES_ENCODING
3122 cpi->current_ref_frames[ALTREF_FRAME] = cm->current_video_frame;
3123 #endif
3124 }
3125 else if (cm->copy_buffer_to_arf)
3126 {
3127 assert(!(cm->copy_buffer_to_arf & ~0x3));
3128
3129 if (cm->copy_buffer_to_arf == 1)
3130 {
3131 if(cm->alt_fb_idx != cm->lst_fb_idx)
3132 {
3133 yv12_fb[cm->lst_fb_idx].flags |= VP8_ALTR_FRAME;
3134 yv12_fb[cm->alt_fb_idx].flags &= ~VP8_ALTR_FRAME;
3135 cm->alt_fb_idx = cm->lst_fb_idx;
3136
3137 #if CONFIG_MULTI_RES_ENCODING
3138 cpi->current_ref_frames[ALTREF_FRAME] =
3139 cpi->current_ref_frames[LAST_FRAME];
3140 #endif
3141 }
3142 }
3143 else /* if (cm->copy_buffer_to_arf == 2) */
3144 {
3145 if(cm->alt_fb_idx != cm->gld_fb_idx)
3146 {
3147 yv12_fb[cm->gld_fb_idx].flags |= VP8_ALTR_FRAME;
3148 yv12_fb[cm->alt_fb_idx].flags &= ~VP8_ALTR_FRAME;
3149 cm->alt_fb_idx = cm->gld_fb_idx;
3150
3151 #if CONFIG_MULTI_RES_ENCODING
3152 cpi->current_ref_frames[ALTREF_FRAME] =
3153 cpi->current_ref_frames[GOLDEN_FRAME];
3154 #endif
3155 }
3156 }
3157 }
3158
3159 if (cm->refresh_golden_frame)
3160 {
3161 assert(!cm->copy_buffer_to_gf);
3162
3163 cm->yv12_fb[cm->new_fb_idx].flags |= VP8_GOLD_FRAME;
3164 cm->yv12_fb[cm->gld_fb_idx].flags &= ~VP8_GOLD_FRAME;
3165 cm->gld_fb_idx = cm->new_fb_idx;
3166
3167 #if CONFIG_MULTI_RES_ENCODING
3168 cpi->current_ref_frames[GOLDEN_FRAME] = cm->current_video_frame;
3169 #endif
3170 }
3171 else if (cm->copy_buffer_to_gf)
3172 {
3173 assert(!(cm->copy_buffer_to_arf & ~0x3));
3174
3175 if (cm->copy_buffer_to_gf == 1)
3176 {
3177 if(cm->gld_fb_idx != cm->lst_fb_idx)
3178 {
3179 yv12_fb[cm->lst_fb_idx].flags |= VP8_GOLD_FRAME;
3180 yv12_fb[cm->gld_fb_idx].flags &= ~VP8_GOLD_FRAME;
3181 cm->gld_fb_idx = cm->lst_fb_idx;
3182
3183 #if CONFIG_MULTI_RES_ENCODING
3184 cpi->current_ref_frames[GOLDEN_FRAME] =
3185 cpi->current_ref_frames[LAST_FRAME];
3186 #endif
3187 }
3188 }
3189 else /* if (cm->copy_buffer_to_gf == 2) */
3190 {
3191 if(cm->alt_fb_idx != cm->gld_fb_idx)
3192 {
3193 yv12_fb[cm->alt_fb_idx].flags |= VP8_GOLD_FRAME;
3194 yv12_fb[cm->gld_fb_idx].flags &= ~VP8_GOLD_FRAME;
3195 cm->gld_fb_idx = cm->alt_fb_idx;
3196
3197 #if CONFIG_MULTI_RES_ENCODING
3198 cpi->current_ref_frames[GOLDEN_FRAME] =
3199 cpi->current_ref_frames[ALTREF_FRAME];
3200 #endif
3201 }
3202 }
3203 }
3204 }
3205
3206 if (cm->refresh_last_frame)
3207 {
3208 cm->yv12_fb[cm->new_fb_idx].flags |= VP8_LAST_FRAME;
3209 cm->yv12_fb[cm->lst_fb_idx].flags &= ~VP8_LAST_FRAME;
3210 cm->lst_fb_idx = cm->new_fb_idx;
3211
3212 #if CONFIG_MULTI_RES_ENCODING
3213 cpi->current_ref_frames[LAST_FRAME] = cm->current_video_frame;
3214 #endif
3215 }
3216
3217 #if CONFIG_TEMPORAL_DENOISING
3218 if (cpi->oxcf.noise_sensitivity)
3219 {
3220 /* we shouldn't have to keep multiple copies as we know in advance which
3221 * buffer we should start - for now to get something up and running
3222 * I've chosen to copy the buffers
3223 */
3224 if (cm->frame_type == KEY_FRAME)
3225 {
3226 int i;
3227 vp8_yv12_copy_frame(
3228 cpi->Source,
3229 &cpi->denoiser.yv12_running_avg[LAST_FRAME]);
3230
3231 vp8_yv12_extend_frame_borders(
3232 &cpi->denoiser.yv12_running_avg[LAST_FRAME]);
3233
3234 for (i = 2; i < MAX_REF_FRAMES - 1; i++)
3235 vp8_yv12_copy_frame(
3236 &cpi->denoiser.yv12_running_avg[LAST_FRAME],
3237 &cpi->denoiser.yv12_running_avg[i]);
3238 }
3239 else /* For non key frames */
3240 {
3241 vp8_yv12_extend_frame_borders(
3242 &cpi->denoiser.yv12_running_avg[INTRA_FRAME]);
3243
3244 if (cm->refresh_alt_ref_frame || cm->copy_buffer_to_arf)
3245 {
3246 vp8_yv12_copy_frame(
3247 &cpi->denoiser.yv12_running_avg[INTRA_FRAME],
3248 &cpi->denoiser.yv12_running_avg[ALTREF_FRAME]);
3249 }
3250 if (cm->refresh_golden_frame || cm->copy_buffer_to_gf)
3251 {
3252 vp8_yv12_copy_frame(
3253 &cpi->denoiser.yv12_running_avg[INTRA_FRAME],
3254 &cpi->denoiser.yv12_running_avg[GOLDEN_FRAME]);
3255 }
3256 if(cm->refresh_last_frame)
3257 {
3258 vp8_yv12_copy_frame(
3259 &cpi->denoiser.yv12_running_avg[INTRA_FRAME],
3260 &cpi->denoiser.yv12_running_avg[LAST_FRAME]);
3261 }
3262 }
3263
3264 }
3265 #endif
3266
3267 }
3268
vp8_loopfilter_frame(VP8_COMP * cpi,VP8_COMMON * cm)3269 void vp8_loopfilter_frame(VP8_COMP *cpi, VP8_COMMON *cm)
3270 {
3271 const FRAME_TYPE frame_type = cm->frame_type;
3272
3273 if (cm->no_lpf)
3274 {
3275 cm->filter_level = 0;
3276 }
3277 else
3278 {
3279 struct vpx_usec_timer timer;
3280
3281 vp8_clear_system_state();
3282
3283 vpx_usec_timer_start(&timer);
3284 if (cpi->sf.auto_filter == 0)
3285 vp8cx_pick_filter_level_fast(cpi->Source, cpi);
3286
3287 else
3288 vp8cx_pick_filter_level(cpi->Source, cpi);
3289
3290 if (cm->filter_level > 0)
3291 {
3292 vp8cx_set_alt_lf_level(cpi, cm->filter_level);
3293 }
3294
3295 vpx_usec_timer_mark(&timer);
3296 cpi->time_pick_lpf += vpx_usec_timer_elapsed(&timer);
3297 }
3298
3299 #if CONFIG_MULTITHREAD
3300 if (cpi->b_multi_threaded)
3301 sem_post(&cpi->h_event_end_lpf); /* signal that we have set filter_level */
3302 #endif
3303
3304 if (cm->filter_level > 0)
3305 {
3306 vp8_loop_filter_frame(cm, &cpi->mb.e_mbd, frame_type);
3307 }
3308
3309 vp8_yv12_extend_frame_borders(cm->frame_to_show);
3310
3311 }
3312
encode_frame_to_data_rate(VP8_COMP * cpi,unsigned long * size,unsigned char * dest,unsigned char * dest_end,unsigned int * frame_flags)3313 static void encode_frame_to_data_rate
3314 (
3315 VP8_COMP *cpi,
3316 unsigned long *size,
3317 unsigned char *dest,
3318 unsigned char* dest_end,
3319 unsigned int *frame_flags
3320 )
3321 {
3322 int Q;
3323 int frame_over_shoot_limit;
3324 int frame_under_shoot_limit;
3325
3326 int Loop = 0;
3327 int loop_count;
3328
3329 VP8_COMMON *cm = &cpi->common;
3330 int active_worst_qchanged = 0;
3331
3332 #if !(CONFIG_REALTIME_ONLY)
3333 int q_low;
3334 int q_high;
3335 int zbin_oq_high;
3336 int zbin_oq_low = 0;
3337 int top_index;
3338 int bottom_index;
3339 int overshoot_seen = 0;
3340 int undershoot_seen = 0;
3341 #endif
3342
3343 int drop_mark = (int)(cpi->oxcf.drop_frames_water_mark *
3344 cpi->oxcf.optimal_buffer_level / 100);
3345 int drop_mark75 = drop_mark * 2 / 3;
3346 int drop_mark50 = drop_mark / 4;
3347 int drop_mark25 = drop_mark / 8;
3348
3349
3350 /* Clear down mmx registers to allow floating point in what follows */
3351 vp8_clear_system_state();
3352
3353 #if CONFIG_MULTITHREAD
3354 /* wait for the last picture loopfilter thread done */
3355 if (cpi->b_lpf_running)
3356 {
3357 sem_wait(&cpi->h_event_end_lpf);
3358 cpi->b_lpf_running = 0;
3359 }
3360 #endif
3361
3362 if(cpi->force_next_frame_intra)
3363 {
3364 cm->frame_type = KEY_FRAME; /* delayed intra frame */
3365 cpi->force_next_frame_intra = 0;
3366 }
3367
3368 /* For an alt ref frame in 2 pass we skip the call to the second pass
3369 * function that sets the target bandwidth
3370 */
3371 #if !(CONFIG_REALTIME_ONLY)
3372
3373 if (cpi->pass == 2)
3374 {
3375 if (cpi->common.refresh_alt_ref_frame)
3376 {
3377 /* Per frame bit target for the alt ref frame */
3378 cpi->per_frame_bandwidth = cpi->twopass.gf_bits;
3379 /* per second target bitrate */
3380 cpi->target_bandwidth = (int)(cpi->twopass.gf_bits *
3381 cpi->output_framerate);
3382 }
3383 }
3384 else
3385 #endif
3386 cpi->per_frame_bandwidth = (int)(cpi->target_bandwidth / cpi->output_framerate);
3387
3388 /* Default turn off buffer to buffer copying */
3389 cm->copy_buffer_to_gf = 0;
3390 cm->copy_buffer_to_arf = 0;
3391
3392 /* Clear zbin over-quant value and mode boost values. */
3393 cpi->mb.zbin_over_quant = 0;
3394 cpi->mb.zbin_mode_boost = 0;
3395
3396 /* Enable or disable mode based tweaking of the zbin
3397 * For 2 Pass Only used where GF/ARF prediction quality
3398 * is above a threshold
3399 */
3400 cpi->mb.zbin_mode_boost_enabled = 1;
3401 if (cpi->pass == 2)
3402 {
3403 if ( cpi->gfu_boost <= 400 )
3404 {
3405 cpi->mb.zbin_mode_boost_enabled = 0;
3406 }
3407 }
3408
3409 /* Current default encoder behaviour for the altref sign bias */
3410 if (cpi->source_alt_ref_active)
3411 cpi->common.ref_frame_sign_bias[ALTREF_FRAME] = 1;
3412 else
3413 cpi->common.ref_frame_sign_bias[ALTREF_FRAME] = 0;
3414
3415 /* Check to see if a key frame is signaled
3416 * For two pass with auto key frame enabled cm->frame_type may already
3417 * be set, but not for one pass.
3418 */
3419 if ((cm->current_video_frame == 0) ||
3420 (cm->frame_flags & FRAMEFLAGS_KEY) ||
3421 (cpi->oxcf.auto_key && (cpi->frames_since_key % cpi->key_frame_frequency == 0)))
3422 {
3423 /* Key frame from VFW/auto-keyframe/first frame */
3424 cm->frame_type = KEY_FRAME;
3425 }
3426
3427 #if CONFIG_MULTI_RES_ENCODING
3428 /* In multi-resolution encoding, frame_type is decided by lowest-resolution
3429 * encoder. Same frame_type is adopted while encoding at other resolution.
3430 */
3431 if (cpi->oxcf.mr_encoder_id)
3432 {
3433 LOWER_RES_FRAME_INFO* low_res_frame_info
3434 = (LOWER_RES_FRAME_INFO*)cpi->oxcf.mr_low_res_mode_info;
3435
3436 cm->frame_type = low_res_frame_info->frame_type;
3437
3438 if(cm->frame_type != KEY_FRAME)
3439 {
3440 cpi->mr_low_res_mv_avail = 1;
3441 cpi->mr_low_res_mv_avail &= !(low_res_frame_info->is_frame_dropped);
3442
3443 if (cpi->ref_frame_flags & VP8_LAST_FRAME)
3444 cpi->mr_low_res_mv_avail &= (cpi->current_ref_frames[LAST_FRAME]
3445 == low_res_frame_info->low_res_ref_frames[LAST_FRAME]);
3446
3447 if (cpi->ref_frame_flags & VP8_GOLD_FRAME)
3448 cpi->mr_low_res_mv_avail &= (cpi->current_ref_frames[GOLDEN_FRAME]
3449 == low_res_frame_info->low_res_ref_frames[GOLDEN_FRAME]);
3450
3451 if (cpi->ref_frame_flags & VP8_ALTR_FRAME)
3452 cpi->mr_low_res_mv_avail &= (cpi->current_ref_frames[ALTREF_FRAME]
3453 == low_res_frame_info->low_res_ref_frames[ALTREF_FRAME]);
3454 }
3455 }
3456 #endif
3457
3458 /* Set various flags etc to special state if it is a key frame */
3459 if (cm->frame_type == KEY_FRAME)
3460 {
3461 int i;
3462
3463 // Set the loop filter deltas and segmentation map update
3464 setup_features(cpi);
3465
3466 /* The alternate reference frame cannot be active for a key frame */
3467 cpi->source_alt_ref_active = 0;
3468
3469 /* Reset the RD threshold multipliers to default of * 1 (128) */
3470 for (i = 0; i < MAX_MODES; i++)
3471 {
3472 cpi->mb.rd_thresh_mult[i] = 128;
3473 }
3474 }
3475
3476 #if 0
3477 /* Experimental code for lagged compress and one pass
3478 * Initialise one_pass GF frames stats
3479 * Update stats used for GF selection
3480 */
3481 {
3482 cpi->one_pass_frame_index = cm->current_video_frame % MAX_LAG_BUFFERS;
3483
3484 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frames_so_far = 0;
3485 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_intra_error = 0.0;
3486 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_coded_error = 0.0;
3487 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_pcnt_inter = 0.0;
3488 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_pcnt_motion = 0.0;
3489 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_mvr = 0.0;
3490 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_mvr_abs = 0.0;
3491 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_mvc = 0.0;
3492 cpi->one_pass_frame_stats[cpi->one_pass_frame_index ].frame_mvc_abs = 0.0;
3493 }
3494 #endif
3495
3496 update_rd_ref_frame_probs(cpi);
3497
3498 if (cpi->drop_frames_allowed)
3499 {
3500 /* The reset to decimation 0 is only done here for one pass.
3501 * Once it is set two pass leaves decimation on till the next kf.
3502 */
3503 if ((cpi->buffer_level > drop_mark) && (cpi->decimation_factor > 0))
3504 cpi->decimation_factor --;
3505
3506 if (cpi->buffer_level > drop_mark75 && cpi->decimation_factor > 0)
3507 cpi->decimation_factor = 1;
3508
3509 else if (cpi->buffer_level < drop_mark25 && (cpi->decimation_factor == 2 || cpi->decimation_factor == 3))
3510 {
3511 cpi->decimation_factor = 3;
3512 }
3513 else if (cpi->buffer_level < drop_mark50 && (cpi->decimation_factor == 1 || cpi->decimation_factor == 2))
3514 {
3515 cpi->decimation_factor = 2;
3516 }
3517 else if (cpi->buffer_level < drop_mark75 && (cpi->decimation_factor == 0 || cpi->decimation_factor == 1))
3518 {
3519 cpi->decimation_factor = 1;
3520 }
3521 }
3522
3523 /* The following decimates the frame rate according to a regular
3524 * pattern (i.e. to 1/2 or 2/3 frame rate) This can be used to help
3525 * prevent buffer under-run in CBR mode. Alternatively it might be
3526 * desirable in some situations to drop frame rate but throw more bits
3527 * at each frame.
3528 *
3529 * Note that dropping a key frame can be problematic if spatial
3530 * resampling is also active
3531 */
3532 if (cpi->decimation_factor > 0)
3533 {
3534 switch (cpi->decimation_factor)
3535 {
3536 case 1:
3537 cpi->per_frame_bandwidth = cpi->per_frame_bandwidth * 3 / 2;
3538 break;
3539 case 2:
3540 cpi->per_frame_bandwidth = cpi->per_frame_bandwidth * 5 / 4;
3541 break;
3542 case 3:
3543 cpi->per_frame_bandwidth = cpi->per_frame_bandwidth * 5 / 4;
3544 break;
3545 }
3546
3547 /* Note that we should not throw out a key frame (especially when
3548 * spatial resampling is enabled).
3549 */
3550 if (cm->frame_type == KEY_FRAME)
3551 {
3552 cpi->decimation_count = cpi->decimation_factor;
3553 }
3554 else if (cpi->decimation_count > 0)
3555 {
3556 cpi->decimation_count --;
3557
3558 cpi->bits_off_target += cpi->av_per_frame_bandwidth;
3559 if (cpi->bits_off_target > cpi->oxcf.maximum_buffer_size)
3560 cpi->bits_off_target = cpi->oxcf.maximum_buffer_size;
3561
3562 #if CONFIG_MULTI_RES_ENCODING
3563 vp8_store_drop_frame_info(cpi);
3564 #endif
3565
3566 cm->current_video_frame++;
3567 cpi->frames_since_key++;
3568 // We advance the temporal pattern for dropped frames.
3569 cpi->temporal_pattern_counter++;
3570
3571 #if CONFIG_INTERNAL_STATS
3572 cpi->count ++;
3573 #endif
3574
3575 cpi->buffer_level = cpi->bits_off_target;
3576
3577 if (cpi->oxcf.number_of_layers > 1)
3578 {
3579 unsigned int i;
3580
3581 /* Propagate bits saved by dropping the frame to higher
3582 * layers
3583 */
3584 for (i=cpi->current_layer+1; i<cpi->oxcf.number_of_layers; i++)
3585 {
3586 LAYER_CONTEXT *lc = &cpi->layer_context[i];
3587 lc->bits_off_target += (int)(lc->target_bandwidth /
3588 lc->framerate);
3589 if (lc->bits_off_target > lc->maximum_buffer_size)
3590 lc->bits_off_target = lc->maximum_buffer_size;
3591 lc->buffer_level = lc->bits_off_target;
3592 }
3593 }
3594
3595 return;
3596 }
3597 else
3598 cpi->decimation_count = cpi->decimation_factor;
3599 }
3600 else
3601 cpi->decimation_count = 0;
3602
3603 /* Decide how big to make the frame */
3604 if (!vp8_pick_frame_size(cpi))
3605 {
3606 /*TODO: 2 drop_frame and return code could be put together. */
3607 #if CONFIG_MULTI_RES_ENCODING
3608 vp8_store_drop_frame_info(cpi);
3609 #endif
3610 cm->current_video_frame++;
3611 cpi->frames_since_key++;
3612 // We advance the temporal pattern for dropped frames.
3613 cpi->temporal_pattern_counter++;
3614 return;
3615 }
3616
3617 /* Reduce active_worst_allowed_q for CBR if our buffer is getting too full.
3618 * This has a knock on effect on active best quality as well.
3619 * For CBR if the buffer reaches its maximum level then we can no longer
3620 * save up bits for later frames so we might as well use them up
3621 * on the current frame.
3622 */
3623 if ((cpi->oxcf.end_usage == USAGE_STREAM_FROM_SERVER) &&
3624 (cpi->buffer_level >= cpi->oxcf.optimal_buffer_level) && cpi->buffered_mode)
3625 {
3626 /* Max adjustment is 1/4 */
3627 int Adjustment = cpi->active_worst_quality / 4;
3628
3629 if (Adjustment)
3630 {
3631 int buff_lvl_step;
3632
3633 if (cpi->buffer_level < cpi->oxcf.maximum_buffer_size)
3634 {
3635 buff_lvl_step = (int)
3636 ((cpi->oxcf.maximum_buffer_size -
3637 cpi->oxcf.optimal_buffer_level) /
3638 Adjustment);
3639
3640 if (buff_lvl_step)
3641 Adjustment = (int)
3642 ((cpi->buffer_level -
3643 cpi->oxcf.optimal_buffer_level) /
3644 buff_lvl_step);
3645 else
3646 Adjustment = 0;
3647 }
3648
3649 cpi->active_worst_quality -= Adjustment;
3650
3651 if(cpi->active_worst_quality < cpi->active_best_quality)
3652 cpi->active_worst_quality = cpi->active_best_quality;
3653 }
3654 }
3655
3656 /* Set an active best quality and if necessary active worst quality
3657 * There is some odd behavior for one pass here that needs attention.
3658 */
3659 if ( (cpi->pass == 2) || (cpi->ni_frames > 150))
3660 {
3661 vp8_clear_system_state();
3662
3663 Q = cpi->active_worst_quality;
3664
3665 if ( cm->frame_type == KEY_FRAME )
3666 {
3667 if ( cpi->pass == 2 )
3668 {
3669 if (cpi->gfu_boost > 600)
3670 cpi->active_best_quality = kf_low_motion_minq[Q];
3671 else
3672 cpi->active_best_quality = kf_high_motion_minq[Q];
3673
3674 /* Special case for key frames forced because we have reached
3675 * the maximum key frame interval. Here force the Q to a range
3676 * based on the ambient Q to reduce the risk of popping
3677 */
3678 if ( cpi->this_key_frame_forced )
3679 {
3680 if ( cpi->active_best_quality > cpi->avg_frame_qindex * 7/8)
3681 cpi->active_best_quality = cpi->avg_frame_qindex * 7/8;
3682 else if ( cpi->active_best_quality < cpi->avg_frame_qindex >> 2 )
3683 cpi->active_best_quality = cpi->avg_frame_qindex >> 2;
3684 }
3685 }
3686 /* One pass more conservative */
3687 else
3688 cpi->active_best_quality = kf_high_motion_minq[Q];
3689 }
3690
3691 else if (cpi->oxcf.number_of_layers==1 &&
3692 (cm->refresh_golden_frame || cpi->common.refresh_alt_ref_frame))
3693 {
3694 /* Use the lower of cpi->active_worst_quality and recent
3695 * average Q as basis for GF/ARF Q limit unless last frame was
3696 * a key frame.
3697 */
3698 if ( (cpi->frames_since_key > 1) &&
3699 (cpi->avg_frame_qindex < cpi->active_worst_quality) )
3700 {
3701 Q = cpi->avg_frame_qindex;
3702 }
3703
3704 /* For constrained quality dont allow Q less than the cq level */
3705 if ( (cpi->oxcf.end_usage == USAGE_CONSTRAINED_QUALITY) &&
3706 (Q < cpi->cq_target_quality) )
3707 {
3708 Q = cpi->cq_target_quality;
3709 }
3710
3711 if ( cpi->pass == 2 )
3712 {
3713 if ( cpi->gfu_boost > 1000 )
3714 cpi->active_best_quality = gf_low_motion_minq[Q];
3715 else if ( cpi->gfu_boost < 400 )
3716 cpi->active_best_quality = gf_high_motion_minq[Q];
3717 else
3718 cpi->active_best_quality = gf_mid_motion_minq[Q];
3719
3720 /* Constrained quality use slightly lower active best. */
3721 if ( cpi->oxcf.end_usage == USAGE_CONSTRAINED_QUALITY )
3722 {
3723 cpi->active_best_quality =
3724 cpi->active_best_quality * 15/16;
3725 }
3726 }
3727 /* One pass more conservative */
3728 else
3729 cpi->active_best_quality = gf_high_motion_minq[Q];
3730 }
3731 else
3732 {
3733 cpi->active_best_quality = inter_minq[Q];
3734
3735 /* For the constant/constrained quality mode we dont want
3736 * q to fall below the cq level.
3737 */
3738 if ((cpi->oxcf.end_usage == USAGE_CONSTRAINED_QUALITY) &&
3739 (cpi->active_best_quality < cpi->cq_target_quality) )
3740 {
3741 /* If we are strongly undershooting the target rate in the last
3742 * frames then use the user passed in cq value not the auto
3743 * cq value.
3744 */
3745 if ( cpi->rolling_actual_bits < cpi->min_frame_bandwidth )
3746 cpi->active_best_quality = cpi->oxcf.cq_level;
3747 else
3748 cpi->active_best_quality = cpi->cq_target_quality;
3749 }
3750 }
3751
3752 /* If CBR and the buffer is as full then it is reasonable to allow
3753 * higher quality on the frames to prevent bits just going to waste.
3754 */
3755 if (cpi->oxcf.end_usage == USAGE_STREAM_FROM_SERVER)
3756 {
3757 /* Note that the use of >= here elliminates the risk of a devide
3758 * by 0 error in the else if clause
3759 */
3760 if (cpi->buffer_level >= cpi->oxcf.maximum_buffer_size)
3761 cpi->active_best_quality = cpi->best_quality;
3762
3763 else if (cpi->buffer_level > cpi->oxcf.optimal_buffer_level)
3764 {
3765 int Fraction = (int)
3766 (((cpi->buffer_level - cpi->oxcf.optimal_buffer_level) * 128)
3767 / (cpi->oxcf.maximum_buffer_size -
3768 cpi->oxcf.optimal_buffer_level));
3769 int min_qadjustment = ((cpi->active_best_quality -
3770 cpi->best_quality) * Fraction) / 128;
3771
3772 cpi->active_best_quality -= min_qadjustment;
3773 }
3774 }
3775 }
3776 /* Make sure constrained quality mode limits are adhered to for the first
3777 * few frames of one pass encodes
3778 */
3779 else if (cpi->oxcf.end_usage == USAGE_CONSTRAINED_QUALITY)
3780 {
3781 if ( (cm->frame_type == KEY_FRAME) ||
3782 cm->refresh_golden_frame || cpi->common.refresh_alt_ref_frame )
3783 {
3784 cpi->active_best_quality = cpi->best_quality;
3785 }
3786 else if (cpi->active_best_quality < cpi->cq_target_quality)
3787 {
3788 cpi->active_best_quality = cpi->cq_target_quality;
3789 }
3790 }
3791
3792 /* Clip the active best and worst quality values to limits */
3793 if (cpi->active_worst_quality > cpi->worst_quality)
3794 cpi->active_worst_quality = cpi->worst_quality;
3795
3796 if (cpi->active_best_quality < cpi->best_quality)
3797 cpi->active_best_quality = cpi->best_quality;
3798
3799 if ( cpi->active_worst_quality < cpi->active_best_quality )
3800 cpi->active_worst_quality = cpi->active_best_quality;
3801
3802 /* Determine initial Q to try */
3803 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
3804
3805 #if !(CONFIG_REALTIME_ONLY)
3806
3807 /* Set highest allowed value for Zbin over quant */
3808 if (cm->frame_type == KEY_FRAME)
3809 zbin_oq_high = 0;
3810 else if ((cpi->oxcf.number_of_layers == 1) && ((cm->refresh_alt_ref_frame ||
3811 (cm->refresh_golden_frame && !cpi->source_alt_ref_active))))
3812 {
3813 zbin_oq_high = 16;
3814 }
3815 else
3816 zbin_oq_high = ZBIN_OQ_MAX;
3817 #endif
3818
3819 /* Setup background Q adjustment for error resilient mode.
3820 * For multi-layer encodes only enable this for the base layer.
3821 */
3822 if (cpi->cyclic_refresh_mode_enabled)
3823 {
3824 if (cpi->current_layer==0)
3825 cyclic_background_refresh(cpi, Q, 0);
3826 else
3827 disable_segmentation(cpi);
3828 }
3829
3830 vp8_compute_frame_size_bounds(cpi, &frame_under_shoot_limit, &frame_over_shoot_limit);
3831
3832 #if !(CONFIG_REALTIME_ONLY)
3833 /* Limit Q range for the adaptive loop. */
3834 bottom_index = cpi->active_best_quality;
3835 top_index = cpi->active_worst_quality;
3836 q_low = cpi->active_best_quality;
3837 q_high = cpi->active_worst_quality;
3838 #endif
3839
3840 vp8_save_coding_context(cpi);
3841
3842 loop_count = 0;
3843
3844 scale_and_extend_source(cpi->un_scaled_source, cpi);
3845
3846 #if !(CONFIG_REALTIME_ONLY) && CONFIG_POSTPROC && !(CONFIG_TEMPORAL_DENOISING)
3847
3848 if (cpi->oxcf.noise_sensitivity > 0)
3849 {
3850 unsigned char *src;
3851 int l = 0;
3852
3853 switch (cpi->oxcf.noise_sensitivity)
3854 {
3855 case 1:
3856 l = 20;
3857 break;
3858 case 2:
3859 l = 40;
3860 break;
3861 case 3:
3862 l = 60;
3863 break;
3864 case 4:
3865 l = 80;
3866 break;
3867 case 5:
3868 l = 100;
3869 break;
3870 case 6:
3871 l = 150;
3872 break;
3873 }
3874
3875
3876 if (cm->frame_type == KEY_FRAME)
3877 {
3878 vp8_de_noise(cm, cpi->Source, cpi->Source, l , 1, 0);
3879 }
3880 else
3881 {
3882 vp8_de_noise(cm, cpi->Source, cpi->Source, l , 1, 0);
3883
3884 src = cpi->Source->y_buffer;
3885
3886 if (cpi->Source->y_stride < 0)
3887 {
3888 src += cpi->Source->y_stride * (cpi->Source->y_height - 1);
3889 }
3890 }
3891 }
3892
3893 #endif
3894
3895 #ifdef OUTPUT_YUV_SRC
3896 vp8_write_yuv_frame(cpi->Source);
3897 #endif
3898
3899 do
3900 {
3901 vp8_clear_system_state();
3902
3903 vp8_set_quantizer(cpi, Q);
3904
3905 /* setup skip prob for costing in mode/mv decision */
3906 if (cpi->common.mb_no_coeff_skip)
3907 {
3908 cpi->prob_skip_false = cpi->base_skip_false_prob[Q];
3909
3910 if (cm->frame_type != KEY_FRAME)
3911 {
3912 if (cpi->common.refresh_alt_ref_frame)
3913 {
3914 if (cpi->last_skip_false_probs[2] != 0)
3915 cpi->prob_skip_false = cpi->last_skip_false_probs[2];
3916
3917 /*
3918 if(cpi->last_skip_false_probs[2]!=0 && abs(Q- cpi->last_skip_probs_q[2])<=16 )
3919 cpi->prob_skip_false = cpi->last_skip_false_probs[2];
3920 else if (cpi->last_skip_false_probs[2]!=0)
3921 cpi->prob_skip_false = (cpi->last_skip_false_probs[2] + cpi->prob_skip_false ) / 2;
3922 */
3923 }
3924 else if (cpi->common.refresh_golden_frame)
3925 {
3926 if (cpi->last_skip_false_probs[1] != 0)
3927 cpi->prob_skip_false = cpi->last_skip_false_probs[1];
3928
3929 /*
3930 if(cpi->last_skip_false_probs[1]!=0 && abs(Q- cpi->last_skip_probs_q[1])<=16 )
3931 cpi->prob_skip_false = cpi->last_skip_false_probs[1];
3932 else if (cpi->last_skip_false_probs[1]!=0)
3933 cpi->prob_skip_false = (cpi->last_skip_false_probs[1] + cpi->prob_skip_false ) / 2;
3934 */
3935 }
3936 else
3937 {
3938 if (cpi->last_skip_false_probs[0] != 0)
3939 cpi->prob_skip_false = cpi->last_skip_false_probs[0];
3940
3941 /*
3942 if(cpi->last_skip_false_probs[0]!=0 && abs(Q- cpi->last_skip_probs_q[0])<=16 )
3943 cpi->prob_skip_false = cpi->last_skip_false_probs[0];
3944 else if(cpi->last_skip_false_probs[0]!=0)
3945 cpi->prob_skip_false = (cpi->last_skip_false_probs[0] + cpi->prob_skip_false ) / 2;
3946 */
3947 }
3948
3949 /* as this is for cost estimate, let's make sure it does not
3950 * go extreme eitehr way
3951 */
3952 if (cpi->prob_skip_false < 5)
3953 cpi->prob_skip_false = 5;
3954
3955 if (cpi->prob_skip_false > 250)
3956 cpi->prob_skip_false = 250;
3957
3958 if (cpi->oxcf.number_of_layers == 1 && cpi->is_src_frame_alt_ref)
3959 cpi->prob_skip_false = 1;
3960 }
3961
3962 #if 0
3963
3964 if (cpi->pass != 1)
3965 {
3966 FILE *f = fopen("skip.stt", "a");
3967 fprintf(f, "%d, %d, %4d ", cpi->common.refresh_golden_frame, cpi->common.refresh_alt_ref_frame, cpi->prob_skip_false);
3968 fclose(f);
3969 }
3970
3971 #endif
3972
3973 }
3974
3975 if (cm->frame_type == KEY_FRAME)
3976 {
3977 if(resize_key_frame(cpi))
3978 {
3979 /* If the frame size has changed, need to reset Q, quantizer,
3980 * and background refresh.
3981 */
3982 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
3983 if (cpi->cyclic_refresh_mode_enabled)
3984 {
3985 if (cpi->current_layer==0)
3986 cyclic_background_refresh(cpi, Q, 0);
3987 else
3988 disable_segmentation(cpi);
3989 }
3990 vp8_set_quantizer(cpi, Q);
3991 }
3992
3993 vp8_setup_key_frame(cpi);
3994 }
3995
3996
3997
3998 #if CONFIG_REALTIME_ONLY & CONFIG_ONTHEFLY_BITPACKING
3999 {
4000 if(cpi->oxcf.error_resilient_mode)
4001 cm->refresh_entropy_probs = 0;
4002
4003 if (cpi->oxcf.error_resilient_mode & VPX_ERROR_RESILIENT_PARTITIONS)
4004 {
4005 if (cm->frame_type == KEY_FRAME)
4006 cm->refresh_entropy_probs = 1;
4007 }
4008
4009 if (cm->refresh_entropy_probs == 0)
4010 {
4011 /* save a copy for later refresh */
4012 vpx_memcpy(&cm->lfc, &cm->fc, sizeof(cm->fc));
4013 }
4014
4015 vp8_update_coef_context(cpi);
4016
4017 vp8_update_coef_probs(cpi);
4018
4019 /* transform / motion compensation build reconstruction frame
4020 * +pack coef partitions
4021 */
4022 vp8_encode_frame(cpi);
4023
4024 /* cpi->projected_frame_size is not needed for RT mode */
4025 }
4026 #else
4027 /* transform / motion compensation build reconstruction frame */
4028 vp8_encode_frame(cpi);
4029
4030 cpi->projected_frame_size -= vp8_estimate_entropy_savings(cpi);
4031 cpi->projected_frame_size = (cpi->projected_frame_size > 0) ? cpi->projected_frame_size : 0;
4032 #endif
4033 vp8_clear_system_state();
4034
4035 /* Test to see if the stats generated for this frame indicate that
4036 * we should have coded a key frame (assuming that we didn't)!
4037 */
4038
4039 if (cpi->pass != 2 && cpi->oxcf.auto_key && cm->frame_type != KEY_FRAME
4040 && cpi->compressor_speed != 2)
4041 {
4042 #if !(CONFIG_REALTIME_ONLY)
4043 if (decide_key_frame(cpi))
4044 {
4045 /* Reset all our sizing numbers and recode */
4046 cm->frame_type = KEY_FRAME;
4047
4048 vp8_pick_frame_size(cpi);
4049
4050 /* Clear the Alt reference frame active flag when we have
4051 * a key frame
4052 */
4053 cpi->source_alt_ref_active = 0;
4054
4055 // Set the loop filter deltas and segmentation map update
4056 setup_features(cpi);
4057
4058 vp8_restore_coding_context(cpi);
4059
4060 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
4061
4062 vp8_compute_frame_size_bounds(cpi, &frame_under_shoot_limit, &frame_over_shoot_limit);
4063
4064 /* Limit Q range for the adaptive loop. */
4065 bottom_index = cpi->active_best_quality;
4066 top_index = cpi->active_worst_quality;
4067 q_low = cpi->active_best_quality;
4068 q_high = cpi->active_worst_quality;
4069
4070 loop_count++;
4071 Loop = 1;
4072
4073 continue;
4074 }
4075 #endif
4076 }
4077
4078 vp8_clear_system_state();
4079
4080 if (frame_over_shoot_limit == 0)
4081 frame_over_shoot_limit = 1;
4082
4083 /* Are we are overshooting and up against the limit of active max Q. */
4084 if (((cpi->pass != 2) || (cpi->oxcf.end_usage == USAGE_STREAM_FROM_SERVER)) &&
4085 (Q == cpi->active_worst_quality) &&
4086 (cpi->active_worst_quality < cpi->worst_quality) &&
4087 (cpi->projected_frame_size > frame_over_shoot_limit))
4088 {
4089 int over_size_percent = ((cpi->projected_frame_size - frame_over_shoot_limit) * 100) / frame_over_shoot_limit;
4090
4091 /* If so is there any scope for relaxing it */
4092 while ((cpi->active_worst_quality < cpi->worst_quality) && (over_size_percent > 0))
4093 {
4094 cpi->active_worst_quality++;
4095 /* Assume 1 qstep = about 4% on frame size. */
4096 over_size_percent = (int)(over_size_percent * 0.96);
4097 }
4098 #if !(CONFIG_REALTIME_ONLY)
4099 top_index = cpi->active_worst_quality;
4100 #endif
4101 /* If we have updated the active max Q do not call
4102 * vp8_update_rate_correction_factors() this loop.
4103 */
4104 active_worst_qchanged = 1;
4105 }
4106 else
4107 active_worst_qchanged = 0;
4108
4109 #if !(CONFIG_REALTIME_ONLY)
4110 /* Special case handling for forced key frames */
4111 if ( (cm->frame_type == KEY_FRAME) && cpi->this_key_frame_forced )
4112 {
4113 int last_q = Q;
4114 int kf_err = vp8_calc_ss_err(cpi->Source,
4115 &cm->yv12_fb[cm->new_fb_idx]);
4116
4117 /* The key frame is not good enough */
4118 if ( kf_err > ((cpi->ambient_err * 7) >> 3) )
4119 {
4120 /* Lower q_high */
4121 q_high = (Q > q_low) ? (Q - 1) : q_low;
4122
4123 /* Adjust Q */
4124 Q = (q_high + q_low) >> 1;
4125 }
4126 /* The key frame is much better than the previous frame */
4127 else if ( kf_err < (cpi->ambient_err >> 1) )
4128 {
4129 /* Raise q_low */
4130 q_low = (Q < q_high) ? (Q + 1) : q_high;
4131
4132 /* Adjust Q */
4133 Q = (q_high + q_low + 1) >> 1;
4134 }
4135
4136 /* Clamp Q to upper and lower limits: */
4137 if (Q > q_high)
4138 Q = q_high;
4139 else if (Q < q_low)
4140 Q = q_low;
4141
4142 Loop = Q != last_q;
4143 }
4144
4145 /* Is the projected frame size out of range and are we allowed
4146 * to attempt to recode.
4147 */
4148 else if ( recode_loop_test( cpi,
4149 frame_over_shoot_limit, frame_under_shoot_limit,
4150 Q, top_index, bottom_index ) )
4151 {
4152 int last_q = Q;
4153 int Retries = 0;
4154
4155 /* Frame size out of permitted range. Update correction factor
4156 * & compute new Q to try...
4157 */
4158
4159 /* Frame is too large */
4160 if (cpi->projected_frame_size > cpi->this_frame_target)
4161 {
4162 /* Raise Qlow as to at least the current value */
4163 q_low = (Q < q_high) ? (Q + 1) : q_high;
4164
4165 /* If we are using over quant do the same for zbin_oq_low */
4166 if (cpi->mb.zbin_over_quant > 0)
4167 zbin_oq_low = (cpi->mb.zbin_over_quant < zbin_oq_high) ?
4168 (cpi->mb.zbin_over_quant + 1) : zbin_oq_high;
4169
4170 if (undershoot_seen)
4171 {
4172 /* Update rate_correction_factor unless
4173 * cpi->active_worst_quality has changed.
4174 */
4175 if (!active_worst_qchanged)
4176 vp8_update_rate_correction_factors(cpi, 1);
4177
4178 Q = (q_high + q_low + 1) / 2;
4179
4180 /* Adjust cpi->zbin_over_quant (only allowed when Q
4181 * is max)
4182 */
4183 if (Q < MAXQ)
4184 cpi->mb.zbin_over_quant = 0;
4185 else
4186 {
4187 zbin_oq_low = (cpi->mb.zbin_over_quant < zbin_oq_high) ?
4188 (cpi->mb.zbin_over_quant + 1) : zbin_oq_high;
4189 cpi->mb.zbin_over_quant =
4190 (zbin_oq_high + zbin_oq_low) / 2;
4191 }
4192 }
4193 else
4194 {
4195 /* Update rate_correction_factor unless
4196 * cpi->active_worst_quality has changed.
4197 */
4198 if (!active_worst_qchanged)
4199 vp8_update_rate_correction_factors(cpi, 0);
4200
4201 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
4202
4203 while (((Q < q_low) ||
4204 (cpi->mb.zbin_over_quant < zbin_oq_low)) &&
4205 (Retries < 10))
4206 {
4207 vp8_update_rate_correction_factors(cpi, 0);
4208 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
4209 Retries ++;
4210 }
4211 }
4212
4213 overshoot_seen = 1;
4214 }
4215 /* Frame is too small */
4216 else
4217 {
4218 if (cpi->mb.zbin_over_quant == 0)
4219 /* Lower q_high if not using over quant */
4220 q_high = (Q > q_low) ? (Q - 1) : q_low;
4221 else
4222 /* else lower zbin_oq_high */
4223 zbin_oq_high = (cpi->mb.zbin_over_quant > zbin_oq_low) ?
4224 (cpi->mb.zbin_over_quant - 1) : zbin_oq_low;
4225
4226 if (overshoot_seen)
4227 {
4228 /* Update rate_correction_factor unless
4229 * cpi->active_worst_quality has changed.
4230 */
4231 if (!active_worst_qchanged)
4232 vp8_update_rate_correction_factors(cpi, 1);
4233
4234 Q = (q_high + q_low) / 2;
4235
4236 /* Adjust cpi->zbin_over_quant (only allowed when Q
4237 * is max)
4238 */
4239 if (Q < MAXQ)
4240 cpi->mb.zbin_over_quant = 0;
4241 else
4242 cpi->mb.zbin_over_quant =
4243 (zbin_oq_high + zbin_oq_low) / 2;
4244 }
4245 else
4246 {
4247 /* Update rate_correction_factor unless
4248 * cpi->active_worst_quality has changed.
4249 */
4250 if (!active_worst_qchanged)
4251 vp8_update_rate_correction_factors(cpi, 0);
4252
4253 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
4254
4255 /* Special case reset for qlow for constrained quality.
4256 * This should only trigger where there is very substantial
4257 * undershoot on a frame and the auto cq level is above
4258 * the user passsed in value.
4259 */
4260 if ( (cpi->oxcf.end_usage == USAGE_CONSTRAINED_QUALITY) &&
4261 (Q < q_low) )
4262 {
4263 q_low = Q;
4264 }
4265
4266 while (((Q > q_high) ||
4267 (cpi->mb.zbin_over_quant > zbin_oq_high)) &&
4268 (Retries < 10))
4269 {
4270 vp8_update_rate_correction_factors(cpi, 0);
4271 Q = vp8_regulate_q(cpi, cpi->this_frame_target);
4272 Retries ++;
4273 }
4274 }
4275
4276 undershoot_seen = 1;
4277 }
4278
4279 /* Clamp Q to upper and lower limits: */
4280 if (Q > q_high)
4281 Q = q_high;
4282 else if (Q < q_low)
4283 Q = q_low;
4284
4285 /* Clamp cpi->zbin_over_quant */
4286 cpi->mb.zbin_over_quant = (cpi->mb.zbin_over_quant < zbin_oq_low) ?
4287 zbin_oq_low : (cpi->mb.zbin_over_quant > zbin_oq_high) ?
4288 zbin_oq_high : cpi->mb.zbin_over_quant;
4289
4290 Loop = Q != last_q;
4291 }
4292 else
4293 #endif
4294 Loop = 0;
4295
4296 if (cpi->is_src_frame_alt_ref)
4297 Loop = 0;
4298
4299 if (Loop == 1)
4300 {
4301 vp8_restore_coding_context(cpi);
4302 loop_count++;
4303 #if CONFIG_INTERNAL_STATS
4304 cpi->tot_recode_hits++;
4305 #endif
4306 }
4307 }
4308 while (Loop == 1);
4309
4310 #if 0
4311 /* Experimental code for lagged and one pass
4312 * Update stats used for one pass GF selection
4313 */
4314 {
4315 cpi->one_pass_frame_stats[cpi->one_pass_frame_index].frame_coded_error = (double)cpi->prediction_error;
4316 cpi->one_pass_frame_stats[cpi->one_pass_frame_index].frame_intra_error = (double)cpi->intra_error;
4317 cpi->one_pass_frame_stats[cpi->one_pass_frame_index].frame_pcnt_inter = (double)(100 - cpi->this_frame_percent_intra) / 100.0;
4318 }
4319 #endif
4320
4321 /* Special case code to reduce pulsing when key frames are forced at a
4322 * fixed interval. Note the reconstruction error if it is the frame before
4323 * the force key frame
4324 */
4325 if ( cpi->next_key_frame_forced && (cpi->twopass.frames_to_key == 0) )
4326 {
4327 cpi->ambient_err = vp8_calc_ss_err(cpi->Source,
4328 &cm->yv12_fb[cm->new_fb_idx]);
4329 }
4330
4331 /* This frame's MVs are saved and will be used in next frame's MV predictor.
4332 * Last frame has one more line(add to bottom) and one more column(add to
4333 * right) than cm->mip. The edge elements are initialized to 0.
4334 */
4335 #if CONFIG_MULTI_RES_ENCODING
4336 if(!cpi->oxcf.mr_encoder_id && cm->show_frame)
4337 #else
4338 if(cm->show_frame) /* do not save for altref frame */
4339 #endif
4340 {
4341 int mb_row;
4342 int mb_col;
4343 /* Point to beginning of allocated MODE_INFO arrays. */
4344 MODE_INFO *tmp = cm->mip;
4345
4346 if(cm->frame_type != KEY_FRAME)
4347 {
4348 for (mb_row = 0; mb_row < cm->mb_rows+1; mb_row ++)
4349 {
4350 for (mb_col = 0; mb_col < cm->mb_cols+1; mb_col ++)
4351 {
4352 if(tmp->mbmi.ref_frame != INTRA_FRAME)
4353 cpi->lfmv[mb_col + mb_row*(cm->mode_info_stride+1)].as_int = tmp->mbmi.mv.as_int;
4354
4355 cpi->lf_ref_frame_sign_bias[mb_col + mb_row*(cm->mode_info_stride+1)] = cm->ref_frame_sign_bias[tmp->mbmi.ref_frame];
4356 cpi->lf_ref_frame[mb_col + mb_row*(cm->mode_info_stride+1)] = tmp->mbmi.ref_frame;
4357 tmp++;
4358 }
4359 }
4360 }
4361 }
4362
4363 /* Count last ref frame 0,0 usage on current encoded frame. */
4364 {
4365 int mb_row;
4366 int mb_col;
4367 /* Point to beginning of MODE_INFO arrays. */
4368 MODE_INFO *tmp = cm->mi;
4369
4370 cpi->zeromv_count = 0;
4371
4372 if(cm->frame_type != KEY_FRAME)
4373 {
4374 for (mb_row = 0; mb_row < cm->mb_rows; mb_row ++)
4375 {
4376 for (mb_col = 0; mb_col < cm->mb_cols; mb_col ++)
4377 {
4378 if(tmp->mbmi.mode == ZEROMV)
4379 cpi->zeromv_count++;
4380 tmp++;
4381 }
4382 tmp++;
4383 }
4384 }
4385 }
4386
4387 #if CONFIG_MULTI_RES_ENCODING
4388 vp8_cal_dissimilarity(cpi);
4389 #endif
4390
4391 /* Update the GF useage maps.
4392 * This is done after completing the compression of a frame when all
4393 * modes etc. are finalized but before loop filter
4394 */
4395 if (cpi->oxcf.number_of_layers == 1)
4396 vp8_update_gf_useage_maps(cpi, cm, &cpi->mb);
4397
4398 if (cm->frame_type == KEY_FRAME)
4399 cm->refresh_last_frame = 1;
4400
4401 #if 0
4402 {
4403 FILE *f = fopen("gfactive.stt", "a");
4404 fprintf(f, "%8d %8d %8d %8d %8d\n", cm->current_video_frame, (100 * cpi->gf_active_count) / (cpi->common.mb_rows * cpi->common.mb_cols), cpi->this_iiratio, cpi->next_iiratio, cm->refresh_golden_frame);
4405 fclose(f);
4406 }
4407 #endif
4408
4409 /* For inter frames the current default behavior is that when
4410 * cm->refresh_golden_frame is set we copy the old GF over to the ARF buffer
4411 * This is purely an encoder decision at present.
4412 */
4413 if (!cpi->oxcf.error_resilient_mode && cm->refresh_golden_frame)
4414 cm->copy_buffer_to_arf = 2;
4415 else
4416 cm->copy_buffer_to_arf = 0;
4417
4418 cm->frame_to_show = &cm->yv12_fb[cm->new_fb_idx];
4419
4420 #if CONFIG_MULTITHREAD
4421 if (cpi->b_multi_threaded)
4422 {
4423 /* start loopfilter in separate thread */
4424 sem_post(&cpi->h_event_start_lpf);
4425 cpi->b_lpf_running = 1;
4426 }
4427 else
4428 #endif
4429 {
4430 vp8_loopfilter_frame(cpi, cm);
4431 }
4432
4433 update_reference_frames(cpi);
4434
4435 #if !(CONFIG_REALTIME_ONLY & CONFIG_ONTHEFLY_BITPACKING)
4436 if (cpi->oxcf.error_resilient_mode)
4437 {
4438 cm->refresh_entropy_probs = 0;
4439 }
4440 #endif
4441
4442 #if CONFIG_MULTITHREAD
4443 /* wait that filter_level is picked so that we can continue with stream packing */
4444 if (cpi->b_multi_threaded)
4445 sem_wait(&cpi->h_event_end_lpf);
4446 #endif
4447
4448 /* build the bitstream */
4449 vp8_pack_bitstream(cpi, dest, dest_end, size);
4450
4451 #if CONFIG_MULTITHREAD
4452 /* if PSNR packets are generated we have to wait for the lpf */
4453 if (cpi->b_lpf_running && cpi->b_calculate_psnr)
4454 {
4455 sem_wait(&cpi->h_event_end_lpf);
4456 cpi->b_lpf_running = 0;
4457 }
4458 #endif
4459
4460 /* Move storing frame_type out of the above loop since it is also
4461 * needed in motion search besides loopfilter */
4462 cm->last_frame_type = cm->frame_type;
4463
4464 /* Update rate control heuristics */
4465 cpi->total_byte_count += (*size);
4466 cpi->projected_frame_size = (*size) << 3;
4467
4468 if (cpi->oxcf.number_of_layers > 1)
4469 {
4470 unsigned int i;
4471 for (i=cpi->current_layer+1; i<cpi->oxcf.number_of_layers; i++)
4472 cpi->layer_context[i].total_byte_count += (*size);
4473 }
4474
4475 if (!active_worst_qchanged)
4476 vp8_update_rate_correction_factors(cpi, 2);
4477
4478 cpi->last_q[cm->frame_type] = cm->base_qindex;
4479
4480 if (cm->frame_type == KEY_FRAME)
4481 {
4482 vp8_adjust_key_frame_context(cpi);
4483 }
4484
4485 /* Keep a record of ambient average Q. */
4486 if (cm->frame_type != KEY_FRAME)
4487 cpi->avg_frame_qindex = (2 + 3 * cpi->avg_frame_qindex + cm->base_qindex) >> 2;
4488
4489 /* Keep a record from which we can calculate the average Q excluding
4490 * GF updates and key frames
4491 */
4492 if ((cm->frame_type != KEY_FRAME) && ((cpi->oxcf.number_of_layers > 1) ||
4493 (!cm->refresh_golden_frame && !cm->refresh_alt_ref_frame)))
4494 {
4495 cpi->ni_frames++;
4496
4497 /* Calculate the average Q for normal inter frames (not key or GFU
4498 * frames).
4499 */
4500 if ( cpi->pass == 2 )
4501 {
4502 cpi->ni_tot_qi += Q;
4503 cpi->ni_av_qi = (cpi->ni_tot_qi / cpi->ni_frames);
4504 }
4505 else
4506 {
4507 /* Damp value for first few frames */
4508 if (cpi->ni_frames > 150 )
4509 {
4510 cpi->ni_tot_qi += Q;
4511 cpi->ni_av_qi = (cpi->ni_tot_qi / cpi->ni_frames);
4512 }
4513 /* For one pass, early in the clip ... average the current frame Q
4514 * value with the worstq entered by the user as a dampening measure
4515 */
4516 else
4517 {
4518 cpi->ni_tot_qi += Q;
4519 cpi->ni_av_qi = ((cpi->ni_tot_qi / cpi->ni_frames) + cpi->worst_quality + 1) / 2;
4520 }
4521
4522 /* If the average Q is higher than what was used in the last
4523 * frame (after going through the recode loop to keep the frame
4524 * size within range) then use the last frame value - 1. The -1
4525 * is designed to stop Q and hence the data rate, from
4526 * progressively falling away during difficult sections, but at
4527 * the same time reduce the number of itterations around the
4528 * recode loop.
4529 */
4530 if (Q > cpi->ni_av_qi)
4531 cpi->ni_av_qi = Q - 1;
4532 }
4533 }
4534
4535 /* Update the buffer level variable. */
4536 /* Non-viewable frames are a special case and are treated as pure overhead. */
4537 if ( !cm->show_frame )
4538 cpi->bits_off_target -= cpi->projected_frame_size;
4539 else
4540 cpi->bits_off_target += cpi->av_per_frame_bandwidth - cpi->projected_frame_size;
4541
4542 /* Clip the buffer level to the maximum specified buffer size */
4543 if (cpi->bits_off_target > cpi->oxcf.maximum_buffer_size)
4544 cpi->bits_off_target = cpi->oxcf.maximum_buffer_size;
4545
4546 /* Rolling monitors of whether we are over or underspending used to
4547 * help regulate min and Max Q in two pass.
4548 */
4549 cpi->rolling_target_bits = ((cpi->rolling_target_bits * 3) + cpi->this_frame_target + 2) / 4;
4550 cpi->rolling_actual_bits = ((cpi->rolling_actual_bits * 3) + cpi->projected_frame_size + 2) / 4;
4551 cpi->long_rolling_target_bits = ((cpi->long_rolling_target_bits * 31) + cpi->this_frame_target + 16) / 32;
4552 cpi->long_rolling_actual_bits = ((cpi->long_rolling_actual_bits * 31) + cpi->projected_frame_size + 16) / 32;
4553
4554 /* Actual bits spent */
4555 cpi->total_actual_bits += cpi->projected_frame_size;
4556
4557 /* Debug stats */
4558 cpi->total_target_vs_actual += (cpi->this_frame_target - cpi->projected_frame_size);
4559
4560 cpi->buffer_level = cpi->bits_off_target;
4561
4562 /* Propagate values to higher temporal layers */
4563 if (cpi->oxcf.number_of_layers > 1)
4564 {
4565 unsigned int i;
4566
4567 for (i=cpi->current_layer+1; i<cpi->oxcf.number_of_layers; i++)
4568 {
4569 LAYER_CONTEXT *lc = &cpi->layer_context[i];
4570 int bits_off_for_this_layer =
4571 (int)(lc->target_bandwidth / lc->framerate -
4572 cpi->projected_frame_size);
4573
4574 lc->bits_off_target += bits_off_for_this_layer;
4575
4576 /* Clip buffer level to maximum buffer size for the layer */
4577 if (lc->bits_off_target > lc->maximum_buffer_size)
4578 lc->bits_off_target = lc->maximum_buffer_size;
4579
4580 lc->total_actual_bits += cpi->projected_frame_size;
4581 lc->total_target_vs_actual += bits_off_for_this_layer;
4582 lc->buffer_level = lc->bits_off_target;
4583 }
4584 }
4585
4586 /* Update bits left to the kf and gf groups to account for overshoot
4587 * or undershoot on these frames
4588 */
4589 if (cm->frame_type == KEY_FRAME)
4590 {
4591 cpi->twopass.kf_group_bits += cpi->this_frame_target - cpi->projected_frame_size;
4592
4593 if (cpi->twopass.kf_group_bits < 0)
4594 cpi->twopass.kf_group_bits = 0 ;
4595 }
4596 else if (cm->refresh_golden_frame || cm->refresh_alt_ref_frame)
4597 {
4598 cpi->twopass.gf_group_bits += cpi->this_frame_target - cpi->projected_frame_size;
4599
4600 if (cpi->twopass.gf_group_bits < 0)
4601 cpi->twopass.gf_group_bits = 0 ;
4602 }
4603
4604 if (cm->frame_type != KEY_FRAME)
4605 {
4606 if (cpi->common.refresh_alt_ref_frame)
4607 {
4608 cpi->last_skip_false_probs[2] = cpi->prob_skip_false;
4609 cpi->last_skip_probs_q[2] = cm->base_qindex;
4610 }
4611 else if (cpi->common.refresh_golden_frame)
4612 {
4613 cpi->last_skip_false_probs[1] = cpi->prob_skip_false;
4614 cpi->last_skip_probs_q[1] = cm->base_qindex;
4615 }
4616 else
4617 {
4618 cpi->last_skip_false_probs[0] = cpi->prob_skip_false;
4619 cpi->last_skip_probs_q[0] = cm->base_qindex;
4620
4621 /* update the baseline */
4622 cpi->base_skip_false_prob[cm->base_qindex] = cpi->prob_skip_false;
4623
4624 }
4625 }
4626
4627 #if 0 && CONFIG_INTERNAL_STATS
4628 {
4629 FILE *f = fopen("tmp.stt", "a");
4630
4631 vp8_clear_system_state();
4632
4633 if (cpi->twopass.total_left_stats.coded_error != 0.0)
4634 fprintf(f, "%10d %10d %10d %10d %10d %10"PRId64" %10"PRId64
4635 "%10"PRId64" %10d %6d %6d %6d %6d %5d %5d %5d %8d "
4636 "%8.2lf %"PRId64" %10.3lf %10"PRId64" %8d\n",
4637 cpi->common.current_video_frame, cpi->this_frame_target,
4638 cpi->projected_frame_size,
4639 (cpi->projected_frame_size - cpi->this_frame_target),
4640 cpi->total_target_vs_actual,
4641 cpi->buffer_level,
4642 (cpi->oxcf.starting_buffer_level-cpi->bits_off_target),
4643 cpi->total_actual_bits, cm->base_qindex,
4644 cpi->active_best_quality, cpi->active_worst_quality,
4645 cpi->ni_av_qi, cpi->cq_target_quality,
4646 cm->refresh_golden_frame, cm->refresh_alt_ref_frame,
4647 cm->frame_type, cpi->gfu_boost,
4648 cpi->twopass.est_max_qcorrection_factor,
4649 cpi->twopass.bits_left,
4650 cpi->twopass.total_left_stats.coded_error,
4651 (double)cpi->twopass.bits_left /
4652 cpi->twopass.total_left_stats.coded_error,
4653 cpi->tot_recode_hits);
4654 else
4655 fprintf(f, "%10d %10d %10d %10d %10d %10"PRId64" %10"PRId64
4656 "%10"PRId64" %10d %6d %6d %6d %6d %5d %5d %5d %8d "
4657 "%8.2lf %"PRId64" %10.3lf %8d\n",
4658 cpi->common.current_video_frame, cpi->this_frame_target,
4659 cpi->projected_frame_size,
4660 (cpi->projected_frame_size - cpi->this_frame_target),
4661 cpi->total_target_vs_actual,
4662 cpi->buffer_level,
4663 (cpi->oxcf.starting_buffer_level-cpi->bits_off_target),
4664 cpi->total_actual_bits, cm->base_qindex,
4665 cpi->active_best_quality, cpi->active_worst_quality,
4666 cpi->ni_av_qi, cpi->cq_target_quality,
4667 cm->refresh_golden_frame, cm->refresh_alt_ref_frame,
4668 cm->frame_type, cpi->gfu_boost,
4669 cpi->twopass.est_max_qcorrection_factor,
4670 cpi->twopass.bits_left,
4671 cpi->twopass.total_left_stats.coded_error,
4672 cpi->tot_recode_hits);
4673
4674 fclose(f);
4675
4676 {
4677 FILE *fmodes = fopen("Modes.stt", "a");
4678
4679 fprintf(fmodes, "%6d:%1d:%1d:%1d ",
4680 cpi->common.current_video_frame,
4681 cm->frame_type, cm->refresh_golden_frame,
4682 cm->refresh_alt_ref_frame);
4683
4684 fprintf(fmodes, "\n");
4685
4686 fclose(fmodes);
4687 }
4688 }
4689
4690 #endif
4691
4692 if (cm->refresh_golden_frame == 1)
4693 cm->frame_flags = cm->frame_flags | FRAMEFLAGS_GOLDEN;
4694 else
4695 cm->frame_flags = cm->frame_flags&~FRAMEFLAGS_GOLDEN;
4696
4697 if (cm->refresh_alt_ref_frame == 1)
4698 cm->frame_flags = cm->frame_flags | FRAMEFLAGS_ALTREF;
4699 else
4700 cm->frame_flags = cm->frame_flags&~FRAMEFLAGS_ALTREF;
4701
4702
4703 if (cm->refresh_last_frame & cm->refresh_golden_frame)
4704 /* both refreshed */
4705 cpi->gold_is_last = 1;
4706 else if (cm->refresh_last_frame ^ cm->refresh_golden_frame)
4707 /* 1 refreshed but not the other */
4708 cpi->gold_is_last = 0;
4709
4710 if (cm->refresh_last_frame & cm->refresh_alt_ref_frame)
4711 /* both refreshed */
4712 cpi->alt_is_last = 1;
4713 else if (cm->refresh_last_frame ^ cm->refresh_alt_ref_frame)
4714 /* 1 refreshed but not the other */
4715 cpi->alt_is_last = 0;
4716
4717 if (cm->refresh_alt_ref_frame & cm->refresh_golden_frame)
4718 /* both refreshed */
4719 cpi->gold_is_alt = 1;
4720 else if (cm->refresh_alt_ref_frame ^ cm->refresh_golden_frame)
4721 /* 1 refreshed but not the other */
4722 cpi->gold_is_alt = 0;
4723
4724 cpi->ref_frame_flags = VP8_ALTR_FRAME | VP8_GOLD_FRAME | VP8_LAST_FRAME;
4725
4726 if (cpi->gold_is_last)
4727 cpi->ref_frame_flags &= ~VP8_GOLD_FRAME;
4728
4729 if (cpi->alt_is_last)
4730 cpi->ref_frame_flags &= ~VP8_ALTR_FRAME;
4731
4732 if (cpi->gold_is_alt)
4733 cpi->ref_frame_flags &= ~VP8_ALTR_FRAME;
4734
4735
4736 if (!cpi->oxcf.error_resilient_mode)
4737 {
4738 if (cpi->oxcf.play_alternate && cm->refresh_alt_ref_frame && (cm->frame_type != KEY_FRAME))
4739 /* Update the alternate reference frame stats as appropriate. */
4740 update_alt_ref_frame_stats(cpi);
4741 else
4742 /* Update the Golden frame stats as appropriate. */
4743 update_golden_frame_stats(cpi);
4744 }
4745
4746 if (cm->frame_type == KEY_FRAME)
4747 {
4748 /* Tell the caller that the frame was coded as a key frame */
4749 *frame_flags = cm->frame_flags | FRAMEFLAGS_KEY;
4750
4751 /* As this frame is a key frame the next defaults to an inter frame. */
4752 cm->frame_type = INTER_FRAME;
4753
4754 cpi->last_frame_percent_intra = 100;
4755 }
4756 else
4757 {
4758 *frame_flags = cm->frame_flags&~FRAMEFLAGS_KEY;
4759
4760 cpi->last_frame_percent_intra = cpi->this_frame_percent_intra;
4761 }
4762
4763 /* Clear the one shot update flags for segmentation map and mode/ref
4764 * loop filter deltas.
4765 */
4766 cpi->mb.e_mbd.update_mb_segmentation_map = 0;
4767 cpi->mb.e_mbd.update_mb_segmentation_data = 0;
4768 cpi->mb.e_mbd.mode_ref_lf_delta_update = 0;
4769
4770
4771 /* Dont increment frame counters if this was an altref buffer update
4772 * not a real frame
4773 */
4774 if (cm->show_frame)
4775 {
4776 cm->current_video_frame++;
4777 cpi->frames_since_key++;
4778 cpi->temporal_pattern_counter++;
4779 }
4780
4781 /* reset to normal state now that we are done. */
4782
4783
4784
4785 #if 0
4786 {
4787 char filename[512];
4788 FILE *recon_file;
4789 sprintf(filename, "enc%04d.yuv", (int) cm->current_video_frame);
4790 recon_file = fopen(filename, "wb");
4791 fwrite(cm->yv12_fb[cm->lst_fb_idx].buffer_alloc,
4792 cm->yv12_fb[cm->lst_fb_idx].frame_size, 1, recon_file);
4793 fclose(recon_file);
4794 }
4795 #endif
4796
4797 /* DEBUG */
4798 /* vp8_write_yuv_frame("encoder_recon.yuv", cm->frame_to_show); */
4799
4800
4801 }
4802 #if !(CONFIG_REALTIME_ONLY)
Pass2Encode(VP8_COMP * cpi,unsigned long * size,unsigned char * dest,unsigned char * dest_end,unsigned int * frame_flags)4803 static void Pass2Encode(VP8_COMP *cpi, unsigned long *size, unsigned char *dest, unsigned char * dest_end, unsigned int *frame_flags)
4804 {
4805
4806 if (!cpi->common.refresh_alt_ref_frame)
4807 vp8_second_pass(cpi);
4808
4809 encode_frame_to_data_rate(cpi, size, dest, dest_end, frame_flags);
4810 cpi->twopass.bits_left -= 8 * *size;
4811
4812 if (!cpi->common.refresh_alt_ref_frame)
4813 {
4814 double two_pass_min_rate = (double)(cpi->oxcf.target_bandwidth
4815 *cpi->oxcf.two_pass_vbrmin_section / 100);
4816 cpi->twopass.bits_left += (int64_t)(two_pass_min_rate / cpi->framerate);
4817 }
4818 }
4819 #endif
4820
4821 /* For ARM NEON, d8-d15 are callee-saved registers, and need to be saved. */
4822 #if HAVE_NEON
4823 extern void vp8_push_neon(int64_t *store);
4824 extern void vp8_pop_neon(int64_t *store);
4825 #endif
4826
4827
vp8_receive_raw_frame(VP8_COMP * cpi,unsigned int frame_flags,YV12_BUFFER_CONFIG * sd,int64_t time_stamp,int64_t end_time)4828 int vp8_receive_raw_frame(VP8_COMP *cpi, unsigned int frame_flags, YV12_BUFFER_CONFIG *sd, int64_t time_stamp, int64_t end_time)
4829 {
4830 #if HAVE_NEON
4831 int64_t store_reg[8];
4832 #if CONFIG_RUNTIME_CPU_DETECT
4833 VP8_COMMON *cm = &cpi->common;
4834 #endif
4835 #endif
4836 struct vpx_usec_timer timer;
4837 int res = 0;
4838
4839 #if HAVE_NEON
4840 #if CONFIG_RUNTIME_CPU_DETECT
4841 if (cm->cpu_caps & HAS_NEON)
4842 #endif
4843 {
4844 vp8_push_neon(store_reg);
4845 }
4846 #endif
4847
4848 vpx_usec_timer_start(&timer);
4849
4850 /* Reinit the lookahead buffer if the frame size changes */
4851 if (sd->y_width != cpi->oxcf.Width || sd->y_height != cpi->oxcf.Height)
4852 {
4853 assert(cpi->oxcf.lag_in_frames < 2);
4854 dealloc_raw_frame_buffers(cpi);
4855 alloc_raw_frame_buffers(cpi);
4856 }
4857
4858 if(vp8_lookahead_push(cpi->lookahead, sd, time_stamp, end_time,
4859 frame_flags, cpi->active_map_enabled ? cpi->active_map : NULL))
4860 res = -1;
4861 vpx_usec_timer_mark(&timer);
4862 cpi->time_receive_data += vpx_usec_timer_elapsed(&timer);
4863
4864 #if HAVE_NEON
4865 #if CONFIG_RUNTIME_CPU_DETECT
4866 if (cm->cpu_caps & HAS_NEON)
4867 #endif
4868 {
4869 vp8_pop_neon(store_reg);
4870 }
4871 #endif
4872
4873 return res;
4874 }
4875
4876
frame_is_reference(const VP8_COMP * cpi)4877 static int frame_is_reference(const VP8_COMP *cpi)
4878 {
4879 const VP8_COMMON *cm = &cpi->common;
4880 const MACROBLOCKD *xd = &cpi->mb.e_mbd;
4881
4882 return cm->frame_type == KEY_FRAME || cm->refresh_last_frame
4883 || cm->refresh_golden_frame || cm->refresh_alt_ref_frame
4884 || cm->copy_buffer_to_gf || cm->copy_buffer_to_arf
4885 || cm->refresh_entropy_probs
4886 || xd->mode_ref_lf_delta_update
4887 || xd->update_mb_segmentation_map || xd->update_mb_segmentation_data;
4888 }
4889
4890
vp8_get_compressed_data(VP8_COMP * cpi,unsigned int * frame_flags,unsigned long * size,unsigned char * dest,unsigned char * dest_end,int64_t * time_stamp,int64_t * time_end,int flush)4891 int vp8_get_compressed_data(VP8_COMP *cpi, unsigned int *frame_flags, unsigned long *size, unsigned char *dest, unsigned char *dest_end, int64_t *time_stamp, int64_t *time_end, int flush)
4892 {
4893 #if HAVE_NEON
4894 int64_t store_reg[8];
4895 #endif
4896 VP8_COMMON *cm;
4897 struct vpx_usec_timer tsctimer;
4898 struct vpx_usec_timer ticktimer;
4899 struct vpx_usec_timer cmptimer;
4900 YV12_BUFFER_CONFIG *force_src_buffer = NULL;
4901
4902 if (!cpi)
4903 return -1;
4904
4905 cm = &cpi->common;
4906
4907 if (setjmp(cpi->common.error.jmp))
4908 {
4909 cpi->common.error.setjmp = 0;
4910 return VPX_CODEC_CORRUPT_FRAME;
4911 }
4912
4913 cpi->common.error.setjmp = 1;
4914
4915 #if HAVE_NEON
4916 #if CONFIG_RUNTIME_CPU_DETECT
4917 if (cm->cpu_caps & HAS_NEON)
4918 #endif
4919 {
4920 vp8_push_neon(store_reg);
4921 }
4922 #endif
4923
4924 vpx_usec_timer_start(&cmptimer);
4925
4926 cpi->source = NULL;
4927
4928 #if !(CONFIG_REALTIME_ONLY)
4929 /* Should we code an alternate reference frame */
4930 if (cpi->oxcf.error_resilient_mode == 0 &&
4931 cpi->oxcf.play_alternate &&
4932 cpi->source_alt_ref_pending)
4933 {
4934 if ((cpi->source = vp8_lookahead_peek(cpi->lookahead,
4935 cpi->frames_till_gf_update_due,
4936 PEEK_FORWARD)))
4937 {
4938 cpi->alt_ref_source = cpi->source;
4939 if (cpi->oxcf.arnr_max_frames > 0)
4940 {
4941 vp8_temporal_filter_prepare_c(cpi,
4942 cpi->frames_till_gf_update_due);
4943 force_src_buffer = &cpi->alt_ref_buffer;
4944 }
4945 cpi->frames_till_alt_ref_frame = cpi->frames_till_gf_update_due;
4946 cm->refresh_alt_ref_frame = 1;
4947 cm->refresh_golden_frame = 0;
4948 cm->refresh_last_frame = 0;
4949 cm->show_frame = 0;
4950 /* Clear Pending alt Ref flag. */
4951 cpi->source_alt_ref_pending = 0;
4952 cpi->is_src_frame_alt_ref = 0;
4953 }
4954 }
4955 #endif
4956
4957 if (!cpi->source)
4958 {
4959 /* Read last frame source if we are encoding first pass. */
4960 if (cpi->pass == 1 && cm->current_video_frame > 0)
4961 {
4962 if((cpi->last_source = vp8_lookahead_peek(cpi->lookahead, 1,
4963 PEEK_BACKWARD)) == NULL)
4964 return -1;
4965 }
4966
4967
4968 if ((cpi->source = vp8_lookahead_pop(cpi->lookahead, flush)))
4969 {
4970 cm->show_frame = 1;
4971
4972 cpi->is_src_frame_alt_ref = cpi->alt_ref_source
4973 && (cpi->source == cpi->alt_ref_source);
4974
4975 if(cpi->is_src_frame_alt_ref)
4976 cpi->alt_ref_source = NULL;
4977 }
4978 }
4979
4980 if (cpi->source)
4981 {
4982 cpi->Source = force_src_buffer ? force_src_buffer : &cpi->source->img;
4983 cpi->un_scaled_source = cpi->Source;
4984 *time_stamp = cpi->source->ts_start;
4985 *time_end = cpi->source->ts_end;
4986 *frame_flags = cpi->source->flags;
4987
4988 if (cpi->pass == 1 && cm->current_video_frame > 0)
4989 {
4990 cpi->last_frame_unscaled_source = &cpi->last_source->img;
4991 }
4992 }
4993 else
4994 {
4995 *size = 0;
4996 #if !(CONFIG_REALTIME_ONLY)
4997
4998 if (flush && cpi->pass == 1 && !cpi->twopass.first_pass_done)
4999 {
5000 vp8_end_first_pass(cpi); /* get last stats packet */
5001 cpi->twopass.first_pass_done = 1;
5002 }
5003
5004 #endif
5005
5006 #if HAVE_NEON
5007 #if CONFIG_RUNTIME_CPU_DETECT
5008 if (cm->cpu_caps & HAS_NEON)
5009 #endif
5010 {
5011 vp8_pop_neon(store_reg);
5012 }
5013 #endif
5014 return -1;
5015 }
5016
5017 if (cpi->source->ts_start < cpi->first_time_stamp_ever)
5018 {
5019 cpi->first_time_stamp_ever = cpi->source->ts_start;
5020 cpi->last_end_time_stamp_seen = cpi->source->ts_start;
5021 }
5022
5023 /* adjust frame rates based on timestamps given */
5024 if (cm->show_frame)
5025 {
5026 int64_t this_duration;
5027 int step = 0;
5028
5029 if (cpi->source->ts_start == cpi->first_time_stamp_ever)
5030 {
5031 this_duration = cpi->source->ts_end - cpi->source->ts_start;
5032 step = 1;
5033 }
5034 else
5035 {
5036 int64_t last_duration;
5037
5038 this_duration = cpi->source->ts_end - cpi->last_end_time_stamp_seen;
5039 last_duration = cpi->last_end_time_stamp_seen
5040 - cpi->last_time_stamp_seen;
5041 /* do a step update if the duration changes by 10% */
5042 if (last_duration)
5043 step = (int)(((this_duration - last_duration) *
5044 10 / last_duration));
5045 }
5046
5047 if (this_duration)
5048 {
5049 if (step)
5050 cpi->ref_framerate = 10000000.0 / this_duration;
5051 else
5052 {
5053 double avg_duration, interval;
5054
5055 /* Average this frame's rate into the last second's average
5056 * frame rate. If we haven't seen 1 second yet, then average
5057 * over the whole interval seen.
5058 */
5059 interval = (double)(cpi->source->ts_end -
5060 cpi->first_time_stamp_ever);
5061 if(interval > 10000000.0)
5062 interval = 10000000;
5063
5064 avg_duration = 10000000.0 / cpi->ref_framerate;
5065 avg_duration *= (interval - avg_duration + this_duration);
5066 avg_duration /= interval;
5067
5068 cpi->ref_framerate = 10000000.0 / avg_duration;
5069 }
5070
5071 if (cpi->oxcf.number_of_layers > 1)
5072 {
5073 unsigned int i;
5074
5075 /* Update frame rates for each layer */
5076 assert(cpi->oxcf.number_of_layers <= VPX_TS_MAX_LAYERS);
5077 for (i=0; i<cpi->oxcf.number_of_layers; i++)
5078 {
5079 LAYER_CONTEXT *lc = &cpi->layer_context[i];
5080 lc->framerate = cpi->ref_framerate /
5081 cpi->oxcf.rate_decimator[i];
5082 }
5083 }
5084 else
5085 vp8_new_framerate(cpi, cpi->ref_framerate);
5086 }
5087
5088 cpi->last_time_stamp_seen = cpi->source->ts_start;
5089 cpi->last_end_time_stamp_seen = cpi->source->ts_end;
5090 }
5091
5092 if (cpi->oxcf.number_of_layers > 1)
5093 {
5094 int layer;
5095
5096 update_layer_contexts (cpi);
5097
5098 /* Restore layer specific context & set frame rate */
5099 layer = cpi->oxcf.layer_id[
5100 cpi->temporal_pattern_counter % cpi->oxcf.periodicity];
5101 restore_layer_context (cpi, layer);
5102 vp8_new_framerate(cpi, cpi->layer_context[layer].framerate);
5103 }
5104
5105 if (cpi->compressor_speed == 2)
5106 {
5107 vpx_usec_timer_start(&tsctimer);
5108 vpx_usec_timer_start(&ticktimer);
5109 }
5110
5111 cpi->lf_zeromv_pct = (cpi->zeromv_count * 100)/cm->MBs;
5112
5113 #if CONFIG_REALTIME_ONLY & CONFIG_ONTHEFLY_BITPACKING
5114 {
5115 int i;
5116 const int num_part = (1 << cm->multi_token_partition);
5117 /* the available bytes in dest */
5118 const unsigned long dest_size = dest_end - dest;
5119 const int tok_part_buff_size = (dest_size * 9) / (10 * num_part);
5120
5121 unsigned char *dp = dest;
5122
5123 cpi->partition_d[0] = dp;
5124 dp += dest_size/10; /* reserve 1/10 for control partition */
5125 cpi->partition_d_end[0] = dp;
5126
5127 for(i = 0; i < num_part; i++)
5128 {
5129 cpi->partition_d[i + 1] = dp;
5130 dp += tok_part_buff_size;
5131 cpi->partition_d_end[i + 1] = dp;
5132 }
5133 }
5134 #endif
5135
5136 /* start with a 0 size frame */
5137 *size = 0;
5138
5139 /* Clear down mmx registers */
5140 vp8_clear_system_state();
5141
5142 cm->frame_type = INTER_FRAME;
5143 cm->frame_flags = *frame_flags;
5144
5145 #if 0
5146
5147 if (cm->refresh_alt_ref_frame)
5148 {
5149 cm->refresh_golden_frame = 0;
5150 cm->refresh_last_frame = 0;
5151 }
5152 else
5153 {
5154 cm->refresh_golden_frame = 0;
5155 cm->refresh_last_frame = 1;
5156 }
5157
5158 #endif
5159 /* find a free buffer for the new frame */
5160 {
5161 int i = 0;
5162 for(; i < NUM_YV12_BUFFERS; i++)
5163 {
5164 if(!cm->yv12_fb[i].flags)
5165 {
5166 cm->new_fb_idx = i;
5167 break;
5168 }
5169 }
5170
5171 assert(i < NUM_YV12_BUFFERS );
5172 }
5173 #if !(CONFIG_REALTIME_ONLY)
5174
5175 if (cpi->pass == 1)
5176 {
5177 Pass1Encode(cpi, size, dest, frame_flags);
5178 }
5179 else if (cpi->pass == 2)
5180 {
5181 Pass2Encode(cpi, size, dest, dest_end, frame_flags);
5182 }
5183 else
5184 #endif
5185 encode_frame_to_data_rate(cpi, size, dest, dest_end, frame_flags);
5186
5187 if (cpi->compressor_speed == 2)
5188 {
5189 unsigned int duration, duration2;
5190 vpx_usec_timer_mark(&tsctimer);
5191 vpx_usec_timer_mark(&ticktimer);
5192
5193 duration = (int)(vpx_usec_timer_elapsed(&ticktimer));
5194 duration2 = (unsigned int)((double)duration / 2);
5195
5196 if (cm->frame_type != KEY_FRAME)
5197 {
5198 if (cpi->avg_encode_time == 0)
5199 cpi->avg_encode_time = duration;
5200 else
5201 cpi->avg_encode_time = (7 * cpi->avg_encode_time + duration) >> 3;
5202 }
5203
5204 if (duration2)
5205 {
5206 {
5207
5208 if (cpi->avg_pick_mode_time == 0)
5209 cpi->avg_pick_mode_time = duration2;
5210 else
5211 cpi->avg_pick_mode_time = (7 * cpi->avg_pick_mode_time + duration2) >> 3;
5212 }
5213 }
5214
5215 }
5216
5217 if (cm->refresh_entropy_probs == 0)
5218 {
5219 vpx_memcpy(&cm->fc, &cm->lfc, sizeof(cm->fc));
5220 }
5221
5222 /* Save the contexts separately for alt ref, gold and last. */
5223 /* (TODO jbb -> Optimize this with pointers to avoid extra copies. ) */
5224 if(cm->refresh_alt_ref_frame)
5225 vpx_memcpy(&cpi->lfc_a, &cm->fc, sizeof(cm->fc));
5226
5227 if(cm->refresh_golden_frame)
5228 vpx_memcpy(&cpi->lfc_g, &cm->fc, sizeof(cm->fc));
5229
5230 if(cm->refresh_last_frame)
5231 vpx_memcpy(&cpi->lfc_n, &cm->fc, sizeof(cm->fc));
5232
5233 /* if its a dropped frame honor the requests on subsequent frames */
5234 if (*size > 0)
5235 {
5236 cpi->droppable = !frame_is_reference(cpi);
5237
5238 /* return to normal state */
5239 cm->refresh_entropy_probs = 1;
5240 cm->refresh_alt_ref_frame = 0;
5241 cm->refresh_golden_frame = 0;
5242 cm->refresh_last_frame = 1;
5243 cm->frame_type = INTER_FRAME;
5244
5245 }
5246
5247 /* Save layer specific state */
5248 if (cpi->oxcf.number_of_layers > 1)
5249 save_layer_context (cpi);
5250
5251 vpx_usec_timer_mark(&cmptimer);
5252 cpi->time_compress_data += vpx_usec_timer_elapsed(&cmptimer);
5253
5254 if (cpi->b_calculate_psnr && cpi->pass != 1 && cm->show_frame)
5255 {
5256 generate_psnr_packet(cpi);
5257 }
5258
5259 #if CONFIG_INTERNAL_STATS
5260
5261 if (cpi->pass != 1)
5262 {
5263 cpi->bytes += *size;
5264
5265 if (cm->show_frame)
5266 {
5267 cpi->common.show_frame_mi = cpi->common.mi;
5268 cpi->count ++;
5269
5270 if (cpi->b_calculate_psnr)
5271 {
5272 uint64_t ye,ue,ve;
5273 double frame_psnr;
5274 YV12_BUFFER_CONFIG *orig = cpi->Source;
5275 YV12_BUFFER_CONFIG *recon = cpi->common.frame_to_show;
5276 int y_samples = orig->y_height * orig->y_width ;
5277 int uv_samples = orig->uv_height * orig->uv_width ;
5278 int t_samples = y_samples + 2 * uv_samples;
5279 double sq_error, sq_error2;
5280
5281 ye = calc_plane_error(orig->y_buffer, orig->y_stride,
5282 recon->y_buffer, recon->y_stride, orig->y_width, orig->y_height);
5283
5284 ue = calc_plane_error(orig->u_buffer, orig->uv_stride,
5285 recon->u_buffer, recon->uv_stride, orig->uv_width, orig->uv_height);
5286
5287 ve = calc_plane_error(orig->v_buffer, orig->uv_stride,
5288 recon->v_buffer, recon->uv_stride, orig->uv_width, orig->uv_height);
5289
5290 sq_error = (double)(ye + ue + ve);
5291
5292 frame_psnr = vpx_sse_to_psnr(t_samples, 255.0, sq_error);
5293
5294 cpi->total_y += vpx_sse_to_psnr(y_samples, 255.0, (double)ye);
5295 cpi->total_u += vpx_sse_to_psnr(uv_samples, 255.0, (double)ue);
5296 cpi->total_v += vpx_sse_to_psnr(uv_samples, 255.0, (double)ve);
5297 cpi->total_sq_error += sq_error;
5298 cpi->total += frame_psnr;
5299 #if CONFIG_POSTPROC
5300 {
5301 YV12_BUFFER_CONFIG *pp = &cm->post_proc_buffer;
5302 double frame_psnr2, frame_ssim2 = 0;
5303 double weight = 0;
5304
5305 vp8_deblock(cm, cm->frame_to_show, &cm->post_proc_buffer, cm->filter_level * 10 / 6, 1, 0);
5306 vp8_clear_system_state();
5307
5308 ye = calc_plane_error(orig->y_buffer, orig->y_stride,
5309 pp->y_buffer, pp->y_stride, orig->y_width, orig->y_height);
5310
5311 ue = calc_plane_error(orig->u_buffer, orig->uv_stride,
5312 pp->u_buffer, pp->uv_stride, orig->uv_width, orig->uv_height);
5313
5314 ve = calc_plane_error(orig->v_buffer, orig->uv_stride,
5315 pp->v_buffer, pp->uv_stride, orig->uv_width, orig->uv_height);
5316
5317 sq_error2 = (double)(ye + ue + ve);
5318
5319 frame_psnr2 = vpx_sse_to_psnr(t_samples, 255.0, sq_error2);
5320
5321 cpi->totalp_y += vpx_sse_to_psnr(y_samples,
5322 255.0, (double)ye);
5323 cpi->totalp_u += vpx_sse_to_psnr(uv_samples,
5324 255.0, (double)ue);
5325 cpi->totalp_v += vpx_sse_to_psnr(uv_samples,
5326 255.0, (double)ve);
5327 cpi->total_sq_error2 += sq_error2;
5328 cpi->totalp += frame_psnr2;
5329
5330 frame_ssim2 = vp8_calc_ssim(cpi->Source,
5331 &cm->post_proc_buffer, 1, &weight);
5332
5333 cpi->summed_quality += frame_ssim2 * weight;
5334 cpi->summed_weights += weight;
5335
5336 if (cpi->oxcf.number_of_layers > 1)
5337 {
5338 unsigned int i;
5339
5340 for (i=cpi->current_layer;
5341 i<cpi->oxcf.number_of_layers; i++)
5342 {
5343 cpi->frames_in_layer[i]++;
5344
5345 cpi->bytes_in_layer[i] += *size;
5346 cpi->sum_psnr[i] += frame_psnr;
5347 cpi->sum_psnr_p[i] += frame_psnr2;
5348 cpi->total_error2[i] += sq_error;
5349 cpi->total_error2_p[i] += sq_error2;
5350 cpi->sum_ssim[i] += frame_ssim2 * weight;
5351 cpi->sum_weights[i] += weight;
5352 }
5353 }
5354 }
5355 #endif
5356 }
5357
5358 if (cpi->b_calculate_ssimg)
5359 {
5360 double y, u, v, frame_all;
5361 frame_all = vp8_calc_ssimg(cpi->Source, cm->frame_to_show,
5362 &y, &u, &v);
5363
5364 if (cpi->oxcf.number_of_layers > 1)
5365 {
5366 unsigned int i;
5367
5368 for (i=cpi->current_layer;
5369 i<cpi->oxcf.number_of_layers; i++)
5370 {
5371 if (!cpi->b_calculate_psnr)
5372 cpi->frames_in_layer[i]++;
5373
5374 cpi->total_ssimg_y_in_layer[i] += y;
5375 cpi->total_ssimg_u_in_layer[i] += u;
5376 cpi->total_ssimg_v_in_layer[i] += v;
5377 cpi->total_ssimg_all_in_layer[i] += frame_all;
5378 }
5379 }
5380 else
5381 {
5382 cpi->total_ssimg_y += y;
5383 cpi->total_ssimg_u += u;
5384 cpi->total_ssimg_v += v;
5385 cpi->total_ssimg_all += frame_all;
5386 }
5387 }
5388
5389 }
5390 }
5391
5392 #if 0
5393
5394 if (cpi->common.frame_type != 0 && cpi->common.base_qindex == cpi->oxcf.worst_allowed_q)
5395 {
5396 skiptruecount += cpi->skip_true_count;
5397 skipfalsecount += cpi->skip_false_count;
5398 }
5399
5400 #endif
5401 #if 0
5402
5403 if (cpi->pass != 1)
5404 {
5405 FILE *f = fopen("skip.stt", "a");
5406 fprintf(f, "frame:%4d flags:%4x Q:%4d P:%4d Size:%5d\n", cpi->common.current_video_frame, *frame_flags, cpi->common.base_qindex, cpi->prob_skip_false, *size);
5407
5408 if (cpi->is_src_frame_alt_ref == 1)
5409 fprintf(f, "skipcount: %4d framesize: %d\n", cpi->skip_true_count , *size);
5410
5411 fclose(f);
5412 }
5413
5414 #endif
5415 #endif
5416
5417 #if HAVE_NEON
5418 #if CONFIG_RUNTIME_CPU_DETECT
5419 if (cm->cpu_caps & HAS_NEON)
5420 #endif
5421 {
5422 vp8_pop_neon(store_reg);
5423 }
5424 #endif
5425
5426 cpi->common.error.setjmp = 0;
5427
5428 return 0;
5429 }
5430
vp8_get_preview_raw_frame(VP8_COMP * cpi,YV12_BUFFER_CONFIG * dest,vp8_ppflags_t * flags)5431 int vp8_get_preview_raw_frame(VP8_COMP *cpi, YV12_BUFFER_CONFIG *dest, vp8_ppflags_t *flags)
5432 {
5433 if (cpi->common.refresh_alt_ref_frame)
5434 return -1;
5435 else
5436 {
5437 int ret;
5438
5439 #if CONFIG_MULTITHREAD
5440 if(cpi->b_lpf_running)
5441 {
5442 sem_wait(&cpi->h_event_end_lpf);
5443 cpi->b_lpf_running = 0;
5444 }
5445 #endif
5446
5447 #if CONFIG_POSTPROC
5448 cpi->common.show_frame_mi = cpi->common.mi;
5449 ret = vp8_post_proc_frame(&cpi->common, dest, flags);
5450 #else
5451
5452 if (cpi->common.frame_to_show)
5453 {
5454 *dest = *cpi->common.frame_to_show;
5455 dest->y_width = cpi->common.Width;
5456 dest->y_height = cpi->common.Height;
5457 dest->uv_height = cpi->common.Height / 2;
5458 ret = 0;
5459 }
5460 else
5461 {
5462 ret = -1;
5463 }
5464
5465 #endif
5466 vp8_clear_system_state();
5467 return ret;
5468 }
5469 }
5470
vp8_set_roimap(VP8_COMP * cpi,unsigned char * map,unsigned int rows,unsigned int cols,int delta_q[4],int delta_lf[4],unsigned int threshold[4])5471 int vp8_set_roimap(VP8_COMP *cpi, unsigned char *map, unsigned int rows, unsigned int cols, int delta_q[4], int delta_lf[4], unsigned int threshold[4])
5472 {
5473 signed char feature_data[MB_LVL_MAX][MAX_MB_SEGMENTS];
5474 int internal_delta_q[MAX_MB_SEGMENTS];
5475 const int range = 63;
5476 int i;
5477
5478 // This method is currently incompatible with the cyclic refresh method
5479 if ( cpi->cyclic_refresh_mode_enabled )
5480 return -1;
5481
5482 // Check number of rows and columns match
5483 if (cpi->common.mb_rows != (int)rows || cpi->common.mb_cols != (int)cols)
5484 return -1;
5485
5486 // Range check the delta Q values and convert the external Q range values
5487 // to internal ones.
5488 if ( (abs(delta_q[0]) > range) || (abs(delta_q[1]) > range) ||
5489 (abs(delta_q[2]) > range) || (abs(delta_q[3]) > range) )
5490 return -1;
5491
5492 // Range check the delta lf values
5493 if ( (abs(delta_lf[0]) > range) || (abs(delta_lf[1]) > range) ||
5494 (abs(delta_lf[2]) > range) || (abs(delta_lf[3]) > range) )
5495 return -1;
5496
5497 if (!map)
5498 {
5499 disable_segmentation(cpi);
5500 return 0;
5501 }
5502
5503 // Translate the external delta q values to internal values.
5504 for ( i = 0; i < MAX_MB_SEGMENTS; i++ )
5505 internal_delta_q[i] =
5506 ( delta_q[i] >= 0 ) ? q_trans[delta_q[i]] : -q_trans[-delta_q[i]];
5507
5508 /* Set the segmentation Map */
5509 set_segmentation_map(cpi, map);
5510
5511 /* Activate segmentation. */
5512 enable_segmentation(cpi);
5513
5514 /* Set up the quant segment data */
5515 feature_data[MB_LVL_ALT_Q][0] = internal_delta_q[0];
5516 feature_data[MB_LVL_ALT_Q][1] = internal_delta_q[1];
5517 feature_data[MB_LVL_ALT_Q][2] = internal_delta_q[2];
5518 feature_data[MB_LVL_ALT_Q][3] = internal_delta_q[3];
5519
5520 /* Set up the loop segment data s */
5521 feature_data[MB_LVL_ALT_LF][0] = delta_lf[0];
5522 feature_data[MB_LVL_ALT_LF][1] = delta_lf[1];
5523 feature_data[MB_LVL_ALT_LF][2] = delta_lf[2];
5524 feature_data[MB_LVL_ALT_LF][3] = delta_lf[3];
5525
5526 cpi->segment_encode_breakout[0] = threshold[0];
5527 cpi->segment_encode_breakout[1] = threshold[1];
5528 cpi->segment_encode_breakout[2] = threshold[2];
5529 cpi->segment_encode_breakout[3] = threshold[3];
5530
5531 /* Initialise the feature data structure */
5532 set_segment_data(cpi, &feature_data[0][0], SEGMENT_DELTADATA);
5533
5534 return 0;
5535 }
5536
vp8_set_active_map(VP8_COMP * cpi,unsigned char * map,unsigned int rows,unsigned int cols)5537 int vp8_set_active_map(VP8_COMP *cpi, unsigned char *map, unsigned int rows, unsigned int cols)
5538 {
5539 if ((int)rows == cpi->common.mb_rows && (int)cols == cpi->common.mb_cols)
5540 {
5541 if (map)
5542 {
5543 vpx_memcpy(cpi->active_map, map, rows * cols);
5544 cpi->active_map_enabled = 1;
5545 }
5546 else
5547 cpi->active_map_enabled = 0;
5548
5549 return 0;
5550 }
5551 else
5552 {
5553 return -1 ;
5554 }
5555 }
5556
vp8_set_internal_size(VP8_COMP * cpi,VPX_SCALING horiz_mode,VPX_SCALING vert_mode)5557 int vp8_set_internal_size(VP8_COMP *cpi, VPX_SCALING horiz_mode, VPX_SCALING vert_mode)
5558 {
5559 if (horiz_mode <= ONETWO)
5560 cpi->common.horiz_scale = horiz_mode;
5561 else
5562 return -1;
5563
5564 if (vert_mode <= ONETWO)
5565 cpi->common.vert_scale = vert_mode;
5566 else
5567 return -1;
5568
5569 return 0;
5570 }
5571
5572
5573
vp8_calc_ss_err(YV12_BUFFER_CONFIG * source,YV12_BUFFER_CONFIG * dest)5574 int vp8_calc_ss_err(YV12_BUFFER_CONFIG *source, YV12_BUFFER_CONFIG *dest)
5575 {
5576 int i, j;
5577 int Total = 0;
5578
5579 unsigned char *src = source->y_buffer;
5580 unsigned char *dst = dest->y_buffer;
5581
5582 /* Loop through the Y plane raw and reconstruction data summing
5583 * (square differences)
5584 */
5585 for (i = 0; i < source->y_height; i += 16)
5586 {
5587 for (j = 0; j < source->y_width; j += 16)
5588 {
5589 unsigned int sse;
5590 Total += vp8_mse16x16(src + j, source->y_stride, dst + j, dest->y_stride, &sse);
5591 }
5592
5593 src += 16 * source->y_stride;
5594 dst += 16 * dest->y_stride;
5595 }
5596
5597 return Total;
5598 }
5599
5600
vp8_get_quantizer(VP8_COMP * cpi)5601 int vp8_get_quantizer(VP8_COMP *cpi)
5602 {
5603 return cpi->common.base_qindex;
5604 }
5605