[求助]求助求助
clear all;k=0.5; % 设置嵌入强度
blocksize=8; % 设置块的大小
midband=[0,0,0,1,1,1,1,0; % 定义DCT中频系数
0,0,1,1,1,1,0,0;
0,1,1,1,1,0,0,0;
1,1,1,1,0,0,0,0;
1,1,1,0,0,0,0,0;
1,1,0,0,0,0,0,0;
1,0,0,0,0,0,0,0;
0,0,0,0,0,0,0,0 ];
% 读入原始图像
file_name='lena.bmp';
cover_object=double(imread(file_name));
% 原始图像的行数与列数
Mc=size(cover_object,1); %原图的行数
Nc=size(cover_object,2); %原图的列数
c=Mc/8;d=Nc/8;m=c*d; %计算图象划分的图象块
% 确定可嵌入的最大信息量
max_message=Mc*Nc*22/(blocksize^2);
% 产生水印信息
x=-1:0.01:1;
%水印图像的行数与列数
Nm=size(x,2); %水印序列的个数
figure(1)
plot(x);
title('水印');
% 检查水印信息是否过大
if (length(Nm) > max_message)
error('水印太大')
end
n=Nm/22;
n1=uint8(Nm/22);
if(n>n1)
n=n1+1;
else
n=n1;
end %计算要嵌入的块数
%计算宿主图象每一块的方差
xx=1;
for j=1:c
for i=1:d
qw(xx)=1/64*sum(sum(cover_object((1+(j-1)*8):j*8,(1+(i-1)*8):i*8))); %图像块的期望
fc(xx)=1/64*sum(sum((cover_object((1+(j-1)*8):j*8,(1+(i-1)*8):i*8)-qw(xx)).^2)); %图像块的方差
xx=xx+1;
end
end
A=sort(fc); %方差从小到大排序
%选取方差最大的前n块
fc_o=ones(1,m);
for g=m-n+1:m
for h=1:m
if A(g)==fc(h)
fc_o(h)=0; %如果是方差较大的前n块则fc_o设为0,表示可以嵌入水印
h=m;
end
end
end
运行之后出现
??? Error using ==> colon
Colon operands must be in range of the data type.
为什么说冒号运算要在数据范围之内?
改成下面的又可以了,这是为什么?
clear all;
k=0.5; % 设置嵌入强度
blocksize=8; % 设置块的大小
midband=[0,0,0,1,1,1,1,0; % 定义DCT中频系数
0,0,1,1,1,1,0,0;
0,1,1,1,1,0,0,0;
1,1,1,1,0,0,0,0;
1,1,1,0,0,0,0,0;
1,1,0,0,0,0,0,0;
1,0,0,0,0,0,0,0;
0,0,0,0,0,0,0,0 ];
% 读入原始图像
file_name='lena.bmp';
cover_object=double(imread(file_name));
% 原始图像的行数与列数
Mc=size(cover_object,1); %原图的行数
Nc=size(cover_object,2); %原图的列数
c=Mc/8;d=Nc/8;m=c*d; %计算图象划分的图象块
% 确定可嵌入的最大信息量
max_message=Mc*Nc*22/(blocksize^2);
% 产生水印信息
x=-1:0.01:1;
%水印图像的行数与列数
Nm=size(x,2); %水印序列的个数
figure(1)
plot(x);
title('水印');
% 检查水印信息是否过大
if (length(Nm) > max_message)
error('水印太大')
end
n=Nm/22;
n1=uint8(Nm/22);
if(n>n1)
n=n1+1;
else
n=n1;
end %计算要嵌入的块数
%计算宿主图象每一块的方差
xx=1;
for j=1:c
for i=1:d
qw(xx)=1/64*sum(sum(cover_object((1+(j-1)*8):j*8,(1+(i-1)*8):i*8))); %图像块的期望
fc(xx)=1/64*sum(sum((cover_object((1+(j-1)*8):j*8,(1+(i-1)*8):i*8)-qw(xx)).^2)); %图像块的方差
xx=xx+1;
end
end
A=sort(fc); %方差从小到大排序
%选取方差最大的前n块
fc_o=ones(1,m);
for g=1015:1024
for h=1:1024
if A(g)==fc(h)
fc_o(h)=0; %如果是方差较大的前n块则fc_o设为0,表示可以嵌入水印
h=m;
end
end
end