最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

MATLAB制作数字水印

来源:动视网 责编:小OO 时间:2025-09-24 17:00:00
文档

MATLAB制作数字水印

1.数字水印背景二十一世纪是数字时代,通信技术的迅速发展和计算机网络的普遍运用,使人们可以通过互联网收发信息,可以随时上传自己创作的数字图象、音乐、视频等作品,可以进行学术交流。然而,也正是由于网络的这种便捷性、传播迅速的优点使其很容易被非法拷贝,导致数字产品的版权、完整性、有效性得不到保证,严重损害了创作者的利益。而一些具有特殊意义的数字信息,如涉及司法诉讼、机要等信息,更是遭到了不法分子地恶意攻击和随意篡改等,这一系列问题给当今科学家带来了巨大挑战。基于以上类似问题,数字水印技术可以说
推荐度:
导读1.数字水印背景二十一世纪是数字时代,通信技术的迅速发展和计算机网络的普遍运用,使人们可以通过互联网收发信息,可以随时上传自己创作的数字图象、音乐、视频等作品,可以进行学术交流。然而,也正是由于网络的这种便捷性、传播迅速的优点使其很容易被非法拷贝,导致数字产品的版权、完整性、有效性得不到保证,严重损害了创作者的利益。而一些具有特殊意义的数字信息,如涉及司法诉讼、机要等信息,更是遭到了不法分子地恶意攻击和随意篡改等,这一系列问题给当今科学家带来了巨大挑战。基于以上类似问题,数字水印技术可以说
1. 数字水印

背景

二十一世纪是数字时代,通信技术的迅速发展和计算机网络的普遍运用,使人们可以通过互联网收发信息,可以随时上传自己创作的数字图象、音乐、视频等作品,可以进行学术交流。

然而,也正是由于网络的这种便捷性、传播迅速的优点使其很容易被非法拷贝,导致数字产品的版权、完整性、有效性得不到保证,严重损害了创作者的利益。而一些具有特殊意义的数字信息,如涉及司法诉讼、机要等信息,更是遭到了不法分子地恶意攻击和随意篡改等,这一系列问题给当今科学家带来了巨大挑战。

基于以上类似问题,数字水印技术可以说是信息时代的特有产物,是一种可以在开放网络环境下保护版权和认证来源及保障信息完整性的新型技术,在音频、图像、视频制品中迅速得到广泛的研究和发展。

基本特点

数字水印是加在数字图象、音频或视频中的微弱信号,这个信号是人们能够建立产品所有权、辨认购买者或提供数字产品的一些额外信息。具体说来,它们都具有以下共同的特征:

1. 不可感知性

对于数字水印的嵌入,应该对观察者没有视觉障碍,理想情况应该是水印图像与原始图像没有丝毫差别。

2. 鲁棒性

鲁棒性是指一个数字水印能够承受攻击的能力,一般来说数字水印方法是针对特定的攻击进行设计。

3. 安全性

水印技术的安全性是其最重要的特性,由于它的商业性,其算法必须公开,算法的安全性完全取决于密钥,而不对算法进行保密。

4. 计算复杂度

不同应用中,对于水印的嵌入算法和提取算法的计算复杂度要求是不同的,复杂度直接与水印系统的实时性相关。

5. 水印容量

水印容量是指载体数据字中可嵌入水印信息位的多少,可以从几兆到几个比特不等。

 数字水印的应用

数字水印是以不可感知的方式嵌入到数字信息中的,总体来说它有以下应用:

数字产品产权保护

这是数字水印最广泛的应用,将秘密的数字信号嵌入到有价值的数字文件中,这些数字信号是产权的标识,在不破坏数字文件的情况下不能被盗版者出去,起到了保护产权的作用。

1. 数据库标识

有时一些文件中提示数据的标识信息往往比文件本身更重要或者一些音像文件需要将说明注释(如字幕等)与音像本身结合起来,这就可以通过数字水印技术加以解决。

2. 文件内容鉴定

水印技术在鉴定数据建立者和鉴别数据内容有着特殊的运用,目的是检测数据是否被修改过或是否经过特殊的处理。

3. 系统升级

日常生活中常常涉及到旧装系统升级情况,这可以通过将“增强层”嵌入到所发送的数据中来给传统的信号发射系统升级。

4. 商务交易中的票据防伪

随着高质量图像输入输出设备的发展,使得货币、支票以及其他票据的伪造变得更加容易。目前,美国、日本以及荷兰都已开始研究用于票据防伪的数字水印技术。

5. 媒体侦破

这一运用的目的是提取对原始信号进行处理过的信息。例如,鉴定方法可以发现一幅图像被篡改过,但无法发现是怎样篡改的。媒体侦破技术就可以指出图像的哪部分被篡改了,指出被插入到原图像中的新对象等等。

 数字水印技术的研究动态

随着多媒体技术和因特网技术的迅猛发展,一系列有关产权保护和信息安全的问题等亟待人们解决。数字水印技术便是二十世纪九十年代初出现的为解决这些问题的一门崭新的技术,也是近几十年来国内外专家和学者研究的一大热点。

1. 数字水印技术的研究现状

1) 空间域数字水印研究

最初提出的数字水印嵌入方法是在空间域上实现的。 

