FFmpeg
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
ituh263enc.c
Go to the documentation of this file.
1 /*
2  * ITU H.263 bitstream encoder
3  * Copyright (c) 2000,2001 Fabrice Bellard
4  * H.263+ support.
5  * Copyright (c) 2001 Juan J. Sierralta P
6  * Copyright (c) 2002-2004 Michael Niedermayer <michaelni@gmx.at>
7  *
8  * This file is part of FFmpeg.
9  *
10  * FFmpeg is free software; you can redistribute it and/or
11  * modify it under the terms of the GNU Lesser General Public
12  * License as published by the Free Software Foundation; either
13  * version 2.1 of the License, or (at your option) any later version.
14  *
15  * FFmpeg is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18  * Lesser General Public License for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public
21  * License along with FFmpeg; if not, write to the Free Software
22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
23  */
24 
25 /**
26  * @file
27  * H.263 bitstream encoder.
28  */
29 
30 #include "config_components.h"
31 
32 #include <limits.h>
33 #include <string.h>
34 
35 #include "libavutil/attributes.h"
36 #include "libavutil/thread.h"
37 #include "avcodec.h"
38 #include "codec_internal.h"
39 #include "mpegvideo.h"
40 #include "flvenc.h"
41 #include "mpegvideoenc.h"
42 #include "h263.h"
43 #include "h263enc.h"
44 #include "h263data.h"
45 #include "h263dsp.h"
46 #include "mathops.h"
47 #include "mpegutils.h"
48 #include "internal.h"
49 
50 /**
51  * Table of number of bits a motion vector component needs.
52  */
53 static uint8_t mv_penalty[MAX_FCODE+1][MAX_DMV*2+1];
54 
55 /**
56  * Minimal fcode that a motion vector component would need in umv.
57  * All entries in this table are 1.
58  */
59 static uint8_t umv_fcode_tab[MAX_MV*2+1];
60 
61 //unified encoding tables for run length encoding of coefficients
62 //unified in the sense that the specification specifies the encoding in several steps.
63 static uint8_t uni_h263_intra_aic_rl_len [64*64*2*2];
64 static uint8_t uni_h263_inter_rl_len [64*64*2*2];
65 //#define UNI_MPEG4_ENC_INDEX(last,run,level) ((last)*128 + (run)*256 + (level))
66 //#define UNI_MPEG4_ENC_INDEX(last,run,level) ((last)*128*64 + (run) + (level)*64)
67 #define UNI_MPEG4_ENC_INDEX(last,run,level) ((last)*128*64 + (run)*128 + (level))
68 
70 {
71  for (int f_code = 1; f_code <= MAX_FCODE; f_code++) {
72  for (int mv = -MAX_DMV; mv <= MAX_DMV; mv++) {
73  int len;
74 
75  if (mv == 0) len = 1; // ff_mvtab[0][1]
76  else {
77  int val, bit_size, code;
78 
79  bit_size = f_code - 1;
80 
81  val = mv;
82  if (val < 0)
83  val = -val;
84  val--;
85  code = (val >> bit_size) + 1;
86  if (code < 33) {
87  len = ff_mvtab[code][1] + 1 + bit_size;
88  } else {
89  len = 12 /* ff_mvtab[32][1] */ + av_log2(code>>5) + 2 + bit_size;
90  }
91  }
92 
93  mv_penalty[f_code][mv + MAX_DMV] = len;
94  }
95  }
96 
97  memset(umv_fcode_tab, 1, sizeof(umv_fcode_tab));
98 }
99 
100 static av_cold void init_uni_h263_rl_tab(const RLTable *rl, uint8_t *len_tab)
101 {
102  av_assert0(MAX_LEVEL >= 64);
103  av_assert0(MAX_RUN >= 63);
104 
105  for (int slevel = -64; slevel < 64; slevel++) {
106  if (slevel == 0) continue;
107  for (int run = 0; run < 64; run++) {
108  for (int last = 0; last <= 1; last++) {
109  const int index = UNI_MPEG4_ENC_INDEX(last, run, slevel + 64);
110  int level = slevel < 0 ? -slevel : slevel;
111  int sign = slevel < 0 ? 1 : 0;
112  int bits, len, code;
113 
114  len_tab[index] = 100;
115 
116  /* ESC0 */
117  code = get_rl_index(rl, last, run, level);
118  bits = rl->table_vlc[code][0];
119  len = rl->table_vlc[code][1];
120  bits = bits * 2 + sign;
121  len++;
122 
123  if (code != rl->n && len < len_tab[index])
124  len_tab[index] = len;
125 
126  /* ESC */
127  bits = rl->table_vlc[rl->n][0];
128  len = rl->table_vlc[rl->n][1];
129  bits = bits * 2 + last; len++;
130  bits = bits * 64 + run; len += 6;
131  bits = bits * 256 + (level & 0xff); len += 8;
132 
133  if (len < len_tab[index])
134  len_tab[index] = len;
135  }
136  }
137  }
138 }
139 
141 {
142  static uint8_t rl_intra_table[2][2 * MAX_RUN + MAX_LEVEL + 3];
143 
144  ff_rl_init(&ff_rl_intra_aic, rl_intra_table);
146 
149 
151 }
152 
153 av_cold const uint8_t (*ff_h263_get_mv_penalty(void))[MAX_DMV*2+1]
154 {
155  static AVOnce init_static_once = AV_ONCE_INIT;
156 
157  ff_thread_once(&init_static_once, h263_encode_init_static);
158 
159  return mv_penalty;
160 }
161 
162 void ff_h263_encode_motion(PutBitContext *pb, int val, int f_code)
163 {
164  if (val == 0) {
165  /* zero vector -- corresponds to ff_mvtab[0] */
166  put_bits(pb, 1, 1);
167  } else {
168  int sign, code, bits;
169  int bit_size = f_code - 1;
170  int range = 1 << bit_size;
171  /* modulo encoding */
172  val = sign_extend(val, 6 + bit_size);
173  sign = val>>31;
174  val= (val^sign)-sign;
175  sign&=1;
176 
177  val--;
178  code = (val >> bit_size) + 1;
179  bits = val & (range - 1);
180 
181  put_bits(pb, ff_mvtab[code][1] + 1, (ff_mvtab[code][0] << 1) | sign);
182  if (bit_size > 0) {
183  put_bits(pb, bit_size, bits);
184  }
185  }
186 }
187 
188 #if CONFIG_H263_ENCODER // Snow and SVQ1 need the above
189 static const uint8_t wrong_run[102] = {
190  1, 2, 3, 5, 4, 10, 9, 8,
191 11, 15, 17, 16, 23, 22, 21, 20,
192 19, 18, 25, 24, 27, 26, 11, 7,
193  6, 1, 2, 13, 2, 2, 2, 2,
194  6, 12, 3, 9, 1, 3, 4, 3,
195  7, 4, 1, 1, 5, 5, 14, 6,
196  1, 7, 1, 8, 1, 1, 1, 1,
197 10, 1, 1, 5, 9, 17, 25, 24,
198 29, 33, 32, 41, 2, 23, 28, 31,
199  3, 22, 30, 4, 27, 40, 8, 26,
200  6, 39, 7, 38, 16, 37, 15, 10,
201 11, 12, 13, 14, 1, 21, 20, 18,
202 19, 2, 1, 34, 35, 36
203 };
204 
205 /**
206  * Return the 4 bit value that specifies the given aspect ratio.
207  * This may be one of the standard aspect ratios or it specifies
208  * that the aspect will be stored explicitly later.
209  */
211  int i;
212 
213  if(aspect.num==0 || aspect.den==0) aspect= (AVRational){1,1};
214 
215  for(i=1; i<6; i++){
216  if(av_cmp_q(ff_h263_pixel_aspect[i], aspect) == 0){
217  return i;
218  }
219  }
220 
221  return FF_ASPECT_EXTENDED;
222 }
223 
224 static int h263_encode_picture_header(MPVMainEncContext *const m)
225 {
226  MPVEncContext *const s = &m->s;
227  int format, coded_frame_rate, coded_frame_rate_base, i, temp_ref;
228  int best_clock_code=1;
229  int best_divisor=60;
230  int best_error= INT_MAX;
231  int custom_pcf;
232 
233  if(s->c.h263_plus){
234  for(i=0; i<2; i++){
235  int div, error;
236  div= (s->c.avctx->time_base.num*1800000LL + 500LL*s->c.avctx->time_base.den) / ((1000LL+i)*s->c.avctx->time_base.den);
237  div= av_clip(div, 1, 127);
238  error= FFABS(s->c.avctx->time_base.num*1800000LL - (1000LL+i)*s->c.avctx->time_base.den*div);
239  if(error < best_error){
240  best_error= error;
241  best_divisor= div;
242  best_clock_code= i;
243  }
244  }
245  }
246  custom_pcf = best_clock_code != 1 || best_divisor != 60;
247  coded_frame_rate= 1800000;
248  coded_frame_rate_base= (1000+best_clock_code)*best_divisor;
249 
250  align_put_bits(&s->pb);
251 
252  put_bits(&s->pb, 22, 0x20); /* PSC */
253  temp_ref= s->c.picture_number * (int64_t)coded_frame_rate * s->c.avctx->time_base.num / //FIXME use timestamp
254  (coded_frame_rate_base * (int64_t)s->c.avctx->time_base.den);
255  put_sbits(&s->pb, 8, temp_ref); /* TemporalReference */
256 
257  put_bits(&s->pb, 1, 1); /* marker */
258  put_bits(&s->pb, 1, 0); /* H.263 id */
259  put_bits(&s->pb, 1, 0); /* split screen off */
260  put_bits(&s->pb, 1, 0); /* camera off */
261  put_bits(&s->pb, 1, 0); /* freeze picture release off */
262 
264  if (!s->c.h263_plus) {
265  /* H.263v1 */
266  put_bits(&s->pb, 3, format);
267  put_bits(&s->pb, 1, (s->c.pict_type == AV_PICTURE_TYPE_P));
268  /* By now UMV IS DISABLED ON H.263v1, since the restrictions
269  of H.263v1 UMV implies to check the predicted MV after
270  calculation of the current MB to see if we're on the limits */
271  put_bits(&s->pb, 1, 0); /* Unrestricted Motion Vector: off */
272  put_bits(&s->pb, 1, 0); /* SAC: off */
273  put_bits(&s->pb, 1, s->c.obmc); /* Advanced Prediction */
274  put_bits(&s->pb, 1, 0); /* only I/P-frames, no PB-frame */
275  put_bits(&s->pb, 5, s->c.qscale);
276  put_bits(&s->pb, 1, 0); /* Continuous Presence Multipoint mode: off */
277  } else {
278  int ufep=1;
279  /* H.263v2 */
280  /* H.263 Plus PTYPE */
281 
282  put_bits(&s->pb, 3, 7);
283  put_bits(&s->pb,3,ufep); /* Update Full Extended PTYPE */
284  if (format == 8)
285  put_bits(&s->pb,3,6); /* Custom Source Format */
286  else
287  put_bits(&s->pb, 3, format);
288 
289  put_bits(&s->pb,1, custom_pcf);
290  put_bits(&s->pb,1, s->c.umvplus); /* Unrestricted Motion Vector */
291  put_bits(&s->pb,1,0); /* SAC: off */
292  put_bits(&s->pb,1,s->c.obmc); /* Advanced Prediction Mode */
293  put_bits(&s->pb,1,s->c.h263_aic); /* Advanced Intra Coding */
294  put_bits(&s->pb,1,s->c.loop_filter); /* Deblocking Filter */
295  put_bits(&s->pb,1,s->c.h263_slice_structured); /* Slice Structured */
296  put_bits(&s->pb,1,0); /* Reference Picture Selection: off */
297  put_bits(&s->pb,1,0); /* Independent Segment Decoding: off */
298  put_bits(&s->pb,1,s->c.alt_inter_vlc); /* Alternative Inter VLC */
299  put_bits(&s->pb,1,s->c.modified_quant); /* Modified Quantization: */
300  put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
301  put_bits(&s->pb,3,0); /* Reserved */
302 
303  put_bits(&s->pb, 3, s->c.pict_type == AV_PICTURE_TYPE_P);
304 
305  put_bits(&s->pb,1,0); /* Reference Picture Resampling: off */
306  put_bits(&s->pb,1,0); /* Reduced-Resolution Update: off */
307  put_bits(&s->pb,1,s->c.no_rounding); /* Rounding Type */
308  put_bits(&s->pb,2,0); /* Reserved */
309  put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
310 
311  /* This should be here if PLUSPTYPE */
312  put_bits(&s->pb, 1, 0); /* Continuous Presence Multipoint mode: off */
313 
314  if (format == 8) {
315  /* Custom Picture Format (CPFMT) */
316  unsigned aspect_ratio_info = ff_h263_aspect_to_info(s->c.avctx->sample_aspect_ratio);
317 
318  put_bits(&s->pb,4, aspect_ratio_info);
319  put_bits(&s->pb,9,(s->c.width >> 2) - 1);
320  put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
321  put_bits(&s->pb,9,(s->c.height >> 2));
322  if (aspect_ratio_info == FF_ASPECT_EXTENDED){
323  put_bits(&s->pb, 8, s->c.avctx->sample_aspect_ratio.num);
324  put_bits(&s->pb, 8, s->c.avctx->sample_aspect_ratio.den);
325  }
326  }
327  if (custom_pcf) {
328  if(ufep){
329  put_bits(&s->pb, 1, best_clock_code);
330  put_bits(&s->pb, 7, best_divisor);
331  }
332  put_sbits(&s->pb, 2, temp_ref>>8);
333  }
334 
335  /* Unlimited Unrestricted Motion Vectors Indicator (UUI) */
336  if (s->c.umvplus)
337 // put_bits(&s->pb,1,1); /* Limited according tables of Annex D */
338 //FIXME check actual requested range
339  put_bits(&s->pb,2,1); /* unlimited */
340  if(s->c.h263_slice_structured)
341  put_bits(&s->pb,2,0); /* no weird submodes */
342 
343  put_bits(&s->pb, 5, s->c.qscale);
344  }
345 
346  put_bits(&s->pb, 1, 0); /* no PEI */
347 
348  if(s->c.h263_slice_structured){
349  put_bits(&s->pb, 1, 1);
350 
351  av_assert1(s->c.mb_x == 0 && s->c.mb_y == 0);
353 
354  put_bits(&s->pb, 1, 1);
355  }
356 
357  return 0;
358 }
359 
360 /**
361  * Encode a group of blocks header.
362  */
363 void ff_h263_encode_gob_header(MPVEncContext *const s, int mb_line)
364 {
365  put_bits(&s->pb, 17, 1); /* GBSC */
366 
367  if(s->c.h263_slice_structured){
368  put_bits(&s->pb, 1, 1);
369 
371 
372  if(s->c.mb_num > 1583)
373  put_bits(&s->pb, 1, 1);
374  put_bits(&s->pb, 5, s->c.qscale); /* GQUANT */
375  put_bits(&s->pb, 1, 1);
376  put_bits(&s->pb, 2, s->c.pict_type == AV_PICTURE_TYPE_I); /* GFID */
377  }else{
378  int gob_number= mb_line / s->c.gob_index;
379 
380  put_bits(&s->pb, 5, gob_number); /* GN */
381  put_bits(&s->pb, 2, s->c.pict_type == AV_PICTURE_TYPE_I); /* GFID */
382  put_bits(&s->pb, 5, s->c.qscale); /* GQUANT */
383  }
384 }
385 
386 /**
387  * modify qscale so that encoding is actually possible in H.263 (limit difference to -2..2)
388  */
390 {
391  int8_t * const qscale_table = s->c.cur_pic.qscale_table;
392 
393  for (int i = 1; i < s->c.mb_num; i++) {
394  if (qscale_table[ s->c.mb_index2xy[i] ] - qscale_table[ s->c.mb_index2xy[i-1] ] > 2)
395  qscale_table[ s->c.mb_index2xy[i] ] = qscale_table[ s->c.mb_index2xy[i-1] ] + 2;
396  }
397  for(int i = s->c.mb_num - 2; i >= 0; i--) {
398  if (qscale_table[ s->c.mb_index2xy[i] ] - qscale_table[ s->c.mb_index2xy[i+1] ] > 2)
399  qscale_table[ s->c.mb_index2xy[i] ] = qscale_table[ s->c.mb_index2xy[i+1] ] + 2;
400  }
401 
402  if (s->c.codec_id != AV_CODEC_ID_H263P) {
403  for (int i = 1; i < s->c.mb_num; i++) {
404  int mb_xy = s->c.mb_index2xy[i];
405 
406  if (qscale_table[mb_xy] != qscale_table[s->c.mb_index2xy[i - 1]] &&
407  (s->mb_type[mb_xy] & CANDIDATE_MB_TYPE_INTER4V)) {
408  s->mb_type[mb_xy]|= CANDIDATE_MB_TYPE_INTER;
409  }
410  }
411  }
412 }
413 
414 static const int dquant_code[5]= {1,0,9,2,3};
415 
416 /**
417  * Encode an 8x8 block.
418  * @param block the 8x8 block
419  * @param n block index (0-3 are luma, 4-5 are chroma)
420  */
421 static void h263_encode_block(MPVEncContext *const s, int16_t block[], int n)
422 {
423  int level, run, last, i, j, last_index, last_non_zero, sign, slevel, code;
424  const RLTable *rl;
425 
426  rl = &ff_h263_rl_inter;
427  if (s->c.mb_intra && !s->c.h263_aic) {
428  /* DC coef */
429  level = block[0];
430  /* 255 cannot be represented, so we clamp */
431  if (level > 254) {
432  level = 254;
433  block[0] = 254;
434  }
435  /* 0 cannot be represented also */
436  else if (level < 1) {
437  level = 1;
438  block[0] = 1;
439  }
440  if (level == 128) //FIXME check rv10
441  put_bits(&s->pb, 8, 0xff);
442  else
443  put_bits(&s->pb, 8, level);
444  i = 1;
445  } else {
446  i = 0;
447  if (s->c.h263_aic && s->c.mb_intra)
448  rl = &ff_rl_intra_aic;
449 
450  if(s->c.alt_inter_vlc && !s->c.mb_intra){
451  int aic_vlc_bits=0;
452  int inter_vlc_bits=0;
453  int wrong_pos=-1;
454  int aic_code;
455 
456  last_index = s->c.block_last_index[n];
457  last_non_zero = i - 1;
458  for (; i <= last_index; i++) {
459  j = s->c.intra_scantable.permutated[i];
460  level = block[j];
461  if (level) {
462  run = i - last_non_zero - 1;
463  last = (i == last_index);
464 
465  if(level<0) level= -level;
466 
467  code = get_rl_index(rl, last, run, level);
468  aic_code = get_rl_index(&ff_rl_intra_aic, last, run, level);
469  inter_vlc_bits += rl->table_vlc[code][1]+1;
470  aic_vlc_bits += ff_rl_intra_aic.table_vlc[aic_code][1]+1;
471 
472  if (code == rl->n) {
473  inter_vlc_bits += 1+6+8-1;
474  }
475  if (aic_code == ff_rl_intra_aic.n) {
476  aic_vlc_bits += 1+6+8-1;
477  wrong_pos += run + 1;
478  }else
479  wrong_pos += wrong_run[aic_code];
480  last_non_zero = i;
481  }
482  }
483  i = 0;
484  if(aic_vlc_bits < inter_vlc_bits && wrong_pos > 63)
485  rl = &ff_rl_intra_aic;
486  }
487  }
488 
489  /* AC coefs */
490  last_index = s->c.block_last_index[n];
491  last_non_zero = i - 1;
492  for (; i <= last_index; i++) {
493  j = s->c.intra_scantable.permutated[i];
494  level = block[j];
495  if (level) {
496  run = i - last_non_zero - 1;
497  last = (i == last_index);
498  sign = 0;
499  slevel = level;
500  if (level < 0) {
501  sign = 1;
502  level = -level;
503  }
504  code = get_rl_index(rl, last, run, level);
505  put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
506  if (code == rl->n) {
507  if(!CONFIG_FLV_ENCODER || s->c.h263_flv <= 1){
508  put_bits(&s->pb, 1, last);
509  put_bits(&s->pb, 6, run);
510 
511  av_assert2(slevel != 0);
512 
513  if(level < 128)
514  put_sbits(&s->pb, 8, slevel);
515  else{
516  put_bits(&s->pb, 8, 128);
517  put_sbits(&s->pb, 5, slevel);
518  put_sbits(&s->pb, 6, slevel>>5);
519  }
520  }else{
521  ff_flv2_encode_ac_esc(&s->pb, slevel, level, run, last);
522  }
523  } else {
524  put_bits(&s->pb, 1, sign);
525  }
526  last_non_zero = i;
527  }
528  }
529 }
530 
531 /* Encode MV differences on H.263+ with Unrestricted MV mode */
532 static void h263p_encode_umotion(PutBitContext *pb, int val)
533 {
534  short sval = 0;
535  short i = 0;
536  short n_bits = 0;
537  short temp_val;
538  int code = 0;
539  int tcode;
540 
541  if ( val == 0)
542  put_bits(pb, 1, 1);
543  else if (val == 1)
544  put_bits(pb, 3, 0);
545  else if (val == -1)
546  put_bits(pb, 3, 2);
547  else {
548 
549  sval = ((val < 0) ? (short)(-val):(short)val);
550  temp_val = sval;
551 
552  while (temp_val != 0) {
553  temp_val = temp_val >> 1;
554  n_bits++;
555  }
556 
557  i = n_bits - 1;
558  while (i > 0) {
559  tcode = (sval & (1 << (i-1))) >> (i-1);
560  tcode = (tcode << 1) | 1;
561  code = (code << 2) | tcode;
562  i--;
563  }
564  code = ((code << 1) | (val < 0)) << 1;
565  put_bits(pb, (2*n_bits)+1, code);
566  }
567 }
568 
569 static int h263_pred_dc(MPVEncContext *const s, int n, int16_t **dc_val_ptr)
570 {
571  int x, y, wrap, a, c, pred_dc;
572  int16_t *dc_val;
573 
574  /* find prediction */
575  if (n < 4) {
576  x = 2 * s->c.mb_x + (n & 1);
577  y = 2 * s->c.mb_y + ((n & 2) >> 1);
578  wrap = s->c.b8_stride;
579  dc_val = s->c.dc_val[0];
580  } else {
581  x = s->c.mb_x;
582  y = s->c.mb_y;
583  wrap = s->c.mb_stride;
584  dc_val = s->c.dc_val[n - 4 + 1];
585  }
586  /* B C
587  * A X
588  */
589  a = dc_val[(x - 1) + (y) * wrap];
590  c = dc_val[(x) + (y - 1) * wrap];
591 
592  /* No prediction outside GOB boundary */
593  if (s->c.first_slice_line && n != 3) {
594  if (n != 2) c = 1024;
595  if (n != 1 && s->c.mb_x == s->c.resync_mb_x) a = 1024;
596  }
597  /* just DC prediction */
598  if (a != 1024 && c != 1024)
599  pred_dc = (a + c) >> 1;
600  else if (a != 1024)
601  pred_dc = a;
602  else
603  pred_dc = c;
604 
605  /* we assume pred is positive */
606  *dc_val_ptr = &dc_val[x + y * wrap];
607  return pred_dc;
608 }
609 
610 static void h263_encode_mb(MPVEncContext *const s,
611  int16_t block[][64],
612  int motion_x, int motion_y)
613 {
614  int cbpc, cbpy, i, cbp, pred_x, pred_y;
615  int16_t pred_dc;
616  int16_t rec_intradc[6];
617  int16_t *dc_ptr[6];
618  const int interleaved_stats = s->c.avctx->flags & AV_CODEC_FLAG_PASS1;
619 
620  if (!s->c.mb_intra) {
621  /* compute cbp */
622  cbp= get_p_cbp(s, block, motion_x, motion_y);
623 
624  if ((cbp | motion_x | motion_y | s->dquant | (s->c.mv_type - MV_TYPE_16X16)) == 0) {
625  /* skip macroblock */
626  put_bits(&s->pb, 1, 1);
627  if(interleaved_stats){
628  s->misc_bits++;
629  s->last_bits++;
630  }
631 
632  return;
633  }
634  put_bits(&s->pb, 1, 0); /* mb coded */
635 
636  cbpc = cbp & 3;
637  cbpy = cbp >> 2;
638  if(s->c.alt_inter_vlc==0 || cbpc!=3)
639  cbpy ^= 0xF;
640  if(s->dquant) cbpc+= 8;
641  if(s->c.mv_type==MV_TYPE_16X16){
642  put_bits(&s->pb,
645 
646  put_bits(&s->pb, ff_h263_cbpy_tab[cbpy][1], ff_h263_cbpy_tab[cbpy][0]);
647  if(s->dquant)
648  put_bits(&s->pb, 2, dquant_code[s->dquant+2]);
649 
650  if(interleaved_stats){
651  s->misc_bits+= get_bits_diff(s);
652  }
653 
654  /* motion vectors: 16x16 mode */
655  ff_h263_pred_motion(&s->c, 0, 0, &pred_x, &pred_y);
656 
657  if (!s->c.umvplus) {
658  ff_h263_encode_motion_vector(s, motion_x - pred_x,
659  motion_y - pred_y, 1);
660  }
661  else {
662  h263p_encode_umotion(&s->pb, motion_x - pred_x);
663  h263p_encode_umotion(&s->pb, motion_y - pred_y);
664  if (((motion_x - pred_x) == 1) && ((motion_y - pred_y) == 1))
665  /* To prevent Start Code emulation */
666  put_bits(&s->pb,1,1);
667  }
668  }else{
669  put_bits(&s->pb,
670  ff_h263_inter_MCBPC_bits[cbpc+16],
671  ff_h263_inter_MCBPC_code[cbpc+16]);
672  put_bits(&s->pb, ff_h263_cbpy_tab[cbpy][1], ff_h263_cbpy_tab[cbpy][0]);
673  if(s->dquant)
674  put_bits(&s->pb, 2, dquant_code[s->dquant+2]);
675 
676  if(interleaved_stats){
677  s->misc_bits+= get_bits_diff(s);
678  }
679 
680  for(i=0; i<4; i++){
681  /* motion vectors: 8x8 mode*/
682  ff_h263_pred_motion(&s->c, i, 0, &pred_x, &pred_y);
683 
684  motion_x = s->c.cur_pic.motion_val[0][s->c.block_index[i]][0];
685  motion_y = s->c.cur_pic.motion_val[0][s->c.block_index[i]][1];
686  if (!s->c.umvplus) {
687  ff_h263_encode_motion_vector(s, motion_x - pred_x,
688  motion_y - pred_y, 1);
689  }
690  else {
691  h263p_encode_umotion(&s->pb, motion_x - pred_x);
692  h263p_encode_umotion(&s->pb, motion_y - pred_y);
693  if (((motion_x - pred_x) == 1) && ((motion_y - pred_y) == 1))
694  /* To prevent Start Code emulation */
695  put_bits(&s->pb,1,1);
696  }
697  }
698  }
699 
700  if(interleaved_stats){
701  s->mv_bits+= get_bits_diff(s);
702  }
703  } else {
704  av_assert2(s->c.mb_intra);
705 
706  cbp = 0;
707  if (s->c.h263_aic) {
708  /* Predict DC */
709  for(i=0; i<6; i++) {
710  int16_t level = block[i][0];
711  int scale = i < 4 ? s->c.y_dc_scale : s->c.c_dc_scale;
712 
713  pred_dc = h263_pred_dc(s, i, &dc_ptr[i]);
714  level -= pred_dc;
715  /* Quant */
716  if (level >= 0)
717  level = (level + (scale>>1))/scale;
718  else
719  level = (level - (scale>>1))/scale;
720 
721  if (!s->c.modified_quant) {
722  if (level < -127)
723  level = -127;
724  else if (level > 127)
725  level = 127;
726  }
727 
728  block[i][0] = level;
729  /* Reconstruction */
730  rec_intradc[i] = scale*level + pred_dc;
731  /* Oddify */
732  rec_intradc[i] |= 1;
733  //if ((rec_intradc[i] % 2) == 0)
734  // rec_intradc[i]++;
735  /* Clipping */
736  if (rec_intradc[i] < 0)
737  rec_intradc[i] = 0;
738  else if (rec_intradc[i] > 2047)
739  rec_intradc[i] = 2047;
740 
741  /* Update AC/DC tables */
742  *dc_ptr[i] = rec_intradc[i];
743  /* AIC can change CBP */
744  if (s->c.block_last_index[i] > 0 ||
745  (s->c.block_last_index[i] == 0 && level !=0))
746  cbp |= 1 << (5 - i);
747  }
748  }else{
749  for(i=0; i<6; i++) {
750  /* compute cbp */
751  if (s->c.block_last_index[i] >= 1)
752  cbp |= 1 << (5 - i);
753  }
754  }
755 
756  cbpc = cbp & 3;
757  if (s->c.pict_type == AV_PICTURE_TYPE_I) {
758  if(s->dquant) cbpc+=4;
759  put_bits(&s->pb,
762  } else {
763  if(s->dquant) cbpc+=8;
764  put_bits(&s->pb, 1, 0); /* mb coded */
765  put_bits(&s->pb,
766  ff_h263_inter_MCBPC_bits[cbpc + 4],
767  ff_h263_inter_MCBPC_code[cbpc + 4]);
768  }
769  if (s->c.h263_aic) {
770  /* XXX: currently, we do not try to use ac prediction */
771  put_bits(&s->pb, 1, 0); /* no AC prediction */
772  }
773  cbpy = cbp >> 2;
774  put_bits(&s->pb, ff_h263_cbpy_tab[cbpy][1], ff_h263_cbpy_tab[cbpy][0]);
775  if(s->dquant)
776  put_bits(&s->pb, 2, dquant_code[s->dquant+2]);
777 
778  if(interleaved_stats){
779  s->misc_bits+= get_bits_diff(s);
780  }
781  }
782 
783  for(i=0; i<6; i++) {
784  /* encode each block */
785  h263_encode_block(s, block[i], i);
786 
787  /* Update INTRADC for decoding */
788  if (s->c.h263_aic && s->c.mb_intra)
789  block[i][0] = rec_intradc[i];
790  }
791 
792  if(interleaved_stats){
793  if (!s->c.mb_intra) {
794  s->p_tex_bits+= get_bits_diff(s);
795  }else{
796  s->i_tex_bits+= get_bits_diff(s);
797  s->i_count++;
798  }
799  }
800 }
801 
802 void ff_h263_update_mb(MPVEncContext *const s)
803 {
804  const int mb_xy = s->c.mb_y * s->c.mb_stride + s->c.mb_x;
805 
806  if (s->c.cur_pic.mbskip_table)
807  s->c.cur_pic.mbskip_table[mb_xy] = s->c.mb_skipped;
808 
809  if (s->c.mv_type == MV_TYPE_8X8)
810  s->c.cur_pic.mb_type[mb_xy] = MB_TYPE_FORWARD_MV | MB_TYPE_8x8;
811  else if(s->c.mb_intra)
812  s->c.cur_pic.mb_type[mb_xy] = MB_TYPE_INTRA;
813  else
814  s->c.cur_pic.mb_type[mb_xy] = MB_TYPE_FORWARD_MV | MB_TYPE_16x16;
815 
817 }
818 
820 {
821  MPVEncContext *const s = &m->s;
822 
823  s->me.mv_penalty = ff_h263_get_mv_penalty(); // FIXME exact table for MSMPEG4 & H.263+
824 
825  ff_h263dsp_init(&s->c.h263dsp);
826 
827  if (s->c.codec_id == AV_CODEC_ID_MPEG4)
828  return;
829 
830  s->intra_ac_vlc_length =s->inter_ac_vlc_length = uni_h263_inter_rl_len;
831  s->intra_ac_vlc_last_length=s->inter_ac_vlc_last_length= uni_h263_inter_rl_len + 128*64;
832  if (s->c.h263_aic) {
833  s->intra_ac_vlc_length = uni_h263_intra_aic_rl_len;
834  s->intra_ac_vlc_last_length= uni_h263_intra_aic_rl_len + 128*64;
835 
836  s->c.y_dc_scale_table =
837  s->c.c_dc_scale_table = ff_aic_dc_scale_table;
838  }
839  s->ac_esc_length= 7+1+6+8;
840 
841  if (s->c.modified_quant)
842  s->c.chroma_qscale_table = ff_h263_chroma_qscale_table;
843 
844  // use fcodes >1 only for MPEG-4 & H.263 & H.263+ FIXME
845  switch(s->c.codec_id){
846  case AV_CODEC_ID_H263P:
847  if (s->c.umvplus)
849  if (s->c.modified_quant) {
850  s->min_qcoeff= -2047;
851  s->max_qcoeff= 2047;
852  }else{
853  s->min_qcoeff= -127;
854  s->max_qcoeff= 127;
855  }
856  break;
857  // Note for MPEG-4 & H.263 the dc-scale table will be set per frame as needed later
858 #if CONFIG_FLV_ENCODER
859  case AV_CODEC_ID_FLV1:
861  if (s->c.h263_flv > 1) {
862  s->min_qcoeff= -1023;
863  s->max_qcoeff= 1023;
864  } else {
865  s->min_qcoeff= -127;
866  s->max_qcoeff= 127;
867  }
868  break;
869 #endif
870  default: //nothing needed - default table already set in mpegvideo.c
871  s->min_qcoeff= -127;
872  s->max_qcoeff= 127;
873  }
874  // H.263, H.263+; will be overwritten for MSMPEG-4 later
875  if (!m->encode_picture_header)
876  m->encode_picture_header = h263_encode_picture_header;
877  if (!s->encode_mb)
878  s->encode_mb = h263_encode_mb;
879 }
880 
882 {
883  int i, mb_pos;
884 
885  for(i=0; i<6; i++){
886  if(s->c.mb_num-1 <= ff_mba_max[i]) break;
887  }
888  mb_pos= s->c.mb_x + s->c.mb_width*s->c.mb_y;
889  put_bits(&s->pb, ff_mba_length[i], mb_pos);
890 }
891 
892 #define OFFSET(x) offsetof(MpegEncContext, x)
893 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
894 static const AVOption h263_options[] = {
895  { "obmc", "use overlapped block motion compensation.", OFFSET(obmc), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
896  { "mb_info", "emit macroblock info for RFC 2190 packetization, the parameter value is the maximum payload size", FF_MPV_OFFSET(mb_info), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, INT_MAX, VE },
899  { NULL },
900 };
901 
902 static const AVClass h263_class = {
903  .class_name = "H.263 encoder",
904  .item_name = av_default_item_name,
905  .option = h263_options,
906  .version = LIBAVUTIL_VERSION_INT,
907 };
908 
909 const FFCodec ff_h263_encoder = {
910  .p.name = "h263",
911  CODEC_LONG_NAME("H.263 / H.263-1996"),
912  .p.type = AVMEDIA_TYPE_VIDEO,
913  .p.id = AV_CODEC_ID_H263,
915  .color_ranges = AVCOL_RANGE_MPEG,
916  .p.priv_class = &h263_class,
918  .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
919  .priv_data_size = sizeof(MPVMainEncContext),
922  .close = ff_mpv_encode_end,
923 };
924 
925 static const AVOption h263p_options[] = {
926  { "umv", "Use unlimited motion vectors.", OFFSET(umvplus), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
927  { "aiv", "Use alternative inter VLC.", OFFSET(alt_inter_vlc), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
928  { "obmc", "use overlapped block motion compensation.", OFFSET(obmc), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE },
929  { "structured_slices", "Write slice start position at every GOB header instead of just GOB number.", OFFSET(h263_slice_structured), AV_OPT_TYPE_BOOL, { .i64 = 0 }, 0, 1, VE},
932  { NULL },
933 };
934 static const AVClass h263p_class = {
935  .class_name = "H.263p encoder",
936  .item_name = av_default_item_name,
937  .option = h263p_options,
938  .version = LIBAVUTIL_VERSION_INT,
939 };
940 
941 const FFCodec ff_h263p_encoder = {
942  .p.name = "h263p",
943  CODEC_LONG_NAME("H.263+ / H.263-1998 / H.263 version 2"),
944  .p.type = AVMEDIA_TYPE_VIDEO,
945  .p.id = AV_CODEC_ID_H263P,
947  .color_ranges = AVCOL_RANGE_MPEG,
948  .p.priv_class = &h263p_class,
949  .p.capabilities = AV_CODEC_CAP_DR1 | AV_CODEC_CAP_SLICE_THREADS |
951  .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
952  .priv_data_size = sizeof(MPVMainEncContext),
955  .close = ff_mpv_encode_end,
956 };
957 #endif
error
static void error(const char *err)
Definition: target_bsf_fuzzer.c:32
MPVMainEncContext::fcode_tab
const uint8_t * fcode_tab
smallest fcode needed for each MV
Definition: mpegvideoenc.h:212
CODEC_PIXFMTS
#define CODEC_PIXFMTS(...)
Definition: codec_internal.h:386
MV_TYPE_16X16
#define MV_TYPE_16X16
1 vector for the whole mb
Definition: mpegvideo.h:192
h263data.h
FF_ASPECT_EXTENDED
#define FF_ASPECT_EXTENDED
Definition: h263.h:26
level
uint8_t level
Definition: svq3.c:205
av_clip
#define av_clip
Definition: common.h:100
MPVEncContext
Definition: mpegvideoenc.h:45
FF_CODEC_CAP_INIT_CLEANUP
#define FF_CODEC_CAP_INIT_CLEANUP
The codec allows calling the close function for deallocation even if the init function returned a fai...
Definition: codec_internal.h:42
align_put_bits
static void align_put_bits(PutBitContext *s)
Pad the bitstream with zeros up to the next byte boundary.
Definition: put_bits.h:435
uni_h263_inter_rl_len
static uint8_t uni_h263_inter_rl_len[64 *64 *2 *2]
Definition: ituh263enc.c:64
UNI_MPEG4_ENC_INDEX
#define UNI_MPEG4_ENC_INDEX(last, run, level)
Definition: ituh263enc.c:67
MAX_FCODE
#define MAX_FCODE
Definition: mpegvideoenc.h:258
thread.h
mpegvideoenc.h
int64_t
long long int64_t
Definition: coverity.c:34
mv
static const int8_t mv[256][2]
Definition: 4xm.c:81
put_sbits
static void put_sbits(PutBitContext *pb, int n, int32_t value)
Definition: put_bits.h:281
MAX_RUN
#define MAX_RUN
Definition: rl.h:35
h263enc.h
ff_clean_h263_qscales
void ff_clean_h263_qscales(MPVEncContext *s)
AV_CODEC_ID_MPEG4
@ AV_CODEC_ID_MPEG4
Definition: codec_id.h:64
CANDIDATE_MB_TYPE_INTER
#define CANDIDATE_MB_TYPE_INTER
Definition: mpegvideoenc.h:264
put_bits
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
Definition: j2kenc.c:223
MAX_DMV
#define MAX_DMV
Definition: motion_est.h:39
internal.h
av_const
#define av_const
Definition: attributes.h:84
h263dsp.h
AVOption
AVOption.
Definition: opt.h:429
MB_TYPE_16x16
#define MB_TYPE_16x16
Definition: mpegutils.h:41
FFCodec
Definition: codec_internal.h:127
init_uni_h263_rl_tab
static av_cold void init_uni_h263_rl_tab(const RLTable *rl, uint8_t *len_tab)
Definition: ituh263enc.c:100
mpegvideo.h
mpegutils.h
MPVMainEncContext::encode_picture_header
int(* encode_picture_header)(struct MPVMainEncContext *m)
Definition: mpegvideoenc.h:221
FF_MPV_COMMON_MOTION_EST_OPTS
#define FF_MPV_COMMON_MOTION_EST_OPTS
Definition: mpegvideoenc.h:350
ff_mpv_encode_picture
int ff_mpv_encode_picture(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pic_arg, int *got_packet)
Definition: mpegvideo_enc.c:1926
FF_MPV_COMMON_OPTS
#define FF_MPV_COMMON_OPTS
Definition: mpegvideoenc.h:309
FFCodec::p
AVCodec p
The public AVCodec.
Definition: codec_internal.h:131
ff_match_2uint16
int ff_match_2uint16(const uint16_t(*tab)[2], int size, int a, int b)
Return the index into tab at which {a,b} match elements {[0],[1]} of tab.
Definition: utils.c:829
ff_h263_pred_motion
int16_t * ff_h263_pred_motion(MpegEncContext *s, int block, int dir, int *px, int *py)
Definition: h263.c:179
wrap
#define wrap(func)
Definition: neontest.h:65
ff_h263_pixel_aspect
const AVRational ff_h263_pixel_aspect[16]
Definition: h263data.c:273
RLTable
RLTable.
Definition: rl.h:39
mv_penalty
static uint8_t mv_penalty[MAX_FCODE+1][MAX_DMV *2+1]
Table of number of bits a motion vector component needs.
Definition: ituh263enc.c:53
ff_h263_encode_init
void ff_h263_encode_init(MPVMainEncContext *m)
val
static double val(void *priv, double ch)
Definition: aeval.c:77
FF_CODEC_ENCODE_CB
#define FF_CODEC_ENCODE_CB(func)
Definition: codec_internal.h:353
ff_h263_update_motion_val
void ff_h263_update_motion_val(MpegEncContext *s)
Definition: h263.c:53
AVRational::num
int num
Numerator.
Definition: rational.h:59
dquant_code
static const int dquant_code[5]
Definition: mpeg4videoenc.c:499
RLTable::n
int n
number of entries of table_vlc minus 1
Definition: rl.h:40
ff_thread_once
static int ff_thread_once(char *control, void(*routine)(void))
Definition: thread.h:205
ff_h263_encode_motion
void ff_h263_encode_motion(PutBitContext *pb, int val, int f_code)
Definition: ituh263enc.c:162
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
av_cold
#define av_cold
Definition: attributes.h:90
ff_h263_encode_gob_header
void ff_h263_encode_gob_header(MPVEncContext *s, int mb_line)
MAX_MV
#define MAX_MV
Definition: motion_est.h:37
ff_h263_chroma_qscale_table
const uint8_t ff_h263_chroma_qscale_table[32]
Definition: h263data.c:260
s
#define s(width, name)
Definition: cbs_vp9.c:198
format
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample format(the sample packing is implied by the sample format) and sample rate. The lists are not just lists
get_rl_index
static int get_rl_index(const RLTable *rl, int last, int run, int level)
Definition: rl.h:101
AV_CODEC_CAP_ENCODER_REORDERED_OPAQUE
#define AV_CODEC_CAP_ENCODER_REORDERED_OPAQUE
This encoder can reorder user opaque values from input AVFrames and return them with corresponding ou...
Definition: codec.h:144
bits
uint8_t bits
Definition: vp3data.h:128
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:40
limits.h
FF_MPV_OFFSET
#define FF_MPV_OFFSET(x)
Definition: mpegvideoenc.h:305
ff_h263_get_mv_penalty
const av_cold uint8_t(* ff_h263_get_mv_penalty(void))[MAX_DMV *2+1]
Definition: ituh263enc.c:153
AV_PIX_FMT_YUV420P
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
Definition: pixfmt.h:73
ff_h263_encode_mba
void ff_h263_encode_mba(MPVEncContext *s)
PutBitContext
Definition: put_bits.h:50
ff_rl_init
av_cold void ff_rl_init(RLTable *rl, uint8_t static_store[2][2 *MAX_RUN+MAX_LEVEL+3])
Initialize index_run, max_level and max_run from n, last, table_vlc, table_run and table_level.
Definition: rl.c:43
CODEC_LONG_NAME
#define CODEC_LONG_NAME(str)
Definition: codec_internal.h:326
FFABS
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
Definition: common.h:74
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
AV_ONCE_INIT
#define AV_ONCE_INIT
Definition: thread.h:203
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:75
NULL
#define NULL
Definition: coverity.c:32
init_mv_penalty_and_fcode
static av_cold void init_mv_penalty_and_fcode(void)
Definition: ituh263enc.c:69
run
uint8_t run
Definition: svq3.c:204
RLTable::table_vlc
const uint16_t(* table_vlc)[2]
Definition: rl.h:42
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
MB_TYPE_8x8
#define MB_TYPE_8x8
Definition: mpegutils.h:44
uni_h263_intra_aic_rl_len
static uint8_t uni_h263_intra_aic_rl_len[64 *64 *2 *2]
Definition: ituh263enc.c:63
av_default_item_name
const char * av_default_item_name(void *ptr)
Return the context name.
Definition: log.c:239
AV_PICTURE_TYPE_I
@ AV_PICTURE_TYPE_I
Intra.
Definition: avutil.h:279
mathops.h
ff_mba_max
const uint16_t ff_mba_max[6]
Definition: h263data.c:265
ff_mpv_encode_end
av_cold int ff_mpv_encode_end(AVCodecContext *avctx)
Definition: mpegvideo_enc.c:1104
get_p_cbp
static int get_p_cbp(MPVEncContext *const s, int16_t block[6][64], int motion_x, int motion_y)
Definition: h263enc.h:45
MPVMainEncContext
Definition: mpegvideoenc.h:172
AVOnce
#define AVOnce
Definition: thread.h:202
index
int index
Definition: gxfenc.c:90
c
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
Definition: undefined.txt:32
MV_TYPE_8X8
#define MV_TYPE_8X8
4 vectors (H.263, MPEG-4 4MV)
Definition: mpegvideo.h:193
MAX_LEVEL
#define MAX_LEVEL
Definition: rl.h:36
init
int(* init)(AVBSFContext *ctx)
Definition: dts2pts.c:368
AV_CODEC_CAP_DR1
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() or get_encode_buffer() for allocating buffers and supports custom allocators.
Definition: codec.h:52
ff_h263_rl_inter
RLTable ff_h263_rl_inter
Definition: h263data.c:159
codec_internal.h
AV_CODEC_ID_H263
@ AV_CODEC_ID_H263
Definition: codec_id.h:56
ff_h263_cbpy_tab
const uint8_t ff_h263_cbpy_tab[16][2]
Definition: h263data.c:82
ff_h263p_encoder
const FFCodec ff_h263p_encoder
ff_rl_intra_aic
RLTable ff_rl_intra_aic
Definition: h263data.c:228
ff_h263dsp_init
av_cold void ff_h263dsp_init(H263DSPContext *ctx)
Definition: h263dsp.c:117
range
enum AVColorRange range
Definition: mediacodec_wrapper.c:2594
a
The reader does not expect b to be semantically here and if the code is changed by maybe adding a a division or other the signedness will almost certainly be mistaken To avoid this confusion a new type was SUINT is the C unsigned type but it holds a signed int to use the same example SUINT a
Definition: undefined.txt:41
AV_CODEC_CAP_SLICE_THREADS
#define AV_CODEC_CAP_SLICE_THREADS
Codec supports slice-based (or partition-based) multithreading.
Definition: codec.h:99
attributes.h
ff_h263_inter_MCBPC_bits
const uint8_t ff_h263_inter_MCBPC_bits[28]
Definition: h263data.c:47
pred_dc
static void FUNC() pred_dc(uint8_t *_src, const uint8_t *_top, const uint8_t *_left, ptrdiff_t stride, int log2_size, int c_idx)
Definition: pred_template.c:391
CANDIDATE_MB_TYPE_INTER4V
#define CANDIDATE_MB_TYPE_INTER4V
Definition: mpegvideoenc.h:265
get_bits_diff
static int get_bits_diff(MPVEncContext *s)
Definition: mpegvideoenc.h:382
av_assert2
#define av_assert2(cond)
assert() equivalent, that does lie in speed critical code.
Definition: avassert.h:67
ff_h263_encoder
const FFCodec ff_h263_encoder
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
code
and forward the test the status of outputs and forward it to the corresponding return FFERROR_NOT_READY If the filters stores internally one or a few frame for some it can consider them to be part of the FIFO and delay acknowledging a status change accordingly Example code
Definition: filter_design.txt:178
ff_h263_update_mb
void ff_h263_update_mb(MPVEncContext *s)
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:56
ff_h263_format
const uint16_t ff_h263_format[8][2]
Definition: h263data.c:236
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:179
ff_h263_aspect_to_info
av_const int ff_h263_aspect_to_info(AVRational aspect)
len
int len
Definition: vorbis_enc_data.h:426
ff_flv_encode_picture_header
int ff_flv_encode_picture_header(MPVMainEncContext *const m)
Definition: flvenc.c:26
AVCOL_RANGE_MPEG
@ AVCOL_RANGE_MPEG
Narrow or limited range content.
Definition: pixfmt.h:733
ff_flv2_encode_ac_esc
void ff_flv2_encode_ac_esc(PutBitContext *pb, int slevel, int level, int run, int last)
Definition: flvenc.c:69
avcodec.h
av_cmp_q
static int av_cmp_q(AVRational a, AVRational b)
Compare two rationals.
Definition: rational.h:89
h263_encode_init_static
static av_cold void h263_encode_init_static(void)
Definition: ituh263enc.c:140
AVClass::class_name
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
Definition: log.h:80
ff_aic_dc_scale_table
const uint8_t ff_aic_dc_scale_table[32]
Definition: h263data.c:245
ff_mvtab
const uint8_t ff_mvtab[33][2]
Definition: h263data.c:88
ff_h263_intra_MCBPC_bits
const uint8_t ff_h263_intra_MCBPC_bits[9]
Definition: h263data.c:33
OFFSET
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option keep it simple and lowercase description are in without and describe what they for example set the foo of the bar offset is the offset of the field in your see the OFFSET() macro
AV_CODEC_ID_H263P
@ AV_CODEC_ID_H263P
Definition: codec_id.h:71
ff_h263_intra_MCBPC_code
const uint8_t ff_h263_intra_MCBPC_code[9]
Definition: h263data.c:32
AVRational::den
int den
Denominator.
Definition: rational.h:60
umv_fcode_tab
static uint8_t umv_fcode_tab[MAX_MV *2+1]
Minimal fcode that a motion vector component would need in umv.
Definition: ituh263enc.c:59
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Underlying C type is int.
Definition: opt.h:259
sign_extend
static av_const int sign_extend(int val, unsigned bits)
Definition: mathops.h:131
ff_mba_length
const uint8_t ff_mba_length[7]
Definition: h263data.c:269
flvenc.h
ff_h263_inter_MCBPC_code
const uint8_t ff_h263_inter_MCBPC_code[28]
Definition: h263data.c:38
AV_PICTURE_TYPE_P
@ AV_PICTURE_TYPE_P
Predicted.
Definition: avutil.h:280
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
ff_mpv_encode_init
av_cold int ff_mpv_encode_init(AVCodecContext *avctx)
Definition: mpegvideo_enc.c:544
scale
static void scale(int *out, const int *in, const int w, const int h, const int shift)
Definition: intra.c:291
AV_OPT_TYPE_BOOL
@ AV_OPT_TYPE_BOOL
Underlying C type is int.
Definition: opt.h:327
ff_h263_encode_motion_vector
static void ff_h263_encode_motion_vector(MPVEncContext *s, int x, int y, int f_code)
Definition: h263enc.h:38
block
The exact code depends on how similar the blocks are and how related they are to the block
Definition: filter_design.txt:207
VE
#define VE
Definition: amfenc_av1.c:30
ff_h263_init_rl_inter
av_cold void ff_h263_init_rl_inter(void)
Definition: h263.c:47
AV_CODEC_ID_FLV1
@ AV_CODEC_ID_FLV1
Definition: codec_id.h:73
av_log2
int av_log2(unsigned v)
Definition: intmath.c:26
MPVMainEncContext::s
MPVEncContext s
The main slicecontext.
Definition: mpegvideoenc.h:173
mb_info
Definition: cinepakenc.c:87
MB_TYPE_FORWARD_MV
#define MB_TYPE_FORWARD_MV
Definition: mpegutils.h:49
MB_TYPE_INTRA
#define MB_TYPE_INTRA
Definition: mpegutils.h:64
AV_CODEC_FLAG_PASS1
#define AV_CODEC_FLAG_PASS1
Use internal 2pass ratecontrol in first pass mode.
Definition: avcodec.h:290
h263.h