文档章节

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

t
 tigerBin
发布于 2017/06/14 12:35
字数 498
阅读 82
收藏 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
粉丝 1
博文 65
码字总数 17440
作品 0
武汉
程序员
私信 提问
x264源代码简单分析:宏块编码(Encode)部分

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/leixiaohua1020/article/details/45938927 ===================================================== H.264源代......

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

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

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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/leixiaohua1020/article/details/45644367 ===================================================== H.264源代......

雷霄骅
2015/05/11
0
0
【广州】我想应聘一个C/C++/java软件开发职位

本人预计六月底七月初将去广州生活。希望在广州找到一份c/c++/java方面的软件开发职位。 以下 是我的简历,希望广州地区的it企业可以联系我。 周西的个人简历 姓  名: 周西 性  别: 男...

numcpp
2012/06/07
512
1
OpenCV - Operations on Arrays 对数组(矩阵)的一些操作

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

苍海一粟
2012/11/20
0
2

没有更多内容

加载失败,请刷新页面

加载更多

java框架学习日志-7(静态代理和JDK代理)

静态代理 我们平时去餐厅吃饭,不是直接告诉厨师做什么菜的,而是先告诉服务员点什么菜,然后由服务员传到给厨师,相当于服务员是厨师的代理,我们通过代理让厨师炒菜,这就是代理模式。代理...

白话
今天
22
0
Flink Window

1.Flink窗口 Window Assigner分配器。 窗口可以是时间驱动的(Time Window,例如:每30秒钟),也可以是数据驱动的(Count Window,例如:每一百个元素)。 一种经典的窗口分类可以分成: 翻...

满小茂
今天
17
0
my.ini

1

architect刘源源
今天
15
0
docker dns

There is a opensource application that solves this issue, it's called DNS Proxy Server It's a DNS server that solves containers hostnames, if could not found a hostname that mat......

kut
今天
15
0
寻找数学的广度——《这才是数学》读书笔记2700字

寻找数学的广度——《这才是数学》读书笔记2700字: 文|程哲。数学学习方式之广:国内外数学教育方面的专家,进行了很多种不同的数学学习方式尝试,如数学绘本、数学游戏、数学实验、数学步道...

原创小博客
今天
27
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部