自学内容网 自学内容网

基于DCT(离散余弦变换)的图像水印算法,Matlab实现

        博主简介: 专注、专一于Matlab图像处理学习、交流,matlab图像代码代做/项目合作可以联系(QQ:3249726188

        个人主页:Matlab_ImagePro-CSDN博客

        原则:代码均由本人编写完成,非中介,提供有偿Matlab算法代码编程服务,不从事不违反涉及学术原则的事。

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

        本次分享的是基于DCT的图像水印算法,用matlab实现。

        一、案例背景介绍

        前期的博文中,我们介绍了DWT数字水印算法,并对数字水印的背景、算法分类情况等做了比较详细的介绍,这里就不再重复叙述了,前期链接如下:

        基于DWT(离散小波变换)的图像水印算法(基于DWT(离散小波变换)的图像水印算法,Matlab实现-CSDN博客

        这次我们分享的是基于DCT的图像水印算法。

        二、算法原理和算法流程

        嵌入过程:

        1、读取原图、水印图像文件

        2、 对水印图进行灰度化、二值化

        3、二值化后的水印图像置乱,置乱算法arnold

        4、水印图嵌入原图中将原载体图像由rgb变换为Ycbcr空间

        (1)对亮度空间进行8*8分块DCT变换,并嵌入水印,嵌入到DCT变换后的图像块中

        (2)图像块进行反变换,IDCT变换

        (3)Ycbcr空间转回RGB空间

        (4)嵌入完成

        提取过程:

        1、 读取嵌入后水印的图

        2、 读取原图

        3、 提取水印

        (1)   原始图像转换为Ycbcr空间

        (2)   嵌入后水印的图像转换为Ycbcr空间

        (3)   分别获取原始图像、嵌入后水印的图像Y图层

        (4)   分别对原始图像、嵌入后水印的图像Y图层进行8*8分块,进行差值计算,得到二值图分块图像

        (5)   二值图分块图像还原为水印尺寸,得到水印图

        4、对提取到的二值图进行水印反置乱(iarnold),得到最终水印图。

        三、Matlab实现效果

        嵌入:

  

  

  

  

        提取效果:

  

  

        

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

专注、专一于Matlab图像处理学习、交流、代做

QQ:3249726188


原文地址:https://blog.csdn.net/Matlab_ImagePro/article/details/137156891

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!