Robust Mesh Watermarking
之前看了一篇题为"Robust Mesh Watermarking"的论文,查阅资料的时候发现了一篇与之很相似的名为"三维模型数字水印系统的设计与实现"的中文论文,在中文论文的帮助下,总算对网格水印有了一定的了解,简单整理了一下。
由于知识版权保护的需要,数字水印技术应运而生。目前,图像、视频、音频、文本的水印研究已经比较成熟,但是三维模型水印的研究还相对匮乏。然而随着三维模型在网络上传播的日益增多,三维模型知识版权的保护也有了一定的研究意义。由于三维模型自身的特点,对嵌入其中的水印提出了不同于传统水印的要求:
- 健壮性
- 可工作在任意的网格上
- 保持原有的连接
- 不可感知
传统的水印一般分为时/空域水印和频域水印。在图像中,空域水印通过直接改变图像的像素来完成(比如早年提出的LSB算法),这类算法复杂度低,效率高,但缺乏健壮性,很容易被去除或破坏;
而频域(也称变换域)则是通过将图像转换到变换域,通过改变变换域中的某些参数来嵌入水印信息。这类变化主要包括DCT、DFT、DWT等。这类算法由于鲁棒性高,得到了普遍的研究。
对于网格而言,没有频域这一表示,因此需要寻找合适的表示方法来类比图像中的频域,本文的作者的出发点就是将图像中的频谱表示方式扩展到网格中来,他们的思路如下:
缺乏进行频率分解的某种自然的参数化方法(无DCT等)à网格多分辨率表示
没有自然的采样 à网格配准和重采样
以下就论文中提到的水印生成、嵌入及提取方法进行整理
水印生成:
以原模型文件MD5加密后的MD5值作为密钥, 将此密钥作为伪随机数生成器的种子, 从均值为0、方差为l 的高斯分布中取 M个随机实数作为水印w = {w0,wl, …… wm-1 },
Key = MD5(models);
W = Random (key)
W ~ N(0,1)
水印嵌入:
w:水印
Φ:基函数系数
d:水印嵌方向
矩阵形式为: V' = V + BW
矩阵X分量形式为:
VX' :加入水印后网格顶点的X坐标
VX :原始网格顶点X坐标
ε:用户自定义的全局参数,用来控制水印嵌入的深度
Φ:是一个n x m的矩阵,由基函数组成的矩阵,其中矩阵中的项表示基函数Φi 在顶点j处的标量系数
hdx: 是一个 m x n 的对角矩阵,其中dx是全局位移趋势di的X分量,hi为第i个基函数的"幅度"
W :水印
下面介绍、di、hi的生成,由于在生成这些值的过程中用到了PM算法,在这之前先简单介绍下渐进网格(Progressive Meshes, PM)算法
下图为边塌陷与顶点分裂对照图,在左图的网格中,顶点uv之间的边动过边塌陷后被去掉了,u点被合并到了v点,在边塌陷的过程中,记录原顶点和新顶点之间的位置以及顶点之间的连接关系的变动,从而可以通过右图的顶点v点分裂可以分裂出点u,然后恢复出uv之间的边。整个边塌陷去掉的是原始网格中能量较小的边,具体的能量函数此处不做讨论。
在每次点分裂过程中,计算几何的幅度h:
- 首先,用当前点的1-领域的质心来表示(预测)当前点分裂后新产生的点,
- 然后,根据当前点的1-领域计算表面法向量
- 最后,h为表面法向量与实际分裂出的新点坐标与预测的新点左边之差之间的点乘,即h = 表面法向量.(实际新点坐标-预测新点坐标)
之后,从若干(作者没有交代具体次数)次点分裂操作中,选出前m次h最大的操作,在这m次操作对应的原始点上生成基函数。
对于每次塌陷,计算"边界"Bi:由塌陷点i的当前邻居经过追踪点分裂操作之后扩展的邻居集合。计算半径rji :对于每个顶点Vj,计算边界内的点Ci到它的距离,当Ci位于边界中心时,半径为0,Ci位于边界上或边界外时,半径为1,其他情况在0到1之间,计算公式如下:
其中,d(v,S)表示v到S中任意一个顶点的距离的最小值,采用的是Dijkstra最短路径算法
(注:对于h和r的计算有点担心理解有偏差,截图附上此部分英文原文)
根据半径r构造基函数,为了得到更好的效果,将基函数构造为墨西哥草帽函数"
之所以选择这个函数是因为这个函数在坐标原点处连续,并且在原点处积分为0,不会引起模型的明显变化。
水印提取:
在进行水印提取之前, 可能需要对受攻击网格进行重定位或者重采样。当三维模型受到相似变换( 平移、旋转、一致放缩) 攻击时, 为了正确地提取水印,需要把模型带回原始的位置和尺度, 这是网格的重定位, 重定位( Registration ) 也称为对准、匹配。
重定位: 重定位可以理解为在两个模型间寻找一个变换, 使得两个模型间的"距离"最小
Get points v* on attacked mesh surface corresponding to original mesh vertices v
Use same basis functions f 1 … f m and hence same matrix B
Resampling choices:
- Closest point projection
- Ray-casting along local normal
- Global deformation of original
完成上述两步(视情况而定,不一定必须)后,可以从可疑网格中提取水印了,根据下列公式
W* :从可疑模型中提取出的水印
V* :可疑网格中的顶点坐标
V :原始网格中的顶点坐标
解决该最小二乘法问题可以求出W*
计算两者之间的相关性:
Pfp computed from r and m using Student's t-test
Declare watermark present if
Pfp < Pthresh ( e.g. Pthresh = 10-6 )
根据作者的实验,这种水印可以抵抗多种攻击,具有较强的鲁棒性。具体实验结果请参看原文。
Robust Mesh Watermarking的更多相关文章
- Geodesic-based robust blind watermarking method for three-dimensional mesh animation by using mesh segmentation and vertex trajectory
之前因为考试,中断了实验室的工作,现在结束考试了,不能再荒废了. 最近看了一篇关于序列水印的文章,大体思想是:对于一个网格序列,首先对第一帧进行处理,在第一帧上,用网格分割算法(SDF)将网格分割成几 ...
- {ICIP2014}{收录论文列表}
This article come from HEREARS-L1: Learning Tuesday 10:30–12:30; Oral Session; Room: Leonard de Vinc ...
- zhuan 常用图像数据集:标注、检索
目录(?)[+] 1.搜狗实验室数据集: http://www.sogou.com/labs/dl/p.html 互联网图片库来自sogou图片搜索所索引的部分数据.其中收集了包括人物.动物. ...
- [转] CVonline: Image Databases
转自:CVonline by Robert Fisher 图像数据库 Index by Topic Action Databases Biological/Medical Face Databases ...
- 【机器学习】【计算机视觉】非常全面的图像数据集《Actions》
目录(?)[+] 1.搜狗实验室数据集: http://www.sogou.com/labs/dl/p.html 互联网图片库来自sogou图片搜索所索引的部分数据.其中收集了包括人物.动物.建筑 ...
- A Blind Watermarking for 3-D Dynamic Mesh Model Using Distribution of Temporal Wavelet Coefficients
这周看了一篇动态网格序列水印的论文,由于目前在网格序列上做水印的工作特别少,加之我所看的这篇论文中的叙述相对简洁,理解起来颇为困难.好在请教了博士师兄,思路明朗了许多,也就把这思路整理在此了. 论文作 ...
- Watermarking 3D Polygonal Meshes in the Mesh Spectral Domain
这周看了一篇Ryutarou Ohbuchi网格水印的论文,论文中提出在网格的频率域中加入水印.对于网格而言,没有如图像中的DCT等转换到频率域的变换,因此用什么量来模拟传统频率域中的系数,是很关键的 ...
- 什么是Service Mesh?
转至大佬宋净明的博客:https://jimmysong.io/posts/what-is-a-service-mesh/ Service mesh 又译作 “服务网格”,作为服务间通信的基础设施层. ...
- Service Mesh(服务网格)
Service Mesh(服务网格) 什么是Service Mesh(服务网格)Service mesh 又译作 "服务网格",作为服务间通信的基础设施层.Buoyant 公司的 ...
随机推荐
- bzoj 3772 :精神污染 线段树+打标记 or 主席树
3772: 精神污染 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 315 Solved: 87[Submit][Status][Discuss] D ...
- 洛谷P3201 [HNOI2009]梦幻布丁(链表 + 启发式合并)
题目链接 给出 \(n\) 个布丁,每个补丁都有其颜色.现在有 \(m\) 次操作,每次操作将第 \(x_i\) 种颜色全部变为第 \(y_i\) 种颜色. 操作中可能会插入询问,回答目前总共有多少段 ...
- Java入门系列:处理Json格式数据
本节主要讲解: 1)json格式数据处理方法 2)第三方工具包的使用方法 3)java集合数据类型 [项目任务] 编写一个程序,显示未来的天气信息. [知识点解析] 为了方便后面代码的分析,先需要掌握 ...
- 字典的setdefault() 和get()方法比较
Python 字典 setdefault() 函数 和get() 类似: 如果键存在字典中,返回其value值 如果键不存在字典中,创建键值对.完后,返回值为默认值. 话不多说,上栗子: setdef ...
- KVM基本实现原理
KVM 虚拟化技术概述 http://blog.csdn.net/yearn520/article/details/6461047 KVM 虚拟化技术在 AMD 平台上的实现 1.http://www ...
- select()函数
select(),确定一个或多个套接口的状态,本函数用于确定一个或多个套接口的状态,对每一个套接口,调用者可查询它的可读性.可写性及错误状态信息,用fd_set结构来表示一组等待检查的套接口,在调用返 ...
- 数据结构编程实验——chapter9-应用二叉树的基本概念编程
二叉树是树结构中的重要概念,一些特殊的二叉树如满二叉树和完全二叉树由于节点序号的特殊关系,在一些算法中十分常见. 这篇文章将从三个方面介绍有关二叉树的知识点: (1) 普通有序树转化为二叉树. ( ...
- 贪心问题 POJ 2393 Yogurt factory
题目:http://poj.org/problem?id=2393 题意:N周,每周生成牛奶(任意!),每周成本为c_i(1~5000),每周出货 y_i:出货可以使用该周生产的,也可以用之前的储存的 ...
- eclipse初始设置
1.界面显示设置 2.快捷创建的设置 window->Customize Perspective->Shortcuts 3.修改编码为utf-8 Preferences->Gener ...
- Is it possible to create @Around Aspect for feign.Client
https://github.com/spring-cloud/spring-cloud-openfeign/issues/59 看到github 有人问这个问题,做了个示例: import org. ...