стеганография изображений — скрытие изображения внутри изображения

Что-то не так с этим кодом после отображения цифры 3. Два изображения не добавляются. Как это исправить? Эта программа скрывает изображение сообщения в нижних битовых плоскостях изображения обложки, читаемого в имени файла изображения обложки.

%covername = input('Enter image file name with extension (like jennifer.bmp): ', 's'); 
%read in message image filename 
%messagename = input('Enter message image file name with extension: ', 's'); 
%open cover and message image files 
cover = imread('hand.jpg'); 
message = imread('coins.png'); 
%display on screen the two images 
figure(1), imshow(cover); title('Original Image (Cover Image)'); 
figure(2), imshow(message);title('Image to Hide (Message Image)'); 
%change to double to work with addition below 
cover=double(cover); 
message=double(message); 
%imbed = no. of bits of message image to embed in cover image 
imbed=4; 
%shift the message image over (8-imbed) bits to right 
messageshift=bitshift(message,-(8-imbed)); 
%show the message image with only embed bits on screen 
%must shift from LSBs to MSBs 
showmess=uint8(messageshift); 
showmess=bitshift(showmess,8-imbed); 
figure(3),imshow(showmess);title('4 Bit Image to Hide'); 
%now zero out imbed bits in cover image 
coverzero = cover; 
for i=1:imbed 
coverzero=bitset(coverzero,i,0); 
end 
cove=uint8(coverzero);
%now add message image and cover image 
stego = imadd(cove,messageshift); 
figure(4),imshow(stego);title('Stego image'); 
%save files if need to
%4 bit file that was embedded = same as file extracted 
imwrite(showmess,'showmess4.bmp');           
%use bmp to preserve lower bits
%jpg will get rid of them
%stego file imwrite(stego,'stego4.bmp');

person user3219263    schedule 27.01.2014    source источник


Ответы (1)


Я считаю, что ваша проблема заключается в том, что imadd выдает вам ошибку «X и Y должны иметь одинаковый размер и класс, или Y должен быть скалярным двойным». Это намекает на то, что ваши изображения не похожи.

Если вы сделаете whos cove messageshift, вы увидите, что cove относится к классу uint8, а messageshift — к двойному. Просто преобразуйте messageshift в uint8 в строке 16, как вы сделали с cove:

messageshift=uint8(bitshift(message,-(8-imbed)));

person Reti43    schedule 27.01.2014