1995年,Btuyndoncky等提出了一个基于空域分块的方法,通过改变均值来嵌入水印。1996年,Patchwork等人提出了一种算法(Patchwork算法),该算法随机选取图像的N对像素点,通过增加其中一个点的亮度值而相应降低另一个点的亮度来隐藏信息。1998年,Darmstaedter等人提出了一种新的空域水印算法,该算法是基于图像的8×8块的空间域分解进行的。

不过上述的一些空域法普遍存在着可嵌入水印能量不好控制、鲁棒性差等缺点,现在已经很少有人使用,人们逐渐将水印的嵌入和检测转到频域上进行。

2) 频域数字水印研究

频域法大体有三类:DFT域、DCT域和DWT域。

Ruanaidh和Pun利用傅立叶域对全局性的旋转,平移和缩放变换具有不变性的特点,将水印嵌入到傅立叶域来达到对这些攻击的鲁棒性。

1999年,Hsu和Wu等人提出了基于可视化模型的算法,该算法具有很强的鲁棒性。2000年,黄继武、易开样等人还提出了一种DCT域数字水印算法:首先把图像分成8×8的不重叠像素块,经过分块DCT变换后,得到有DCT系数组成的频率块,然后随机选取一些频率块,水印信号嵌入到由密钥控制选择的一些DCT系数中。2004年,王向阳等提出了一种DCT域自适应彩色图像二维数字水印算法,将灰度图像嵌入到原始彩色图像中。其实 ,很多国内外研究人员提出的其他DCT域数字水印算法,采用的多是基于DCT的8×8图像块。

总的来说,基于图像特征的方法是探索性的,很难用目前现有的模型进行理论分析,了这种方法在需要有严格性能规定的实际商业中的应用。

2. 数字水印技术的前景与意义

从国际、国内对数字水印研究现状和重视程度,可见数字水印对社会的应用是多么重要,所以它的研究前景是十分广阔的。数字水印技术是近十年来横跨信号处理、数字通信、密码学、计算机网络技术等多学科的新兴技术,具有潜在的应用市场和良好的应用前景。

从研究意义来看,对它的研究具有重要的学术、经济和军事价值。一方面,它将促进多媒体技术、网络技术、通信技术、信号处理技术等多门新兴技术的有机结合,促进多媒体网络的进一步繁荣;另一方面,它将有助于多媒体信息版权保护及其冲突问题的解决。同时,它将促进隐蔽通信技术、信息安全技术的提高。

2. 数字水印技术概况

数字水印技术是利用数字产品普遍存在的冗余数据与随机性,将水印信息嵌入在数字产品本身中,从而起到保护数字产品版权或者完整性的一种技术。

 数字水印的分类

    数字水印技术根据不同的根据有不同的分类方法,一般有如下分类:

依据其特性来分可以将数字水印分为鲁棒数字水印和脆弱水印两种。前一种要求嵌入的水印对常用的编辑处理或恶意攻击有一定的抵抗性;而后一种则要求对信息的改动有很强的敏感性。

按水印的用途分类可将其分为版权水印、图像认证水印、隐藏标识水印、防止复印水印等。

按检测的过程来划分数字水印有非盲水印系统和盲水印系统。一般而言,非盲水印的鲁棒性较强,而其应用受到存储成本的。不过,目前学术界研究的数字水印大多数是盲水印。

根据内容划分水印又可以分为有意义水印和无意义水印。二者区别在于前者本身也是个图像或者音频片段的编码;而后者却是一个序列号。

按数字水印的隐藏的位置划分,数字水印又有空(时)域数字水印、频域数字水印、时/频域数字水印和时间/尺度域数字水印。

 数字水印系统的模型

现在学术界对数字水印算法的理解都是将一些不易察觉的具有随机特性的数据嵌入到图像频域或空域的系数上。从信号处理的角度看,嵌入水印可以看成是在强背景下迭加一个弱信号,由于人类视觉系统的分辨率受到一定的,只要迭加的信号幅度不超过HVS的对比门限,人眼就无法感觉到信号的存在,所以可以通过对原始图像进行一定调整,在不影响视觉效果的情况下嵌入一些水印信息。

数字水印系统的一般模型如图1所示:

图1  数字水印系统基本模型

水印嵌入器的输入量有三个:水印信号M,宿主信号S和密钥K。

水印信号M是指原始水印(图像或一个数字序列)通过一定的方法经过调制将嵌入到宿主信号中的数字信号。

宿主信号S是指被嵌入水印的信号(原始信号)。

密钥K则指用于提高水印系统安全性的密码信息,它于宿主信号。密钥有私有密钥和公共密钥之分,前者指攻击者在明确了水印嵌入方法但又不知道密钥的情况下,水印不会被破坏或盗取;后者是指攻击者对宿主信号(如内容标识、语言字幕等)不感兴趣的情况下,密钥也就不存在保密性,可以作为公共密钥。

 数字水印算法

1. 水印嵌入算法

数字水印技术涉及到了多门学科:信号处理、数字通信、密码学、模式识别等,研究人员从各个角度对水印嵌入算法进行了研究。以下简要介绍几种典型的算法。

1)空域水印嵌入算法

