21 |
* along with this program; if not, write to the Free Software |
* along with this program; if not, write to the Free Software |
22 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
23 |
* |
* |
24 |
* $Id: xvid_encraw.c,v 1.11.2.33 2003-08-09 16:46:46 Isibaar Exp $ |
* $Id: xvid_encraw.c,v 1.11.2.36 2003-10-27 00:48:29 edgomez Exp $ |
25 |
* |
* |
26 |
****************************************************************************/ |
****************************************************************************/ |
27 |
|
|
130 |
static int ARG_STATS = 0; |
static int ARG_STATS = 0; |
131 |
static int ARG_DUMP = 0; |
static int ARG_DUMP = 0; |
132 |
static int ARG_LUMIMASKING = 0; |
static int ARG_LUMIMASKING = 0; |
|
static int ARG_QUARTERPEL = 0; |
|
133 |
static int ARG_BITRATE = 0; |
static int ARG_BITRATE = 0; |
134 |
static int ARG_SINGLE = 0; |
static int ARG_SINGLE = 0; |
135 |
static char *ARG_PASS1 = 0; |
static char *ARG_PASS1 = 0; |
150 |
static int ARG_PACKED = 0; |
static int ARG_PACKED = 0; |
151 |
static int ARG_DEBUG = 0; |
static int ARG_DEBUG = 0; |
152 |
static int ARG_VOPDEBUG = 0; |
static int ARG_VOPDEBUG = 0; |
153 |
|
static int ARG_GMC = 0; |
154 |
|
static int ARG_QPEL = 0; |
155 |
|
static int ARG_CLOSED_GOP = 0; |
156 |
|
|
157 |
#ifndef READ_PNM |
#ifndef READ_PNM |
158 |
#define IMAGE_SIZE(x,y) ((x)*(y)*3/2) |
#define IMAGE_SIZE(x,y) ((x)*(y)*3/2) |
324 |
ARG_DUMP = 1; |
ARG_DUMP = 1; |
325 |
} else if (strcmp("-lumimasking", argv[i]) == 0) { |
} else if (strcmp("-lumimasking", argv[i]) == 0) { |
326 |
ARG_LUMIMASKING = 1; |
ARG_LUMIMASKING = 1; |
|
} else if (strcmp("-quarterpel", argv[i]) == 0) { |
|
|
ARG_QUARTERPEL = 1; |
|
327 |
} else if (strcmp("-type", argv[i]) == 0 && i < argc - 1) { |
} else if (strcmp("-type", argv[i]) == 0 && i < argc - 1) { |
328 |
i++; |
i++; |
329 |
ARG_INPUTTYPE = atoi(argv[i]); |
ARG_INPUTTYPE = atoi(argv[i]); |
340 |
ARG_OUTPUTFILE = argv[i]; |
ARG_OUTPUTFILE = argv[i]; |
341 |
} else if (strcmp("-vop_debug", argv[i]) == 0) { |
} else if (strcmp("-vop_debug", argv[i]) == 0) { |
342 |
ARG_VOPDEBUG = 1; |
ARG_VOPDEBUG = 1; |
343 |
|
} else if (strcmp("-qpel", argv[i]) == 0) { |
344 |
|
ARG_QPEL = 1; |
345 |
|
} else if (strcmp("-gmc", argv[i]) == 0) { |
346 |
|
ARG_GMC = 1; |
347 |
|
} else if (strcmp("-closed_gop", argv[i]) == 0) { |
348 |
|
ARG_CLOSED_GOP = 1; |
349 |
} else if (strcmp("-help", argv[i])) { |
} else if (strcmp("-help", argv[i])) { |
350 |
usage(); |
usage(); |
351 |
return (0); |
return (0); |
691 |
fprintf(stderr, "Other options\n"); |
fprintf(stderr, "Other options\n"); |
692 |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
693 |
fprintf(stderr, " -quality integer: quality ([0..%d])\n", ME_ELEMENTS - 1); |
fprintf(stderr, " -quality integer: quality ([0..%d])\n", ME_ELEMENTS - 1); |
694 |
fprintf(stderr, " -quarterpel : use quarterpel refinement\n"); |
fprintf(stderr, " -qpel : use quarter pixel ME\n"); |
695 |
|
fprintf(stderr, " -gmc : use global motion compensation\n"); |
696 |
fprintf(stderr, " -packed : packed mode\n"); |
fprintf(stderr, " -packed : packed mode\n"); |
697 |
|
fprintf(stderr, " -closed_gop : closed GOP mode\n"); |
698 |
fprintf(stderr, " -lumimasking : use lumimasking algorithm\n"); |
fprintf(stderr, " -lumimasking : use lumimasking algorithm\n"); |
699 |
fprintf(stderr, " -stats : print stats about encoded frames\n"); |
fprintf(stderr, " -stats : print stats about encoded frames\n"); |
700 |
fprintf(stderr, " -debug : activates xvidcore internal debugging output\n"); |
fprintf(stderr, " -debug : activates xvidcore internal debugging output\n"); |
1014 |
if (ARG_PACKED) |
if (ARG_PACKED) |
1015 |
xvid_enc_create.global |=XVID_GLOBAL_PACKED; |
xvid_enc_create.global |=XVID_GLOBAL_PACKED; |
1016 |
|
|
1017 |
|
if (ARG_CLOSED_GOP) |
1018 |
|
xvid_enc_create.global |= XVID_GLOBAL_CLOSED_GOP; |
1019 |
|
|
1020 |
if (ARG_STATS) |
if (ARG_STATS) |
1021 |
xvid_enc_create.global |=XVID_GLOBAL_EXTRASTATS_ENABLE; |
xvid_enc_create.global |=XVID_GLOBAL_EXTRASTATS_ENABLE; |
1022 |
|
|
1080 |
} |
} |
1081 |
|
|
1082 |
/* Set up core's general features */ |
/* Set up core's general features */ |
1083 |
xvid_enc_frame.vol_flags = XVID_VOL_GMC; |
xvid_enc_frame.vol_flags = 0; |
1084 |
if (ARG_STATS) |
if (ARG_STATS) |
1085 |
xvid_enc_frame.vol_flags |= XVID_VOL_EXTRASTATS; |
xvid_enc_frame.vol_flags |= XVID_VOL_EXTRASTATS; |
1086 |
|
if (ARG_QPEL) |
|
if (ARG_QUARTERPEL) |
|
1087 |
xvid_enc_frame.vol_flags |= XVID_VOL_QUARTERPEL; |
xvid_enc_frame.vol_flags |= XVID_VOL_QUARTERPEL; |
1088 |
|
if (ARG_GMC) |
1089 |
|
xvid_enc_frame.vol_flags |= XVID_VOL_GMC; |
1090 |
|
|
1091 |
/* Set up core's general features */ |
/* Set up core's general features */ |
1092 |
xvid_enc_frame.vop_flags = vop_presets[ARG_QUALITY]; |
xvid_enc_frame.vop_flags = vop_presets[ARG_QUALITY]; |
1093 |
|
if (ARG_GMC) |
1094 |
|
xvid_enc_frame.vop_flags |= XVID_ME_GME_REFINE; |
1095 |
|
|
1096 |
if (ARG_VOPDEBUG) { |
if (ARG_VOPDEBUG) { |
1097 |
xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG; |
xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG; |
1098 |
} |
} |
1106 |
/* Set up motion estimation flags */ |
/* Set up motion estimation flags */ |
1107 |
xvid_enc_frame.motion = motion_presets[ARG_QUALITY]; |
xvid_enc_frame.motion = motion_presets[ARG_QUALITY]; |
1108 |
|
|
1109 |
if (ARG_QUARTERPEL) |
if (ARG_QPEL) |
1110 |
xvid_enc_frame.motion |= (XVID_ME_QUARTERPELREFINE16 | XVID_ME_QUARTERPELREFINE8); |
xvid_enc_frame.motion |= XVID_ME_QUARTERPELREFINE16; |
1111 |
|
if (ARG_QPEL && (xvid_enc_frame.vop_flags & XVID_VOP_INTER4V)) |
1112 |
|
xvid_enc_frame.motion |= XVID_ME_QUARTERPELREFINE8; |
1113 |
|
|
1114 |
/* We don't use special matrices */ |
/* We don't use special matrices */ |
1115 |
xvid_enc_frame.quant_intra_matrix = NULL; |
xvid_enc_frame.quant_intra_matrix = NULL; |
1116 |
xvid_enc_frame.quant_inter_matrix = NULL; |
xvid_enc_frame.quant_inter_matrix = NULL; |
1117 |
|
|
1118 |
/* Encode the frame */ |
/* Encode the frame */ |
1119 |
ret = |
ret = xvid_encore(enc_handle, XVID_ENC_ENCODE, &xvid_enc_frame, |
|
xvid_encore(enc_handle, XVID_ENC_ENCODE, &xvid_enc_frame, |
|
1120 |
&xvid_enc_stats); |
&xvid_enc_stats); |
1121 |
|
|
1122 |
*key = (xvid_enc_frame.out_flags & XVID_KEYFRAME); |
*key = (xvid_enc_frame.out_flags & XVID_KEYFRAME); |