Mercurial > hg > wm
comparison Meerwald/dct.h @ 0:be303a3f5ea8
import
| author | Peter Meerwald <pmeerw@cosy.sbg.ac.at> |
|---|---|
| date | Sun, 12 Aug 2007 13:14:34 +0200 |
| parents | |
| children | acb6967ee76d |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:be303a3f5ea8 |
|---|---|
| 1 #ifndef DCT_H | |
| 2 #define DCT_H | |
| 3 | |
| 4 #include "wm.h" | |
| 5 #include "coeff.h" | |
| 6 #ifdef __cplusplus | |
| 7 extern "C" { | |
| 8 #endif | |
| 9 #include "pgm.h" | |
| 10 #ifdef __cplusplus | |
| 11 } | |
| 12 #endif | |
| 13 | |
| 14 extern int N; | |
| 15 extern int M; | |
| 16 | |
| 17 void init_dct_NxM(int width, int height); | |
| 18 void fdct_NxM(gray **pixels, double **dcts); | |
| 19 void idct_NxM(double **dcts, gray **pixels); | |
| 20 | |
| 21 void init_dct_NxN(int width, int height); | |
| 22 void fdct_NxN(gray **pixels, double **dcts); | |
| 23 void idct_NxN(double **dcts, gray **pixels); | |
| 24 void fdct_inplace_NxN(double **coeffs); | |
| 25 void idct_inplace_NxN(double **coeffs); | |
| 26 | |
| 27 /* | |
| 28 * 'NJPEG' defines the JPEG's DCT block size (8x8) | |
| 29 */ | |
| 30 #define NJPEG 8 | |
| 31 | |
| 32 void init_quantum_8x8(int quality); | |
| 33 void init_quantum_JPEG_lumin(int quality); | |
| 34 void init_quantum_JPEG_chromin(int quality); | |
| 35 void quantize_8x8(double **transform); | |
| 36 void dequantize_8x8(double **transform); | |
| 37 void init_dct_8x8(); | |
| 38 void fdct_8x8(gray **input, double **output); | |
| 39 void fdct_block_8x8(gray **input, int col, int row, double **output); | |
| 40 void idct_8x8(double **input, gray **output); | |
| 41 void idct_block_8x8(double **input, gray **output, int col, int row); | |
| 42 int is_middle_frequency_coeff_8x8(int coeff); | |
| 43 | |
| 44 #endif |
