Parent Directory
|
Revision Log
Revision 1.34 - (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 : | Isibaar | 1.34 | * Copyright(C) 2002-2010 Michael Militzer <isibaar@xvid.org> |
7 : | edgomez | 1.28 | * 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 : | Isibaar | 1.34 | * $Id: encoder.h,v 1.33 2010/09/13 07:38:09 Isibaar 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 : | typedef struct | ||
103 : | { | ||
104 : | int iTextBits; | ||
105 : | int iMvSum; | ||
106 : | int iMvCount; | ||
107 : | int kblks; | ||
108 : | int mblks; | ||
109 : | int ublks; | ||
110 : | int gblks; | ||
111 : | Isibaar | 1.30 | int iMVBits; |
112 : | edgomez | 1.28 | } Statistics; |
113 : | |||
114 : | /* encoding queue */ | ||
115 : | typedef struct | ||
116 : | { | ||
117 : | xvid_enc_frame_t frame; | ||
118 : | unsigned char quant_intra_matrix[64]; | ||
119 : | unsigned char quant_inter_matrix[64]; | ||
120 : | IMAGE image; | ||
121 : | } QUEUEINFO; | ||
122 : | suxen_drol | 1.5 | |
123 : | typedef struct | ||
124 : | { | ||
125 : | edgomez | 1.28 | int frame_num; |
126 : | int fincr; | ||
127 : | int vol_flags; | ||
128 : | int vop_flags; | ||
129 : | int motion_flags; | ||
130 : | |||
131 : | int coding_type; | ||
132 : | edgomez | 1.8 | uint32_t quant; |
133 : | uint32_t rounding_type; | ||
134 : | uint32_t fcode; | ||
135 : | suxen_drol | 1.5 | uint32_t bcode; |
136 : | |||
137 : | suxen_drol | 1.6 | uint32_t seconds; |
138 : | uint32_t ticks; | ||
139 : | edgomez | 1.27 | int64_t stamp; |
140 : | suxen_drol | 1.5 | |
141 : | IMAGE image; | ||
142 : | |||
143 : | edgomez | 1.9 | MACROBLOCK *mbs; |
144 : | suxen_drol | 1.5 | |
145 : | edgomez | 1.28 | WARPPOINTS warp; /* as in bitstream */ |
146 : | GMC_DATA gmc_data; /* common data for all MBs */ | ||
147 : | NEW_GMC_DATA new_gmc_data; /* common data for all MBs */ | ||
148 : | |||
149 : | int length; /* the encoded size of this frame */ | ||
150 : | |||
151 : | edgomez | 1.27 | Statistics sStat; |
152 : | edgomez | 1.28 | int is_edged, is_interpolated; |
153 : | } FRAMEINFO; | ||
154 : | Isibaar | 1.1 | |
155 : | syskin | 1.31 | #include "motion/motion_smp.h" |
156 : | |||
157 : | Isibaar | 1.1 | typedef struct |
158 : | { | ||
159 : | edgomez | 1.8 | MBParam mbParam; |
160 : | Isibaar | 1.1 | |
161 : | edgomez | 1.8 | int iFrameNum; |
162 : | Isibaar | 1.1 | int bitrate; |
163 : | |||
164 : | edgomez | 1.28 | /* zones */ |
165 : | unsigned int num_zones; | ||
166 : | xvid_enc_zone_t * zones; | ||
167 : | |||
168 : | /* plugins */ | ||
169 : | int num_plugins; /* note: we store plugin flags in MBPARAM */ | ||
170 : | xvid_enc_plugin_t * plugins; | ||
171 : | |||
172 : | /* dquant */ | ||
173 : | |||
174 : | int * temp_dquants; | ||
175 : | |||
176 : | syskin | 1.29 | /* lambda */ |
177 : | |||
178 : | float * temp_lambda; | ||
179 : | |||
180 : | edgomez | 1.28 | /* images */ |
181 : | Isibaar | 1.1 | |
182 : | edgomez | 1.9 | FRAMEINFO *current; |
183 : | FRAMEINFO *reference; | ||
184 : | suxen_drol | 1.5 | |
185 : | edgomez | 1.28 | IMAGE sOriginal; /* original image copy for i/p frames */ |
186 : | IMAGE sOriginal2; /* original image copy for b-frames */ | ||
187 : | edgomez | 1.8 | IMAGE vInterH; |
188 : | IMAGE vInterV; | ||
189 : | edgomez | 1.27 | IMAGE vInterVf; |
190 : | edgomez | 1.8 | IMAGE vInterHV; |
191 : | edgomez | 1.27 | IMAGE vInterHVf; |
192 : | |||
193 : | IMAGE vGMC; | ||
194 : | |||
195 : | /* image queue */ | ||
196 : | int queue_head; | ||
197 : | int queue_tail; | ||
198 : | int queue_size; | ||
199 : | edgomez | 1.28 | QUEUEINFO *queue; |
200 : | edgomez | 1.27 | |
201 : | /* bframe buffer */ | ||
202 : | int bframenum_head; | ||
203 : | int bframenum_tail; | ||
204 : | int flush_bframes; | ||
205 : | |||
206 : | FRAMEINFO **bframes; | ||
207 : | IMAGE f_refh; | ||
208 : | IMAGE f_refv; | ||
209 : | IMAGE f_refhv; | ||
210 : | edgomez | 1.28 | |
211 : | /* closed_gop fixup temporary storage */ | ||
212 : | int closed_bframenum; /* == -1 if there is no fixup intended */ | ||
213 : | QUEUEINFO closed_qframe; /* qFrame, only valid when >= 0 */ | ||
214 : | edgomez | 1.27 | |
215 : | syskin | 1.31 | /* multithreaded stuff */ |
216 : | Isibaar | 1.34 | int num_threads; /* number of encoder threads */ |
217 : | SMPData * smpData; /* data structures used to pass all thread-specific data */ | ||
218 : | syskin | 1.31 | |
219 : | edgomez | 1.27 | int m_framenum; /* debug frame num counter; unlike iFrameNum, does not reset at ivop */ |
220 : | suxen_drol | 1.11 | |
221 : | edgomez | 1.27 | float fMvPrevSigma; |
222 : | Isibaar | 1.34 | |
223 : | int num_slices; /* number of slices to code */ | ||
224 : | edgomez | 1.28 | } Encoder; |
225 : | Isibaar | 1.1 | |
226 : | edgomez | 1.10 | /***************************************************************************** |
227 : | * Inline functions | ||
228 : | ****************************************************************************/ | ||
229 : | edgomez | 1.9 | |
230 : | static __inline uint8_t | ||
231 : | get_fcode(uint16_t sr) | ||
232 : | Isibaar | 1.1 | { |
233 : | edgomez | 1.8 | if (sr <= 16) |
234 : | Isibaar | 1.1 | return 1; |
235 : | |||
236 : | edgomez | 1.9 | else if (sr <= 32) |
237 : | Isibaar | 1.1 | return 2; |
238 : | |||
239 : | edgomez | 1.8 | else if (sr <= 64) |
240 : | Isibaar | 1.1 | return 3; |
241 : | |||
242 : | edgomez | 1.8 | else if (sr <= 128) |
243 : | Isibaar | 1.1 | return 4; |
244 : | |||
245 : | edgomez | 1.8 | else if (sr <= 256) |
246 : | Isibaar | 1.1 | return 5; |
247 : | |||
248 : | edgomez | 1.8 | else if (sr <= 512) |
249 : | Isibaar | 1.1 | return 6; |
250 : | |||
251 : | edgomez | 1.8 | else if (sr <= 1024) |
252 : | Isibaar | 1.1 | return 7; |
253 : | |||
254 : | edgomez | 1.8 | else |
255 : | Isibaar | 1.1 | return 0; |
256 : | } | ||
257 : | |||
258 : | edgomez | 1.10 | /***************************************************************************** |
259 : | * Prototypes | ||
260 : | ****************************************************************************/ | ||
261 : | |||
262 : | void init_encoder(uint32_t cpu_flags); | ||
263 : | |||
264 : | edgomez | 1.28 | int enc_create(xvid_enc_create_t * create); |
265 : | int enc_destroy(Encoder * pEnc); | ||
266 : | int enc_encode(Encoder * pEnc, | ||
267 : | xvid_enc_frame_t * pFrame, | ||
268 : | xvid_enc_stats_t * stats); | ||
269 : | edgomez | 1.10 | |
270 : | #endif |
No admin address has been configured | ViewVC Help |
Powered by ViewVC 1.0.4 |