This invention related to the field of facial feature detection and tracking in still and video images, and, in particular, presents a solution for facial feature detection and tracking using the supervised descent method.
The problem addressed by the present invention is real-time, accurate facial feature detection and tracking in unconstrained images and videos. There are existing algorithms for detecting landmarks in images however; the prior art methods lack accuracy, robustness and can be too slow for real-time applications.
U.S. Pat. No. 8,121,347 (“System and Method for Detecting and Tracking Features in Images”) proposes the formation of clustered shape subspaces corresponding to a set of images so that shape changes nonlinearly due to perspective projection and complex 3D movements. Then a traditional landmark localization algorithm is used on each of the clusters. There are several drawbacks of the proposed method: (1) it uses a model, and cannot represent asymmetric expressions well; (2) the method is slow because it has to search for each landmark along the diagonal; (3) the method to create the model has to cluster the data and hence is prone to local minima; and (4) it is unclear that richer and more discriminative features can be added. Instead the proposed method uses richer features and proposes a new and better algorithm for landmark localization.
U.S. Pat. No. 8,103,058 (“Detecting and Tracking Objects in Digital Images”), presents a solution for detecting and tracking objects in digital images which includes selecting a neighborhood for each pixel under observation, the neighborhood being of known size and form, and reading pixel values of the neighborhood. However, the described method does not work well for deformable objects, such as faces.
The problem of facial feature detection and tracking can be formulated as a non-linear least square problem. To solve non-linear least squares problems it is generally accepted that 2nd order descent methods are the most robust, fast and reliable approach for nonlinear optimization of a general smooth function. However, in the context of facial feature detection and tracking, 2nd order descent methods have two main drawbacks: (1) The function might not be analytically differentiable (e.g., when using histogram of gradients (HoG) features) and numerical approximations are impractical; and (2) The Hessian might be large and not positive definite.
It would therefore be desirable to provide a method of detecting and tracking facial features that addresses the identified deficiencies of the prior art methods.
The limitations and non-effectiveness of the prior art have been overcome by the present invention as described below. The present invention is used in conjunction with a digital still or video camera or a pre-recorded video. Given an image containing one or more faces, the present invention will detect and track facial landmarks in each of the faces. This invention can be used in many applications, including, but not limited to, face editing, facial expression analysis, face recognition, gaze estimation, facial expression transferring and any application that has to do with facial image analysis.
The invention formulates the facial feature detection and tracking as a non-linear least squares (NLS) problem and describes the “Supervised Descent Method” (SDM), a method for minimizing the NLS function. During training, the SDM learns a sequence of descent directions that minimizes the mean of NLS functions. In use, SDM minimizes the NLS objective using the learned descent directions without computing the Jacobian or the Hessian (that are required for Newton's method).
This method has some important and useful properties. Firstly, it can be implemented very efficiently, allowing real-time processing, even on low-power devices, such as mobile phones. Secondly, most of the processing of the present invention involves matrix operations so it can be easily parallelized and/or vectorized taking advantage of modern multi-core CPUs/GPUs. Thirdly, the size of the model is compact (a few megabytes). Fourth, the method can recover from tracking failure and allows long-term tracking. Fourthly, the method outperforms state-of-the-art approaches for facial feature detection and tracking.
These and other features, objects, and advantages of the present invention will be readily apparent to persons of ordinary skill in the art.
In the present disclosure, numerous specific details are provided, such as examples of the method and of how the software works, to provide a thorough understanding of embodiments of the invention. Persons of ordinary skill in the art will recognize, however, that the invention can be practiced without one or more of the specific details. In other instances, well-known details are not shown.
The term “camera” as used herein shall mean the source of a digital still or video image. In addition to traditional still and video cameras, for purposes herein a camera could include, for example, a storage medium having a video file stored thereon could be a camera for purposes of this invention.
The term “microprocessor” as used herein shall mean an integrated circuit that contains all the functions for processing. This includes, for example, graphics processing units (GPUs), field-programmable gate array (FPGA), a traditional computer processor, or any other means of executing program instructions or otherwise processing data.
Supervised Descent Method (SDM)
The present invention describes the SDM in the context of face alignment.
Derivation of SDM
Given an image dϵm×1, of m pixels, d(x)ϵp×1 indexes p landmarks in the image. h is non-linear feature extraction function (e.g., HoG) and h(d(x))ϵp×1 in the case of extracting HoG features. During training, it is assumed that the correct p landmarks (in the preferred embodiment of the invention, 66 landmarks are used) are known, and they will be referred to as x* (see
ƒ(x0+Δx)=∥h(d(x0+Δx))−φ*∥22, (3)
where φ*=h(d(x*)) represents the HoG values in the manually labeled landmarks. In the training images, φ*, and Δx are known. This invention aligns the image with respect to a template φ* that will be learned during training.
Eq. 3 has several fundamental differences with previous work. First, in Eq. 3 no model of shape or appearance is learned beforehand from training data. Recall that in traditional methods such as Active Appearance Models, Constrained Local Models or Morphable Models, the non-rigid motion is modeled as a linear combination of shape basis learned by computing PCA on a training set. In our case, the shape model is a non-parametric one, and the landmark locations xϵ2p×1 are optimized directly. This non-parametric shape model is able to generalize better to untrained situations (e.g., asymmetric facial gestures). Although the method can be used with a previously learned model. Second, the present invention uses HoG features extracted from patches around the landmarks to achieve a robust representation against illumination. Observe that the HoG operator is not differentiable and minimizing Eq. 3 using first or second order methods requires numerical approximations (e.g., finite differences) of the Jacobian and the Hessian. However, numerical approximations will be very computationally expensive. The goal of this invention (SDM) is to learn a series of descent directions and re-scaling factors (done by the Hessian in the case of Newton's method) such that it produces a sequence of updates (xk+1=xk+Δxk) starting from x0 that converges to x* in the training data.
Now, only for derivation purposes, It is assumed that h is twice differentiable. Such assumption will be dropped at a later part of the section Similar to Newton's method, a second order Taylor expansion is applied to Eq. 3 as,
where Jƒ(x0) and H(x0) are the Jacobian and Hessian matrices of ƒ evaluated at x0. In the following, x0 is omitted to simplify the notation. Differentiating (4) with respect to Δx and setting it to zero gives us the first update for x,
Δx1=−H−1Jƒ=−2H−1JhT(φ0−φ*), (5)
where the present invention made use of the chain rule to show that
Jƒ=2JhT(φ0−φ*), where φ0=h(d(x0)).
The first Newton step can be seen as projecting Δφ0=φ0−φ* onto the row vectors of matrix R0=−2H−1JhT. In the rest of the description, the present invention will refer to R0 as a descent direction. The computation of this descent direction requires the function h to be twice differentiable or expensive numerical approximations for the Jacobian and Hessian. The present invention will directly estimate R0 from training data by learning a linear regression between Δx*=x*−x0 and Δφ0. Therefore, this method is not limited to functions that are twice differentiable. However, note that during testing (i.e., inference) φ* is unknown but fixed during the optimization process. To use the descent direction during testing, the invention will not use the information of φ* for training. Instead, it rewrites Eq. 5 as a generic linear combination of feature vector φ0 plus a bias term b0 that can be learned during training,
Δx1=R0φ0+b0. (6)
Using training examples, the SDM will learn R0, b0 used in the first step of the optimization procedure.
It is unlikely that the algorithm can converge in a single update step unless ƒ is quadratic under x. To deal with non-quadratic functions, the SDM will generate a sequence of descent directions. For a particular image, Newton's method generates a sequence of updates along the image-specific gradient directions,
xk=xk−1−2H−1JhT(φk−1−φ*). (7)
φk−1=h(d(xk−1)) is the feature vector extracted at previous landmark locations xk−1. In contrast, SDM will learn a sequence of generic descent directions {Rk} and bias terms {bk},
xk=xk−1+Rk−1φk−1+bk−1, (8)
such that the succession of xk converges to x* for all images in the training set. Eq. (8) represents one possible update of the landmarks. In the following, we will develop the equations for the linear regression case, Eq. (8). Other more general regression/mappings from features to landmarks are possible and the modification of the algorithm is straight-forward. A more general update equation than Eq. (8) is:
i. xk=xk−1+ƒ(φk−1)+bk−1,
Learning for SDM
Below, we describe how to learn Rk, bk from training data (the linear regression case), but using a more generic regression f( ) is straight-forward. Assume a set of face images {di} and their corresponding hand-labeled landmarks {x*i} is given. For each image starting from an initial estimate of the landmarks x0i, R0 and b0 are obtained by minimizing the expected loss between the predicted and the optimal landmark displacement under many possible initializations. The L2-loss is chosen for its simplicity and this solve for the R0 and b0 that minimizes
where Δxi=x*i−x0i and φ0i=h(di(x0i)). It is assumed that x0i is sampled from a Normal distribution whose parameters capture the variance of a face detector. The integration is then approximated with Monte Carlo sampling, and instead minimize
Minimizing Eq. 10 is the well-known linear least squares problem, which can be solved in closed-form.
The subsequent Rk, bk can be learned as follows. At each step, a new dataset {Δx*i, φki} can be created by recursively applying the update rule in Eq. 8 with previously learned Rk−1, bk−1. More explicitly, after Rk−1, bk−1 is learned, the current landmarks estimate xki is updated using Eq. 8. A new set of training data is generated by computing the new optimal parameter update Δx*ki=x*i−xki and the new feature vector, φki=h(di(xki)). Rk and bk can be learned from a new linear regressor in the new training set by minimizing:
The error monotonically decreases as a function of the number of regressors that are added. In all experiments, in 4 or 5 steps the algorithm has converged.
It is important to note, that a more generic mapping/regression functions ƒ(φk−1) can easily be learned using standard methods that minimize:
arg minƒ( ),b
For the first iteration, and we could proceed as before for the remaining iterations. Recall that if ƒk (φk)=Rkφk we have the method explained in the previous paragraphs.
Online Learning for SDM
SDM may have poor performance on an unseen sample that is dramatically different from those in the training set. It would be desirable to incorporate this new sample into the existing model without re-training. The following describes such a procedure that updates an existing SDM model in an online fashion. Below, we assume that ƒ is a linear mapping function. Assume that one is given a trained SDM model, represented by {Rk, bk, Σk−1}, where Σk=ΦkΦkT and Φk is the data matrix where each of the columns represents a feature vector extracted from one particular training image and one particular landmark configuration. For a given new face image d, and labeled landmarks x*, one can compute the initial landmark perturbation Δx0=x*−x0 and the feature vector extracted at x0, φ0=h(d(x0)). Using recursive least squares algorithm, SDM can be re-trained by iterating the following three steps:
Step 1—update the inverse covariance matrix,
Σk−1=Σk−1−Σk−1φk(w−1+φkTΣk−1φk)−1φkTΣk−1.
Step 2—update the generic descent map,
Rk=Rk+(Δxk−Rkφk)wφkTΣk−1.
Step 3—generate a new pair Δxk+1 and φk+1 and go to Step 1,
Δxk+1=Δxk−Rkφk
φk+1=h(d(x*+Δxk+1)).
Above w is a scalar representing the weight for the new sample. Note that above we did not show how to update bk. In practice, one can incorporate the bias term into Rk by augmenting the feature vector with one.
Algorithm for Facial Feature Detection
This embodiment of the invention describes more specifically the SDM method for facial feature detection in unconstrained images and videos. For instance, low resolution images, images with highly cluttered background. The embodiment assumes the existence of a database of training data, as described below.
Step 1— A face detector which returns a bounding box containing a face, as shown in
Step 2— The landmark locations x0 are initialized by placing an average face in the center of the normalized bounding box given in Step 1. The average face is computed offline using a large face database.
Step 3— This step involves regression from image features to displacement of landmarks. The image features are computed in a local patch around each predicted landmark using a histogram of gradients (HoG). The feature extraction step may take place at different resolutions (e.g., different levels of an image pyramid). The symbol φk is used to denote the image features extracted at the kth iteration. The displacement of landmarks is computed using a pre-learned function ƒ that takes the above image features as inputs:
xk=xk−1+ƒk(φk).
In the case of linear regression, ƒk(φk)=Rkφk, but any regression or mapping method can be used. The displacement of landmarks can be represented directly by the (x, y) image coordinates or more compactly by a shape model, such as a principal component analysis (PCA) model. Better results are achieved by regressing onto image coordinates.
To compute the HoG for each landmark, a square image patch surrounding the landmark is used. Preferably, the image patch will be 28×28 pixels. Calculating the HoG descriptor computation consists of the following steps. First, an image gradient is computed for the image patch. The image patch is then divided into 4×4 pixel spatial regions. For each pixel in the region a vote for an orientation histogram bin is calculated based on the orientation of the gradient element centered on it. Votes are accumulated into orientation bins over local spatial regions. The orientation bins are evenly spaced over 0°-180°, and in the preferred embodiment, are 22.5° wide. The vote is computed as the gradient magnitude. Lastly, in each spatial region, the accumulated histogram bins are normalized into unit vectors and all 4×4 unit vectors are concatenated into a column vector. Recall that many other features, other than HoG, could be used for the method.
Step 4— This step involves iterating Steps 2 and 3. The number of iterations is defined in the training stage. The same number of iterations is used in testing.
Step 5—This step provides a calculation of a prediction score: A classifier is trained offline on landmarks well positioned and landmarks that do not correspond to facial features. The output of the classifier is used as the prediction score to evaluate quality of landmark prediction.
Algorithm for Facial Feature Tracking
The tracking of facial features is very similar to the detection of facial features described above. The main differences are that the tracking process happens from frame to frame in a video and the confidence score calculate in Step 5 below is used to determine if the face has been lost from frame to frame.
Step 1—The face image is normalized. From the prediction made in the previous frame, an estimate of scale and orientation of the face in the current frame is obtained. Using that information, the current frame is normalized to the same scale and orientation that were used in training.
Step 2—The landmark locations x0 are initialized by placing an average face in the center of the normalized image given in step 1.
Step 3—This step involves regression from image features to displacement of landmarks. The image features are computed in a local patch around each predicted landmark using a histogram of gradients. The feature extraction step may take place at different resolutions (e.g., different levels of an image pyramid). The symbol φk is used to denote the image features extracted at the kth iteration. The displacement of landmarks is computed using a pre-learned function ƒ that takes the above image features as inputs:
xk=xk−1+ƒk((φk).
The landmark locations may be represented by (x, y) image coordinates or more compactly by a shape model, such as a PCA model.
Step 4—This step involves iterating Steps 2 and 3. The number of iterations is defined in the training stage. The same number of iterations is used in testing.
Step 5—This step involves calculation of a prediction score. A classifier is trained offline on faces and non-faces. The output of the classifier is used as the prediction score to evaluate quality of landmark prediction. If the score is lower than a threshold, we determine that the tracker is lost (i.e., no face can be found in the frame).
Algorithm for Multi-View Facial Feature Tracking
An extension of the proposed SDM to improve tracking performance is possible by using multiple models rather than only one. The tracking of facial features is very similar to the detection of facial features described in the previous sections, the main difference is an additional step to select the adequate model.
Step 1—The face image is normalized. From the prediction made in the previous frame, an estimate of scale and orientation of the face in the current frame is obtained. Using that information, the current frame is normalized to the same scale and orientation that were used in training and the face is placed in a bounding box.
Step 2—This step involves selection of SDM models. A set of models are trained for different views of faces. The training set is divided into different clusters according to face shapes and their appearances. The shape and appearance predicted from the previous frame are compared with the means of each cluster. The model with the closest distance to the mean is selected. The number of clusters is chosen using a validation dataset. When consecutive frames land in the boundary of two clusters, the model tends to alternate between the two. This will result in unpleasant effects (e.g., unstable, jumping landmarks) in tracking. One can enforce a temporal smoothness in the model selection procedure to eliminate such undesired effects.
Step 3—The landmark locations x0 are initialized by placing an average face in the center of the bonding box used in Step 1. (i.e., the normalized image given in step 1). For different views, a different average face is used. Several possible ways of initializing the landmarks are possible, the only requirement is that the same process is done in training and testing. For instance, a simple initialize is applying an average landmark averaging to the center of the bounding box.
Step 4—This step involves regression from image features to displacement of landmarks. The image features are computed in a local patch around each predicted landmark using a histogram of gradients. The feature extraction step may take place at different resolutions (e.g., different levels of an image pyramid). The symbol φk is used to denote the image features extracted at the kth iteration. The displacement of landmarks is computed using a pre-learned function ƒ(a regressor) that takes the above image features as inputs:
xk=xk−1+ƒk(φk).
A different function is learned for each view. A set of regressors is trained during the training phase using the Supervised Descent Method to update the landmarks during testing. For training, the algorithm has a set of manually labeled images and a face detector that detects a bounding box in each of the images. Preferably, several models can be trained for different face poses.
The landmark locations may be represented by (x, y) image coordinates or more compactly by a shape model, such as a PCA model.
Step 5—This step involves iterating Steps 2 through 4. The number of iterations is defined in the training stage. The same number of iterations is used in testing.
Step 6—This step involves calculation of a prediction score. Multiple classifiers are trained offline on faces and non-faces, one for each view. The output of the classifier is used as the prediction score to evaluate the quality of landmark prediction. If the score is lower than a threshold, we determine that the tracker is lost (i.e., no face can be found in the frame). If it is determined that no face has been found in the frame, the face detector is run again and Steps 1-6 are repeated once a face is found. A classifier is a function that maps image features to discrete classes. In our case, the two classes which are correctly predicted landmarks, and incorrectly predicted landmarks. Such classifier is trained with images where the landmarks in the images are well place (positive class) and face images where the landmarks are incorrectly placed (negative images). Given a set of landmarks in an image, the classifier will return 1 if the landmarks are well placed in the image and −1 if they are not well placed.
Facial Feature Detection and Tracking During Training
Step 1— This step involves the manual location of facial landmarks in an image. In the preferred embodiment of the invention, 66 landmarks are manually placed to indicate the locations of facial features, although any number of landmarks may be used. The training data consists of a set of face images having their corresponding landmarks {x*i} labeled. Some examples of facial images having features marked with landmarks are shown in
Step 2—This step involves the generation of initial landmark estimates. For each normalized image, an average face is placed in the center of frame. Additional samples are added by perturbing the average face and those are used initial estimates of the landmarks {x0i}.
Step 3— The third step involves learning regression from image features to displacements of landmark. For each sample, the image features are computed in the local patch around each predicted landmark using, in the preferred embodiment, a histogram of gradients. The feature extraction step may take place at different resolutions (e.g., different levels of an image pyramid). The symbol φki is used to denote the image features extracted from the ith sample at the kth iteration. The displacement of landmarks Δx*i is computed as the difference between the current landmark prediction and the labeled landmarks.
Δx*i=xki−x*i
The landmark locations may be represented by (x, y) image coordinates or more compactly by a shape model, such as a PCA model. A function ƒ (regressor) is learned as a mapping between the two by minimizing the following loss:
Step 4— In this step, the landmarks are updated. For each sample, landmarks are updated using the following equation, where ƒ is the learned function from step 3,
xki=xk−1i+ƒ(φki).
Step 5—This step involves iterating Steps 3 and 4 until convergence is achieved. The method is said to be converged in training if the predicted landmark locations are sufficiently close to the true landmarks.
While specific embodiments of the present invention have been provided, it is to be understood that these embodiments are for illustration purposes and are not limiting. Many additional embodiments will be apparent to persons of ordinary skill in the art. It should also be noted that the method could be applied to shapes other than faces, given an appropriate set of training images for the desired shape.
This application claims the benefit of U.S. Provisional Application Ser. No. 62/166,934, filed May 27, 2015, and is also a continuation-in-part of currently pending U.S. application Ser. No. 14/596,148, filed Jan. 13, 2015, which claims the benefit of U.S. Provisional Application Ser. No. 61/964,744, filed Jan. 13, 2014, and 62/122,064, filed Oct. 9, 2014, all of which are incorporated herein in their entirety.
This invention was made with partial support of the government under the National Science Foundation Number U.S. Pat. No. 1,116,583. The government has certain rights in this invention.
Number | Name | Date | Kind |
---|---|---|---|
5802220 | Black | Sep 1998 | A |
8121347 | Metaxas | Feb 2012 | B2 |
8155399 | Liu | Apr 2012 | B2 |
9152847 | Zhou | Oct 2015 | B2 |
9218542 | Zhan | Dec 2015 | B2 |
9405982 | Zhang | Aug 2016 | B2 |
9633250 | Tuzel | Apr 2017 | B2 |
20080187174 | Metaxas | Aug 2008 | A1 |
20140147022 | Zhou | May 2014 | A1 |
20140185924 | Cao | Jul 2014 | A1 |
20140270374 | Unzueta | Sep 2014 | A1 |
20150043799 | Zhan | Feb 2015 | A1 |
20150169938 | Yao | Jun 2015 | A1 |
20150186748 | Cootes | Jul 2015 | A1 |
20150310306 | Song | Oct 2015 | A1 |
20150347822 | Zhou | Dec 2015 | A1 |
20150363634 | Yin | Dec 2015 | A1 |
20160191995 | el Kaliouby | Jun 2016 | A1 |
20160196665 | Abreu | Jul 2016 | A1 |
20160205382 | Chen | Jul 2016 | A1 |
20160275721 | Park | Sep 2016 | A1 |
Entry |
---|
Cao et al (“Face Alignment by Explicit Shape Regression”, 2013). |
Huang, et al., Facial Action Transfer With Personalized Bilinear Regression, Robotics Institute, Carnegie Mellon University, Oct. 2012. |
Number | Date | Country | |
---|---|---|---|
20160275339 A1 | Sep 2016 | US |
Number | Date | Country | |
---|---|---|---|
62166934 | May 2015 | US | |
61964744 | Jan 2014 | US | |
62122064 | Oct 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14596148 | Jan 2015 | US |
Child | 15166317 | US |