信息隐藏技术课件第三章图像信息隐藏与水印.
- 格式:ppt
- 大小:317.00 KB
- 文档页数:68
信息隐藏技术第三章隐写与隐写分析隐写术是一种信息隐藏技术,它通过在其他媒介中嵌入、存储或传输秘密信息,使其对外不可见或不易被察觉。
隐写术分为多种类型,其中隐写和隐写分析是其中两个重要方面。
隐写是指通过各种手段将秘密信息嵌入到另一种媒介中,使得只有特定的接受者能够探测到并提取出这些信息。
常见的隐写技术包括文本隐写、图像隐写、音频隐写和视频隐写等。
这些技术广泛应用于情报、网络安全和数字水印等领域。
文本隐写是将秘密信息隐藏在文本中的一种技术。
其中一种常见的方法是通过改变文本的字体、大小、颜色或字符间距等细小变化来隐藏信息。
另一种方法是通过在文本中的无关词汇或标点符号中嵌入秘密信息。
这些方法不会改变原始文本的外观,仅有经过特定处理的接收方能够提取出隐藏的信息。
图像隐写是将秘密信息隐藏在数字图像中的一种技术。
常见的图像隐写方法包括使用最低有效位(LSB)算法和改变像素间关系等方法。
在LSB算法中,秘密信息被嵌入到图像像素的最低有效位中,从而不会引起明显的视觉变化。
改变像素间关系的方法则通过微调图像的RGB值,来隐藏秘密信息。
音频隐写是将秘密信息隐藏在数字音频中的一种技术。
常见的音频隐写方法包括频域隐写和时域隐写。
在频域隐写中,秘密信息会嵌入到音频信号的频域中,例如改变频率或幅度。
而在时域隐写中,隐藏信息会直接嵌入到音频的波形中,例如改变采样率或声音强度。
视频隐写是将秘密信息隐藏在数字视频中的一种技术。
常见的视频隐写方法包括使用帧间差异、改变像素值和时间域隐写等方法。
在帧间差异方法中,秘密信息会嵌入到相邻帧之间的差异中,这样即使在视频中提取单个帧也无法获得完整的秘密信息。
隐写分析是指研究和识别隐写技术的过程。
通过隐写分析,人们可以检测出隐藏在媒介中的秘密信息,并且识别出使用的隐写技术。
隐写分析技术有三种主要方法,分别是统计分析、视觉分析和机器学习。
统计分析是通过特定的统计方法来分析媒介中的数据,从而检测是否存在隐藏的秘密信息。
实验三:LSB图像信息隐藏一、实验目的了解信息隐藏中最常用的LSB算法的特点,掌握LSB算法原理,设计并实现一种基于图像的LSB隐藏算法;了解如何通过峰值信噪比来对图像进行客观评价,并计算峰值信噪比值。
二、实验环境(1)Windows 7操作系统;(2)MATLAB R2012b版本软件;(3)BMP格式灰度图像文件。
三、原理简介任何多媒体信息在数字化时都会产生物理随机噪声,而人的感官系统对这些随机噪声并不敏感。
替换技术就是利用这个原理,通过使用秘密信息比特替换随机噪声,从而实现信息隐藏目的。
在BMP灰度图像的位平面中,每个像素值为8比特二进制,表示该点亮度。
图像高位平面对图像感官质量起主要作用,去除图像最低几个位平面并不会造成画面质量的明显下降。
利用这个原理可用秘密信息(或称水印信息)替代载体图像低位平面以实现信息嵌入。
本算法选用最低位平面来嵌入秘密信息。
最低位平面对图像的视觉效果影响最轻微,但很容易受噪声影响和攻击,可采用冗余嵌入的方式来增强稳健性加以解决,即在一个区域(多个像素)中嵌入相同的信息,提取时根据该区域中的所有像素判断。
四、实验步骤1. 隐藏提取及测试算法分为三个部分实现:(1)隐藏算法;(2)提取算法;(3)测试脚本。
1)隐藏算法源代码hide_lis.m如下:function o = hide_lsb(block,data,I)%function o = hide_lsb(block,data,I)%隐藏提取及测试%block:隐藏的最小分块大小%data:秘密信息%I:原始载体si = size(I);lend = length(data);N = floor(si(2)/block(2));%将图像划分为M*N个小块M = min(floor(si(1)/block(1)),ceil(lend/N));o = I;for i = 0 : M-1 %计算每小块隐藏的秘密信息rst = i*block(1) + 1;red = (i+1)*block(1);for j = 0 : N-1 %计算每小块隐藏的秘密信息的序号idx = i*N + j + 1;if idx > lendbreak;end%取每小块隐藏的秘密信息bit = data(idx);%计算每小块水平方向起止位置cst = j*block(2) + 1;ced = (j+1)*block(2);%将每小块最低位平面替换为秘密信息o(rst:red,cst:ced) = bitset(o(rst:red,cst:ced),1,bit);endend2)提取算法源代码dh_lsb.m如下:function out = dh_lsb(block,I)%function out = dh_lsb(block,I)%源代码dh_lsb.m如下:%block:隐藏的最小分块大小%I:携密载体si = size(I);%将图像划分为M*N个小块N = floor(si(2)/block(2));M = floor(si(1)/block(2));out = [];%计算比特1判决阀值:每小块半数以上元素隐藏是比特1时,判决该小块嵌入信息为1thr = ceil((block(1)*block(2) + 1)/2);idx = 0;for i = 0 : M-1%计算每小块垂直方向起止位置rst = i*block(1) + 1;red = (i+1)*block(1);for j = 0 : N-1%计算每小块将要数据的秘密信息的序号idx = i*N + j + 1;%计算每小块水平方向起止位置cst = j*block(2) + 1;ced = (j + 1)*block(2);%提取小块最低位平面,统计1比特个数,判决输出秘密信息 tmp = sum(sum(bitget(I(rst : red,cst : ced),1)));if (tmp >= thr)out(idx) = 1;elseout(idx) = 0;endendend3)测试脚本源代码test.m如下:fid = 1;len = 10;%随机生成要隐藏的秘密信息d = randsrc(1,len,[0 1]);block = [3,3];[fn,pn] = uigetfile({'* .bmp','bmp file(* .bmp)';},'选择载体');s = imread(strcat(pn,fn));ss = size(s);if (length(ss) >= 3)I = rgb2gray(s);elseI = s;endsi = size(I);sN = floor(si(1)/block(1))*floor(si(2)/block(2));tN = length(d);%如果载体图像尺寸不足以隐藏秘密信息,则在垂直方向上复制填充图像if sN < tNmultiple = ceil(tN/sN);tmp = [];for i = 1 : multipletmp = [tmp;I];endI = tmp;end%调用隐藏算法,把携密载体写至硬盘stegoed = hide_lsb(block,d,I);imwrite(stegoed,'hide.bmp','bmp');[fn,pn] = uigetfile({'*.bmp','bmp file(*.bmp)';},'选择隐蔽载体');y = imread(strcat(pn,fn));sy = size(y);if (length(sy) > 3)I = rgb2gray(y);elseI=y;end%调用提取算法,获得秘密信息out = dh_lsb(block,I);%计算误码率len = min(length(d),length(out));rate = sum(abs(out(1:len)-d(1:len)))/len;y = 1 - rate;fprintf(fid,'LSB:len:% d\t error rate:% f\t error num:% d\n',len,rate,len*rate);2. 计算峰值信噪比(1)峰值信噪比定义:2,2,,,,max ()x y x y x y x yx y p PSNR XY p p =-∑(2)峰值信噪比函数。
信息隐藏与数字水印实验教程课程设计课程设计简介信息隐藏和数字水印是一类在数字媒体内容中嵌入一些“隐蔽”的信息的可逆技术,其中信息隐藏以隐藏为目标,数字水印以鉴别为目标。
本课程设计是一款针对信息隐藏和数字水印技术的实验教程,旨在让学生了解信息隐藏和数字水印的基本概念、算法流程及实验操作。
实验教程实验1:LSB信息隐藏LSB信息隐藏是一种较为简单的信息隐藏技术,利用了图像或音频信号中的最低有效位(LSB)来储存信息。
本实验将让学生了解LSB信息隐藏的基本思路和实现流程。
实验步骤:1.安装Python编程环境和必要的库(numpy、pillow等);2.编写Python代码实现将信息隐藏到图像中的最低有效位;3.对图像进行解密,将隐藏的信息提取出来并显示。
实验要求:1.能够了解LSB信息隐藏的原理;2.能够独立完成Python代码的编写和调试;3.能够对嵌入信息后的图像进行正确解密。
实验2:DCT数字水印DCT数字水印是一种在频域中实现数字水印嵌入到图像或视频信号中的可逆算法,其中DCT(离散余弦变换)是一种常见的频域转换方式。
本实验将让学生了解DCT数字水印的基本原理和实现方法。
实验步骤:1.安装MATLAB编程环境和必要的工具箱(image processing等);2.编写MATLAB代码实现将数字水印嵌入图像中的DCT系数;3.对嵌入数字水印后的图像进行攻击,如JPEG压缩、调整亮度等;4.对加入攻击后的图像进行解密,将数字水印提取出来并验证。
实验要求:1.能够了解DCT数字水印的基本原理;2.能够独立完成MATLAB代码的编写和调试;3.能够对加入攻击后的图像进行正确解密和验证。
实验结论通过本次课程设计,学生能够了解信息隐藏和数字水印的基本概念,并通过实验了解LSB信息隐藏和DCT数字水印的基本算法和实现方式。
同时,学生也能够了解到数字水印的鲁棒性和对攻击的抵抗能力,以及对数字媒体内容可信度的提升。