20 #define VPX_CODEC_DISABLE_COMPAT 1
21 #include "./vpx_config.h"
22 #include "vpx_ports/vpx_timer.h"
26 #include "./tools_common.h"
27 #include "./video_writer.h"
29 static const char *exec_name;
40 kDenoiserOnYUVAggressive
43 static int mode_to_num_layers[12] = {1, 2, 2, 3, 3, 3, 3, 5, 2, 3, 3, 3};
46 struct RateControlMetrics {
71 static void set_rate_control_metrics(
struct RateControlMetrics *rc,
79 rc->layer_framerate[0];
83 rc->layer_pfb[i] = 1000.0 *
85 (rc->layer_framerate[i] - rc->layer_framerate[i - 1]);
87 rc->layer_input_frames[i] = 0;
88 rc->layer_enc_frames[i] = 0;
89 rc->layer_tot_enc_frames[i] = 0;
90 rc->layer_encoding_bitrate[i] = 0.0;
91 rc->layer_avg_frame_size[i] = 0.0;
92 rc->layer_avg_rate_mismatch[i] = 0.0;
96 static void printout_rate_control_summary(
struct RateControlMetrics *rc,
100 int tot_num_frames = 0;
101 printf(
"Total number of processed frames: %d\n\n", frame_cnt -1);
102 printf(
"Rate control layer stats for %d layer(s):\n\n",
105 const int num_dropped = (i > 0) ?
106 (rc->layer_input_frames[i] - rc->layer_enc_frames[i]) :
107 (rc->layer_input_frames[i] - rc->layer_enc_frames[i] - 1);
108 tot_num_frames += rc->layer_input_frames[i];
109 rc->layer_encoding_bitrate[i] = 0.001 * rc->layer_framerate[i] *
110 rc->layer_encoding_bitrate[i] / tot_num_frames;
111 rc->layer_avg_frame_size[i] = rc->layer_avg_frame_size[i] /
112 rc->layer_enc_frames[i];
113 rc->layer_avg_rate_mismatch[i] = 100.0 * rc->layer_avg_rate_mismatch[i] /
114 rc->layer_enc_frames[i];
115 printf(
"For layer#: %d \n", i);
117 rc->layer_encoding_bitrate[i]);
118 printf(
"Average frame size (target vs actual): %f %f \n", rc->layer_pfb[i],
119 rc->layer_avg_frame_size[i]);
120 printf(
"Average rate_mismatch: %f \n", rc->layer_avg_rate_mismatch[i]);
121 printf(
"Number of input frames, encoded (non-key) frames, "
122 "and perc dropped frames: %d %d %f \n", rc->layer_input_frames[i],
123 rc->layer_enc_frames[i],
124 100.0 * num_dropped / rc->layer_input_frames[i]);
127 if ((frame_cnt - 1) != tot_num_frames)
128 die(
"Error: Number of input frames not equal to output! \n");
136 static void set_temporal_layer_pattern(
int layering_mode,
139 int *flag_periodicity) {
140 switch (layering_mode) {
145 *flag_periodicity = 1;
158 *flag_periodicity = 2;
180 int ids[3] = {0, 1, 1};
182 *flag_periodicity = 3;
197 int ids[6] = {0, 2, 2, 1, 2, 2};
199 *flag_periodicity = 6;
218 int ids[4] = {0, 2, 1, 2};
220 *flag_periodicity = 4;
238 int ids[4] = {0, 2, 1, 2};
240 *flag_periodicity = 4;
259 int ids[4] = {0, 2, 1, 2};
261 *flag_periodicity = 4;
279 int ids[16] = {0, 4, 3, 4, 2, 4, 3, 4, 1, 4, 3, 4, 2, 4, 3, 4};
281 *flag_periodicity = 16;
312 *flag_periodicity = 8;
334 layer_flags[4] = layer_flags[2];
336 layer_flags[5] = layer_flags[3];
338 layer_flags[6] = layer_flags[4];
340 layer_flags[7] = layer_flags[5];
345 int ids[4] = {0, 2, 1, 2};
347 *flag_periodicity = 8;
375 int ids[4] = {0, 2, 1, 2};
377 *flag_periodicity = 8;
401 layer_flags[5] = layer_flags[3];
405 layer_flags[7] = layer_flags[3];
412 int ids[4] = {0, 2, 1, 2};
414 *flag_periodicity = 8;
424 layer_flags[4] = layer_flags[0];
427 layer_flags[6] = layer_flags[2];
431 layer_flags[3] = layer_flags[1];
432 layer_flags[5] = layer_flags[1];
433 layer_flags[7] = layer_flags[1];
439 int main(
int argc,
char **argv) {
454 int frame_duration = 1;
455 int layering_mode = 0;
457 int flag_periodicity = 1;
458 int max_intra_size_pct;
460 const VpxInterface *encoder = NULL;
462 struct RateControlMetrics rc;
468 die(
"Usage: %s <infile> <outfile> <codec_type(vp8/vp9)> <width> <height> "
469 "<rate_num> <rate_den> <speed> <frame_drop_threshold> <mode> "
470 "<Rate_0> ... <Rate_nlayers-1> \n", argv[0]);
473 encoder = get_vpx_encoder_by_name(argv[3]);
475 die(
"Unsupported codec.");
479 width = strtol(argv[4], NULL, 0);
480 height = strtol(argv[5], NULL, 0);
481 if (width < 16 || width % 2 || height < 16 || height % 2) {
482 die(
"Invalid resolution: %d x %d", width, height);
485 layering_mode = strtol(argv[10], NULL, 0);
486 if (layering_mode < 0 || layering_mode > 12) {
487 die(
"Invalid layering mode (0..12) %s", argv[10]);
490 if (argc != 11 + mode_to_num_layers[layering_mode]) {
491 die(
"Invalid number of arguments");
495 die(
"Failed to allocate image", width, height);
513 speed = strtol(argv[8], NULL, 0);
515 die(
"Invalid speed setting: must be positive");
518 for (i = 11; (int)i < 11 + mode_to_num_layers[layering_mode]; ++i) {
542 set_temporal_layer_pattern(layering_mode,
547 set_rate_control_metrics(&rc, &cfg);
554 if (!(infile = fopen(argv[1],
"rb"))) {
555 die(
"Failed to open %s for reading", argv[1]);
560 char file_name[PATH_MAX];
562 info.codec_fourcc = encoder->fourcc;
563 info.frame_width = cfg.
g_w;
564 info.frame_height = cfg.
g_h;
568 snprintf(file_name,
sizeof(file_name),
"%s_%d.ivf", argv[2], i);
569 outfile[i] = vpx_video_writer_open(file_name, kContainerIVF, &info);
571 die(
"Failed to open %s for writing", file_name);
578 die_codec(&codec,
"Failed to initialize encoder");
580 if (strncmp(encoder->name,
"vp8", 3) == 0) {
583 }
else if (strncmp(encoder->name,
"vp9", 3) == 0) {
589 die_codec(&codec,
"Failed to set SVC");
600 max_intra_size_pct = 200;
604 while (frame_avail || got_data) {
605 struct vpx_usec_timer timer;
612 if (strncmp(encoder->name,
"vp9", 3) == 0) {
615 flags = layer_flags[frame_cnt % flag_periodicity];
616 frame_avail = vpx_img_read(&raw, infile);
619 vpx_usec_timer_start(&timer);
622 die_codec(&codec,
"Failed to encode frame");
624 vpx_usec_timer_mark(&timer);
625 cx_time += vpx_usec_timer_elapsed(&timer);
627 if (layering_mode != 7) {
637 vpx_video_writer_write_frame(outfile[i], pkt->
data.
frame.buf,
639 ++rc.layer_tot_enc_frames[i];
640 rc.layer_encoding_bitrate[i] += 8.0 * pkt->
data.
frame.sz;
644 rc.layer_avg_frame_size[i] += 8.0 * pkt->
data.
frame.sz;
645 rc.layer_avg_rate_mismatch[i] +=
646 fabs(8.0 * pkt->
data.
frame.sz - rc.layer_pfb[i]) /
648 ++rc.layer_enc_frames[i];
657 pts += frame_duration;
660 printout_rate_control_summary(&rc, &cfg, frame_cnt);
662 printf(
"Frame cnt and encoding time/FPS stats for encoding: %d %f %f \n",
664 1000 * (
float)cx_time / (
double)(frame_cnt * 1000000),
665 1000000 * (
double)frame_cnt / (
double)cx_time);
668 die_codec(&codec,
"Failed to destroy codec");
672 vpx_video_writer_close(outfile[i]);
unsigned int rc_buf_initial_sz
Decoder Buffer Initial Size.
Definition: vpx_encoder.h:566
unsigned int ts_number_layers
Number of temporal coding layers.
Definition: vpx_encoder.h:671
control function to set vp8 encoder cpuused
Definition: vp8cx.h:149
#define VP8_EFLAG_NO_REF_LAST
Don't reference the last frame.
Definition: vp8cx.h:55
#define VP8_EFLAG_NO_UPD_GF
Don't update the golden frame.
Definition: vp8cx.h:89
Image Descriptor.
Definition: vpx_image.h:102
Describes the encoder algorithm interface to applications.
const char * vpx_codec_iface_name(vpx_codec_iface_t *iface)
Return the name for a given interface.
const char * vpx_codec_err_to_string(vpx_codec_err_t err)
Convert error number to printable string.
#define VPX_TS_MAX_LAYERS
Definition: vpx_encoder.h:40
struct vpx_rational g_timebase
Stream timebase units.
Definition: vpx_encoder.h:353
Definition: vpx_encoder.h:247
unsigned int rc_buf_sz
Decoder Buffer Size.
Definition: vpx_encoder.h:556
#define VP8_EFLAG_NO_REF_GF
Don't reference the golden frame.
Definition: vp8cx.h:64
enum vpx_kf_mode kf_mode
Keyframe placement mode.
Definition: vpx_encoder.h:621
int den
Definition: vpx_encoder.h:232
vpx_codec_err_t vpx_codec_encode(vpx_codec_ctx_t *ctx, const vpx_image_t *img, vpx_codec_pts_t pts, unsigned long duration, vpx_enc_frame_flags_t flags, unsigned long deadline)
Encode a frame.
unsigned int rc_max_quantizer
Maximum (Worst Quality) Quantizer.
Definition: vpx_encoder.h:508
unsigned int rc_min_quantizer
Minimum (Best Quality) Quantizer.
Definition: vpx_encoder.h:497
unsigned int kf_max_dist
Keyframe maximum interval.
Definition: vpx_encoder.h:641
unsigned int g_lag_in_frames
Allow lagged encoding.
Definition: vpx_encoder.h:385
Encoder configuration structure.
Definition: vpx_encoder.h:285
Definition: vpx_encoder.h:263
int spatial_layer_id
Definition: vp8cx.h:324
Max data rate for Intra frames.
Definition: vp8cx.h:190
Encoder output packet.
Definition: vpx_encoder.h:185
unsigned int rc_overshoot_pct
Rate control adaptation overshoot control.
Definition: vpx_encoder.h:539
unsigned int ts_rate_decimator[5]
Frame rate decimation factor for each temporal layer.
Definition: vpx_encoder.h:685
unsigned int rc_buf_optimal_sz
Decoder Buffer Optimal Size.
Definition: vpx_encoder.h:576
unsigned int kf_min_dist
Keyframe minimum interval.
Definition: vpx_encoder.h:631
unsigned int ts_layer_id[16]
Template defining the membership of frames to temporal layers.
Definition: vpx_encoder.h:703
struct vpx_codec_cx_pkt::@1::@2 frame
vpx_image_t * vpx_img_alloc(vpx_image_t *img, vpx_img_fmt_t fmt, unsigned int d_w, unsigned int d_h, unsigned int align)
Open a descriptor, allocating storage for the underlying image.
Definition: vpx_image.h:56
unsigned int g_w
Width of the frame.
Definition: vpx_encoder.h:328
unsigned int ts_target_bitrate[5]
Target bitrate for each temporal layer.
Definition: vpx_encoder.h:678
unsigned int rc_undershoot_pct
Rate control adaptation undershoot control.
Definition: vpx_encoder.h:526
unsigned int g_h
Height of the frame.
Definition: vpx_encoder.h:338
enum vpx_codec_cx_pkt_kind kind
Definition: vpx_encoder.h:186
unsigned int rc_dropframe_thresh
Temporal resampling configuration, if supported by the codec.
Definition: vpx_encoder.h:408
vp9 svc layer parameters
Definition: vp8cx.h:323
#define VP8_EFLAG_NO_UPD_LAST
Don't update the last frame.
Definition: vp8cx.h:81
void vpx_img_free(vpx_image_t *img)
Close an image descriptor.
unsigned int rc_target_bitrate
Target data rate.
Definition: vpx_encoder.h:481
#define VPX_DL_REALTIME
Definition: vpx_encoder.h:838
int num
Definition: vpx_encoder.h:231
vpx_codec_err_t vpx_codec_enc_config_default(vpx_codec_iface_t *iface, vpx_codec_enc_cfg_t *cfg, unsigned int usage)
Get a default configuration.
unsigned int ss_number_layers
Number of spatial coding layers.
Definition: vpx_encoder.h:651
Provides definitions for using the VP8 encoder algorithm within the vpx Codec Interface.
#define vpx_codec_enc_init(ctx, iface, cfg, flags)
Convenience macro for vpx_codec_enc_init_ver()
Definition: vpx_encoder.h:740
unsigned int rc_resize_allowed
Enable/disable spatial resampling, if supported by the codec.
Definition: vpx_encoder.h:418
vpx_codec_err_t
Algorithm return codes.
Definition: vpx_codec.h:89
const vpx_codec_cx_pkt_t * vpx_codec_get_cx_data(vpx_codec_ctx_t *ctx, vpx_codec_iter_t *iter)
Encoded data iterator.
union vpx_codec_cx_pkt::@1 data
int temporal_layer_id
Definition: vp8cx.h:325
#define VPX_TS_MAX_PERIODICITY
Definition: vpx_encoder.h:37
#define vpx_codec_control(ctx, id, data)
vpx_codec_control wrapper macro
Definition: vpx_codec.h:405
unsigned int ts_periodicity
Length of the sequence defining frame temporal layer membership.
Definition: vpx_encoder.h:694
#define VP8_EFLAG_NO_REF_ARF
Don't reference the alternate reference frame.
Definition: vp8cx.h:73
vpx_codec_err_t vpx_codec_destroy(vpx_codec_ctx_t *ctx)
Destroy a codec instance.
#define VPX_FRAME_IS_KEY
Definition: vpx_encoder.h:123
#define VPX_EFLAG_FORCE_KF
Definition: vpx_encoder.h:276
const void * vpx_codec_iter_t
Iterator.
Definition: vpx_codec.h:188
Definition: vpx_encoder.h:169
vpx_codec_er_flags_t g_error_resilient
Enable error resilient modes.
Definition: vpx_encoder.h:362
#define VP8_EFLAG_NO_UPD_ARF
Don't update the alternate reference frame.
Definition: vp8cx.h:97
#define VP8_EFLAG_NO_UPD_ENTROPY
Disable entropy update.
Definition: vp8cx.h:121
control function to set svc layer for spatial and temporal.
Definition: vp8cx.h:208
enum vpx_rc_mode rc_end_usage
Rate control algorithm to use.
Definition: vpx_encoder.h:460
Codec context structure.
Definition: vpx_codec.h:199