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.28 2003-06-25 23:23:21 edgomez Exp $ |
* $Id: xvid_encraw.c,v 1.11.2.35 2003-08-10 13:10:09 Isibaar Exp $ |
25 |
* |
* |
26 |
****************************************************************************/ |
****************************************************************************/ |
27 |
|
|
55 |
/***************************************************************************** |
/***************************************************************************** |
56 |
* Quality presets |
* Quality presets |
57 |
****************************************************************************/ |
****************************************************************************/ |
58 |
static xvid_motion_t const motion_presets[] = { |
|
59 |
|
static const int motion_presets[] = { |
60 |
/* quality 0 */ |
/* quality 0 */ |
61 |
0, |
0, |
62 |
|
|
73 |
/* quality 4 */ |
/* quality 4 */ |
74 |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
75 |
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | |
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | |
76 |
XVID_ME_CHROMA16 | XVID_ME_CHROMA8, |
XVID_ME_CHROMA_PVOP | XVID_ME_CHROMA_BVOP, |
77 |
|
|
78 |
/* quality 5 */ |
/* quality 5 */ |
79 |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | |
80 |
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | |
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | |
81 |
XVID_ME_CHROMA16 | XVID_ME_CHROMA8, |
XVID_ME_CHROMA_PVOP | XVID_ME_CHROMA_BVOP, |
82 |
|
|
83 |
/* quality 6 */ |
/* quality 6 */ |
84 |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | XVID_ME_EXTSEARCH16 | |
XVID_ME_ADVANCEDDIAMOND16 | XVID_ME_HALFPELREFINE16 | XVID_ME_EXTSEARCH16 | |
85 |
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | XVID_ME_EXTSEARCH8 | |
XVID_ME_ADVANCEDDIAMOND8 | XVID_ME_HALFPELREFINE8 | XVID_ME_EXTSEARCH8 | |
86 |
XVID_ME_CHROMA16 | XVID_ME_CHROMA8 , |
XVID_ME_CHROMA_PVOP | XVID_ME_CHROMA_BVOP, |
87 |
|
|
88 |
}; |
}; |
89 |
#define ME_ELEMENTS (sizeof(motion_presets)/sizeof(motion_presets[0])) |
#define ME_ELEMENTS (sizeof(motion_presets)/sizeof(motion_presets[0])) |
90 |
|
|
91 |
static xvid_vop_t const vop_presets[] = { |
static const int vop_presets[] = { |
92 |
/* quality 0 */ |
/* quality 0 */ |
93 |
0, |
0, |
94 |
|
|
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 |
|
|
156 |
#ifndef READ_PNM |
#ifndef READ_PNM |
157 |
#define IMAGE_SIZE(x,y) ((x)*(y)*3/2) |
#define IMAGE_SIZE(x,y) ((x)*(y)*3/2) |
339 |
ARG_OUTPUTFILE = argv[i]; |
ARG_OUTPUTFILE = argv[i]; |
340 |
} else if (strcmp("-vop_debug", argv[i]) == 0) { |
} else if (strcmp("-vop_debug", argv[i]) == 0) { |
341 |
ARG_VOPDEBUG = 1; |
ARG_VOPDEBUG = 1; |
342 |
|
} else if (strcmp("-qpel", argv[i]) == 0) { |
343 |
|
ARG_QPEL = 1; |
344 |
|
} else if (strcmp("-gmc", argv[i]) == 0) { |
345 |
|
ARG_GMC = 1; |
346 |
} else if (strcmp("-help", argv[i])) { |
} else if (strcmp("-help", argv[i])) { |
347 |
usage(); |
usage(); |
348 |
return (0); |
return (0); |
688 |
fprintf(stderr, "Other options\n"); |
fprintf(stderr, "Other options\n"); |
689 |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
fprintf(stderr, " -asm : use assembly optmized code\n"); |
690 |
fprintf(stderr, " -quality integer: quality ([0..%d])\n", ME_ELEMENTS - 1); |
fprintf(stderr, " -quality integer: quality ([0..%d])\n", ME_ELEMENTS - 1); |
691 |
|
fprintf(stderr, " -qpel : use quarter pixel ME\n"); |
692 |
|
fprintf(stderr, " -gmc : use global motion compensation\n"); |
693 |
fprintf(stderr, " -packed : packed mode\n"); |
fprintf(stderr, " -packed : packed mode\n"); |
694 |
fprintf(stderr, " -lumimasking : use lumimasking algorithm\n"); |
fprintf(stderr, " -lumimasking : use lumimasking algorithm\n"); |
695 |
fprintf(stderr, " -stats : print stats about encoded frames\n"); |
fprintf(stderr, " -stats : print stats about encoded frames\n"); |
896 |
if (use_assembler) { |
if (use_assembler) { |
897 |
|
|
898 |
#ifdef ARCH_IS_IA64 |
#ifdef ARCH_IS_IA64 |
899 |
xvid_gbl_init.cpu_flags = XVID_CPU_FORCE | XVID_CPU_IA64; |
xvid_gbl_init.cpu_flags = XVID_CPU_FORCE | XVID_CPU_ASM; |
900 |
#else |
#else |
901 |
xvid_gbl_init.cpu_flags = 0; |
xvid_gbl_init.cpu_flags = 0; |
902 |
#endif |
#endif |
1076 |
xvid_enc_frame.vol_flags = 0; |
xvid_enc_frame.vol_flags = 0; |
1077 |
if (ARG_STATS) |
if (ARG_STATS) |
1078 |
xvid_enc_frame.vol_flags |= XVID_VOL_EXTRASTATS; |
xvid_enc_frame.vol_flags |= XVID_VOL_EXTRASTATS; |
1079 |
|
if (ARG_QPEL) |
1080 |
|
xvid_enc_frame.vol_flags |= XVID_VOL_QUARTERPEL; |
1081 |
|
if (ARG_GMC) |
1082 |
|
xvid_enc_frame.vol_flags |= XVID_VOL_GMC; |
1083 |
|
|
1084 |
/* Set up core's general features */ |
/* Set up core's general features */ |
1085 |
xvid_enc_frame.vop_flags = vop_presets[ARG_QUALITY]; |
xvid_enc_frame.vop_flags = vop_presets[ARG_QUALITY]; |
1086 |
|
if (ARG_GMC) |
1087 |
|
xvid_enc_frame.vop_flags |= XVID_ME_GME_REFINE; |
1088 |
|
|
1089 |
if (ARG_VOPDEBUG) { |
if (ARG_VOPDEBUG) { |
1090 |
xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG; |
xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG; |
1091 |
} |
} |
1099 |
/* Set up motion estimation flags */ |
/* Set up motion estimation flags */ |
1100 |
xvid_enc_frame.motion = motion_presets[ARG_QUALITY]; |
xvid_enc_frame.motion = motion_presets[ARG_QUALITY]; |
1101 |
|
|
1102 |
|
if (ARG_QPEL) |
1103 |
|
xvid_enc_frame.motion |= XVID_ME_QUARTERPELREFINE16; |
1104 |
|
if (ARG_QPEL && (xvid_enc_frame.vop_flags & XVID_VOP_INTER4V)) |
1105 |
|
xvid_enc_frame.motion |= XVID_ME_QUARTERPELREFINE8; |
1106 |
|
|
1107 |
/* We don't use special matrices */ |
/* We don't use special matrices */ |
1108 |
xvid_enc_frame.quant_intra_matrix = NULL; |
xvid_enc_frame.quant_intra_matrix = NULL; |
1109 |
xvid_enc_frame.quant_inter_matrix = NULL; |
xvid_enc_frame.quant_inter_matrix = NULL; |
1110 |
|
|
1111 |
/* Encode the frame */ |
/* Encode the frame */ |
1112 |
ret = |
ret = xvid_encore(enc_handle, XVID_ENC_ENCODE, &xvid_enc_frame, |
|
xvid_encore(enc_handle, XVID_ENC_ENCODE, &xvid_enc_frame, |
|
1113 |
&xvid_enc_stats); |
&xvid_enc_stats); |
1114 |
|
|
1115 |
*key = (xvid_enc_frame.out_flags & XVID_KEYFRAME); |
*key = (xvid_enc_frame.out_flags & XVID_KEYFRAME); |