空域水印嵌入算法包括最低有效位算法LSB、Patchwork 方法、纹理映射编码方法等。其中最低有效位算法LSB是指首先把一个密钥输入一个m-序列发生器来产生水印信号,然后将其重新排列成2维水印信号,并按象素点逐一插入到原始图像象素值的最低位。由于水印信号被安排在了最底位上,是不可见的,基于同样的原因,可以轻易的被移去,所以它的鲁棒性很差。而Patchwork 方法是一种基于统计的数字水印嵌入方法,是通过增加一个象素点的亮度值,再相应的减少另一个象素点的亮度值来隐藏信息。纹理映射编码方法则是将数字信息隐藏于数字图象的任意纹理部分,该算法对于滤波、压缩和旋转等操作具有抵抗能力。

2)变换域水印嵌入算法 

变换域中能量分布集中,有利于保证水印的不可见性,提高了水印的鲁棒性,所以这一算法得到了广泛的应用。图2是变换域水印算法的过程

图2  变换域水印嵌入过程图

变换域算法中有一种典型的算法DCT域数字水印算法,该算法是通过对选定的DCT系数进行微小变换以满足特定的关系,来表示一个比特的信息。在水印信号提取时,则选取相同的DCT系数,并根据系数之间的关系抽取比特信息。其特点是数据改变幅度较小,且透明性好,但是其抵抗几何变换等攻击的能力较弱。另外基于DFT和DWT算法与上述算法具有相似的原理。 

目前DWT域的算法还不多见,但小波域具有良好的空频分解特性,而且嵌入式零树小波编码将在新一代的压缩标准中被采用,迎合着国际压缩标准,小波域的水印算法具有良好的发展前景。

2. 水印检测算法

水印检测是上述嵌入过程的逆过程,以下详细介绍一下水印相关检测技术。

待测试图像与原始图像的差为:

        (2-1)

对进行域变换,再利用下式提取水印序列:

                  (2-2)

得到了可提取的待测试序列:

                  (2-3)

待测序列中假设有n个数据值与原始水印序列中对应位上的值不相同,则定义误码率:

                    (2-4)

则有相关系数:

             (2-5)

从而可以得到相关系数和误码率的关系:

                      (2-6)

根据误码率的值可判断图像中是否含有水印信号,从而达到版权保护的目的。判定准则为:事先设定阈值。若,可以判定被测图像中含有水印;否则,没有水印。阈值的选择要同时考虑虚警概率和漏警概率。虚警概率是指待测图像中不包含水印而检测器输出结果却表明含有水印的概率;漏警概率是指待测图像中包含水印而检测器输出结果却表明不含有水印的概率。增大,则漏警概率降低而虚警概率提高;反之亦然。若与不相关,的概率等于具有Gaussian分布的随机变量超过其均值T倍方差的概率。

图3是典型的水印检测/提取系统 

图3  水印检测提取系统

3. MATLAB软件的介绍

MATLAB语言是一种非常强大的工程语言,被广泛应用于包括信号与图象处理、控制系统设计、通信、系统仿真等诸多领域。

 MATLAB研究数字水印的优点

MATLAB语言有不同于其他高级语言特点,它在研究数字水印有如下特点:

1. 编程效率高

MATLAB语言是用数学形式的语言编写程序,用MATLAB编写程序犹如在演算纸上排列公式与求解问题。由于它编写简单,所以编程效率高,易学易懂。 

2.用户使用方便

与其他语言相比,MATLAB能在同一画面上进行灵活操作,快速排除输入程序中的书写错误、语法错误甚至语意错误,从而加快了用户编写、修改和调试程序的速度,便于操作。

3. 扩充能力强,交互性好

MATLAB语言库函数丰富,用户还可以根据自己的需要方便地建立和扩充新的库函数,提高MATLAB使用效率和扩充功能。良好的交互性使程序员可以使用以前编写过的程序,减少重复性工作。

4. 移植性好,开放性好

MATLAB是用C语言编写的,而C语言的可移植性很好。于是MATLAB可以很方便地移植到能运行C语言的操作平台上。

5. 语言简单,内涵丰富

MATLAB语言中最基本最重要的成分是函数,同一函数名,不同数目的输入变量及不同数目的输出变量,代表着不同的含义。这不仅使MATLAB的库函数功能更丰富,而且大大减少了需要的磁盘空间,使得MATLAB编写的M文件简单、短小而高效。

6. 方便的绘图功能

MATLAB软件中有一系列绘图函数,在运用MATLAB软件时只需要调用不同的绘图函数,即可在图上标出图题、XY轴标注。

7. 功能强大的工具箱是MATLAB的另一特色。

MATLAB工具箱中的信号处理、控制系统、神经网络、图象处理、鲁棒控制、非线性系统控制设计、系统辨识、最优化、模糊逻辑、小波、通信、统计(statistics等工具箱),这些工具箱给各个领域的研究和工程应用提供了有力的工具。 

8. MATLAB的缺点

它和其他高级程序相比,程序的执行速度较慢。由于MATLAB的程序不用编译等预处理,也不生成可执行文件,程序为解释执行,所以速度较慢。

 MATLAB函数介绍

在研究水印技术时,我们处理的图像数据是二维信号,而声音是一维信号,所以在这里,我门只简单介绍与水印有关的函数。

1. 数据输入输出函数

imread()和imwrite():可以读写bmp, jpg/jpeg, tif/tiff, png, hdf, pcx, wxd格式文件。读索引文件时,还可以得到相应的调色板数据。

2. 图象显示

imshow():显示一幅图像;imfinfo():可以得到读入图像的信息。如文件的大小、格式、格式版本号、图像的高度、宽度、颜色类型(真彩色,灰度图还是索引图)等。

3. 变换域函数

对信号采用不同的变换,是实现频域法水印的至关重要的一步,MATLAB中的一维信号和二维信号分别提供了各种变换和逆变换函数。  

1) 离散余弦变换(DCT)

(1) dct(),dct2():分别实现一维信号和二维信号的DCT(离散余弦变换);

(2) idct(),idct2():分别实现一维信号和二维信号的IDCT(逆离散余弦变换);

2) 离散傅立叶变换(DFT)

(1) fft(),fft2():分别实现一维信号和二维信号的DFT(离散傅立叶变换);

(2) ifft(),ifft2():分别实现一维信号和二维信号的IDFT(逆离散傅立叶变换);

4. 攻击函数

对算法进行攻击测试是对水印鲁棒性检测的一种重要手段,一个好的水印算法必须经过各种攻击测试才能对之做出客观的评价。

MATLAB中的许多函数可以直接用来做攻击测试:

1)旋转:rotate()可以对图像进行任意角度的旋转;

2)剪裁:imcrop()可以按精确定位的各点坐标进行剪裁;

3)滤波:filter()和filter2()可实现对一维信号和二维信号的滤波;

4)加各种噪声:imnoise()可以对图像加入各种噪声,如白噪声、椒盐噪声等。

 

4. 基于DCT域的数字水印技术

离散余弦变换,简称DCT,是一种实数域变换,其变换核为实数的余弦函数,计算速度较快,是一种近似最佳变换,很适合于做图象压缩和随机信号处理,它对常用的图象压缩有较强的鲁棒性。

基于DCT域的数字水印算法,一般而言有两种算法。一种是直接对整幅图像进行DCT计算,选取合适频段的系数,嵌入水印。另一种是,首先将整幅图像分成块,对每一块分别进行DCT计算,在每一块中选取合适频段的系数,将水印信息分散嵌入到每一块所选取的DCT系数中。这种方法称为分块DCT,这种方法非常适合于8×8的图像块DCT变换。目前,DCT域的水印方法大多数是采用分块DCT方法。

 二维DCT概述

一般而言,数字图象,其二维DCT变换用矩阵表示,其定义式如下式所示:

  (4-1)

二维IDCT定义如下: 

  (4-2)

其中  并且

               (4-3)

我们最常用到的是8×8分块DCT,也就是首先将大小为M×N的图像分成的非重叠的大小为8×8的块,然后对每一块作DCT。根据式(4-1)和式(4-2),8×8DCT的定义如下:

    (4-4)

8×8IDCT的定义如下:

    (4-5)

其中, 并且

                  (4-6)

4.2基于DCT域数字水印嵌入算法

DCT域的水印嵌入过程,就是首先对宿主图像S进行分块DCT运算,选取出要嵌入的DCT系数C,并且对宿主图像用HVS模型进行分析,得到感知系数掩蔽模板,用其来控制水印嵌入强度,再将编码后的水印信号W,用一定方式嵌入到选好的系数中。用嵌入水印的系数替代原来位置的系数,再进行逆DCT(Inverse Discrete Cosine Transform,IDCT)变换,就得到了含有水印的图像X。DCT域水印系统的水印嵌入过程框图如图4所示:

图4  DCT域水印嵌入过程方框图

水印嵌入步骤如下:

1. 将宿主图像分成8×8的块,每一块都进行DCT变换,得到与宿主图象相同尺寸的DCT域系数矩阵。

2. 产生两个不相关的伪随机序列,并设定一个密钥key。

3. 将每个8×8的DCT系数矩阵,从每一块的中频段取出个系数。

4. 然后嵌入水印,嵌入规则为当水印图像元素为‘0’时,按照式子(其中alpha为尺度因子,mark为随机序列,为原图像的分块DCT系数),将一个随机序列与原始图像块的幅度谱对应元素进行乘性叠加;为‘1’时,用另一个伪随机序列与幅度谱对应元素进行乘性叠加。

5. 用得到的新的DCT系数对原来位置的DCT系数进行置换。

6. 对新的DCT系数矩阵进行DCT逆变换,得到了嵌入水印信号的图像。

 基于DCT域数字水印检测提取算法

DCT域水印的验证过程(即包括水印的检测和提取过程),就是将待测图像Y(注意此时的图像也许已经遭受了图象处理或恶意攻击)进行DCT运算;然后按着嵌入水印时选取的DCT系数,选取其含有水印的系数,进行水印提取,然后利用相关检测法判断水印是否存在。如果水印检测器输出结果显示水印存在,则根据需要可以用水印解码器对提取的水印进行解码,恢复水印。水印检测提取过程如图5

图5  DCT域数字水印检测提取框图

水印检测提取步骤如下:

1. 对含有水印图像进行8×8的块DCT变换。

2. 对每一块的DCT系数进行“之”字型排列,从我们已知的嵌入位置取出可能含有水印的系数,将所有提取出的系数,按顺序组成新的系数序列。 

3. 用密钥生成水印信号

4. 将含水印的系数序列与水印信号进行相关计算,得到归一化相关系数。

 实验结果及分析

以下是尺度因子alpha=30时的实验结果,以及受到各种攻击后所提取到的水印图像及其与原始水印图像的相关系数:

