您的位置:首页 > 编程语言 > MATLAB

基于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');
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: