FFmpeg
j2kenc.c
Go to the documentation of this file.
1 /*
2  * JPEG2000 image encoder
3  * Copyright (c) 2007 Kamil Nowosad
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  *
24  *
25  * This source code incorporates work covered by the following copyright and
26  * permission notice:
27  *
28  * Copyright (c) 2002-2007, Communications and Remote Sensing Laboratory, Universite catholique de Louvain (UCL), Belgium
29  * Copyright (c) 2002-2007, Professor Benoit Macq
30  * Copyright (c) 2001-2003, David Janssens
31  * Copyright (c) 2002-2003, Yannick Verschueren
32  * Copyright (c) 2003-2007, Francois-Olivier Devaux and Antonin Descampe
33  * Copyright (c) 2005, Herve Drolon, FreeImage Team
34  * Copyright (c) 2007, Callum Lerwick <seg@haxxed.com>
35  * All rights reserved.
36  *
37  * Redistribution and use in source and binary forms, with or without
38  * modification, are permitted provided that the following conditions
39  * are met:
40  * 1. Redistributions of source code must retain the above copyright
41  * notice, this list of conditions and the following disclaimer.
42  * 2. Redistributions in binary form must reproduce the above copyright
43  * notice, this list of conditions and the following disclaimer in the
44  * documentation and/or other materials provided with the distribution.
45  *
46  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
47  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
48  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
49  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
50  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
51  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
52  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
53  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
54  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
55  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
56  * POSSIBILITY OF SUCH DAMAGE.
57  */
58 
59 
60 /**
61  * JPEG2000 image encoder
62  * @file
63  * @author Kamil Nowosad
64  */
65 
66 #include <float.h>
67 #include "avcodec.h"
68 #include "internal.h"
69 #include "bytestream.h"
70 #include "jpeg2000.h"
71 #include "libavutil/common.h"
72 #include "libavutil/pixdesc.h"
73 #include "libavutil/opt.h"
74 #include "libavutil/intreadwrite.h"
75 
76 #define NMSEDEC_BITS 7
77 #define NMSEDEC_FRACBITS (NMSEDEC_BITS-1)
78 #define WMSEDEC_SHIFT 13 ///< must be >= 13
79 #define LAMBDA_SCALE (100000000LL << (WMSEDEC_SHIFT - 13))
80 
81 #define CODEC_JP2 1
82 #define CODEC_J2K 0
83 
84 static int lut_nmsedec_ref [1<<NMSEDEC_BITS],
88 
89 static const int dwt_norms[2][4][10] = { // [dwt_type][band][rlevel] (multiplied by 10000)
90  {{10000, 19650, 41770, 84030, 169000, 338400, 676900, 1353000, 2706000, 5409000},
91  {20220, 39890, 83550, 170400, 342700, 686300, 1373000, 2746000, 5490000},
92  {20220, 39890, 83550, 170400, 342700, 686300, 1373000, 2746000, 5490000},
93  {20800, 38650, 83070, 171800, 347100, 695900, 1393000, 2786000, 5572000}},
94 
95  {{10000, 15000, 27500, 53750, 106800, 213400, 426700, 853300, 1707000, 3413000},
96  {10380, 15920, 29190, 57030, 113300, 226400, 452500, 904800, 1809000},
97  {10380, 15920, 29190, 57030, 113300, 226400, 452500, 904800, 1809000},
98  { 7186, 9218, 15860, 30430, 60190, 120100, 240000, 479700, 959300}}
99 };
100 
101 typedef struct {
103 } Jpeg2000Tile;
104 
105 typedef struct {
106  AVClass *class;
108  const AVFrame *picture;
109 
110  int width, height; ///< image width and height
111  uint8_t cbps[4]; ///< bits per sample in particular components
112  int chroma_shift[2];
115  int tile_width, tile_height; ///< tile size
116  int numXtiles, numYtiles;
117 
122 
123  int64_t lambda;
124 
127 
129 
130  int format;
131  int pred;
133 
134 
135 /* debug */
136 #if 0
137 #undef ifprintf
138 #undef printf
139 
140 static void nspaces(FILE *fd, int n)
141 {
142  while(n--) putc(' ', fd);
143 }
144 
145 static void printcomp(Jpeg2000Component *comp)
146 {
147  int i;
148  for (i = 0; i < comp->y1 - comp->y0; i++)
149  ff_jpeg2000_printv(comp->i_data + i * (comp->x1 - comp->x0), comp->x1 - comp->x0);
150 }
151 
152 static void dump(Jpeg2000EncoderContext *s, FILE *fd)
153 {
154  int tileno, compno, reslevelno, bandno, precno;
155  fprintf(fd, "XSiz = %d, YSiz = %d, tile_width = %d, tile_height = %d\n"
156  "numXtiles = %d, numYtiles = %d, ncomponents = %d\n"
157  "tiles:\n",
158  s->width, s->height, s->tile_width, s->tile_height,
159  s->numXtiles, s->numYtiles, s->ncomponents);
160  for (tileno = 0; tileno < s->numXtiles * s->numYtiles; tileno++){
161  Jpeg2000Tile *tile = s->tile + tileno;
162  nspaces(fd, 2);
163  fprintf(fd, "tile %d:\n", tileno);
164  for(compno = 0; compno < s->ncomponents; compno++){
165  Jpeg2000Component *comp = tile->comp + compno;
166  nspaces(fd, 4);
167  fprintf(fd, "component %d:\n", compno);
168  nspaces(fd, 4);
169  fprintf(fd, "x0 = %d, x1 = %d, y0 = %d, y1 = %d\n",
170  comp->x0, comp->x1, comp->y0, comp->y1);
171  for(reslevelno = 0; reslevelno < s->nreslevels; reslevelno++){
172  Jpeg2000ResLevel *reslevel = comp->reslevel + reslevelno;
173  nspaces(fd, 6);
174  fprintf(fd, "reslevel %d:\n", reslevelno);
175  nspaces(fd, 6);
176  fprintf(fd, "x0 = %d, x1 = %d, y0 = %d, y1 = %d, nbands = %d\n",
177  reslevel->x0, reslevel->x1, reslevel->y0,
178  reslevel->y1, reslevel->nbands);
179  for(bandno = 0; bandno < reslevel->nbands; bandno++){
180  Jpeg2000Band *band = reslevel->band + bandno;
181  nspaces(fd, 8);
182  fprintf(fd, "band %d:\n", bandno);
183  nspaces(fd, 8);
184  fprintf(fd, "x0 = %d, x1 = %d, y0 = %d, y1 = %d,"
185  "codeblock_width = %d, codeblock_height = %d cblknx = %d cblkny = %d\n",
186  band->x0, band->x1,
187  band->y0, band->y1,
188  band->codeblock_width, band->codeblock_height,
189  band->cblknx, band->cblkny);
190  for (precno = 0; precno < reslevel->num_precincts_x * reslevel->num_precincts_y; precno++){
191  Jpeg2000Prec *prec = band->prec + precno;
192  nspaces(fd, 10);
193  fprintf(fd, "prec %d:\n", precno);
194  nspaces(fd, 10);
195  fprintf(fd, "xi0 = %d, xi1 = %d, yi0 = %d, yi1 = %d\n",
196  prec->xi0, prec->xi1, prec->yi0, prec->yi1);
197  }
198  }
199  }
200  }
201  }
202 }
203 #endif
204 
205 /* bitstream routines */
206 
207 /** put n times val bit */
208 static void put_bits(Jpeg2000EncoderContext *s, int val, int n) // TODO: optimize
209 {
210  while (n-- > 0){
211  if (s->bit_index == 8)
212  {
213  s->bit_index = *s->buf == 0xff;
214  *(++s->buf) = 0;
215  }
216  *s->buf |= val << (7 - s->bit_index++);
217  }
218 }
219 
220 /** put n least significant bits of a number num */
221 static void put_num(Jpeg2000EncoderContext *s, int num, int n)
222 {
223  while(--n >= 0)
224  put_bits(s, (num >> n) & 1, 1);
225 }
226 
227 /** flush the bitstream */
229 {
230  if (s->bit_index){
231  s->bit_index = 0;
232  s->buf++;
233  }
234 }
235 
236 /* tag tree routines */
237 
238 /** code the value stored in node */
239 static void tag_tree_code(Jpeg2000EncoderContext *s, Jpeg2000TgtNode *node, int threshold)
240 {
241  Jpeg2000TgtNode *stack[30];
242  int sp = 1, curval = 0;
243  stack[0] = node;
244 
245  node = node->parent;
246  while(node){
247  if (node->vis){
248  curval = node->val;
249  break;
250  }
251  node->vis++;
252  stack[sp++] = node;
253  node = node->parent;
254  }
255  while(--sp >= 0){
256  if (stack[sp]->val >= threshold){
257  put_bits(s, 0, threshold - curval);
258  break;
259  }
260  put_bits(s, 0, stack[sp]->val - curval);
261  put_bits(s, 1, 1);
262  curval = stack[sp]->val;
263  }
264 }
265 
266 /** update the value in node */
268 {
269  int lev = 0;
270  while (node->parent){
271  if (node->parent->val <= node->val)
272  break;
273  node->parent->val = node->val;
274  node = node->parent;
275  lev++;
276  }
277 }
278 
280 {
281  int i;
282 
283  if (s->buf_end - s->buf < 40 + 3 * s->ncomponents)
284  return -1;
285 
286  bytestream_put_be16(&s->buf, JPEG2000_SIZ);
287  bytestream_put_be16(&s->buf, 38 + 3 * s->ncomponents); // Lsiz
288  bytestream_put_be16(&s->buf, 0); // Rsiz
289  bytestream_put_be32(&s->buf, s->width); // width
290  bytestream_put_be32(&s->buf, s->height); // height
291  bytestream_put_be32(&s->buf, 0); // X0Siz
292  bytestream_put_be32(&s->buf, 0); // Y0Siz
293 
294  bytestream_put_be32(&s->buf, s->tile_width); // XTSiz
295  bytestream_put_be32(&s->buf, s->tile_height); // YTSiz
296  bytestream_put_be32(&s->buf, 0); // XT0Siz
297  bytestream_put_be32(&s->buf, 0); // YT0Siz
298  bytestream_put_be16(&s->buf, s->ncomponents); // CSiz
299 
300  for (i = 0; i < s->ncomponents; i++){ // Ssiz_i XRsiz_i, YRsiz_i
301  bytestream_put_byte(&s->buf, 7);
302  bytestream_put_byte(&s->buf, i?1<<s->chroma_shift[0]:1);
303  bytestream_put_byte(&s->buf, i?1<<s->chroma_shift[1]:1);
304  }
305  return 0;
306 }
307 
309 {
310  Jpeg2000CodingStyle *codsty = &s->codsty;
311 
312  if (s->buf_end - s->buf < 14)
313  return -1;
314 
315  bytestream_put_be16(&s->buf, JPEG2000_COD);
316  bytestream_put_be16(&s->buf, 12); // Lcod
317  bytestream_put_byte(&s->buf, 0); // Scod
318  // SGcod
319  bytestream_put_byte(&s->buf, 0); // progression level
320  bytestream_put_be16(&s->buf, 1); // num of layers
321  if(s->avctx->pix_fmt == AV_PIX_FMT_YUV444P){
322  bytestream_put_byte(&s->buf, 0); // unspecified
323  }else{
324  bytestream_put_byte(&s->buf, 0); // unspecified
325  }
326  // SPcod
327  bytestream_put_byte(&s->buf, codsty->nreslevels - 1); // num of decomp. levels
328  bytestream_put_byte(&s->buf, codsty->log2_cblk_width-2); // cblk width
329  bytestream_put_byte(&s->buf, codsty->log2_cblk_height-2); // cblk height
330  bytestream_put_byte(&s->buf, 0); // cblk style
331  bytestream_put_byte(&s->buf, codsty->transform == FF_DWT53); // transformation
332  return 0;
333 }
334 
335 static int put_qcd(Jpeg2000EncoderContext *s, int compno)
336 {
337  int i, size;
338  Jpeg2000CodingStyle *codsty = &s->codsty;
339  Jpeg2000QuantStyle *qntsty = &s->qntsty;
340 
341  if (qntsty->quantsty == JPEG2000_QSTY_NONE)
342  size = 4 + 3 * (codsty->nreslevels-1);
343  else // QSTY_SE
344  size = 5 + 6 * (codsty->nreslevels-1);
345 
346  if (s->buf_end - s->buf < size + 2)
347  return -1;
348 
349  bytestream_put_be16(&s->buf, JPEG2000_QCD);
350  bytestream_put_be16(&s->buf, size); // LQcd
351  bytestream_put_byte(&s->buf, (qntsty->nguardbits << 5) | qntsty->quantsty); // Sqcd
352  if (qntsty->quantsty == JPEG2000_QSTY_NONE)
353  for (i = 0; i < codsty->nreslevels * 3 - 2; i++)
354  bytestream_put_byte(&s->buf, qntsty->expn[i] << 3);
355  else // QSTY_SE
356  for (i = 0; i < codsty->nreslevels * 3 - 2; i++)
357  bytestream_put_be16(&s->buf, (qntsty->expn[i] << 11) | qntsty->mant[i]);
358  return 0;
359 }
360 
361 static int put_com(Jpeg2000EncoderContext *s, int compno)
362 {
363  int size = 4 + strlen(LIBAVCODEC_IDENT);
364 
365  if (s->avctx->flags & AV_CODEC_FLAG_BITEXACT)
366  return 0;
367 
368  if (s->buf_end - s->buf < size + 2)
369  return -1;
370 
371  bytestream_put_be16(&s->buf, JPEG2000_COM);
372  bytestream_put_be16(&s->buf, size);
373  bytestream_put_be16(&s->buf, 1); // General use (ISO/IEC 8859-15 (Latin) values)
374 
376 
377  return 0;
378 }
379 
381 {
382  uint8_t *psotptr;
383 
384  if (s->buf_end - s->buf < 12)
385  return NULL;
386 
387  bytestream_put_be16(&s->buf, JPEG2000_SOT);
388  bytestream_put_be16(&s->buf, 10); // Lsot
389  bytestream_put_be16(&s->buf, tileno); // Isot
390 
391  psotptr = s->buf;
392  bytestream_put_be32(&s->buf, 0); // Psot (filled in later)
393 
394  bytestream_put_byte(&s->buf, 0); // TPsot
395  bytestream_put_byte(&s->buf, 1); // TNsot
396  return psotptr;
397 }
398 
399 /**
400  * compute the sizes of tiles, resolution levels, bands, etc.
401  * allocate memory for them
402  * divide the input image into tile-components
403  */
405 {
406  int tileno, tilex, tiley, compno;
407  Jpeg2000CodingStyle *codsty = &s->codsty;
408  Jpeg2000QuantStyle *qntsty = &s->qntsty;
409 
410  s->numXtiles = ff_jpeg2000_ceildiv(s->width, s->tile_width);
411  s->numYtiles = ff_jpeg2000_ceildiv(s->height, s->tile_height);
412 
413  s->tile = av_calloc(s->numXtiles, s->numYtiles * sizeof(Jpeg2000Tile));
414  if (!s->tile)
415  return AVERROR(ENOMEM);
416  for (tileno = 0, tiley = 0; tiley < s->numYtiles; tiley++)
417  for (tilex = 0; tilex < s->numXtiles; tilex++, tileno++){
418  Jpeg2000Tile *tile = s->tile + tileno;
419 
420  tile->comp = av_mallocz_array(s->ncomponents, sizeof(Jpeg2000Component));
421  if (!tile->comp)
422  return AVERROR(ENOMEM);
423  for (compno = 0; compno < s->ncomponents; compno++){
424  Jpeg2000Component *comp = tile->comp + compno;
425  int ret, i, j;
426 
427  comp->coord[0][0] = comp->coord_o[0][0] = tilex * s->tile_width;
428  comp->coord[0][1] = comp->coord_o[0][1] = FFMIN((tilex+1)*s->tile_width, s->width);
429  comp->coord[1][0] = comp->coord_o[1][0] = tiley * s->tile_height;
430  comp->coord[1][1] = comp->coord_o[1][1] = FFMIN((tiley+1)*s->tile_height, s->height);
431  if (compno > 0)
432  for (i = 0; i < 2; i++)
433  for (j = 0; j < 2; j++)
434  comp->coord[i][j] = comp->coord_o[i][j] = ff_jpeg2000_ceildivpow2(comp->coord[i][j], s->chroma_shift[i]);
435 
437  codsty,
438  qntsty,
439  s->cbps[compno],
440  compno?1<<s->chroma_shift[0]:1,
441  compno?1<<s->chroma_shift[1]:1,
442  s->avctx
443  )) < 0)
444  return ret;
445  }
446  }
447  return 0;
448 }
449 
451 {
452  int tileno, compno, i, y, x;
453  uint8_t *line;
454  for (tileno = 0; tileno < s->numXtiles * s->numYtiles; tileno++){
455  Jpeg2000Tile *tile = s->tile + tileno;
456  if (s->planar){
457  for (compno = 0; compno < s->ncomponents; compno++){
458  Jpeg2000Component *comp = tile->comp + compno;
459  int *dst = comp->i_data;
460  line = s->picture->data[compno]
461  + comp->coord[1][0] * s->picture->linesize[compno]
462  + comp->coord[0][0];
463  for (y = comp->coord[1][0]; y < comp->coord[1][1]; y++){
464  uint8_t *ptr = line;
465  for (x = comp->coord[0][0]; x < comp->coord[0][1]; x++)
466  *dst++ = *ptr++ - (1 << 7);
467  line += s->picture->linesize[compno];
468  }
469  }
470  } else{
471  line = s->picture->data[0] + tile->comp[0].coord[1][0] * s->picture->linesize[0]
472  + tile->comp[0].coord[0][0] * s->ncomponents;
473 
474  i = 0;
475  for (y = tile->comp[0].coord[1][0]; y < tile->comp[0].coord[1][1]; y++){
476  uint8_t *ptr = line;
477  for (x = tile->comp[0].coord[0][0]; x < tile->comp[0].coord[0][1]; x++, i++){
478  for (compno = 0; compno < s->ncomponents; compno++){
479  tile->comp[compno].i_data[i] = *ptr++ - (1 << 7);
480  }
481  }
482  line += s->picture->linesize[0];
483  }
484  }
485  }
486 }
487 
489 {
490  int compno, reslevelno, bandno;
491  Jpeg2000QuantStyle *qntsty = &s->qntsty;
492  Jpeg2000CodingStyle *codsty = &s->codsty;
493 
494  for (compno = 0; compno < s->ncomponents; compno++){
495  int gbandno = 0;
496  for (reslevelno = 0; reslevelno < codsty->nreslevels; reslevelno++){
497  int nbands, lev = codsty->nreslevels - reslevelno - 1;
498  nbands = reslevelno ? 3 : 1;
499  for (bandno = 0; bandno < nbands; bandno++, gbandno++){
500  int expn, mant = 0;
501 
502  if (codsty->transform == FF_DWT97_INT){
503  int bandpos = bandno + (reslevelno>0),
504  ss = 81920000 / dwt_norms[0][bandpos][lev],
505  log = av_log2(ss);
506  mant = (11 - log < 0 ? ss >> log - 11 : ss << 11 - log) & 0x7ff;
507  expn = s->cbps[compno] - log + 13;
508  } else
509  expn = ((bandno&2)>>1) + (reslevelno>0) + s->cbps[compno];
510 
511  qntsty->expn[gbandno] = expn;
512  qntsty->mant[gbandno] = mant;
513  }
514  }
515  }
516 }
517 
518 static void init_luts(void)
519 {
520  int i, a,
521  mask = ~((1<<NMSEDEC_FRACBITS)-1);
522 
523  for (i = 0; i < (1 << NMSEDEC_BITS); i++){
524  lut_nmsedec_sig[i] = FFMAX((3 * i << (13 - NMSEDEC_FRACBITS)) - (9 << 11), 0);
525  lut_nmsedec_sig0[i] = FFMAX((i*i + (1<<NMSEDEC_FRACBITS-1) & mask) << 1, 0);
526 
527  a = (i >> (NMSEDEC_BITS-2)&2) + 1;
528  lut_nmsedec_ref[i] = FFMAX((a - 2) * (i << (13 - NMSEDEC_FRACBITS)) +
529  (1 << 13) - (a * a << 11), 0);
530  lut_nmsedec_ref0[i] = FFMAX(((i * i - (i << NMSEDEC_BITS) + (1 << 2 * NMSEDEC_FRACBITS) + (1 << (NMSEDEC_FRACBITS - 1))) & mask)
531  << 1, 0);
532  }
533 }
534 
535 /* tier-1 routines */
536 static int getnmsedec_sig(int x, int bpno)
537 {
538  if (bpno > NMSEDEC_FRACBITS)
539  return lut_nmsedec_sig[(x >> (bpno - NMSEDEC_FRACBITS)) & ((1 << NMSEDEC_BITS) - 1)];
540  return lut_nmsedec_sig0[x & ((1 << NMSEDEC_BITS) - 1)];
541 }
542 
543 static int getnmsedec_ref(int x, int bpno)
544 {
545  if (bpno > NMSEDEC_FRACBITS)
546  return lut_nmsedec_ref[(x >> (bpno - NMSEDEC_FRACBITS)) & ((1 << NMSEDEC_BITS) - 1)];
547  return lut_nmsedec_ref0[x & ((1 << NMSEDEC_BITS) - 1)];
548 }
549 
550 static void encode_sigpass(Jpeg2000T1Context *t1, int width, int height, int bandno, int *nmsedec, int bpno)
551 {
552  int y0, x, y, mask = 1 << (bpno + NMSEDEC_FRACBITS);
553  for (y0 = 0; y0 < height; y0 += 4)
554  for (x = 0; x < width; x++)
555  for (y = y0; y < height && y < y0+4; y++){
556  if (!(t1->flags[(y+1) * t1->stride + x+1] & JPEG2000_T1_SIG) && (t1->flags[(y+1) * t1->stride + x+1] & JPEG2000_T1_SIG_NB)){
557  int ctxno = ff_jpeg2000_getsigctxno(t1->flags[(y+1) * t1->stride + x+1], bandno),
558  bit = t1->data[(y) * t1->stride + x] & mask ? 1 : 0;
559  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, bit);
560  if (bit){
561  int xorbit;
562  int ctxno = ff_jpeg2000_getsgnctxno(t1->flags[(y+1) * t1->stride + x+1], &xorbit);
563  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, (t1->flags[(y+1) * t1->stride + x+1] >> 15) ^ xorbit);
564  *nmsedec += getnmsedec_sig(t1->data[(y) * t1->stride + x], bpno + NMSEDEC_FRACBITS);
565  ff_jpeg2000_set_significance(t1, x, y, t1->flags[(y+1) * t1->stride + x+1] >> 15);
566  }
567  t1->flags[(y+1) * t1->stride + x+1] |= JPEG2000_T1_VIS;
568  }
569  }
570 }
571 
572 static void encode_refpass(Jpeg2000T1Context *t1, int width, int height, int *nmsedec, int bpno)
573 {
574  int y0, x, y, mask = 1 << (bpno + NMSEDEC_FRACBITS);
575  for (y0 = 0; y0 < height; y0 += 4)
576  for (x = 0; x < width; x++)
577  for (y = y0; y < height && y < y0+4; y++)
578  if ((t1->flags[(y+1) * t1->stride + x+1] & (JPEG2000_T1_SIG | JPEG2000_T1_VIS)) == JPEG2000_T1_SIG){
579  int ctxno = ff_jpeg2000_getrefctxno(t1->flags[(y+1) * t1->stride + x+1]);
580  *nmsedec += getnmsedec_ref(t1->data[(y) * t1->stride + x], bpno + NMSEDEC_FRACBITS);
581  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, t1->data[(y) * t1->stride + x] & mask ? 1:0);
582  t1->flags[(y+1) * t1->stride + x+1] |= JPEG2000_T1_REF;
583  }
584 }
585 
586 static void encode_clnpass(Jpeg2000T1Context *t1, int width, int height, int bandno, int *nmsedec, int bpno)
587 {
588  int y0, x, y, mask = 1 << (bpno + NMSEDEC_FRACBITS);
589  for (y0 = 0; y0 < height; y0 += 4)
590  for (x = 0; x < width; x++){
591  if (y0 + 3 < height && !(
592  (t1->flags[(y0+1) * t1->stride + x+1] & (JPEG2000_T1_SIG_NB | JPEG2000_T1_VIS | JPEG2000_T1_SIG)) ||
593  (t1->flags[(y0+2) * t1->stride + x+1] & (JPEG2000_T1_SIG_NB | JPEG2000_T1_VIS | JPEG2000_T1_SIG)) ||
594  (t1->flags[(y0+3) * t1->stride + x+1] & (JPEG2000_T1_SIG_NB | JPEG2000_T1_VIS | JPEG2000_T1_SIG)) ||
595  (t1->flags[(y0+4) * t1->stride + x+1] & (JPEG2000_T1_SIG_NB | JPEG2000_T1_VIS | JPEG2000_T1_SIG))))
596  {
597  // aggregation mode
598  int rlen;
599  for (rlen = 0; rlen < 4; rlen++)
600  if (t1->data[(y0+rlen) * t1->stride + x] & mask)
601  break;
602  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + MQC_CX_RL, rlen != 4);
603  if (rlen == 4)
604  continue;
605  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + MQC_CX_UNI, rlen >> 1);
606  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + MQC_CX_UNI, rlen & 1);
607  for (y = y0 + rlen; y < y0 + 4; y++){
608  if (!(t1->flags[(y+1) * t1->stride + x+1] & (JPEG2000_T1_SIG | JPEG2000_T1_VIS))){
609  int ctxno = ff_jpeg2000_getsigctxno(t1->flags[(y+1) * t1->stride + x+1], bandno);
610  if (y > y0 + rlen)
611  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, t1->data[(y) * t1->stride + x] & mask ? 1:0);
612  if (t1->data[(y) * t1->stride + x] & mask){ // newly significant
613  int xorbit;
614  int ctxno = ff_jpeg2000_getsgnctxno(t1->flags[(y+1) * t1->stride + x+1], &xorbit);
615  *nmsedec += getnmsedec_sig(t1->data[(y) * t1->stride + x], bpno + NMSEDEC_FRACBITS);
616  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, (t1->flags[(y+1) * t1->stride + x+1] >> 15) ^ xorbit);
617  ff_jpeg2000_set_significance(t1, x, y, t1->flags[(y+1) * t1->stride + x+1] >> 15);
618  }
619  }
620  t1->flags[(y+1) * t1->stride + x+1] &= ~JPEG2000_T1_VIS;
621  }
622  } else{
623  for (y = y0; y < y0 + 4 && y < height; y++){
624  if (!(t1->flags[(y+1) * t1->stride + x+1] & (JPEG2000_T1_SIG | JPEG2000_T1_VIS))){
625  int ctxno = ff_jpeg2000_getsigctxno(t1->flags[(y+1) * t1->stride + x+1], bandno);
626  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, t1->data[(y) * t1->stride + x] & mask ? 1:0);
627  if (t1->data[(y) * t1->stride + x] & mask){ // newly significant
628  int xorbit;
629  int ctxno = ff_jpeg2000_getsgnctxno(t1->flags[(y+1) * t1->stride + x+1], &xorbit);
630  *nmsedec += getnmsedec_sig(t1->data[(y) * t1->stride + x], bpno + NMSEDEC_FRACBITS);
631  ff_mqc_encode(&t1->mqc, t1->mqc.cx_states + ctxno, (t1->flags[(y+1) * t1->stride + x+1] >> 15) ^ xorbit);
632  ff_jpeg2000_set_significance(t1, x, y, t1->flags[(y+1) * t1->stride + x+1] >> 15);
633  }
634  }
635  t1->flags[(y+1) * t1->stride + x+1] &= ~JPEG2000_T1_VIS;
636  }
637  }
638  }
639 }
640 
642  int width, int height, int bandpos, int lev)
643 {
644  int pass_t = 2, passno, x, y, max=0, nmsedec, bpno;
645  int64_t wmsedec = 0;
646 
647  memset(t1->flags, 0, t1->stride * (height + 2) * sizeof(*t1->flags));
648 
649  for (y = 0; y < height; y++){
650  for (x = 0; x < width; x++){
651  if (t1->data[(y) * t1->stride + x] < 0){
652  t1->flags[(y+1) * t1->stride + x+1] |= JPEG2000_T1_SGN;
653  t1->data[(y) * t1->stride + x] = -t1->data[(y) * t1->stride + x];
654  }
655  max = FFMAX(max, t1->data[(y) * t1->stride + x]);
656  }
657  }
658 
659  if (max == 0){
660  cblk->nonzerobits = 0;
661  bpno = 0;
662  } else{
663  cblk->nonzerobits = av_log2(max) + 1 - NMSEDEC_FRACBITS;
664  bpno = cblk->nonzerobits - 1;
665  }
666 
667  cblk->data[0] = 0;
668  ff_mqc_initenc(&t1->mqc, cblk->data + 1);
669 
670  for (passno = 0; bpno >= 0; passno++){
671  nmsedec=0;
672 
673  switch(pass_t){
674  case 0: encode_sigpass(t1, width, height, bandpos, &nmsedec, bpno);
675  break;
676  case 1: encode_refpass(t1, width, height, &nmsedec, bpno);
677  break;
678  case 2: encode_clnpass(t1, width, height, bandpos, &nmsedec, bpno);
679  break;
680  }
681 
682  cblk->passes[passno].rate = ff_mqc_flush_to(&t1->mqc, cblk->passes[passno].flushed, &cblk->passes[passno].flushed_len);
683  wmsedec += (int64_t)nmsedec << (2*bpno);
684  cblk->passes[passno].disto = wmsedec;
685 
686  if (++pass_t == 3){
687  pass_t = 0;
688  bpno--;
689  }
690  }
691  cblk->npasses = passno;
692  cblk->ninclpasses = passno;
693 
694  if (passno)
695  cblk->passes[passno-1].rate = ff_mqc_flush_to(&t1->mqc, cblk->passes[passno-1].flushed, &cblk->passes[passno-1].flushed_len);
696 }
697 
698 /* tier-2 routines: */
699 
701 {
702  if (n == 1)
703  put_num(s, 0, 1);
704  else if (n == 2)
705  put_num(s, 2, 2);
706  else if (n <= 5)
707  put_num(s, 0xc | (n-3), 4);
708  else if (n <= 36)
709  put_num(s, 0x1e0 | (n-6), 9);
710  else
711  put_num(s, 0xff80 | (n-37), 16);
712 }
713 
714 
715 static int encode_packet(Jpeg2000EncoderContext *s, Jpeg2000ResLevel *rlevel, int precno,
716  uint8_t *expn, int numgbits)
717 {
718  int bandno, empty = 1;
719 
720  // init bitstream
721  *s->buf = 0;
722  s->bit_index = 0;
723 
724  // header
725 
726  // is the packet empty?
727  for (bandno = 0; bandno < rlevel->nbands; bandno++){
728  if (rlevel->band[bandno].coord[0][0] < rlevel->band[bandno].coord[0][1]
729  && rlevel->band[bandno].coord[1][0] < rlevel->band[bandno].coord[1][1]){
730  empty = 0;
731  break;
732  }
733  }
734 
735  put_bits(s, !empty, 1);
736  if (empty){
737  j2k_flush(s);
738  return 0;
739  }
740 
741  for (bandno = 0; bandno < rlevel->nbands; bandno++){
742  Jpeg2000Band *band = rlevel->band + bandno;
743  Jpeg2000Prec *prec = band->prec + precno;
744  int yi, xi, pos;
745  int cblknw = prec->nb_codeblocks_width;
746 
747  if (band->coord[0][0] == band->coord[0][1]
748  || band->coord[1][0] == band->coord[1][1])
749  continue;
750 
751  for (pos=0, yi = 0; yi < prec->nb_codeblocks_height; yi++){
752  for (xi = 0; xi < cblknw; xi++, pos++){
753  prec->cblkincl[pos].val = prec->cblk[yi * cblknw + xi].ninclpasses == 0;
754  tag_tree_update(prec->cblkincl + pos);
755  prec->zerobits[pos].val = expn[bandno] + numgbits - 1 - prec->cblk[yi * cblknw + xi].nonzerobits;
756  tag_tree_update(prec->zerobits + pos);
757  }
758  }
759 
760  for (pos=0, yi = 0; yi < prec->nb_codeblocks_height; yi++){
761  for (xi = 0; xi < cblknw; xi++, pos++){
762  int pad = 0, llen, length;
763  Jpeg2000Cblk *cblk = prec->cblk + yi * cblknw + xi;
764 
765  if (s->buf_end - s->buf < 20) // approximately
766  return -1;
767 
768  // inclusion information
769  tag_tree_code(s, prec->cblkincl + pos, 1);
770  if (!cblk->ninclpasses)
771  continue;
772  // zerobits information
773  tag_tree_code(s, prec->zerobits + pos, 100);
774  // number of passes
775  putnumpasses(s, cblk->ninclpasses);
776 
777  length = cblk->passes[cblk->ninclpasses-1].rate;
778  llen = av_log2(length) - av_log2(cblk->ninclpasses) - 2;
779  if (llen < 0){
780  pad = -llen;
781  llen = 0;
782  }
783  // length of code block
784  put_bits(s, 1, llen);
785  put_bits(s, 0, 1);
786  put_num(s, length, av_log2(length)+1+pad);
787  }
788  }
789  }
790  j2k_flush(s);
791  for (bandno = 0; bandno < rlevel->nbands; bandno++){
792  Jpeg2000Band *band = rlevel->band + bandno;
793  Jpeg2000Prec *prec = band->prec + precno;
794  int yi, cblknw = prec->nb_codeblocks_width;
795  for (yi =0; yi < prec->nb_codeblocks_height; yi++){
796  int xi;
797  for (xi = 0; xi < cblknw; xi++){
798  Jpeg2000Cblk *cblk = prec->cblk + yi * cblknw + xi;
799  if (cblk->ninclpasses){
800  if (s->buf_end - s->buf < cblk->passes[cblk->ninclpasses-1].rate)
801  return -1;
802  bytestream_put_buffer(&s->buf, cblk->data + 1, cblk->passes[cblk->ninclpasses-1].rate
803  - cblk->passes[cblk->ninclpasses-1].flushed_len);
804  bytestream_put_buffer(&s->buf, cblk->passes[cblk->ninclpasses-1].flushed,
805  cblk->passes[cblk->ninclpasses-1].flushed_len);
806  }
807  }
808  }
809  }
810  return 0;
811 }
812 
813 static int encode_packets(Jpeg2000EncoderContext *s, Jpeg2000Tile *tile, int tileno)
814 {
815  int compno, reslevelno, ret;
816  Jpeg2000CodingStyle *codsty = &s->codsty;
817  Jpeg2000QuantStyle *qntsty = &s->qntsty;
818 
819  av_log(s->avctx, AV_LOG_DEBUG, "tier2\n");
820  // lay-rlevel-comp-pos progression
821  for (reslevelno = 0; reslevelno < codsty->nreslevels; reslevelno++){
822  for (compno = 0; compno < s->ncomponents; compno++){
823  int precno;
824  Jpeg2000ResLevel *reslevel = s->tile[tileno].comp[compno].reslevel + reslevelno;
825  for (precno = 0; precno < reslevel->num_precincts_x * reslevel->num_precincts_y; precno++){
826  if ((ret = encode_packet(s, reslevel, precno, qntsty->expn + (reslevelno ? 3*reslevelno-2 : 0),
827  qntsty->nguardbits)) < 0)
828  return ret;
829  }
830  }
831  }
832  av_log(s->avctx, AV_LOG_DEBUG, "after tier2\n");
833  return 0;
834 }
835 
836 static int getcut(Jpeg2000Cblk *cblk, int64_t lambda, int dwt_norm)
837 {
838  int passno, res = 0;
839  for (passno = 0; passno < cblk->npasses; passno++){
840  int dr;
841  int64_t dd;
842 
843  dr = cblk->passes[passno].rate
844  - (res ? cblk->passes[res-1].rate:0);
845  dd = cblk->passes[passno].disto
846  - (res ? cblk->passes[res-1].disto:0);
847 
848  if (((dd * dwt_norm) >> WMSEDEC_SHIFT) * dwt_norm >= dr * lambda)
849  res = passno+1;
850  }
851  return res;
852 }
853 
855 {
856  int precno, compno, reslevelno, bandno, cblkno, lev;
857  Jpeg2000CodingStyle *codsty = &s->codsty;
858 
859  for (compno = 0; compno < s->ncomponents; compno++){
860  Jpeg2000Component *comp = tile->comp + compno;
861 
862  for (reslevelno = 0, lev = codsty->nreslevels-1; reslevelno < codsty->nreslevels; reslevelno++, lev--){
863  Jpeg2000ResLevel *reslevel = comp->reslevel + reslevelno;
864 
865  for (precno = 0; precno < reslevel->num_precincts_x * reslevel->num_precincts_y; precno++){
866  for (bandno = 0; bandno < reslevel->nbands ; bandno++){
867  int bandpos = bandno + (reslevelno > 0);
868  Jpeg2000Band *band = reslevel->band + bandno;
869  Jpeg2000Prec *prec = band->prec + precno;
870 
871  for (cblkno = 0; cblkno < prec->nb_codeblocks_height * prec->nb_codeblocks_width; cblkno++){
872  Jpeg2000Cblk *cblk = prec->cblk + cblkno;
873 
874  cblk->ninclpasses = getcut(cblk, s->lambda,
875  (int64_t)dwt_norms[codsty->transform == FF_DWT53][bandpos][lev] * (int64_t)band->i_stepsize >> 15);
876  }
877  }
878  }
879  }
880  }
881 }
882 
883 static int encode_tile(Jpeg2000EncoderContext *s, Jpeg2000Tile *tile, int tileno)
884 {
885  int compno, reslevelno, bandno, ret;
887  Jpeg2000CodingStyle *codsty = &s->codsty;
888  for (compno = 0; compno < s->ncomponents; compno++){
889  Jpeg2000Component *comp = s->tile[tileno].comp + compno;
890 
891  t1.stride = (1<<codsty->log2_cblk_width) + 2;
892 
893  av_log(s->avctx, AV_LOG_DEBUG,"dwt\n");
894  if ((ret = ff_dwt_encode(&comp->dwt, comp->i_data)) < 0)
895  return ret;
896  av_log(s->avctx, AV_LOG_DEBUG,"after dwt -> tier1\n");
897 
898  for (reslevelno = 0; reslevelno < codsty->nreslevels; reslevelno++){
899  Jpeg2000ResLevel *reslevel = comp->reslevel + reslevelno;
900 
901  for (bandno = 0; bandno < reslevel->nbands ; bandno++){
902  Jpeg2000Band *band = reslevel->band + bandno;
903  Jpeg2000Prec *prec = band->prec; // we support only 1 precinct per band ATM in the encoder
904  int cblkx, cblky, cblkno=0, xx0, x0, xx1, y0, yy0, yy1, bandpos;
905  yy0 = bandno == 0 ? 0 : comp->reslevel[reslevelno-1].coord[1][1] - comp->reslevel[reslevelno-1].coord[1][0];
906  y0 = yy0;
907  yy1 = FFMIN(ff_jpeg2000_ceildivpow2(band->coord[1][0] + 1, band->log2_cblk_height) << band->log2_cblk_height,
908  band->coord[1][1]) - band->coord[1][0] + yy0;
909 
910  if (band->coord[0][0] == band->coord[0][1] || band->coord[1][0] == band->coord[1][1])
911  continue;
912 
913  bandpos = bandno + (reslevelno > 0);
914 
915  for (cblky = 0; cblky < prec->nb_codeblocks_height; cblky++){
916  if (reslevelno == 0 || bandno == 1)
917  xx0 = 0;
918  else
919  xx0 = comp->reslevel[reslevelno-1].coord[0][1] - comp->reslevel[reslevelno-1].coord[0][0];
920  x0 = xx0;
921  xx1 = FFMIN(ff_jpeg2000_ceildivpow2(band->coord[0][0] + 1, band->log2_cblk_width) << band->log2_cblk_width,
922  band->coord[0][1]) - band->coord[0][0] + xx0;
923 
924  for (cblkx = 0; cblkx < prec->nb_codeblocks_width; cblkx++, cblkno++){
925  int y, x;
926  if (codsty->transform == FF_DWT53){
927  for (y = yy0; y < yy1; y++){
928  int *ptr = t1.data + (y-yy0)*t1.stride;
929  for (x = xx0; x < xx1; x++){
930  *ptr++ = comp->i_data[(comp->coord[0][1] - comp->coord[0][0]) * y + x] * (1 << NMSEDEC_FRACBITS);
931  }
932  }
933  } else{
934  for (y = yy0; y < yy1; y++){
935  int *ptr = t1.data + (y-yy0)*t1.stride;
936  for (x = xx0; x < xx1; x++){
937  *ptr = (comp->i_data[(comp->coord[0][1] - comp->coord[0][0]) * y + x]);
938  *ptr = (int64_t)*ptr * (int64_t)(16384 * 65536 / band->i_stepsize) >> 15 - NMSEDEC_FRACBITS;
939  ptr++;
940  }
941  }
942  }
943  if (!prec->cblk[cblkno].data)
944  prec->cblk[cblkno].data = av_malloc(1 + 8192);
945  if (!prec->cblk[cblkno].passes)
946  prec->cblk[cblkno].passes = av_malloc_array(JPEG2000_MAX_PASSES, sizeof (*prec->cblk[cblkno].passes));
947  if (!prec->cblk[cblkno].data || !prec->cblk[cblkno].passes)
948  return AVERROR(ENOMEM);
949  encode_cblk(s, &t1, prec->cblk + cblkno, tile, xx1 - xx0, yy1 - yy0,
950  bandpos, codsty->nreslevels - reslevelno - 1);
951  xx0 = xx1;
952  xx1 = FFMIN(xx1 + (1 << band->log2_cblk_width), band->coord[0][1] - band->coord[0][0] + x0);
953  }
954  yy0 = yy1;
955  yy1 = FFMIN(yy1 + (1 << band->log2_cblk_height), band->coord[1][1] - band->coord[1][0] + y0);
956  }
957  }
958  }
959  av_log(s->avctx, AV_LOG_DEBUG, "after tier1\n");
960  }
961 
962  av_log(s->avctx, AV_LOG_DEBUG, "rate control\n");
963  truncpasses(s, tile);
964  if ((ret = encode_packets(s, tile, tileno)) < 0)
965  return ret;
966  av_log(s->avctx, AV_LOG_DEBUG, "after rate control\n");
967  return 0;
968 }
969 
971 {
972  int tileno, compno;
973  Jpeg2000CodingStyle *codsty = &s->codsty;
974 
975  if (!s->tile)
976  return;
977  for (tileno = 0; tileno < s->numXtiles * s->numYtiles; tileno++){
978  if (s->tile[tileno].comp) {
979  for (compno = 0; compno < s->ncomponents; compno++){
980  Jpeg2000Component *comp = s->tile[tileno].comp + compno;
981  ff_jpeg2000_cleanup(comp, codsty);
982  }
983  av_freep(&s->tile[tileno].comp);
984  }
985  }
986  av_freep(&s->tile);
987 }
988 
990 {
991  int tileno, compno;
992  for (tileno = 0; tileno < s->numXtiles * s->numYtiles; tileno++){
993  Jpeg2000Tile *tile = s->tile + tileno;
994  for (compno = 0; compno < s->ncomponents; compno++)
995  ff_jpeg2000_reinit(tile->comp + compno, &s->codsty);
996  }
997 }
998 
999 static void update_size(uint8_t *size, const uint8_t *end)
1000 {
1001  AV_WB32(size, end-size);
1002 }
1003 
1005  const AVFrame *pict, int *got_packet)
1006 {
1007  int tileno, ret;
1009  uint8_t *chunkstart, *jp2cstart, *jp2hstart;
1010 
1011  if ((ret = ff_alloc_packet2(avctx, pkt, avctx->width*avctx->height*9 + AV_INPUT_BUFFER_MIN_SIZE, 0)) < 0)
1012  return ret;
1013 
1014  // init:
1015  s->buf = s->buf_start = pkt->data;
1016  s->buf_end = pkt->data + pkt->size;
1017 
1018  s->picture = pict;
1019 
1020  s->lambda = s->picture->quality * LAMBDA_SCALE;
1021 
1022  copy_frame(s);
1023  reinit(s);
1024 
1025  if (s->format == CODEC_JP2) {
1026  av_assert0(s->buf == pkt->data);
1027 
1028  bytestream_put_be32(&s->buf, 0x0000000C);
1029  bytestream_put_be32(&s->buf, 0x6A502020);
1030  bytestream_put_be32(&s->buf, 0x0D0A870A);
1031 
1032  chunkstart = s->buf;
1033  bytestream_put_be32(&s->buf, 0);
1034  bytestream_put_buffer(&s->buf, "ftyp", 4);
1035  bytestream_put_buffer(&s->buf, "jp2\040\040", 4);
1036  bytestream_put_be32(&s->buf, 0);
1037  bytestream_put_buffer(&s->buf, "jp2\040", 4);
1038  update_size(chunkstart, s->buf);
1039 
1040  jp2hstart = s->buf;
1041  bytestream_put_be32(&s->buf, 0);
1042  bytestream_put_buffer(&s->buf, "jp2h", 4);
1043 
1044  chunkstart = s->buf;
1045  bytestream_put_be32(&s->buf, 0);
1046  bytestream_put_buffer(&s->buf, "ihdr", 4);
1047  bytestream_put_be32(&s->buf, avctx->height);
1048  bytestream_put_be32(&s->buf, avctx->width);
1049  bytestream_put_be16(&s->buf, s->ncomponents);
1050  bytestream_put_byte(&s->buf, s->cbps[0]);
1051  bytestream_put_byte(&s->buf, 7);
1052  bytestream_put_byte(&s->buf, 0);
1053  bytestream_put_byte(&s->buf, 0);
1054  update_size(chunkstart, s->buf);
1055 
1056  chunkstart = s->buf;
1057  bytestream_put_be32(&s->buf, 0);
1058  bytestream_put_buffer(&s->buf, "colr", 4);
1059  bytestream_put_byte(&s->buf, 1);
1060  bytestream_put_byte(&s->buf, 0);
1061  bytestream_put_byte(&s->buf, 0);
1062  if (avctx->pix_fmt == AV_PIX_FMT_RGB24 || avctx->pix_fmt == AV_PIX_FMT_PAL8) {
1063  bytestream_put_be32(&s->buf, 16);
1064  } else if (s->ncomponents == 1) {
1065  bytestream_put_be32(&s->buf, 17);
1066  } else {
1067  bytestream_put_be32(&s->buf, 18);
1068  }
1069  update_size(chunkstart, s->buf);
1070  if (avctx->pix_fmt == AV_PIX_FMT_PAL8) {
1071  int i;
1072  uint8_t *palette = pict->data[1];
1073  chunkstart = s->buf;
1074  bytestream_put_be32(&s->buf, 0);
1075  bytestream_put_buffer(&s->buf, "pclr", 4);
1076  bytestream_put_be16(&s->buf, AVPALETTE_COUNT);
1077  bytestream_put_byte(&s->buf, 3); // colour channels
1078  bytestream_put_be24(&s->buf, 0x070707); //colour depths
1079  for (i = 0; i < AVPALETTE_COUNT; i++) {
1080  bytestream_put_be24(&s->buf, HAVE_BIGENDIAN ? AV_RB24(palette + 1) : AV_RL24(palette));
1081  palette += 4;
1082  }
1083  update_size(chunkstart, s->buf);
1084  chunkstart = s->buf;
1085  bytestream_put_be32(&s->buf, 0);
1086  bytestream_put_buffer(&s->buf, "cmap", 4);
1087  for (i = 0; i < 3; i++) {
1088  bytestream_put_be16(&s->buf, 0); // component
1089  bytestream_put_byte(&s->buf, 1); // palette mapping
1090  bytestream_put_byte(&s->buf, i); // index
1091  }
1092  update_size(chunkstart, s->buf);
1093  }
1094  update_size(jp2hstart, s->buf);
1095 
1096  jp2cstart = s->buf;
1097  bytestream_put_be32(&s->buf, 0);
1098  bytestream_put_buffer(&s->buf, "jp2c", 4);
1099  }
1100 
1101  if (s->buf_end - s->buf < 2)
1102  return -1;
1103  bytestream_put_be16(&s->buf, JPEG2000_SOC);
1104  if ((ret = put_siz(s)) < 0)
1105  return ret;
1106  if ((ret = put_cod(s)) < 0)
1107  return ret;
1108  if ((ret = put_qcd(s, 0)) < 0)
1109  return ret;
1110  if ((ret = put_com(s, 0)) < 0)
1111  return ret;
1112 
1113  for (tileno = 0; tileno < s->numXtiles * s->numYtiles; tileno++){
1114  uint8_t *psotptr;
1115  if (!(psotptr = put_sot(s, tileno)))
1116  return -1;
1117  if (s->buf_end - s->buf < 2)
1118  return -1;
1119  bytestream_put_be16(&s->buf, JPEG2000_SOD);
1120  if ((ret = encode_tile(s, s->tile + tileno, tileno)) < 0)
1121  return ret;
1122  bytestream_put_be32(&psotptr, s->buf - psotptr + 6);
1123  }
1124  if (s->buf_end - s->buf < 2)
1125  return -1;
1126  bytestream_put_be16(&s->buf, JPEG2000_EOC);
1127 
1128  if (s->format == CODEC_JP2)
1129  update_size(jp2cstart, s->buf);
1130 
1131  av_log(s->avctx, AV_LOG_DEBUG, "end\n");
1132  pkt->size = s->buf - s->buf_start;
1134  *got_packet = 1;
1135 
1136  return 0;
1137 }
1138 
1140 {
1141  int i, ret;
1143  Jpeg2000CodingStyle *codsty = &s->codsty;
1144  Jpeg2000QuantStyle *qntsty = &s->qntsty;
1145 
1146  s->avctx = avctx;
1147  av_log(s->avctx, AV_LOG_DEBUG, "init\n");
1148 
1149 #if FF_API_PRIVATE_OPT
1151  if (avctx->prediction_method)
1152  s->pred = avctx->prediction_method;
1154 #endif
1155 
1156  if (avctx->pix_fmt == AV_PIX_FMT_PAL8 && (s->pred != FF_DWT97_INT || s->format != CODEC_JP2)) {
1157  av_log(s->avctx, AV_LOG_WARNING, "Forcing lossless jp2 for pal8\n");
1158  s->pred = FF_DWT97_INT;
1159  s->format = CODEC_JP2;
1160  }
1161 
1162  // defaults:
1163  // TODO: implement setting non-standard precinct size
1164  memset(codsty->log2_prec_widths , 15, sizeof(codsty->log2_prec_widths ));
1165  memset(codsty->log2_prec_heights, 15, sizeof(codsty->log2_prec_heights));
1166  codsty->nreslevels2decode=
1167  codsty->nreslevels = 7;
1168  codsty->log2_cblk_width = 4;
1169  codsty->log2_cblk_height = 4;
1170  codsty->transform = s->pred ? FF_DWT53 : FF_DWT97_INT;
1171 
1172  qntsty->nguardbits = 1;
1173 
1174  if ((s->tile_width & (s->tile_width -1)) ||
1175  (s->tile_height & (s->tile_height-1))) {
1176  av_log(avctx, AV_LOG_WARNING, "Tile dimension not a power of 2\n");
1177  }
1178 
1179  if (codsty->transform == FF_DWT53)
1180  qntsty->quantsty = JPEG2000_QSTY_NONE;
1181  else
1182  qntsty->quantsty = JPEG2000_QSTY_SE;
1183 
1184  s->width = avctx->width;
1185  s->height = avctx->height;
1186 
1187  for (i = 0; i < 3; i++)
1188  s->cbps[i] = 8;
1189 
1190  if (avctx->pix_fmt == AV_PIX_FMT_RGB24){
1191  s->ncomponents = 3;
1192  } else if (avctx->pix_fmt == AV_PIX_FMT_GRAY8 || avctx->pix_fmt == AV_PIX_FMT_PAL8){
1193  s->ncomponents = 1;
1194  } else{ // planar YUV
1195  s->planar = 1;
1196  s->ncomponents = 3;
1198  s->chroma_shift, s->chroma_shift + 1);
1199  if (ret)
1200  return ret;
1201  }
1202 
1205  init_luts();
1206 
1208  if ((ret=init_tiles(s)) < 0)
1209  return ret;
1210 
1211  av_log(s->avctx, AV_LOG_DEBUG, "after init\n");
1212 
1213  return 0;
1214 }
1215 
1216 static int j2kenc_destroy(AVCodecContext *avctx)
1217 {
1219 
1220  cleanup(s);
1221  return 0;
1222 }
1223 
1224 // taken from the libopenjpeg wraper so it matches
1225 
1226 #define OFFSET(x) offsetof(Jpeg2000EncoderContext, x)
1227 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
1228 static const AVOption options[] = {
1229  { "format", "Codec Format", OFFSET(format), AV_OPT_TYPE_INT, { .i64 = CODEC_JP2 }, CODEC_J2K, CODEC_JP2, VE, "format" },
1230  { "j2k", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = CODEC_J2K }, 0, 0, VE, "format" },
1231  { "jp2", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = CODEC_JP2 }, 0, 0, VE, "format" },
1232  { "tile_width", "Tile Width", OFFSET(tile_width), AV_OPT_TYPE_INT, { .i64 = 256 }, 1, 1<<30, VE, },
1233  { "tile_height", "Tile Height", OFFSET(tile_height), AV_OPT_TYPE_INT, { .i64 = 256 }, 1, 1<<30, VE, },
1234  { "pred", "DWT Type", OFFSET(pred), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1, VE, "pred" },
1235  { "dwt97int", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 0 }, INT_MIN, INT_MAX, VE, "pred" },
1236  { "dwt53", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = 0 }, INT_MIN, INT_MAX, VE, "pred" },
1237 
1238  { NULL }
1239 };
1240 
1241 static const AVClass j2k_class = {
1242  .class_name = "jpeg 2000 encoder",
1243  .item_name = av_default_item_name,
1244  .option = options,
1245  .version = LIBAVUTIL_VERSION_INT,
1246 };
1247 
1249  .name = "jpeg2000",
1250  .long_name = NULL_IF_CONFIG_SMALL("JPEG 2000"),
1251  .type = AVMEDIA_TYPE_VIDEO,
1252  .id = AV_CODEC_ID_JPEG2000,
1253  .priv_data_size = sizeof(Jpeg2000EncoderContext),
1254  .init = j2kenc_init,
1255  .encode2 = encode_frame,
1256  .close = j2kenc_destroy,
1257  .pix_fmts = (const enum AVPixelFormat[]) {
1263  },
1264  .priv_class = &j2k_class,
1265  .caps_internal = FF_CODEC_CAP_INIT_CLEANUP,
1266 };
AVCodec
AVCodec.
Definition: codec.h:190
FF_ENABLE_DEPRECATION_WARNINGS
#define FF_ENABLE_DEPRECATION_WARNINGS
Definition: internal.h:85
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:182
encode_packets
static int encode_packets(Jpeg2000EncoderContext *s, Jpeg2000Tile *tile, int tileno)
Definition: j2kenc.c:813
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:64
tag_tree_code
static void tag_tree_code(Jpeg2000EncoderContext *s, Jpeg2000TgtNode *node, int threshold)
code the value stored in node
Definition: j2kenc.c:239
init
static av_cold int init(AVCodecContext *avctx)
Definition: avrndec.c:35
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
opt.h
Jpeg2000QuantStyle::quantsty
uint8_t quantsty
Definition: jpeg2000.h:152
LIBAVCODEC_IDENT
#define LIBAVCODEC_IDENT
Definition: version.h:42
JPEG2000_EOC
@ JPEG2000_EOC
Definition: jpeg2000.h:58
options
static const AVOption options[]
Definition: j2kenc.c:1228
comp
static void comp(unsigned char *dst, ptrdiff_t dst_stride, unsigned char *src, ptrdiff_t src_stride, int add)
Definition: eamad.c:83
Jpeg2000EncoderContext::buf
uint8_t * buf
Definition: j2kenc.c:119
ff_jpeg2000_init_component
int ff_jpeg2000_init_component(Jpeg2000Component *comp, Jpeg2000CodingStyle *codsty, Jpeg2000QuantStyle *qntsty, int cbps, int dx, int dy, AVCodecContext *avctx)
Definition: jpeg2000.c:451
JPEG2000_QSTY_NONE
@ JPEG2000_QSTY_NONE
Definition: jpeg2000.h:65
Jpeg2000EncoderContext::bit_index
int bit_index
Definition: j2kenc.c:121
j2kenc_init
static av_cold int j2kenc_init(AVCodecContext *avctx)
Definition: j2kenc.c:1139
JPEG2000_QCD
@ JPEG2000_QCD
Definition: jpeg2000.h:46
Jpeg2000Prec::nb_codeblocks_height
int nb_codeblocks_height
Definition: jpeg2000.h:182
end
static av_cold int end(AVCodecContext *avctx)
Definition: avrndec.c:92
Jpeg2000Band::i_stepsize
int i_stepsize
Definition: jpeg2000.h:193
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:300
put_bits
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
Definition: j2kenc.c:208
pixdesc.h
internal.h
AVPacket::data
uint8_t * data
Definition: packet.h:355
j2k_class
static const AVClass j2k_class
Definition: j2kenc.c:1241
Jpeg2000Prec::zerobits
Jpeg2000TgtNode * zerobits
Definition: jpeg2000.h:183
CODEC_J2K
#define CODEC_J2K
Definition: j2kenc.c:82
AVOption
AVOption.
Definition: opt.h:246
JPEG2000_SOD
@ JPEG2000_SOD
Definition: jpeg2000.h:57
JPEG2000_SOC
@ JPEG2000_SOC
Definition: jpeg2000.h:39
ff_dwt_encode
int ff_dwt_encode(DWTContext *s, void *t)
Definition: jpeg2000dwt.c:581
Jpeg2000Prec
Definition: jpeg2000.h:180
av_mallocz_array
void * av_mallocz_array(size_t nmemb, size_t size)
Definition: mem.c:190
float.h
JPEG2000_SOT
@ JPEG2000_SOT
Definition: jpeg2000.h:54
Jpeg2000TgtNode::parent
struct Jpeg2000TgtNode * parent
Definition: jpeg2000.h:131
Jpeg2000Band
Definition: jpeg2000.h:190
t1
#define t1
Definition: regdef.h:29
Jpeg2000EncoderContext::lambda
int64_t lambda
Definition: j2kenc.c:123
encode_frame
static int encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pict, int *got_packet)
Definition: j2kenc.c:1004
max
#define max(a, b)
Definition: cuda_runtime.h:33
Jpeg2000Pass::rate
uint16_t rate
Definition: jpeg2000.h:157
LAMBDA_SCALE
#define LAMBDA_SCALE
Definition: j2kenc.c:79
Jpeg2000Tile
Definition: j2kenc.c:101
ff_jpeg2000_getrefctxno
static int ff_jpeg2000_getrefctxno(int flag)
Definition: jpeg2000.h:250
Jpeg2000Pass::flushed_len
int flushed_len
Definition: jpeg2000.h:160
j2kenc_destroy
static int j2kenc_destroy(AVCodecContext *avctx)
Definition: j2kenc.c:1216
AV_PKT_FLAG_KEY
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
Definition: packet.h:388
AVFrame::data
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
Definition: frame.h:314
av_malloc
#define av_malloc(s)
Definition: tableprint_vlc.h:31
bit
#define bit(string, value)
Definition: cbs_mpeg2.c:58
tag_tree_update
static void tag_tree_update(Jpeg2000TgtNode *node)
update the value in node
Definition: j2kenc.c:267
AVCodecContext::prediction_method
attribute_deprecated int prediction_method
Definition: avcodec.h:885
Jpeg2000CodingStyle::log2_cblk_width
uint8_t log2_cblk_width
Definition: jpeg2000.h:137
Jpeg2000EncoderContext::buf_end
uint8_t * buf_end
Definition: j2kenc.c:120
Jpeg2000Cblk::passes
Jpeg2000Pass * passes
Definition: jpeg2000.h:176
Jpeg2000CodingStyle::log2_prec_heights
uint8_t log2_prec_heights[JPEG2000_MAX_RESLEVELS]
Definition: jpeg2000.h:146
val
static double val(void *priv, double ch)
Definition: aeval.c:76
av_pix_fmt_get_chroma_sub_sample
int av_pix_fmt_get_chroma_sub_sample(enum AVPixelFormat pix_fmt, int *h_shift, int *v_shift)
Utility function to access log2_chroma_w log2_chroma_h from the pixel format AVPixFmtDescriptor.
Definition: pixdesc.c:2577
MQC_CX_UNI
#define MQC_CX_UNI
Definition: mqc.h:33
j2k_flush
static void j2k_flush(Jpeg2000EncoderContext *s)
flush the bitstream
Definition: j2kenc.c:228
Jpeg2000EncoderContext::numYtiles
int numYtiles
Definition: j2kenc.c:116
ss
#define ss(width, name, subs,...)
Definition: cbs_vp9.c:261
put_cod
static int put_cod(Jpeg2000EncoderContext *s)
Definition: j2kenc.c:308
Jpeg2000T1Context
Definition: jpeg2000.h:121
Jpeg2000ResLevel
Definition: jpeg2000.h:198
av_cold
#define av_cold
Definition: attributes.h:90
mask
static const uint16_t mask[17]
Definition: lzw.c:38
Jpeg2000Pass::disto
int64_t disto
Definition: jpeg2000.h:158
Jpeg2000QuantStyle::nguardbits
uint8_t nguardbits
Definition: jpeg2000.h:153
init_luts
static void init_luts(void)
Definition: j2kenc.c:518
Jpeg2000Tile::comp
Jpeg2000Component * comp
Definition: j2kenc.c:102
width
#define width
intreadwrite.h
Jpeg2000CodingStyle::transform
uint8_t transform
Definition: jpeg2000.h:139
s
#define s(width, name)
Definition: cbs_vp9.c:257
lut_nmsedec_sig0
static int lut_nmsedec_sig0[1<< NMSEDEC_BITS]
Definition: j2kenc.c:87
Jpeg2000ResLevel::band
Jpeg2000Band * band
Definition: jpeg2000.h:203
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
getcut
static int getcut(Jpeg2000Cblk *cblk, int64_t lambda, int dwt_norm)
Definition: j2kenc.c:836
jpeg2000.h
Jpeg2000Cblk::data
uint8_t * data
Definition: jpeg2000.h:171
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:37
pix_fmts
static enum AVPixelFormat pix_fmts[]
Definition: libkvazaar.c:275
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:197
Jpeg2000Band::coord
int coord[2][2]
Definition: jpeg2000.h:191
Jpeg2000EncoderContext::planar
uint8_t planar
Definition: j2kenc.c:113
xi
#define xi(width, name, var, range_min, range_max, subs,...)
Definition: cbs_h2645.c:396
encode_sigpass
static void encode_sigpass(Jpeg2000T1Context *t1, int width, int height, int bandno, int *nmsedec, int bpno)
Definition: j2kenc.c:550
AV_INPUT_BUFFER_MIN_SIZE
#define AV_INPUT_BUFFER_MIN_SIZE
Definition: avcodec.h:222
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:66
JPEG2000_COM
@ JPEG2000_COM
Definition: jpeg2000.h:53
if
if(ret)
Definition: filter_design.txt:179
Jpeg2000CodingStyle::log2_prec_widths
uint8_t log2_prec_widths[JPEG2000_MAX_RESLEVELS]
Definition: jpeg2000.h:145
ff_mqc_init_context_tables
void av_cold ff_mqc_init_context_tables(void)
MQ-coder Initialize context tables (QE, NLPS, NMPS)
Definition: mqc.c:97
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:67
NULL
#define NULL
Definition: coverity.c:32
put_num
static void put_num(Jpeg2000EncoderContext *s, int num, int n)
put n least significant bits of a number num
Definition: j2kenc.c:221
Jpeg2000EncoderContext::codsty
Jpeg2000CodingStyle codsty
Definition: j2kenc.c:125
av_default_item_name
const char * av_default_item_name(void *ptr)
Return the context name.
Definition: log.c:235
Jpeg2000Band::prec
Jpeg2000Prec * prec
Definition: jpeg2000.h:195
JPEG2000_T1_VIS
#define JPEG2000_T1_VIS
Definition: jpeg2000.h:95
Jpeg2000ResLevel::num_precincts_y
int num_precincts_y
Definition: jpeg2000.h:201
AV_PIX_FMT_GRAY8
@ AV_PIX_FMT_GRAY8
Y , 8bpp.
Definition: pixfmt.h:74
Jpeg2000Band::log2_cblk_height
uint16_t log2_cblk_height
Definition: jpeg2000.h:192
AVPALETTE_COUNT
#define AVPALETTE_COUNT
Definition: pixfmt.h:33
truncpasses
static void truncpasses(Jpeg2000EncoderContext *s, Jpeg2000Tile *tile)
Definition: j2kenc.c:854
Jpeg2000EncoderContext::format
int format
Definition: j2kenc.c:130
getnmsedec_sig
static int getnmsedec_sig(int x, int bpno)
Definition: j2kenc.c:536
JPEG2000_T1_SIG_NB
#define JPEG2000_T1_SIG_NB
Definition: jpeg2000.h:85
for
for(j=16;j >0;--j)
Definition: h264pred_template.c:469
AV_WB32
#define AV_WB32(p, v)
Definition: intreadwrite.h:419
Jpeg2000Prec::nb_codeblocks_width
int nb_codeblocks_width
Definition: jpeg2000.h:181
JPEG2000_T1_SGN
#define JPEG2000_T1_SGN
Definition: jpeg2000.h:99
ff_jpeg2000_cleanup
void ff_jpeg2000_cleanup(Jpeg2000Component *comp, Jpeg2000CodingStyle *codsty)
Definition: jpeg2000.c:585
getnmsedec_ref
static int getnmsedec_ref(int x, int bpno)
Definition: j2kenc.c:543
Jpeg2000Component
Definition: jpeg2000.h:206
AV_PIX_FMT_RGB24
@ AV_PIX_FMT_RGB24
packed RGB 8:8:8, 24bpp, RGBRGB...
Definition: pixfmt.h:68
Jpeg2000Prec::cblkincl
Jpeg2000TgtNode * cblkincl
Definition: jpeg2000.h:184
encode_clnpass
static void encode_clnpass(Jpeg2000T1Context *t1, int width, int height, int bandno, int *nmsedec, int bpno)
Definition: j2kenc.c:586
Jpeg2000EncoderContext::picture
const AVFrame * picture
Definition: j2kenc.c:108
Jpeg2000Component::i_data
int * i_data
Definition: jpeg2000.h:210
AVPacket::size
int size
Definition: packet.h:356
NULL_IF_CONFIG_SMALL
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
Definition: internal.h:188
encode_tile
static int encode_tile(Jpeg2000EncoderContext *s, Jpeg2000Tile *tile, int tileno)
Definition: j2kenc.c:883
Jpeg2000ResLevel::nbands
uint8_t nbands
Definition: jpeg2000.h:199
sp
#define sp
Definition: regdef.h:63
FFMAX
#define FFMAX(a, b)
Definition: common.h:94
size
int size
Definition: twinvq_data.h:11134
Jpeg2000Cblk
Definition: jpeg2000.h:163
Jpeg2000Cblk::ninclpasses
uint8_t ninclpasses
Definition: jpeg2000.h:165
NMSEDEC_FRACBITS
#define NMSEDEC_FRACBITS
Definition: j2kenc.c:77
AV_RL24
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_RL24
Definition: bytestream.h:89
height
#define height
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
FFMIN
#define FFMIN(a, b)
Definition: common.h:96
JPEG2000_COD
@ JPEG2000_COD
Definition: jpeg2000.h:41
ff_jpeg2000_getsgnctxno
static int ff_jpeg2000_getsgnctxno(int flag, int *xorbit)
Definition: jpeg2000.h:259
line
Definition: graph2dot.c:48
AVPacket::flags
int flags
A combination of AV_PKT_FLAG values.
Definition: packet.h:361
Jpeg2000TgtNode
Definition: jpeg2000.h:128
OFFSET
#define OFFSET(x)
Definition: j2kenc.c:1226
reinit
static void reinit(Jpeg2000EncoderContext *s)
Definition: j2kenc.c:989
Jpeg2000CodingStyle::nreslevels
int nreslevels
Definition: jpeg2000.h:135
ff_jpeg2000_reinit
void ff_jpeg2000_reinit(Jpeg2000Component *comp, Jpeg2000CodingStyle *codsty)
Definition: jpeg2000.c:564
bytestream_put_buffer
static av_always_inline void bytestream_put_buffer(uint8_t **b, const uint8_t *src, unsigned int size)
Definition: bytestream.h:368
Jpeg2000CodingStyle::log2_cblk_height
uint8_t log2_cblk_height
Definition: jpeg2000.h:138
put_sot
static uint8_t * put_sot(Jpeg2000EncoderContext *s, int tileno)
Definition: j2kenc.c:380
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:269
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: internal.h:48
Jpeg2000ResLevel::num_precincts_x
int num_precincts_x
Definition: jpeg2000.h:201
JPEG2000_T1_REF
#define JPEG2000_T1_REF
Definition: jpeg2000.h:97
cleanup
static void cleanup(Jpeg2000EncoderContext *s)
Definition: j2kenc.c:970
Jpeg2000QuantStyle::expn
uint8_t expn[JPEG2000_MAX_DECLEVELS *3]
Definition: jpeg2000.h:150
av_malloc_array
#define av_malloc_array(a, b)
Definition: tableprint_vlc.h:32
dwt_norms
static const int dwt_norms[2][4][10]
Definition: j2kenc.c:89
common.h
encode_cblk
static void encode_cblk(Jpeg2000EncoderContext *s, Jpeg2000T1Context *t1, Jpeg2000Cblk *cblk, Jpeg2000Tile *tile, int width, int height, int bandpos, int lev)
Definition: j2kenc.c:641
ff_mqc_initenc
void ff_mqc_initenc(MqcState *mqc, uint8_t *bp)
initialize the encoder
Definition: mqcenc.c:69
JPEG2000_SIZ
@ JPEG2000_SIZ
Definition: jpeg2000.h:40
uint8_t
uint8_t
Definition: audio_convert.c:194
Jpeg2000Band::log2_cblk_width
uint16_t log2_cblk_width
Definition: jpeg2000.h:192
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:197
ff_jpeg2000_getsigctxno
static int ff_jpeg2000_getsigctxno(int flag, int bandno)
Definition: jpeg2000.h:241
WMSEDEC_SHIFT
#define WMSEDEC_SHIFT
must be >= 13
Definition: j2kenc.c:78
AV_CODEC_ID_JPEG2000
@ AV_CODEC_ID_JPEG2000
Definition: codec_id.h:137
AVCodecContext::height
int height
Definition: avcodec.h:699
AVCodecContext::pix_fmt
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
Definition: avcodec.h:736
JPEG2000_MAX_PASSES
#define JPEG2000_MAX_PASSES
Definition: jpeg2000.h:73
Jpeg2000EncoderContext::tile_width
int tile_width
Definition: j2kenc.c:115
lut_nmsedec_ref
static int lut_nmsedec_ref[1<< NMSEDEC_BITS]
Definition: j2kenc.c:84
Jpeg2000EncoderContext::width
int width
Definition: j2kenc.c:110
Jpeg2000QuantStyle::mant
uint16_t mant[JPEG2000_MAX_DECLEVELS *3]
Definition: jpeg2000.h:151
avcodec.h
JPEG2000_T1_SIG
#define JPEG2000_T1_SIG
Definition: jpeg2000.h:96
AV_PIX_FMT_PAL8
@ AV_PIX_FMT_PAL8
8 bits with AV_PIX_FMT_RGB32 palette
Definition: pixfmt.h:77
ret
ret
Definition: filter_design.txt:187
put_qcd
static int put_qcd(Jpeg2000EncoderContext *s, int compno)
Definition: j2kenc.c:335
pred
static const float pred[4]
Definition: siprdata.h:259
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:72
JPEG2000_QSTY_SE
@ JPEG2000_QSTY_SE
Definition: jpeg2000.h:67
NMSEDEC_BITS
#define NMSEDEC_BITS
Definition: j2kenc.c:76
Jpeg2000EncoderContext::buf_start
uint8_t * buf_start
Definition: j2kenc.c:118
encode_refpass
static void encode_refpass(Jpeg2000T1Context *t1, int width, int height, int *nmsedec, int bpno)
Definition: j2kenc.c:572
Jpeg2000Pass::flushed
uint8_t flushed[4]
Definition: jpeg2000.h:159
pos
unsigned int pos
Definition: spdifenc.c:412
lut_nmsedec_sig
static int lut_nmsedec_sig[1<< NMSEDEC_BITS]
Definition: j2kenc.c:86
MQC_CX_RL
#define MQC_CX_RL
Definition: mqc.h:34
Jpeg2000Component::coord
int coord[2][2]
Definition: jpeg2000.h:211
AVCodecContext
main external API structure.
Definition: avcodec.h:526
copy_frame
static void copy_frame(Jpeg2000EncoderContext *s)
Definition: j2kenc.c:450
FF_DWT53
@ FF_DWT53
Definition: jpeg2000dwt.h:38
ff_jpeg2000_ceildiv
static int ff_jpeg2000_ceildiv(int a, int b)
Definition: jpeg2000.h:222
av_calloc
void * av_calloc(size_t nmemb, size_t size)
Non-inlined equivalent of av_mallocz_array().
Definition: mem.c:245
ff_jpeg2000_ceildivpow2
static int ff_jpeg2000_ceildivpow2(int a, int b)
Definition: jpeg2000.h:217
put_siz
static int put_siz(Jpeg2000EncoderContext *s)
Definition: j2kenc.c:279
pkt
static AVPacket pkt
Definition: demuxing_decoding.c:54
CODEC_JP2
#define CODEC_JP2
Definition: j2kenc.c:81
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:65
ff_jpeg2000_encoder
AVCodec ff_jpeg2000_encoder
Definition: j2kenc.c:1248
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Definition: opt.h:223
ff_jpeg2000_init_tier1_luts
void av_cold ff_jpeg2000_init_tier1_luts(void)
Definition: jpeg2000.c:159
AV_PIX_FMT_YUV444P
@ AV_PIX_FMT_YUV444P
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
Definition: pixfmt.h:71
Jpeg2000EncoderContext::pred
int pred
Definition: j2kenc.c:131
FF_DISABLE_DEPRECATION_WARNINGS
#define FF_DISABLE_DEPRECATION_WARNINGS
Definition: internal.h:84
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
Jpeg2000EncoderContext::qntsty
Jpeg2000QuantStyle qntsty
Definition: j2kenc.c:126
AV_PIX_FMT_YUV422P
@ AV_PIX_FMT_YUV422P
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
Definition: pixfmt.h:70
VE
#define VE
Definition: j2kenc.c:1227
put_com
static int put_com(Jpeg2000EncoderContext *s, int compno)
Definition: j2kenc.c:361
AV_CODEC_FLAG_BITEXACT
#define AV_CODEC_FLAG_BITEXACT
Use only bitexact stuff (except (I)DCT).
Definition: avcodec.h:333
ff_mqc_flush_to
int ff_mqc_flush_to(MqcState *mqc, uint8_t *dst, int *dst_len)
Definition: mqcenc.c:122
putnumpasses
static void putnumpasses(Jpeg2000EncoderContext *s, int n)
Definition: j2kenc.c:700
Jpeg2000Cblk::npasses
uint8_t npasses
Definition: jpeg2000.h:164
Jpeg2000CodingStyle::nreslevels2decode
int nreslevels2decode
Definition: jpeg2000.h:136
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:553
AVPacket
This structure stores compressed data.
Definition: packet.h:332
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
ff_jpeg2000_set_significance
void ff_jpeg2000_set_significance(Jpeg2000T1Context *t1, int x, int y, int negative)
Definition: jpeg2000.c:171
AV_PIX_FMT_YUV411P
@ AV_PIX_FMT_YUV411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples)
Definition: pixfmt.h:73
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:699
bytestream.h
Jpeg2000TgtNode::val
uint8_t val
Definition: jpeg2000.h:129
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:72
update_size
static void update_size(uint8_t *size, const uint8_t *end)
Definition: j2kenc.c:999
Jpeg2000TgtNode::vis
uint8_t vis
Definition: jpeg2000.h:130
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:28
Jpeg2000CodingStyle
Definition: jpeg2000.h:134
Jpeg2000QuantStyle
Definition: jpeg2000.h:149
Jpeg2000Cblk::nonzerobits
uint8_t nonzerobits
Definition: jpeg2000.h:166
Jpeg2000Prec::cblk
Jpeg2000Cblk * cblk
Definition: jpeg2000.h:185
AV_RB24
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_RB24
Definition: bytestream.h:93
Jpeg2000EncoderContext::avctx
AVCodecContext * avctx
Definition: j2kenc.c:107
ff_mqc_encode
void ff_mqc_encode(MqcState *mqc, uint8_t *cxstate, int d)
code bit d with context cx
Definition: mqcenc.c:79
ff_alloc_packet2
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size, int64_t min_size)
Check AVPacket size and/or allocate data.
Definition: encode.c:32
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Definition: opt.h:232
av_log2
int av_log2(unsigned v)
Definition: intmath.c:26
Jpeg2000EncoderContext::ncomponents
int ncomponents
Definition: j2kenc.c:114
init_tiles
static int init_tiles(Jpeg2000EncoderContext *s)
compute the sizes of tiles, resolution levels, bands, etc.
Definition: j2kenc.c:404
init_quantization
static void init_quantization(Jpeg2000EncoderContext *s)
Definition: j2kenc.c:488
lut_nmsedec_ref0
static int lut_nmsedec_ref0[1<< NMSEDEC_BITS]
Definition: j2kenc.c:85
FF_DWT97_INT
@ FF_DWT97_INT
Definition: jpeg2000dwt.h:39
Jpeg2000EncoderContext::tile
Jpeg2000Tile * tile
Definition: j2kenc.c:128
line
The official guide to swscale for confused that consecutive non overlapping rectangles of slice_bottom special converter These generally are unscaled converters of common like for each output line the vertical scaler pulls lines from a ring buffer When the ring buffer does not contain the wanted line
Definition: swscale.txt:40
Jpeg2000EncoderContext
Definition: j2kenc.c:105
encode_packet
static int encode_packet(Jpeg2000EncoderContext *s, Jpeg2000ResLevel *rlevel, int precno, uint8_t *expn, int numgbits)
Definition: j2kenc.c:715