3.1 图像数字水印的技术方案

在数据库中存储在国际互联网上传输的水印图像一般会被压缩,有时达到很高的压缩比。因此,数字水印算法所面临的第一个考验就是压缩。JPEG和EZW(Embedded Zero-Tree Wavelet)压缩是最常见的两种压缩方法。JPEG是基于离散余弦变换域的压缩方法,而EZW是基于小波变换域的压缩方法。前人的研究证明采用与压缩算法相同的变换域水印方法,对于压缩的稳健性较强。因此,我研究图像文件水印算法主要集中在变换域算法及利用人眼视觉特性上。

数字水印的嵌入要求即要考虑视觉透明性,又要保证嵌入水印后图像的稳健性,这两个方面存在着矛盾。保证视觉透明性,就要将水印嵌入到人眼不敏感区,也就是嵌入到图像的高频分量中。而多数图像处理方法对于图像高频部分的损坏程度较高,如有损压缩、高频滤波等。水印很容易在经历图像处理的过程中丢失。这样,则无法保证图像数字水印的稳健性。如果要获得很好的稳健性,数字水印应加在人眼敏感的低频部分,图像的大部分能量集中在低频部分,如果对于低频部分进行处理,水印固然会失去,而图像也没有了利用价值,然而,水印的嵌入会对图像的质量有非常大的影响,这又无法保证视觉透明性。

数字水印算法的实现基本分为三个部分:宿主图像的变换,水印的嵌入和水印的检测,分别描述如下。

3.2 基于DCT域的图像数字水印技术

离散余弦变换(Discrete Cosine Transform)属于正交变换图像编码方法中的一种。正交变换图像编码始于1968年。当时安德鲁斯(Andrews)等人发现大多数自然图像的高频分量相对幅度较低,可完全舍弃或者只用少数码字编码,提出不对图像本身编码,只对其二维傅立叶(DFT)系数进行编码和传输。但DFT是一种正交变换,运算量很大,常常使实时处理发生困难,第二年他们就用Walsh-Hadamard变换(WHT)取代DFT可以使运算量明显减少,这是因为WHT变换只有加减法而无需乘法。但是更有意义的是离散余弦变换和离散正旋变换的出现,它们具有快速算法,精确度高。其中最重要的是1974年提出的DCT,因为其变换矩阵的基向量很近似于托伯利兹矩阵的特征向量,而托伯利兹矩阵又体现了人类语言及图像信号的相关性。因此,DCT常常被认为是语音与图像信号变换的准最佳变换。

图像是二维的,所以在研究时主要用到二维DCT,以及二维IDCT来对图像进行处理。

3.2.1 离散余弦变换(DCT)的定义

数字图像X(m,n)是具有M行N列的一个矩阵。为了同时减弱或去除图像数据相关性,可以运用二维DCT,将图像从空间域转换到DCT变换域。

根据定义,二维离散余弦变换(DCT)定义如下:

v2-e74622930a73a62fcb9c9f5c1b426746_b.jpg
v2-5d7ed632adb87d868391c2625a9bc95b_b.jpg

式中:m,k=0,1,…,M-1; n,

v2-5d7ed632adb87d868391c2625a9bc95b_b.jpg
v2-940bfcb2cf7117d7edcccc587ecef0d5_b.jpg

=0,1,…,N-1。

v2-829da5545441a49d32be0433c395bd3e_b.jpg
v2-ad61a861db9705f26d467e7f860fa5d6_b.jpg

二维逆离散余弦变换(IDCT)的定义如下:

v2-f291d52a3b25c2ba3607238bc60c4314_b.jpg

式中:m,k=0,1,…,M-1; n,

v2-e2c011912f8d3b5c247f591fc21a93fa_b.jpg

=0,1,…N-1。

3.2.2 离散余弦变换的特点

在基于DCT的变换编码中,图像是先经分块(8×8或16×16)后再经DCT,这种变换是局部的,只反映了图像某一部分的信息。当然也可以对整幅图像的特点,但是运算速度比分块DCT要慢。图像经DCT后,得到的DCT图像有三个特点:

