Modeling shape, motion, and flexion of non-rigid 3D objects in a sequence of images

Information

  • Patent Application
  • 20030072482
  • Publication Number
    20030072482
  • Date Filed
    February 22, 2001
    23 years ago
  • Date Published
    April 17, 2003
    21 years ago
Abstract
A method models a non-rigid three-dimensional object directly from a sequence of images. A shape of the object is represented as a matrix of 3D points, and a basis of possible deformations of the object is represented as a matrix of displacements of the 3D points. The matrices of 3D points and displacements forming a model of the object. Evidence for an optical flow is determined from image intensities in a local region near each 3D point. The evidence is factored into 3D rotation, translation, and deformation coefficients of the model to track the object in the video.
Description


FIELD OF THE INVENTION

[0001] The present invention relates generally to computer vision, and more particularly to a method for modeling shape, motion, and flexion of deformable objects in a sequence of images



BACKGROUND OF THE INVENTION

[0002] The relation between point correspondences in an optical flow to a shape of a three-dimensional (3D) rigid-body for the purpose of modeling has been extensively described, see, for example, Barron et al., “The feasibility of motion and structure from noisy time-varying image velocity information,” IJCV, 5(3):239-270, December 1990, Heyden et al., “An iterative factorization method for projective structure and motion from image sequences,” IVC, 17(13):981-991, November 1999, Stein et al., “Model-based brightness constraints: On direct estimation of structure and motion,” PAMI, 22(9):992-1015, September 2000, Sugihara et al., “Recovery of rigid structure from orthographically projected optical flow,” CVGIP, 27(3):309-320, September 1984, and Waxman et al., “Surface structure and three-dimensional motion from image flow kinematics,” IJRR, 4(3):72-94, 1985.


[0003] Most modern methods for extracting 3D information from image sequences (e.g., a video) are based on the Tomasi & Kanade “rank theorem” as described by Tomasi et al. in “Shape and motion from image streams under orthography: A factorization method,” International Journal of Computer Vision, 9(2):137-154, 1992. Matrices used for orthographically projected rigid-body motion have rank-3. That is, the matrices can be expressed as three linearly independent vectors. It is well known that the matrices can be factored into shape and projection via a thin single value decomposition (SVD). Bregler et al. in “Recovering non-rigid 3D shape from image streams,” Proc. CVPR, 2000, describe an extension to k-mode non-rigid motion via rank-3k double-SVD. To date, all such factorization methods require successful point tracking data as input.


[0004] Non-rigid two-dimensional (2D) modeling methods for object matching or tracking are also known. These are either based on eigenspace representations of variability of shape, see Black and Yacoob, “Eigentracking: Robust matching and tracking of articulated objects using a view-based representation,” IJCV, pages 63-84, 1998, Cootes et al., “Active appearance models,” Proc. ECCV, volume 2, pages 484-498, 1998, and Covell, “Eigen-points: Control-point location using principal component analysis,” Proc. 2nd IWAFGR, 1996, or parametric representations of variability, see Black and Jepson “Tracking and recognizing rigid and non-rigid facial motions using local parametric models of image motion,” Proc. ICCV, 1995, and Sclaroff et al., “Active blobs,” Proc. ICCV, 1998.


[0005] Most of these methods require a large number of hand-marked images for training the model. Covell's eigenpoint tracker employs an eigen-basis to relate affine-warped images of individual facial features to hand-marked fiduciary points on those features. Black and Yacoob described parametric 2D models of flow for non-rigid facial features, and Black and Jepson also use an eigen-basis of views for 2D tracking of non-rigid objects. Cootes et al. employ statistical models of 2D shape to handle variation in facial images due to pose and identity, but not expression. Many of these approaches require robustizing methods to discard outliers. Clearly, there is a price to pay for using 2D models of what is essentially 3D variability.


[0006] Bascle et al. in “Separability of pose and expression in facial tracking and animation,” Proc. ICCV, 1998, describe an interesting compromise between 2D and 3D tracking by factoring the motion of tracked contours into flexion and 2D affine-with-parallax warps via SVD.


[0007] None of the prior art addresses the full problem of tracking a non-rigid 3D object in video and recovering its 3D motion and flexion parameters, nor recovering such parameters directly from variations in pixel intensities. It is desired to provide an improved method for acquiring models and their motions from a sequence of images. The method determines 3D motion and flexion directly from intensities in the images without losing information while determining intermediate results. The method should minimize uncertainty, and prior probabilities should give confidence measures.



