基于DCT变换的信息隐藏(数字水印)嵌入算法的设计(Matlab)
2007-08-11 14:06
1651 查看
隐藏信息嵌入程序,老师写的!
%------------------------------------------------------------------%
% 基于DCT变换的信息隐藏(数字水印)嵌入算法的设计____2007.06.19 %% %% %
%-----------------------------------------------------------=------%
clear all;
close all;
clc
%-----------------读入"W",并进行WPP处理---------------------
wm0=imread('watermark.bmp');
% wm0=imresize(wm0,[64 64]);
[Mm,Nm]=size(wm0) ; %计算水印图象的高度和宽度
n=Mm*Nm;
subplot(131)
imshow(wm0);
title('my watermark');
wm=double(wm0);
for i=1:Mm
for j=1:Nm
if wm(i,j)==0
wm(i,j)=-1;
end
end
end
%-----------------------读入"C",并进行CPP处理--------------------------
% cover_image=imread('cameraman.tif');
cover_image=imread('lena.bmp');
[Mc,Nc]=size(cover_image); %计算载体图象的高度和宽度
subplot(132);
imshow(cover_image);
title('my coverimage');
cover_image=double(cover_image);%读入原始宿主图象,并转换为双精度数组
%------------------分块DCT变换,嵌入水印----------------------------
%设置水印嵌入强度
% k=369;
k=70;
%设置嵌入位置
x=3;
y=5;
%设定图象的分块大小为8*8
blocksize=8;
c=Mc/blocksize;
d=Nc/blocksize;
m=c*d;%计算图象划分的图象块
%判断载体图像尺寸是否适合水印大小
if n>m
error('^_^ Dear classmates~~~~~~The watermark is too large to be imbeded into the coverimage,hehe~~~');
end
%分块DCT变换,嵌入水印
for j=1:c
for i=1:d
dct_block=dct2(cover_image((1+(j-1)*8):j*8,(1+(i-1)*8):i*8));
dct_block(x,y)=k*wm(j,i);
watermarked_image((1+(j-1)*8):j*8,(1+(i-1)*8):i*8)=idct2(dct_block);
end
end
%------------------------------------------------------------------
%生成并输出嵌入水印后的图象
imwrite(uint8(watermarked_image),'watermarked_image.bmp','bmp');
%显示嵌入水印后的图象
subplot(133);
imshow(uint8(watermarked_image))
title('watermarkedImage')
隐藏信息提取程序,我写的!
clear all ;
close all ;
clc
%定义一个空空间来存储提取的水印
wm_image=zeros(32,32);
% subplot(122);
% imshow(wm_image);
%read the marked image and transfer it to double precise
%-------------------------------------------------------
watermarked_image=imread('watermarked_image.bmp');
[M_marked,N_marked]=size(watermarked_image);
subplot(121);
imshow(watermarked_image);
title('The marked image') ;
watermarked_image=double(watermarked_image);
blocksize=8;
k=1/70;
x=3;
y=5;
c=M_marked/blocksize;
d=N_marked/blocksize;
for j=1:c
for i=1:d
dct_markedblock=dct2(watermarked_image((1+(j-1)*8):j*8,(1+(i-1)*8):i*8));
if k*dct_markedblock(x,y)>0
wm_image(j,i)=1;
else
vm_image(j,i)=0;
end
end
end
subplot(122);
imshow(wm_image);
title('mark image');
imwrite((wm_image),'MYwm_image.bmp','bmp');
%------------------------------------------------------------------%
% 基于DCT变换的信息隐藏(数字水印)嵌入算法的设计____2007.06.19 %% %% %
%-----------------------------------------------------------=------%
clear all;
close all;
clc
%-----------------读入"W",并进行WPP处理---------------------
wm0=imread('watermark.bmp');
% wm0=imresize(wm0,[64 64]);
[Mm,Nm]=size(wm0) ; %计算水印图象的高度和宽度
n=Mm*Nm;
subplot(131)
imshow(wm0);
title('my watermark');
wm=double(wm0);
for i=1:Mm
for j=1:Nm
if wm(i,j)==0
wm(i,j)=-1;
end
end
end
%-----------------------读入"C",并进行CPP处理--------------------------
% cover_image=imread('cameraman.tif');
cover_image=imread('lena.bmp');
[Mc,Nc]=size(cover_image); %计算载体图象的高度和宽度
subplot(132);
imshow(cover_image);
title('my coverimage');
cover_image=double(cover_image);%读入原始宿主图象,并转换为双精度数组
%------------------分块DCT变换,嵌入水印----------------------------
%设置水印嵌入强度
% k=369;
k=70;
%设置嵌入位置
x=3;
y=5;
%设定图象的分块大小为8*8
blocksize=8;
c=Mc/blocksize;
d=Nc/blocksize;
m=c*d;%计算图象划分的图象块
%判断载体图像尺寸是否适合水印大小
if n>m
error('^_^ Dear classmates~~~~~~The watermark is too large to be imbeded into the coverimage,hehe~~~');
end
%分块DCT变换,嵌入水印
for j=1:c
for i=1:d
dct_block=dct2(cover_image((1+(j-1)*8):j*8,(1+(i-1)*8):i*8));
dct_block(x,y)=k*wm(j,i);
watermarked_image((1+(j-1)*8):j*8,(1+(i-1)*8):i*8)=idct2(dct_block);
end
end
%------------------------------------------------------------------
%生成并输出嵌入水印后的图象
imwrite(uint8(watermarked_image),'watermarked_image.bmp','bmp');
%显示嵌入水印后的图象
subplot(133);
imshow(uint8(watermarked_image))
title('watermarkedImage')
隐藏信息提取程序,我写的!
clear all ;
close all ;
clc
%定义一个空空间来存储提取的水印
wm_image=zeros(32,32);
% subplot(122);
% imshow(wm_image);
%read the marked image and transfer it to double precise
%-------------------------------------------------------
watermarked_image=imread('watermarked_image.bmp');
[M_marked,N_marked]=size(watermarked_image);
subplot(121);
imshow(watermarked_image);
title('The marked image') ;
watermarked_image=double(watermarked_image);
blocksize=8;
k=1/70;
x=3;
y=5;
c=M_marked/blocksize;
d=N_marked/blocksize;
for j=1:c
for i=1:d
dct_markedblock=dct2(watermarked_image((1+(j-1)*8):j*8,(1+(i-1)*8):i*8));
if k*dct_markedblock(x,y)>0
wm_image(j,i)=1;
else
vm_image(j,i)=0;
end
end
end
subplot(122);
imshow(wm_image);
title('mark image');
imwrite((wm_image),'MYwm_image.bmp','bmp');
相关文章推荐
- 【MATLAB】基于DCT变换的数字水印
- 基于SIMD的AVS整数反变换算法设计与优化
- 基于多项滤波的数字正交变换MATLAB仿真程序
- 基于matlab的快速傅里叶(fft)变换以及滤波设计
- 基于HSV色彩空间变换的阴影检测算法——MATLAB实现
- 基于matlab的数字图像处理GUI设计
- 基于鲁棒性的数字水印的嵌入与提取
- 基于dct变换的图像编解码(包含Z扫描与反Z扫描)的matlab程序
- 基于DCT变换的数字图像分层压缩编码
- 基于MATLAB的数字水印技术研究
- Matlab 基于机器视觉的硬币自动分类算法设计
- 基于的DCT水印算法实现
- DCT域自适应混沌加密的二值图像数字水印算法
- 基于matlab的数字陷波器设计
- 基于MATLAB的数字水印技术研究
- 数字水印嵌入的matlab程序
- SSE图像算法优化系列二十一:基于DCT变换图像去噪算法的进一步优化(100W像素30ms)。
- 数字图像去噪典型算法及matlab实现
- C#中调用Matlab人工神经网络算法实现手写数字识别
- NEC算法以及数字水印的攻击