图6  原始图像和嵌入水印后的图像

此时,alpha=30

图7  没有受到攻击的图像及提取到的水印图像

此时相关系数=1

图8  加入白噪声后的图像、原始水印和提取的水印图像

此时相关系数=

图9  高斯低通滤波后的图像及提取的水印图像

此时相关系数=

图10  剪切后的图像及提取的水印图像

此时相关系数=

图11  旋转10后的图像及提取的水印图像

此时相关系数=

从以上结果可以看出:当图像(宿主信息)受到加噪、高斯低通滤波、剪切等攻击后,其可视度、提取的水印图像与原始水印图像的相似度(都在90%以上)

都是非常令人满意的;当受到旋转攻击后,其提取的水印图像与原始水印图像的相似度(不足50%)却令人感到失望,不过仍可证明水印信息的存在。

5 基于傅立叶域变换的数字水印技术

 傅立叶变换概述 

傅立叶变换(Fourier Transform)是线性系统分析的一个有力工具,是研究信号的频谱方法,它架起了时域和频域之间的桥梁。使我们能够定量分析诸如数字化系统、采样点、电子放大器、卷积滤波器、噪声等的作用,把傅立叶变换的理论同其物理解释相结合,将大大有助于解决大多数图象处理问题。

Fourier分析理论十分完善,既可以处理连续信号也可以处理离散信号。计算机只能处理离散信号,且在数字图象处理中,输入图像和输出图像通常都是二维的,一般表示成二维数字矩阵,因此这里直接讨论二维离散傅立叶变换(DFT)和二维快速傅立叶变换(FFT)。

1. 二维离散傅立叶变换DFT(Discrete Fourier Transform)

二维离散傅立叶变换对定义式如下:

  (5-1)

 (5-2)

二维离散傅立叶变换的傅立叶谱、相位、功率谱分别如下:

    傅立叶谱:                  (5-3)

    相位:                     (5-4)

    功率谱:              (5-5)

式子(5-1)可以分离为:

        (5-6)

式子(5-2)可以分离为:

       (5-7)

由上两式可知,二维傅立叶变换可由连续两次一维傅立叶变换得到,从而将二维DFT分解为水平和垂直两部分运算,上式中方括号中的项表示在图像的行上计算的DFT,方括号外边的求和则实现结果数组在列上的DFT,这种分解使我们可以用一维FFT来快速实现二维DFT。

2. 二维快速傅立叶变换FFT(Fast Fourier Transform)

FFT的基本思想是:

令序列的长度为,如果不满足,在尾部补零,没有任何影响。按n奇偶把分解为两个N/2点的子序列:

                  (5-8)

                 (5-9)

那么

              (5-10)

将(5-8)和(5-9)式代入上式得:

             (5-11)

上式右边的两部分恰好是长度(周期)为N/2的的傅立叶变换,所以:

           (5-12)

        (5-13)

这样一个长度为N的DFT就分解为两个长度为N/2的DFT,然后进行N/2次复数的蝶式运算,再运用分解-递归思想,分解次,每一次均有N/2个蝶式运算,所以FFT的时间复杂度为。

FFT在图像运用中的思想是,先将原图像进行转置,按行对转置后的图像矩阵做一维FFT,将此变换所得的中间矩阵再转置,再按对转置后的中间矩阵做一维FFT,最后得到的就是二维FFT。

 基于傅立叶域的数字水印嵌入算法

这里的嵌入算法大抵同前面所讲的嵌入过程,唯一不同的是傅立叶变换中涉及到复数运算,所以在嵌入过程中还需要计算一下其变换后的幅度值方可嵌入,嵌入算法的步骤如下:

1. 将宿主图像分成8×8的块,每一块都进行DFT变换,得到与宿主图象相同尺寸的DFT域图象系数矩阵。

2. 产生两个不相关的伪随机序列,并设定一个密钥key。

3. 将每个8×8的DFT系数矩阵,从每一块的中频段取出个系数。

4. 由于DFT域的幅度谱具有对称性,为了水印嵌入后保持这种对称性,也为了确保恢复图像像素值为实数,嵌入水印时采用对称嵌入。嵌入规则为当水印图像元素为‘0’时,按照式子(其中alfa为尺度因子,mark为随机序列,为原图像的分块DFT系数),将一个随机序列与原始图像块的幅度谱对应元素进行乘性叠加;为‘1’时,用另一个伪随机序列与幅度谱对应元素进行乘性叠加。

5. 用得到的新的DFT系数对原来位置的DFT系数进行置换。

6. 对每一图像块进行DFT逆变换,得到含水印图像。

 基于傅立叶域的数字水印检测提取算法

这里的检测提取算法过程大抵同前面所讲的DCT域数字水印检测提取算法,提取算法步骤如下:

1. 将宿主图像分成8×8的块,每一块都进行DFT变换,得到与宿主图像相同尺寸的DFT域图象系数矩阵。

2. 对每一块的DFT系数进行“之”字型排列,从我们已知的嵌入位置取出可能含有水印的系数,将所有提取出的系数,按顺序组成新的系数序列。 

3. 计算嵌入水印图像块的幅度谱与两个伪随机序列的相关性,假设嵌入的水印图像矩阵为‘0’时叠加的是随机序列A,为‘1’时叠加的是随机序列B,则提取时如果嵌入水印幅度谱与随机序列A的相关性大于其B的相关性,那么这个位置嵌入的是水印图像矩阵‘0’元素。按这个规则即可提取出水印图像。

