FFmpeg
svq1enc.c
Go to the documentation of this file.
1 /*
2  * SVQ1 Encoder
3  * Copyright (C) 2004 Mike Melanson <melanson@pcisys.net>
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 /**
23  * @file
24  * Sorenson Vector Quantizer #1 (SVQ1) video codec.
25  * For more information of the SVQ1 algorithm, visit:
26  * http://www.pcisys.net/~melanson/codecs/
27  */
28 
29 #include "libavutil/emms.h"
30 #include "libavutil/mem.h"
31 #include "avcodec.h"
32 #include "codec_internal.h"
33 #include "encode.h"
34 #include "hpeldsp.h"
35 #include "me_cmp.h"
36 #include "mpegvideo.h"
37 #include "h263.h"
38 #include "h263enc.h"
39 #include "internal.h"
40 #include "mpegutils.h"
41 #include "packet_internal.h"
42 #include "put_bits.h"
43 #include "svq1.h"
44 #include "svq1encdsp.h"
45 #include "svq1enc_cb.h"
46 #include "version.h"
47 
48 #include "libavutil/avassert.h"
49 #include "libavutil/frame.h"
50 #include "libavutil/mem_internal.h"
51 
52 // Workaround for GCC bug 102513
53 #if AV_GCC_VERSION_AT_LEAST(10, 0) && AV_GCC_VERSION_AT_MOST(12, 0) \
54  && !defined(__clang__) && !defined(__INTEL_COMPILER)
55 #pragma GCC optimize ("no-ipa-cp-clone")
56 #endif
57 
58 typedef struct SVQ1EncContext {
59  /* FIXME: Needed for motion estimation, should not be used for anything
60  * else, the idea is to make the motion estimation eventually independent
61  * of MPVEncContext, so this will be removed then. */
68 
69  /* Some compression statistics */
71  int quality;
72 
73  /* why ooh why this sick breadth first order,
74  * everything is slower and more complex */
76 
79 
80  /* Y plane block dimensions */
83 
84  /* U & V plane (C planes) block dimensions */
87 
88  DECLARE_ALIGNED(16, int16_t, encoded_block_levels)[6][7][256];
89 
90  uint16_t *mb_type;
91  uint32_t *dummy;
92  int16_t (*motion_val8[3])[2];
93  int16_t (*motion_val16[3])[2];
94 
96 
97  uint8_t *scratchbuf;
98 
101 
103 {
104  int i;
105 
106  /* frame code */
107  put_bits(pb, 22, 0x20);
108 
109  /* temporal reference (sure hope this is a "don't care") */
110  put_bits(pb, 8, 0x00);
111 
112  /* frame type */
113  put_bits(pb, 2, frame_type - 1);
114 
115  if (frame_type == AV_PICTURE_TYPE_I) {
116  /* no checksum since frame code is 0x20 */
117  /* no embedded string either */
118  /* output 5 unknown bits (2 + 2 + 1) */
119  put_bits(pb, 5, 2); /* 2 needed by quicktime decoder */
120 
123  s->frame_width, s->frame_height);
124  put_bits(pb, 3, i);
125 
126  if (i == 7) {
127  put_bits(pb, 12, s->frame_width);
128  put_bits(pb, 12, s->frame_height);
129  }
130  }
131 
132  /* no checksum or extra data (next 2 bits get 0) */
133  put_bits(pb, 2, 0);
134 }
135 
136 #define QUALITY_THRESHOLD 100
137 #define THRESHOLD_MULTIPLIER 0.6
138 
139 static int encode_block(SVQ1EncContext *s, uint8_t *src, uint8_t *ref,
140  uint8_t *decoded, int stride, unsigned level,
141  int threshold, int lambda, int intra)
142 {
143  int count, y, x, i, j, split, best_mean, best_score, best_count;
144  int best_vector[6];
145  int block_sum[7] = { 0, 0, 0, 0, 0, 0 };
146  int w = 2 << (level + 2 >> 1);
147  int h = 2 << (level + 1 >> 1);
148  int size = w * h;
149  int16_t (*block)[256] = s->encoded_block_levels[level];
150  const int8_t *codebook_sum, *codebook;
151  const uint16_t(*mean_vlc)[2];
152  const uint8_t(*multistage_vlc)[2];
153 
154  best_score = 0;
155  // FIXME: Optimize, this does not need to be done multiple times.
156  if (intra) {
157  // level is 5 when encode_block is called from svq1_encode_plane
158  // and always < 4 when called recursively from this function.
159  codebook_sum = level < 4 ? svq1_intra_codebook_sum[level] : NULL;
161  mean_vlc = ff_svq1_intra_mean_vlc;
162  multistage_vlc = ff_svq1_intra_multistage_vlc[level];
163  for (y = 0; y < h; y++) {
164  for (x = 0; x < w; x++) {
165  int v = src[x + y * stride];
166  block[0][x + w * y] = v;
167  best_score += v * v;
168  block_sum[0] += v;
169  }
170  }
171  } else {
172  // level is 5 or < 4, see above for details.
173  codebook_sum = level < 4 ? svq1_inter_codebook_sum[level] : NULL;
175  mean_vlc = ff_svq1_inter_mean_vlc + 256;
176  multistage_vlc = ff_svq1_inter_multistage_vlc[level];
177  for (y = 0; y < h; y++) {
178  for (x = 0; x < w; x++) {
179  int v = src[x + y * stride] - ref[x + y * stride];
180  block[0][x + w * y] = v;
181  best_score += v * v;
182  block_sum[0] += v;
183  }
184  }
185  }
186 
187  best_count = 0;
188  best_score -= (int)((unsigned)block_sum[0] * block_sum[0] >> (level + 3));
189  best_mean = block_sum[0] + (size >> 1) >> (level + 3);
190 
191  if (level < 4) {
192  for (count = 1; count < 7; count++) {
193  int best_vector_score = INT_MAX;
194  int best_vector_sum = -999, best_vector_mean = -999;
195  const int stage = count - 1;
196  const int8_t *vector;
197 
198  for (i = 0; i < 16; i++) {
199  int sum = codebook_sum[stage * 16 + i];
200  int sqr, diff, score;
201 
202  vector = codebook + stage * size * 16 + i * size;
203  sqr = s->svq1encdsp.ssd_int8_vs_int16(vector, block[stage], size);
204  diff = block_sum[stage] - sum;
205  score = sqr - (diff * (int64_t)diff >> (level + 3)); // FIXME: 64 bits slooow
206  if (score < best_vector_score) {
207  int mean = diff + (size >> 1) >> (level + 3);
208  av_assert2(mean > -300 && mean < 300);
209  mean = av_clip(mean, intra ? 0 : -256, 255);
210  best_vector_score = score;
211  best_vector[stage] = i;
212  best_vector_sum = sum;
213  best_vector_mean = mean;
214  }
215  }
216  av_assert0(best_vector_mean != -999);
217  vector = codebook + stage * size * 16 + best_vector[stage] * size;
218  for (j = 0; j < size; j++)
219  block[stage + 1][j] = block[stage][j] - vector[j];
220  block_sum[stage + 1] = block_sum[stage] - best_vector_sum;
221  best_vector_score += lambda *
222  (+1 + 4 * count +
223  multistage_vlc[1 + count][1]
224  + mean_vlc[best_vector_mean][1]);
225 
226  if (best_vector_score < best_score) {
227  best_score = best_vector_score;
228  best_count = count;
229  best_mean = best_vector_mean;
230  }
231  }
232  }
233 
234  if (best_mean == -128)
235  best_mean = -127;
236  else if (best_mean == 128)
237  best_mean = 127;
238 
239  split = 0;
240  if (best_score > threshold && level) {
241  int score = 0;
242  int offset = level & 1 ? stride * h / 2 : w / 2;
243  PutBitContext backup[6];
244 
245  for (i = level - 1; i >= 0; i--)
246  backup[i] = s->reorder_pb[i];
247  score += encode_block(s, src, ref, decoded, stride, level - 1,
248  threshold >> 1, lambda, intra);
249  score += encode_block(s, src + offset, ref + offset, decoded + offset,
250  stride, level - 1, threshold >> 1, lambda, intra);
251  score += lambda;
252 
253  if (score < best_score) {
254  best_score = score;
255  split = 1;
256  } else {
257  for (i = level - 1; i >= 0; i--)
258  s->reorder_pb[i] = backup[i];
259  }
260  }
261  if (level > 0)
262  put_bits(&s->reorder_pb[level], 1, split);
263 
264  if (!split) {
265  av_assert1(best_mean >= 0 && best_mean < 256 || !intra);
266  av_assert1(best_mean >= -256 && best_mean < 256);
267  av_assert1(best_count >= 0 && best_count < 7);
268  av_assert1(level < 4 || best_count == 0);
269 
270  /* output the encoding */
271  put_bits(&s->reorder_pb[level],
272  multistage_vlc[1 + best_count][1],
273  multistage_vlc[1 + best_count][0]);
274  put_bits(&s->reorder_pb[level], mean_vlc[best_mean][1],
275  mean_vlc[best_mean][0]);
276 
277  for (i = 0; i < best_count; i++) {
278  av_assert2(best_vector[i] >= 0 && best_vector[i] < 16);
279  put_bits(&s->reorder_pb[level], 4, best_vector[i]);
280  }
281 
282  for (y = 0; y < h; y++)
283  for (x = 0; x < w; x++)
284  decoded[x + y * stride] = src[x + y * stride] -
285  block[best_count][x + w * y] +
286  best_mean;
287  }
288 
289  return best_score;
290 }
291 
292 static void init_block_index(MpegEncContext *const s)
293 {
294  s->block_index[0]= s->b8_stride*(s->mb_y*2 ) + s->mb_x*2;
295  s->block_index[1]= s->b8_stride*(s->mb_y*2 ) + 1 + s->mb_x*2;
296  s->block_index[2]= s->b8_stride*(s->mb_y*2 + 1) + s->mb_x*2;
297  s->block_index[3]= s->b8_stride*(s->mb_y*2 + 1) + 1 + s->mb_x*2;
298  s->block_index[4]= s->mb_stride*(s->mb_y + 1) + s->b8_stride*s->mb_height*2 + s->mb_x;
299  s->block_index[5]= s->mb_stride*(s->mb_y + s->mb_height + 2) + s->b8_stride*s->mb_height*2 + s->mb_x;
300 }
301 
302 static int svq1_encode_plane(SVQ1EncContext *s, int plane,
303  PutBitContext *pb,
304  const unsigned char *src_plane,
305  unsigned char *ref_plane,
306  unsigned char *decoded_plane,
307  int width, int height, int src_stride, int stride)
308 {
309  MpegEncContext *const s2 = &s->m.c;
310  int x, y;
311  int i;
312  int block_width, block_height;
313  int level;
314  int threshold[6];
315  uint8_t *src = s->scratchbuf + stride * 32;
316  const int lambda = (s->quality * s->quality) >>
317  (2 * FF_LAMBDA_SHIFT);
318 
319  /* figure out the acceptable level thresholds in advance */
320  threshold[5] = QUALITY_THRESHOLD;
321  for (level = 4; level >= 0; level--)
322  threshold[level] = threshold[level + 1] * THRESHOLD_MULTIPLIER;
323 
324  block_width = (width + 15) / 16;
325  block_height = (height + 15) / 16;
326 
327  if (s->pict_type == AV_PICTURE_TYPE_P) {
328  s2->avctx = s->avctx;
329  s2->last_pic.data[0] = ref_plane;
330  s2->linesize =
331  s2->last_pic.linesize[0] =
332  s->m.new_pic->linesize[0] =
333  s2->cur_pic.linesize[0] = stride;
334  s2->width = width;
335  s2->height = height;
336  s2->mb_width = block_width;
337  s2->mb_height = block_height;
338  s2->mb_stride = s2->mb_width + 1;
339  s2->b8_stride = 2 * s2->mb_width + 1;
340  s2->f_code = 1;
341  s2->pict_type = s->pict_type;
342  s->m.me.scene_change_score = 0;
343  // s2->out_format = FMT_H263;
344  // s2->unrestricted_mv = 1;
345  s->m.lambda = s->quality;
346  s2->qscale = s->m.lambda * 139 +
347  FF_LAMBDA_SCALE * 64 >>
348  FF_LAMBDA_SHIFT + 7;
349  s->m.lambda2 = s->m.lambda * s->m.lambda +
350  FF_LAMBDA_SCALE / 2 >>
352 
353  if (!s->motion_val8[plane]) {
354  s->motion_val8[plane] = av_mallocz((s2->b8_stride *
355  block_height * 2 + 2) *
356  2 * sizeof(int16_t));
357  s->motion_val16[plane] = av_mallocz((s2->mb_stride *
358  (block_height + 2) + 1) *
359  2 * sizeof(int16_t));
360  if (!s->motion_val8[plane] || !s->motion_val16[plane])
361  return AVERROR(ENOMEM);
362  }
363 
364  s->m.mb_type = s->mb_type;
365 
366  // dummies, to avoid segfaults
367  s->m.mb_mean = (uint8_t *)s->dummy;
368  s->m.mb_var = (uint16_t *)s->dummy;
369  s->m.mc_mb_var = (uint16_t *)s->dummy;
370  s2->cur_pic.mb_type = s->dummy;
371 
372  s2->cur_pic.motion_val[0] = s->motion_val8[plane] + 2;
373  s->m.p_mv_table = s->motion_val16[plane] +
374  s2->mb_stride + 1;
375  ff_me_init_pic(&s->m);
376 
377  s->m.me.dia_size = s->avctx->dia_size;
378  s2->first_slice_line = 1;
379  for (y = 0; y < block_height; y++) {
380  s->m.new_pic->data[0] = src - y * 16 * stride; // ugly
381  s2->mb_y = y;
382 
383  for (i = 0; i < 16 && i + 16 * y < height; i++) {
384  memcpy(&src[i * stride], &src_plane[(i + 16 * y) * src_stride],
385  width);
386  for (x = width; x < 16 * block_width; x++)
387  src[i * stride + x] = src[i * stride + x - 1];
388  }
389  for (; i < 16 && i + 16 * y < 16 * block_height; i++)
390  memcpy(&src[i * stride], &src[(i - 1) * stride],
391  16 * block_width);
392 
393  for (x = 0; x < block_width; x++) {
394  s2->mb_x = x;
395  init_block_index(s2);
396 
397  ff_estimate_p_frame_motion(&s->m, x, y);
398  }
399  s2->first_slice_line = 0;
400  }
401 
403  ff_fix_long_mvs(&s->m, NULL, 0, s->m.p_mv_table, s2->f_code,
405  }
406 
407  s2->first_slice_line = 1;
408  for (y = 0; y < block_height; y++) {
409  for (i = 0; i < 16 && i + 16 * y < height; i++) {
410  memcpy(&src[i * stride], &src_plane[(i + 16 * y) * src_stride],
411  width);
412  for (x = width; x < 16 * block_width; x++)
413  src[i * stride + x] = src[i * stride + x - 1];
414  }
415  for (; i < 16 && i + 16 * y < 16 * block_height; i++)
416  memcpy(&src[i * stride], &src[(i - 1) * stride], 16 * block_width);
417 
418  s2->mb_y = y;
419  for (x = 0; x < block_width; x++) {
420  uint8_t reorder_buffer[2][6][7 * 32];
421  int count[2][6];
422  int offset = y * 16 * stride + x * 16;
423  uint8_t *decoded = decoded_plane + offset;
424  const uint8_t *ref = ref_plane + offset;
425  int score[4] = { 0, 0, 0, 0 }, best;
426  uint8_t *temp = s->scratchbuf;
427 
428  if (put_bytes_left(pb, 0) < 3000) { // FIXME: check size
429  av_log(s->avctx, AV_LOG_ERROR, "encoded frame too large\n");
430  return -1;
431  }
432 
433  s2->mb_x = x;
434  init_block_index(s2);
435 
436  if (s->pict_type == AV_PICTURE_TYPE_I ||
437  (s->m.mb_type[x + y * s2->mb_stride] &
439  for (i = 0; i < 6; i++)
440  init_put_bits(&s->reorder_pb[i], reorder_buffer[0][i],
441  7 * 32);
442  if (s->pict_type == AV_PICTURE_TYPE_P) {
444  score[0] = SVQ1_BLOCK_INTRA_LEN * lambda;
445  }
446  score[0] += encode_block(s, src + 16 * x, src + 16 * x /* unused */,
447  temp, stride, 5, 64, lambda, 1);
448  for (i = 0; i < 6; i++) {
449  count[0][i] = put_bits_count(&s->reorder_pb[i]);
450  flush_put_bits(&s->reorder_pb[i]);
451  }
452  } else
453  score[0] = INT_MAX;
454 
455  best = 0;
456 
457  if (s->pict_type == AV_PICTURE_TYPE_P) {
458  int mx, my, pred_x, pred_y, dxy;
459  int16_t *motion_ptr;
460 
461  motion_ptr = ff_h263_pred_motion(s2, 0, 0, &pred_x, &pred_y);
462  if (s->m.mb_type[x + y * s2->mb_stride] &
464  for (i = 0; i < 6; i++)
465  init_put_bits(&s->reorder_pb[i], reorder_buffer[1][i],
466  7 * 32);
467 
469 
470  mx = motion_ptr[0];
471  my = motion_ptr[1];
472  av_assert1(mx >= -32 && mx <= 31);
473  av_assert1(my >= -32 && my <= 31);
474  av_assert1(pred_x >= -32 && pred_x <= 31);
475  av_assert1(pred_y >= -32 && pred_y <= 31);
476  ff_h263_encode_motion(&s->reorder_pb[5], mx - pred_x, 1);
477  ff_h263_encode_motion(&s->reorder_pb[5], my - pred_y, 1);
478  score[1] += lambda * put_bits_count(&s->reorder_pb[5]);
479 
480  dxy = (mx & 1) + 2 * (my & 1);
481 
482  s->hdsp.put_pixels_tab[0][dxy](temp + 16*stride,
483  ref + (mx >> 1) +
484  stride * (my >> 1),
485  stride, 16);
486 
487  score[1] += encode_block(s, src + 16 * x, temp + 16*stride,
488  decoded, stride, 5, 64, lambda, 0);
489  best = score[1] <= score[0];
490 
491  score[2] = s->mecc.sse[0](NULL, src + 16 * x, ref,
492  stride, 16);
493  score[2] += SVQ1_BLOCK_SKIP_LEN * lambda;
494  if (score[2] < score[best] && mx == 0 && my == 0) {
495  best = 2;
496  s->hdsp.put_pixels_tab[0][0](decoded, ref, stride, 16);
498  }
499  }
500 
501  if (best == 1) {
502  for (i = 0; i < 6; i++) {
503  count[1][i] = put_bits_count(&s->reorder_pb[i]);
504  flush_put_bits(&s->reorder_pb[i]);
505  }
506  } else {
507  motion_ptr[0] =
508  motion_ptr[1] =
509  motion_ptr[2] =
510  motion_ptr[3] =
511  motion_ptr[0 + 2 * s2->b8_stride] =
512  motion_ptr[1 + 2 * s2->b8_stride] =
513  motion_ptr[2 + 2 * s2->b8_stride] =
514  motion_ptr[3 + 2 * s2->b8_stride] = 0;
515  }
516  }
517 
518  s->rd_total += score[best];
519 
520  if (best != 2)
521  for (i = 5; i >= 0; i--)
522  ff_copy_bits(pb, reorder_buffer[best][i],
523  count[best][i]);
524  if (best == 0)
525  s->hdsp.put_pixels_tab[0][0](decoded, temp, stride, 16);
526  }
527  s2->first_slice_line = 0;
528  }
529  return 0;
530 }
531 
533 {
534  SVQ1EncContext *const s = avctx->priv_data;
535  int i;
536 
537  if (avctx->frame_num)
538  av_log(avctx, AV_LOG_DEBUG, "RD: %f\n",
539  s->rd_total / (double)(avctx->width * avctx->height *
540  avctx->frame_num));
541 
542  av_freep(&s->m.me.scratchpad);
543  av_freep(&s->mb_type);
544  av_freep(&s->dummy);
545  av_freep(&s->scratchbuf);
546 
547  s->m.mb_type = NULL;
548  ff_mpv_common_end(&s->m.c);
549 
550  for (i = 0; i < 3; i++) {
551  av_freep(&s->motion_val8[i]);
552  av_freep(&s->motion_val16[i]);
553  }
554 
555  av_frame_free(&s->current_picture);
556  av_frame_free(&s->last_picture);
557  av_frame_free(&s->m.new_pic);
558 
559  return 0;
560 }
561 
562 static av_cold int write_ident(AVCodecContext *avctx, const char *ident)
563 {
564  int size = strlen(ident);
565  avctx->extradata = av_malloc(size + 8);
566  if (!avctx->extradata)
567  return AVERROR(ENOMEM);
568  AV_WB32(avctx->extradata, size + 8);
569  AV_WL32(avctx->extradata + 4, MKTAG('S', 'V', 'Q', '1'));
570  memcpy(avctx->extradata + 8, ident, size);
571  avctx->extradata_size = size + 8;
572  return 0;
573 }
574 
576 {
577  SVQ1EncContext *const s = avctx->priv_data;
578  int ret;
579 
580  if (avctx->width >= 4096 || avctx->height >= 4096) {
581  av_log(avctx, AV_LOG_ERROR, "Dimensions too large, maximum is 4095x4095\n");
582  return AVERROR(EINVAL);
583  }
584 
585  ff_hpeldsp_init(&s->hdsp, avctx->flags);
586  ff_me_cmp_init(&s->mecc, avctx);
587  ret = ff_me_init(&s->m.me, avctx, &s->mecc, 0);
588  if (ret < 0)
589  return ret;
590  ff_mpegvideoencdsp_init(&s->m.mpvencdsp, avctx);
591 
592  s->current_picture = av_frame_alloc();
593  s->last_picture = av_frame_alloc();
594  if (!s->current_picture || !s->last_picture) {
595  return AVERROR(ENOMEM);
596  }
597 
598  s->frame_width = avctx->width;
599  s->frame_height = avctx->height;
600 
601  s->y_block_width = (s->frame_width + 15) / 16;
602  s->y_block_height = (s->frame_height + 15) / 16;
603 
604  s->c_block_width = (s->frame_width / 4 + 15) / 16;
605  s->c_block_height = (s->frame_height / 4 + 15) / 16;
606 
607  s->avctx = avctx;
608  s->m.c.avctx = avctx;
609 
610  ret = ff_mpv_common_init(&s->m.c);
611  if (ret < 0)
612  return ret;
613 
614  s->m.c.picture_structure = PICT_FRAME;
615  s->m.me.temp =
616  s->m.me.scratchpad = av_mallocz((avctx->width + 64) *
617  2 * 16 * 2 * sizeof(uint8_t));
618  s->mb_type = av_mallocz((s->y_block_width + 1) *
619  s->y_block_height * sizeof(int16_t));
620  s->dummy = av_mallocz((s->y_block_width + 1) *
621  s->y_block_height * sizeof(int32_t));
622  s->m.new_pic = av_frame_alloc();
623 
624  if (!s->m.me.scratchpad ||
625  !s->mb_type || !s->dummy || !s->m.new_pic)
626  return AVERROR(ENOMEM);
627 
628  ff_svq1enc_init(&s->svq1encdsp);
629 
630  s->m.me.mv_penalty = ff_h263_get_mv_penalty();
631 
632  return write_ident(avctx, s->avctx->flags & AV_CODEC_FLAG_BITEXACT ? "Lavc" : LIBAVCODEC_IDENT);
633 }
634 
636  const AVFrame *pict, int *got_packet)
637 {
638  SVQ1EncContext *const s = avctx->priv_data;
639  PutBitContext pb;
640  int i, ret;
641 
642  ret = ff_alloc_packet(avctx, pkt, s->y_block_width * s->y_block_height *
644  if (ret < 0)
645  return ret;
646 
647  if (avctx->pix_fmt != AV_PIX_FMT_YUV410P) {
648  av_log(avctx, AV_LOG_ERROR, "unsupported pixel format\n");
649  return -1;
650  }
651 
652  if (!s->current_picture->data[0]) {
653  if ((ret = ff_encode_alloc_frame(avctx, s->current_picture)) < 0) {
654  return ret;
655  }
656  }
657  if (!s->last_picture->data[0]) {
658  ret = ff_encode_alloc_frame(avctx, s->last_picture);
659  if (ret < 0)
660  return ret;
661  }
662  if (!s->scratchbuf) {
663  s->scratchbuf = av_malloc_array(s->current_picture->linesize[0], 16 * 3);
664  if (!s->scratchbuf)
665  return AVERROR(ENOMEM);
666  }
667 
668  FFSWAP(AVFrame*, s->current_picture, s->last_picture);
669 
670  if (avctx->gop_size && (avctx->frame_num % avctx->gop_size))
671  s->pict_type = AV_PICTURE_TYPE_P;
672  else
673  s->pict_type = AV_PICTURE_TYPE_I;
674  s->quality = pict->quality;
675 
676  ff_side_data_set_encoder_stats(pkt, pict->quality, NULL, 0, s->pict_type);
677 
678  init_put_bits(&pb, pkt->data, pkt->size);
679  svq1_write_header(s, &pb, s->pict_type);
680  for (i = 0; i < 3; i++) {
681  int ret = svq1_encode_plane(s, i, &pb,
682  pict->data[i],
683  s->last_picture->data[i],
684  s->current_picture->data[i],
685  s->frame_width / (i ? 4 : 1),
686  s->frame_height / (i ? 4 : 1),
687  pict->linesize[i],
688  s->current_picture->linesize[i]);
689  emms_c();
690  if (ret < 0) {
691  int j;
692  for (j = 0; j < i; j++) {
693  av_freep(&s->motion_val8[j]);
694  av_freep(&s->motion_val16[j]);
695  }
696  av_freep(&s->scratchbuf);
697  return -1;
698  }
699  }
700 
701  // align_put_bits(&pb);
702  while (put_bits_count(&pb) & 31)
703  put_bits(&pb, 1, 0);
704 
705  flush_put_bits(&pb);
706 
707  pkt->size = put_bytes_output(&pb);
708  if (s->pict_type == AV_PICTURE_TYPE_I)
710  *got_packet = 1;
711 
712  return 0;
713 }
714 
715 #define OFFSET(x) offsetof(struct SVQ1EncContext, x)
716 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
717 static const AVOption options[] = {
718  { "motion-est", "Motion estimation algorithm", OFFSET(m.me.motion_est), AV_OPT_TYPE_INT, { .i64 = FF_ME_EPZS }, FF_ME_ZERO, FF_ME_XONE, VE, .unit = "motion-est"},
719  { "zero", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = FF_ME_ZERO }, 0, 0, FF_MPV_OPT_FLAGS, .unit = "motion-est" },
720  { "epzs", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = FF_ME_EPZS }, 0, 0, FF_MPV_OPT_FLAGS, .unit = "motion-est" },
721  { "xone", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = FF_ME_XONE }, 0, 0, FF_MPV_OPT_FLAGS, .unit = "motion-est" },
722 
723  { NULL },
724 };
725 
726 static const AVClass svq1enc_class = {
727  .class_name = "svq1enc",
728  .item_name = av_default_item_name,
729  .option = options,
730  .version = LIBAVUTIL_VERSION_INT,
731 };
732 
734  .p.name = "svq1",
735  CODEC_LONG_NAME("Sorenson Vector Quantizer 1 / Sorenson Video 1 / SVQ1"),
736  .p.type = AVMEDIA_TYPE_VIDEO,
737  .p.id = AV_CODEC_ID_SVQ1,
739  .priv_data_size = sizeof(SVQ1EncContext),
740  .p.priv_class = &svq1enc_class,
741  .init = svq1_encode_init,
743  .close = svq1_encode_end,
745  .color_ranges = AVCOL_RANGE_MPEG,
746  .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
747 };
PICT_FRAME
#define PICT_FRAME
Definition: mpegutils.h:33
ff_fix_long_p_mvs
void ff_fix_long_p_mvs(MPVEncContext *const s, int type)
Definition: motion_est.c:1661
ff_mpv_common_init
av_cold int ff_mpv_common_init(MpegEncContext *s)
init common structure for both encoder and decoder.
Definition: mpegvideo.c:422
ff_fix_long_mvs
void ff_fix_long_mvs(MPVEncContext *const s, uint8_t *field_select_table, int field_select, int16_t(*mv_table)[2], int f_code, int type, int truncate)
Definition: motion_est.c:1710
MPVWorkPicture::linesize
ptrdiff_t linesize[MPV_MAX_PLANES]
Definition: mpegpicture.h:97
CODEC_PIXFMTS
#define CODEC_PIXFMTS(...)
Definition: codec_internal.h:386
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
FF_LAMBDA_SCALE
#define FF_LAMBDA_SCALE
Definition: avutil.h:226
AVERROR
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 they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
LIBAVCODEC_IDENT
#define LIBAVCODEC_IDENT
Definition: version.h:43
AV_WL32
#define AV_WL32(p, v)
Definition: intreadwrite.h:422
mem_internal.h
svq1enc_cb.h
ff_me_init
av_cold int ff_me_init(MotionEstContext *c, AVCodecContext *avctx, const MECmpContext *mecc, int mpvenc)
Definition: motion_est.c:309
put_bytes_output
static int put_bytes_output(const PutBitContext *s)
Definition: put_bits.h:89
FF_ME_EPZS
#define FF_ME_EPZS
Definition: motion_est.h:43
write_ident
static av_cold int write_ident(AVCodecContext *avctx, const char *ident)
Definition: svq1enc.c:562
options
static const AVOption options[]
Definition: svq1enc.c:717
SVQ1_BLOCK_INTRA_CODE
#define SVQ1_BLOCK_INTRA_CODE
Definition: svq1.h:51
ff_svq1_inter_codebooks
const FF_VISIBILITY_PUSH_HIDDEN int8_t *const ff_svq1_inter_codebooks[6]
Definition: svq1_cb.h:776
AVPictureType
AVPictureType
Definition: avutil.h:277
SVQ1EncContext
Definition: svq1enc.c:58
int64_t
long long int64_t
Definition: coverity.c:34
block_sum
static int block_sum(const uint8_t *block, int w, int h, int linesize)
Definition: mobiclip.c:813
init_put_bits
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s.
Definition: put_bits.h:62
svq1_encode_frame
static int svq1_encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pict, int *got_packet)
Definition: svq1enc.c:635
ff_me_init_pic
void ff_me_init_pic(MPVEncContext *const s)
Definition: motion_est.c:371
h263enc.h
ff_svq1_intra_codebooks
const int8_t *const ff_svq1_intra_codebooks[6]
Definition: svq1_cb.h:1519
av_frame_free
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
Definition: frame.c:63
CANDIDATE_MB_TYPE_INTER
#define CANDIDATE_MB_TYPE_INTER
Definition: mpegvideoenc.h:264
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:410
put_bits
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
Definition: j2kenc.c:223
w
uint8_t w
Definition: llviddspenc.c:38
SVQ1EncContext::frame_width
int frame_width
Definition: svq1enc.c:77
internal.h
AVPacket::data
uint8_t * data
Definition: packet.h:535
MpegEncContext::mb_width
int mb_width
Definition: mpegvideo.h:109
VE
#define VE
Definition: svq1enc.c:716
AVOption
AVOption.
Definition: opt.h:429
encode.h
FFCodec
Definition: codec_internal.h:127
version.h
SVQ1EncContext::pict_type
enum AVPictureType pict_type
Definition: svq1enc.c:70
SVQ1_BLOCK_SKIP_CODE
#define SVQ1_BLOCK_SKIP_CODE
Definition: svq1.h:47
mpegvideo.h
MpegEncContext::avctx
struct AVCodecContext * avctx
Definition: mpegvideo.h:82
sqr
static double sqr(double in)
Definition: af_afwtdn.c:872
FF_LAMBDA_SHIFT
#define FF_LAMBDA_SHIFT
Definition: avutil.h:225
MpegEncContext::height
int height
picture size. must be a multiple of 16
Definition: mpegvideo.h:91
mpegutils.h
SVQ1EncContext::encoded_block_levels
int16_t encoded_block_levels[6][7][256]
Definition: svq1enc.c:88
AV_PKT_FLAG_KEY
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
Definition: packet.h:590
svq1_inter_codebook_sum
static const int8_t svq1_inter_codebook_sum[4][16 *6]
Definition: svq1enc_cb.h:32
FF_INPUT_BUFFER_MIN_SIZE
#define FF_INPUT_BUFFER_MIN_SIZE
Used by some encoders as upper bound for the length of headers.
Definition: encode.h:33
svq1encdsp.h
MPVWorkPicture::mb_type
uint32_t * mb_type
types and macros are defined in mpegutils.h
Definition: mpegpicture.h:105
AVFrame::data
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
Definition: frame.h:431
MPVWorkPicture::motion_val
int16_t(*[2] motion_val)[2]
Definition: mpegpicture.h:103
SVQ1EncContext::c_block_width
int c_block_width
Definition: svq1enc.c:85
av_malloc
#define av_malloc(s)
Definition: tableprint_vlc.h:31
ff_svq1_intra_multistage_vlc
const uint8_t ff_svq1_intra_multistage_vlc[6][8][2]
Definition: svq1_vlc.h:33
ff_copy_bits
void ff_copy_bits(PutBitContext *pb, const uint8_t *src, int length)
Copy the content of src to the bitstream.
Definition: bitstream.c:49
mx
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t mx
Definition: dsp.h:53
ff_svq1_inter_mean_vlc
const uint16_t ff_svq1_inter_mean_vlc[512][2]
Definition: svq1_vlc.h:136
MpegEncContext::mb_height
int mb_height
number of MBs horizontally & vertically
Definition: mpegvideo.h:109
FFCodec::p
AVCodec p
The public AVCodec.
Definition: codec_internal.h:131
MpegEncContext::pict_type
int pict_type
AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B, ...
Definition: mpegvideo.h:168
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
SVQ1EncContext::svq1encdsp
SVQ1EncDSPContext svq1encdsp
Definition: svq1enc.c:99
MpegEncContext::linesize
ptrdiff_t linesize
line size, in bytes, may be different from width
Definition: mpegvideo.h:114
ff_me_cmp_init
av_cold void ff_me_cmp_init(MECmpContext *c, AVCodecContext *avctx)
Definition: me_cmp.c:996
AVCodecContext::flags
int flags
AV_CODEC_FLAG_*.
Definition: avcodec.h:488
MpegEncContext::width
int width
Definition: mpegvideo.h:91
FF_CODEC_ENCODE_CB
#define FF_CODEC_ENCODE_CB(func)
Definition: codec_internal.h:353
put_bytes_left
static int put_bytes_left(const PutBitContext *s, int round_up)
Definition: put_bits.h:135
av_frame_alloc
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
Definition: frame.c:51
SVQ1EncContext::m
MPVEncContext m
Definition: svq1enc.c:62
avassert.h
pkt
AVPacket * pkt
Definition: movenc.c:60
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:209
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
av_cold
#define av_cold
Definition: attributes.h:90
svq1_encode_plane
static int svq1_encode_plane(SVQ1EncContext *s, int plane, PutBitContext *pb, const unsigned char *src_plane, unsigned char *ref_plane, unsigned char *decoded_plane, int width, int height, int src_stride, int stride)
Definition: svq1enc.c:302
SVQ1EncContext::last_picture
AVFrame * last_picture
Definition: svq1enc.c:67
emms_c
#define emms_c()
Definition: emms.h:63
AVCodecContext::extradata_size
int extradata_size
Definition: avcodec.h:518
SVQ1EncContext::y_block_height
int y_block_height
Definition: svq1enc.c:82
MAX_MB_BYTES
#define MAX_MB_BYTES
Definition: mpegutils.h:35
SVQ1_BLOCK_SKIP_LEN
#define SVQ1_BLOCK_SKIP_LEN
Definition: svq1.h:48
s
#define s(width, name)
Definition: cbs_vp9.c:198
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
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:40
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:230
SVQ1EncContext::frame_height
int frame_height
Definition: svq1enc.c:78
SVQ1_BLOCK_INTRA_LEN
#define SVQ1_BLOCK_INTRA_LEN
Definition: svq1.h:52
THRESHOLD_MULTIPLIER
#define THRESHOLD_MULTIPLIER
Definition: svq1enc.c:137
ff_svq1_encoder
const FFCodec ff_svq1_encoder
Definition: svq1enc.c:733
MpegEncContext::cur_pic
MPVWorkPicture cur_pic
copy of the current picture structure.
Definition: mpegvideo.h:144
svq1_write_header
static void svq1_write_header(SVQ1EncContext *s, PutBitContext *pb, int frame_type)
Definition: svq1enc.c:102
PutBitContext
Definition: put_bits.h:50
CODEC_LONG_NAME
#define CODEC_LONG_NAME(str)
Definition: codec_internal.h:326
ff_hpeldsp_init
av_cold void ff_hpeldsp_init(HpelDSPContext *c, int flags)
Definition: hpeldsp.c:338
my
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t my
Definition: dsp.h:53
ff_mpv_common_end
av_cold void ff_mpv_common_end(MpegEncContext *s)
Definition: mpegvideo.c:509
MpegEncContext::mb_stride
int mb_stride
mb_width+1 used for some arrays to allow simple addressing of left & top MBs without sig11
Definition: mpegvideo.h:110
MECmpContext
Definition: me_cmp.h:55
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:75
NULL
#define NULL
Definition: coverity.c:32
MpegEncContext::mb_y
int mb_y
Definition: mpegvideo.h:211
MpegEncContext::f_code
int f_code
forward MV resolution
Definition: mpegvideo.h:182
SVQ1EncContext::current_picture
AVFrame * current_picture
Definition: svq1enc.c:66
MPVWorkPicture::data
uint8_t * data[MPV_MAX_PLANES]
Definition: mpegpicture.h:96
ff_svq1enc_init
static void ff_svq1enc_init(SVQ1EncDSPContext *c)
Definition: svq1encdsp.h:47
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
options
Definition: swscale.c:43
MpegEncContext::b8_stride
int b8_stride
2*mb_width+1 used for some 8x8 block arrays to allow simple addressing
Definition: mpegvideo.h:111
SVQ1EncContext::c_block_height
int c_block_height
Definition: svq1enc.c:86
ff_h263_get_mv_penalty
const uint8_t(* ff_h263_get_mv_penalty(void))[MAX_DMV *2+1]
Definition: ituh263enc.c:153
FF_ME_XONE
#define FF_ME_XONE
Definition: motion_est.h:44
AV_WB32
#define AV_WB32(p, v)
Definition: intreadwrite.h:415
svq1_encode_end
static av_cold int svq1_encode_end(AVCodecContext *avctx)
Definition: svq1enc.c:532
SVQ1EncContext::rd_total
int64_t rd_total
Definition: svq1enc.c:95
HpelDSPContext
Half-pel DSP context.
Definition: hpeldsp.h:45
ff_encode_alloc_frame
int ff_encode_alloc_frame(AVCodecContext *avctx, AVFrame *frame)
Allocate buffers for a frame.
Definition: encode.c:818
SVQ1EncContext::dummy
uint32_t * dummy
Definition: svq1enc.c:91
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
SVQ1EncContext::quality
int quality
Definition: svq1enc.c:71
AVPacket::size
int size
Definition: packet.h:536
AVCodecContext::gop_size
int gop_size
the number of pictures in a group of pictures, or 0 for intra_only
Definition: avcodec.h:1008
MpegEncContext::qscale
int qscale
QP.
Definition: mpegvideo.h:166
height
#define height
Definition: dsp.h:85
codec_internal.h
DECLARE_ALIGNED
#define DECLARE_ALIGNED(n, t, v)
Definition: mem_internal.h:104
MpegEncContext::first_slice_line
int first_slice_line
used in MPEG-4 too to handle resync markers
Definition: mpegvideo.h:275
AVFrame::quality
int quality
quality (between 1 (good) and FF_LAMBDA_MAX (bad))
Definition: frame.h:532
OFFSET
#define OFFSET(x)
Definition: svq1enc.c:715
size
int size
Definition: twinvq_data.h:10344
SVQ1EncContext::reorder_pb
PutBitContext reorder_pb[6]
Definition: svq1enc.c:75
CANDIDATE_MB_TYPE_INTRA
#define CANDIDATE_MB_TYPE_INTRA
Definition: mpegvideoenc.h:263
SVQ1EncContext::mb_type
uint16_t * mb_type
Definition: svq1enc.c:90
frame.h
diff
static av_always_inline int diff(const struct color_info *a, const struct color_info *b, const int trans_thresh)
Definition: vf_paletteuse.c:166
split
static char * split(char *message, char delim)
Definition: af_channelmap.c:89
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 offset
Definition: writing_filters.txt:86
SVQ1_BLOCK_INTER_CODE
#define SVQ1_BLOCK_INTER_CODE
Definition: svq1.h:49
AVPacket::flags
int flags
A combination of AV_PKT_FLAG values.
Definition: packet.h:541
init_block_index
static void init_block_index(MpegEncContext *const s)
Definition: svq1enc.c:292
SVQ1EncContext::avctx
AVCodecContext * avctx
Definition: svq1enc.c:63
AV_CODEC_ID_SVQ1
@ AV_CODEC_ID_SVQ1
Definition: codec_id.h:74
emms.h
QUALITY_THRESHOLD
#define QUALITY_THRESHOLD
Definition: svq1enc.c:136
av_assert2
#define av_assert2(cond)
assert() equivalent, that does lie in speed critical code.
Definition: avassert.h:67
SVQ1_BLOCK_INTER_LEN
#define SVQ1_BLOCK_INTER_LEN
Definition: svq1.h:50
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
put_bits_count
static int put_bits_count(PutBitContext *s)
Definition: put_bits.h:80
frame_type
frame_type
Definition: jpeg2000_parser.c:31
AVCodecContext::extradata
uint8_t * extradata
Out-of-band global headers that may be used by some codecs.
Definition: avcodec.h:517
SVQ1EncContext::mecc
MECmpContext mecc
Definition: svq1enc.c:64
av_malloc_array
#define av_malloc_array(a, b)
Definition: tableprint_vlc.h:32
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:56
MpegEncContext::mb_x
int mb_x
Definition: mpegvideo.h:211
av_mallocz
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
Definition: mem.c:256
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:179
MpegEncContext::last_pic
MPVWorkPicture last_pic
copy of the previous picture structure.
Definition: mpegvideo.h:132
SVQ1EncContext::motion_val8
int16_t(*[3] motion_val8)[2]
Definition: svq1enc.c:92
AVCodecContext::height
int height
Definition: avcodec.h:595
AVCodecContext::pix_fmt
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
Definition: avcodec.h:634
SVQ1EncContext::hdsp
HpelDSPContext hdsp
Definition: svq1enc.c:65
AVCOL_RANGE_MPEG
@ AVCOL_RANGE_MPEG
Narrow or limited range content.
Definition: pixfmt.h:733
svq1_intra_codebook_sum
static const int8_t svq1_intra_codebook_sum[4][16 *6]
Definition: svq1enc_cb.h:59
avcodec.h
stride
#define stride
Definition: h264pred_template.c:536
ff_svq1_inter_multistage_vlc
const uint8_t ff_svq1_inter_multistage_vlc[6][8][2]
Definition: svq1_vlc.h:50
AVCodecContext::frame_num
int64_t frame_num
Frame counter, set by libavcodec.
Definition: avcodec.h:1884
SVQ1EncContext::y_block_width
int y_block_width
Definition: svq1enc.c:81
SVQ1EncDSPContext
Definition: svq1encdsp.h:28
ret
ret
Definition: filter_design.txt:187
FFSWAP
#define FFSWAP(type, a, b)
Definition: macros.h:52
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
me_cmp.h
SVQ1EncContext::motion_val16
int16_t(*[3] motion_val16)[2]
Definition: svq1enc.c:93
AVCodecContext
main external API structure.
Definition: avcodec.h:431
FF_MPV_OPT_FLAGS
#define FF_MPV_OPT_FLAGS
Definition: mpegvideoenc.h:308
ff_svq1_intra_mean_vlc
const uint16_t ff_svq1_intra_mean_vlc[256][2]
Definition: svq1_vlc.h:67
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Underlying C type is int.
Definition: opt.h:259
svq1.h
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:117
temp
else temp
Definition: vf_mcdeint.c:263
mean
static float mean(const float *input, int size)
Definition: vf_nnedi.c:861
encode_block
static int encode_block(SVQ1EncContext *s, uint8_t *src, uint8_t *ref, uint8_t *decoded, int stride, unsigned level, int threshold, int lambda, int intra)
Definition: svq1enc.c:139
svq1enc_class
static const AVClass svq1enc_class
Definition: svq1enc.c:726
ff_estimate_p_frame_motion
void ff_estimate_p_frame_motion(MPVEncContext *const s, int mb_x, int mb_y)
Definition: motion_est.c:892
AV_PICTURE_TYPE_P
@ AV_PICTURE_TYPE_P
Predicted.
Definition: avutil.h:280
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
mem.h
packet_internal.h
AV_CODEC_FLAG_BITEXACT
#define AV_CODEC_FLAG_BITEXACT
Use only bitexact stuff (except (I)DCT).
Definition: avcodec.h:322
flush_put_bits
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros.
Definition: put_bits.h:143
SVQ1EncContext::scratchbuf
uint8_t * scratchbuf
Definition: svq1enc.c:97
AVPacket
This structure stores compressed data.
Definition: packet.h:512
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:458
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
ff_mpegvideoencdsp_init
av_cold void ff_mpegvideoencdsp_init(MpegvideoEncDSPContext *c, AVCodecContext *avctx)
Definition: mpegvideoencdsp.c:253
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:595
int32_t
int32_t
Definition: audioconvert.c:56
hpeldsp.h
AVFrame::linesize
int linesize[AV_NUM_DATA_POINTERS]
For video, a positive or negative value, which is typically indicating the size in bytes of each pict...
Definition: frame.h:455
AV_PIX_FMT_YUV410P
@ AV_PIX_FMT_YUV410P
planar YUV 4:1:0, 9bpp, (1 Cr & Cb sample per 4x4 Y samples)
Definition: pixfmt.h:79
block
The exact code depends on how similar the blocks are and how related they are to the block
Definition: filter_design.txt:207
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
ff_side_data_set_encoder_stats
int ff_side_data_set_encoder_stats(AVPacket *pkt, int quality, int64_t *error, int error_count, int pict_type)
Definition: packet.c:610
MKTAG
#define MKTAG(a, b, c, d)
Definition: macros.h:55
h
h
Definition: vp9dsp_template.c:2070
width
#define width
Definition: dsp.h:85
ff_h263_encode_motion
void ff_h263_encode_motion(PutBitContext *pb, int val, int f_code)
Definition: ituh263enc.c:162
put_bits.h
ff_svq1_frame_size_table
const uint16_t ff_svq1_frame_size_table[7][2]
Definition: svq1.c:40
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Special option type for declaring named constants.
Definition: opt.h:299
MpegEncContext
MpegEncContext.
Definition: mpegvideo.h:64
svq1_encode_init
static av_cold int svq1_encode_init(AVCodecContext *avctx)
Definition: svq1enc.c:575
ff_alloc_packet
int ff_alloc_packet(AVCodecContext *avctx, AVPacket *avpkt, int64_t size)
Check AVPacket size and allocate data.
Definition: encode.c:62
src
#define src
Definition: vp8dsp.c:248
codebook
static const unsigned codebook[256][2]
Definition: cfhdenc.c:41
FF_ME_ZERO
#define FF_ME_ZERO
Definition: motion_est.h:42
h263.h