基于二维CS-SCHT变换和LABS方法的水印嵌入和提取算法matlab仿真

简介: 该内容包括一个算法的运行展示和详细步骤,使用了MATLAB2022a。算法涉及水印嵌入和提取,利用LAB色彩空间可能用于隐藏水印。水印通过二维CS-SCHT变换、低频系数处理和特定解码策略来提取。代码段展示了水印置乱、图像处理(如噪声、旋转、剪切等攻击)以及水印的逆置乱和提取过程。最后,计算并保存了比特率,用于评估水印的稳健性。

1.算法运行效果图预览

1.jpeg
2.jpeg
3.jpeg
4.jpeg

2.算法运行软件版本
matlab2022a

3.算法理论概述
水印嵌入原理

image.png

   LABS方法在这里不太明确,如果指的是色彩空间转换,可能是在嵌入或提取阶段将RGB图像转换至LAB色彩空间,因为LAB空间更适合人眼对颜色的感知,有利于隐藏水印而不易察觉。

水印提取原理:

将嵌入水印的图像再次进行二维CS-SCHT变换。

提取变换后的低频系数,并按照嵌入时的规则去除宿主图像内容的影响,恢复出水印信息 Wm′。

image.png

如果“LABS方法”涉及某种特定的解码策略,则在此步骤中可能会进一步应用相应的色彩空间处理和解码算法,以确保正确无误地还原水印信息。

4.部分核心程序

Marks1s     = Arnold(Marks1,1,0); 

figure(1)
subplot(131);
imshow(I0,[]);
title('原始图像');
subplot(132);
imshow(Marks1,[]);
title('水印');
subplot(133);
imshow(Marks1s,[]);
title('置乱后水印');
%对图像进行处理
Mwk_1st   = func_wk_insert(I0,Marks1s,Power,Blksize,RR,CC);


if SEL == 1
%噪声攻击
noise0    = 20*randn(size(Mwk_1st));
Mwk_1st   = double(Mwk_1st) + noise0;
end
if SEL == 2
%旋转攻击
Mwk_1st   = double(imrotate(Mwk_1st,0.1,'bilinear','crop'));
end
if SEL == 3
%剪切攻击
Mwk_1st(501:800,501:800) = 255*rand(300,300);
end
if SEL == 4
%缩放攻击
Mwk_1st   = imresize(Mwk_1st,1/2);
Mwk_1st   = imresize(Mwk_1st,2);
end
if SEL == 5
%去除行列攻击
Mwk_1st(200,:) = 255*rand(1,1024);
Mwk_1st(:,400) = 255*rand(1024,1);
end
if SEL == 6
%模糊攻击
G = fspecial('gaussian', [5 5], 0.5);
Mwk_1st = imfilter(Mwk_1st,G,'same');
end
if SEL == 7
%增强攻击
Mwk_1st = double((1.2*Mwk_1st));
end


Msg1      = func_wk_desert(Mwk_1st,Blksize,RR,CC,4);
%对水印进行逆置乱
Msg1s     = Arnold(uint8(255*Msg1),1,1); 

figure(2)
subplot(221);
imshow(I0,[]);
title('原始图像');
subplot(222);
imshow(Marks1,[]);
title('水印');
subplot(223);
imshow(Mwk_1st,[]);
title('加入攻击的图像');
subplot(224);
imshow(Msg1s,[]);
title('水印提取');


%%
%水印提取,计算NC和PSNR
Marks1   = imresize(Marks1,[RR,CC]);
NC(indx) = func_nc(uint8(Marks1),uint8(Msg1s)); 
pause(1); 
end

figure;
plot(NC,'b-o');
grid on
xlabel('视频帧数');
ylabel('比特率');
axis([0,15,0.8*min(NC),1.1*max(NC)]);

save R1.mat NC
相关文章
|
19小时前
|
算法
基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真
本程序基于海鸥优化算法(SOA)进行三维曲面最高点搜索的MATLAB仿真,输出收敛曲线和搜索结果。使用MATLAB2022A版本运行,核心代码实现种群初始化、适应度计算、交叉变异等操作。SOA模拟海鸥觅食行为,通过搜索飞行、跟随飞行和掠食飞行三种策略高效探索解空间,找到全局最优解。
|
19小时前
|
算法 数据可视化 数据安全/隐私保护
一级倒立摆平衡控制系统MATLAB仿真,可显示倒立摆平衡动画,对比极点配置,线性二次型,PID,PI及PD五种算法
本课题基于MATLAB对一级倒立摆控制系统进行升级仿真,增加了PI、PD控制器,并对比了极点配置、线性二次型、PID、PI及PD五种算法的控制效果。通过GUI界面显示倒立摆动画和控制输出曲线,展示了不同控制器在偏转角和小车位移变化上的性能差异。理论部分介绍了倒立摆系统的力学模型,包括小车和杆的动力学方程。核心程序实现了不同控制算法的选择与仿真结果的可视化。
24 13
|
6月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
272 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
6月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
162 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
6月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
138 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
9月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
9月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
9月前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
|
9月前
|
供应链 算法
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)