matlab 隐藏实时计算结果,EMD信息隐藏算法的MATLAB实现(基础)

EMD算法原理:

1b984fba4e858f0b14c3b6c7e9756b55.png

5c1403c7902b2cfde90b886c25b81c01.png

MATLAB代码如下:

clear;

clc;

pout=imread('pout.tif');

[m,n]= size(pout);%读取出图片的列像素个数和行像素个数

S = floor(rand(1,(m*n)/2)*5);%产生一组二分之一像素个数的0—4的随机数,作为待隐藏的信息

carrier = reshape(pout,1,m*n);%将载体图片转化为一维数组

figure(1);

subplot(1,2,1),imshow(pout), title('原始图像');%显示原始图像;

%加密算法

for i=1:2:m*n

g1=double(carrier(i));

g2=double(carrier(i+1));

f=mod((g1+g2*2),5);

r=mod((S((i+1)/2)-f),5);

if(r==0) %r=0时,g1,g2保持不变

g1=g1;

g2=g2;

elseif(r<=2) %r小于等于二时,gr+1

if(r==1)

g1=g1+1;

else

g2=g2+1;

end

elseif(r>2) %r大于2时,g(5-r)—-5

if(5-r==1)

g1=g1-1;

else

g2=g2-1;

end

end

newcarrier(i)=uint8(g1);

newcarrier(i+1)=uint8(g2);

end

newimg=reshape(newcarrier,m,n);

subplot(1,2,2),imshow(newimg),title('嵌入信息后');%打印嵌入信息后的图片

%提取算法

for k=1:2:m*n

b1=double(newcarrier(k));

b2=double(newcarrier(k+1));

information((k+1)/2)=mod((b1+b2*2),5);

end

执行效果:

图像的像素发生了变化:

7714e3bd2563567f22abcab8912d94e9.png

56f5db537e4e2579ee826bd838f4fcd8.png

提取信息结果:

8a61c4e71bd165a6f4f8f788fe44d372.png

实验中踩的坑:

图像中均采用uint8的类型,f函数运算溢出的话,模将为0。所以在运算f之前,需要把g1,g2变量转换为其他类型。到显示新图像之前还要将其转换为uint8类型。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值