第五章-数字水印-1-位平面

news2024/12/26 16:21:14

数字水印概念

数字水印是一种将特定数字信息嵌入到数字作品中从而实现信息隐藏、版权认证、完整性认证、数字签名等功能的技术。

以图片水印为例:

水印嵌入过程:版权信息水印A嵌入到图像B中,得到含有水印的图像C,图像C与图像B在外观上基本一致,肉眼无法区分差异。

水印提取过程:通过水印提取技术,将图像C中的水印提取得到删除水印的D和提取的水印E,图像C应和图像D在外观上基本一致,同时肉眼无法区分,另外,水印E应和水印A一致。

同样的,为了保证嵌入水印前后肉眼不能够观察到差异,必须确保嵌入的水印对载体的影响较小,这就要求嵌入的位置隐藏在相对不重要的位置。

而我们知道的,在一个多位的10进制数字中,修改高位的数值比修改低位的数值对数值的影响要大的多,同样的,修改载体图像像素点的最低位来实现水印的嵌入,对载体图像的影响也是最小的。这就延伸出一个新的概念--位平面。

位平面

提取灰度图像中所有像素点的二进制形式像素值中处于同一比特位上的值,得到一副二值图像,该图像被称为灰度图像的一个位平面,其他位平面的过程成为位平面分解。

任意 x ∈[0,255]都满足x =a8 * 2^7 + a7 * 2^6 + a6 * 2^5 + a5 * 2^4 + a4 * 2^3 + a3 * 2^2 + a2 * 2^1 + a1 * 2^0 ,其中 a1、a2、a3、a4、a5、a6、a7、a8等于0或者1。

点位图分解就是对所有像素点的值分别取出所有的a1、a2、a3、a4、a5、a6、a7、a8到一个独立的数组中,这些数组就是位平面,取出的位平面是个二值图。涉及比特位取位运算,关键操作当然少不了与运算。

另外,显示位平面时,低位取出的位平面趋近为黑色。具体操作为位平面RD的像素点大于0(有值)时置为true,等于0的位置置为false形成一个模板mask,再对模板位置为true的位置置为255,具体如下:

mask = ( RD > 0 )

RD[ mask ] = 255

简化后为:RD[ RD > 0 ] = 255

获取图像的位平面代码如下:

import cv2 as cv
import numpy as np

# 读取原始图
lena = cv.imread("lena.png", 0)
cv.imshow("lena", lena)

r, c = lena.shape
# 获取位平面当然是用比特位与运算
# 8个位平面对应需要8个与图像等宽高的矩阵
x = np.zeros((r, c, 8), dtype=np.uint8)
for i in range(8):
    x[:, :, i] = 2 ** i  # 每个矩阵填充做与运算的数值
    # cv.imshow(str(i),x[:,:,i])#为什么后面要做阈值处理,这里可以看出,只有6,7稍微白一些,0-5都挺黑的

# 用来保存位平面结果的数组
result_images = np.zeros((r, c, 8), dtype=np.uint8)
for i in range(8):
    # 原图和矩阵进行与运算,并把结果保存好
    result_images[:, :, i] = cv.bitwise_and(lena, x[:, :, i])  # 与运算后得到一个灰度图(里面只有0和位值)

    mask = result_images[:, :, i] > 0  # 灰度图中值大于0的位置为true,等于0的位置为false,得到一个掩模
    result_images[mask] = 255  # 根据掩模进行处理,灰度图变成了二值图
    cv.imshow(str(i), result_images[:, :, i])

cv.waitKey()
cv.destroyAllWindows()

程序运行如下:

如果把掩模处理的步骤去掉,运行效果如下:

总结:高位位平面和原始图相似度更高,对原图的影响也更大,但低位位平面能够对高位位平面进行细节上的圆润,使得图像更加饱满和生动。

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

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

相关文章

OpenHarmony的线程间通信EventHandler

一、初识EventHandler ​ 在OpenHarmony的开发过程中,如果遇到处理下载、运算等较为耗时的操作时,会阻塞当前线程,但是实际操作中又不希望当前线程受到阻塞。比如:我们的app在界面上有一个下载文件的处理按钮,如果在按…

计算机网络基础 第三章练习题

计算机网络基础 第三章练习题 现在大量的计算机是通过诸如以太网这样的局域网连入广域网的,而局域网与广城网的互联是通过( A)实现的。 A. 路由器B. 资源子网C. 桥接器D. 中继器 下列不属于数据链路层功能的是(B )。 A. 帧定界功能B. 电路管理功能C. 差错控制功能D…

HCIP——交换

交换 园区网架构 交换机实现了一下功能 无限的传输距离——识别,重写电信号(帧)保证信息完整彻底解决了冲突二层单播——MAC地址表提高端口密度 MAC 单播地址:MAC地址第一个字节第8位为0 组播地址:MAC地址第一个字…

Camera | 8.让rk3568支持前后置摄像头

一、目标 本文主要目标是,支持前置摄像头0v5648、后置摄像头ov13850,以及移植过程遇到的一些小问题的解决。 1. 摄像头连接图 参考上图,摄像头详细信息如下: 2个摄像头均连接在I2C通道42个摄像头共用同一个MIPI数据通道2个摄像…

C++——探究引用

文章目录 概述引用的概念引用特性引用的作用**引用做参数****引用作为函数返回值** 常引用引用的底层实现总结一下引用和指针的不同点 概述 本篇博客将讲述c相对于c新增的一个重要的内容——引用,深入研究其语法细节以及其需要注意的一些要点。 引用的概念 竟然要学…

