annotate libmpcodecs/ve_divx4.c @ 5766:ee396f7cb6a0

added my todo ;)
author alex
date Sun, 21 Apr 2002 16:09:37 +0000
parents 26c89aadf6f8
children 3a961eaf45b9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
1 #include <stdio.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
2 #include <stdlib.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
3 #include <string.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
4
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
5 #include "../config.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
6 #include "../mp_msg.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
7
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
8 #ifdef HAVE_DIVX4ENCORE
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
9
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
10 #include "codec-cfg.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
11 #include "stream.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
12 #include "demuxer.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
13 #include "stheader.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
14
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
15 #include "aviwrite.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
16
5607
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5551
diff changeset
17 #include "img_format.h"
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5551
diff changeset
18 #include "mp_image.h"
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
19 #include "vf.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
20
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
21 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
22
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
23 #include "divx4_vbr.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
24
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
25 extern int pass;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
26 extern char* passtmpfile;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
27
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
28 #include <encore2.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
29
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
30 ENC_PARAM divx4_param;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
31 int divx4_crispness;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
32
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
33 #include "cfgparser.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
34
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
35 struct config divx4opts_conf[]={
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
36 {"br", &divx4_param.bitrate, CONF_TYPE_INT, CONF_RANGE, 4, 24000000, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
37 {"rc_period", &divx4_param.rc_period, CONF_TYPE_INT, 0,0,0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
38 {"rc_reaction_period", &divx4_param.rc_reaction_period, CONF_TYPE_INT, 0,0,0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
39 {"rc_reaction_ratio", &divx4_param.rc_reaction_ratio, CONF_TYPE_INT, 0,0,0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
40 {"min_quant", &divx4_param.min_quantizer, CONF_TYPE_INT, CONF_RANGE,0,32, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
41 {"max_quant", &divx4_param.max_quantizer, CONF_TYPE_INT, CONF_RANGE,0,32, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
42 {"key", &divx4_param.max_key_interval, CONF_TYPE_INT, CONF_MIN,0,0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
43 {"deinterlace", &divx4_param.deinterlace, CONF_TYPE_FLAG, 0,0,1, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
44 {"q", &divx4_param.quality, CONF_TYPE_INT, CONF_RANGE, 1, 5, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
45 {"crispness", &divx4_crispness, CONF_TYPE_INT, CONF_RANGE,0,100, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
46 {"help", "TODO: divx4opts help!\n", CONF_TYPE_PRINT, CONF_NOCFG, 0, 0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
47 {NULL, NULL, 0, 0, 0, 0, NULL}
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
48 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
49
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
50 struct vf_priv_s {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
51 aviwrite_stream_t* mux;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
52 ENC_RESULT enc_result;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
53 ENC_FRAME enc_frame;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
54 void* enc_handle;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
55 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
56
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
57 #define mux_v (vf->priv->mux)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
58
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
59 static int config(struct vf_instance_s* vf,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
60 int width, int height, int d_width, int d_height,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
61 unsigned int flags, unsigned int outfmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
62
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
63 mux_v->bih->biWidth=width;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
64 mux_v->bih->biHeight=height;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
65
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
66 divx4_param.x_dim=width;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
67 divx4_param.y_dim=height;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
68 divx4_param.framerate=(float)mux_v->h.dwRate/mux_v->h.dwScale;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
69 mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*3;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
70
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
71 if(!divx4_param.bitrate) divx4_param.bitrate=800000;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
72 else if(divx4_param.bitrate<=16000) divx4_param.bitrate*=1000;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
73 if(!divx4_param.quality) divx4_param.quality=5; // the quality of compression ( 1 - fastest, 5 - best )
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
74
5551
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
75 // set some usefull defaults:
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
76 if(!divx4_param.min_quantizer) divx4_param.min_quantizer=2;
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
77 if(!divx4_param.max_quantizer) divx4_param.max_quantizer=31;
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
78 if(!divx4_param.rc_period) divx4_param.rc_period=2000;
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
79 if(!divx4_param.rc_reaction_period) divx4_param.rc_reaction_period=10;
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
80 if(!divx4_param.rc_reaction_ratio) divx4_param.rc_reaction_ratio=20;
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
81
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
82 divx4_param.handle=NULL;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
83 encore(NULL,ENC_OPT_INIT,&divx4_param,NULL);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
84 vf->priv->enc_handle=divx4_param.handle;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
85 switch(outfmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
86 case IMGFMT_YV12: vf->priv->enc_frame.colorspace=ENC_CSP_YV12; break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
87 case IMGFMT_IYUV:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
88 case IMGFMT_I420: vf->priv->enc_frame.colorspace=ENC_CSP_I420; break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
89 case IMGFMT_YUY2: vf->priv->enc_frame.colorspace=ENC_CSP_YUY2; break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
90 case IMGFMT_UYVY: vf->priv->enc_frame.colorspace=ENC_CSP_UYVY; break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
91 case IMGFMT_RGB24:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
92 case IMGFMT_BGR24:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
93 vf->priv->enc_frame.colorspace=ENC_CSP_RGB24; break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
94 default:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
95 mp_msg(MSGT_MENCODER,MSGL_ERR,"divx4: unsupported picture format (%s)!\n",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
96 vo_format_name(outfmt));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
97 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
98 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
99
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
100 switch(pass){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
101 case 1:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
102 if (VbrControl_init_2pass_vbr_analysis(passtmpfile, divx4_param.quality) == -1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
103 mp_msg(MSGT_MENCODER,MSGL_ERR,"2pass failed: filename=%s\n", passtmpfile);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
104 pass=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
105 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
106 break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
107 case 2:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
108 if (VbrControl_init_2pass_vbr_encoding(passtmpfile,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
109 divx4_param.bitrate,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
110 divx4_param.framerate,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
111 divx4_crispness,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
112 divx4_param.quality) == -1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
113 mp_msg(MSGT_MENCODER,MSGL_ERR,"2pass failed: filename=%s\n", passtmpfile);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
114 pass=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
115 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
116 break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
117 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
118
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
119 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
120 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
121
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
122 static int control(struct vf_instance_s* vf, int request, void* data){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
123
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
124 return CONTROL_UNKNOWN;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
125 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
126
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
127 static int query_format(struct vf_instance_s* vf, unsigned int fmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
128 switch(fmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
129 case IMGFMT_YV12:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
130 case IMGFMT_IYUV:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
131 case IMGFMT_I420:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
132 return 3; // no conversion
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
133 case IMGFMT_YUY2:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
134 case IMGFMT_UYVY:
5706
26c89aadf6f8 flipped rgb fixed
arpi
parents: 5607
diff changeset
135 return 1; // conversion
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
136 case IMGFMT_RGB24:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
137 case IMGFMT_BGR24:
5706
26c89aadf6f8 flipped rgb fixed
arpi
parents: 5607
diff changeset
138 return 1 | VFCAP_FLIPPED; // conversion+flipped
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
139 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
140 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
141 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
142
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
143 static void put_image(struct vf_instance_s* vf, mp_image_t *mpi){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
144 ENC_RESULT enc_result;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
145 vf->priv->enc_frame.image=mpi->planes[0];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
146 vf->priv->enc_frame.bitstream=mux_v->buffer;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
147 vf->priv->enc_frame.length=mux_v->buffer_size;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
148 vf->priv->enc_frame.mvs=NULL;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
149 if(pass==2){ // handle 2-pass:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
150 vf->priv->enc_frame.quant = VbrControl_get_quant();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
151 vf->priv->enc_frame.intra = VbrControl_get_intra();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
152 encore(vf->priv->enc_handle,ENC_OPT_ENCODE_VBR,&vf->priv->enc_frame,&enc_result);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
153 VbrControl_update_2pass_vbr_encoding(enc_result.motion_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
154 enc_result.texture_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
155 enc_result.total_bits);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
156 } else {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
157 vf->priv->enc_frame.quant=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
158 vf->priv->enc_frame.intra=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
159 encore(vf->priv->enc_handle,ENC_OPT_ENCODE,&vf->priv->enc_frame,&enc_result);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
160 if(pass==1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
161 VbrControl_update_2pass_vbr_analysis(enc_result.is_key_frame,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
162 enc_result.motion_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
163 enc_result.texture_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
164 enc_result.total_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
165 enc_result.quantizer);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
166 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
167 }
5551
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
168 mencoder_write_chunk(mux_v,vf->priv->enc_frame.length,enc_result.is_key_frame?0x10:0);
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
169 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
170
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
171 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
172
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
173 static int vf_open(vf_instance_t *vf, char* args){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
174 vf->config=config;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
175 vf->control=control;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
176 vf->query_format=query_format;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
177 vf->put_image=put_image;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
178 vf->priv=malloc(sizeof(struct vf_priv_s));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
179 memset(vf->priv,0,sizeof(struct vf_priv_s));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
180 vf->priv->mux=args;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
181
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
182 mux_v->bih=malloc(sizeof(BITMAPINFOHEADER));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
183 mux_v->bih->biSize=sizeof(BITMAPINFOHEADER);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
184 mux_v->bih->biWidth=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
185 mux_v->bih->biHeight=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
186 mux_v->bih->biPlanes=1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
187 mux_v->bih->biBitCount=24;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
188 mux_v->bih->biCompression=mmioFOURCC('d','i','v','x');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
189
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
190 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
191 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
192
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
193 vf_info_t ve_info_divx4 = {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
194 "divx4 encoder",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
195 "divx4",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
196 "A'rpi",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
197 "for internal use by mencoder",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
198 vf_open
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
199 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
200
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
201 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
202 #endif