第35卷(2007)第8期 计算机与数字工程 109
基于DCT变换的图像数字水印算法4 徐世刚1’李娟1’
胡广2’(武汉科技大学电子信息工程系1’武汉430081)(华中科技大学电子信息工程系2’
武汉430074)
摘要数字水印技术在保护数据信息安全和版权方面有着重要的应用。对基本DcT域图像数字水印算法进行改进,该算法采用可视的二值图像作为水印信息,利用人类视觉系统(HVs)的冗余特性,将图像块进行分类,并结合边缘检测
和Amold型置乱变换加密,通过在图像块DcT域中修改低频区Dc分量来嵌入不同强度的水印。实验结果表明,该算法生成的水印是不可见的,并且对常见的图像处理和噪声干扰具有较好的鲁棒性。
关键词
数字水印边缘检测 图像置乱Amold变换 中图分类号TP391 1
数字水印概述
变换域图像的大部分能量集中在低频部分,DcT变换后低频系数值较大,而高频系数值较小。数字水印技术是一种将特制的不可见的标记,
人眼对于DcT域低频区敏感,对于高频区则不十利用数字内嵌的方法隐藏在数字图像、声音、文档、分敏感。如果要获得很好的稳健性,数字水印应加图书、视频等数字产品中,用以证明原始作者对其在低频部分,但是这样引起的图像降质较大,无法作品的所有权,并作为鉴定、起诉非法侵权的证据,保证视觉透明性。为了避开这一矛盾,很多文献中同时通过对水印的检测和分析,验证数字信息的完将水印嵌入选在图像的中频部分,从而在视觉透明整可靠性,从而成为知识产权保护和数字多媒体防性和稳健性之间进行折衷。
伪的有效手段。一般认为数字水印应具有安全性黄继武…等人在对DcT系数Dc和Ac分量(可证明性)、隐形性(不可感知性)、稳健性(鲁棒
的定性和定量分析的基础上,指出Dc分量有更大性)和自恢复性等特点。具有上述特点的水印才
的视觉容量,比Ac分量适合嵌入水印,而且Dc分是严格意义上的数字水印,但由于对数字水印的定义尚未统一,许多文献中讨论的数字水印并不具备量的水印具有更好的稳健性。本文采用将水印信上述特点,或者仅具有上述的部分特点。由于数字息嵌入到DCT变换后低频区的DC分量上,即选择图像比声音、文字等蕴涵更多的信息量,因而现今每个DcT块左上角的一个点作为嵌入位置。
对数字水印的研究,大多数都是针对图像进行的。 3
水印信息置乱加密与解密 2水印嵌入、提取位置的选择
置乱技术怛。是随着信息安全与保密被日益重
早期的基于DcT变换的水印算法是把水印嵌视而发展起来的图像加密技术。目前,常用的技术
入到频域的高频系数中,因为原始图像经过DcT主要有以下几种:Amold变换po、幻方、Hilbert曲
变换后,大部分信息集中在低频部分,因此可以将线、conway游戏、Gmy变换等。将置乱技术应用于水印嵌入含信息量少的高频部分,以尽量减少对原水印系统,是通过置乱变换尽可能地分散错误比特始图像的影响。这样能保证视觉透明性,但是,各的分布,以提高数字水印的视觉效果,增强数字水种常见的图像处理操作对于图像高频部分的损坏印的鲁棒性。
可能性很大,如有损压缩、低通滤波等,水印很容易设原图像I为N×M大小,假定像素位置为在经历图像处理的过程中损失,故这类算法所产生
(名,y),按几何变换置乱后的像素位置为(石’,戈’),的水印稳健性很差。
则几何变换的置乱方法如公式(1)所示: +收到本文时间:2006年4月2日
作者简介:徐世刚,男,本科生。李娟,女,硕士,助教,研究方向:图像处理与模式识别。胡广,男,博士研究生,讲师,
研究方向:图像处理与模式识别。 万 方数据 110
徐世刚等:基于DCT变换的图像数字水印算法第35卷
其中,A中元素均为整数,当A取l::l时,就为‘\lz, 著名的Amold变换。在一定条件下,Amold型置 乱变换具有周期性。
本文采用Amold变换的数字图像置乱技术。将数字水印图像视为一个矩阵,则经过Amold变换后的图像会变得混乱不堪,但继续使用Amold变换,一定会出现原始图像。在嵌入水印信息时,利用密钥来控制水印信息置乱次数,对水印信息加密。在水印提取时,只有通过正确的密钥才能解密得到水印信息,即使攻击者知道嵌入算法,提取的也只是一堆毫无意义的乱码。此外,可以随机控制水印图像信息嵌入前变换的次数。
4
边缘检测加重水印嵌入强度
边缘检测M1方法试图通过检测不同区域间的
边缘来解决水印嵌入强度的问题。常用的微分算子有梯度算子(如Robert算子、Prewitt算子、sobel算子)、方向算子(如Kirsch算子)、拉普拉斯算子、马尔算子、综合正交算子、坎尼算子和沈俊算子等。本文考虑人眼视觉对边缘变化激烈处的不敏感特性和边缘检测技术的特征,结合边缘检测对图像进行处理。将原始图像进行分块DcT变换后,在嵌入水印的同时对各块做边缘检测,对处于边缘地带的分块加重水印嵌入的强度。在提取水印时,根据各块的边缘检测选择不同的提取系数提取水印信息。本文选用sobel算子对图像求边缘,S0bel算子利用像素的上、下、左、右邻域的灰度加权算法,根据在边缘点处达到极值这一原理进行边缘检测。该方法不但能产生较好的检测效果,而且对噪声具有平滑作用,可以提供较为精确的边缘方向信息。
5
水印算法流程
5.1水印的嵌入
设,是大小为M×Ⅳ的原始图像,‘,是大小为
P×Q的水印图像,M和Ⅳ分别是P和Q的偶数倍。把水印信息l,加载到原始图像,中,算法分以
下步骤进行:
(1)对原始图像,分块,将,分解为(∥8)× (Ⅳ/8)个大小为譬笋×坠笋的子块,每个分块互 不重叠;同时,对经过A瑚纪变换置乱技术加密的 水印图像进行分块,分解为个大小为的方块;如果 万
方数据嵌入的水印信息比较少,可以多次嵌入水印信息以 达到加强水印鲁棒性的效果。
(2)对原始图像的每个子块进行二维DCT变换。(3)对每一个DCT变换后的子块,根据公式(2)嵌入水印:
E=K(1+oⅨi) (2)
其中,K是原始图像的Dc丁系数,y’i是嵌入水印后图像的DcT系数,置是与原始图像块号相同经过加密后的水印图像信息,理是水印嵌入强度。
(4)对嵌入水印后的每个DcT系数块进行IDCT变换,重建图像,得到嵌入水印后的图像。