SUMMARY THE INVENTION

[0008] The invention provides non-rigid 3D model-based flow and model acquisition from a sequence of images in the context of linear deformable models and scaled orthography. The method according to the invention obtains maximum likelihood and maximum posterior 3D motion and flexion estimators that operate directly on image intensity gradients. The method minimizes information loss in matrix operations and manipulates the error norms of least-squares operations so that calculations are most influenced by evidence from the most informative parts of each image. The invention also provides model refinement for increasing the detail and accuracy of models, allowing very detailed models to be refined from very generic models. Due to the minimized information loss, all the described determinations are fast, accurate, and robust in the face of noise and other degradations.


[0009] More specifically, the invention provides method that models a non-rigid three-dimensional object directly from a sequence of images. A shape of the object is represented as a matrix of 3D points, and a basis of possible deformations of the object is represented as a matrix of displacements of the 3D points. The matrices of 3D points and displacements forming a model of the object. Evidence for an optical flow is determined from image intensities in a local region near each 3D point. The evidence is factored into 3D rotation, translation, and deformation coefficients of the model to track the object in the video.







BRIEF DESCRIPTION OF THE DRAWINGS

[0010]
FIG. 1 is a diagram of an object modeled by a matrix of 3D points that can be displaced for changes in shape and pose of the model;


[0011]
FIG. 2 is a diagram of the projection which models the flexion and posing of the object;


[0012]
FIG. 3 is a diagram of optical flow in a sequence of images in terms of optical flow intensities;


[0013]
FIG. 4 is a diagram of optical flow equated with model flexion and posing;


[0014]
FIG. 5 is a diagram of solutions for various model variables; and


[0015]
FIG. 6 is a flow diagram of data information flow and processes according to the invention.







DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0016] Introduction


[0017] The invention provides a linear, model-based object tracking method. The method tracks a non-rigid, three-dimensional (3D) object in a sequence of images. The image sequence can be composed of 2D data, e.g. a video, or 3D volumetric data, e.g., a time-series of volume data sets. The method determines 3D motion and flexion, i.e., deformation coefficients, directly from intensity values in the images without information-lossy intermediate results. A Bayesian framework manages uncertainty, and accommodates prior probabilities to give confidence measures.


[0018] The invention provides accurate and robust closed-form motion estimators by minimizing information loss from non-reversible matrix operations such as divisions, inner products and least-squares calculations such as divisions. These matrix operations are either eliminated, or else, where unavoidable, delayed as long as possible and then performed with appropriate error norms. For model acquisition, the method according to the invention refines a generic model to fit a non-rigid 3D object in the sequence of images. As an advantage, the described method for model acquisition, model tracking, and model refinement can be applied to a low-quality, low-resolution sequence of images.


[0019] Overview


[0020] Knowledge of 3D shape and deformation of a non-rigid 3D object is a valuable constraint in tracking the object in a sequence of images. A sequence of images of modest number should contain sufficient information to recover such a model. Herein, the tracking and refinement of a model of a non-rigid 3D object, observed in a low-resolution sequence of images, is described in the context of a scaled orthographic camera.


[0021] Model-Based Optical Flow


[0022] As shown in FIGS. 1, 2 and 6, the invention provides a linear method for determining 3D flex-constrained optical flow in a sequence of 2D or 3D images. FIG. 1 shows the basic “cloud-of-points” 102 model 100, FIG. 2 shows the projection 200 of the model 100, and FIG. 6 shows the motion estimation 600 and refinement 601 steps of the model. The present method enables real-time monocular 3D tracking and model refinement. The model of the non-rigid 3D object, e.g., a face, is expressed in the form of the 3D cloud-of-points 100 describing the average 3D shape 202 and its modes of deformation 203-205. A deformation 203-205 defines a unique 3D displacement for each point. A flexion 207, determined by step 606 of the motion refinement loop 601, describes the amplitude of a deformation. For example, there may be a deformation that moves the lips of the face model. That deformation may be flexed positively or negatively to open or close the mouth. A wide variety of shape changes can be modeled by combining several deformations, each flexed a different amount.


