matlab程序中function J = wmIwg此函数为嵌入过程输入:I为原始图像;w为水印信息;g为水印嵌入的阈值输出:J为嵌入水印的图像参数设置step = 05; 小波系数增长步长mmnn = sizeI;一层小波分解LLLHHLHH = dwt2Ihaar;=======计算avr_LH======m0n0 = sizeLH; avr_LH = 0;=======计算avr_HL==
function loca = wm_type_1(loca,w,step,g) %此函数用于在HL子带嵌入水印 %输入:loca为要嵌入水印的子带 %输出:loca为嵌入水印后的子带
[m2,n2] = size(loca);
index = 1;
%取出22的块
for k = 1:2:m2-1
for kk = 1:2:n2-1
tem = loca(k:k+1,kk:kk+1);
a11 = tem(1,1);
a12 = tem(1,2);
a21 = tem(2,1);
a22 = tem(2,2);
if 0 == w(index)
for s = step:step:100step
if a12-a22<=g %如果满足条件,a12增,a22减
a12 = a12 + s;
a22 = a22 - s;
else
break; %不满足条件,跳出此循环
end
end
%-----如果a11和a21不满足条件,则也要调整------------
if a11-a21>=g
for s = step:step:100*step
if a11-a21>=g
a11 = a11 - s;
a21 = a21 + s;
else
break;
end
end
end
end
if 1 == w(index)
for s = step:step:100*step
if a12-a22>=-g %如果满足条件,a12减,a22增
a12 = a12 - s;
a22 = a22 + s;
else
break; %不满足条件,跳出此循环
end
end
%-----如果a11和a21不满足条件,则也要调整------------
if a11-a21<=-g
for s = step:step:100*step
if a11-a21<=-g
a11 = a11 + s;
a21 = a21 - s;
else
break;
end
end
end
end
index = index + 1;
tem(1,1) = a11;
tem(1,2) = a12;
tem(2,1) = a21;
tem(2,2) = a22;
loca(k:k+1,kk:kk+1) = tem;
end
end
en
原文地址: https://www.cveoy.top/t/topic/fF6e 著作权归作者所有。请勿转载和采集!