一、基于分数阶傅立叶变换的水印算法简介

1 分数阶傅立叶变换
FRFT可以解释为信号在时频平面内坐标轴绕原点逆时针旋转任意角度后构成的分数阶Fourier域上的表示方法, 它的基本定义是从线性积分变换的角度给出的。定义在t域的函数x (t) 的p阶分数阶傅立叶变换如下:

式中FRFT的变换核Kp (t, u) 如下:

其中α≡pπ2。记阶数为P的FRFT线性算子为FP。对于二维图像信号x (x, y) , 其二维FRFT如下:

P1和P2表示了在二维空间中的单独分数阶次, 两者可以相同, 也可以不同。当阶数接近于0时, 分数阶傅立叶变换将主要反映信号的时域特征, 当阶数接近于1时, 分数阶傅立叶变换将主要反映信号的频域特征, 为不失一般性, 本文令变换阶数P1=P2=0.3。

2 基于分数阶傅立叶变换的水印算法
2.1 水印的嵌入算法

为了保证水印算法的鲁棒性, 水印应该嵌入到图像的重要分量上, 通常重要分量为变换域系数集中幅值较大的系数。信号的分数阶傅立叶变换系数为一复数, 与变换域水印算法的基本原理相同, 分数阶傅立叶变换域水印的嵌入也是通过对信号的傅立叶变换系数的修改来实现的, 在这里我们采用加性嵌入规则。

(1) 对大小为N×N的图像I(x,y)进行二维分数阶傅立叶变换, 变换阶数为 (0.3, 0.3) , 将二维分数阶傅立叶变换系数按照递减顺序重新排列为序列S={Si|Si≥Si−1}。较大的分数阶傅立叶变换, 系数嵌入水印, 嵌入后的水印图像会产生比较明显的失真;较小的分数阶傅立叶变换系数嵌入水印, 算法对抗压缩和低通滤波攻击的性能不好。所以, 在嵌入水印时将最大的L个系数舍弃不用, 而将水印嵌入其后的M个系数中。

(2) 令水印数据是一个伪随机序列, 序列的长度为M‚R={Ri|i=1,2,…,M}, 那么在这种算法中, 水印的容量就可用伪随机序列的长度M来表示, 便于进行统计分析。

(3) 采用加性规则表示分数阶傅立叶变换域水印嵌入的过程如下:
Swi=Si+αRii=L+1, L+2, …, L+M (4)
其中, α为水印的嵌入强度。

(4) 将嵌入水印之后的序列Swi重新排列为N×N的矩阵, 对其进行变换阶数为 (-0.3, -0.3) 的二维分数阶傅立叶变换, 得到含有水印的图像。

2.2 水印的检测方法
水印的检测过程为水印加入的逆过程, 采用相关检测方法。水印提取的过程如下:将水印图像和原始图像分别进行(0.3,0.3)的分数阶傅立叶变换, 从中抽取值序列V′={v′1,v′2,⋯,vL´}和V={v1,v2,⋯,vL}。利用水印的嵌入公式, 水印的提取如下:
wi = v′i-vi/α (5)
由此得到提取出的水印序列X∗={x1∗,x2∗,⋯,xL∗}, 通过式 (5) 计算X与原来嵌入的水印序列X={x1,x2,⋯,xL}的相似度如下:

引入一个可以判断X
和X是否相似的门限值T, 在实验中, 为减少误判和错判, 一般将T设为6, 如果sim(X,X∗)>6, 就可认为X*是由X派生的。

二、部分源代码

close all;
clear all;
clc;
a=0.5;
alpha=0.08;
A = imread('lenaTest3.jpg');
w = imread('cameraman.pgm');
W=double(w);
[W_IM,S,Uw,Vw ] = embedding(A,W,a,alpha);
[ EX_WM ] = extraction(S,W,W_IM ,a,alpha,Uw,Vw);
[ N_IM ] = addnoise(A,S,W,W_IM ,a,alpha,Uw,Vw);[ Blur_IM ] = blurring(A,S,W,W_IM ,a,alpha,Uw,Vw);[ compress_IM ] = compression(A,S,W,W_IM ,a,alpha,Uw,Vw);[ crop_IM ] = cropping(A,S,W,W_IM ,a,alpha,Uw,Vw );[R_IM1,R_IM2] = Rotation( A,S,W,W_IM ,a,alpha,Uw,Vw );[I] = row_col_blank( A,S,W,W_IM ,a,alpha,Uw,Vw  );[ sharp_IM ] = sharpening( A,S,W,W_IM ,a,alpha,Uw,Vw );[ J] = translation( A, S,W,W_IM ,a,alpha,Uw,Vw);

三、运行结果


















四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]韩纪庆,张磊,郑铁然.语音信号处理(第3版)[M].清华大学出版社,2019.
[2]柳若边.深度学习:语音识别技术实践[M].清华大学出版社,2019.
[3]杨守义,姬留杰,穆晓敏,齐林.基于FRFT的数字水印算法分析[J].计算机应用与软件. 2009,26(01)

