视觉(3)blepo
视觉(3)blepo
把matlab转成c程序有好办法了,从网上下载了一个函数库blepo,转换为c几乎是一行对一行,openCv经常涉及到的内存申请和释放这里都不用管。高兴!
看看这段程序比较一下差别
matlab的
function [A,R,t]=art(P,fsign)
%ART Factorize camera matrix into intrinsic and extrinsic matrices
%
% [A,R,t] = art(P,fsign) factorize the projection matrix P
% as P=A*[R;t] and enforce the sign of the focal lenght to be fsign.
% By defaukt fsign=1.
% Author: A. Fusiello, 1999
%
% fsign tells the position of the image plane wrt the focal plane. If it is
% negative the image plane is behind the focal plane.


% by default assume POSITIVE focal lenght
if nargin == 1
fsign = 1;
end
s = P(1:3,4);
Q = inv(P(1:3, 1:3));
[U,B] = qr(Q);
% fix the sign of B(3,3). This can possibly change the sign of the resulting matrix,
% which is defined up to a scale factor, however.
sig = sign(B(3,3));
B=B*sig;
s=s*sig;
% if the sign of the focal lenght is not the required one,
% change it, and change the rotation accordingly.
if fsign*B(1,1) < 0
E= [-1 0 0
0 1 0
0 0 1];
B = E*B;
U = U*E;
end
if fsign*B(2,2) < 0
E= [1 0 0
0 -1 0
0 0 1];
B = E*B;
U = U*E;
end
% if U is not a rotation, fix the sign. This can possibly change the sign
% of the resulting matrix, which is defined up to a scale factor, however.
if det(U)< 0
U = -U;
s= - s;
end
% sanity check
if (norm(Q-U*B)>1e-10) & (norm(Q+U*B)>1e-10)
error('Something wrong with the QR factorization.'); end
R = U';
t = B*s;
A = inv(B);
A = A ./A(3,3);

% sanity check
if det(R) < 0 error('R is not a rotation matrix'); end
if A(3,3) < 0 error('Wrong sign of A(3,3)'); end
% this guarantee that the result *is* a factorization of the given P, up to a scale factor
W = A*[R,t];
if (rank([P(:), W(:)]) ~= 1 )
error('Something wrong with the ART factorization.'); end



