【信号隐藏-数字水印】基于奇异值分解svd实现音频水印嵌入提取含攻击附Matlab代码

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: 【信号隐藏-数字水印】基于奇异值分解svd实现音频水印嵌入提取含攻击附Matlab代码

1 内容介绍

提供一种基于奇异值分解的数字水印的嵌入和提取方法及系统,包括:获取水印图像和待加水印图像;基于所述待加水印图像,对所述水印图像进行加密,得到加密水印图像;基于奇异值分解,将所述加密水印图像嵌入到所述待加水印图像中,得到加水印图像;对应存储待加水印图像,加水印图像,以及基于奇异值分解得到的所述待加水印图像的加密向量.本发明通过根据待加水印图像,对水印图像进行加密,使得加密水印图像可分散分布在整个待加水印图像上,进一步基于奇异值分解,将所述加密水印图像嵌入到所述待加水印图像中,实现数字水印的无痕嵌入到待加水印图像中,从而可避免通过裁剪等方法将数字水印删除.

2 仿真代码

function M = Arnold(Image,Frequency,crypt)

%图像数值矩阵Arnold转换函数

%输入参数

%   Image:    待加密(待解密)图像文件名(注意写格式后缀),只能为二维

%   Frequency:   图像需要变换迭的次数

%       crypt           0~加密;1~解密

%输出参数

%   M:     转换后图像数据矩阵

%            输出由M对应的图像文件

if nargin<3

   disp('请按程序的输入参数格式输入参数!!!');

   return;

end

if crypt~=0 & crypt~=1

   disp('encrypt 必须为0或1!');

end

%将Q赋值给M,计算Q的大小

Q=Image;

M = Q ;

Size_Q   = size(Q);

%如果不是二维或三维数组,则不处理,返回

if (length(Size_Q) <= 2)

  if Size_Q(1) ~= Size_Q(2)

     disp('不是方阵,不能Arnold转换');

     return

  end

else

  disp('不是二维数组,不进行Arnold变换');

  return

end

   %------------------------------------------

  %Arnold转换

  n = 0;

  K = Size_Q(1);

 

  M1_t = Q;

  M2_t = Q;

 

  if crypt==1   %解密

      Frequency=ArnoldPeriod( Size_Q(1) )-Frequency;

  end

     

  for s = 1:Frequency

      n = n + 1;

      if mod(n,2) == 0

           for i = 1:K

              for j = 1:K

                 c = M2_t(i,j);

                 M1_t(mod(i+j-2,K)+1,mod(i+2*j-3,K)+1) = c;

              end

           end

      else

           for i = 1:K

              for j = 1:K

                  c = M1_t(i,j);

                  M2_t(mod(i+j-2,K)+1,mod(i+2*j-3,K)+1) = c;

              end

           end

      end

  end

 

  if mod(Frequency,2) == 0

     M = M1_t;

  else

     M = M2_t;

  end

  %------------------------------------------

  %imwrite( double(M)/255,strcat( 'Arnold_',num2str(Frequency),'_',Image ),'bmp' );

%    imshow(M);

 

  function Period=ArnoldPeriod(N)

% 求周期

if ( N<2 )

   Period=0;

   return;

end

n=1;

x=1;

y=1;

while n~=0

   xn=x+y;

   yn=x+2*y;

   if ( mod(xn,N)==1 && mod(yn,N)==1 )

       Period=n;

       return;

   end

   x=mod(xn,N);

   y=mod(yn,N);

   n=n+1;

end

3 运行结果

4 参考文献

[1]杜康华, 任文越, and 王崇. "一种基于奇异值分解的数字水印的嵌入和提取方法及系统.", 2018.

[2]刘广起, 郑晓势, 赵彦玲. 基于奇异值分解的DCT域音频数字水印算法[J]. 电声技术, 2010(3):5.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

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


相关文章
|
8月前
|
算法 数据安全/隐私保护 计算机视觉
基于二维CS-SCHT变换和LABS方法的水印嵌入和提取算法matlab仿真
该内容包括一个算法的运行展示和详细步骤,使用了MATLAB2022a。算法涉及水印嵌入和提取,利用LAB色彩空间可能用于隐藏水印。水印通过二维CS-SCHT变换、低频系数处理和特定解码策略来提取。代码段展示了水印置乱、图像处理(如噪声、旋转、剪切等攻击)以及水印的逆置乱和提取过程。最后,计算并保存了比特率,用于评估水印的稳健性。
|
3月前
|
人工智能 算法 数据安全/隐私保护
基于遗传优化的SVD水印嵌入提取算法matlab仿真
该算法基于遗传优化的SVD水印嵌入与提取技术,通过遗传算法优化水印嵌入参数,提高水印的鲁棒性和隐蔽性。在MATLAB2022a环境下测试,展示了优化前后的性能对比及不同干扰下的水印提取效果。核心程序实现了SVD分解、遗传算法流程及其参数优化,有效提升了水印技术的应用价值。
|
8月前
|
算法 数据安全/隐私保护 C++
基于二维CS-SCHT变换和扩频方法的彩色图像水印嵌入和提取算法matlab仿真
该内容是关于一个图像水印算法的描述。在MATLAB2022a中运行,算法包括水印的嵌入和提取。首先,RGB图像转换为YUV格式,然后水印通过特定规则嵌入到Y分量中,并经过Arnold置乱增强安全性。水印提取时,经过逆过程恢复,使用了二维CS-SCHT变换和噪声对比度(NC)计算来评估水印的鲁棒性。代码中展示了从RGB到YUV的转换、水印嵌入、JPEG压缩攻击模拟以及水印提取的步骤。
|
8月前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于DCT变换和位平面分解的数字水印嵌入提取算法matlab仿真
这是一个关于数字水印算法的摘要:使用MATLAB2022a实现,结合DCT和位平面分解技术。算法先通过DCT变换将图像转至频域,随后利用位平面分解嵌入水印,确保在图像处理后仍能提取。核心程序包括水印嵌入和提取,以及性能分析部分,通过PSNR和NC指标评估水印在不同噪声条件下的鲁棒性。
|
5月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
247 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
5月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
147 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
5月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
117 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
8月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
8月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)