资料介绍
#define EXTRA_NAME "@dcttransform."
#include "loadbmp.h"
#define Point(x,y) lpPoints[(x)+(y)*nWidth]
void FFT(COMPLEX * TD, COMPLEX * FD, int power)
{
int count;
int i,j,k,bfsize,p;
double angle;
COMPLEX *W,*X1,*X2,*X;
count=1<
X1=(COMPLEX *)malloc(sizeof(COMPLEX)*count);
X2=(COMPLEX *)malloc(sizeof(COMPLEX)*count);
for(i=0;i
angle=-i*pi*2/count;
W[i].re=cos(angle);
W[i].im=sin(angle);
}
memcpy(X1,TD,sizeof(COMPLEX)*count);
for(k=0;k
for(j=0;j<1<
bfsize=1<<(power-k);
for(i=0;i
p=j*bfsize;
X2[i+p]=Add(X1[i+p],X1[i+p+bfsize/2]);
X2[i+p+bfsize/2]=Mul(Sub(X1[i+p],X1[i+p+bfsize/2]),W[i*(1<
}
X=X1;
X1=X2;
X2=X;
}
for(j=0;j
p=0;
for(i=0;i
if (j&(1< }
FD[j]=X1[p];
}
free(W);
free(X1);
free(X2);
}
void DCT_Pre(double *f, double *F, int power)
{
int i,count;
COMPLEX *X;
double s;
count=1<
memset(X,0,sizeof(COMPLEX)*count*2);
for(i=0;i
X[i].re=f[i];
}
FFT(X,X,power+1);
s=1/sqrt(count);
F[0]=X[0].re*s;
s*=sqrt(2);
for(i=1;i
F[i]=(X[i].re*cos(i*pi/(count*2))+X[i].im*sin(i*pi/(count*2)))*s;
}
free(X);
}
void Dct()
{
int w=1,h=1,wp=0,hp=0;
while(w*2<=nWidth)
{
w*=2;
wp++;
}
while(h*2<=nHeight)
{
h*=2;
hp++;
}
int x,y;
BYTE *lpPoints=new BYTE[nWidth*nHeight];
GetPoints(lpPoints);
double *f=new double[w*h];
double *W=new double[w*h];
for(y=0;y
for(x=0;x
f[x+y*w]=Point(x,y);
}
}
for(y=0;y
DCT_Pre(&f[w*y],&W[w*y],wp);
}
for(y=0;y
for(x=0;x
f[x*h+y]=W[x+w*y];
}
}
for(x=0;x
DCT_Pre(&f[x*h],&W[x*h],hp);
}
double a;
memset(lpPoints,0,nWidth*nHeight);
for(y=0;y
for(x=0;x
a=fabs(W[x*h+y]);
if (a>255) a=255;
Point(x,nHeight-y-1)=(BYTE)(a);
}
}
delete f;
delete W;
PutPoints(lpPoints);
delete lpPoints;
}
void main(int argc, char *argv[])
{
if(argc==2)
FileName=argv[1];
else
return;
OpenFile();
Dct();
SaveAs();
}
- 离散余弦变换(DCT)的DSP仿真实现
- 基于低频奇异值均值的图像零水印算法 3次下载
- 基于多变换域的彩色图像多功能水印算法 12次下载
- 形态学图像处理综合示例_《OpenCV3编程入门》书本配套源代码 8次下载
- 用morphologyEx进行图像开运算_《OpenCV3编程入门》配套源代码 11次下载
- 用morphologyEx进行图像膨胀_《OpenCV3编程入门》配套源代码 12次下载
- 用morphologyEx进行图像腐蚀_《OpenCV3编程入门》配套源代码 2次下载
- 离散傅里叶变换 5次下载
- 基于离散余弦的数字水印算法 0次下载
- 去降Mallat离散小波变换实现彩色图像分割 19次下载
- 有限长离散变换-离散傅里叶变换
- 一种基于二维离散小波变换的医学图像增强算法
- 基于余弦变换和小波变换的数字水印算法
- 基于离散余弦变换矩阵的隐私数据保护方法
- matlab图像处理源代码
- 经典傅里叶变换与快速傅里叶变换的区别 457次阅读
- 如何实现离散傅里叶变换 448次阅读
- 傅里叶变换在信号处理中的应用 1819次阅读
- dct变换的主要优点有哪些 612次阅读
- 在距离多普勒处理中使用Keystone变换进行距离徙动校正 2325次阅读
- LOAM源代码中坐标变换部分的详细讲解 2150次阅读
- OpenCV库在图像处理和深度学习中的应用 923次阅读
- 浅谈隐写技术在保密安全中的应用 1813次阅读
- 用matlab对信号进行傅里叶变换 1856次阅读
- 解答数字信号处理主要包括的内容及系统稳定条件 5330次阅读
- 图像处理之图像的灰度变换 8219次阅读
- 集中离散的傅氏变换以及matlab实现方法 4717次阅读
- 数字图像处理入门基础知识(步骤) 1.9w次阅读
- MATLAB如何实现图像增强灰度变换直方图均衡匹配 1w次阅读
- 数字图像处理及应用主要有哪些 3.3w次阅读
下载排行
本周
- 1电子电路原理第七版PDF电子教材免费下载
- 0.00 MB | 1490次下载 | 免费
- 2单片机典型实例介绍
- 18.19 MB | 92次下载 | 1 积分
- 3S7-200PLC编程实例详细资料
- 1.17 MB | 27次下载 | 1 积分
- 4笔记本电脑主板的元件识别和讲解说明
- 4.28 MB | 18次下载 | 4 积分
- 5开关电源原理及各功能电路详解
- 0.38 MB | 10次下载 | 免费
- 6基于AT89C2051/4051单片机编程器的实验
- 0.11 MB | 4次下载 | 免费
- 7蓝牙设备在嵌入式领域的广泛应用
- 0.63 MB | 3次下载 | 免费
- 89天练会电子电路识图
- 5.91 MB | 3次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 2PADS 9.0 2009最新版 -下载
- 0.00 MB | 66304次下载 | 免费
- 3protel99下载protel99软件下载(中文版)
- 0.00 MB | 51209次下载 | 免费
- 4LabView 8.0 专业版下载 (3CD完整版)
- 0.00 MB | 51043次下载 | 免费
- 5555集成电路应用800例(新编版)
- 0.00 MB | 33562次下载 | 免费
- 6接口电路图大全
- 未知 | 30320次下载 | 免费
- 7Multisim 10下载Multisim 10 中文版
- 0.00 MB | 28588次下载 | 免费
- 8开关电源设计实例指南
- 未知 | 21539次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935053次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537791次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233045次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191183次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183277次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138039次下载 | 免费
评论