c++的:
//P 3*4
//A,R 3*3,T 3*1
void art(MatDbl P,
OUT MatDbl *A,OUT MatDbl *R,OUT MatDbl *T,
int fsign=1)
{
MatDbl s;
MatDbl Q;
s=P.GetSubMat(0,3,3,1);
Q=Inverse(P.GetSubMat(0,0,3,3));
// Display(s,"s");
// Display(Q,"Q");
MatDbl U,B;
Qr(Q,&U,&B);
// PrintF(U,"U");
// PrintF(B,"B");
// PrintF(U*B-Q,"U*B-Q");
// PrintF(U*Transpose(U),"U*U'");
if(B(2,2)<0)
{
Negate(B,&B);
Negate(s,&s);
}
if(fsign*B(0,0)<0)
{
double E[9]={-1 ,0 ,0 ,0 ,1 ,0 ,0 ,0 ,1};
MatDbl _E;
_E.FromArray(E,3,3);
B=_E*B;
U=U*_E;
}
if(fsign*B(1,1)<0)
{
double E[9]={1 ,0 ,0 ,0 ,-1 ,0 ,0 ,0 ,1};
MatDbl _E;
_E.FromArray(E,3,3);
B=_E*B;
U=U*_E;
}
if(Determinant(U)<0)
{
Negate(U,&U);
Negate(s,&s);
}
// if(Norm((Q-U*B))>1e-10 && Norm((Q+U*B).ToVector)>1e-10)
// printf("'Something wrong with the QR factorization.'\n") ;
*R=Transpose(U);
*T=B*s;
*A=Inverse(B);
*A= *A * (1.0 / (*A)(2,2));
// PrintF(*A,"A");
// PrintF(*R,"R");
// PrintF(*T,"T");
// PrintF((*A) * (*R),"A*R");
// PrintF((*A) * (*T),"A*T");
}
//[T1,T2,Pn1,Pn2] = rectify(Po1,Po2,d1,d2)
void Rectify(MatDbl Po1,MatDbl Po2,
OUT MatDbl &T1,OUT MatDbl &T2,OUT MatDbl &Pn1,OUT MatDbl &Pn2
/*double d1=0,double d2=0*/)
{
MatDbl A1,R1,t1;
MatDbl A2,R2,t2;
art(Po1,&A1,&R1,&t1);
art(Po2,&A2,&R2,&t2);
MatDbl c1,c2;
c1=-Transpose(R1)*Inverse(A1)*Po1.GetSubMat(0,3,3,1);
c2=-Transpose(R2)*Inverse(A2)*Po2.GetSubMat(0,3,3,1);
// PrintF(c1,"c1");
// PrintF(c2,"c2");
MatDbl v1,v2,v3;
v1=c2-c1;
v2=CrossProduct(Transpose(R1.GetSubMat(2,0,1,3)),v1);
v3=CrossProduct(v1,v2);
// Display(v1,"v1");
// Display(v2,"v2");
// Display(v3,"v3");
v1=(v1 * (1.0/Norm(v1)));
v2=(v2 * (1.0/Norm(v2)));
v3=(v3 * (1.0/Norm(v3)));
double r[9]={v1(0),v1(1),v1(2),
v2(0),v2(1),v2(2),
v3(0),v3(1),v3(2)};
MatDbl R;
R.FromArray(r,3,3);
//Display(R,"R");
MatDbl An1=A2;
An1(1,0)=0;
MatDbl An2=An1;
//PrintF(An1,"An1");
// Display(An1 *(-1.0) * R * c1,"An1 *(-1.0) * R * c1");
Pn1=An1 * PackX(R, (-1.0) * R * c1);
Pn2=An2 * PackX(R, (-1.0) * R * c2);
PrintF(Pn1,"Pn1");
PrintF(Pn2,"Pn2");
T1=Pn1.GetSubMat(0,0,3,3) * Inverse(Po1.GetSubMat(0,0,3,3));
T2=Pn2.GetSubMat(0,0,3,3) * Inverse(Po2.GetSubMat(0,0,3,3));
PrintF(T1,"T1");
PrintF(T2,"T2");
}视觉(3)blepo的更多相关文章
- 理解CSS视觉格式化
前面的话 CSS视觉格式化这个词可能比较陌生,但说起盒模型可能就恍然大悟了.实际上,盒模型只是CSS视觉格式化的一部分.视觉格式化分为块级和行内两种处理方式.理解视觉格式化,可以确定得到的效果是应 ...
- CSS学习笔记——视觉格式化模型 visual formatting model
CSS 视觉格式化模型(visual formatting model)是用来处理文档并将它显示在视觉媒体上的机制.他有一套既定的规则(也就是W3C规范),规定了浏览器该怎么处理每一个盒子.以下内容翻 ...
- 【原】为什么选择iPhone5的分辨率作为H5视觉稿尺寸
[20160105更新:可以用iPhone6分辨率为视觉稿尺寸啦] 又是一年的520网络情人节,深圳这边却下了大雨,这雨只能是单身汉的泪,而对于我来说这一天具有特别的意义,一来怀念父亲,二来对我这种结 ...
- 怪物AI之发现玩家(视觉范围发现系列)
在网上找到一些资料参考,然后写写自己的想法. 这里感谢MOMO等大神. 我们用玩家检测怪物的方法来测,这样比较试用与弱联网游戏,每次在同步玩家的时候来判断玩家与怪物的位置. 这里给出两个处理方式: 1 ...
- 【转】Caffe初试(五)视觉层及参数
本文只讲解视觉层(Vision Layers)的参数,视觉层包括Convolution, Pooling, Local Response Normalization (LRN), im2col等层. ...
- 视觉机器学习笔记------CNN学习
卷积神经网络是第一个被成功训练的多层神经网络结构,具有较强的容错.自学习及并行处理能力. 一.基本原理 1.CNN算法思想 卷积神经网络可以看作为前馈网络的特例,主要在网络结构上对前馈网络进行简化和改 ...
- 视觉机器学习------K-means算法
K-means(K均值)是基于数据划分的无监督聚类算法. 一.基本原理 聚类算法可以理解为无监督的分类方法,即样本集预先不知所属类别或标签,需要根据样本之间的距离或相似程度自动进行分类.聚 ...
- MG--滚动的视觉差效果
#几句代码完成tableView滚动的视觉差 - 效果图 (失帧严重) 和文档树中其他元素的关系 ...
随机推荐
- .Net 执行 Oracle SQL语句时, 中文变问号
带中文的Sql语句在.Net调用时, 中文变问号(可使用 SQL Tracker工具跟踪) 问题: 服务器的字符集与客户端的字符集不一致. 解决方法: 1. 查看服务端的字符集: ...
- WPF 详解模板
在WPF中有三大模板 ControlTemplate,ItemsPanelTemplate,DataTemplate.其中ControlTemplate和 ItemsPanelTemplate是控件模 ...
- Topcoder SRM 630div 2
A:不断的消除两个相邻的相等字符,简单题. 真心不习惯STL.. #include<iostream> #include <string> #include <vecto ...
- RCC 2014 Warmup (Div. 2)
一场很很多HACK的比赛,PREtest太弱了,真的很多坑!平时练习的时候很少注意这些东西了! A:开始一直在模拟,后来发现自己的思路逻辑很乱,果然做比赛不给力! 直接在代码中解释了 #include ...
- Excel每隔两行自动求和一次怎么操作?
今天ytkah得到一份数据,要求进行统计分析,由于是原始数据,还没处理过,数据量有点大,如下图所示(Excel每隔两行自动求和),每天的数字由两项组成,男生的人数.消费值和女生的人数和消费值,数字都在 ...
- NodeJS异常处理uncaughtException篇
很多 NodeJS 的开发者在抱怨异常处理太麻烦,我们会通过一些列博客梳理一下NodeJS中常见的异常处理的手段. 和大多数编程语言一样,在 NodeJS 里可以通过throw抛出一个异常: thro ...
- ASP.NET Web.Config配置数据库连接的一种方法
所谓的webConfig配置数据库连接就是在里面某个特定名称的节点中写下ADP.NET中的ConnectString,就这么简单 1.首先在Web.Config文件里写下数据库连接字符串. <c ...
- Webpack教程二
Webpack教程一 开发技巧 启用source-map 现在的代码是合并以后的代码,不利于排错和定位,只需要在config中添加 ... devtool: 'eval-source-map', .. ...
- java集合之ArrayList的实现原理
1. ArrayList概述: ArrayList是List接口的可变数组的实现.实现了所有可选列表操作,并允许包括 null 在内的所有元素.除了实现 List 接口外,此类还提供一些方法来操作内部 ...
- CSS3做小三角形
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAXgAAAA2CAIAAABC2hVZAAAgAElEQVR4nKzcd3cbV57web+1p20FW8