DWT隐写术

时间:2014-12-04 18:30:51

标签: steganography dwt lsb

我正在隐写术/水印领域学习。我对此很新,所以请耐心等待!我使用LSB方法在How do I encapsulate some text information in an image and extract it using MATLAB?找到了一篇优秀的帖子,我很满意! 我想问的问题是,链接中使用的代码是否可以修改为使用LSB隐藏DWT转换中的数据。如果是这样,我会如何尝试,正如我所说,我对此很新。我是否会获得四个子带以及我想要嵌入的子带(即LH_1)只是对代码进行更改,例如,L被指定为封面图像,我会将L更改为LL_1吗?

我很抱歉如果我把这个问题弄糊涂了。但我需要帮助才能知道!谢谢你很多

修改

%Cover Image
origIm = imread('lena.bmp');


% Discrete Wavelet Transform
[LL LH HL HH]=dwt2(origIm,'haar');
dec=[...
    LL,LH
    HL,HH
    ...
    ];

%figure;imshow(dec,[]);title ('DWT');
%[visibleRows visibleColumns] = size(origIm);

A = importdata('minutiaTest.txt');
binaryString = transpose(dec2bin(A,8));
binaryString = binaryString(:);
N = length(binaryString);

b = zeros(N,1); %b is a vector of bits
   for k = 1:N
       if(binaryString(k) == '1')
              b(k) = 1;
       else
              b(k) = 0;
       end
   end
%c=HH;   
s = HH;
%figure (1);imshow(s);
height = size(HH,1);
width = size(HH,2);

k = 1; Array=[];l=1;my=1;
   for i = 1 : height
       for j = 1 : width
           LSB = mod(double(HH(i,j)), 2);
             if (k>N || LSB == b(k))
                s(i,j) = HH(i,j);
                    l=k+1;
             else 
       if(LSB == 1)
           s(i,j) = HH(i,j) - 1;
       else
           s(i,j) = HH(i,j) + 1;
             Array(my)=l;
                l=l+1;
                    my= my + 1;
       end
                          k = k + 1;
     end
   end
   end


  %figure (2); imshow(s);

  stego=idwt2(LL,LH,HL,HH,'haar');
  imwrite(uint8(stego), 'hiddenmsgimage.bmp');
  %imshow(stego);



  Stego = imread('hiddenmsgimage.bmp');
  %imshow(Stego);


 [LL LH HL HH]=dwt2(Stego,'haar');
dec=[...
    LL,LH
    HL,HH
    ...
    ];
%imshow(HH);
%figure;imshow(dec,[]);title ('DWT');
k = 1;my=1;ur=1;
for i = 1 : height
  for j = 1 : width
    if( k<=N )
      if (my<numel(Array) && Array(my)==ur)
         b(k)=~(mod(double(s(i,j)),2));
      else
         b(k) = mod(double(s(i,j)),2);
      end
    k = k + 1;
    my= my + 1;
 end
 ur=ur+1;
  end
end

好的,这就是我到目前为止所做的。我现在正在尝试提取我隐藏的数据,有人可以帮忙吗?

0 个答案:

没有答案