data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
function [A,R,t]=art(P,fsign)
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
%ART Factorize camera matrix into intrinsic and extrinsic matrices
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
%
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% [A,R,t] = art(P,fsign) factorize the projection matrix P
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% as P=A*[R;t] and enforce the sign of the focal lenght to be fsign.
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% By defaukt fsign=1.
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% Author: A. Fusiello, 1999
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
%
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% fsign tells the position of the image plane wrt the focal plane. If it is
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% negative the image plane is behind the focal plane.
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% by default assume POSITIVE focal lenght
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if nargin == 1
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
fsign = 1;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
s = P(1:3,4);
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
Q = inv(P(1:3, 1:3));
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
[U,B] = qr(Q);
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% fix the sign of B(3,3). This can possibly change the sign of the resulting matrix,
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% which is defined up to a scale factor, however.
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
sig = sign(B(3,3));
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
B=B*sig;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
s=s*sig;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% if the sign of the focal lenght is not the required one,
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% change it, and change the rotation accordingly.
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if fsign*B(1,1) < 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
E= [-1 0 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
0 1 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
0 0 1];
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
B = E*B;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
U = U*E;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if fsign*B(2,2) < 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
E= [1 0 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
0 -1 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
0 0 1];
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
B = E*B;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
U = U*E;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% if U is not a rotation, fix the sign. This can possibly change the sign
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% of the resulting matrix, which is defined up to a scale factor, however.
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if det(U)< 0
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
U = -U;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
s= - s;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% sanity check
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if (norm(Q-U*B)>1e-10) & (norm(Q+U*B)>1e-10)
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
error(‘Something wrong with the QR factorization.‘); end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
R = U‘;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
t = B*s;
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
A = inv(B);
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
A = A ./A(3,3);
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% sanity check
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if det(R) < 0 error(‘R is not a rotation matrix‘); end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if A(3,3) < 0 error(‘Wrong sign of A(3,3)‘); end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
% this guarantee that the result *is* a factorization of the given P, up to a scale factor
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
W = A*[R,t];
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
if (rank([P(:), W(:)]) ~= 1 )
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
error(‘Something wrong with the ART factorization.‘); end
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"
data:image/s3,"s3://crabby-images/aa390/aa3903cd961c3d16f931ca431ec935664bbef871" alt="bubuko.com,布布扣"