[0023] The described method solves directly for the object's translation 206, rotation 201, and flexion 207 in each image. The flexion also caries scale information as described below. It also gives a confidence measure in the form of a posterior probability 604. Maximum likelihood and Bayesian maximum a posterior (MAP) motion (652) and flexion (654) are determined directly from intensity gradients without information-lossy intermediate results, i.e., without estimating the optical flow. In other words, the preferred method uses actual optical flow evidence, and not optical flow estimates. The method also accommodates motion prior probabilities (priors) 614, and can exploit multi-image and multi-view constraints.


[0024] Maximizing Information State


[0025] The invention uses matrix transforms to maximize an information state in calculations. It is well known that non-reversible matrix operations, such as multiplication, division, and thin SVD, reduce the information state and consequently increase errors. For example, a multiplication's inner product reduces information state because two vectors are reduced to a single value. If the vectors represent measurements with some associated uncertainty, a conventional inner product can actually yield the wrong value. Division and SVD are particularly troublesome because results obtained by these matrix operations are correct only in a least-squares sense. This implies a spherical error norm, which is known to be the wrong error norm for many computer vision problems.


[0026] Therefore, the invention arranges sequences of matrix operations so that the information state increases rather than decreases. This is done principally by a judicious substitution of reversible analogues, for example, substituting Kronecker products for matrix multiplications, thereby eliminating inner products. This enables the invention to eliminate, or at least maximally delay, least-squares operations until the information state must finally be reduced to give the shape, motion, and flexion. To do this, several useful identities are described below. These entities enable the present method to factor information out of expanded arrays under arbitrary elliptical (Mahalonobis) error norms.


[0027] Robust Tracking Without Features


[0028] “Image uncertainty” refers to uncertainty about the exact value of a measurement, for example, the location of a “landmark” in an image. Sources of uncertainty are blur, sensor noise, and the limited dynamic range and sampling rate of the imaging sensor. When quantifiable, image uncertainty can carry as much information as the measurement itself. While tracking the non-rigid 3D objects in the sequence of video images, the method of the invention propagates image uncertainties back through the projection model until the uncertainties can be resolved via interaction with global geometric invariants. The resulting tracker uses whatever information is available in an arbitrary sampling of image regions and gives accurate motion, even when most of these regions are low quality, e.g., textureless, or self-occluded.


[0029] Acquiring Model Geometry


[0030] The described method also provides a novel solution for estimating the 3D linearly deformable model for the non-rigid object in the sequence of images. Model refinement 626 combines a poorly fit model with its tracking residuals to yield a more accurate model with increased detail, i.e., increasing the number of “points” in the “cloud.”


[0031] Outline


[0032] To start, an object tracker applies a geometry-based model for 3D motion and flexion to an intensity-based description of 2D optical flow in the sequence of images. The optical flow is eliminated, and motion parameters are derived directly from the optical flow intensities. All determinations are made in sub-spaces of the 3D motion and flexion yielding a robust 3D tracker. Image uncertainty information is propagated throughout the determinations This increases accuracy and naturally leads to a Bayesian formulation. Finally, a solution for the geometry of the model is described.


[0033] The following notations for matrix operations are used in this description, see, Golub et al., “Matrix Computations,” Johns Hopkins U. Press, 1996, and Magnus et al., “Matrix differential calculus with applications in statistics and econometrics,” Wiley, 1999.
1SymbolMeaning{circle over (x)}Kronecker ProductHadamard ProductTiled AdditiontrATraceA†PseudoinverseATVector-Transpose


[0034] Flex and Flow


[0035] Object Flex


[0036] As shown in FIGS. 1 and 2, the invention expresses the base shape 202 of the model 100 of the non-rigid 3D object 101 in a sequence of images by a matrix of 3D points 102. The example object modeled is a face. It should be noted that the clouds of points can be located in three-dimensions.


[0037] As shown in FIG. 2, the shape and motion, i.e., the projection or pose P 200, of the model 100 onto each image of the sequence of images can be expressed by




P=R


d×3
(B3×n+(Cl×k{circle over (x)}I3)D3k×n)⊕T2×l,  (1)



[0038] where R 201 is an orthographic projective rotation matrix, d the number of dimensions, B 202 is the matrix of the 3D points 102, C 207 is a vector of the flexion, i.e., deformation coefficients, I is the identity matrix, D 205 is a vector of k linearly separable deformations of the model, and T 206 is a 2D translation matrix. The deformations 203-205 are weighted by the flexion coefficients 207. If the rotation matrix R drops the depth dimension, then the projection is orthographic, and if the basis set of deformations includes the base shape, then the orthographic projection is scaled.


