blob: 6a8fc9fee4aaee9e81a3e9e6c6579f4902afd262 [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.
DRC7e3acc02015-10-10 10:25:46 -05008 * 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
23#define MAX_COEF_BITS 10
24#else
25#define MAX_COEF_BITS 14
26#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 */
Thomas G. Lane489583f1996-02-07 00:00:00 +000037EXTERN(void) jpeg_make_c_derived_tbl
DRCbc56b752014-05-16 10:43:44 +000038 (j_compress_ptr cinfo, boolean isDC, int tblno,
39 c_derived_tbl ** pdtbl);
Thomas G. Lanebc79e061995-08-02 00:00:00 +000040
41/* Generate an optimal table definition given the specified counts */
Thomas G. Lane489583f1996-02-07 00:00:00 +000042EXTERN(void) jpeg_gen_optimal_table
DRCbc56b752014-05-16 10:43:44 +000043 (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[]);