Parent Directory | Revision Log
Revision 1.32 - (view) (download)
1 : | edgomez | 1.10 | /***************************************************************************** |
2 : | Isibaar | 1.1 | * |
3 : | edgomez | 1.10 | * XVID MPEG-4 VIDEO CODEC |
4 : | edgomez | 1.28 | * - Encoder related header - |
5 : | Isibaar | 1.1 | * |
6 : | edgomez | 1.28 | * Copyright(C) 2002-2003 Michael Militzer <isibaar@xvid.org> |
7 : | * 2002-2003 Peter Ross <pross@xvid.org> | ||
8 : | edgomez | 1.27 | * |
9 : | * This program is free software ; you can redistribute it and/or modify | ||
10 : | * it under the terms of the GNU General Public License as published by | ||
11 : | * the Free Software Foundation ; either version 2 of the License, or | ||
12 : | edgomez | 1.10 | * (at your option) any later version. |
13 : | Isibaar | 1.1 | * |
14 : | edgomez | 1.10 | * This program is distributed in the hope that it will be useful, |
15 : | edgomez | 1.27 | * but WITHOUT ANY WARRANTY ; without even the implied warranty of |
16 : | edgomez | 1.10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
17 : | * GNU General Public License for more details. | ||
18 : | * | ||
19 : | * You should have received a copy of the GNU General Public License | ||
20 : | edgomez | 1.27 | * along with this program ; if not, write to the Free Software |
21 : | edgomez | 1.10 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
22 : | * | ||
23 : | syskin | 1.32 | * $Id: encoder.h,v 1.31 2006/02/24 08:46:22 syskin Exp $ |
24 : | edgomez | 1.21 | * |
25 : | edgomez | 1.10 | ****************************************************************************/ |
26 : | Isibaar | 1.1 | |
27 : | #ifndef _ENCODER_H_ | ||
28 : | #define _ENCODER_H_ | ||
29 : | |||
30 : | #include "xvid.h" | ||
31 : | #include "portab.h" | ||
32 : | #include "global.h" | ||
33 : | |||
34 : | edgomez | 1.10 | /***************************************************************************** |
35 : | * Constants | ||
36 : | ****************************************************************************/ | ||
37 : | |||
38 : | syskin | 1.29 | /* lambda base exponential. 1<<LAMBDA_EXP is the neutral lambda */ |
39 : | #define LAMBDA_EXP 6 | ||
40 : | |||
41 : | edgomez | 1.10 | /***************************************************************************** |
42 : | * Types | ||
43 : | ****************************************************************************/ | ||
44 : | Isibaar | 1.1 | |
45 : | edgomez | 1.10 | typedef int bool; |
46 : | Isibaar | 1.1 | |
47 : | edgomez | 1.10 | /***************************************************************************** |
48 : | * Structures | ||
49 : | ****************************************************************************/ | ||
50 : | Isibaar | 1.1 | |
51 : | typedef struct | ||
52 : | { | ||
53 : | edgomez | 1.28 | /* --- constants --- */ |
54 : | edgomez | 1.8 | uint32_t width; |
55 : | uint32_t height; | ||
56 : | Isibaar | 1.1 | |
57 : | uint32_t edged_width; | ||
58 : | uint32_t edged_height; | ||
59 : | uint32_t mb_width; | ||
60 : | uint32_t mb_height; | ||
61 : | |||
62 : | edgomez | 1.28 | int plugin_flags; |
63 : | |||
64 : | suxen_drol | 1.6 | /* frame rate increment & base */ |
65 : | edgomez | 1.28 | int32_t fincr; |
66 : | suxen_drol | 1.6 | uint32_t fbase; |
67 : | |||
68 : | edgomez | 1.28 | int profile; |
69 : | |||
70 : | int global_flags; | ||
71 : | edgomez | 1.27 | int bquant_ratio; |
72 : | int bquant_offset; | ||
73 : | int frame_drop_ratio; | ||
74 : | |||
75 : | edgomez | 1.28 | int min_quant[3]; |
76 : | int max_quant[3]; | ||
77 : | |||
78 : | int par; | ||
79 : | int par_width; | ||
80 : | int par_height; | ||
81 : | |||
82 : | edgomez | 1.27 | int iMaxKeyInterval; |
83 : | int max_bframes; | ||
84 : | |||
85 : | edgomez | 1.28 | /* --- inbetween vop stuff --- */ |
86 : | edgomez | 1.8 | /* rounding type; alternate 0-1 after each interframe */ |
87 : | Isibaar | 1.1 | /* 1 <= fixed_code <= 4 |
88 : | automatically adjusted using motion vector statistics inside | ||
89 : | edgomez | 1.9 | */ |
90 : | Isibaar | 1.1 | |
91 : | suxen_drol | 1.5 | /* vars that not "quite" frame independant */ |
92 : | uint32_t m_rounding_type; | ||
93 : | uint32_t m_fcode; | ||
94 : | edgomez | 1.28 | int vol_flags; |
95 : | suxen_drol | 1.5 | |
96 : | edgomez | 1.28 | int64_t m_stamp; |
97 : | suxen_drol | 1.5 | |
98 : | edgomez | 1.28 | uint16_t *mpeg_quant_matrices; |
99 : | syskin | 1.32 | uint32_t last_quant_initialized_intra; /* needed for mpeg matrices initialization */ |
100 : | edgomez | 1.28 | } MBParam; |
101 : | edgomez | 1.27 | |
102 : | suxen_drol | 1.6 | |
103 : | edgomez | 1.27 | typedef struct |
104 : | { | ||
105 : | int iTextBits; | ||
106 : | int iMvSum; | ||
107 : | int iMvCount; | ||
108 : | int kblks; | ||
109 : | int mblks; | ||
110 : | int ublks; | ||
111 : | int gblks; | ||
112 : | Isibaar | 1.30 | int iMVBits; |
113 : | edgomez | 1.28 | } Statistics; |
114 : | |||
115 : | |||
116 : | /* encoding queue */ | ||
117 : | typedef struct | ||
118 : | { | ||
119 : | xvid_enc_frame_t frame; | ||
120 : | unsigned char quant_intra_matrix[64]; | ||
121 : | unsigned char quant_inter_matrix[64]; | ||
122 : | IMAGE image; | ||
123 : | } QUEUEINFO; | ||
124 : | suxen_drol | 1.5 | |
125 : | |||
126 : | typedef struct | ||
127 : | { | ||
128 : | edgomez | 1.28 | int frame_num; |
129 : | int fincr; | ||
130 : | int vol_flags; | ||
131 : | int vop_flags; | ||
132 : | int motion_flags; | ||
133 : | |||
134 : | int coding_type; | ||
135 : | edgomez | 1.8 | uint32_t quant; |
136 : | uint32_t rounding_type; | ||
137 : | uint32_t fcode; | ||
138 : | suxen_drol | 1.5 | uint32_t bcode; |
139 : | |||
140 : | suxen_drol | 1.6 | uint32_t seconds; |
141 : | uint32_t ticks; | ||
142 : | edgomez | 1.27 | int64_t stamp; |
143 : | suxen_drol | 1.5 | |
144 : | IMAGE image; | ||
145 : | |||
146 : | edgomez | 1.9 | MACROBLOCK *mbs; |
147 : | suxen_drol | 1.5 | |
148 : | edgomez | 1.28 | WARPPOINTS warp; /* as in bitstream */ |
149 : | GMC_DATA gmc_data; /* common data for all MBs */ | ||
150 : | NEW_GMC_DATA new_gmc_data; /* common data for all MBs */ | ||
151 : | |||
152 : | int length; /* the encoded size of this frame */ | ||
153 : | |||
154 : | edgomez | 1.27 | Statistics sStat; |
155 : | edgomez | 1.28 | int is_edged, is_interpolated; |
156 : | } FRAMEINFO; | ||
157 : | Isibaar | 1.1 | |
158 : | |||
159 : | syskin | 1.31 | #include "motion/motion_smp.h" |
160 : | |||
161 : | Isibaar | 1.1 | typedef struct |
162 : | { | ||
163 : | edgomez | 1.8 | MBParam mbParam; |
164 : | Isibaar | 1.1 | |
165 : | edgomez | 1.8 | int iFrameNum; |
166 : | Isibaar | 1.1 | int bitrate; |
167 : | |||
168 : | edgomez | 1.28 | /* zones */ |
169 : | unsigned int num_zones; | ||
170 : | xvid_enc_zone_t * zones; | ||
171 : | |||
172 : | /* plugins */ | ||
173 : | int num_plugins; /* note: we store plugin flags in MBPARAM */ | ||
174 : | xvid_enc_plugin_t * plugins; | ||
175 : | |||
176 : | /* dquant */ | ||
177 : | |||
178 : | int * temp_dquants; | ||
179 : | |||
180 : | syskin | 1.29 | /* lambda */ |
181 : | |||
182 : | float * temp_lambda; | ||
183 : | |||
184 : | edgomez | 1.28 | /* images */ |
185 : | Isibaar | 1.1 | |
186 : | edgomez | 1.9 | FRAMEINFO *current; |
187 : | FRAMEINFO *reference; | ||
188 : | suxen_drol | 1.5 | |
189 : | edgomez | 1.28 | IMAGE sOriginal; /* original image copy for i/p frames */ |
190 : | IMAGE sOriginal2; /* original image copy for b-frames */ | ||
191 : | edgomez | 1.8 | IMAGE vInterH; |
192 : | IMAGE vInterV; | ||
193 : | edgomez | 1.27 | IMAGE vInterVf; |
194 : | edgomez | 1.8 | IMAGE vInterHV; |
195 : | edgomez | 1.27 | IMAGE vInterHVf; |
196 : | |||
197 : | IMAGE vGMC; | ||
198 : | |||
199 : | /* image queue */ | ||
200 : | int queue_head; | ||
201 : | int queue_tail; | ||
202 : | int queue_size; | ||
203 : | edgomez | 1.28 | QUEUEINFO *queue; |
204 : | edgomez | 1.27 | |
205 : | /* bframe buffer */ | ||
206 : | int bframenum_head; | ||
207 : | int bframenum_tail; | ||
208 : | int flush_bframes; | ||
209 : | |||
210 : | FRAMEINFO **bframes; | ||
211 : | IMAGE f_refh; | ||
212 : | IMAGE f_refv; | ||
213 : | IMAGE f_refhv; | ||
214 : | edgomez | 1.28 | |
215 : | /* closed_gop fixup temporary storage */ | ||
216 : | int closed_bframenum; /* == -1 if there is no fixup intended */ | ||
217 : | QUEUEINFO closed_qframe; /* qFrame, only valid when >= 0 */ | ||
218 : | edgomez | 1.27 | |
219 : | syskin | 1.31 | /* multithreaded stuff */ |
220 : | int num_threads; /* number of additional threads */ | ||
221 : | SMPmotionData * motionData; /* data structures used to pass all thread-specific data */ | ||
222 : | |||
223 : | edgomez | 1.27 | int m_framenum; /* debug frame num counter; unlike iFrameNum, does not reset at ivop */ |
224 : | suxen_drol | 1.11 | |
225 : | edgomez | 1.27 | float fMvPrevSigma; |
226 : | edgomez | 1.28 | } Encoder; |
227 : | Isibaar | 1.1 | |
228 : | edgomez | 1.10 | /***************************************************************************** |
229 : | * Inline functions | ||
230 : | ****************************************************************************/ | ||
231 : | edgomez | 1.9 | |
232 : | static __inline uint8_t | ||
233 : | get_fcode(uint16_t sr) | ||
234 : | Isibaar | 1.1 | { |
235 : | edgomez | 1.8 | if (sr <= 16) |
236 : | Isibaar | 1.1 | return 1; |
237 : | |||
238 : | edgomez | 1.9 | else if (sr <= 32) |
239 : | Isibaar | 1.1 | return 2; |
240 : | |||
241 : | edgomez | 1.8 | else if (sr <= 64) |
242 : | Isibaar | 1.1 | return 3; |
243 : | |||
244 : | edgomez | 1.8 | else if (sr <= 128) |
245 : | Isibaar | 1.1 | return 4; |
246 : | |||
247 : | edgomez | 1.8 | else if (sr <= 256) |
248 : | Isibaar | 1.1 | return 5; |
249 : | |||
250 : | edgomez | 1.8 | else if (sr <= 512) |
251 : | Isibaar | 1.1 | return 6; |
252 : | |||
253 : | edgomez | 1.8 | else if (sr <= 1024) |
254 : | Isibaar | 1.1 | return 7; |
255 : | |||
256 : | edgomez | 1.8 | else |
257 : | Isibaar | 1.1 | return 0; |
258 : | } | ||
259 : | |||
260 : | edgomez | 1.10 | |
261 : | /***************************************************************************** | ||
262 : | * Prototypes | ||
263 : | ****************************************************************************/ | ||
264 : | |||
265 : | void init_encoder(uint32_t cpu_flags); | ||
266 : | |||
267 : | edgomez | 1.28 | int enc_create(xvid_enc_create_t * create); |
268 : | int enc_destroy(Encoder * pEnc); | ||
269 : | int enc_encode(Encoder * pEnc, | ||
270 : | xvid_enc_frame_t * pFrame, | ||
271 : | xvid_enc_stats_t * stats); | ||
272 : | edgomez | 1.10 | |
273 : | #endif |
No admin address has been configured | ViewVC Help |
Powered by ViewVC 1.0.4 |