[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 1054, Mon Jun 9 13:55:56 2003 UTC revision 1121, Sun Aug 10 13:10:09 2003 UTC
# Line 21  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.27 2003-06-09 13:49:25 edgomez Exp $   * $Id: xvid_encraw.c,v 1.11.2.35 2003-08-10 13:10:09 Isibaar Exp $
25   *   *
26   ****************************************************************************/   ****************************************************************************/
27    
# Line 50  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 71  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 148  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 180  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 325  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 373  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 439  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 535  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 659  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");
# Line 678  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 733  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 824  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 989  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 999  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_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      }      }
# Line 1015  Line 1099 
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);

Legend:
Removed from v.1054  
changed lines
  Added in v.1121

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