DCT, IDCT变换--C语言实现
2017-06-14 00:00
369 查看
变换矩阵,DCT = IDCT'
变换方程: F(u,v) = G * f * G'
逆变换方程: f(x,y) = G' * F * G
其中 G = DCT, G' = IDCT , G 与 G' 互为转置
计算:
测试:
最后计算结果与原始数据相差不大
static const double MtxDCT[8][8] = { {0.3536, 0.3536, 0.3536, 0.3536, 0.3536, 0.3536, 0.3536, 0.3536}, {0.4904, 0.4157, 0.2778, 0.0975, -0.0975, -0.2778, -0.4157, -0.4904}, {0.4619, 0.1913, -0.1913, -0.4619, -0.4619, -0.1913, 0.1913, 0.4619}, {0.4157, -0.0975, -0.4904, -0.2778, 0.2778, 0.4904, 0.0975, -0.4157}, {0.3536, -0.3536, -0.3536, 0.3536, 0.3536, -0.3536, -0.3536, 0.3536}, {0.2778, -0.4904, 0.0975, 0.4157, -0.4157, -0.0975, 0.4904, -0.2778}, {0.1913, -0.4619, 0.4619, -0.1913, -0.1913, 0.4619, -0.4619, 0.1913}, {0.0975, -0.2778, 0.4157, -0.4904, 0.4904, -0.4157, 0.2778, -0.0975} }; static const double MtxIDCT[8][8] = { {0.3536, 0.4904, 0.4619, 0.4157, 0.3536, 0.2778, 0.1913, 0.0975}, {0.3536, 0.4157, 0.1913, -0.0975, -0.3536, -0.4904, -0.4619, -0.2778}, {0.3536, 0.2778, -0.1913, -0.4904, -0.3536, 0.0975, 0.4619, 0.4157}, {0.3536, 0.0975, -0.4619, -0.2778, 0.3536, 0.4157, -0.1913, -0.4904}, {0.3536, -0.0975, -0.4619, 0.2778, 0.3536, -0.4157, -0.1913, 0.4904}, {0.3536, -0.2778, -0.1913, 0.4904, -0.3536, -0.0975, 0.4619, -0.4157}, {0.3536, -0.4157, 0.1913, 0.0975, -0.3536, 0.4904, -0.4619, 0.2778}, {0.3536, -0.4904, 0.4619, -0.4157, 0.3536, -0.2778, 0.1913, -0.0975} };
变换方程: F(u,v) = G * f * G'
逆变换方程: f(x,y) = G' * F * G
其中 G = DCT, G' = IDCT , G 与 G' 互为转置
计算:
class MCU { public: int *operator[] (int row) { return data[row]; } int data[8][8]; }; MCU MtxMulI2D(MCU &left, const double right[8][8]) { MCU dctBuf; for (int i = 0; i < 8; i++) { for (int j = 0; j < 8; j++) { double tempVal = 0.0; for (int k = 0; k < 8; k++) { tempVal += left[i][k] * right[k][j]; } dctBuf[i][j] = round(tempVal); } } return dctBuf; } MCU MtxMulD2I(const double left[8][8], MCU &right) { MCU dctBuf; for (int i = 0; i < 8; i++) { for (int j = 0; j < 8; j++) { double tempVal = 0.0; for (int k = 0; k < 8; k++) { tempVal += left[i][k] * right[k][j]; } dctBuf[i][j] = round(tempVal); } } return dctBuf; } void DCT(MCU &block) { block = MtxMulD2I(MtxDCT, block); block = MtxMulI2D(block, MtxIDCT); } void IDCT(MCU &block) { block = MtxMulD2I(MtxIDCT, block); block = MtxMulI2D(block, MtxDCT); }
测试:
int data2[8][8] = { {144,146,149,152,154,156,156,156}, {148,150,152,154,156,156,156,156}, {155,156,157,158,158,157,156,155}, {160,161,161,162,161,159,157,155}, {163,163,164,163,162,160,158,156}, {163,163,164,164,162,160,158,157}, {160,161,162,162,162,161,159,158}, {158,159,161,161,162,161,159,158} }; int data1[8][8] = { {139, 144, 149, 153, 155, 155, 155, 155}, {144, 151, 153, 156, 159, 156, 156, 156}, {150, 155, 160, 163, 158, 156, 156, 156}, {159, 161, 162, 160, 160, 159, 159, 159}, {159, 160, 161, 162, 162, 155, 155, 155}, {161, 161, 161, 161, 160, 157, 157, 157}, {162, 162, 161, 163, 162, 157, 157, 157}, {162, 162, 161, 161, 163, 158, 158, 158} }; void Show(MCU &block) { for (int i=0;i<8;i++) { for(int j=0;j<8;j++) { printf("%4d ", block[i][j]); } printf("\n"); } } int main(int argc, char *argv[]) { MCU block; for (int i=0;i<8;i++) { for(int j=0;j<8;j++) { block[i][j] = data1[i][j]; } } DCT(block); // 离散余弦变换 IDCT(block); // 逆离散余弦变换 Show(block); return 0; }
最后计算结果与原始数据相差不大
相关文章推荐
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?(无代码,无真相)
- DCT变换及matlab实现
- 傅立叶变换与傅立叶反变换的C语言实现
- 基于Python二维离散余弦变换(DCT)及其反变换(IDCT)---程序对比
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?(无代码,无真相)
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?
- OpenCV 区域编码和阈值编码实现图像压缩(8*8DCT变换,保留50%的系数)
- OpenCV实现基于8*8块DCT变换的图像压缩
- Sobel变换c语言实现
- FFT变换的C语言实现
- 图像处理-MFC学习(7)——实现8*8数组的DCT、IDCT
- DCT变换以及量化,反量化,逆DCT变换的实现。
- DCT变换在图像压缩中的实现
- DCT变换及量化的c++实现(基于opencv矩阵运算)
- 怎样用C语言实现一个十进制数向R进制变换并输出(数据结构)
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?
- 傅立叶变换与傅立叶反变换的C语言实现
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?
- H.264中整数DCT变换,量化,反量化,反DCT究竟是如何实现的?(无代码,无真相)