【毕业设计系列】视频图像数字水印matlab GUI系统设计

Date: 2019.3.24


前言

    数字水印技术一般用于版权认证。在实际使用中,嵌入水印的鲁棒性就显得非常重要。通常会采用各种方式进行攻击测试,比如加噪滤波,缩放、旋转、剪切、JPEG压缩等。本文讲述了采用DCT变换的方式进行嵌入水印和提取水印,并加入高斯噪声和均值滤波进行攻击测试。

1、参考

https://blog.csdn.net/a573233077/article/details/73498650
https://blog.csdn.net/zxc024000/article/details/49429405
https://zhidao.baidu.com/question/418723318.html
http://www.pudn.com/Download/item/id/3349409.html
https://doc.mbalib.com/view/deb57fe43c2b56e02e272596ae5d855b.html
http://blog.sina.com.cn/s/blog_a98e39a20101507s.html

2、Matlab实现

下面只是嵌入水印部分的代码,提取部分有需要可以通过博客左侧公告栏中的QQ图标或者直接加QQ(2963033731)联系我。

%% 基于DCT的视频水印技术Matlab实现
% Date: 2019.3.22
clc;
clear all;
%mov=aviread('lww.avi'); %读取视频
%movie(mov); %显示视频内容

%% 1.读取视频内容并显示
readerobj = VideoReader('longmao.mp4','tag','myreader');
vidFrames = read(readerobj);
numFrames = get(readerobj, 'NumberOfFrames');  %获取视频帧数
 for k = 1 : numFrames
         mov(k).cdata = vidFrames(:,:,:,k);
         mov(k).colormap = [];
 end
% 创建一个显示句柄
hf = figure; 
% 设置自适应视频宽高
set(hf, 'position', [150 150 readerobj.Width readerobj.Height])
%播放视频内容
movie(hf, mov, 1, readerobj.FrameRate);

[filename, filepath] = uigetfile('.bmp', '输入水印图像');
watermarkImgFile = strcat(filepath, filename);
watermarkImg = imread(watermarkImgFile);

%% 2.采用DCT方式嵌入水印图像
 for m = 1 : 3 %numFrames  %若需要处理全部视频帧,可以将3修改为numFrames
    k=50;           %设置最小相关系数差别
    blocksize=8;    % 设置嵌入的块尺寸

    %读取嵌入对象
    data = imresize(mov(m).cdata,[512 512]);%对处理的视频图像进行裁剪为512x512,便于处理
    data = rgb2gray(data);%灰度化处理
    %% 添加高斯噪声
   Img =  imnoise(data, 'gaussian',0, 0.01);
   figure,
   imshow(Img, []),title('高斯噪声图像');
   imwrite(Img, '高斯噪声图像.jpg');
    
   %% 对高斯噪声视频图像进行均值滤波
    n = 3; % 3x3模板
    A=fspecial('average',n);
    FilterImg=filter2(A, Img);
    figure, imshow(FilterImg, []),title('均值滤波后的图像');
    cover_object= FilterImg;
    FilterImg = uint8(FilterImg);
    imwrite(FilterImg, '均值滤波后的图像.jpg');

    %确定嵌入对象的尺寸
    Mc=size(cover_object,1);            %高度
    Nc=size(cover_object,2);            %宽度

    %基于嵌入对象尺寸和和块尺寸决定最大信息量
    max_message=Mc*Nc/(blocksize^2);

    %读取水印图像(信息)
    message=double(watermarkImg);
    Mm=size(message,1);                 %高度
    Nm=size(message,2);                 %宽度

    % 调整信息为向量表示
    message=fix(reshape(message,Mm*Nm,1)./2);

    % 检查信息不能太长导致难以嵌入
   if (length(message) > max_message)
      error('Message too large to fit in Cover Object')
   end

    % 填充信息量到最大尺寸
    message_pad=ones(1,max_message);
    message_pad(1:length(message))=message;

    % generate shell of watermarked image
    watermarked_image=cover_object;

    % process the image in blocks
    % encodes such that (5,2) > (4,3) when message(kk)=0
    % and that (5,2) < (4,3) when message(kk)=1
    x=1;
    y=1;
    h=waitbar(0,'DCT嵌入水印,请等待');
    for kk = 1:length(message_pad)

        % transform block using DCT
        dct_block=dct2(cover_object(y:y+blocksize-1,x:x+blocksize-1));

        % if message bit is black, (5,2) > (4,3)
        if (message_pad(kk) == 0)

            % if (5,2) < (4,3) then we need to swap them
            if (dct_block(5,2) < dct_block(4,3))
                    temp=dct_block(4,3);
                    dct_block(4,3)=dct_block(5,2);
                    dct_block(5,2)=temp;
            end

        % if message bit is white, (5,2) < (4,3)
        elseif (message_pad(kk) == 1)

            % if (5,2) > (4,3) then we need to swap them
            if (dct_block(5,2) >= dct_block(4,3))
                    temp=dct_block(4,3);
                    dct_block(4,3)=dct_block(5,2);
                    dct_block(5,2)=temp;
            end
        end

        % now we adjust the two values such that their difference >= k
        if dct_block(5,2) > dct_block(4,3)
            if dct_block(5,2) - dct_block(4,3) < k
                dct_block(5,2)=dct_block(5,2)+(k/2);
                dct_block(4,3)=dct_block(4,3)-(k/2);            
            end
        else  
             if dct_block(4,3) - dct_block(5,2) < k
                dct_block(4,3)=dct_block(4,3)+(k/2);  
                dct_block(5,2)=dct_block(5,2)-(k/2);
            end
        end

        % transform block back into spatial domain
        watermarked_image(y:y+blocksize-1,x:x+blocksize-1)=idct2(dct_block);    
        % move on to next block. At and of row move to next row
        if (x+blocksize) >= Nc
            x=1;
            y=y+blocksize;
        else
            x=x+blocksize;
        end
         waitbar(kk/max_message,h);
    end
    close(h);
    % convert to uint8 and write the watermarked image out to a file
    watermarked_image_int=uint8(watermarked_image);

    % 显示嵌入水印图像
    imshow(watermarked_image_int,[]),title('嵌入水印图像')
    imwrite(watermarked_image_int, '嵌入水印图像.jpg');

3、实验效果图

image.png

image.png

image.png

image.png

image.png

4、鲁棒性攻击测试

主要包括加噪滤波,缩放、旋转、剪切、JPEG压缩。

5、补充知识

matlab如何将矩阵保存为图片?

原文:https://blog.csdn.net/a573233077/article/details/73498650

方法一:

imwrite(mat2gray(matrix), 'matrix.tif');

不管matrix原先是double或者uint8类型,数据均被扩展到0-255的范围。
好处是打开图片后就是需要的效果,缺点是再次load该矩阵时,值不再反应原来的数值,而是0-255区间的。

方法二:

imwrite(uint8(matrix)), 'matrix.tif' );

缺点是打开图片后色彩和理想的不同,好处是完整的保存了原来的数据。load后可直接使用。

注意,保存时要是uint8数据,若是double类型直接保存,则保存的图片只有0和1数值。

matlab如何将图片保存为矩阵呢?

Mat = imread('picture');

THE END!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容