X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=vp8_multi_resolution_encoder.c;h=81e71375dff8ac95100c098bfdd5402f16c8c0b6;hb=caf0f14f84b7d66a614bc6f83ca7b311dcda437b;hp=11c33d618769bc8304c23780fd2644d26f3c8513;hpb=b2c8dff727e9020baed12feb40268f555cd4c8fc;p=profile%2Fivi%2Flibvpx.git diff --git a/vp8_multi_resolution_encoder.c b/vp8_multi_resolution_encoder.c index 11c33d6..81e7137 100644 --- a/vp8_multi_resolution_encoder.c +++ b/vp8_multi_resolution_encoder.c @@ -212,7 +212,10 @@ int main(int argc, char **argv) double psnr_totals[NUM_ENCODERS][4] = {{0,0}}; int psnr_count[NUM_ENCODERS] = {0}; - /* Set the required target bitrates for each resolution level. */ + /* Set the required target bitrates for each resolution level. + * If target bitrate for highest-resolution level is set to 0, + * (i.e. target_bitrate[0]=0), we skip encoding at that level. + */ unsigned int target_bitrate[NUM_ENCODERS]={1400, 500, 100}; /* Enter the frame rate of the input video */ int framerate = 30; @@ -241,6 +244,12 @@ int main(int argc, char **argv) /* Open output file for each encoder to output bitstreams */ for (i=0; i< NUM_ENCODERS; i++) { + if(!target_bitrate[i]) + { + outfile[i] = NULL; + continue; + } + if(!(outfile[i] = fopen(argv[i+4], "wb"))) die("Failed to open %s for writing", argv[i+4]); } @@ -279,8 +288,13 @@ int main(int argc, char **argv) cfg[0].g_lag_in_frames = 0; /* Disable automatic keyframe placement */ + /* Note: These 3 settings are copied to all levels. But, except the lowest + * resolution level, all other levels are set to VPX_KF_DISABLED internally. + */ //cfg[0].kf_mode = VPX_KF_DISABLED; - cfg[0].kf_min_dist = cfg[0].kf_max_dist = 1000; + cfg[0].kf_mode = VPX_KF_AUTO; + cfg[0].kf_min_dist = 0; + cfg[0].kf_max_dist = 150; cfg[0].rc_target_bitrate = target_bitrate[0]; /* Set target bitrate */ cfg[0].g_timebase.num = 1; /* Set fps */ @@ -322,7 +336,8 @@ int main(int argc, char **argv) read_frame_p = read_frame_by_row; for (i=0; i< NUM_ENCODERS; i++) - write_ivf_file_header(outfile[i], &cfg[i], 0); + if(outfile[i]) + write_ivf_file_header(outfile[i], &cfg[i], 0); /* Initialize multi-encoder */ if(vpx_codec_enc_init_multi(&codec[0], interface, &cfg[0], NUM_ENCODERS, @@ -428,10 +443,9 @@ int main(int argc, char **argv) fclose(infile); + printf("Processed %ld frames.\n",(long int)frame_cnt-1); for (i=0; i< NUM_ENCODERS; i++) { - printf("Processed %ld frames.\n",(long int)frame_cnt-1); - /* Calculate PSNR and print it out */ if ( (show_psnr) && (psnr_count[i]>0) ) { @@ -451,13 +465,17 @@ int main(int argc, char **argv) if(vpx_codec_destroy(&codec[i])) die_codec(&codec[i], "Failed to destroy codec"); + vpx_img_free(&raw[i]); + + if(!outfile[i]) + continue; + /* Try to rewrite the file header with the actual frame count */ if(!fseek(outfile[i], 0, SEEK_SET)) write_ivf_file_header(outfile[i], &cfg[i], frame_cnt-1); fclose(outfile[i]); - - vpx_img_free(&raw[i]); } + printf("\n"); return EXIT_SUCCESS; }