⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vgg_t_from_p.m

📁 多视图几何三维重建程序
💻 M
字号:
% T = vgg_T_from_P(P)  Trifocal tensor from 3 camera matrices.
%
% P ... cell (3), camera matrices
% T ... double (3,3,3) 
%
% For 3 corresponding lines l1..l3 (each of size (1,3)) in cameras P1..P3 it is
%         for i=1:3, l1(1,i) = l2*T(:,:,i)*l3'; end
% up to scale.
%
% T is obtained by with unique absolute scale. In detail, for any cameras P{1:3} and 
% scene line L (4-by-4 Pluecker matrix, L+L'=0, vgg_contreps(L)*L=0), if
%
%   for i=1:3, l{i} = vgg_contreps(P{i}*L*P{i}'); end
%   T = vgg_T_from_P(P);
%   for i=1:3, l1(1,i) = l{2}*T(:,:,i)*l{3}'; end
%
% then
%
%   l1 ==  l{1}*(l{3}*e32) == -l{1}*(l{2}*e23)
%
% where e32 = P{3}*vgg_C_from_P(P{2}), e23 = P{2}*vgg_C_from_P(P{3}) are epipoles.

function T = vgg_T_from_P(P)

T(:,:,1) = P{2}*vgg_contreps(P{1}(2,:)'*P{1}(3,:)-P{1}(3,:)'*P{1}(2,:))*P{3}';
T(:,:,2) = P{2}*vgg_contreps(P{1}(3,:)'*P{1}(1,:)-P{1}(1,:)'*P{1}(3,:))*P{3}';
T(:,:,3) = P{2}*vgg_contreps(P{1}(1,:)'*P{1}(2,:)-P{1}(2,:)'*P{1}(1,:))*P{3}';

return

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -