blob: 314a2325c9e55b9958dedea9d101b3dc2af221ef [file] [log] [blame]
Thomas G. Lanebc79e061995-08-02 00:00:00 +00001/*
2 * jchuff.h
3 *
DRC5033f3e2014-05-18 18:33:44 +00004 * This file was part of the Independent JPEG Group's software:
Thomas G. Lane5ead57a1998-03-27 00:00:00 +00005 * Copyright (C) 1991-1997, Thomas G. Lane.
DRC5033f3e2014-05-18 18:33:44 +00006 * It was modified by The libjpeg-turbo Project to include only code relevant
7 * to libjpeg-turbo.
Alex Naidis6eb7d372016-10-16 23:10:08 +02008 * For conditions of distribution and use, see the accompanying README.ijg
9 * file.
Thomas G. Lanebc79e061995-08-02 00:00:00 +000010 *
11 * This file contains declarations for Huffman entropy encoding routines
12 * that are shared between the sequential encoder (jchuff.c) and the
13 * progressive encoder (jcphuff.c). No other modules need to see these.
14 */
15
Thomas G. Lane5ead57a1998-03-27 00:00:00 +000016/* The legal range of a DCT coefficient is
17 * -1024 .. +1023 for 8-bit data;
18 * -16384 .. +16383 for 12-bit data.
19 * Hence the magnitude should always fit in 10 or 14 bits respectively.
20 */
21
22#if BITS_IN_JSAMPLE == 8
Leon Scroggins III3993b372018-07-16 10:43:45 -040023#define MAX_COEF_BITS 10
Thomas G. Lane5ead57a1998-03-27 00:00:00 +000024#else
Leon Scroggins III3993b372018-07-16 10:43:45 -040025#define MAX_COEF_BITS 14
Thomas G. Lane5ead57a1998-03-27 00:00:00 +000026#endif
27
Thomas G. Lanebc79e061995-08-02 00:00:00 +000028/* Derived data constructed for each Huffman table */
29
30typedef struct {
DRCe5eaf372014-05-09 18:00:32 +000031 unsigned int ehufco[256]; /* code for each symbol */
32 char ehufsi[256]; /* length of code for each symbol */
Thomas G. Lanebc79e061995-08-02 00:00:00 +000033 /* If no code has been allocated for a symbol S, ehufsi[S] contains 0 */
34} c_derived_tbl;
35
Thomas G. Lanebc79e061995-08-02 00:00:00 +000036/* Expand a Huffman table definition into the derived format */
Leon Scroggins III3993b372018-07-16 10:43:45 -040037EXTERN(void) jpeg_make_c_derived_tbl(j_compress_ptr cinfo, boolean isDC,
38 int tblno, c_derived_tbl **pdtbl);
Thomas G. Lanebc79e061995-08-02 00:00:00 +000039
40/* Generate an optimal table definition given the specified counts */
Leon Scroggins III3993b372018-07-16 10:43:45 -040041EXTERN(void) jpeg_gen_optimal_table(j_compress_ptr cinfo, JHUFF_TBL *htbl,
42 long freq[]);