[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 1019, Wed May 14 11:53:16 2003 UTC revision 1081, Thu Jul 10 17:41:48 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.22 2003-05-14 11:53:16 suxen_drol Exp $   * $Id: xvid_encraw.c,v 1.11.2.29 2003-07-10 17:39:40 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
# Line 87  Line 92 
92          0,          0,
93    
94          /* quality 1 */          /* quality 1 */
95          XVID_VOP_DYNAMIC_BFRAMES,          0,
96    
97          /* quality 2 */          /* quality 2 */
98          XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL,          XVID_VOP_HALFPEL,
99    
100          /* quality 3 */          /* quality 3 */
101          XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL |          XVID_VOP_HALFPEL | XVID_VOP_INTER4V,
         XVID_VOP_INTER4V,  
102    
103          /* quality 4 */          /* quality 4 */
104          XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL |          XVID_VOP_HALFPEL | XVID_VOP_INTER4V,
         XVID_VOP_INTER4V,  
105    
106          /* quality 5 */          /* quality 5 */
107          XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL |          XVID_VOP_HALFPEL | XVID_VOP_INTER4V |
108          XVID_VOP_INTER4V | XVID_VOP_TRELLISQUANT,          XVID_VOP_TRELLISQUANT,
109    
110          /* quality 6 */          /* quality 6 */
111          XVID_VOP_DYNAMIC_BFRAMES | XVID_VOP_HALFPEL |          XVID_VOP_HALFPEL | XVID_VOP_INTER4V |
112          XVID_VOP_INTER4V | XVID_VOP_TRELLISQUANT |          XVID_VOP_TRELLISQUANT | XVID_VOP_HQACPRED,
         XVID_VOP_HQACPRED,  
113    
114  };  };
115  #define VOP_ELEMENTS (sizeof(vop_presets)/sizeof(vop_presets[0]))  #define VOP_ELEMENTS (sizeof(vop_presets)/sizeof(vop_presets[0]))
# Line 131  Line 133 
133  static int ARG_SINGLE = 0;  static int ARG_SINGLE = 0;
134  static char *ARG_PASS1 = 0;  static char *ARG_PASS1 = 0;
135  static char *ARG_PASS2 = 0;  static char *ARG_PASS2 = 0;
136  static int ARG_QUALITY = 3;  static int ARG_QUALITY = ME_ELEMENTS - 1;
137  static float ARG_FRAMERATE = 25.00f;  static float ARG_FRAMERATE = 25.00f;
138  static int ARG_MAXFRAMENR = ABS_MAXFRAMENR;  static int ARG_MAXFRAMENR = ABS_MAXFRAMENR;
139    static int ARG_MAXKEYINTERVAL = 0;
140  static char *ARG_INPUTFILE = NULL;  static char *ARG_INPUTFILE = NULL;
141  static int ARG_INPUTTYPE = 0;  static int ARG_INPUTTYPE = 0;
142  static int ARG_SAVEMPEGSTREAM = 0;  static int ARG_SAVEMPEGSTREAM = 0;
# Line 145  Line 148 
148  static int ARG_MAXBFRAMES = 0;  static int ARG_MAXBFRAMES = 0;
149  static int ARG_PACKED = 0;  static int ARG_PACKED = 0;
150  static int ARG_DEBUG = 0;  static int ARG_DEBUG = 0;
151    static int ARG_VOPDEBUG = 0;
152    
153    #ifndef READ_PNM
154  #define IMAGE_SIZE(x,y) ((x)*(y)*3/2)  #define IMAGE_SIZE(x,y) ((x)*(y)*3/2)
155    #else
156    #define IMAGE_SIZE(x,y) ((x)*(y)*3)
157    #endif
158    
159  #define MAX(A,B) ( ((A)>(B)) ? (A) : (B) )  #define MAX(A,B) ( ((A)>(B)) ? (A) : (B) )
160  #define SMALL_EPS (1e-10)  #define SMALL_EPS (1e-10)
# Line 177  Line 185 
185  static double msecond();  static double msecond();
186    
187  /* PGM related functions */  /* PGM related functions */
188    #ifndef READ_PNM
189  static int read_pgmheader(FILE * handle);  static int read_pgmheader(FILE * handle);
190  static int read_pgmdata(FILE * handle,  static int read_pgmdata(FILE * handle,
191                                                  unsigned char *image);                                                  unsigned char *image);
192    #else
193    static int read_pnmheader(FILE * handle);
194    static int read_pnmdata(FILE * handle,
195                                                    unsigned char *image);
196    #endif
197  static int read_yuvdata(FILE * handle,  static int read_yuvdata(FILE * handle,
198                                                  unsigned char *image);                                                  unsigned char *image);
199    
# Line 294  Line 308 
308                  } else if (strcmp("-framerate", argv[i]) == 0 && i < argc - 1) {                  } else if (strcmp("-framerate", argv[i]) == 0 && i < argc - 1) {
309                          i++;                          i++;
310                          ARG_FRAMERATE = (float) atof(argv[i]);                          ARG_FRAMERATE = (float) atof(argv[i]);
311                    } else if (strcmp("-max_key_interval", argv[i]) == 0 && i < argc - 1) {
312                            i++;
313                            ARG_MAXKEYINTERVAL = atoi(argv[i]);
314                  } else if (strcmp("-i", argv[i]) == 0 && i < argc - 1) {                  } else if (strcmp("-i", argv[i]) == 0 && i < argc - 1) {
315                          i++;                          i++;
316                          ARG_INPUTFILE = argv[i];                          ARG_INPUTFILE = argv[i];
# Line 312  Line 329 
329                  } else if (strcmp("-save", argv[i]) == 0) {                  } else if (strcmp("-save", argv[i]) == 0) {
330                          ARG_SAVEMPEGSTREAM = 1;                          ARG_SAVEMPEGSTREAM = 1;
331                  } else if (strcmp("-debug", argv[i]) == 0) {                  } else if (strcmp("-debug", argv[i]) == 0) {
332                          ARG_DEBUG = 1;                          i++;
333                if (sscanf(argv[i],"0x%x", &ARG_DEBUG) || sscanf(argv[i],"%d", &ARG_DEBUG)) ;
334                  } else if (strcmp("-o", argv[i]) == 0 && i < argc - 1) {                  } else if (strcmp("-o", argv[i]) == 0 && i < argc - 1) {
335                          i++;                          i++;
336                          ARG_OUTPUTFILE = argv[i];                          ARG_OUTPUTFILE = argv[i];
337                    } else if (strcmp("-vop_debug", argv[i]) == 0) {
338                            ARG_VOPDEBUG = 1;
339                  } else if (strcmp("-help", argv[i])) {                  } else if (strcmp("-help", argv[i])) {
340                          usage();                          usage();
341                          return (0);                          return (0);
# Line 364  Line 384 
384          }          }
385    
386          if (ARG_INPUTTYPE) {          if (ARG_INPUTTYPE) {
387    #ifndef READ_PNM
388                  if (read_pgmheader(in_file)) {                  if (read_pgmheader(in_file)) {
389    #else
390                    if (read_pnmheader(in_file)) {
391    #endif
392                          fprintf(stderr,                          fprintf(stderr,
393                                          "Wrong input format, I want YUV encapsulated in PGM\n");                                          "Wrong input format, I want YUV encapsulated in PGM\n");
394                          return (-1);                          return (-1);
# Line 430  Line 454 
454                  if (!result) {                  if (!result) {
455                          if (ARG_INPUTTYPE) {                          if (ARG_INPUTTYPE) {
456                                  /* read PGM data (YUV-format) */                                  /* read PGM data (YUV-format) */
457    #ifndef READ_PNM
458                                  result = read_pgmdata(in_file, in_buffer);                                  result = read_pgmdata(in_file, in_buffer);
459    #else
460                                    result = read_pnmdata(in_file, in_buffer);
461    #endif
462                          } else {                          } else {
463                                  /* read raw data (YUV-format) */                                  /* read raw data (YUV-format) */
464                                  result = read_yuvdata(in_file, in_buffer);                                  result = read_yuvdata(in_file, in_buffer);
# Line 449  Line 477 
477    
478                  /* Write the Frame statistics */                  /* Write the Frame statistics */
479    
480                  printf("%5d: key=%i, time= %6.0f, length= %7d", !result ? input_num : -1,                  printf("%5d: key=%i, time= %6.0f, len= %7d", !result ? input_num : -1,
481                             key, (float) enctime, (int) m4v_size);                             key, (float) enctime, (int) m4v_size);
482    
483                  if (stats_type > 0) {   /* !XVID_TYPE_NOTHING */                  if (stats_type > 0) {   /* !XVID_TYPE_NOTHING */
# Line 472  Line 500 
500                                  break;                                  break;
501                          }                          }
502    
503                          printf(" | type=%s, quant= %2d, length= %7d", type, stats_quant,                          printf(" | type=%s, quant= %2d, len= %7d", type, stats_quant,
504                                     stats_length);                                     stats_length);
505    
506  #define SSE2PSNR(sse, width, height) ((!(sse))?0.0f : 48.131f - 10*(float)log10((float)(sse)/((float)((width)*(height)))))  #define SSE2PSNR(sse, width, height) ((!(sse))?0.0f : 48.131f - 10*(float)log10((float)(sse)/((float)((width)*(height)))))
# Line 526  Line 554 
554    
555                  /* Read the header if it's pgm stream */                  /* Read the header if it's pgm stream */
556                  if (!result && ARG_INPUTTYPE)                  if (!result && ARG_INPUTTYPE)
557    #ifndef READ_PNM
558                          result = read_pgmheader(in_file);                          result = read_pgmheader(in_file);
559    #else
560                            result = read_pnmheader(in_file);
561    #endif
562          } while (1);          } while (1);
563    
564    
# Line 643  Line 674 
674      fprintf(stderr,     " -single                        : single pass mode\n");      fprintf(stderr,     " -single                        : single pass mode\n");
675          fprintf(stderr, " -pass1     filename            : twopass mode (first pass)\n");          fprintf(stderr, " -pass1     filename            : twopass mode (first pass)\n");
676          fprintf(stderr, " -pass2     filename            : twopass mode (2nd pass)\n");          fprintf(stderr, " -pass2     filename            : twopass mode (2nd pass)\n");
677      fprintf(stderr,     " -zq frame float               : bitrate zone; quant\n");          fprintf(stderr, " -zq starting_frame float       : bitrate zone; quant\n");
678      fprintf(stderr,     " -zw frame float               : bitrate zone; weight\n");          fprintf(stderr, " -zw starting_frame float       : bitrate zone; weight\n");
679        fprintf(stderr, " -max_key_interval integer      : maximum keyframe interval\n");
680          fprintf(stderr, "\n");          fprintf(stderr, "\n");
681          fprintf(stderr, "Other options\n");          fprintf(stderr, "Other options\n");
682          fprintf(stderr, " -asm            : use assembly optmized code\n");          fprintf(stderr, " -asm            : use assembly optmized code\n");
# Line 652  Line 684 
684          fprintf(stderr, " -packed         : packed mode\n");          fprintf(stderr, " -packed         : packed mode\n");
685          fprintf(stderr, " -lumimasking    : use lumimasking algorithm\n");          fprintf(stderr, " -lumimasking    : use lumimasking algorithm\n");
686          fprintf(stderr, " -stats          : print stats about encoded frames\n");          fprintf(stderr, " -stats          : print stats about encoded frames\n");
687          fprintf(stderr, " -debug          : print all MB dquants\n");          fprintf(stderr, " -debug          : activates xvidcore internal debugging output\n");
688            fprintf(stderr, " -vop_debug      : print some info directly into encoded frames\n");
689          fprintf(stderr, " -help           : prints this help message\n");          fprintf(stderr, " -help           : prints this help message\n");
690            fprintf(stderr, "\n");
691            fprintf(stderr, "NB: You can define %d zones repeating the -z[qw] option as many times as needed.\n", MAX_ZONES);
692            fprintf(stderr, "\n");
693  }  }
694    
695  /*****************************************************************************  /*****************************************************************************
# Line 664  Line 700 
700   *   *
701   *****************************************************************************/   *****************************************************************************/
702    
703    #ifndef READ_PNM
704  static int  static int
705  read_pgmheader(FILE * handle)  read_pgmheader(FILE * handle)
706  {  {
# Line 719  Line 756 
756    
757          return (0);          return (0);
758  }  }
759    #else
760    static int
761    read_pnmheader(FILE * handle)
762    {
763            int bytes, xsize, ysize, depth;
764            char dummy[2];
765    
766            bytes = fread(dummy, 1, 2, handle);
767    
768            if ((bytes < 2) || (dummy[0] != 'P') || (dummy[1] != '6'))
769                    return (1);
770    
771            fscanf(handle, "%d %d %d", &xsize, &ysize, &depth);
772            if ((xsize > 1440) || (ysize > 2880) || (depth != 255)) {
773                    fprintf(stderr, "%d %d %d\n", xsize, ysize, depth);
774                    return (2);
775            }
776    
777            XDIM = xsize;
778            YDIM = ysize;
779    
780            return (0);
781    }
782    
783    static int
784    read_pnmdata(FILE * handle,
785                             unsigned char *image)
786    {
787            int i;
788            char dummy;
789    
790            /* read Y component of picture */
791            fread(image, 1, XDIM * YDIM * 3, handle);
792    
793            /*  I don't know why, but this seems needed */
794            fread(&dummy, 1, 1, handle);
795    
796            return (0);
797    }
798    #endif
799    
800  static int  static int
801  read_yuvdata(FILE * handle,  read_yuvdata(FILE * handle,
# Line 803  Line 880 
880          /* Set version -- version checking will done by xvidcore */          /* Set version -- version checking will done by xvidcore */
881          memset(&xvid_gbl_init, 0, sizeof(xvid_gbl_init));          memset(&xvid_gbl_init, 0, sizeof(xvid_gbl_init));
882          xvid_gbl_init.version = XVID_VERSION;          xvid_gbl_init.version = XVID_VERSION;
883        xvid_gbl_init.debug = ARG_DEBUG;
884    
885    
886          /* Do we have to enable ASM optimizations ? */          /* Do we have to enable ASM optimizations ? */
887          if (use_assembler) {          if (use_assembler) {
888    
889  #ifdef ARCH_IS_IA64  #ifdef ARCH_IS_IA64
890                  xvid_gbl_init.cpu_flags = XVID_CPU_FORCE | XVID_CPU_IA64;                  xvid_gbl_init.cpu_flags = XVID_CPU_FORCE | XVID_CPU_ASM;
891  #else  #else
892                  xvid_gbl_init.cpu_flags = 0;                  xvid_gbl_init.cpu_flags = 0;
893  #endif  #endif
# Line 882  Line 960 
960                  xvid_enc_create.num_plugins++;                  xvid_enc_create.num_plugins++;
961          }          }
962    
963    #if 0
964          if (ARG_DEBUG) {          if (ARG_DEBUG) {
965                  plugins[xvid_enc_create.num_plugins].func = rawenc_debug;                  plugins[xvid_enc_create.num_plugins].func = rawenc_debug;
966                  plugins[xvid_enc_create.num_plugins].param = NULL;                  plugins[xvid_enc_create.num_plugins].param = NULL;
967                  xvid_enc_create.num_plugins++;                  xvid_enc_create.num_plugins++;
968          }          }
969    #endif
970    
971          /* No fancy thread tests */          /* No fancy thread tests */
972          xvid_enc_create.num_threads = 0;          xvid_enc_create.num_threads = 0;
# Line 901  Line 981 
981          }          }
982    
983          /* Maximum key frame interval */          /* Maximum key frame interval */
984        if (ARG_MAXKEYINTERVAL > 0) {
985            xvid_enc_create.max_key_interval = ARG_MAXKEYINTERVAL;
986        }else {
987          xvid_enc_create.max_key_interval = (int) ARG_FRAMERATE *10;          xvid_enc_create.max_key_interval = (int) ARG_FRAMERATE *10;
988        }
989    
990          /* Bframes settings */          /* Bframes settings */
991          xvid_enc_create.max_bframes = ARG_MAXBFRAMES;          xvid_enc_create.max_bframes = ARG_MAXBFRAMES;
# Line 968  Line 1052 
1052          /* Initialize input image fields */          /* Initialize input image fields */
1053          if (image) {          if (image) {
1054                  xvid_enc_frame.input.plane[0] = image;                  xvid_enc_frame.input.plane[0] = image;
1055    #ifndef READ_PNM
1056                  xvid_enc_frame.input.csp = XVID_CSP_I420;                  xvid_enc_frame.input.csp = XVID_CSP_I420;
1057                  xvid_enc_frame.input.stride[0] = XDIM;                  xvid_enc_frame.input.stride[0] = XDIM;
1058    #else
1059                    xvid_enc_frame.input.csp = XVID_CSP_BGR;
1060                    xvid_enc_frame.input.stride[0] = XDIM*3;
1061    #endif
1062          } else {          } else {
1063                  xvid_enc_frame.input.csp = XVID_CSP_NULL;                  xvid_enc_frame.input.csp = XVID_CSP_NULL;
1064          }          }
# Line 981  Line 1070 
1070    
1071          /* Set up core's general features */          /* Set up core's general features */
1072          xvid_enc_frame.vop_flags = vop_presets[ARG_QUALITY];          xvid_enc_frame.vop_flags = vop_presets[ARG_QUALITY];
1073        if (ARG_VOPDEBUG) {
1074            xvid_enc_frame.vop_flags |= XVID_VOP_DEBUG;
1075        }
1076    
1077          /* Frame type -- let core decide for us */          /* Frame type -- let core decide for us */
1078          xvid_enc_frame.type = XVID_TYPE_AUTO;          xvid_enc_frame.type = XVID_TYPE_AUTO;

Legend:
Removed from v.1019  
changed lines
  Added in v.1081

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