Baumer工业相机堡盟工业相机如何联合BGAPISDK和佳能EF变焦镜头实现相机的自动变焦(C++)

Baumer工业相机堡盟工业相机如何联合BGAPISDK和佳能EF变焦镜头实现相机的自动变焦(C) Baumer工业相机Baumer工业相机BGAPISDK中控制变焦镜头的技术背景代码案例分享第一步:开启相机自动调焦功能模块第二步:控制自动变焦镜头电机的…

Java+SSM+Mysql在线图书超市

课题背景及意义 随着现代网络技术发展,对于在线图书超市的设计现在正处于发展的阶段,所以对的要求也是比较严格的,要从系统的功能和用户实际需求来进行对系统制定开发的发展方式,依靠网络技术的的快速发展和现代通讯技术的结合为…

C++11: lambda、包装器、模板参数包和线程库

lambda C98中的一个例子 在C98中,如果想要对一个数据集合中的元素进行排序,可以使用std::sort方法。 int main() {int array[] { 4,1,8,5,3,7,0,9,2,6 };// 默认按照小于比较,排出来结果是升序std::sort(array, array sizeof(array) / s…

socket.io 解决浏览器兼容性(WebSocket)

在上一篇讲了 npm 上最流行的 WebSocket 库之一的 ws 库,那么本篇就来讲另外一个,就是 socket.io 库,socket.io 其实是一个兼容方案,当浏览器不支持 H5 的情况下就不能够使用上一篇内容讲的 WebSocket ,只能采用其他的…

【数据统计】— 极大似然估计 MLE、最大后验估计 MAP、贝叶斯估计

【数据统计】— 极大似然估计 MLE、最大后验估计 MAP、贝叶斯估计 极大似然估计、最大后验概率估计(MAP),贝叶斯估计极大似然估计(Maximum Likelihood Estimate,MLE)MLE目标例子: 扔硬币极大似然估计—高斯分布的参数 矩估计 vs LSE vs MLE贝叶斯公式&am…

JavaScript函数基础

●我们代码里面所说的函数和我们上学的时候学习的什么三角函数、二次函数之类的不是一个东西 函数的概念 ●对于 js 来说,函数就是把任意一段代码放在一个 盒子 里面 ●在我想要让这段代码执行的时候,直接执行这个 盒子 里面的代码就行 ●先看一段代码 …

[golang gin框架] 25.Gin 商城项目-配置清除缓存以及前台列表页面数据渲染公共数据

配置清除缓存 当进入前台首页时,会缓存对应的商品相关数据,这时,如果后台修改了商品的相关数据,缓存中的对应数据并没有随之发生改变,这时就需要需改对应的缓存数据,这里有两种方法: 方法一 在管理后台操作直接清除缓存中的所有数据,当再次访问前台首页时,就会先从数据库中获取…

巧用千寻位置GNSS软件|直线放样有技巧

日常测量作业中,直线放样是对设计好的直线进行放样,其中包括直线的里程,左右偏距及设计直线范围内的高程控制。本文将介绍如何运用千寻位置GNSS软件完成日常的直线放样。 点击【测量】->【直线放样】->【直线库】,选择一条直…

Python数组仿射变换

文章目录 仿射变换坐标变换的逻辑scipy实现 仿射变换 前面提到的平移、旋转以及缩放,都可以通过一个变换矩阵来实现,以二维空间中的变换矩阵为例,记点的坐标向量为 ( x , y , 1 ) (x,y,1) (x,y,1),则平移矩阵可表示为 [ 1 0 T x …

数据结构和算法学习记录——二叉搜索树的插入操作、删除操作

目录 二叉搜索树的插入 思路图解 代码实现 要点 例题 二叉搜索树的删除 情况一 情况二 情况三 右子树的最小元素 左子树的最大元素 代码实现 二叉搜索树的插入 要进行二叉搜索树的插入, 关键点在于要找到元素应该插入到哪个位置,可以采…

Echarts数据可视化(下)

四、数据可视化项目实战 后台搭建 结合Vue开发图表组件 WebSocket实现数据推送 主题切换/页面合并/全屏切换 4.1 Koa2 学习介绍:koa2 - 简书 官网:Koa (koajs) -- 基于 Node.js 平台的下一代 web 开发框架 | Koajs 中文文档 4.1.1 Koa2 的介绍 基…

springboot+vue校园新闻网站(源码+说明文档)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的校园新闻网站。项目源码以及部署相关请联系风歌,文末附上联系信息 。 💕💕作者:风歌&a…

【数据结构】树及二叉树的概念

😛作者:日出等日落 📘 专栏:数据结构 一次失败,只是证明我们成功的决心还够坚强。 ——博 维 目录 🎄树概念及结构: ✔树的概念: ✔树的相关概念 :​编辑 ✔树的…

【C++】-一文让你半只脚进入C++,还不进来看看??

作者:小树苗渴望变成参天大树 作者宣言:认真写好每一篇博客 作者gitee:gitee 如 果 你 喜 欢 作 者 的 文 章 ,就 给 作 者 点 点 关 注 吧! C入门 前言一、C关键字二、namespace和using关键字2.1namespace和using的使用2.2names…

WebStorm前端启动JetLinks 物联网基础平台(2.x)

目录 一、环境准备 二、下载源码 三、安装依赖 ​四、修改配置 五、启动项目 六、访问项目 一、环境准备 1.降级node版本为12.22.0 使用node版本管理器gnvm_苍穹之跃的博客-CSDN博客以管理员身份打开cmd,cd到node安装目录。https://blog.csdn.net/wenxingch…