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

news2024/12/28 12:47:18

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

        个人主页:Matlab_ImagePro-CSDN博客

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

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

        本次分享的是基于DWT(离散小波变换)的图像水印算法,用matlab实现。(有疑问或者想交流细节的QQ:3249726188

        一、案例背景介绍

        数字水印技术就是信息隐藏技术的一种,其方法是将一些标识信息(即数字水印)直接嵌入数字载体(包括多媒体、文档、软件等)当中,但不影响原载体的使用价值,也不容易被人的知觉系统(如视觉或听觉系统)觉察或注意到,通过这样来达到保护和鉴别数字作品的目的。数字水印技术除了有信息隐藏技术的一般性特点外,还拥有固定的特点和研究方法,由于其可靠的安全性,隐蔽性,同时可以在原始数据中一次性植入大量的水印信息,因此,数字水印技术已经成为当今信息安全领域最炙手可热的一种技术之一,在学术界和业界引起了广泛的关注,在其研究领域也取得了越来越多的成果。

        水印总的来说可以分类两类:时/空域水印算法和变换域水印算法。时/空域水印算法是通过改变载体图像的某些像素的灰度来嵌入水印信息的,而变换域水印算法是通过改变变换域系数来嵌入水印信息的。在早期的时候,人们的研究基本上是基于时/空域的,早期的水印算法相对较简单,实用性较强,但是鲁棒性较差。最低有效位水印算法和双集法等都是时/空域最典型的算法。

        时/空域水印算法在容量和鲁棒性等方面比不上变换域水印算法,但是它的复杂度较低,实用性较强,并且具有对攻击的时间和空间位置的定位能力,所以适合设计半脆弱水印算法和脆弱水印算法。最低有效位法(LSB)和双集法师空域中两种很典型的数字水印算法。

        1974,J.Morlet提出了小波变换的概念。对小波变换的研究发展到现在,小波变换已经是图像压缩标准的一个主要技术,已经成为了研究的重点和热点。同样的基于小波域的数字水印研究也是近年来数字水印技术算法研究的一个热点领域。小波变换是在时频的联合域上对信号进行分析,而不是仅仅停留在时域或者频域上进行单一的分析,所以时频局域化使得小波变换在信号分析中有很大优势。

        在图像上来说,人类视觉系统特性主要有以下三个方面的表现:亮度特性,频域特性和图像类特性。人眼对亮度变化的敏感性称为亮度特性,这是人类视觉系统特性中最基本的一种。人类视觉系统特性表明了人眼对高频的内容变化的敏感性较低,这就意味着图像的背景亮度越高,可以嵌入的附加信息就越多。同理,人眼对低频部分的变换较为敏感,所以在低频部分嵌入的信息就较少。人眼对不同的颜色同样有不同的敏感性。一幅彩色图像,每一个像素都可以分为R,G,B三种基色,根据人眼的敏感性不同,在嵌入水印的时候,会对不同颜色的嵌入量进行调整,R:G:B的比例一般选取为2:1:4。

        这次我们分享的算法,就是基于人类视觉系统的DWT数字水印算法。

        二、算法原理流程

        由小波分解可知,对图像每进行一次小波分解,图像就会被分成四个部分,分别是低频,水平细节,垂直细节和高频部分。然后继续对低频部分进行第二次分解,同样可以得到四个部分,以此类推。经过小波分解之后,因为低频部分与原图有较大的相似性,所以低频部分的鲁棒性会较好。把水印和载体图像都进行小波分解,分别成为3个基色分量,CR,CG,CB和WR,WG,WB,然后将水印的三基色系数分别对应嵌入到载体图像的三基色系数中,嵌入公式为:

CR(G,B)A2(I,j)= CR(G,B)A2(I,j)+r(g,b)*WR(G,B)A1(I,j)

CR(G,B)H1(I,j)= CR(G,B) H1 (I,j)+r(g,b)*WR(G,B) H1(I,j)

CR(G,B)V1(I,j)= CR(G,B) V1 (I,j)+r(g,b)*WR(G,B) V1(I,j)

CR(G,B)D1(I,j)= CR(G,B) D1 (I,j)+r(g,b)*WR(G,B) D1(I,j)

        其中,CR(G,B)A2(I,j)表示载体图像在嵌入水印前红色(绿,蓝)的分量经过两次小波分解后坐标域(I,j)对应的小波系数,WR(G,B)A1(I,j)表示水印图像红色(绿,蓝)经过一次小波分解之后坐标域(I,j)对应的小波系数,r(g,b)为三基色中红色的加权系数,且满足r:g:b=2:1:4的关系。

        水印的嵌入步骤大概可以分为以下的几步:

        (1)载入二值原始载体彩色图像和水印图像,并且将两个图像都分解为三个基色分量。

        (2)把两个图像都进行相应次数的小波分解(本文的方法为对原始图像分解两次,水印图像分解一次)。

        (3)根据Lewis和Knowles所提出的JND模型可知,当嵌入深度小于误差阈值的一半时,水印是不可感知的,DWT域系数量化后可嵌入的最大深度为:

ωθ(i,j)= (I,j)

        (4)把分解之后的水印图像像素点以此嵌入到载体图像中,嵌入公式为

I’θi(I,j)=Iθi(i,j)+αωθ(i,j)ωi

        I’θi(I,j)是小波变换系数,ωi是灰度水印序列,而ωθ(i,j)则是根据人类视觉系统掩蔽特性所计算出来的权值因子函数。α是拉伸因子,控制水印强度,它的值越大,鲁棒性就越好,但是透明性就越差,但是它的值越小,鲁棒性就越差,透明性就越好。

        (5)重复以上的步骤,就可以得到嵌入水印后的系数,然后对嵌入水印后的系数进行小波反变换就可以得到水印图像了。

        而水印的提取就像是水印嵌入的逆过程。其步骤也可以大概分为以下的几步:

        (1)载入原始图像和水印图像,把两个图像都分解为三个基色分量。

        (2)把两个图像分别进行相应次数的小波逆变换。

        (3)重构水印图像。

ωi=(I’θi(I,j)­- Iθi(i,j)) αωθ(i,j)

        三、Matlab实现效果

        嵌入部分:

       嵌入后的图直接提取水印的效果:

       嵌入后的图像经过jpeg压缩攻击后,提取到水印的效果图:

        

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

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

QQ:3249726188

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1549378.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Seata:分布式事务

Seata简介 Seata(Simple Extensible Autonomous Transaction Architecture,简单可扩展自治事务框架)是 2019 年 1 月份蚂蚁金服和阿里巴巴共同开源的分布式事务解决方案。Seata 开源半年左右,目前已经有超过 1.1 万 star&#xf…

babyos 学习记录

宏定义头文件 将一个宏定义取不同的数据到不同的数组中; 侵入式链表 struct list_head { struct list_head *next, *prev; }; // 添加(list_add_tail/list_add)、删除、查找 xx.h // 定义一个用于链表管理的结构体 typedef sturct{ xxx …

搜维尔科技:【应急演练】【工业仿真】救援模拟演练可视化仿真项目实施

安全救援综合演练系统是一套面向公共安全事故、预案管理、应急救援模拟演练的虚拟仿真解决方案,它为警察、消防以及专门的应急救援保障部门提供一个综合的应急救援培训和仿真演练平台。平台主要通过设计不同的事故模型和特定的灾难场景,定制不同的应急救…

跨站脚本攻击

跨站脚本攻击又称XSS攻击,是代码注入攻击的一种。利用XSS漏洞,攻击者可以窃取Cookies或劫持会话,或注入恶意 HTML 或 JavaScript 代码到页面中,又或者将当前页面重定向至一个攻击者搭建的恶意网站。XSS漏洞的产生多是因为网站开发…

全国草地资源类型分布图

草地出现在世界各地,约占全球陆地面积的24%,大多分布于大陆内部气候干燥、降水较少的地区,其中澳大利亚、俄罗斯、中国、美国和巴西等国面积较大。中国草地面积约占国土面积的40%,主要分布在内蒙古、东北、西北和青藏高原&#xf…

前端学习之JavaScript有关字符串的一些方法

&#xff08;注释是对各个方法的一些解释&#xff09; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>字符串</title> </head> <body><script>let str1 test1let str2 n…

nvidia-smi参数信息

nvidia-smi参数信息 如图所示

组织机构代码是哪9位在那里怎么查询?

全国组织机构代码由八位数字&#xff08;或大写拉丁字母&#xff09;本体代码和一位数字&#xff08;或大写拉丁字母&#xff09;校验码&#xff0c;共9位组成&#xff1b; 组织机构代码在哪里怎么查询&#xff1f; 1、打开「词令」小程序&#xff1b; 2、打开词令小程序后&a…

数据结构之单链表的详细实现(图解)

前言 本次博客讲结合图例讲解单向不带头非循环链表 此后会讲解一些题目 1单链表的实现 1.1什么是单链表 我们先看数组&#xff0c;即顺序表的是什么样的&#xff0c;再看链表 1.2单链表的特点 实际中要实现的链表的结构非常多样&#xff0c;以下情况组合起来就有8种链表结…

Avalonia笔记2 -数据集合类控件

学习笔记&#xff1a; 1. DataGrid 笔记1中已经记录&#xff1b; 2. ItemsControl 属性&#xff1a; ItemsSource&#xff1a;数据源 ItemsControl.ItemTemplate&#xff1a;单项数据模板&#xff0c;内部使用<DataTemplate> 示例&#xff1a; <ItemsContr…

html页面使用@for(){},@if(){},利用jquery 获取当前class在列表中的下标

基于以前的项目进行修改优化&#xff0c;前端代码根据List元素在html里进行遍历显示 原先的代码&#xff1a; 其中&#xff0c;noticeGuide.Id是标识noticeGuide的唯一值&#xff0c;但是不是从0开始的【是数据库自增字段】 但是在页面初始化加载的时候&#xff0c;我们只想…

程序员35岁的职业困惑及应对之道

35岁,对许多程序员来说,是一个职业生涯的重要分水岭。在这个年龄,一些人开始感到迷茫和焦虑,担心自己的技能已经落后,难以跟上日新月异的技术变革。而另一些人则充满信心,认为多年来积累的丰富经验和扎实的技术功底,将助力他们在未来的职业道路上取得新的飞跃。 无疑,在AI、自…

Transformer的前世今生 day09(Transformer的框架概述)

前情提要 编码器-解码器结构 如果将一个模型分为两块&#xff1a;编码器和解码器那么编码器-解码器结构为&#xff1a;编码器负责处理输入&#xff0c;解码器负责生成输出流程&#xff1a;我们先将输入送入编码器层&#xff0c;得到一个中间状态state&#xff0c;并送入解码器…

11.Notepad++

文章目录 一、下载和安装设置练习 以前在记事本上写的代码看上去有点累&#xff0c;因为所有的单词看上去都是黑色的&#xff0c;并且当代码出现问题后&#xff0c;它提示第三行&#xff0c;我们还需要一行一行去数。这些问题都可以由一个高级记事本&#xff1a; Notepad 来解…

书生浦语大模型实战营第一课笔记

书生浦语大模型全链路开源体系 课程笔记大模型的发展趋势InternLM2的主要亮点模型到应用的典型流程全链路的开源工具 InternLM2技术报告笔记大型语言模型的发展InternEvoModel Structure训练数据 课程笔记 第一节课主要对大模型进行介绍&#xff0c;特别是书生浦语大模型的发展…

嵌入式学习46——硬件相关2串口通信

串口&#xff1a; 端口&#xff1a; COM 波特率&#xff1a; 9600 115200 &#xff08;bps&#xff09; 每秒传输的数据…

Qt开发(2)——在已有VS项目中配置Qt

在之前的Qt开发学习中&#xff0c;基本都是在Qt Creator中创建一个Qt项目&#xff0c;或者即便是在VS中也是直接新建一个Qt项目。但很少有记录如何在已有的C项目中添加Qt,这就好比我有个项目已经开发完了&#xff0c;现在又说加个Qt界面的功能。这篇文章就是记录如何在已有项目…

Unity3d C#转换微信小游戏 Dotween插件在苹果(IOS)设备中异常问题高性能模式修复

问题 使用minigame-unity-webgl-transform插件转换微信小游戏&#xff0c;功能在安卓和开发工具上都能正常&#xff0c;不过使用Dotween(版本DOTweenPro v1.0.244)插件实现的功能在苹果系统中却都不能正常对比如下&#xff1a; 云移动正常&#xff1a; 云移动IOS异常&#x…

远程监控电脑软件下载安装

员工随意下载和安装软件的行为&#xff0c;往往会给企业带来潜在的安全风险和管理难题。 为了防止员工随意下载软件&#xff0c;企业有必要实施远程监控&#xff0c;记录员工电脑上软件的下载和安装情况。 在此之前&#xff0c;先要明确远程监控的目标和意义。 通过监控员工电…

【搞不明白】redis和mysql、mybatisplus有啥关系

一个解决三天的bug&#xff0c;到现在也没有搞明白&#xff0c;如题&#xff0c;到底redis和mysql、mybatisplus能有啥关系。三个不相关的嘛 记录下问题&#xff1a; (框架用的Jeecgboot 3.6.0) – 学习使用 看下面的一段代码&#xff0c;是一个分页查询&#xff1a;注意引用的…