一是系数值全部集中到0值附近(从直方图统计的意义上),动态范围很小,这说明用较小的量化比特数即可表示DCT系数;

二是DCT变换后图像能量集中在图像的低频部分,即DCT图像中不为零的系数大部分集中在一起(左上角),因此编码效率很高。

三是没有保留原图像块的精细结构,从中反映不了原图像块的边缘、轮廓等信息,这一特点是由DCT缺乏时局域性造成的。

如下左图3—1是原始图像经过DCT变换后的系数图像为图3—2。两条线划分出图像的低频、中频和高频分别所在的矩形区域。可以看出,图像DCT变换后大部分参数接近于零,只有左上角的低频部分有较大的数值,中频部分参数值相对较小,而大部分高频参数值非常小,接近于零。

图 3—1:原图像 图 3—2:变换后的系数图像

3.2.3 离散余弦变换的数字水印算法

根据离散余弦变换后的参数性质,本文采用了以ZigZag方式重排变换域系数的方法,选出中频分量,用数字水印序列对其进行非线性调制。水印检测时,待检测图像仍按比方式选择变换域系数,与待水印进行相关运算,与阈值比较来判断是否所含水印。

离散余弦域的数字水印算法的具体实现分为三步:宿主图像的变换,数字水印的嵌入,数字水印的检测。

3.2.3.1 宿主图像的DCT变换

对于N×N大小的256灰度级的宿主图像I进行N×N二维离散余弦变换(DCT)。以ZigZag方式对于DCT变换后的图像频率系数重新排列成一维向量Y={y1, y2,…yN×N}.

并取出序列中第L+1到L+M的中频系数部分,得到YL={ YL+1, YL+2,…, YL+M}

3.2.3.2 数字水印的嵌入

假设数字水印W为一服从标准正态分布的随机实数序列,用数字序列表示为W={W1 ,W2 ,…WM }。用W对Y序列中第L+1到L+M的中频系数部分的值进行修改,按以下公式进行:

v2-b9652c976e5407e47a47fe63b9b6cdd3_b.jpg

经过修改的系数序列Y′ ={ Y1′, Y2′,... Y′N×N} 以ZigZag逆变换形式重组,再进行N×N DCT逆变换,得到嵌有数字水印的图像I′。

3.2.3.3 数字水印的检测

待检测的可能含有水印的图像I" 。假设I"未损失大量信息,可以近似认为I"= I′。在此假设下可以运用统计的方法来检测水印。

(1)待检水印域待检图像中频系数相关性的测定

同样对I′进行DCT变换,以ZigZag方式将DCT系数排成一维向量Y "= { Y1 ", Y2 ",... YN×N"}。由于假设I"=I′,则Y"= Y ′。

