- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
DCT域图像水印技术.doc
DCT域图像水印技术
一.实验目的:
使用MATLAB软件,熟悉DCT域图像水印技术,并学会该技术将特定的内容嵌入图像中。
二.实验原理:
离散余弦变化(Discrete Consine Transform)简称DCT。
任何连续的实对称函数的傅立叶变换中只含有余弦项,因此余弦变换与傅立叶变换一样有明确的物理意义,DCT变换避免了傅立叶变换中的复数运算,它是基于实数的正交变换。DCT变换矩阵的基向量很近似于Toeplitz矩阵(系数矩阵对称且沿着与主对角线平行的任意一对角线上的元素都相等)的特征向量,而Toeplitz矩阵又体现了人类语言及图像信号的相关特性。
故DCT常常被认为是对语音和图像编码的最佳变换,同时DCT算法较易于在数字信号处理器中快速实现,因此它目前在图像编码中占有重要的地位。
二维DCT变换是目前最常使用的有损数字图像压缩系统——JPEG系统的核心。
在本次实验中我们用了matlab内嵌的函数dct2()和idct2(),来进行dct变化和反变换。大大简化的试验的过程。
与空域图像水印相比,DCT域图像水印对压缩,滤波和其他一些数字处理算子具有更强的稳健性,同时又与常用的图像压缩标准JPEG兼容,因而得到了广泛的重视,基于DCT的数字水印技术是目前水印技术中研究的最多,最深入,而且也是最成熟的。
本次试验为了简化过程,所以没有进行通常的图像分块DCT的过程,而是直接寻找DCT变换值小于门限的位置,并在这些位置中嵌入水印。
以图像Lena为载体图像,大小为 256×256。shuiyin.txt为存放水印的文件(复旦大学数字水印2006年12月22日)。
DCT嵌入水印及水印提取的过程如下:
读原始图像和水印文件。
图像进行DCT变换。
根据水印的字符多少来确定DCT门限值的大小。
根据DCT门限值来确定图像中要嵌入水印的位置。
在变换后的图像中嵌入水印。
用之前得到的嵌入水印的位置提取出水印。
三.实验内容:
以下是进行DCT域图像隐藏的程序。
DCT_suiyinqr.m
clc
fid=fopen(shuiyin.txt,rt); % 打开shuiyin.txt文件,对其进行读操作
[A,count]=fread(fid);
% 将标识符为fid的文件以二进制的方式全部读入A中
% count中存放的是A的大小
fclose(fid); % 关闭文件
RGB=imread(Lenna.bmp); % 装入图像
figure(1),imshow(RGB); % 显示图像
I=rgb2gray(RGB); % 将真彩图像转换为灰度图像
figure(2),imshow(I); % 显示灰度图像
J=dct2(I); % 进行余弦变换
[m n]=size(J); % 计算矩阵J的大小
%%%%%%%%%%%%%%%%%%%%%%%%%%
% 根据shuiyin文件中的字符数,计算DCT变换的门限值的大小,并放在num变量中
if count=20
num=0.001;
else if count=44
num=0.002;
else if count=116
num=0.005;
else if count=224
num=0.01;
else num=0.1;
end
end
end
end
%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%%%%%%%
% 记录DCT变换值小于num的位置
% 并将DCT变换值小于num的元素设为0
j=0;
for i=1:m*n
if abs(J(i))num
j=j+1;
s(j)=i;
J(i)=0;
end
end
%%%%%%%%%%%%%%%%%%%%%
K=idct2(J)/255; % 进行余弦反变换
figure(3),imshow(K); % 显示一部分元素被设为0后的图像
%%%%%%%%%%%%%%%%%%%%%
% 将A中字符逐一嵌入J中
for i=1:count
J(s(i))=A(i);
end
%%%%%%%%%%%%%%%%%%%%%
figure(4),imshow(K); % 显示嵌入水印后的图像
imwrite (K, result.jpg, jpg);
for i=1:count
文档评论(0)