第五章-数字水印-2-原理及实现

news/2024/4/20 8:52:27/文章来源:https://blog.csdn.net/sunguanyong/article/details/130328494

数字水印原理

根据之前图像获取位平面的操作可知,最低位位平面对整体图像的影响最小,因此数字水印的原理为在图像的最低有效位上嵌入隐藏信息,即在图像的最低位替换为数字水印位平面,完成数字的嵌入操作,对已嵌入数字水印的图片提取最低位位平面,即可得到数字水印和解密后的图像,因操作在最低位位平面,所以可以忽略对图像的影响。

数字水印制造

数字水印的实现基于上述原理的具体实现,首先准备需要嵌入数字水印的lena图(512*512)以及获取数字水印的原始图(512*512)。

数字水印的原始图是在纯白(255)背景上随便写的字,通过代码把数字水印原始图变成数字水印图。

大体步骤如下:

  1. 数字原始图片显示为灰度图
  2. 灰度图中把关键信息独立出来,具体为把背景色置为0(这里用的纯白背景255,实际可能是一定范围的颜色区间)
  3. 灰度图只有水印关键信息,把此信息的颜色值变为1,灰度图变为最低位平面,得到数字水印

代码如下:

import cv2 as cv
import numpy as np# --------------------------制造数字水印
# step1 读取原始图
key = cv.imread("key.png", 0)
#  step2 得到数字水印灰度图 可以看到文字及背景白色
cv.imshow("key255", key)
# step3  之前提取位平面图的掩模操作,把白色255背景变成黑色0
key[key == 255] = 0
cv.imshow("key0", key)
# step4 再把文字变成1,这样就得到了数字水印
key[key > 0] = 1
cv.imshow("key", key)
cv.waitKey()
cv.destroyAllWindows()

运行效果如下:

数字水印嵌入及提取

理解了数字水印的原理再来分析数字的嵌入及提取就会觉得特别简单了。

  1. 先把数字水印生成好,看上面即可。
  2. 把载体图像的最低位位平面给处理掉,使用一个254的矩阵与载体图像做与运算即可。
  3. 数字水印加入到载体图像的最低位位平面即可,此时完成数字水印的嵌入。
  4. 生成一个全部为1的矩阵与载体图像做与运算从而得到最低位位平面,此时得到的就是水印。
  5. 嵌入数字水印的图像做减法运算即可得到丢失了最低位位平面的原始图像
  6. 此时水印只有1和0,再转为二值图显示数字水印的图像,显示完成即可。

具体实现如下:

import cv2 as cv
import numpy as np# --------------------------制造数字水印
# step1 读取原始图
key = cv.imread("key.png", 0)
#  step2 得到数字水印灰度图 可以看到文字及背景白色
cv.imshow("key255", key)
# step3  之前提取位平面图的掩模操作,把白色255背景变成黑色0
key[key == 255] = 0
cv.imshow("key0", key)
# step4 再把文字变成1,这样就得到了数字水印
key[key > 0] = 1
cv.imshow("key", key)
# -----------------------嵌入水印过程
# step1 生成值全为254的模板
lena = cv.imread("lena.jpg", 0)
cv.imshow("lena", lena)
r, c = lena.shape
mask_254 = np.ones((r, c), dtype=np.uint8) * 254
# step2 用254模板把lena的最低位
lena_high_bit = cv.bitwise_and(lena, mask_254)# step3 去掉最低位的lena嵌入数字水印 这一步用或运算也行
# lena_water = cv.bitwise_xor(lena_high_bit, key)
lena_water = lena_high_bit + keycv.imshow("lena_water", lena_water)# -----------------------提取水印过程
# step4 生成各全为1的模板,用来把数字水印提取出来
mask_1 = np.ones((r, c), dtype=np.uint8)
# step5 嵌入水印的图像与1模板做与运算,把水印提取出来
key_after = cv.bitwise_and(lena_water, mask_1)
# step6 嵌入水印的图像减去水印得到的就是失去最低位的"原图" 这一步也可以用254的模板做与运算
# mask_254 = np.ones((r, c), dtype=np.uint8) * 254
# lena_after = cv.bitwise_and(lena_water, mask_254)
lena_after = lena_water - key_after
cv.imshow("lena_after", lena_after)# step7 把数字水印转化为二值图,直接显示出来
key_after[key_after > 0] = 255
cv.imshow("key_after", key_after)cv.waitKey()
cv.destroyAllWindows()

