Trifocal tensor

In computer vision, the trifocal tensor (also tritensor) is a 3×3×3 array of numbers (i.e., a tensor) that incorporates all projective geometric relationships among three views. It relates the coordinates of corresponding points or lines in three views, being independent of the scene structure and depending only on the relative motion (i.e., pose) among the three views and their intrinsic calibration parameters. Hence, the trifocal tensor can be considered as the generalization of the fundamental matrix in three views. It is noted that despite that the tensor is made up of 27 elements, only 18 of them are actually independent.

Contents

Correlation slices

The tensor can also be seen as a collection of three rank-two 3 x 3 matrices {\mathbf T}_1, \; {\mathbf T}_2, \; {\mathbf T}_3 known as its correlation slices. Assuming that the projection matrices of tree views are {\mathbf P}=[ {\mathbf I} \; | \; {\mathbf 0} ] and {\mathbf P}^'=[ {\mathbf A} \; | \; {\mathbf a}_4 ], \; {\mathbf P^{''}}=[{\mathbf B} \; | \; {\mathbf b}_4 ], the correlation slices of the corresponding tensor can be expressed in closed form as {\mathbf T}_i={\mathbf a}_i {\mathbf b}_4^t - {\mathbf a}_4 {\mathbf b}_i^t, \; i=1 \ldots 3, where {\mathbf a}_i, \; {\mathbf b}_i are respectively the ith columns of the camera matrices. In practice, however, the tensor is estimated from point and line matches across the three views.

Trilinear constraints

One of the most important properties of the trifocal tensor is that it gives rise to linear relationships between lines and points in three images. More specifically, for triplets of corresponding points {\mathbf x} \; \leftrightarrow \; {\mathbf x}^{'} \; \leftrightarrow  \;{\mathbf x}^{''} and any corresponding lines {\mathbf l} \; \leftrightarrow \; {\mathbf l}^{'} \; \leftrightarrow  \;{\mathbf l}^{''} through them, the following trilinear constraints hold:


({\mathbf l}^{'t} \left[{\mathbf T}_1, \; {\mathbf T}_2, \; {\mathbf T}_3 \right] {\mathbf l}^{''}) [{\mathbf l}]_{\times} = {\mathbf 0}^t

{\mathbf l}^{'t} \left( \sum_i x_i {\mathbf T}_i \right) {\mathbf l}^{''} = 0

{\mathbf l}^{'t} \left( \sum_i x_i {\mathbf T}_i \right) [{\mathbf x}^{''}]_{\times} = {\mathbf 0}^t

[{\mathbf x}^']_{\times} \left( \sum_i x_i {\mathbf T}_i \right) {\mathbf l}^{''} = {\mathbf 0}

[{\mathbf x}^']_{\times} \left( \sum_i x_i {\mathbf T}_i \right) [{\mathbf x}^{''}]_{\times} = {\mathbf 0}_{3 \times 3}

where  [\cdot]_{\times} denotes the skew-symmetric cross product matrix.

Transfer

Given the trifocal tensor of three views and a pair of matched points in two views, it is possible to determine the location of the point in the third view without any further information. This is known as point transfer and a similar result holds for lines.

References

External links