4. 将含水印的系数序列与水印信号进行相关计算,得到归一化相关系数。

 实验结果与分析

以下是尺度因子alpha=260时的实验结果,以及受到各种攻击后所提取到的水印图像及其与原始水印图像的相关系数:

图12  原始图像与嵌入水印后的图像

图13  没有受到攻击的图像和直接提取的水印图像

此时相关系数=1

图14  加入白噪声后的图像、原始水印图像及提取的水印图像

此时相关系数=

图15  高斯低通滤波后的图像及提取的水印图像

此时相关系数=

图16  剪切后的图像及提取的水印图像

此时相关系数=

图17  旋转后的图像及提取的水印图像

此时相关系数=

从以上结果可以看出,由于DFT域对全局性的旋转、平移和缩放变换具有不变性的特点,基于DFT域的数字水印技术要比基于DCT域的数字水印技术的鲁棒性要强的多,特别是对于旋转攻击,前者的优势更加突出!

结  论

本文首先对数字水印技术进行了简单的概述,介绍了近些年来,国内外学者在这一方面所做出的努力和成就,并对其进行了一下客观的展望。其次,分别从数字水印可能受到的攻击、数字水印技术的嵌入、提取和检测四个方面展开了研究。

在研究过程中,通过改变尺度因子,进而改变水印信息的嵌入强度,然后比较嵌入水印信息后宿主图像的可视度来确定最佳尺度因子。经过实验观察,尺度因子越大嵌入水印后宿主图像的可视度就越小,即图像越模糊不清,却有利于提高其鲁棒性;反之亦然。

对于数字水印技术,除了通过改进算法来提高鲁棒性外,我们还可以从密码学角度通过提高攻破密钥所需要的代价来保护我们所传送的信息。另外,还可以仿照互联网中通过建立标准的协议和方法来进一步改变现状等等。

总之,这是一门崭新而富有挑战的学科,而且,随着网络的发展其前景也是非常乐观的,它需要各个领域的专家联合攻关共同努力才能取得理想的效果。同时,也希望自己能在这一领域有所作为!

参考文献

[1] 朱丹丹.图像数字水印技术要析[J] .通化师范学院学报.-通化:2008年2月第29卷第2期:39

[2] 彭静.数字水印算法检测标准的研究[J] .电子科技大学学报.-西安:2007年6月第36卷第3期:567

[3] 耿永军,朱雪芹.基于离散余弦变换的数字水印算法[J] .郑州大学学报.-郑州:2005

[4] 刘慧珍.变换域数字水印算法研究[J] .华侨大学硕士学位论文.-广州:2006:16~17

[5] 庞小红.图像数字水印理论与技术研究.哈尔滨工程大学博士学位论文.-哈尔滨:2006:29~30

[6] 曾满红.傅立叶明文水印及零水印算法的研究.燕山大学硕士学位论文.-北京:2005:16~17

[7] 庞小红.图像数字水印理论与技术研究.哈尔滨工程大学博士学位论文.-哈尔滨:2006:34

[8] Rafael ,Richad .数字图像处理(阮秋琦,阮宇智等译)[M]. -北京:电子工业出版社,2003

[9] 飞思科技产品研发中心.MATLAB 辅助图象处理[M] .-北京:电子工业出版社,2003

附录A(基于DCT域的数字水印算法程序)

%%%%%%%%%%%%% 嵌入算法 %%%%%%%%%%%%%%%

clear all; 

clc;

%%%%%% 读取水印图像 %%%%%%%%

omark=double(imread(''))/255;

mo=size(omark,1);

no=size(omark,2);

%%%%% 以下生成水印信息 %%%%%%

mark=omark;

alpha=30;

rand1=randn(1,8);

rand2=randn(1,8);

%%%%%% 读取宿主图像 %%%%%%%%

cimage=imread('');

figure(1);

subplot(2,3,1),imshow(cimage,[]),title(‘原始的宿主图像’);

[mc,nc]=size(cimage);

cda0=blkproc(cimage,[8,8],'dct2');

%%%%%%% 嵌入水印 %%%%%%%%%

cda1=cda0;  

for i=1:mo 

    for j=1:no 

        x=(i-1)*8;y=(j-1)*8;

        if mark(i,j)==1

        k=rand1;

        else

        k=rand2; 

        end

    cda1(x+1,y+8)=cda0(x+1,y+8)+alpha*k(1);

    cda1(x+2,y+7)=cda0(x+2,y+7)+alpha*k(2);

    cda1(x+3,y+6)=cda0(x+3,y+6)+alpha*k(3);

    cda1(x+4,y+5)=cda0(x+4,y+5)+alpha*k(4);

    cda1(x+5,y+4)=cda0(x+5,y+4)+alpha*k(5);

    cda1(x+6,y+3)=cda0(x+6,y+3)+alpha*k(6);

    cda1(x+7,y+2)=cda0(x+7,y+2)+alpha*k(7);

    cda1(x+8,y+1)=cda0(x+8,y+1)+alpha*k(8);

    end

end

%%%%%% 嵌入水印后图象 %%%%%%

wimage=blkproc(cda1,[8,8],'idct2'); 

wimage_1=uint8(wimage);