运行效果如下:

总结:知道数字水印的原理整体实现起来就轻松多了,大体就是在图片的最低位加入数字水印,提取水印也就是把提取出已嵌入水印的图像的最低位位平面。后面的可视化水印及艺术文字大体就是对图像和数字水印图像的区域运算,不再做单独讨论。

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【opencv】图像数字化——矩阵的运算( 5 乘法运算)

5 乘法运算 5.1使用“*”运算符 对于Mat对象的乘法&#xff0c;两个Mat只能同时是float或者double类型&#xff0c;对于其它数据类型的矩阵乘法会报错src1的列数等于src2的行数mn * npmp #include <opencv2/core/core.hpp> #include<iostream> using namesp…

实战iOS App 重签名

熟悉iOS开发的同学都知道,iOS应用的上架流程主要分为以下几步: 创建开发者账号借助辅助工具appuploader创建证书,描述文件iTunes connect创建App打包IPA上传App Store等待审核在签名的流程中,有一个App重签名的步骤,主要针对的是一些大公司有多个App的情况,多个App一个申…

数据库基础篇 《4. 运算符》

目录 1. 算术运算符 1&#xff0e;加法与减法运算符 2&#xff0e;乘法与除法运算符 3&#xff0e;求模&#xff08;求余&#xff09;运算符 2. 比较运算符 1&#xff0e;等号运算符 2&#xff0e;安全等于运算符 3&#xff0e;不等于运算符 4. 空运算符 5. 非空运算…

Unity 工具控件 之 Text 文本字间距调整(老版本的Unity编写工具控件/新版本Unity使用TMP)

Unity 工具控件 之 Text 文本字间距调整(老版本的Unity编写工具控件/新版本Unity使用TMP) 目录 Unity 工具控件 之 Text 文本字间距调整(老版本的Unity编写工具控件/新版本Unity使用TMP) 一、简单介绍 二、老版本 Unity Text 使用工具控件调整行间距 三、新版本 Unity Text…

站在程序猿的角度理解:UDP 协议

哈喽&#xff0c;大家好~我是你们的老朋友&#xff1a; 保护小周ღ&#xff0c;本期为大家带来的是 网络基础原理中的 UDP 协议&#xff0c;从什么协议&#xff1f;&#xff0c;认识 UDP 协议&#xff0c;UDP 的报文格式&#xff0c;UDP 传输大文件时的策略&#xff0c;以及 UD…

VS code 插件之中英文间自动添加空格

前言 不知道大家在开发过程中是不是会遇到写代码注释或者文本内容时中英文之间没有空格的情况&#xff0c;很多时候在写代码尤其是写注释的时候容易忘记加空格&#xff0c;但回过头来看又难以忍受&#xff0c;于是我就想着自己写一个 vscode 插件来解决这个问题&#xff0c;希…

展会邀请 | 虹科诚邀您4月26-28日前来参观成都国际工业博览会

HONGKE NEWS 2023 成都国际工业博览会精准聚焦中国智能制造&#xff0c;将通过展示自动化和工业机器人技术、新一代信息技术、金属加工、节能与工业配套、新材料等全行业最新技术和解决方案&#xff0c;完美呈现智能工业产业链中的创新技术及产品的有效融合。 2023年4月26日-…

高效编程----VSCode+ChatGPT插件

VSCode中使用ChatGPT插件 首先在VSCode中打开扩展面板&#xff0c;搜索ChatGPT&#xff0c;安装蓝色圈出插件&#xff0c;如图所示&#xff1a; 安装完成后&#xff0c;需要重启VSCode 注册账号&#xff0c;如图所示&#xff1a; 然后在ChatGPT对话框中输入信息即可使用&#…

Python 实验四 常用数据结构(1)

1.从键盘输入一个正整数列表&#xff0c;以一1结束&#xff0c;分别计算列表中奇数和偶数的和。 n int(input("请输入一个正整数&#xff1a;")) list [] while n ! -1:list.append(n)n int(input("请输入一个正整数&#xff1a;")) else:print("…

【Linux网络】部署YUM仓库及NFS服务

