Grok  7.6.3
Quantizer.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2016-2021 Grok Image Compression Inc.
3  *
4  * This source code is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU Affero General Public License, version 3,
6  * as published by the Free Software Foundation.
7  *
8  * This source code is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU Affero General Public License for more details.
12  *
13  * You should have received a copy of the GNU Affero General Public License
14  * along with this program. If not, see <http://www.gnu.org/licenses/>.
15  *
16  *
17  * This source code incorporates work covered by the BSD 2-clause license.
18  * Please see the LICENSE file in the root directory for details.
19  *
20  */
21 
22 #pragma once
23 
24 #include <cstdint>
25 
26 
27 namespace grk {
28 
29 
30 struct CodeStream;
31 
35 struct grk_stepsize {
36  grk_stepsize() : expn(0), mant(0)
37  {}
39  uint8_t expn;
41  uint16_t mant;
42 };
43 
44 
45 
46 struct CodeStream;
48 struct BufferedStream;
49 struct Subband;
50 struct TileCodingParams;
51 struct TileProcessor;
52 
53 
54 class Quantizer {
55 public:
56 
58  Subband *band,
59  uint32_t resno,
60  uint8_t bandIndex,
62  uint8_t image_precision,
63  bool compress);
64 
65 
66  uint32_t get_SQcd_SQcc_size(CodeStream *codeStream, uint32_t comp_no);
67  bool compare_SQcd_SQcc(CodeStream *codeStream,
68  uint32_t first_comp_no, uint32_t second_comp_no);
69  bool read_SQcd_SQcc(CodeStream *codeStream,bool fromQCC, uint32_t comp_no,
70  uint8_t *p_header_data, uint16_t *header_size);
71  bool write_SQcd_SQcc(CodeStream *codeStream,uint32_t comp_no, BufferedStream *stream);
73 };
74 
75 }
grk::BufferedStream::write_byte
bool write_byte(uint8_t value)
Definition: BufferedStream.cpp:182
grk::TileComponentCodingParams::fromQCC
bool fromQCC
Definition: CodingParams.h:70
grk::Quantizer::get_SQcd_SQcc_size
uint32_t get_SQcd_SQcc_size(CodeStream *codeStream, uint32_t comp_no)
Definition: Quantizer.cpp:126
grk::TileProcessor
Tile compressor/decompressor.
Definition: TileProcessor.h:63
grk::TileCodingParams
Tile coding parameters : this structure is used to store coding/decoding parameters common to all til...
Definition: CodingParams.h:121
grk::TileCodingParams::tccps
TileComponentCodingParams * tccps
tile-component coding parameters
Definition: CodingParams.h:163
grk::Subband::numbps
uint32_t numbps
Definition: T1Structs.h:223
grk::Quantizer::write_SQcd_SQcc
bool write_SQcd_SQcc(CodeStream *codeStream, uint32_t comp_no, BufferedStream *stream)
Definition: Quantizer.cpp:89
grk::BufferedStream
Byte input-output stream.
Definition: BufferedStream.h:38
grk::TileComponentCodingParams::fromTileHeader
bool fromTileHeader
Definition: CodingParams.h:72
grk::TileComponentCodingParams
Tile-component coding parameters.
Definition: CodingParams.h:49
grk::BufferedStream::write_short
bool write_short(uint16_t value)
Definition: BufferedStream.cpp:185
grk::GRK_WARN
void GRK_WARN(const char *fmt,...)
Definition: logger.cpp:49
grk::Quantizer::compare_SQcd_SQcc
bool compare_SQcd_SQcc(CodeStream *codeStream, uint32_t first_comp_no, uint32_t second_comp_no)
Definition: Quantizer.cpp:147
grk::Quantizer::read_SQcd_SQcc
bool read_SQcd_SQcc(CodeStream *codeStream, bool fromQCC, uint32_t comp_no, uint8_t *p_header_data, uint16_t *header_size)
Definition: Quantizer.cpp:188
grk::grk_stepsize::mant
uint16_t mant
mantissa -11 bits
Definition: Quantizer.h:41
grk::grk_stepsize
Quantization stepsize.
Definition: Quantizer.h:35
grk::TileComponentCodingParams::qmfbid
uint8_t qmfbid
discrete wavelet transform identifier
Definition: CodingParams.h:65
J2K_CCP_QNTSTY_NOQNT
#define J2K_CCP_QNTSTY_NOQNT
Definition: CodeStream.h:66
GRK_J2K_MAXBANDS
#define GRK_J2K_MAXBANDS
Maximum number of sub-bands.
Definition: grok.h:83
grk::CodeStream
Definition: CodeStream.h:164
grk::CodeStream::m_cp
CodingParams m_cp
Coding parameters.
Definition: CodeStream.h:309
grk::Subband::stepsize
float stepsize
Definition: T1Structs.h:224
grk::TileComponentCodingParams::numgbits
uint8_t numgbits
number of guard bits
Definition: CodingParams.h:80
grk::grk_stepsize::grk_stepsize
grk_stepsize()
Definition: Quantizer.h:36
grk
Copyright (C) 2016-2021 Grok Image Compression Inc.
Definition: BitIO.cpp:23
grk::TileComponentCodingParams::qntsty
uint8_t qntsty
quantisation style
Definition: CodingParams.h:74
J2K_CCP_QNTSTY_SIQNT
#define J2K_CCP_QNTSTY_SIQNT
Definition: CodeStream.h:67
grk_includes.h
grk::CodeStream::isDecodingTilePartHeader
bool isDecodingTilePartHeader()
Definition: CodeStream.cpp:1992
J2K_CCP_QNTSTY_SEQNT
#define J2K_CCP_QNTSTY_SEQNT
Definition: CodeStream.h:68
grk::Quantizer::apply_quant
void apply_quant(TileComponentCodingParams *src, TileComponentCodingParams *dest)
Definition: Quantizer.cpp:70
grk::Quantizer::setBandStepSizeAndBps
bool setBandStepSizeAndBps(TileCodingParams *tcp, Subband *band, uint32_t resno, uint8_t bandIndex, TileComponentCodingParams *tccp, uint8_t image_precision, bool compress)
Definition: Quantizer.cpp:26
grk::CodeStream::get_current_decode_tcp
TileCodingParams * get_current_decode_tcp(void)
Definition: CodeStream.cpp:1995
grk::Subband::orientation
eBandOrientation orientation
Definition: T1Structs.h:218
grk::TileComponentCodingParams::stepsizes
grk_stepsize stepsizes[GRK_J2K_MAXBANDS]
stepsizes used for quantization
Definition: CodingParams.h:76
grk::grk_stepsize::expn
uint8_t expn
exponent - 5 bits
Definition: Quantizer.h:39
grk::Subband::inv_step
uint32_t inv_step
Definition: T1Structs.h:226
grk::TileComponentCodingParams::roishift
uint8_t roishift
Region Of Interest shift.
Definition: CodingParams.h:82
grk::GRK_ERROR
void GRK_ERROR(const char *fmt,...)
Definition: logger.cpp:57
grk::Subband
Definition: T1Structs.h:203
grk::TileCodingParams::isHT
bool isHT
Definition: CodingParams.h:199
grk::Quantizer
Definition: Quantizer.h:54