[0039] Optical Flow


[0040] As stated above, the motion and flexion are determined from intensity gradients in the images. As shown in FIG. 3, the 2D or 3D optical flow evidence ({right arrow over (F)}←Y/X) 300 of a small local region (r) 310 of the object in two consecutive images I 311 and J 312 of the sequence of images 320, can be determined (flow calculation) 656, to a first-order, by image intensity values that consider:
1spatialvariationX=.Rg(x)Tg(x)(x))301;temporalvariationY=.R[I(x)-J(x)]g(x)(x)302,


[0041] and


[0042] spatial gradients g(x)=[∂x(I+J),∂y(I+J)] 303


[0043] of the intensities in the images I and J, see Lucas et al. “An Iterative Image Registration Technique with an Application to Stereo Vision,” International Joint Conference on Artificial Intelligence, pages 674-679, 1981. Multiple (n) regions R 310 can be concurrently tracked by extending the vectors F and Y, and diagonally stacking the matrix X.


[0044] However, it is well known that the optical flow 300 in the small local regions R 310 is an unreliable indicator of actual physical motion without some global constraints to make the n concurrent estimations mutually dependent.


[0045] Motion Estimation


[0046] Therefore, as shown in FIG. 4, the method according to the invention constrains 400 the optical flow from image I to J to lie in the sub-space of allowable deformations and 3D motion. Without loss of generality, the shape and deformations can be made zero-mean so that the mean motion of all points 102 of the model 100 gives the 2D or 3D displacement of the shape of the object 101. This allows the method to determine 620 the translation T 206. Translation is then be removed 660 by shifting the two consecutive images I and J into alignment. A new temporal variation Y 401 can be determined 622 from the aligned regions of the two images 311-312.


[0047] If matrix B 202 of points 102 represents the base shape of the object 101 in the image I 311, the matrix D 205 the deformations, the matrix C 207 the unknown flexion (deformations coefficients) from image I to image J, and the matrix O the 2D orthographic projector—so that {overscore (B)}≐OB, then the optical flow F 300 can also be expressed as:




vec
(R(B+(C{circle over (x)}I3)D)−{overscore (B)})T=F=Y′/X=PI−PJ 400,  (2)



[0048] that is, the difference between the projections in the consecutive images 311-312.


[0049] Equation (2) can be rewritten in simplified form as




vec
(R(C′{circle over (x)}I3)D′)TX=(Y′+(vec{overscore (B)})TX).  (3)



[0050] The use of vec and {circle over (x )} allows the left-hand side of the equation to be expressed in product form, which enables solving for any one of the unknowns with a single division.


[0051] As shown in FIG. 5, the method according to the invention solves for various variables (T, C, R) 501-503 that are used to model shape, motion, and flexion of the non-rigid object 101 in the sequence of images 320, alone and in various combinations. As an advantage, the invention uses a minimum number of inner product and least-square operations to maximize an information state, and minimize an uncertainty (error norm Q 504) as described in greater detail below.


[0052] Naive Solution


[0053] First the rotation and the flexion are isolated by:
2(CR)2×3(k+1)=vec2×n((Y+(vecB_)TX)/X)/D=(vec2×n(Y/X)+B_)/D(4)


[0054] As stated above, it is desired to reduce the number of the divisions. The minimization of divisions is described below. To extract the rotation and the flexion, the left-hand side of equation (4) is arranged to form a rank-1 matrix




M


6×(k+l)
≐((C′{circle over (x)}R)T)(3)=[Rxx,Rxy, Rxz, Ryx, Ryy, Ryz]TC′



[0055] If the matrix M is noiseless, the value vec {circumflex over (R)}T is the first column of matrix M, and Ĉ←(vec{circumflex over (R)})\M.


[0056] Orthonormal Decomposition


[0057] A noisy matrix can be factored as follows. The factorization of (vec{circumflex over (R)}T)Ĉ←M, i.e., the vectorized orthonormal matrix times the deformation coefficient matrix, is usually performed by a thin
3SVDUSVTSVD1M