部署YUM仓库及NSF服务 一、YUM仓库1.1、YUM仓库概述1.2准备安装来源1.3在软件仓库加载非官方RPM包组1.4yum与apt 二、配置yam源与制作索引表2.1配置FTP源2.2配置国内在线yum源2.3在线源与本地源同时使用2.4建立软件包索引关系表的三种方法 三、nfs共享存储服务3.1安装软件&…

Django框架之创建项目、应用并配置数据库

django3.0框架创建项目、应用并配置数据库 创建项目 进入命令行 新建一个全英文的目录 进入目录 输入命令 django-admin startproject project 项目目录层级 查看当前目录层级 tree /f 目录文件说明 创建数据库 做一个学生管理系统做演示&#xff0c;使用navicat创建数据…

ML之DR:sklearn.manifold(流形学习和降维的算法模块)的简介、部分源码解读、案例应用之详细攻略

ML之DR&#xff1a;sklearn.manifold(流形学习和降维的算法模块)的简介、部分源码解读、案例应用之详细攻略 目录 sklearn.manifold的简介 sklearn.manifold(流形学习和降维的算法模块)的概述 外文翻译 sklearn.manifold的部分源码解读 sklearn.manifold的简介 sklearn.ma…

Bugku——应急加固1

来打一下bugku的应急加固靶场&#xff0c;靶场链接&#xff1a;https://ctf.bugku.com/ctfplus/detail/id/2.html 启动环境 1、JS劫持域名 直接访问ip地址&#xff0c;发现是xxx学院二手交易市场&#xff0c;随后被劫持跳转到了一个博客页面。 博客地址就是第一个flag&…

Android音视频开发-OpenGL ES正交投影实现方法

本文实例为大家分享了OpenGL ES正交投影展示的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下 绘制正方形 在最开始绘制的六边形里面好像看起来挺容易的&#xff0c;也没有出现什么问题&#xff0c;接下来不妨忘记前面绘制六边形的代码&#xff0c;让我们按照自己的…

Ubuntu下打开QtCreator,环境变量(PATH、LD_LIBRARY_PATH等)与预期不一致的问题

现象展示 在Ubuntu中&#xff0c;安装好Qt之后&#xff0c;可以在系统桌面的左下角找到启动图标 但是&#xff0c;这种方式启动的QtCreator所读取到的环境变量和我们从命令行读取到的不一致&#xff1a; 可以看到&#xff0c;明显少了这个&#xff1a;/opt/ros/humble/bin 因…

很合适新手入门使用的Python游戏开发包pygame实例教程-02[如何控制飞行]

前面一篇博文&#xff0c;我们让飞机动起来了&#xff0c;但不是那么完美&#xff0c;我们继续来完善我们的游戏代码&#xff0c;本篇博文主要介绍获取按键的方式已经飞行的控制。 文章目录 一、获取按键的三种方式1、通过event.get配合pygame.key枚举2、通过event.get配合ord…

微积分入门

文章目录 前言初期积分微分微积分问题 后期极限 ε \varepsilon ε- δ \delta δ极限勒贝格积分 结语 前言 微积分总共走过了两个时期。首先是牛顿和莱布尼茨利用无穷小量定义微分和积分&#xff0c;并且发现了微分和积分的关系&#xff0c;这是第一个时期&#xff0c;这时的…

设计模式——组件协作模式之模板方法模式

文章目录 前言一、“组件协作” 模式二、模板方法模式1、动机2、源码分析讲解①、结构化软件设计②、面向对象软件设计 三、模板方法模式定义四、结构要点总结 前言 一、“组件协作” 模式 现代软件专业分工之后的第一个结果是 “框架与应用程序的划分”&#xff0c;“组件协作…

Cuckoo Filter

其他判重数据结构 Bloom Filter 无法支持删除和计数的功能&#xff0c;需要更多的存储空间来存储数据 因为在CS中&#xff0c;删除和计数是常见的操作&#xff0c;但是这会对布隆过滤器的存储空间产生影响&#xff0c;同样为了实现这一操作&#xff0c;需要更多的存储空间 数…

ArcGIS Pro导航工具

主要导航工具为浏览工具 、屏幕导航器 、书签 、转到XY工具 。 其它还包括链接视图、地图比例&#xff08;2D&#xff09;、场景高度&#xff08;3D&#xff09;、暂停并刷新绘制、照相机属性、在3D模式下导航、键盘快捷键等。 1 主要导航工具 地图和场景的默认工具为浏览工具…