【信号隐藏-数字水印】基于奇异值分解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代码问题可私信交流。

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


目录
打赏
0
0
0
0
845
分享
相关文章
基于遗传优化的SVD水印嵌入提取算法matlab仿真
该算法基于遗传优化的SVD水印嵌入与提取技术,通过遗传算法优化水印嵌入参数,提高水印的鲁棒性和隐蔽性。在MATLAB2022a环境下测试,展示了优化前后的性能对比及不同干扰下的水印提取效果。核心程序实现了SVD分解、遗传算法流程及其参数优化,有效提升了水印技术的应用价值。
|
8月前
|
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
305 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
182 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
214 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
地震波功率谱密度函数、功率谱密度曲线,反应谱转功率谱,matlab代码
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等