取出Y"(等于Y′)中第L+1到L+M的中频系数部分YL "={ YL+1 ", YL+2"’,... YL+M"}。假设待检测的数字水印X={X1,X2,... XM}为一符合标准正态分布的实数伪随机序列。则可以通过待检水印与图像中频系数作相关运算来判断是否所加入了水印。只有在待检水印为所加入的水印时,才能得到较大的相关值。否则相关值很小,接近于零。

v2-aa74dbd8262dc9cc91358f3bc92919f2_b.jpg

用符号E表示数学期望,得到:

v2-24028f467f8fb14295d9baa1c795ac34_b.jpg

(2)阈值的确定

根据中心极限定理,参照水印匹配与不匹配两种情况得到阈值为

v2-ef6461568334a11e78db4619298fc63e_b.jpg

。由于原始图像难以得到,因此从实用性出发,阈值定义为:

v2-cc1aebc0deba328ee5b2f982c22a0e17_b.jpg

综上所述,满足

v2-591dcd9355579c0bd30d890ddcda61ee_b.jpg

时,则表明检测到匹配水印。否则,未检测到匹配的水印。

3.3 MATLAB工具简介

3.3.1. 简介

Matlab是当前在国内外十分流行的工程设计和系统仿真软件包。它是MathWorks公司于1982年推出的一套高性能的数值计算和可视化软件,它集数值分析、矩阵运算、信号处理和图形显示于一体,构成了一人方便的、界面友好的用户环境。

Matlab的推出得到了各个领域专家、学者的广泛关注,其强大的扩展功能为各个领域的应用提供了基础。由各个专家学者相继推出了MATLAB工具箱,其中的信号处理(signal processing)、控制系统(control system)、神经网络(neural network)、图像处理(image processing)、鲁棒控制(robust control)、非线性系统控制设计(nonlinear system control design)、系统辨识(system identification)、最优化(optimization)、模糊逻辑(fuzzy logic)、小波(wavelet)、通信(communication)、统计(statistics)等工具箱,这些工具箱给各个领域的研究和工程应用提供了有力的工具,借助于这些“巨人肩上的工具”,各个层次的研究人员可直观、方便地进行分析、计算及设计工作,从而大大地节省了时间。

3.3.2. MATLAB研究数字水印的优点

  1. 集成了DCT、DWT等函数有丰富的小波函数和处理函数,这不仅方便了研究人员,而且使源程序简洁明了、易实现。
  2. 强大的数学运算功能。能够方便、高效地实现音频、视频中的大量矩阵运算。
  3. 提供了图像处理工具箱、小波分析工具箱、数字信号处理工具箱。用来编制跨数字图像处理技术、数字信号处理等多学科的数字水印技术是非常好的选择。
  4. MATLAB与目前最强大的编程工具——Visual C++具有良好的接口。

3.3.3. MATLAB函数介绍

在介绍函数之前,我们必须明确一点:作水印程序时,处理的图像数据是二维信号,而声音信号是一维信号。这里,我们仅仅简单介绍与水印有关的函数。

  1. 数据输入输出函数

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

auread()、auwrite()、wavread()和wavwrite():可以方便地读写au和wav文件,并可控制其中的位及频率。

② 图像显示

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

③ 变换频函数

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

  • 离散余弦变换(DCT)

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

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

  • 离散小波变换(DWT)

dwt(),dwt2():分别实现一维信号和二维信号的DWT(离散小波变换)

idwt(),idwt2():分别实现一维信号和二维信号的IDWT(离散小波变换);

Wavedec2():多级二维小波分解函数;

Waveinfo():提供小波包中所有的小波信息;

④攻击函数

对算法进行攻击测试是对水印鲁棒性检测的一种重要手段,一个好的水印算法必须经过各种攻击测试才能对之做出客观的评价。MATLAB中的许多函数可以直接用来做攻击测试。

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

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

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

抖动:dither()对图像进行抖动;抖动攻击考验水印鲁棒性的一个很好的攻击;

jpeg压缩:imwrite()中jpg和quality参数能对图像进行可控jpg压缩;

加各种噪声:imnoise()可以对图像加入各种噪声,如白噪声、椒盐噪声等,加入噪声是对水印鲁棒性考验的一种常见的攻击;

放大/缩小:imresize()可以以指定的插值方法来对图像进行放大和缩小。

第四章: 图像数字水印技术的实现

4.1 基于离散余弦变法(DCT)实现数字水印技术

① 打开原始及水印图像

subplot(2,2,1)

I=uigetfile('*.bmp','打开原始彩色图像文件');

RGB=imread(I);

image(RGB);

title('原始彩色图像');

subplot(2,2,2)

I=uigetfile('*.bmp','打开水印灰度图像文件');

imshow(I);

title('灰度水印图像');

subplot(2,2,3)

H=imread(I);

J=dct2(H);

imshow(log(abs(J)),[]),colorbar;

title('水印图像经DCT变换后能量分布情况')

运行结果:

② 水印全过程:

0%水印加入程序

Q=input('请输入放缩因子的值(建议小于1):Q=')

subplot(2,3,1)

RGB=imread('浙江台州学院','jpg');

imshow(RGB);

title('原始图像');

subplot(2,3,2)

N=dct2(RGB(:,:,3));

imshow(log(abs(N)),[]),colorbar;

title('Y分量能量分布');

subplot(2,3,4)

I=imread('lena1','bmp');

imshow(I);

title('灰度水印图像');

subplot(2,3,5)

M=dct2(I);

imshow(log(abs(M)),[]),colorbar;

title('水印能量分布');

subplot(2,3,6)

J=M(1:128,1:128);

J(128:364,128:400)=0;

J=rot90(J);

J=rot90(J);

J(365:600,401:750)=0;

J=rot90(J);

J=rot90(J);

N=N+Q*J;

K=idct2(N);

RGB(:,:,3)=K;

imshow(RGB);

title('加入水印后图像');

%水印提取程序

subplot(2,3,3)

RGB1=imread('浙江台州学院','jpg');

N=dct2(RGB(:,:,3));

M=dct2(RGB1(:,:,3));

M=(N-M)/Q;

B=idct2(M(236:365,350:401));

Y=mat2gray(B);

imshow(Y);

title('提取的水印图像')

运行结果:

③ 水印全过程(经剪切检测水印)

%水印加入程序

Q=input('请输入放缩因子的值(建议小于1):Q=')

subplot(3,3,1)

RGB=imread('MM','jpg');

imshow(RGB);

title('原始图像');

subplot(3,3,2)

imshow(RGB(:,:,3));

title('B分量');

subplot(3,3,3)

N=dct2(RGB(:,:,3));

imshow(log(abs(N)),[]),colorbar;

title('B分量能量分布');

subplot(3,3,4)

I=imread('lena1','bmp');

imshow(I);

title('灰度水印图像');

subplot(3,3,5)

M=dct2(I);

imshow(log(abs(M)),[]),colorbar;

title('水印能量分布');

subplot(3,3,7)

J=M(1:128,1:128);

J(128:464,128:364)=0;

J=rot90(J);

J=rot90(J);

J(465:800,365:600)=0;

J=rot90(J);

J=rot90(J);

N=N+Q*J;

K=idct2(N);

RGB(:,:,3)=K;

imshow(RGB);

title('加入水印后图像');

subplot(3,3,8)

I=imcrop(RGB,[1 1 598 798]);

imshow(I);

subplot(3,3,9)

%水印提取程序

subplot(3,3,6)

RGB1=imread('MM','jpg');

J=RGB1(:,:,3);

X=J(1:799,1:599);

N=dct2(I(:,:,3));

M=dct2(X);

M=(N-M)/Q;

B=idct2(M(337:464,237:364));

Y=mat2gray(B);

imshow(Y);

title('经放缩后提取的水印图像')

运行结果:

④ 水印全过程(经空域压缩检测水印)

程序源代码

%水印加入程序

Q=input('请输入放缩因子的值(建议小于1):Q=')

P=input('请输入您所希望的图像放缩系数值(建议取值不要小于0.5):P=')

subplot(3,3,1)

RGB=imread('浙江台州学院','jpg');

imshow(RGB);

title('原始图像');

subplot(3,3,2)

imshow(RGB(:,:,3));

title('B分量');

subplot(3,3,3)

N=dct2(RGB(:,:,3));

imshow(log(abs(N)),[]),colorbar;

title('B分量能量分布');

subplot(3,3,4)

I=imread('lena1','bmp');

imshow(I);

title('灰度水印图像');

subplot(3,3,5)

M=dct2(I);

imshow(log(abs(M)),[]),colorbar;

title('水印能量分布');

subplot(3,3,7)

J=M(1:128,1:128);

J(128:364,128:400)=0;

J=rot90(J);

J=rot90(J);

J(365:600,401:750)=0;

J=rot90(J);

J=rot90(J);

N=N+Q*J;

K=idct2(N);

RGB(:,:,3)=K;

imshow(RGB);

title('加入水印后图像');

subplot(3,3,8)

I=imresize(RGB,P,'nearest');

imshow(I);

title('压缩P倍图像');

subplot(3,3,9)

J=imresize(I,1/P,'nearest');

imshow(J);

title('再放大P倍还原图像')

%水印提取程序

subplot(3,3,6)

RGB1=imread('浙江台州学院','jpg');

N=dct2(J(:,:,3));

M=dct2(RGB1(:,:,3));

M=(N-M)/Q;

B=idct2(M(236:365,350:401));

Y=mat2gray(B);

imshow(Y);

title('经放缩后提取的水印图像'):

运行结果:

4.2 图像水印的dwt算法

%以下是水印提取算法

clear all;

clc;

%保存时间

start_time=cputime;

figure(1);

%读出原始图像

subplot(1,2,1);

input=imread('2.jpg');

imshow(input);

title('原始图像');

%读出水印图像

subplot(1,2,2);

watermarked_image=imread('watermarked.bmp');

imshow(watermarked_image,[]);

title('水印图像');

%三色分离

input=double(input);

watermarked_image=double(watermarked_image);

inputr=input(:,:,1);

watermarked_imager=watermarked_image(:,:,1);

inputg=input(:,:,2);

watermarked_imageg=watermarked_image(:,:,2);

inputb=input(:,:,3);

watermarked_imageb=watermarked_image(:,:,3);

%水印图像R的分解

[Cwr,Swr]=WAVEDEC2(watermarked_imager,2,'haar');

%图像R的分解

[Cr,Sr]=WAVEDEC2(inputr,2,'haar');

%水印图像G的分解

[Cwg,Swg]=WAVEDEC2(watermarked_imageg,2,'haar');

%图像R的分解

[Cg,Sg]=WAVEDEC2(inputg,2,'haar');

%水印图像B的分解

[Cwb,Swb]=WAVEDEC2(watermarked_imageb,2,'haar');

%图像B的分解

[Cb,Sb]=WAVEDEC2(inputb,2,'haar');

%提取水印小波系数

%提取水印R的小波系数

r=0.06;

for k=0:3

whr(k+1,:)=Cwr(1+size(Cwr,2)/4+k*size(Cwr,2)/16:...

size(Cwr,2)/4+(k+1)*size(Cwr,2)/16)-...

Cr(1+size(Cr,2)/4+k*size(Cr,2)/16:...

size(Cr,2)/4+(k+1)*size(Cr,2)/16);

wvr(k+1,:)=Cwr(1+size(Cwr,2)/2+k*size(Cwr,2)/16:...

size(Cwr,2)/2+(k+1)*size(Cwr,2)/16)-...

Cr(1+size(Cr,2)/2+k*size(Cr,2)/16:...

size(Cr,2)/2+(k+1)*size(Cr,2)/16);

wdr(k+1,:)=Cwr(1+3*size(Cwr,2)/4+k*size(Cwr,2)/16:...

3*size(Cwr,2)/4+(k+1)*size(Cwr,2)/16)-...

Cr(1+3*size(Cr,2)/4+k*size(Cr,2)/16:...

3*size(Cr,2)/4+(k+1)*size(Cr,2)/16);

end

whr=(whr(1,:)+whr(2,:)+whr(3,:)+whr(4,:))/(4*r);

wvr=(wvr(1,:)+wvr(2,:)+wvr(3,:)+wvr(4,:))/(4*r);

wdr=(wdr(1,:)+wdr(2,:)+wdr(3,:)+wdr(4,:))/(4*r);

war=(Cwr(1:size(Cwr,2)/16)-Cr(1:size(Cr,2)/16))/r;

%提取水印小波系数

%提取水印G的小波系数

g=0.03;

for k=0:3

whg(k+1,:)=Cwg(1+size(Cwg,2)/4+k*size(Cwg,2)/16:...

size(Cwg,2)/4+(k+1)*size(Cwg,2)/16)-...

Cg(1+size(Cg,2)/4+k*size(Cg,2)/16:...

size(Cg,2)/4+(k+1)*size(Cg,2)/16);

wvg(k+1,:)=Cwg(1+size(Cwg,2)/2+k*size(Cwg,2)/16:...

size(Cwg,2)/2+(k+1)*size(Cwg,2)/16)-...

Cg(1+size(Cg,2)/2+k*size(Cg,2)/16:...

size(Cg,2)/2+(k+1)*size(Cg,2)/16);

wdg(k+1,:)=Cwg(1+3*size(Cwg,2)/4+k*size(Cwg,2)/16:...

3*size(Cwg,2)/4+(k+1)*size(Cwg,2)/16)-...

Cg(1+3*size(Cg,2)/4+k*size(Cg,2)/16:...

3*size(Cg,2)/4+(k+1)*size(Cg,2)/16);

end

%提取水印小波系数

%提取水印B的小波系数

b=0.12;

for k=0:3

whb(k+1,:)=Cwb(1+size(Cwb,2)/4+k*size(Cwb,2)/16:...

size(Cwb,2)/4+(k+1)*size(Cwb,2)/16)-...

Cb(1+size(Cb,2)/4+k*size(Cb,2)/16:...

size(Cb,2)/4+(k+1)*size(Cb,2)/16);

wvb(k+1,:)=Cwb(1+size(Cwb,2)/2+k*size(Cwb,2)/16:...

size(Cwb,2)/2+(k+1)*size(Cwb,2)/16)-...

Cb(1+size(Cb,2)/2+k*size(Cb,2)/16:...

size(Cb,2)/2+(k+1)*size(Cb,2)/16);

wdb(k+1,:)=Cwb(1+3*size(Cwb,2)/4+k*size(Cwb,2)/16:...

3*size(Cwb,2)/4+(k+1)*size(Cwb,2)/16)-...

Cb(1+3*size(Cb,2)/4+k*size(Cb,2)/16:...

3*size(Cb,2)/4+(k+1)*size(Cb,2)/16);

end

whb=(whb(1,:)+whb(2,:)+whb(3,:)+whb(4,:))/(4*b);

wvb=(wvb(1,:)+wvb(2,:)+wvb(3,:)+wvb(4,:))/(4*b);

wdb=(wdb(1,:)+wdb(2,:)+wdb(3,:)+wdb(4,:))/(4*b);

wab=(Cwb(1:size(Cwb,2)/16)-Cb(1:size(Cb,2)/16))/b;

%重构水印图像

cwr=[war,whr,wvr,wdr];

swr(:,1)=[sqrt(size(war,2)),sqrt(size(war,2)),2*sqrt(size(war,2))];

swr(:,2)=[sqrt(size(war,2)),sqrt(size(war,2)),2*sqrt(size(war,2))];

wr = waverec2(cwr,swr,'haar');

cwg=[wag,whg,wvg,wdg];

swg(:,1)=[sqrt(size(wag,2)),sqrt(size(wag,2)),2*sqrt(size(wag,2))];

swg(:,2)=[sqrt(size(wag,2)),sqrt(size(wag,2)),2*sqrt(size(wag,2))];

wg=waverec2(cwg,swg,'haar');

%将R,G,B叠加

temp=size(wr);

pic=zeros(temp(1),temp(2),3);

for i=1:temp(1);

for j=1:temp(2);

pic(i,j,1)=wr(i,j);

pic(i,j,2)=wg(i,j);

pic(i,j,3)=wb(i,j);

end

end

output=uint8(round(pic));

%转化为uint8

watermark_image_uint8=uint8(output);

imwrite(watermark_image_uint8,'watermark.bmp','bmp');

figure(2);

imshow(watermark_image_uint8);

title('提取出的水印');

原始图像

加入小波的图像

小波 提取的小波

MATLAB图像数字水印的方案相关推荐

  1. 水印鲁棒性的分析matlab程序,图像数字水印+matlab程序

    第三章 图像数字水印的方案 3.1 图像数字水印的技术方案 在数据库中存储在国际互联网上传输的水印图像一般会被压缩,有时达到很高的压 缩比.因此,数字水印算法所面临的第一个考验就是压缩.JPEG和EZ ...

  2. bmp文件数字水印c语言代码,图像数字水印+matlab程序文件.doc

    word格式精心整理版 范文范例 学习指导 第三章 图像数字水印的方案 3.1 图像数字水印的技术方案 在数据库中存储在国际互联网上传输的水印图像一般会被压缩,有时达到很高的压缩比.因此,数字水印算法 ...

  3. 数字水印算法matlab源程序 matlab版数字水印算法 /DCT/DWT/LSB/HVS/W-SVD数字水印源码 数字水印的嵌入和提取 W-SVD数字水印实现

    发以下多套系统源码: 1.matlab版数字水印算法 2.MATLAB数字水印 源代码+文档 3.数字水印技术matlab代码 4.数字水印 JPEG压缩 matlab代码 5.数字水印 添加噪声 m ...

  4. matlab图像水印技术研究,动态图像数字水印matlab的实现开题报告.doc

    您所在位置:网站首页 > 海量文档 &nbsp>&nbsp计算机&nbsp>&nbspmatlab 动态图像数字水印matlab的实现开题报告.doc ...

  5. 基于MATLAB的数字水印算法研究实现

    基于MATLAB的数字水印算法研究实现 一.课题背景 随着图像.音频.视频等多媒体信息以及Internet的迅速发展,多媒体信息在互联 网上的广泛传播变得及其便利,数据的交换和传输过程变得相对简单.多 ...

  6. 基于matlab的数字水印技术研究,MATLAB在数字水印技术研究中的应用

    MATLAB在数字水印技术研究中的应用 随着网络技术和数字技术的发展,数字水印技术在版权保护.数据鉴别.数字产品认证等领域有着广泛的应用前景.因而数字水印日益成为一个非常活跃 (本文共4页) 阅读全文 ...

  7. python数字水印嵌入与提取_基于LSB的图像数字水印实验

    1. 实验类别 设计型实验:MATLAB设计并实现基于LSB的图像数字水印算法. 2. 实验目的 了解信息隐藏中最常用的LSB算法的特点,掌握LSB算法原理,设计并实现一种基于图像的LSB隐藏算法. ...

  8. MATLAB图像融合拼接

    MATLAB图像融合拼接 本文说明的内容是图像拼接,采用基于特征点的匹配方法将两张定点拍摄的照片进行拼接,合成一张图,将全景图生成简化成两张图片的拼接,具体可以分为以下几点: 掌握图像灰度化.图像投影 ...

  9. MATLAB图像去雾技术研究

    MATLAB图像去雾技术研究 基本任务及要求: 雾天拍摄的风景图片清晰度下降,而去雾技术可还原其本来面目,增加明艳度.而去雾技术的更重要应用在于卫星图片的清晰度增强. 设计要求: 介绍图像去雾的相关知 ...

最新文章

  1. [WebDev]Web 开发与设计师速查手册大全
  2. Matlab GUI 界面设计基础(1)
  3. 程序员永远不要再犯的5个编程错误
  4. asp.net控件库FineUI使用入门图解
  5. centos7挂载windows共享文件
  6. 【编译原理】构建一个简单的解释器(Let’s Build A Simple Interpreter. Part 7.)(笔记)解释器 interpreter 解析器 parser 抽象语法树AST
  7. Linux系统下,虚拟终端开启256色_虚拟终端类型xterm开启256色
  8. python审计分析_【干货】Python自动化审计及实现
  9. Ext Designer
  10. vector 使用 c++11 Lambda 表达式 排序
  11. “三低”用户养活的互联网
  12. DECLARE_DYNAMIC IMPLEMENT_DYNAMIC
  13. keras利用flow_from_directoryt自己构建数据集
  14. path和classpath的用途
  15. SQLServer版本对应内部数据库版本号配置表
  16. 计算机需要那些高中数学知识点,高中必考数学知识点归纳整理
  17. u盘稳定测试软件,u盘检测工具最新版
  18. 电话号码的字母组合---2022/01/23
  19. linux未编辑的文件,如果是linux没有vi,vim等编辑器如何操..._网络编辑_帮考网
  20. KDD 2020阿里巴巴论文一分钟秒读

热门文章

  1. word/exce转lPDF乱码(思源字体)
  2. Mac 更新port卡住怎么办?
  3. 2022-2028全球与中国汽车软内饰材料市场现状及未来发展趋势
  4. ACE_Message_QueueACE_MT_SYNCH::putq ()使用时需要注意的地方
  5. Django的视图函数(二):request对象、视图函数返回值(HTML响应、JsonResponse)、反向解析(视图函数)、HttpResponse子类
  6. 普通索引 唯一索引 主键索引 组合索引 全文索引
  7. CAD绘制区域覆盖对象
  8. 【Android控件】呼吸效果的动画
  9. 如何在网页标题前添加图标
  10. unity世界坐标与相对坐标转换