19 |
* along with this program; if not, write to the Free Software |
* along with this program; if not, write to the Free Software |
20 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
21 |
* |
* |
22 |
* $Id: xvid_encraw.c,v 1.11.2.14 2003-03-26 14:56:09 edgomez Exp $ |
* $Id: xvid_encraw.c,v 1.11.2.18 2003-04-19 11:26:47 chl Exp $ |
23 |
* |
* |
24 |
****************************************************************************/ |
****************************************************************************/ |
25 |
|
|
94 |
static int ARG_BITRATE = 0; |
static int ARG_BITRATE = 0; |
95 |
static char *ARG_PASS1 = 0; |
static char *ARG_PASS1 = 0; |
96 |
static char *ARG_PASS2 = 0; |
static char *ARG_PASS2 = 0; |
97 |
|
static int ARG_PASS2_BITRATE = 0; |
98 |
static float ARG_QUANTI = 0.0f; |
static float ARG_QUANTI = 0.0f; |
99 |
static int ARG_QUALITY = 5; |
static int ARG_QUALITY = 5; |
100 |
static float ARG_FRAMERATE = 25.00f; |
static float ARG_FRAMERATE = 25.00f; |
174 |
|
|
175 |
double enctime; |
double enctime; |
176 |
double totalenctime = 0.; |
double totalenctime = 0.; |
177 |
|
float totalPSNR[3] = {0., 0., 0.}; |
178 |
|
|
179 |
int totalsize; |
int totalsize; |
180 |
int result; |
int result; |
218 |
ARG_PASS1 = argv[i]; |
ARG_PASS1 = argv[i]; |
219 |
} else if (strcmp("-pass2", argv[i]) == 0 && i < argc - 2) { |
} else if (strcmp("-pass2", argv[i]) == 0 && i < argc - 2) { |
220 |
i++; |
i++; |
|
ARG_PASS1 = argv[i]; |
|
|
i++; |
|
221 |
ARG_PASS2 = argv[i]; |
ARG_PASS2 = argv[i]; |
222 |
|
i++; |
223 |
|
ARG_PASS2_BITRATE = atoi(argv[i]); |
224 |
} else if (strcmp("-max_bframes", argv[i]) == 0 && i < argc - 1) { |
} else if (strcmp("-max_bframes", argv[i]) == 0 && i < argc - 1) { |
225 |
i++; |
i++; |
226 |
ARG_MAXBFRAMES = atoi(argv[i]); |
ARG_MAXBFRAMES = atoi(argv[i]); |
428 |
SSE2PSNR(sse[0], XDIM, YDIM), SSE2PSNR(sse[1], XDIM / 2, |
SSE2PSNR(sse[0], XDIM, YDIM), SSE2PSNR(sse[1], XDIM / 2, |
429 |
YDIM / 2), |
YDIM / 2), |
430 |
SSE2PSNR(sse[2], XDIM / 2, YDIM / 2)); |
SSE2PSNR(sse[2], XDIM / 2, YDIM / 2)); |
431 |
|
|
432 |
|
totalPSNR[0] += SSE2PSNR(sse[0], XDIM, YDIM); |
433 |
|
totalPSNR[1] += SSE2PSNR(sse[1], XDIM/2, YDIM/2); |
434 |
|
totalPSNR[2] += SSE2PSNR(sse[2], XDIM/2, YDIM/2); |
435 |
} |
} |
436 |
|
|
437 |
} |
} |
488 |
if (input_num > 0) { |
if (input_num > 0) { |
489 |
totalsize /= input_num; |
totalsize /= input_num; |
490 |
totalenctime /= input_num; |
totalenctime /= input_num; |
491 |
|
totalPSNR[0] /= input_num; |
492 |
|
totalPSNR[1] /= input_num; |
493 |
|
totalPSNR[2] /= input_num; |
494 |
} else { |
} else { |
495 |
totalsize = -1; |
totalsize = -1; |
496 |
totalenctime = -1; |
totalenctime = -1; |
497 |
} |
} |
498 |
|
|
499 |
printf("Avg: enctime(ms) =%7.2f, fps =%7.2f, length(bytes) = %7d\n", |
printf("Avg: enctime(ms) =%7.2f, fps =%7.2f, length(bytes) = %7d, ", |
500 |
totalenctime, 1000 / totalenctime, (int) totalsize); |
totalenctime, 1000 / totalenctime, (int) totalsize); |
501 |
|
if (ARG_STATS) { |
502 |
|
printf("psnr y = %2.2f, psnr u = %2.2f, psnr v = %2.2f", |
503 |
|
totalPSNR[0],totalPSNR[1],totalPSNR[2]); |
504 |
|
} |
505 |
|
printf("\n"); |
506 |
|
|
507 |
|
|
508 |
/***************************************************************************** |
/***************************************************************************** |
587 |
fprintf(stderr, " -framerate float : target framerate (>0 | default=25.0)\n"); |
fprintf(stderr, " -framerate float : target framerate (>0 | default=25.0)\n"); |
588 |
fprintf(stderr, " -bitrate integer : bitrate -- for CBR/VBR pass2\n"); |
fprintf(stderr, " -bitrate integer : bitrate -- for CBR/VBR pass2\n"); |
589 |
fprintf(stderr, " -quant float : quantizer -- for \"Fixed\" quantizer RC\n"); |
fprintf(stderr, " -quant float : quantizer -- for \"Fixed\" quantizer RC\n"); |
590 |
fprintf(stderr, " -pass1 filename : stats filename\n"); |
fprintf(stderr, " -pass1 filename : output stats filename\n"); |
591 |
fprintf(stderr, " -pass2 filename1 filename2 : first pass stats and scaled stats filename\n"); |
fprintf(stderr, " -pass2 filename bitrate : input stats filename, target bitrate\n"); |
592 |
fprintf(stderr, "\n"); |
fprintf(stderr, "\n"); |
593 |
fprintf(stderr, "Other options\n"); |
fprintf(stderr, "Other options\n"); |
594 |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
781 |
xvid_enc_create.num_plugins = 0; |
xvid_enc_create.num_plugins = 0; |
782 |
|
|
783 |
if (ARG_BITRATE) { |
if (ARG_BITRATE) { |
|
cbr.version = XVID_VERSION; |
|
784 |
memset(&cbr, 0, sizeof(xvid_plugin_cbr_t)); |
memset(&cbr, 0, sizeof(xvid_plugin_cbr_t)); |
785 |
|
cbr.version = XVID_VERSION; |
786 |
cbr.bitrate = ARG_BITRATE; |
cbr.bitrate = ARG_BITRATE; |
787 |
|
|
788 |
plugins[xvid_enc_create.num_plugins].func = xvid_plugin_cbr; |
plugins[xvid_enc_create.num_plugins].func = xvid_plugin_cbr; |
791 |
} |
} |
792 |
|
|
793 |
if (ARG_QUANTI) { |
if (ARG_QUANTI) { |
794 |
|
memset(&rcfixed, 0, sizeof(xvid_plugin_fixed_t)); |
795 |
rcfixed.version = XVID_VERSION; |
rcfixed.version = XVID_VERSION; |
796 |
/* We will use a 1/10 precision, just to make sure it works */ |
/* We will use a 1/10 precision, just to make sure it works */ |
797 |
rcfixed.quant_base = 10; |
rcfixed.quant_base = 10; |
802 |
xvid_enc_create.num_plugins++; |
xvid_enc_create.num_plugins++; |
803 |
} |
} |
804 |
|
|
805 |
if (ARG_PASS1 && ARG_PASS2) { |
if (ARG_PASS2) { |
|
rc2pass2.version = XVID_VERSION; |
|
806 |
memset(&rc2pass2, 0, sizeof(xvid_plugin_2pass2_t)); |
memset(&rc2pass2, 0, sizeof(xvid_plugin_2pass2_t)); |
807 |
rc2pass2.filename1 = ARG_PASS1; |
rc2pass2.version = XVID_VERSION; |
808 |
rc2pass2.filename2 = ARG_PASS2; |
rc2pass2.filename = ARG_PASS2; |
809 |
|
rc2pass2.bitrate = ARG_PASS2_BITRATE; |
810 |
|
|
811 |
plugins[xvid_enc_create.num_plugins].func = xvid_plugin_2pass2; |
plugins[xvid_enc_create.num_plugins].func = xvid_plugin_2pass2; |
812 |
plugins[xvid_enc_create.num_plugins].param = &rc2pass2; |
plugins[xvid_enc_create.num_plugins].param = &rc2pass2; |
813 |
xvid_enc_create.num_plugins++; |
xvid_enc_create.num_plugins++; |
814 |
} else if (ARG_PASS1) { |
} |
815 |
rc2pass1.version = XVID_VERSION; |
|
816 |
|
if (ARG_PASS1) { |
817 |
memset(&rc2pass1, 0, sizeof(xvid_plugin_2pass1_t)); |
memset(&rc2pass1, 0, sizeof(xvid_plugin_2pass1_t)); |
818 |
|
rc2pass1.version = XVID_VERSION; |
819 |
rc2pass1.filename = ARG_PASS1; |
rc2pass1.filename = ARG_PASS1; |
820 |
|
|
821 |
plugins[xvid_enc_create.num_plugins].func = xvid_plugin_2pass1; |
plugins[xvid_enc_create.num_plugins].func = xvid_plugin_2pass1; |