Grok  7.6.6
mct.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 namespace grk {
24 
25 
26 class mct {
27 
28 public:
29 
37  static void compress_rev(int32_t *c0, int32_t *c1, int32_t *c2, uint64_t n);
44  static void decompress_rev(grk_tile *tile, GrkImage *image,
46 
50  static const double* get_norms_rev(void);
51 
52 
60  static void compress_irrev(int *c0, int *c1, int *c2, uint64_t n);
67  static void decompress_irrev(grk_tile *tile, GrkImage *image,
69 
73  static const double* get_norms_irrev(void);
74 
84  static bool compress_custom(uint8_t *p_coding_data, uint64_t n, uint8_t **p_data,
85  uint32_t nb_comp, uint32_t is_signed);
95  static bool decompress_custom(uint8_t *pDecodingData, uint64_t n, uint8_t **pData,
96  uint32_t pNbComp, uint32_t isSigned);
103  static void calculate_norms(double *pNorms, uint32_t nb_comps, float *pMatrix);
104 
111  static void decompress_dc_shift_rev(grk_tile *tile, GrkImage *image,TileComponentCodingParams *tccps, uint32_t compno);
112 
119  static void decompress_dc_shift_irrev(grk_tile *tile, GrkImage *image,TileComponentCodingParams *tccps, uint32_t compno);
120 
121 };
122 
123 /* ----------------------------------------------------------------------- */
127 
128 }
Definition: GrkImage.h:11
Definition: mct.h:26
static void decompress_dc_shift_rev(grk_tile *tile, GrkImage *image, TileComponentCodingParams *tccps, uint32_t compno)
Apply a reversible inverse dc shift to an image.
Definition: mct.cpp:297
static const double * get_norms_rev(void)
Get wavelet norms for reversible transform.
Definition: mct.cpp:37
static void calculate_norms(double *pNorms, uint32_t nb_comps, float *pMatrix)
Calculate norm of MCT transform.
Definition: mct.cpp:549
static void decompress_dc_shift_irrev(grk_tile *tile, GrkImage *image, TileComponentCodingParams *tccps, uint32_t compno)
Apply an irreversible inverse dc shift to an image.
Definition: mct.cpp:109
static const double * get_norms_irrev(void)
Get wavelet norms for irreversible transform.
Definition: mct.cpp:40
static bool compress_custom(uint8_t *p_coding_data, uint64_t n, uint8_t **p_data, uint32_t nb_comp, uint32_t is_signed)
Custom MCT transform.
Definition: mct.cpp:568
static bool decompress_custom(uint8_t *pDecodingData, uint64_t n, uint8_t **pData, uint32_t pNbComp, uint32_t isSigned)
Custom MCT decode.
Definition: mct.cpp:604
static void compress_irrev(int *c0, int *c1, int *c2, uint64_t n)
Apply an irreversible multi-component transform to an image.
Definition: mct.cpp:469
static void compress_rev(int32_t *c0, int32_t *c1, int32_t *c2, uint64_t n)
Apply a reversible multi-component transform to an image.
Definition: mct.cpp:48
static void decompress_rev(grk_tile *tile, GrkImage *image, TileComponentCodingParams *tccps)
Apply a reversible multi-component inverse transform to an image.
Definition: mct.cpp:369
static void decompress_irrev(grk_tile *tile, GrkImage *image, TileComponentCodingParams *tccps)
Apply an irreversible multi-component inverse transform to an image.
Definition: mct.cpp:186
Copyright (C) 2016-2021 Grok Image Compression Inc.
Definition: BitIO.cpp:23
Tile-component coding parameters.
Definition: CodingParams.h:49
Definition: TileProcessor.h:37