文档章节

DCT, IDCT变换--C语言实现

t
 tigerBin
发布于 2017/06/14 12:35
字数 498
阅读 59
收藏 0

变换矩阵,DCT = IDCT'

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;
}

最后计算结果与原始数据相差不大

© 著作权归作者所有

共有 人打赏支持
t
粉丝 0
博文 62
码字总数 17049
作品 0
武汉
程序员
x264源代码简单分析:宏块编码(Encode)部分

===================================================== H.264源代码分析文章列表: 【编码 - x264】 x264源代码简单分析:概述 x264源代码简单分析:x264命令行工具(x264.exe) x264源代码...

leixiaohua1020
2015/05/24
0
0
从零开始手敲次世代游戏引擎(JPEG特别篇)-1

上一篇我们导入了Aili这个相对比较复杂的模型,并发现了一些问题,进行了修正。 但是目前我们所渲染的只是一个没有任何材质的模型(也常常被称为白模,或者灰模)。为了能够输出类似Blender...

陈文礼
2017/12/01
0
0
x264源代码简单分析:编码器主干部分-1

===================================================== H.264源代码分析文章列表: 【编码 - x264】 x264源代码简单分析:概述 x264源代码简单分析:x264命令行工具(x264.exe) x264源代码...

leixiaohua1020
2015/05/11
0
0
【DCT】OPENCV python 离散余弦变换问题

因为项目需要,目前在研究《基于离散余弦变换和区域生长的白粉虱图像分割算法》,使用的OPENCV python。 论文地址:%e5%9f%ba%e4%ba%8e%e7%a6%bb%e6%95%a3%e4%bd%99%e5%bc%a6%e5%8f%98%e6%8d...

majisong
2016/06/02
1K
0
OpenCV - Operations on Arrays 对数组(矩阵)的一些操作

Function (函数名) Use (函数用处) add 矩阵加法,A+B的更高级形式,支持mask scaleAdd 矩阵加法,一个带有缩放因子dst(I) = scale * src1(I) + src2(I) addWeighted 矩阵加法,两个带有缩放...

苍海一粟
2012/11/20
0
2

没有更多内容

加载失败,请刷新页面

加载更多

下一页

RabbitMQ在CentOS环境安装

1.废话不多说准备一台虚拟机,系统为centos,我这里使用的系统版本如下图所示:

凌晨一点
49分钟前
0
0
线程池相关

在java.util.concurrent包下,提供了一系列与线程池相关的类。 使用线程池的好处 降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成的消耗; 提高响应速度。当任务到达时,任务...

edwardGe
51分钟前
0
0
学习大数据这三个关键技术是一定要掌握!

大数据时代全面来临,大数据、人工智能等技术引领科技创新潮流,获得国家政策大力支持,前景广阔。学习大数据技术的人自然是络绎不绝, 学习大数据虽然是一个趋势,但也要注意大数据培训课程...

董黎明
今天
0
0
jetbrains 上传代码到github

设置中找github 获取token 验证是否成功 测试git 生成key,一路回车即可 ssh-keygen -t rsa -C “youremail@example.com” 打开pub复制key,需要再次输入一次密码 验证是否成功,输入yes即可...

阿豪boy
今天
0
0
分布式服务框架(拾遗)

前言 现在的大部分工程都已经是基于分布式架构来处理。所以这里对分布式框架做一个简单的总结 常用的RPC框架 RPC框架原理 RPC(Remote Procedure Call,远程过程调用)一般用来实现部署在不同...

kukudeku
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部