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.h,v 1.27.2.6 2003-03-15 14:32:56 suxen_drol Exp $ |
* $Id: xvid.h,v 1.27.2.13 2003-03-26 14:56:10 edgomez Exp $ |
23 |
* |
* |
24 |
****************************************************************************/ |
****************************************************************************/ |
25 |
|
|
239 |
int time_increment; /* [out] time increment */ |
int time_increment; /* [out] time increment */ |
240 |
|
|
241 |
/* XXX: external deblocking stuff */ |
/* XXX: external deblocking stuff */ |
242 |
unsigned char * qscale; /* [out] pointer to quantizer table */ |
int * qscale; /* [out] pointer to quantizer table */ |
243 |
int qscale_stride; /* [out] quantizer scale stride */ |
int qscale_stride; /* [out] quantizer scale stride */ |
244 |
|
|
245 |
} vop; |
} vop; |
272 |
|
|
273 |
/* xvid_plg_info_t.flags */ |
/* xvid_plg_info_t.flags */ |
274 |
#define XVID_REQORIGINAL 1 /* plugin requires a copy of the original (uncompressed) image */ |
#define XVID_REQORIGINAL 1 /* plugin requires a copy of the original (uncompressed) image */ |
275 |
|
#define XVID_REQPSNR 2 /* plugin requires psnr between the uncompressed and compressed image*/ |
276 |
|
#define XVID_REQDQUANTS 3 /* plugin requires access to the dquant table */ |
277 |
|
|
278 |
|
|
279 |
typedef struct |
typedef struct |
287 |
{ |
{ |
288 |
int version; |
int version; |
289 |
|
|
290 |
int width, height; |
int width; |
291 |
int fincr, fbase; |
int height; |
292 |
|
int mb_width; |
293 |
|
int mb_height; |
294 |
|
int fincr; |
295 |
|
int fbase; |
296 |
|
|
297 |
void * param; |
void * param; |
298 |
} xvid_plg_create_t; |
} xvid_plg_create_t; |
302 |
{ |
{ |
303 |
int version; |
int version; |
304 |
|
|
305 |
|
int num_frames; /* [out] totlal frame encoded */ |
306 |
|
} xvid_plg_destroy_t; |
307 |
|
|
308 |
|
|
309 |
|
typedef struct |
310 |
|
{ |
311 |
|
int version; |
312 |
|
|
313 |
int width; /* [out] */ |
int width; /* [out] */ |
314 |
int height; /* [out] */ |
int height; /* [out] */ |
315 |
|
int mb_width; /* [out] */ |
316 |
|
int mb_height; /* [out] */ |
317 |
int fincr; /* [out] */ |
int fincr; /* [out] */ |
318 |
int fbase; /* [out] */ |
int fbase; /* [out] */ |
319 |
|
|
325 |
int type; /* [in,out] */ |
int type; /* [in,out] */ |
326 |
int quant; /* [in,out] */ |
int quant; /* [in,out] */ |
327 |
|
|
328 |
unsigned char * qscale; /* [in,out] pointer to quantizer table */ |
int * dquant; /* [in,out] pointer to diff quantizer table */ |
329 |
int qscale_stride; /* [in,out] quantizer scale stride */ |
int dquant_stride; /* [in,out] diff quantizer stride */ |
330 |
|
|
331 |
int vop_flags; /* [in,out] */ |
int vop_flags; /* [in,out] */ |
332 |
int vol_flags; /* [in,out] */ |
int vol_flags; /* [in,out] */ |
334 |
|
|
335 |
int length; /* [out] after: length of encoded frame */ |
int length; /* [out] after: length of encoded frame */ |
336 |
int kblks, mblks, ublks; /* [out] after: */ |
int kblks, mblks, ublks; /* [out] after: */ |
337 |
|
int sse_y, sse_u, sse_v; /* [out] */ |
338 |
} xvid_plg_data_t; |
} xvid_plg_data_t; |
339 |
|
|
340 |
|
|
366 |
void * param; |
void * param; |
367 |
} xvid_enc_plugin_t; |
} xvid_enc_plugin_t; |
368 |
|
|
369 |
xvid_plugin_func xvid_plugin_psnr; /* stdout psnr calculator */ |
|
370 |
|
|
371 |
|
xvid_plugin_func xvid_plugin_fixed; /* fixed quantizer control */ |
372 |
|
xvid_plugin_func xvid_plugin_cbr; /* constant bitrate control */ |
373 |
|
xvid_plugin_func xvid_plugin_2pass1; /* 2pass rate control: first pass */ |
374 |
|
xvid_plugin_func xvid_plugin_2pass2; /* 2pass rate control: second pass */ |
375 |
|
|
376 |
|
xvid_plugin_func xvid_plugin_lumimasking; /* lumimasking */ |
377 |
|
|
378 |
|
xvid_plugin_func xvid_plugin_psnr; /* write psnr values to stdout */ |
379 |
xvid_plugin_func xvid_plugin_dump; /* dump before and after yuvpgms */ |
xvid_plugin_func xvid_plugin_dump; /* dump before and after yuvpgms */ |
380 |
|
|
381 |
|
|
382 |
|
typedef struct |
383 |
|
{ |
384 |
|
int version; |
385 |
|
int quant_increment; |
386 |
|
int quant_base; |
387 |
|
} xvid_plugin_fixed_t; |
388 |
|
|
389 |
|
|
390 |
|
typedef struct |
391 |
|
{ |
392 |
|
int version; |
393 |
|
int bitrate; |
394 |
|
int max_quantizer; |
395 |
|
int min_quantizer; |
396 |
|
int reaction_delay_factor; |
397 |
|
int averaging_period; |
398 |
|
int buffer; |
399 |
|
} xvid_plugin_cbr_t; |
400 |
|
|
401 |
|
|
402 |
|
typedef struct { |
403 |
|
int version; |
404 |
|
char * filename; |
405 |
|
} xvid_plugin_2pass1_t; |
406 |
|
|
407 |
|
|
408 |
|
#define XVID_CURVE_COSINE 0 /* low aggressiveness */ |
409 |
|
#define XVID_CURVE_LINEAR 1 /* medium aggressiveness */ |
410 |
|
#define XVID_CURVE_SINE 2 /* high aggressiveness */ |
411 |
|
|
412 |
|
#define XVID_PAYBACK_BIAS 0 /* payback with bias */ |
413 |
|
#define XVID_PAYBACK_PROP 1 /* payback proportionally */ |
414 |
|
|
415 |
|
typedef struct { |
416 |
|
int version; |
417 |
|
char * filename1; |
418 |
|
char * filename2; |
419 |
|
|
420 |
|
int keyframe_boost; /* keyframe boost percentage: [0..100...]; */ |
421 |
|
int payback_method; |
422 |
|
int bitrate_payback_delay; |
423 |
|
int curve_compression_high; |
424 |
|
int curve_compression_low; |
425 |
|
int max_overflow_improvement; |
426 |
|
int max_overflow_degradation; |
427 |
|
int min_quant[3]; |
428 |
|
int max_quant[3]; |
429 |
|
|
430 |
|
int use_alt_curve; |
431 |
|
int alt_curve_high_dist; |
432 |
|
int alt_curve_low_dist; |
433 |
|
int alt_curve_use_auto; |
434 |
|
int alt_curve_auto_str; |
435 |
|
int alt_curve_type; /* XVID_CURVE_ */ |
436 |
|
int alt_curve_min_rel_qual; |
437 |
|
int alt_curve_use_auto_bonus_bias; |
438 |
|
int alt_curve_bonus_bias; |
439 |
|
|
440 |
|
int kftreshold; |
441 |
|
int kfreduction; |
442 |
|
int min_key_interval; |
443 |
|
}xvid_plugin_2pass2_t; |
444 |
|
|
445 |
|
|
446 |
/***************************************************************************** |
/***************************************************************************** |
447 |
* xvid_encore() |
* xvid_encore() |
459 |
/* global flags */ |
/* global flags */ |
460 |
typedef enum |
typedef enum |
461 |
{ |
{ |
462 |
XVID_PACKED = 0x00000001, /* packed bitstream */ |
XVID_GLOBAL_PACKED = 0x00000001, /* packed bitstream */ |
463 |
XVID_CLOSED_GOP = 0x00000002, /* closed_gop: was DX50BVOP dx50 bvop compatibility */ |
XVID_GLOBAL_CLOSED_GOP = 0x00000002, /* closed_gop: was DX50BVOP dx50 bvop compatibility */ |
464 |
/*define XVID_VOL_AT_IVOP 0x00000008 write vol at every ivop: WIN32/divx compatibility */ |
XVID_GLOBAL_EXTRASTATS_ENABLE = 0x00000004 |
465 |
/*define XVID_FORCE_VOL 0x00000008 XXX: when vol-based parameters are changed, insert an ivop NOT recommended */ |
/*define XVID_GLOBAL_VOL_AT_IVOP 0x00000008 write vol at every ivop: WIN32/divx compatibility */ |
466 |
|
/*define XVID_GLOBAL_FORCE_VOL 0x00000008 XXX: when vol-based parameters are changed, insert an ivop NOT recommended */ |
467 |
} xvid_global_t; |
} xvid_global_t; |
468 |
|
|
469 |
|
|
470 |
/* XVID_ENC_ENCODE param1 */ |
/* XVID_ENC_ENCODE param1 */ |
471 |
/* vol-based flags */ |
/* vol-based flags */ |
472 |
typedef enum { |
typedef enum { |
473 |
XVID_MPEGQUANT = 0x00000001, |
XVID_VOL_MPEGQUANT = 0x00000001, |
474 |
XVID_QUARTERPEL = 0x00000004, /* enable quarterpel: frames will encoded as quarterpel */ |
XVID_VOL_EXTRASTATS = 0x00000002, |
475 |
XVID_GMC = 0x00000008, /* enable GMC; frames will be checked for gmc suitability */ |
XVID_VOL_QUARTERPEL = 0x00000004, /* enable quarterpel: frames will encoded as quarterpel */ |
476 |
XVID_REDUCED_ENABLE = 0x00000010, /* enable reduced resolution vops: frames will be checked for rrv suitability */ |
XVID_VOL_GMC = 0x00000008, /* enable GMC; frames will be checked for gmc suitability */ |
477 |
XVID_INTERLACING = 0x00000400, /* enable interlaced encoding */ |
XVID_VOL_REDUCED_ENABLE = 0x00000010, /* enable reduced resolution vops: frames will be checked for rrv suitability */ |
478 |
|
XVID_VOL_INTERLACING = 0x00000400, /* enable interlaced encoding */ |
479 |
} xvid_vol_t; |
} xvid_vol_t; |
480 |
|
|
481 |
|
|
482 |
/* vop-based flags */ |
/* vop-based flags */ |
483 |
typedef enum { |
typedef enum { |
484 |
XVID_DEBUG = 0x00000001, |
XVID_VOP_DEBUG = 0x00000001, |
485 |
|
|
486 |
XVID_HALFPEL = 0x00000004, /* use halfpel interpolation */ |
XVID_VOP_HALFPEL = 0x00000004, /* use halfpel interpolation */ |
487 |
XVID_INTER4V = 0x00000008, |
XVID_VOP_INTER4V = 0x00000008, |
|
XVID_LUMIMASKING = 0x00000010, |
|
488 |
|
|
489 |
XVID_CHROMAOPT = 0x00000020, /* enable chroma optimization pre-filter */ |
XVID_VOP_CHROMAOPT = 0x00000020, /* enable chroma optimization pre-filter */ |
490 |
XVID_GREYSCALE = 0x00000040, /* enable greyscale only mode (even for |
XVID_VOP_GREYSCALE = 0x00000040, /* enable greyscale only mode (even for |
491 |
color input material chroma is ignored) */ |
color input material chroma is ignored) */ |
492 |
XVID_HQACPRED = 0x00000080, /* 20030209: high quality ac prediction */ |
XVID_VOP_HQACPRED = 0x00000080, /* 20030209: high quality ac prediction */ |
493 |
XVID_MODEDECISION_BITS = 0x00000100, /* enable DCT-ME and use it for mode decision */ |
XVID_VOP_MODEDECISION_BITS = 0x00000100, /* enable DCT-ME and use it for mode decision */ |
494 |
XVID_DYNAMIC_BFRAMES = 0x00000200, |
XVID_VOP_DYNAMIC_BFRAMES = 0x00000200, |
495 |
|
|
496 |
/* only valid for vol_flags|=XVID_INTERLACING */ |
/* only valid for vol_flags|=XVID_VOL_INTERLACING */ |
497 |
XVID_TOPFIELDFIRST = 0x00000400, /* set top-field-first flag */ |
XVID_VOP_TOPFIELDFIRST = 0x00000400, /* set top-field-first flag */ |
498 |
XVID_ALTERNATESCAN = 0x00000800, /* set alternate vertical scan flag */ |
XVID_VOP_ALTERNATESCAN = 0x00000800, /* set alternate vertical scan flag */ |
499 |
|
|
500 |
/* only valid for vol_flags|=XVID_REDUCED_ENABLED */ |
/* only valid for vol_flags|=XVID_VOL_REDUCED_ENABLED */ |
501 |
XVID_REDUCED = 0x00001000, /* reduced resolution vop */ |
XVID_VOP_REDUCED = 0x00001000, /* reduced resolution vop */ |
502 |
} xvid_vop_t; |
} xvid_vop_t; |
503 |
|
|
504 |
|
|
505 |
typedef enum { |
typedef enum { |
506 |
PMV_ADVANCEDDIAMOND16 = 0x00008000, /* use advdiamonds instead of diamonds as search pattern */ |
XVID_ME_ADVANCEDDIAMOND16 = 0x00008000, /* use advdiamonds instead of diamonds as search pattern */ |
507 |
PMV_USESQUARES16 = 0x00800000, /* use squares instead of diamonds as search pattern */ |
XVID_ME_USESQUARES16 = 0x00800000, /* use squares instead of diamonds as search pattern */ |
508 |
|
|
509 |
PMV_HALFPELREFINE16 = 0x00020000, |
XVID_ME_HALFPELREFINE16 = 0x00020000, |
510 |
PMV_HALFPELREFINE8 = 0x02000000, |
XVID_ME_HALFPELREFINE8 = 0x02000000, |
511 |
|
|
512 |
PMV_QUARTERPELREFINE16 = 0x00040000, |
XVID_ME_QUARTERPELREFINE16 = 0x00040000, |
513 |
PMV_QUARTERPELREFINE8 = 0x04000000, |
XVID_ME_QUARTERPELREFINE8 = 0x04000000, |
514 |
|
|
515 |
PMV_EXTSEARCH16 = 0x00080000, /* extend PMV by more searches */ |
XVID_ME_EXTSEARCH16 = 0x00080000, /* extend PMV by more searches */ |
516 |
|
|
517 |
PMV_EXTSEARCH8 = 0x08000000, /* use diamond/square for extended 8x8 search */ |
XVID_ME_EXTSEARCH8 = 0x08000000, /* use diamond/square for extended 8x8 search */ |
518 |
PMV_ADVANCEDDIAMOND8 = 0x00004000, /* use advdiamond for PMV_EXTSEARCH8 */ |
XVID_ME_ADVANCEDDIAMOND8 = 0x00004000, /* use advdiamond for XVID_ME_EXTSEARCH8 */ |
519 |
PMV_USESQUARES8 = 0x80000000, /* use square for PMV_EXTSEARCH8 */ |
XVID_ME_USESQUARES8 = 0x80000000, /* use square for XVID_ME_EXTSEARCH8 */ |
520 |
|
|
521 |
PMV_CHROMA16 = 0x00100000, /* also use chroma for P_VOP/S_VOP ME */ |
XVID_ME_CHROMA16 = 0x00100000, /* also use chroma for P_VOP/S_VOP ME */ |
522 |
PMV_CHROMA8 = 0x10000000, /* also use chroma for B_VOP ME */ |
XVID_ME_CHROMA8 = 0x10000000, /* also use chroma for B_VOP ME */ |
523 |
|
|
524 |
/* Motion search using DCT. use XVID_MODEDECISION_BITS to enable */ |
/* Motion search using DCT. use XVID_VOP_MODEDECISION_BITS to enable */ |
525 |
HALFPELREFINE16_BITS = 0x00000100, /* perform DCT-based halfpel refinement */ |
XVID_ME_HALFPELREFINE16_BITS = 0x00000100, /* perform DCT-based halfpel refinement */ |
526 |
HALFPELREFINE8_BITS = 0x00000200, /* perform DCT-based halfpel refinement for 8x8 mode */ |
XVID_ME_HALFPELREFINE8_BITS = 0x00000200, /* perform DCT-based halfpel refinement for 8x8 mode */ |
527 |
QUARTERPELREFINE16_BITS = 0x00000400, /* perform DCT-based qpel refinement */ |
XVID_ME_QUARTERPELREFINE16_BITS = 0x00000400, /* perform DCT-based qpel refinement */ |
528 |
QUARTERPELREFINE8_BITS = 0x00000800, /* perform DCT-based qpel refinement for 8x8 mode */ |
XVID_ME_QUARTERPELREFINE8_BITS = 0x00000800, /* perform DCT-based qpel refinement for 8x8 mode */ |
529 |
|
|
530 |
EXTSEARCH_BITS = 0x00001000, /* perform DCT-based search using square pattern |
XVID_ME_EXTSEARCH_BITS = 0x00001000, /* perform DCT-based search using square pattern |
531 |
enable PMV_EXTSEARCH8 to do this in 8x8 search as well */ |
enable XVID_ME_EXTSEARCH8 to do this in 8x8 search as well */ |
532 |
CHECKPREDICTION_BITS = 0x00002000, /* always check vector equal to prediction */ |
XVID_ME_CHECKPREDICTION_BITS = 0x00002000, /* always check vector equal to prediction */ |
533 |
|
|
534 |
PMV_UNRESTRICTED16 = 0x00200000, /* unrestricted ME, not implemented */ |
XVID_ME_UNRESTRICTED16 = 0x00200000, /* unrestricted ME, not implemented */ |
535 |
PMV_OVERLAPPING16 = 0x00400000, /* overlapping ME, not implemented */ |
XVID_ME_OVERLAPPING16 = 0x00400000, /* overlapping ME, not implemented */ |
536 |
PMV_UNRESTRICTED8 = 0x20000000, /* unrestricted ME, not implemented */ |
XVID_ME_UNRESTRICTED8 = 0x20000000, /* unrestricted ME, not implemented */ |
537 |
PMV_OVERLAPPING8 = 0x40000000 /* overlapping ME, not implemented */ |
XVID_ME_OVERLAPPING8 = 0x40000000 /* overlapping ME, not implemented */ |
538 |
} xvid_motion_t; |
} xvid_motion_t; |
539 |
|
|
540 |
|
|
575 |
xvid_enc_create_t; |
xvid_enc_create_t; |
576 |
|
|
577 |
|
|
|
typedef struct { |
|
|
int version; |
|
|
int type; /* [in] rate control type: XVID_RC_xxx */ |
|
|
|
|
|
/* common stuff */ |
|
|
int min_iquant; /* [in:opt] ivop quantizer upper/lower limit */ |
|
|
int max_iquant; /* [in:opt] */ |
|
|
int min_pquant; /* [in:opt] psvop quantizer upper/lower limit */ |
|
|
int max_pquant; /* [in:opt] */ |
|
|
int min_bquant; /* [in:opt] bvop quantizer upper/lower limit */ |
|
|
int max_bquant; /* [in:opt] */ |
|
|
|
|
|
union { |
|
|
struct { /* XVID_RC_FQUANT */ |
|
|
float quant; /* [in] quantizer */ |
|
|
} fquant; |
|
|
struct { /* XVID_RC_CBR */ |
|
|
int bitrate; /* [in] the bitrate of the target encoded stream, in bits/second */ |
|
|
int reaction_delay_factor; /* [in] how fast the rate control reacts - lower values are faster */ |
|
|
int averaging_period; /* [in] */ |
|
|
int buffer; /* [in] */ |
|
|
} cbr; |
|
|
} data; |
|
|
} xvid_enc_rc_t; |
|
|
|
|
|
|
|
|
|
|
578 |
#define XVID_KEYFRAME 0x00000001 |
#define XVID_KEYFRAME 0x00000001 |
579 |
|
|
580 |
typedef struct { |
typedef struct { |
593 |
int par_height; /* [in:opt] aspect ratio height */ |
int par_height; /* [in:opt] aspect ratio height */ |
594 |
/* ^^^----------------------------------------------------------------------------------*/ |
/* ^^^----------------------------------------------------------------------------------*/ |
595 |
|
|
596 |
|
int fincr; /* framerate increment, for variable framerate only */ |
597 |
xvid_vop_t vop_flags; /* [in] (general)vop-based flags */ |
xvid_vop_t vop_flags; /* [in] (general)vop-based flags */ |
598 |
xvid_motion_t motion; /* [in] ME options */ |
xvid_motion_t motion; /* [in] ME options */ |
599 |
|
|
601 |
|
|
602 |
int type; /* [in:opt] coding type */ |
int type; /* [in:opt] coding type */ |
603 |
int quant; /* [in] frame quantizer; if <=0, automatatic (ratecontrol) */ |
int quant; /* [in] frame quantizer; if <=0, automatatic (ratecontrol) */ |
|
int bquant; /* [in:opt] bframe quantizer; if <=0, automatic*/ |
|
604 |
|
|
605 |
void *bitstream; /* [in:opt] bitstream ptr (written to)*/ |
void *bitstream; /* [in:opt] bitstream ptr (written to)*/ |
606 |
int length; /* [in:opt] bitstream length (bytes) */ |
int length; /* [in:opt] bitstream length (bytes) */ |