imwrite(wimage_1,'','bmp');

subplot(2,3,2),imshow(wimage,[]),title(‘嵌入水印后图象’);

%%%%%%%%%%%%%% 进行攻击测试 %%%%%%%%%%%

disp(‘1-->加入白噪声’);

disp(‘2-->高斯低通滤波’);

disp(‘3-->剪切图像’);

disp(‘4-->旋转攻击’);

disp(‘5-->直接检测’)

begin=input(‘请选择攻击(1-5):’)

switch begin

%%%%%%% 加入白噪声 %%%%%%%%

    case 1

Aimage1=wimage;

Wnoise=20*randn(size(Aimage1));

Aimage1=Aimage1+Wnoise;

subplot(2,3,4),imshow(Aimage1,[]),title(‘加入白噪声后的图象’);

att=Aimage1;

imwrite(att,'');

%%%%%%% 高斯低通滤波 %%%%%%%

    case 2

Aimage2=wimage;

H=fspecial('gaussian',[4,4],;

Aimage2=imfilter(Aimage2,H);

subplot(2,3,4),imshow(Aimage2,[]),title(‘高斯低通滤波后的图象’);

att=Aimage2;

imwrite(att,'')

%%%%%%%% 剪切攻击 %%%%%%%%

    case 3

Aimage3=wimage;

Aimage3(1:128,1:128)=256;

subplot(2,3,4),imshow(Aimage3,[]),title(‘剪切后的图象’);

att=Aimage3;

imwrite(att,'');

%%%%%%%% 旋转攻击 %%%%%%%%

    case 4

Aimage4=wimage;

Aimage4=imrotate(Aimage4,10,'bilinear','crop');

Aimage_4=mat2gray(Aimage4);

subplot(2,3,4),imshow(Aimage_4,[]),title(‘旋转10 度后的图象’);

att=Aimage_4;

imwrite(att,'');

%%%%%%% 没有受到攻击 %%%%%%%

    case 5

subplot(2,3,4),imshow(wimage,[]),title(‘直接提取的图像’);

att=wimage;

imwrite(att,'');

end

%%%%%%%%%%%%% 提取水印 %%%%%%%%%%%%%%

tmark_0=att;

tmark_0=blkproc(tmark_0,[8,8],'dct2');

pass=zeros(1,8);

for i=1:mo

    for j=1:no

        x=(i-1)*8;y=(j-1)*8;

        pass(1)=tmark_0(x+1,y+8);

        pass(2)=tmark_0(x+2,y+7);

        pass(3)=tmark_0(x+3,y+6);

        pass(4)=tmark_0(x+4,y+5);

        pass(5)=tmark_0(x+5,y+4);

        pass(6)=tmark_0(x+6,y+3);

        pass(7)=tmark_0(x+7,y+2);

        pass(8)=tmark_0(x+8,y+1);

if (corr2(pass,rand1)>corr2(pass,rand2))

             tmark_1(i,j)=1;

        else

             tmark_1(i,j)=0;

        end

    end

end

%%%%%%%%%% 计算NC(归一化相关系数)%%%%%%%%

g_mark=double(tmark_1);

o_mark=double(omark);

[m,n]=size(g_mark);

nc_0=0;

nc_1=0;

nc_2=0;

for i=1:m

    for j=1:n

        nc_0=nc_0+g_mark(i,j)*o_mark(i,j);

        nc_1=nc_1+o_mark(i,j)*o_mark(i,j);

        nc_2=nc_2+g_mark(i,j)*g_mark(i,j);

    end

end

NC=nc_0/sqrt(nc_1*nc_2);

%%%%%% 显示提取水印 %%%%%%%%

subplot(2,3,5),imshow(''),title(‘原始水印图像’);

subplot(2,3,6),imshow(tmark_1,[]);

name=‘提取得水印图像’;

title(strcat(num2str(name),'NC=',num2str(NC)));

附录B(基于FFT域的数字水印算法程序)

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%% 嵌入水印算法 %%%%%%%%%%%%%%

clear all; 

clc;

%%%%%% 读取水印图象 %%%%%%% 

omark=double(imread(''))/255;

mo=size(omark,1);

no=size(omark,2);

%%%%% 以下生成水印信息 %%%%%%

mark=omark;

alpha=200;

R1=randn(1,8);

rand1=round(R1);

R2=randn(1,8);

rand2=round(R2);

%%%%%%% 读取宿主图像 %%%%%%%

cimage=imread('');

figure(1);

subplot(2,3,1),imshow(cimage,[]),title('原始的宿主图像');

[mc,nc]=size(cimage);

cimage=double(cimage);

fft0=blkproc(cimage,[8,8],'fft2');

%%%%%%% 嵌入水印 %%%%%%%%%

fft_abs=abs(fft0);

fft_angle=angle(fft0);

fft1=fft_abs;

for ii=1:mo 

    for jj=1:no 

        x=(ii-1)*8;y=(jj-1)*8;

        if mark(ii,jj)==1

        k=rand1;

        else

        k=rand2; 

        end

    fft1(x+1,y+8)=fft_abs(x+1,y+8)+alpha*k(1);

    fft1(x+2,y+7)=fft_abs(x+2,y+7)+alpha*k(2);

    fft1(x+3,y+6)=fft_abs(x+3,y+6)+alpha*k(3);

    fft1(x+4,y+5)=fft_abs(x+4,y+5)+alpha*k(4);

    fft1(x+5,y+4)=fft_abs(x+5,y+4)+alpha*k(5);

    fft1(x+6,y+3)=fft_abs(x+6,y+3)+alpha*k(6);

    fft1(x+7,y+2)=fft_abs(x+7,y+2)+alpha*k(7);

    fft1(x+8,y+1)=fft_abs(x+8,y+1)+alpha*k(8);

    end

end

fft_abs_0=fft1;

fft_abs_1=(fft_abs_0.*exp(i*fft_angle));

wimage_0=blkproc(fft_abs_1,[8,8],'ifft2');

wimage=abs(wimage_0);

%%%%%% 显示嵌入水印图象 %%%%%

wimage_1=uint8(wimage);

imwrite(wimage_1,'','bmp');

subplot(2,3,2),imshow(wimage,[]),title('嵌入水印后的图象');

%%%%%%%%%%%%% 进行各种攻击 %%%%%%%%%%%%

disp('1-->加入白噪声');

disp('2-->高斯低通滤波');

disp('3-->剪切图像');

disp('4-->旋转图象');

disp('5-->直接检测');

begin=input('请选择攻击(1-5)');

switch  begin

%%%%%%%%加入白噪声%%%%%%%%

    case 1

Aimage1=wimage;

Wnoise=12*randn(size(Aimage1));

Aimage1=Aimage1+Wnoise;

subplot(2,3,4),imshow(Aimage1,[]),title('加入白噪声后的图象');

att=Aimage1;

imwrite(att,'');

%%%%%% 高斯低通滤波 %%%%%%%%

    case 2

Aimage2=wimage;

H=fspecial('gaussian',[4,4],;

Aimage2=imfilter(Aimage2,H);

subplot(2,3,4),imshow(Aimage2,[]),title('高斯低通滤波后的图象');

att=Aimage2;

imwrite(att,'')

%%%%%%% 剪切攻击 %%%%%%%%%

    case 3

Aimage3=wimage;

Aimage3(1:128,1:128)=256;

subplot(2,3,4),imshow(Aimage3,[]),title('剪切后的图象');

att=Aimage3;

imwrite(att,'');

%%%%%%% 旋转攻击 %%%%%%%%%

    case 4

Aimage4=wimage;

Aimage4=imrotate(Aimage4,10,'bilinear','crop');

Aimage_4=mat2gray(Aimage4);

subplot(2,3,4),imshow(Aimage_4,[]),title('旋转10度后的图象');

att=Aimage_4;

imwrite(att,'');

%%%%%%% 没有受到攻击 %%%%%%%

    case 5

subplot(2,3,4),imshow(wimage,[]),title('直接提取的图象');

att=wimage;

imwrite(att,'');

end

%%%%%%%%%%%%%%% 提取水印 %%%%%%%%%%%%%

tmark_0=att;

tmark_0=blkproc(tmark_0,[8,8],'fft2');

tmark_0=abs(tmark_0);

pass=zeros(1,8);

for ii=1:mo

    for jj=1:no

        x=(ii-1)*8;y=(jj-1)*8;

        pass(1)=tmark_0(x+1,y+8);

        pass(2)=tmark_0(x+2,y+7);

        pass(3)=tmark_0(x+3,y+6);

        pass(4)=tmark_0(x+4,y+5);

        pass(5)=tmark_0(x+5,y+4);

        pass(6)=tmark_0(x+6,y+3);

        pass(7)=tmark_0(x+7,y+2);

        pass(8)=tmark_0(x+8,y+1);

if (corr2(pass,rand1)>corr2(pass,rand2))

             tmark_1(ii,jj)=1;

        else

             tmark_1(ii,jj)=0;

        end

    end

end

%%%%%%%%%% 计算NC(归一化相关系数)%%%%%%%%

g_mark=double(tmark_1);

o_mark=double(omark);

[m,n]=size(g_mark);

nc_0=0;

nc_1=0;

nc_2=0;

for ii=1:m

    for jj=1:n

        nc_0=nc_0+g_mark(ii,jj)*o_mark(ii,jj);

        nc_1=nc_1+o_mark(ii,jj)*o_mark(ii,jj);

        nc_2=nc_2+g_mark(ii,jj)*g_mark(ii,jj);

    end

end

NC=nc_0/sqrt(nc_1*nc_2);

%%%%%% 显示提取水印图象 %%%%%

subplot(2,3,5),imshow(''),title('原始水印图象');

subplot(2,3,6),imshow(tmark_1,[]);

name='提取的水印图像';

title(strcat(num2str(name),'NC=',num2str(NC)));

文档

MATLAB制作数字水印

1.数字水印背景二十一世纪是数字时代,通信技术的迅速发展和计算机网络的普遍运用,使人们可以通过互联网收发信息,可以随时上传自己创作的数字图象、音乐、视频等作品,可以进行学术交流。然而,也正是由于网络的这种便捷性、传播迅速的优点使其很容易被非法拷贝,导致数字产品的版权、完整性、有效性得不到保证,严重损害了创作者的利益。而一些具有特殊意义的数字信息,如涉及司法诉讼、机要等信息,更是遭到了不法分子地恶意攻击和随意篡改等,这一系列问题给当今科学家带来了巨大挑战。基于以上类似问题,数字水印技术可以说
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top