【图像隐藏】基于RS码结合小波变换实现数字水印嵌入与提取附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信       无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机 

⛄ 内容介绍

Reed-Solomon(RS)码是一种纠错编码,通常用于在有噪声干扰的数据传输信道中纠正错误。小波变换是一种广泛应用于信号分析和处理的数学工具。将RS码与小波变换结合可以增强其纠错能力。

将RS码与小波变换结合可以实现数字水印的嵌入和提取。数字水印是一种隐蔽性较强的信息隐藏技术,通常用于版权保护、认证等领域。

数字水印的嵌入过程主要包括以下几个步骤:

  1. 将原始图像进行小波分解,得到不同频率子带。

  2. 对每个子带进行RS编码,并将数字水印信息添加到编码结果中。

  3. 将加入水印信息的子带进行反变换,得到含有数字水印的图像。

数字水印的提取过程主要包括以下几个步骤:

  1. 对含有数字水印的图像进行小波分解,得到相应的子带。

  2. 对每个子带进行RS译码,提取出其中的数字水印信息。

  3. 将提取出的数字水印信息进行解密和验证,以确定其是否为正确的水印信息。

⛄ 部分代码

            switch attack

                case 1,%-----------------不受攻击

                X_attack=X;

                subplot 121

                imshow(X8);title('不受攻击');

                break;

                case 2,%----------------椒盐噪声

                salt=input('椒盐噪声强度(0.005 0.01 0.03 0.05):');

               Xsalt8=imnoise(X8,'salt & pepper',salt);

               Xsalt=double(Xsalt8);

               X_attack=Xsalt;

               subplot 121

               imshow(Xsalt8);title('受椒盐噪声攻击的图像');

               break;

                case 3,%---------------高斯噪声

                    Xgaussian8=imnoise(X8,'gaussian',0,0.03);

                    Xgaussian=double(Xgaussian8);

                    X_attack=Xgaussian;

                    subplot 121

                    imshow(Xgaussian8);title('受高斯噪声攻击的图像');

                    break;

                case 4,%--------------右下角剪切1/4图像

                     X_attack1=X;

                   X_attack1(257:512,257:512)=255;

                   X_attack=X_attack1;

                   subplot 121

                   imshow(uint8(X_attack1));title('剪切1/4后图像');

                   break;

                case 5,%------------------左上角剪切1/8图像

                     X_attack1=X;

                   X_attack1(1:128,1:128)=255;

                   X_attack=X_attack1;

                    subplot 121

                   imshow(uint8(X_attack1));title('剪切1/8后图像');

                   break; 

                case 6,%------------------中间横向剪切1/8图像

                     X_attack1=X;

                   X_attack1(257:384,1:512)=255;

                   X_attack=X_attack1;

                    subplot 121

                   imshow(uint8(X_attack1));title('中间横向剪切1/4后图像');

                   break; 

                   

                case 7 %-------------JPEG压缩攻击

                    O=input('选择压缩质量因子(40   55  70  85):');

                    imwrite(X8,'jpegattack.jpg','jpeg','Quality',O);

                    X_attack=imread('jpegattack.jpg','jpeg');

                    subplot 121

                    imshow(X_attack);title('JPEG攻击后的图像');

                    X_attack=double(X_attack);

                    break;

                case 8 %------------中值滤波

                    ang=input('选择参数 1.3*3    2. 7*7:');

                    if  ang==1

                    X_attack=medfilt2(X8,[3,3]);

                    else

                      X_attack=medfilt2(X8,[2,2]);   

                    end

                    subplot 121

                    imshow(X_attack);title('中值滤波后的图像');

                    X_attack=double(X_attack);

                    break;

                case 9 %--------------旋转攻击

                    angle=input('选择旋转的角度:');

                    rotate=imrotate(X8,angle,'nearest','crop');

                    subplot 121

                    imshow(rotate);title('旋转后的图像');

                    X_attack1=imrotate(rotate,-angle,'nearest','crop');

                    X_attack=double(X_attack1);

                    break;

            end

⛄ 运行结果

⛄ 参考文献

[1] 徐芳.基于小波傅立叶变换的数字水印方法研究[D].电子科技大学,2007.DOI:10.7666/d.D310686.

[2] 郝东东,展美宁.基于离散小波变换的数字水印嵌入与提取[J].现代商贸工业, 2011, 23(21):2.DOI:10.3969/j.issn.1672-3198.2011.21.213.

[3] 蔚立磊,王俊飞,李新锋.基于小波变换的数字水印及Matlab仿真实现[J].信息技术, 2009(6):4.DOI:10.3969/j.issn.1009-2552.2009.06.025.

[4] 李栩,刘达通,陈军萍.基于小波变换的数字水印嵌入和提取[J].  2009.

⛳️ 代码获取关注我

❤️部分理论引用网络文献,若有侵权联系博主删除

❤️ 关注我领取海量matlab电子书和数学建模资料

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值