[0058] followed by orthonormalization of (vec3U)Tto yield {circumflex over (R)}, then corrective redivision Ĉ′←(vec{circumflex over (R)}T)\M. This finds the rotation closest to the vector that best divides M, which is generally not the best rotation available from M. Because M is small, the SVD may incorporate noise rather than suppress it, especially noise that is not independent and identically distributed (i.i.d.) Gaussian random variables.


[0059] Instead, the preferred method uses an orthonormal decomposition 650 that directly recovers the rotation R 201 more accurately and econonically than standard SVD-based methods. Geometrically, matrix R is the rotation that brings the axes in OT, scaled by Ĉ′, into alignment with the columns of the top and bottom halves (M, M) of matrix M.


[0060] This can be expressed as an absolute orientation, see Horn et al., “Closed form solution of absolute orientation using orthonormal matrices,” J. of the Optical Society A, 5(7):1127-1135, 1988.


[0061] Let A≐(O{circle over (x)}ĈT)[M↑,M]=vec3(MĈ′T), Then, {circle over (R)}←(A/{square root}{square root over (ATA)})T−1/2VTAT, using the 2D eigen-decomposition VΛVT=ATA. Thus, the O(k3) SVD is replaced with an 0(1) eigenproblem.


[0062] This requires an initial determination of the deformation coefficients, e.g., C′←(sgn(Mcol(l)TCT∘{square root}{square root over (11×6(M∘M))2)}, and yields Ĉ′←(vec{circumflex over (R)}T)\M . The final value is relatively insensitive to the value, e.g., using Ĉ′=1 works well.


[0063] This direct factoring, as done by the present invention, gives a best-fit rotation rather than a rotation closest to the best-fit factor of the noisy matrix M, and thus outperforms the standard SVD plus orthonormalization process, particularly, as noise increases. At high noise levels, the orthonormal decomposition is substantially the correct rotation with p<0.01 levels of statistical significance for matrices of 2D projections generated with random rotations, k coefficients, and noise sources.


[0064] Motion Refinement


[0065] Due to the first-order nature of the formulation of the optical flow, for large motion, it may be desirable to recalculate the temporal variation (Y′), and the spatial variation X from a image region offset by the optical flow F implied in equation (2) when the optical flow is symmetric. The recalculation is done in optional flow determination step 628.


[0066] Then, the matrices R and C can be refined 652, 654 by the substituting Y′→YΔY′+(vec{circumflex over (F)})T X. While doing this, one can determined {circumflex over (R)} and Ĉ from each other by:
4R^(vec2×n(Y/X)+B_)/((CI3)D)(5)




Ĉ
←(+(vec({overscore (B)}−RB))TX)/(((Ik{circle over (x)}R)D)(2)TX)  (6)



[0067] using the identity Aixj{circle over (x)}B=CA←(vecj((vecB)\vecmnC(m)))T.


[0068] Equation (6) is the first example of an estimator that constrains the optical flow of the sequence of images to be oriented in the appropriate sub-space, e.g., the flexion as expressed by the matrix C 207.


[0069] By reshaping and multiplicative canceling, three separate divisions, as used in the standard practice of equation (3), have been converted in equations (5-6) into a single division by a product, saving the least-squares operation for last, thereby minimizing the error in the information state.


[0070] The dividend and divisors of the so-structured estimators are called “evidence matrices.” These are described in greater detail below with respect to incorporating uncertainty information, developing single-division, and sub-space-constrained versions of equations (4) and (5).


[0071] Scaled Orthography


[0072] Equation (4) above and equation (7) below are scaled orthographic, with the first element of the matrix C 207 giving the change in scale. Equation (6) can be made scaled orthographic via a substitutions k→k+1, D→D′.


[0073] Oblique and Occluded Regions


[0074] On a image-by-image basis, backfacing and silhouette-edge regions can be discounted by adding information about surface normals to the model. The contribution of each flow window to X and Y can be weighed by max(0, z), where z is the depth component of its associated unit normal. For occluded points, the translation vector {circumflex over (T)} must be refined as well.


[0075] Propagating Image Uncertainties


[0076] Assuming Gaussian noise in the images, the uncertainty of an unconstrained optical flow (F=Y/X) is described by a full-covariance 2D normal probability distribution function with a posterior inverse covariance Σ−1=X. As stated above, the division Y/X discards this uncertainty information. In contrast, the method according to the invention propagates this uncertainty information forward so that the information can interact with known invariants until the information state of the model is finally reduced to give the final shape, motion, and flexion.


[0077] Division with an Elliptical Error Norm


[0078] Generally, when solving problems of the form E=JK−L=0, one replaces the implicit spherical error norm tr(ETE) with an elliptical error norm (vecE)TΣ−1(vecE) having a symmetric covariance Σ. The vecE enables arbitrary covariance constraints between all variables, even when the variables are in different columns of E. Setting the derivative of the matrix E to zero, the solution must satisfy 0=(vec(JK−L))TQ, where Q 504, a factor of Σ−1, determines the error norm that the solution minimizes, i.e., Q=Ispherical error norm.


[0079] Because the uncertainty information specifies an elliptical error norm, Q={square root}{square root over (Σ)}, i.e., the columns of Q 504 are the scaled eigenvectors of Σ−1 such that




Q=V{square root}{square root over (Λ)}, QQ


T


=VΛV


T
and VVT=VTV=I.



[0080] The elliptical error norm Q 504 rotates the directions of the greatest and least uncertainty of the problem into axis-alignment, and scales each axis proportional to its certainty. The identity (JK)=(I{circle over (x)}J)vecK =(KT{circle over (x)}Irows(J))vecJ yields solutions




{circumflex over (K)}←vec


rows(K)
((QT(Icols(K){circle over (x)}J))\QTvecL, and





Ĵvec


rows(J)
((QT(KT{circle over (x)}Irows(J)))\(QTvecL)).



[0081] Certainty-Weighted Estimators


[0082] Because Σ−1X is 2×2 block diagonal, Q 504 can be determined in step 612. The temporal gradient of the image information, warped into certainty-weighted data space by an uncertainty transform 658, is calculated as Y′″Y″QΛ−l (covariance-weighted flow statistics). Removing the global translation 660 yields weighted and centered statistics 622. The uncertainty-propagating forms of constraint equations (4-6) determined in steps 650, 642, 654 are
5Mvec6×(k+1)[(Y′′′+(vecB_)TQ)/((DI2)Q)](7)




Ĉ
←(Y′″+(vec({overscore (B)}−RB))TQ)/(((IK{circle over (x)}R)D)(2)TQ), and  (8)


6






R
^




vec

2
×
3


[



(


Y
′′′

+



(

vec


B
_


)

T


Q


)

/

(


(


(


(


C




I
3


)



D



)



I
2


)


Q

]


,






(
9
)










[0083] respectively.


[0084] Consequently, as intended, all optical flow determinations are now performed in the sub-spaces of rotation and flexion. A similar, simpler form gives the translation vector {circumflex over (T)}.


[0085] Equations (7-9) give much better performance than the prior art estimators, and are numerically better behaved. Their numerical advantages can further be leveraged by making the deformations in D′ unit length so that numerical accuracy is not concentrated in any one flexion.


[0086] Fast Approximation


[0087] At the risk of exaggerating certainties, one can substitute Q X to obtain equation (6) and
7M=vec6×(k+1)[(vecY+XvecB_)T/((DI2)XR^=vec2×3[(vecY+XvecB_)T/((((CI3)D)I2)X)].


[0088] Bayesian Formulation


[0089] Residuals and Likelihoods


[0090] Given an optical flow {circumflex over (F)}←((C′{circle over (x)}R)D′−{overscore (B)})⊕T, the unaccounted temporal intensity information is H≐Y−(vec{circumflex over (F)})T X intensity-levels times pixel-lengths. Working forward from the Gaussian uncertainty model of low-level optical flow, the tracking residue 604, or Mahalonobis distance determined during error calculation 605, is {square root}{square root over (HXHT)} intensity-levels per image. This implies that the likelihood (residual & probability) 604 of the optical flow evidence, given the motion, p(X,Y|R,C,T)=e−(HX−lHT+2nlog2x−log|x|)/2. Each of the equations (8-9) yields the optimum of p in its subspace.


[0091] Priors and Maximum a Posterior Probabilities


[0092] Consider a Gaussian prior probability pC′(C′) on scaling and the flexion, with a mean of μC′and a covariance of ΣC′. Because the log-posterior probability is a sum balancing log-likelihood against the log-prior probability, the maximum a posteriori estimator
8C^MAP=.argmaxCp(CX,Y,R,T,μC,C)


[0093]

654
is constructed by concatenating the following underlined terms to the evidence matrices of the maximum likelihood:
9C^MAP[Y′′′+(vec(B_-RB))TQ,μCQC_]/[((Ik+1R)D)(2)TQ,QC_],(10)


[0094] where QC′ are scaled eigenvectors of
10C-1


[0095] satisfying
11QCT=C-1.


[0096] MAP estimators can similarly be constructed for translation and rotation.


[0097] Multi-Image/Multi-View Constraints


[0098] Multi-image and multi-view constraints are determined as follows. Choose any set of previously processed images and produce virtual images by warping the processed images into the pose of the image I using the motion and flexion as described above. Then, the multi-image motion/flexion estimators for the next image J are built by concatenating the evidence matrices while comparing each virtual image with image J. The matrices are already weighted by their certainties, so the result is a proper expectation instead of a mere average. Even though the tendency of the optical flow to drift has been reduced by the geometric constraints of the model, multi-image estimators can further stabilize the texture against the inherent drift. Evidence from multiple cameras can be combined in the flex estimator by similar concatenation.


[0099] MODEL ACQUISITION


[0100] Model Refinement


[0101] When rotation (652) and flexion (654) are determined for many images, the model D′, including B, can be refined to better fit the object in the sequence of images as follows. Let R0→t and C0→t be the rotation and flexion taking image 0 into image t, and N0←l≐C′0→t{circle over (x)}R0→t−C′0→t−l{circle over (x)}R0→t−l. Let Ft−l→t be the optical flow that takes image t−1 into image t, and let Tt−l→t be the translational component of the optical flow. Then, equation (2) yields D′=[t−lTN0→t]/[t−lTFt−l→t−Tt−l→t], where signifies vertical stacking.


[0102] If this equation is rewritten using the uncertainty information, then one obtains a solution for the model that minimizes tracking residuals for the motion:
12D^vec3(k+1)×n[[t=1TQt-1tT(InN0t)]\[t=1TQt-1tTvec(Ft-1t-Tt-1tT)]](10)


[0103] where Q and Λ are those of equations (7-8). This model refinement 626 takes the output of one tracking run and produces a better model suitable for another run of tracking. One can determine the shape of the object directly from optical flow gradients by replacing
13Qt-1tTvec(Ft-1t-Tt-1tT)


[0104] with
14Λt-1t-1Qt-1tTvec(Yt-1t-(11×nTt-1tT)Xt-1t).


[0105] However, this shape can be sensitive to brightness constancy violations, e.g., specularities. It is possible to constrain equation (11) to retain the x, y coordinates of the original model and to solve only for depth and deformations by stacking heavily weighted rows with frontal-plane-only rotations.


[0106] Adding Detail


[0107] Model refinement 626 makes it possible to increase the level of detail of the model. New points can be interpolated, extrapolated, tracked, and refined to get corrected depths and deformations for all points.


[0108] This invention is described using specific terms and examples. It is to be understood that various other adaptations and modifications may be made within the spirit and scope of the invention. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the invention.


Claims
  • 1. A method for modeling a non-rigid three-dimensional object directly from a sequence of images, comprising: representing a shape of the object as a matrix of 3D points, and a basis of possible deformations of the object as a matrix of displacements of the 3D points, the matrices of 3D points and displacements forming a model of the object; determining evidence for an optical flow from image intensities in a local region near each 3D point; and factoring the evidence into 3D rotation, translation, and deformation coefficients of the model to track the object in the video.
  • 2. The method of claim 1 wherein the evidence includes local spatial variation, temporal variation, and spatial gradients of image intensities in the local regions in each image of the sequence.
  • 3. The method of claim 2 wherein the spatial variation at any point
  • 4. The method of claim 1 wherein an orthographic projection of the model onto each image of the video is expressed by
  • 5. The method of claim 4 Wherein the matrix of displacements includes a matrix of shape to handle scaling of the object in the video.
  • 6. The method of claim 1 wherein the rotation, translation, and deformation are determined with a minimal number of inner product and least-squares operations to minimize information loss, and all least-squares calculations utilize elliptical error norms derived from the evidence.
  • 7. The method of claim 1 wherein the optical flow determined from the evidence for local regions in the sequence of images is constrained to be globally consistent with the model.
  • 8. The method of claim 1 wherein the model is derived directly from a generic model and residuals obtained by using the generic model to track the object in video using the evidence, rotation, translation, and deformation.