整理了一下要实现的论文Watermarking 3D Polygonal Meshes in the Mesh Spectral Domain,步骤如下:

嵌入水印 à 提取水印 à 优化(网格细分)

嵌入水印的过程包括一下几个阶段

输入:原始网格

获取拉普拉斯矩阵K

对矩阵K做特征值分解

将原始网格中的顶点投影到特征向量的单位向量上,得到网格频谱系数

修改网格频谱系数

将频谱系数反变换得到顶点坐标

输出:水印网格

目前在嵌入水印阶段遇到了以下错误:

错误:

无法打开文件

"D:\code\GeometryProcessing-1\Debug\GeometryProcess.lib"

解决:这个问题一般是由其他问题所引起的,查看错误列表,从上往下逐个解决错误,这个错误自然就消失了。

打开解决方案时,提示如下语句

!!! Qt4 Add-in was found and closed! !!!

Qt4 and Qt5 versions can't be used at the same time.

Add-in Manager from Tools menu can be used to close Qt5 Add-in and to restart Qt4 Add-in.

解决参考:http://qiusuoge.com/11742.html

以下两个操作是取顶点坐标和将修改后的坐标放入原始的顶点坐标中。

注意,当将修改后的顶点坐标赋回给网格上的顶点时,要使用引用类型

也可以将顶点信息放入一个double数组,然后用指针指向该数组,一遍传入matlab

注意,因为使用了auto类型,所以指针和整数的int j要定义在for循环外面,

下面来看下实验结果

输入: 输出:

什么鬼,肯定是代码写错了,泪

输出前10个点分别看看修改前后的值

从上面的结果看到点的坐标改动太大了,应该是逻辑出现了错误

修改之后仍然错误。。。

之后我开始怀疑是特征值分解的时候出错了

然后我换了其他几个模型,得到的结果如图

以斜杠为分界,左边是原始网格中的点,右边是水印网格中的点

从这个正24面体的顶点改动情况来看,应也是符合预期的,顶点的轻微改动肉眼不宜察觉。

当输入的模型是一个球是,变换明显是错误的。。。

而当我把模型换成马时,程序中断了

使用之前记录的buffer的调试方法,发现是矩阵特征值分解出错了,错误提示如下:

这应该是对于一个非对称的模型,其特征值可能有复数造成的。

如果特征向量之间正交,那么单位化后也是正交的,则在求Rs1时,直接在下式两端乘以e1即可。

拉普拉斯矩阵的特征值分解后得到的特征向量不一定是正交的,因此得到的结果是错误的。

C++实现网格水印之调试笔记(二)的更多相关文章

  1. C++实现网格水印之调试笔记(六)—— 提取完成

    昨天在修改了可以调试出来的错误之后,提取出的水印和嵌入的仍然相去甚远.这个时候我觉得有必要整理一下嵌入和提取的整个过程. 嵌入过程: Step1,嵌入的时候对网格的拉普拉斯矩阵L进行特征值分解,得到特 ...

  2. C++实现网格水印之调试笔记(六)——补充

    调用matlab生成的网格水印特征向量矩阵 从文件中读取的原始网格的特征向量矩阵 好吧,之前得出的结果不正确是因为代码写错了.因为实现论文中的提取方案时代码写错了,自己想了另外一个方法,结果方向两者在 ...

  3. C++实现网格水印之调试笔记(五)—— 提取出错

    在实现提取水印的过程中,遇到了一些问题 首先还是根据论文中的思路来梳理一下整个提取流程 读入两个模型,一个原始模型ori_mesh, 一个水印模型wm_mesh. 将两个模型对齐(即放在同一个坐标系下 ...

  4. C++实现网格水印之调试笔记(四)—— 完成嵌入

    接下来的问题是,当模型是对称的时候,结果是符合预期的,但是当模型是不对称的时候,结果是错误的,如下: 输入: 顶点:233 输出: 这又是什么鬼...,我的马呢!!! 看来逻辑上还是有错误 注意这时候 ...

  5. C++实现网格水印之调试笔记(三)—— 初有结果

    错误: error C2338: THE_BRACKET_OPERATOR_IS_ONLY_FOR_VECTORS__USE_THE_PARENTHESIS_OPERATOR_INSTEAD 这种错误 ...

  6. C++实现网格水印之调试笔记(一)

    首先说一下我的一些简单的调试方法,除了常规的断点调试之外,我还会使用注释的方法来调试.当整个工程代码量相当多且调用层次关系较为复杂时,这种方法能够比较高效的定位到出错误的代码段或某个函数,然后在出现错 ...

  7. Tomcat调试笔记

    调试笔记 在使用Tomcat过程中经常碰到问题,导致tomcat启动失败.如下↓ 由于报错太过笼统,我根本无法找出错误.后来我切换到Console视图下,看到了如下错误信息. 根据报错信息,错误原因是 ...

  8. JavaScript特效(调试笔记)

    JavaScript特效 一.在网页上显示当前的时间日期,例如:“2016年3月26日 星期六”. js源代码: function getTime() { var today = new Date() ...

  9. webpy使用笔记(二) session/sessionid的使用

    webpy使用笔记(二) session的使用 webpy使用系列之session的使用,虽然工作中使用的是django,但是自己并不喜欢那种大而全的东西~什么都给你准备好了,自己好像一个机器人一样赶 ...

随机推荐

  1. PKUSC 模拟赛 day1 下午总结

    下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...

  2. *[hackerrank]Lexicographic paths

    https://www.hackerrank.com/contests/w9/challenges/lexicographic-steps 这题还是折腾很久的.题目意思相当于,比如有两个1两个0,那么 ...

  3. 【Linux高频命令专题(23)】tar

    概述 通过SSH访问服务器,难免会要用到压缩,解压缩,打包,解包等,这时候tar命令就是是必不可少的一个功能强大的工具.linux中最流行的tar是麻雀虽小,五脏俱全,功能强大. tar命令可以为li ...

  4. Dozer应用——类之间值的映射

    1. Mappings via Annotation public class SourceBean { private Long id; private String name; @Mapping( ...

  5. Codeforces Round #232 (Div. 2) B. On Corruption and Numbers

    题目:http://codeforces.com/contest/397/problem/B 题意:给一个n ,求能不能在[l, r]的区间内的数字相加得到, 数字可多次重复.. 比赛的时候没有想出来 ...

  6. parseInt和valueOf

    .parseInt和valueOf.split static int parseInt(String s) 将字符串参数作为有符号的十进制整数进行分析. static Integer valueOf( ...

  7. Windows下免费、开源邮件服务器hMailServer

    Windows下免费.开源邮件服务器hMailServer 一.Windows下搭建免费.开源的邮件服务器hMailServer 二.邮件服务器hMailServer管理工具hMailServer A ...

  8. UVa 12063 (DP) Zeros and Ones

    题意: 找出长度为n.0和1个数相等.没有前导0且为k的倍数的二进制数的个数. 分析: 这道题要用动态规划来做. 设dp(zeros, ones, mod)为有zeros个0,ones个1,除以k的余 ...

  9. UVa 1347 (双线程DP) Tour

    题意: 平面上有n个坐标均为正数的点,按照x坐标从小到大一次给出.求一条最短路线,从最左边的点出发到最右边的点,再回到最左边的点.除了第一个和最右一个点其他点恰好只经过一次. 分析: 可以等效为两个人 ...

  10. codeforces 333B - Chips

    注意:横向纵向交叉时,只要两条边不是正中的边(当n&1!=1),就可以余下两个chip. 代码里数组a[][]第二维下标 0表示横向边,1表示纵向边. #include<stdio.h& ...