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.16 2003-04-14 20:19:00 edgomez Exp $ |
* $Id: xvid_encraw.c,v 1.11.2.21 2003-05-12 00:06:49 edgomez Exp $ |
23 |
* |
* |
24 |
****************************************************************************/ |
****************************************************************************/ |
25 |
|
|
50 |
/***************************************************************************** |
/***************************************************************************** |
51 |
* Quality presets |
* Quality presets |
52 |
****************************************************************************/ |
****************************************************************************/ |
|
|
|
53 |
static xvid_motion_t const motion_presets[] = { |
static xvid_motion_t const motion_presets[] = { |
54 |
|
/* quality 0 */ |
55 |
0, |
0, |
|
XVID_ME_HALFPELREFINE16, |
|
|
XVID_ME_HALFPELREFINE16, |
|
|
XVID_ME_HALFPELREFINE16 | XVID_ME_HALFPELREFINE8, |
|
|
XVID_ME_HALFPELREFINE16 | XVID_ME_HALFPELREFINE8 | XVID_ME_EXTSEARCH16 | |
|
|
XVID_ME_USESQUARES16, |
|
|
XVID_ME_HALFPELREFINE16 | XVID_ME_HALFPELREFINE8 | XVID_ME_EXTSEARCH16 | |
|
|
XVID_ME_USESQUARES16 | XVID_ME_CHROMA16 | XVID_ME_CHROMA8, |
|
|
}; |
|
56 |
|
|
57 |
static xvid_vol_t const vol_presets[] = { |
/* quality 1 */ |
58 |
XVID_VOL_MPEGQUANT, |
XVID_ME_ADVANCEDDIAMOND16, |
59 |
0, |
|
60 |
0, |
/* quality 2 */ |
61 |
XVID_VOL_QUARTERPEL, |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16, |
62 |
XVID_VOL_QUARTERPEL | XVID_VOL_GMC, |
|
63 |
0 |
/* quality 3 */ |
64 |
|
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
65 |
|
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8, |
66 |
|
|
67 |
|
/* quality 4 */ |
68 |
|
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
69 |
|
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | |
70 |
|
XVID_ME_CHROMA16 | XVID_ME_CHROMA8, |
71 |
|
|
72 |
|
/* quality 5 */ |
73 |
|
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
74 |
|
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | |
75 |
|
XVID_ME_CHROMA16 | XVID_ME_CHROMA8, |
76 |
|
|
77 |
|
/* quality 6 */ |
78 |
|
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | XVID_ME_EXTSEARCH16 | |
79 |
|
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | XVID_ME_EXTSEARCH8 | |
80 |
|
XVID_ME_CHROMA16 | XVID_ME_CHROMA8 , |
81 |
|
|
82 |
}; |
}; |
83 |
|
#define ME_ELEMENTS (sizeof(motion_presets)/sizeof(motion_presets[0])) |
84 |
|
|
85 |
static xvid_vop_t const vop_presets[] = { |
static xvid_vop_t const vop_presets[] = { |
86 |
|
/* quality 0 */ |
87 |
|
0, |
88 |
|
|
89 |
|
/* quality 1 */ |
90 |
XVID_VOP_DYNAMIC_BFRAMES, |
XVID_VOP_DYNAMIC_BFRAMES, |
91 |
XVID_VOP_DYNAMIC_BFRAMES, |
|
92 |
|
/* quality 2 */ |
93 |
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL, |
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL, |
94 |
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | XVID_VOP_INTER4V, |
|
95 |
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | XVID_VOP_INTER4V | XVID_VOP_HQACPRED, |
/* quality 3 */ |
96 |
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | XVID_VOP_HQACPRED | |
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | |
97 |
XVID_VOP_MODEDECISION_BITS |
XVID_VOP_INTER4V, |
98 |
|
|
99 |
|
/* quality 4 */ |
100 |
|
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | |
101 |
|
XVID_VOP_INTER4V, |
102 |
|
|
103 |
|
/* quality 5 */ |
104 |
|
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | |
105 |
|
XVID_VOP_INTER4V | XVID_VOP_TRELLISQUANT, |
106 |
|
|
107 |
|
/* quality 6 */ |
108 |
|
XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL | |
109 |
|
XVID_VOP_INTER4V | XVID_VOP_TRELLISQUANT | |
110 |
|
XVID_VOP_HQACPRED, |
111 |
|
|
112 |
}; |
}; |
113 |
|
#define VOP_ELEMENTS (sizeof(vop_presets)/sizeof(vop_presets[0])) |
114 |
|
|
115 |
/***************************************************************************** |
/***************************************************************************** |
116 |
* Command line global variables |
* Command line global variables |
127 |
static char *ARG_PASS2 = 0; |
static char *ARG_PASS2 = 0; |
128 |
static int ARG_PASS2_BITRATE = 0; |
static int ARG_PASS2_BITRATE = 0; |
129 |
static float ARG_QUANTI = 0.0f; |
static float ARG_QUANTI = 0.0f; |
130 |
static int ARG_QUALITY = 5; |
static int ARG_QUALITY = 3; |
131 |
static float ARG_FRAMERATE = 25.00f; |
static float ARG_FRAMERATE = 25.00f; |
132 |
static int ARG_MAXFRAMENR = ABS_MAXFRAMENR; |
static int ARG_MAXFRAMENR = ABS_MAXFRAMENR; |
133 |
static char *ARG_INPUTFILE = NULL; |
static char *ARG_INPUTFILE = NULL; |
205 |
|
|
206 |
double enctime; |
double enctime; |
207 |
double totalenctime = 0.; |
double totalenctime = 0.; |
208 |
|
float totalPSNR[3] = {0., 0., 0.}; |
209 |
|
|
210 |
int totalsize; |
int totalsize; |
211 |
int result; |
int result; |
227 |
printf("xvid_encraw - raw mpeg4 bitstream encoder "); |
printf("xvid_encraw - raw mpeg4 bitstream encoder "); |
228 |
printf("written by Christoph Lampert 2002-2003\n\n"); |
printf("written by Christoph Lampert 2002-2003\n\n"); |
229 |
|
|
230 |
|
/* Is there a dumb XviD coder ? */ |
231 |
|
if(ME_ELEMENTS != VOP_ELEMENTS) { |
232 |
|
fprintf(stderr, "Presets' arrays should have the same number of elements -- Please fill a bug to xvid-devel@xvid.org\n"); |
233 |
|
return(-1); |
234 |
|
} |
235 |
|
|
236 |
/***************************************************************************** |
/***************************************************************************** |
237 |
* Command line parsing |
* Command line parsing |
238 |
****************************************************************************/ |
****************************************************************************/ |
320 |
ARG_INPUTTYPE = 1; /* pgm */ |
ARG_INPUTTYPE = 1; /* pgm */ |
321 |
} |
} |
322 |
|
|
323 |
if (ARG_QUALITY < 0 || ARG_QUALITY > 5) { |
if (ARG_QUALITY < 0 ) { |
324 |
fprintf(stderr, "Wrong Quality\n"); |
ARG_QUALITY = 0; |
325 |
return (-1); |
} else if (ARG_QUALITY >= ME_ELEMENTS) { |
326 |
|
ARG_QUALITY = ME_ELEMENTS - 1; |
327 |
} |
} |
328 |
|
|
329 |
if (ARG_FRAMERATE <= 0) { |
if (ARG_FRAMERATE <= 0) { |
466 |
SSE2PSNR(sse[0], XDIM, YDIM), SSE2PSNR(sse[1], XDIM / 2, |
SSE2PSNR(sse[0], XDIM, YDIM), SSE2PSNR(sse[1], XDIM / 2, |
467 |
YDIM / 2), |
YDIM / 2), |
468 |
SSE2PSNR(sse[2], XDIM / 2, YDIM / 2)); |
SSE2PSNR(sse[2], XDIM / 2, YDIM / 2)); |
469 |
|
|
470 |
|
totalPSNR[0] += SSE2PSNR(sse[0], XDIM, YDIM); |
471 |
|
totalPSNR[1] += SSE2PSNR(sse[1], XDIM/2, YDIM/2); |
472 |
|
totalPSNR[2] += SSE2PSNR(sse[2], XDIM/2, YDIM/2); |
473 |
} |
} |
474 |
|
|
475 |
} |
} |
526 |
if (input_num > 0) { |
if (input_num > 0) { |
527 |
totalsize /= input_num; |
totalsize /= input_num; |
528 |
totalenctime /= input_num; |
totalenctime /= input_num; |
529 |
|
totalPSNR[0] /= input_num; |
530 |
|
totalPSNR[1] /= input_num; |
531 |
|
totalPSNR[2] /= input_num; |
532 |
} else { |
} else { |
533 |
totalsize = -1; |
totalsize = -1; |
534 |
totalenctime = -1; |
totalenctime = -1; |
535 |
} |
} |
536 |
|
|
537 |
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", |
538 |
totalenctime, 1000 / totalenctime, (int) totalsize); |
totalenctime, 1000 / totalenctime, (int) totalsize); |
539 |
|
if (ARG_STATS) { |
540 |
|
printf(", psnr y = %2.2f, psnr u = %2.2f, psnr v = %2.2f", |
541 |
|
totalPSNR[0],totalPSNR[1],totalPSNR[2]); |
542 |
|
} |
543 |
|
printf("\n"); |
544 |
|
|
545 |
|
|
546 |
/***************************************************************************** |
/***************************************************************************** |
630 |
fprintf(stderr, "\n"); |
fprintf(stderr, "\n"); |
631 |
fprintf(stderr, "Other options\n"); |
fprintf(stderr, "Other options\n"); |
632 |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
633 |
fprintf(stderr, " -quality integer: quality ([0..5])\n"); |
fprintf(stderr, " -quality integer: quality ([0..%d])\n", ME_ELEMENTS - 1); |
634 |
fprintf(stderr, " -packed : packed mode\n"); |
fprintf(stderr, " -packed : packed mode\n"); |
635 |
fprintf(stderr, " -lumimasking : use lumimasking algorithm\n"); |
fprintf(stderr, " -lumimasking : use lumimasking algorithm\n"); |
636 |
fprintf(stderr, " -stats : print stats about encoded frames\n"); |
fprintf(stderr, " -stats : print stats about encoded frames\n"); |
966 |
} |
} |
967 |
|
|
968 |
/* Set up core's general features */ |
/* Set up core's general features */ |
969 |
xvid_enc_frame.vol_flags = vol_presets[ARG_QUALITY]; |
xvid_enc_frame.vol_flags = 0; |
970 |
if (ARG_STATS) |
if (ARG_STATS) |
971 |
xvid_enc_frame.vol_flags |= XVID_VOL_EXTRASTATS; |
xvid_enc_frame.vol_flags |= XVID_VOL_EXTRASTATS; |
972 |
|
|