[svn] / branches / dev-api-4 / xvidcore / examples / xvid_encraw.c Repository:
ViewVC logotype

Diff of /branches/dev-api-4/xvidcore/examples/xvid_encraw.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1031, Sat May 17 13:26:51 2003 UTC revision 1119, Sat Aug 9 17:19:20 2003 UTC
# Line 3  Line 3 
3   *  XVID MPEG-4 VIDEO CODEC   *  XVID MPEG-4 VIDEO CODEC
4   *  - Console based test application  -   *  - Console based test application  -
5   *   *
6   *  Copyright(C) 2002-2003 Christoph Lampert   *  Copyright(C) 2002-2003 Christoph Lampert <gruel@web.de>
7     *               2002-2003 Edouard Gomez <ed.gomez@free.fr>
8     *               2003      Peter Ross <pross@xvid.org>
9   *   *
10   *  This program is free software; you can redistribute it and/or modify   *  This program is free software; you can redistribute it and/or modify
11   *  it under the terms of the GNU General Public License as published by   *  it under the terms of the GNU General Public License as published by
# Line 19  Line 21 
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.25 2003-05-17 13:21:26 suxen_drol Exp $   * $Id: xvid_encraw.c,v 1.11.2.34 2003-08-09 17:19:20 edgomez Exp $
25   *   *
26   ****************************************************************************/   ****************************************************************************/
27    
# Line 32  Line 34 
34   *  The program is plain C and needs no libraries except for libxvidcore,   *  The program is plain C and needs no libraries except for libxvidcore,
35   *  and maths-lib.   *  and maths-lib.
36   *   *
37     *  Use ./xvid_encraw -help for a list of options
38     *
39   ************************************************************************/   ************************************************************************/
40    
41  #include <stdio.h>  #include <stdio.h>
# Line 46  Line 50 
50    
51  #include "xvid.h"  #include "xvid.h"
52    
53    #undef READ_PNM
54    
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    
# Line 67  Line 73 
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    
# Line 144  Line 150 
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
157  #define IMAGE_SIZE(x,y) ((x)*(y)*3/2)  #define IMAGE_SIZE(x,y) ((x)*(y)*3/2)
158    #else
159    #define IMAGE_SIZE(x,y) ((x)*(y)*3)
160    #endif
161    
162  #define MAX(A,B) ( ((A)>(B)) ? (A) : (B) )  #define MAX(A,B) ( ((A)>(B)) ? (A) : (B) )
163  #define SMALL_EPS (1e-10)  #define SMALL_EPS (1e-10)
# Line 176  Line 188 
188  static double msecond();  static double msecond();
189    
190  /* PGM related functions */  /* PGM related functions */
191    #ifndef READ_PNM
192  static int read_pgmheader(FILE * handle);  static int read_pgmheader(FILE * handle);
193  static int read_pgmdata(FILE * handle,  static int read_pgmdata(FILE * handle,
194                                                  unsigned char *image);                                                  unsigned char *image);
195    #else
196    static int read_pnmheader(FILE * handle);
197    static int read_pnmdata(FILE * handle,
198                                                    unsigned char *image);
199    #endif
200  static int read_yuvdata(FILE * handle,  static int read_yuvdata(FILE * handle,
201                                                  unsigned char *image);                                                  unsigned char *image);
202    
# Line 321  Line 339 
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);
# Line 370  Line 391 
391          }          }
392    
393          if (ARG_INPUTTYPE) {          if (ARG_INPUTTYPE) {
394    #ifndef READ_PNM
395                  if (read_pgmheader(in_file)) {                  if (read_pgmheader(in_file)) {
396    #else
397                    if (read_pnmheader(in_file)) {
398    #endif
399                          fprintf(stderr,                          fprintf(stderr,
400                                          "Wrong input format, I want YUV encapsulated in PGM\n");                                          "Wrong input format, I want YUV encapsulated in PGM\n");
401                          return (-1);                          return (-1);
# Line 436  Line 461 
461                  if (!result) {                  if (!result) {
462                          if (ARG_INPUTTYPE) {                          if (ARG_INPUTTYPE) {
463                                  /* read PGM data (YUV-format) */                                  /* read PGM data (YUV-format) */
464    #ifndef READ_PNM
465                                  result = read_pgmdata(in_file, in_buffer);                                  result = read_pgmdata(in_file, in_buffer);
466    #else
467                                    result = read_pnmdata(in_file, in_buffer);
468    #endif
469                          } else {                          } else {
470                                  /* read raw data (YUV-format) */                                  /* read raw data (YUV-format) */
471                                  result = read_yuvdata(in_file, in_buffer);                                  result = read_yuvdata(in_file, in_buffer);
# Line 532  Line 561 
561    
562                  /* Read the header if it's pgm stream */                  /* Read the header if it's pgm stream */
563                  if (!result && ARG_INPUTTYPE)                  if (!result && ARG_INPUTTYPE)
564    #ifndef READ_PNM
565                          result = read_pgmheader(in_file);                          result = read_pgmheader(in_file);
566    #else
567                            result = read_pnmheader(in_file);
568    #endif
569          } while (1);          } while (1);
570    
571    
# Line 656  Line 688 
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");
696          fprintf(stderr, " -debug          : print all MB dquants\n");          fprintf(stderr, " -debug          : activates xvidcore internal debugging output\n");
697            fprintf(stderr, " -vop_debug      : print some info directly into encoded frames\n");
698          fprintf(stderr, " -help           : prints this help message\n");          fprintf(stderr, " -help           : prints this help message\n");
699          fprintf(stderr, "\n");          fprintf(stderr, "\n");
700          fprintf(stderr, "NB: You can define %d zones repeating the -z[qw] option as many times as needed.\n", MAX_ZONES);          fprintf(stderr, "NB: You can define %d zones repeating the -z[qw] option as many times as needed.\n", MAX_ZONES);
# Line 674  Line 709 
709   *   *
710   *****************************************************************************/   *****************************************************************************/
711    
712    #ifndef READ_PNM
713  static int  static int
714  read_pgmheader(FILE * handle)  read_pgmheader(FILE * handle)
715  {  {
# Line 729  Line 765 
765    
766          return (0);          return (0);
767  }  }
768    #else
769    static int
770    read_pnmheader(FILE * handle)
771    {
772            int bytes, xsize, ysize, depth;
773            char dummy[2];
774    
775            bytes = fread(dummy, 1, 2, handle);
776    
777            if ((bytes < 2) || (dummy[0] != 'P') || (dummy[1] != '6'))
778                    return (1);
779    
780            fscanf(handle, "%d %d %d", &xsize, &ysize, &depth);
781            if ((xsize > 1440) || (ysize > 2880) || (depth != 255)) {
782                    fprintf(stderr, "%d %d %d\n", xsize, ysize, depth);
783                    return (2);
784            }
785    
786            XDIM = xsize;
787            YDIM = ysize;
788    
789            return (0);
790    }
791    
792    static int
793    read_pnmdata(FILE * handle,
794                             unsigned char *image)
795    {
796            int i;
797            char dummy;
798    
799            /* read Y component of picture */
800            fread(image, 1, XDIM * YDIM * 3, handle);
801    
802            /*  I don't know why, but this seems needed */
803            fread(&dummy, 1, 1, handle);
804    
805            return (0);
806    }
807    #endif
808    
809  static int  static int
810  read_yuvdata(FILE * handle,  read_yuvdata(FILE * handle,
# Line 813  Line 889 
889          /* Set version -- version checking will done by xvidcore */          /* Set version -- version checking will done by xvidcore */
890          memset(&xvid_gbl_init, 0, sizeof(xvid_gbl_init));          memset(&xvid_gbl_init, 0, sizeof(xvid_gbl_init));
891          xvid_gbl_init.version = XVID_VERSION;          xvid_gbl_init.version = XVID_VERSION;
     printf("0x%x\n", ARG_DEBUG);  
892      xvid_gbl_init.debug = ARG_DEBUG;      xvid_gbl_init.debug = ARG_DEBUG;
893    
894    
# Line 821  Line 896 
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
# Line 894  Line 969 
969                  xvid_enc_create.num_plugins++;                  xvid_enc_create.num_plugins++;
970          }          }
971    
972          /* if (ARG_DEBUG) {  #if 0
973            if (ARG_DEBUG) {
974                  plugins[xvid_enc_create.num_plugins].func = rawenc_debug;                  plugins[xvid_enc_create.num_plugins].func = rawenc_debug;
975                  plugins[xvid_enc_create.num_plugins].param = NULL;                  plugins[xvid_enc_create.num_plugins].param = NULL;
976                  xvid_enc_create.num_plugins++;                  xvid_enc_create.num_plugins++;
977          }*/          }
978    #endif
979    
980          /* No fancy thread tests */          /* No fancy thread tests */
981          xvid_enc_create.num_threads = 0;          xvid_enc_create.num_threads = 0;
# Line 913  Line 990 
990          }          }
991    
992          /* Maximum key frame interval */          /* Maximum key frame interval */
   
993      if (ARG_MAXKEYINTERVAL > 0) {      if (ARG_MAXKEYINTERVAL > 0) {
994          xvid_enc_create.max_key_interval = ARG_MAXKEYINTERVAL;          xvid_enc_create.max_key_interval = ARG_MAXKEYINTERVAL;
995      }else {      }else {
# Line 985  Line 1061 
1061          /* Initialize input image fields */          /* Initialize input image fields */
1062          if (image) {          if (image) {
1063                  xvid_enc_frame.input.plane[0] = image;                  xvid_enc_frame.input.plane[0] = image;
1064    #ifndef READ_PNM
1065                  xvid_enc_frame.input.csp = XVID_CSP_I420;                  xvid_enc_frame.input.csp = XVID_CSP_I420;
1066                  xvid_enc_frame.input.stride[0] = XDIM;                  xvid_enc_frame.input.stride[0] = XDIM;
1067    #else
1068                    xvid_enc_frame.input.csp = XVID_CSP_BGR;
1069                    xvid_enc_frame.input.stride[0] = XDIM*3;
1070    #endif
1071          } else {          } else {
1072                  xvid_enc_frame.input.csp = XVID_CSP_NULL;                  xvid_enc_frame.input.csp = XVID_CSP_NULL;
1073          }          }
# Line 995  Line 1076 
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_QPEL && (xvid_enc_frame.vop_flags & XVID_ME_HALFPELREFINE16))
1087                    xvid_enc_frame.vop_flags |= XVID_ME_QUARTERPELREFINE16;
1088            if (ARG_QPEL && (xvid_enc_frame.vop_flags & XVID_ME_HALFPELREFINE8))
1089                    xvid_enc_frame.vop_flags |= XVID_ME_QUARTERPELREFINE8;
1090            if (ARG_GMC)
1091                    xvid_enc_frame.vop_flags |= XVID_ME_GME_REFINE;
1092    
1093      if (ARG_VOPDEBUG) {      if (ARG_VOPDEBUG) {
1094          xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG;          xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG;
1095      }      }
# Line 1016  Line 1108 
1108          xvid_enc_frame.quant_inter_matrix = NULL;          xvid_enc_frame.quant_inter_matrix = NULL;
1109    
1110          /* Encode the frame */          /* Encode the frame */
1111          ret =          ret = xvid_encore(enc_handle, XVID_ENC_ENCODE, &xvid_enc_frame,
                 xvid_encore(enc_handle, XVID_ENC_ENCODE, &xvid_enc_frame,  
1112                                          &xvid_enc_stats);                                          &xvid_enc_stats);
1113    
1114          *key = (xvid_enc_frame.out_flags & XVID_KEYFRAME);          *key = (xvid_enc_frame.out_flags & XVID_KEYFRAME);

Legend:
Removed from v.1031  
changed lines
  Added in v.1119

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4