【图像隐写】基于matlab FRFT+SVD盲水印嵌入+攻击+提取【含Matlab源码 1757期】相关推荐

  1. 【Matlab车牌识别】停车计费系统【含GUI源码 735期】

    一.代码运行视频(哔哩哔哩) [Matlab车牌识别]停车计费系统[含GUI源码 735期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅.MATLA ...

  2. 【Matlab生物电信号】生物电信号仿真【含GUI源码 684期】

    一.代码运行视频(哔哩哔哩) [Matlab生物电信号]生物电信号仿真[含GUI源码 684期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]董兵,超于毅,李 ...

  3. 【Matlab语音分析】语音信号分析【含GUI源码 1718期】

    一.代码运行视频(哔哩哔哩) [Matlab语音分析]语音信号分析[含GUI源码 1718期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊,郑铁 ...

  4. 【Matlab身份证识别】身份证号码识别【含GUI源码 014期】

    一.代码运行视频(哔哩哔哩) [Matlab身份证识别]身份证号码识别[含GUI源码 014期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅.MAT ...

  5. 【Matlab水果识别】自助水果超市【含GUI源码 594期】

    一.代码运行视频(哔哩哔哩) [Matlab水果识别]自助水果超市[含GUI源码 594期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]倪云峰,叶健,樊娇娇 ...

  6. 【图像隐藏】基于DCT和FFT数字水印嵌入+攻击+提取含Matlab源码

    1 简介 文章对DCT(离散余弦变换)和FFT域图像数字水印算法进行了研究,并用matlab工具进行实验,结果表明该算法使水印的嵌入达到了较好的鲁棒性和不可见性.​ 2 部分代码 function [ ...

  7. 【Matlab语音隐写】DCT+DWT音频数字水印嵌入提取【含GUI源码 836期】

    一.代码运行视频(哔哩哔哩) [Matlab语音隐写]DCT+DWT音频数字水印嵌入提取[含GUI源码 836期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1 ...

  8. 【Matlab语音隐写】DWT音频数字水印【含GUI源码 712期】

    一.代码运行视频(哔哩哔哩) [Matlab语音隐写]DWT音频数字水印[含GUI源码 712期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊, ...

  9. 【Matlab图像融合】小波变换遥感图像融合【含GUI源码 744期】

    一.代码运行视频(哔哩哔哩) [Matlab图像融合]小波变换遥感图像融合[含GUI源码 744期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 包子阳,余 ...

  10. 【Matlab图像加密】正交拉丁方置乱算法图像加解密【含GUI源码 182期】

    一.代码运行视频(哔哩哔哩) [Matlab图像加密]正交拉丁方置乱算法图像加解密[含GUI源码 182期] 二.matlab版本及参考文献 一.代码运行视频(哔哩哔哩) [Matlab图像处理]自动 ...

最新文章

  1. 【LeetCode】309. Best Time to Buy and Sell Stock with Cooldown
  2. ACE框架解读 - 源码篇
  3. [lct] Luogu P4219 大融合
  4. java单双引号的区别
  5. sed的模式匹配用法探讨
  6. 【数据结构和算法笔记】最小生成树(贪心算法讲解 )
  7. linux免密码登录ppk,【原创文章】通过WDCP生成密钥对免密码登录linux的方法
  8. Jenkins+CCNET的另类部署图
  9. html简单页面实验报告原理,html网页设计实验报告
  10. 电信接入点服务器修改,修改apn加快电信4g网速(电信最佳apn接入点)
  11. 高效记忆/形象记忆(11)110数字编码表 51-60
  12. mac chrome 重启电脑 插件消失
  13. 高精度乘法———列表法
  14. android mb kb单位转换,存储单位的换算(KB, MB, GB)
  15. Linux内核Notifier机制
  16. 小牛电动Q2财报:国外不乐观,国内狂下沉
  17. sql注入预防 [ 光影人像 东海陈光剑 的博客 ]
  18. 成为REAL程序员的终极指南
  19. 管道,Linux命令,Windows命令,cmd命令,tmux,vim,shell,bash,sh文件,bat文件
  20. 用计算机时按错了按什么键恢复出厂设置,电脑开机按什么键进入一键还原 选择高级—将系统恢复到过去某...

热门文章

  1. JSP基础--J2EE赢在起跑线
  2. [XA]读书感想:个人对敏捷软件开发宣言的理解
  3. Java - Java Mail邮件开发(3)spring +Java Mail + Velocity
  4. Git-第四篇廖雪峰Git教程学习笔记(3)远程仓库,克隆远端库
  5. 2018/12/04 PAT刷题 L1-008 求整数段和 java
  6. hdu1403(后缀数组模板)
  7. linux 中的快捷键
  8. table中强制不换行
  9. WPF基础之体系结构
  10. c++/cli 之数据库操作