• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2012 Google Inc. All Rights Reserved.
2 //
3 // Use of this source code is governed by a BSD-style license
4 // that can be found in the COPYING file in the root of the source
5 // tree. An additional intellectual property rights grant can be found
6 // in the file PATENTS. All contributing project authors may
7 // be found in the AUTHORS file in the root of the source tree.
8 // -----------------------------------------------------------------------------
9 //
10 // Utilities for building and looking up Huffman trees.
11 //
12 // Author: Urvang Joshi (urvang@google.com)
13 
14 #ifndef WEBP_UTILS_HUFFMAN_UTILS_H_
15 #define WEBP_UTILS_HUFFMAN_UTILS_H_
16 
17 #include <assert.h>
18 #include "src/webp/format_constants.h"
19 #include "src/webp/types.h"
20 
21 #ifdef __cplusplus
22 extern "C" {
23 #endif
24 
25 #define HUFFMAN_TABLE_BITS      8
26 #define HUFFMAN_TABLE_MASK      ((1 << HUFFMAN_TABLE_BITS) - 1)
27 
28 #define LENGTHS_TABLE_BITS      7
29 #define LENGTHS_TABLE_MASK      ((1 << LENGTHS_TABLE_BITS) - 1)
30 
31 
32 // Huffman lookup table entry
33 typedef struct {
34   uint8_t bits;     // number of bits used for this symbol
35   uint16_t value;   // symbol value or table offset
36 } HuffmanCode;
37 
38 // long version for holding 32b values
39 typedef struct {
40   int bits;         // number of bits used for this symbol,
41                     // or an impossible value if not a literal code.
42   uint32_t value;   // 32b packed ARGB value if literal,
43                     // or non-literal symbol otherwise
44 } HuffmanCode32;
45 
46 // Contiguous memory segment of HuffmanCodes.
47 typedef struct HuffmanTablesSegment {
48   HuffmanCode* start;
49   // Pointer to where we are writing into the segment. Starts at 'start' and
50   // cannot go beyond 'start' + 'size'.
51   HuffmanCode* curr_table;
52   // Pointer to the next segment in the chain.
53   struct HuffmanTablesSegment* next;
54   int size;
55 } HuffmanTablesSegment;
56 
57 // Chained memory segments of HuffmanCodes.
58 typedef struct HuffmanTables {
59   HuffmanTablesSegment root;
60   // Currently processed segment. At first, this is 'root'.
61   HuffmanTablesSegment* curr_segment;
62 } HuffmanTables;
63 
64 // Allocates a HuffmanTables with 'size' contiguous HuffmanCodes. Returns 0 on
65 // memory allocation error, 1 otherwise.
66 int VP8LHuffmanTablesAllocate(int size, HuffmanTables* huffman_tables);
67 void VP8LHuffmanTablesDeallocate(HuffmanTables* const huffman_tables);
68 
69 #define HUFFMAN_PACKED_BITS 6
70 #define HUFFMAN_PACKED_TABLE_SIZE (1u << HUFFMAN_PACKED_BITS)
71 
72 // Huffman table group.
73 // Includes special handling for the following cases:
74 //  - is_trivial_literal: one common literal base for RED/BLUE/ALPHA (not GREEN)
75 //  - is_trivial_code: only 1 code (no bit is read from bitstream)
76 //  - use_packed_table: few enough literal symbols, so all the bit codes
77 //    can fit into a small look-up table packed_table[]
78 // The common literal base, if applicable, is stored in 'literal_arb'.
79 typedef struct HTreeGroup HTreeGroup;
80 struct HTreeGroup {
81   HuffmanCode* htrees[HUFFMAN_CODES_PER_META_CODE];
82   int      is_trivial_literal;  // True, if huffman trees for Red, Blue & Alpha
83                                 // Symbols are trivial (have a single code).
84   uint32_t literal_arb;         // If is_trivial_literal is true, this is the
85                                 // ARGB value of the pixel, with Green channel
86                                 // being set to zero.
87   int is_trivial_code;          // true if is_trivial_literal with only one code
88   int use_packed_table;         // use packed table below for short literal code
89   // table mapping input bits to a packed values, or escape case to literal code
90   HuffmanCode32 packed_table[HUFFMAN_PACKED_TABLE_SIZE];
91 };
92 
93 // Creates the instance of HTreeGroup with specified number of tree-groups.
94 HTreeGroup* VP8LHtreeGroupsNew(int num_htree_groups);
95 
96 // Releases the memory allocated for HTreeGroup.
97 void VP8LHtreeGroupsFree(HTreeGroup* const htree_groups);
98 
99 // Builds Huffman lookup table assuming code lengths are in symbol order.
100 // The 'code_lengths' is pre-allocated temporary memory buffer used for creating
101 // the huffman table.
102 // Returns built table size or 0 in case of error (invalid tree or
103 // memory error).
104 int VP8LBuildHuffmanTable(HuffmanTables* const root_table, int root_bits,
105                           const int code_lengths[], int code_lengths_size);
106 
107 #ifdef __cplusplus
108 }    // extern "C"
109 #endif
110 
111 #endif  // WEBP_UTILS_HUFFMAN_UTILS_H_
112