35 #define CFACTOR_Y422 2
36 #define CFACTOR_Y444 3
38 #define MAX_MBS_PER_SLICE 8
61 4, 7, 9, 11, 13, 14, 15, 63,
62 7, 7, 11, 12, 14, 15, 63, 63,
63 9, 11, 13, 14, 15, 63, 63, 63,
64 11, 11, 13, 14, 63, 63, 63, 63,
65 11, 13, 14, 63, 63, 63, 63, 63,
66 13, 14, 63, 63, 63, 63, 63, 63,
67 13, 63, 63, 63, 63, 63, 63, 63,
68 63, 63, 63, 63, 63, 63, 63, 63,
71 4, 5, 6, 7, 9, 11, 13, 15,
72 5, 5, 7, 8, 11, 13, 15, 17,
73 6, 7, 9, 11, 13, 15, 15, 17,
74 7, 7, 9, 11, 13, 15, 17, 19,
75 7, 9, 11, 13, 14, 16, 19, 23,
76 9, 11, 13, 14, 16, 19, 23, 29,
77 9, 11, 13, 15, 17, 21, 28, 35,
78 11, 13, 16, 17, 21, 28, 35, 41,
81 4, 4, 5, 5, 6, 7, 7, 9,
82 4, 4, 5, 6, 7, 7, 9, 9,
83 5, 5, 6, 7, 7, 9, 9, 10,
84 5, 5, 6, 7, 7, 9, 9, 10,
85 5, 6, 7, 7, 8, 9, 10, 12,
86 6, 7, 7, 8, 9, 10, 12, 15,
87 6, 7, 7, 9, 10, 11, 14, 17,
88 7, 7, 9, 10, 11, 14, 17, 21,
91 4, 4, 4, 4, 4, 4, 4, 4,
92 4, 4, 4, 4, 4, 4, 4, 4,
93 4, 4, 4, 4, 4, 4, 4, 4,
94 4, 4, 4, 4, 4, 4, 4, 5,
95 4, 4, 4, 4, 4, 4, 5, 5,
96 4, 4, 4, 4, 4, 5, 5, 6,
97 4, 4, 4, 4, 5, 5, 6, 7,
98 4, 4, 4, 4, 5, 6, 7, 7,
101 4, 4, 4, 4, 4, 4, 4, 4,
102 4, 4, 4, 4, 4, 4, 4, 4,
103 4, 4, 4, 4, 4, 4, 4, 4,
104 4, 4, 4, 4, 4, 4, 4, 4,
105 4, 4, 4, 4, 4, 4, 4, 4,
106 4, 4, 4, 4, 4, 4, 4, 4,
107 4, 4, 4, 4, 4, 4, 4, 4,
108 4, 4, 4, 4, 4, 4, 4, 4,
112 #define NUM_MB_LIMITS 4
130 .tag =
MKTAG(
'a',
'p',
'c',
'o'),
133 .br_tab = { 300, 242, 220, 194 },
138 .tag =
MKTAG(
'a',
'p',
'c',
's'),
141 .br_tab = { 720, 560, 490, 440 },
145 .full_name =
"standard",
146 .tag =
MKTAG(
'a',
'p',
'c',
'n'),
149 .br_tab = { 1050, 808, 710, 632 },
153 .full_name =
"high quality",
154 .tag =
MKTAG(
'a',
'p',
'c',
'h'),
157 .br_tab = { 1566, 1216, 1070, 950 },
162 .tag =
MKTAG(
'a',
'p',
'4',
'h'),
165 .br_tab = { 2350, 1828, 1600, 1425 },
170 #define TRELLIS_WIDTH 16
171 #define SCORE_LIMIT INT_MAX / 2
180 #define MAX_STORED_Q 16
199 int linesize, int16_t *
block);
230 int linesize,
int x,
int y,
int w,
int h,
231 int16_t *blocks, uint16_t *emu_buf,
232 int mbs_per_slice,
int blocks_per_mb,
int is_chroma)
234 const uint16_t *esrc;
235 const int mb_width = 4 * blocks_per_mb;
239 for (i = 0; i < mbs_per_slice; i++, src += mb_width) {
241 memset(blocks, 0, 64 * (mbs_per_slice - i) * blocks_per_mb
245 if (x + mb_width <= w && y + 16 <= h) {
247 elinesize = linesize;
252 elinesize = 16 *
sizeof(*emu_buf);
254 bw =
FFMIN(w - x, mb_width);
255 bh =
FFMIN(h - y, 16);
257 for (j = 0; j < bh; j++) {
258 memcpy(emu_buf + j * 16,
259 (
const uint8_t*)src + j * linesize,
261 pix = emu_buf[j * 16 + bw - 1];
262 for (k = bw; k < mb_width; k++)
263 emu_buf[j * 16 + k] = pix;
266 memcpy(emu_buf + j * 16,
267 emu_buf + (bh - 1) * 16,
268 mb_width *
sizeof(*emu_buf));
271 ctx->
fdct(&ctx->
fdsp, esrc, elinesize, blocks);
273 if (blocks_per_mb > 2) {
274 ctx->
fdct(&ctx->
fdsp, esrc + 8, elinesize, blocks);
277 ctx->
fdct(&ctx->
fdsp, esrc + elinesize * 4, elinesize, blocks);
279 if (blocks_per_mb > 2) {
280 ctx->
fdct(&ctx->
fdsp, esrc + elinesize * 4 + 8, elinesize, blocks);
284 ctx->
fdct(&ctx->
fdsp, esrc, elinesize, blocks);
286 ctx->
fdct(&ctx->
fdsp, esrc + elinesize * 4, elinesize, blocks);
288 if (blocks_per_mb > 2) {
289 ctx->
fdct(&ctx->
fdsp, esrc + 8, elinesize, blocks);
291 ctx->
fdct(&ctx->
fdsp, esrc + elinesize * 4 + 8, elinesize, blocks);
301 int linesize,
int x,
int y,
int w,
int h,
302 int16_t *blocks,
int mbs_per_slice,
int abits)
304 const int slice_width = 16 * mbs_per_slice;
305 int i, j, copy_w, copy_h;
307 copy_w =
FFMIN(w - x, slice_width);
308 copy_h =
FFMIN(h - y, 16);
309 for (i = 0; i < copy_h; i++) {
310 memcpy(blocks, src, copy_w *
sizeof(*src));
312 for (j = 0; j < copy_w; j++)
315 for (j = 0; j < copy_w; j++)
316 blocks[j] = (blocks[j] << 6) | (blocks[j] >> 4);
317 for (j = copy_w; j < slice_width; j++)
318 blocks[j] = blocks[copy_w - 1];
319 blocks += slice_width;
320 src += linesize >> 1;
322 for (; i < 16; i++) {
323 memcpy(blocks, blocks - slice_width, slice_width *
sizeof(*blocks));
324 blocks += slice_width;
333 unsigned int rice_order, exp_order, switch_bits, switch_val;
337 switch_bits = (codebook & 3) + 1;
338 rice_order = codebook >> 5;
339 exp_order = (codebook >> 2) & 7;
341 switch_val = switch_bits << rice_order;
343 if (val >= switch_val) {
344 val -= switch_val - (1 << exp_order);
347 put_bits(pb, exponent - exp_order + switch_bits, 0);
350 exponent = val >> rice_order;
360 #define GET_SIGN(x) ((x) >> 31)
361 #define MAKE_CODE(x) (((x) << 1) ^ GET_SIGN(x))
364 int blocks_per_slice,
int scale)
367 int codebook = 3, code,
dc, prev_dc,
delta, sign, new_sign;
369 prev_dc = (blocks[0] - 0x4000) / scale;
375 for (i = 1; i < blocks_per_slice; i++, blocks += 64) {
376 dc = (blocks[0] - 0x4000) / scale;
377 delta = dc - prev_dc;
379 delta = (delta ^ sign) - sign;
382 codebook = (code + (code & 1)) >> 1;
383 codebook =
FFMIN(codebook, 3);
390 int blocks_per_slice,
391 int plane_size_factor,
392 const uint8_t *scan,
const int16_t *qmat)
396 int max_coeffs, abs_level;
398 max_coeffs = blocks_per_slice << 6;
403 for (i = 1; i < 64; i++) {
404 for (idx = scan[i]; idx < max_coeffs; idx += 64) {
405 level = blocks[idx] / qmat[scan[i]];
407 abs_level =
FFABS(level);
424 const uint16_t *
src,
int linesize,
425 int mbs_per_slice, int16_t *blocks,
426 int blocks_per_mb,
int plane_size_factor,
429 int blocks_per_slice, saved_pos;
432 blocks_per_slice = mbs_per_slice * blocks_per_mb;
434 encode_dcs(pb, blocks, blocks_per_slice, qmat[0]);
435 encode_acs(pb, blocks, blocks_per_slice, plane_size_factor,
444 const int dbits = (abits == 8) ? 4 : 7;
445 const int dsize = 1 << dbits - 1;
446 int diff = cur - prev;
448 diff = av_mod_uintp2(diff, abits);
449 if (diff >= (1 << abits) - dsize)
451 if (diff < -dsize || diff > dsize || !diff) {
476 int mbs_per_slice, uint16_t *blocks,
480 const int mask = (1 << abits) - 1;
481 const int num_coeffs = mbs_per_slice * 256;
483 int prev =
mask, cur;
500 }
while (idx < num_coeffs);
516 int slice_width_factor =
av_log2(mbs_per_slice);
517 int num_cblocks, pwidth, linesize, line_add;
518 int plane_factor, is_chroma;
532 for (i = 0; i < 64; i++)
537 is_chroma = (i == 1 || i == 2);
538 plane_factor = slice_width_factor + 2;
545 pwidth = avctx->
width;
550 pwidth = avctx->
width >> 1;
554 src = (
const uint16_t*)(pic->
data[i] + yp * linesize +
561 mbs_per_slice, num_cblocks, is_chroma);
563 mbs_per_slice, ctx->
blocks[0],
564 num_cblocks, plane_factor,
573 total_size += sizes[i];
576 "Underestimated required buffer size.\n");
585 unsigned int rice_order, exp_order, switch_bits, switch_val;
589 switch_bits = (codebook & 3) + 1;
590 rice_order = codebook >> 5;
591 exp_order = (codebook >> 2) & 7;
593 switch_val = switch_bits << rice_order;
595 if (val >= switch_val) {
596 val -= switch_val - (1 << exp_order);
599 return exponent * 2 - exp_order + switch_bits + 1;
601 return (val >> rice_order) + rice_order + 1;
605 static int estimate_dcs(
int *error, int16_t *blocks,
int blocks_per_slice,
609 int codebook = 3, code,
dc, prev_dc,
delta, sign, new_sign;
612 prev_dc = (blocks[0] - 0x4000) / scale;
617 *error +=
FFABS(blocks[0] - 0x4000) % scale;
619 for (i = 1; i < blocks_per_slice; i++, blocks += 64) {
620 dc = (blocks[0] - 0x4000) / scale;
621 *error +=
FFABS(blocks[0] - 0x4000) % scale;
622 delta = dc - prev_dc;
624 delta = (delta ^ sign) - sign;
627 codebook = (code + (code & 1)) >> 1;
628 codebook =
FFMIN(codebook, 3);
636 static int estimate_acs(
int *error, int16_t *blocks,
int blocks_per_slice,
637 int plane_size_factor,
638 const uint8_t *scan,
const int16_t *qmat)
642 int max_coeffs, abs_level;
645 max_coeffs = blocks_per_slice << 6;
650 for (i = 1; i < 64; i++) {
651 for (idx = scan[i]; idx < max_coeffs; idx += 64) {
652 level = blocks[idx] / qmat[scan[i]];
653 *error +=
FFABS(blocks[idx]) % qmat[scan[i]];
655 abs_level =
FFABS(level);
673 const uint16_t *
src,
int linesize,
675 int blocks_per_mb,
int plane_size_factor,
678 int blocks_per_slice;
681 blocks_per_slice = mbs_per_slice * blocks_per_mb;
685 plane_size_factor, ctx->
scantable, qmat);
692 const int dbits = (abits == 8) ? 4 : 7;
693 const int dsize = 1 << dbits - 1;
694 int diff = cur - prev;
696 diff = av_mod_uintp2(diff, abits);
697 if (diff >= (1 << abits) - dsize)
699 if (diff < -dsize || diff > dsize || !diff)
706 const uint16_t *
src,
int linesize,
707 int mbs_per_slice,
int quant,
711 const int mask = (1 << abits) - 1;
712 const int num_coeffs = mbs_per_slice * 256;
713 int prev =
mask, cur;
737 }
while (idx < num_coeffs);
750 int trellis_node,
int x,
int y,
int mbs_per_slice,
754 int i, q, pq, xp, yp;
756 int slice_width_factor =
av_log2(mbs_per_slice);
761 int error,
bits, bits_limit;
762 int mbs, prev, cur, new_score;
766 int linesize[4], line_add;
772 mbs = x + mbs_per_slice;
775 is_chroma[i] = (i == 1 || i == 2);
776 plane_factor[i] = slice_width_factor + 2;
783 pwidth = avctx->
width;
788 pwidth = avctx->
width >> 1;
792 src = (
const uint16_t *)(ctx->
pic->
data[i] + yp * linesize[i] +
799 mbs_per_slice, num_cblocks[i], is_chroma[i]);
807 for (q = min_quant; q < max_quant + 2; q++) {
813 for (q = min_quant; q <=
max_quant; q++) {
820 num_cblocks[i], plane_factor[i],
825 mbs_per_slice, q, td->
blocks[3]);
826 if (bits > 65000 * 8)
829 slice_bits[q] =
bits;
830 slice_score[q] = error;
832 if (slice_bits[max_quant] <= ctx->
bits_per_mb * mbs_per_slice) {
833 slice_bits[max_quant + 1] = slice_bits[
max_quant];
834 slice_score[max_quant + 1] = slice_score[
max_quant] + 1;
837 for (q = max_quant + 1; q < 128; q++) {
844 for (i = 0; i < 64; i++)
851 num_cblocks[i], plane_factor[i],
856 mbs_per_slice, q, td->
blocks[3]);
857 if (bits <= ctx->bits_per_mb * mbs_per_slice)
861 slice_bits[max_quant + 1] =
bits;
862 slice_score[max_quant + 1] = error;
865 td->
nodes[trellis_node + max_quant + 1].
quant = overquant;
868 for (pq = min_quant; pq < max_quant + 2; pq++) {
871 for (q = min_quant; q < max_quant + 2; q++) {
872 cur = trellis_node + q;
874 bits = td->
nodes[prev].
bits + slice_bits[q];
875 error = slice_score[q];
876 if (bits > bits_limit)
895 for (q = min_quant + 1; q < max_quant + 2; q++) {
896 if (td->
nodes[trellis_node + q].
score <= error) {
898 pq = trellis_node + q;
906 int jobnr,
int threadnr)
911 int x, y = jobnr,
mb, q = 0;
913 for (x = mb = 0; x < ctx->
mb_width; x += mbs_per_slice, mb++) {
914 while (ctx->
mb_width - x < mbs_per_slice)
930 const AVFrame *pic,
int *got_packet)
936 int x, y, i,
mb, q = 0;
937 int sizes[4] = { 0 };
938 int slice_hdr_size = 2 + 2 * (ctx->
num_planes - 1);
950 orig_buf = pkt->
data;
954 bytestream_put_be32 (&orig_buf,
FRAME_ID);
960 bytestream_put_be16 (&buf, 0);
962 bytestream_put_be16 (&buf, avctx->
width);
963 bytestream_put_be16 (&buf, avctx->
height);
968 bytestream_put_byte (&buf, frame_flags);
970 bytestream_put_byte (&buf, 0);
972 bytestream_put_byte (&buf, avctx->
color_trc);
973 bytestream_put_byte (&buf, avctx->
colorspace);
974 bytestream_put_byte (&buf, 0x40 | (ctx->
alpha_bits >> 3));
975 bytestream_put_byte (&buf, 0);
977 bytestream_put_byte (&buf, 0x03);
979 for (i = 0; i < 64; i++)
980 bytestream_put_byte(&buf, ctx->
quant_mat[i]);
982 for (i = 0; i < 64; i++)
983 bytestream_put_byte(&buf, ctx->
quant_mat[i]);
985 bytestream_put_byte (&buf, 0x00);
987 bytestream_put_be16 (&tmp, buf - orig_buf);
993 picture_size_pos = buf + 1;
994 bytestream_put_byte (&buf, 0x40);
1013 for (x = mb = 0; x < ctx->
mb_width; x += mbs_per_slice, mb++) {
1017 while (ctx->
mb_width - x < mbs_per_slice)
1018 mbs_per_slice >>= 1;
1020 bytestream_put_byte(&buf, slice_hdr_size << 3);
1022 buf += slice_hdr_size - 1;
1023 if (pkt_size <= buf - orig_buf + 2 * max_slice_size) {
1029 max_slice_size - pkt_size;
1031 delta =
FFMAX(delta, 2 * max_slice_size);
1036 "Packet too small: is %i,"
1037 " needs %i (slice: %i). "
1038 "Correct allocation",
1039 pkt_size, delta, max_slice_size);
1049 orig_buf = pkt->
data + (orig_buf -
start);
1051 picture_size_pos = pkt->
data + (picture_size_pos -
start);
1052 slice_sizes = pkt->
data + (slice_sizes -
start);
1053 slice_hdr = pkt->
data + (slice_hdr -
start);
1062 bytestream_put_byte(&slice_hdr, q);
1063 slice_size = slice_hdr_size + sizes[ctx->
num_planes - 1];
1065 bytestream_put_be16(&slice_hdr, sizes[i]);
1066 slice_size += sizes[i];
1068 bytestream_put_be16(&slice_sizes, slice_size);
1069 buf += slice_size - slice_hdr_size;
1070 if (max_slice_size < slice_size)
1071 max_slice_size = slice_size;
1075 picture_size = buf - (picture_size_pos - 1);
1076 bytestream_put_be32(&picture_size_pos, picture_size);
1080 frame_size = buf - orig_buf;
1081 bytestream_put_be32(&orig_buf, frame_size);
1106 int linesize, int16_t *
block)
1109 const uint16_t *tsrc =
src;
1111 for (y = 0; y < 8; y++) {
1112 for (x = 0; x < 8; x++)
1113 block[y * 8 + x] = tsrc[x];
1114 tsrc += linesize >> 1;
1128 #if FF_API_CODED_FRAME
1141 if (mps & (mps - 1)) {
1143 "there should be an integer power of two MBs per slice\n");
1153 ?
"4:4:4:4 profile because of the used input colorspace"
1154 :
"HQ profile to keep best quality");
1160 "encode alpha. Override with -profile if needed.\n");
1195 if (strlen(ctx->
vendor) != 4) {
1216 for (j = 0; j < 64; j++)
1240 for (i = min_quant; i < max_quant + 2; i++) {
1254 for (j = 0; j < 64; j++) {
1281 "profile %d, %d slices, interlacing: %s, %d bits per MB\n",
1290 #define OFFSET(x) offsetof(ProresContext, x)
1291 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
1294 {
"mbs_per_slice",
"macroblocks per slice",
OFFSET(mbs_per_slice),
1300 0, 0,
VE,
"profile" },
1302 0, 0,
VE,
"profile" },
1304 0, 0,
VE,
"profile" },
1306 0, 0,
VE,
"profile" },
1308 0, 0,
VE,
"profile" },
1310 0, 0,
VE,
"profile" },
1311 {
"vendor",
"vendor ID",
OFFSET(vendor),
1313 {
"bits_per_mb",
"desired bits per macroblock",
OFFSET(bits_per_mb),
1318 0, 0,
VE,
"quant_mat" },
1320 0, 0,
VE,
"quant_mat" },
1322 0, 0,
VE,
"quant_mat" },
1324 0, 0,
VE,
"quant_mat" },
1326 0, 0,
VE,
"quant_mat" },
1328 0, 0,
VE,
"quant_mat" },
1330 { .i64 = 16 }, 0, 16,
VE },
1342 .
name =
"prores_ks",
static const AVClass proresenc_class
#define MAX_MBS_PER_SLICE
static void prores_fdct(FDCTDSPContext *fdsp, const uint16_t *src, int linesize, int16_t *block)
const char const char void * val
static int encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pic, int *got_packet)
void(* fdct)(FDCTDSPContext *fdsp, const uint16_t *src, int linesize, int16_t *block)
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
This structure describes decoded (raw) audio or video data.
static void get_slice_data(ProresContext *ctx, const uint16_t *src, int linesize, int x, int y, int w, int h, int16_t *blocks, uint16_t *emu_buf, int mbs_per_slice, int blocks_per_mb, int is_chroma)
#define AV_CODEC_FLAG_INTERLACED_DCT
Use interlaced DCT.
static void put_sbits(PutBitContext *pb, int n, int32_t value)
static av_cold int encode_init(AVCodecContext *avctx)
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
#define AV_LOG_WARNING
Something somehow does not look correct.
#define LIBAVUTIL_VERSION_INT
const uint8_t ff_prores_ac_codebook[7]
static av_cold int init(AVCodecContext *avctx)
static int estimate_acs(int *error, int16_t *blocks, int blocks_per_slice, int plane_size_factor, const uint8_t *scan, const int16_t *qmat)
#define DECLARE_ALIGNED(n, t, v)
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
unsigned mb_height
height of the current picture in mb
const uint8_t * scantable
static const AVOption options[]
int bits_per_raw_sample
Bits per sample/pixel of internal libavcodec pixel/sample format.
static av_cold int encode_close(AVCodecContext *avctx)
av_cold void ff_fdctdsp_init(FDCTDSPContext *c, AVCodecContext *avctx)
uint8_t log2_chroma_w
Amount to shift the luma width right to find the chroma width.
int16_t quants[MAX_STORED_Q][64]
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
void void avpriv_request_sample(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
#define AV_PIX_FMT_FLAG_ALPHA
The pixel format has an alpha channel.
static int estimate_vlc(unsigned codebook, int val)
static int encode_slice(AVCodecContext *avctx, const AVFrame *pic, PutBitContext *pb, int sizes[4], int x, int y, int quant, int mbs_per_slice)
const uint8_t ff_prores_run_to_cb_index[16]
Lookup tables for adaptive switching between codebooks according with previous run/level value...
const uint8_t ff_prores_lev_to_cb_index[10]
int bits_per_coded_sample
bits per sample/pixel from the demuxer (needed for huffyuv).
static void encode_acs(PutBitContext *pb, int16_t *blocks, int blocks_per_slice, int plane_size_factor, const uint8_t *scan, const int16_t *qmat)
#define AV_INPUT_BUFFER_MIN_SIZE
minimum encoding buffer size Used to avoid some checks during header writing.
static int est_alpha_diff(int cur, int prev, int abits)
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
int16_t blocks[MAX_PLANES][64 *4 *MAX_MBS_PER_SLICE]
unsigned mb_width
width of the current picture in mb
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
uint8_t log2_chroma_h
Amount to shift the luma height right to find the chroma height.
static int put_bits_left(PutBitContext *s)
static const uint16_t mask[17]
static const int sizes[][2]
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
const struct prores_profile * profile_info
int flags
AV_CODEC_FLAG_*.
const char * name
Name of the codec implementation.
#define AV_PIX_FMT_YUV444P10
static void get_alpha_data(ProresContext *ctx, const uint16_t *src, int linesize, int x, int y, int w, int h, int16_t *blocks, int mbs_per_slice, int abits)
static const int prores_mb_limits[NUM_MB_LIMITS]
int flags
A combination of AV_PKT_FLAG values.
struct TrellisNode * nodes
static int put_bits_count(PutBitContext *s)
uint64_t flags
Combination of AV_PIX_FMT_FLAG_...
static void encode_vlc_codeword(PutBitContext *pb, unsigned codebook, int val)
Write an unsigned rice/exp golomb codeword.
enum AVPictureType pict_type
Picture type of the frame.
int num_chroma_blocks
number of chrominance blocks in a macroblock
int width
picture width / height.
typedef void(APIENTRY *FF_PFNGLACTIVETEXTUREPROC)(GLenum texture)
const uint8_t ff_prores_dc_codebook[4]
enum AVColorPrimaries color_primaries
Chromaticity coordinates of the source primaries.
static int estimate_slice_plane(ProresContext *ctx, int *error, int plane, const uint16_t *src, int linesize, int mbs_per_slice, int blocks_per_mb, int plane_size_factor, const int16_t *qmat, ProresThreadData *td)
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
static void put_alpha_diff(PutBitContext *pb, int cur, int prev, int abits)
#define AV_PIX_FMT_YUVA444P10
static void encode_dcs(PutBitContext *pb, int16_t *blocks, int blocks_per_slice, int scale)
int thread_count
thread count is used to decide how many independent tasks should be passed to execute() ...
#define AV_CODEC_CAP_SLICE_THREADS
Codec supports slice-based (or partition-based) multithreading.
static int estimate_alpha_plane(ProresContext *ctx, int *error, const uint16_t *src, int linesize, int mbs_per_slice, int quant, int16_t *blocks)
#define AV_LOG_INFO
Standard information.
const uint8_t ff_prores_interlaced_scan[64]
Libavcodec external API header.
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
void(* fdct)(int16_t *block)
main external API structure.
const uint8_t ff_prores_progressive_scan[64]
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A').
#define AVERROR_BUG
Internal bug, also see AVERROR_BUG2.
Describe the class of an AVClass context structure.
enum AVColorSpace colorspace
YUV colorspace type.
enum AVColorTransferCharacteristic color_trc
Color Transfer Characteristic.
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size, int64_t min_size)
Check AVPacket size and/or allocate data.
static enum AVPixelFormat pix_fmts[]
int global_quality
Global quality for codecs which cannot change it per frame.
#define AV_PIX_FMT_YUV422P10
static int find_slice_quant(AVCodecContext *avctx, int trellis_node, int x, int y, int mbs_per_slice, ProresThreadData *td)
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
int br_tab[NUM_MB_LIMITS]
static void put_alpha_run(PutBitContext *pb, int run)
#define FF_DISABLE_DEPRECATION_WARNINGS
static int encode_alpha_plane(ProresContext *ctx, PutBitContext *pb, int mbs_per_slice, uint16_t *blocks, int quant)
static const uint8_t prores_quant_matrices[][64]
common internal api header.
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros.
static int find_quant_thread(AVCodecContext *avctx, void *arg, int jobnr, int threadnr)
attribute_deprecated AVFrame * coded_frame
the picture in the bitstream
int av_grow_packet(AVPacket *pkt, int grow_by)
Increase packet size, correctly zeroing padding.
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s.
static av_always_inline void bytestream_put_buffer(uint8_t **b, const uint8_t *src, unsigned int size)
static av_always_inline int diff(const uint32_t a, const uint32_t b)
static int encode_slice_plane(ProresContext *ctx, PutBitContext *pb, const uint16_t *src, int linesize, int mbs_per_slice, int16_t *blocks, int blocks_per_mb, int plane_size_factor, const int16_t *qmat)
static const struct prores_profile prores_profile_info[5]
#define FF_ENABLE_DEPRECATION_WARNINGS
int top_field_first
If the content is interlaced, is top field displayed first.
int(* execute2)(struct AVCodecContext *c, int(*func)(struct AVCodecContext *c2, void *arg, int jobnr, int threadnr), void *arg2, int *ret, int count)
The codec may call this to execute several independent things.
int key_frame
1 -> keyframe, 0-> not
#define FF_QP2LAMBDA
factor to convert from H.263 QP to lambda
uint8_t pi<< 24) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_U8, uint8_t,(*(constuint8_t *) pi-0x80)*(1.0f/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_U8, uint8_t,(*(constuint8_t *) pi-0x80)*(1.0/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S16, int16_t,(*(constint16_t *) pi >>8)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S16, int16_t,*(constint16_t *) pi *(1.0f/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S16, int16_t,*(constint16_t *) pi *(1.0/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S32, int32_t,(*(constint32_t *) pi >>24)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S32, int32_t,*(constint32_t *) pi *(1.0f/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S32, int32_t,*(constint32_t *) pi *(1.0/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_FLT, float, av_clip_uint8(lrintf(*(constfloat *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_FLT, float, av_clip_int16(lrintf(*(constfloat *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_FLT, float, av_clipl_int32(llrintf(*(constfloat *) pi *(1U<< 31)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_DBL, double, av_clip_uint8(lrint(*(constdouble *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_DBL, double, av_clip_int16(lrint(*(constdouble *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_DBL, double, av_clipl_int32(llrint(*(constdouble *) pi *(1U<< 31))))#defineSET_CONV_FUNC_GROUP(ofmt, ifmt) staticvoidset_generic_function(AudioConvert *ac){}voidff_audio_convert_free(AudioConvert **ac){if(!*ac) return;ff_dither_free(&(*ac) ->dc);av_freep(ac);}AudioConvert *ff_audio_convert_alloc(AVAudioResampleContext *avr, enumAVSampleFormatout_fmt, enumAVSampleFormatin_fmt, intchannels, intsample_rate, intapply_map){AudioConvert *ac;intin_planar, out_planar;ac=av_mallocz(sizeof(*ac));if(!ac) returnNULL;ac->avr=avr;ac->out_fmt=out_fmt;ac->in_fmt=in_fmt;ac->channels=channels;ac->apply_map=apply_map;if(avr->dither_method!=AV_RESAMPLE_DITHER_NONE &&av_get_packed_sample_fmt(out_fmt)==AV_SAMPLE_FMT_S16 &&av_get_bytes_per_sample(in_fmt)>2){ac->dc=ff_dither_alloc(avr, out_fmt, in_fmt, channels, sample_rate, apply_map);if(!ac->dc){av_free(ac);returnNULL;}returnac;}in_planar=ff_sample_fmt_is_planar(in_fmt, channels);out_planar=ff_sample_fmt_is_planar(out_fmt, channels);if(in_planar==out_planar){ac->func_type=CONV_FUNC_TYPE_FLAT;ac->planes=in_planar?ac->channels:1;}elseif(in_planar) ac->func_type=CONV_FUNC_TYPE_INTERLEAVE;elseac->func_type=CONV_FUNC_TYPE_DEINTERLEAVE;set_generic_function(ac);if(ARCH_AARCH64) ff_audio_convert_init_aarch64(ac);if(ARCH_ARM) ff_audio_convert_init_arm(ac);if(ARCH_X86) ff_audio_convert_init_x86(ac);returnac;}intff_audio_convert(AudioConvert *ac, AudioData *out, AudioData *in){intuse_generic=1;intlen=in->nb_samples;intp;if(ac->dc){av_log(ac->avr, AV_LOG_TRACE,"%dsamples-audio_convert:%sto%s(dithered)\n", len, av_get_sample_fmt_name(ac->in_fmt), av_get_sample_fmt_name(ac->out_fmt));returnff_convert_dither(ac-> dc
AVCodec ff_prores_ks_encoder
const uint8_t * quant_mat
#define MKTAG(a, b, c, d)
int frame_size_upper_bound
AVPixelFormat
Pixel format.
This structure stores compressed data.
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
static int estimate_dcs(int *error, int16_t *blocks, int blocks_per_slice, int scale)