The invention relates to digital image processing systems. More particularly, the invention relates to a method and an image processing system for synthesizing and replacing faces of image objects.
Digital image processing has many applications in a wide variety of fields. Conventional digital image processing systems involve processing two-dimensional (2D) images. The 2D images are digitally processed for subsequent uses.
In one application, digital image processing is used in the field of security for recognising objects such as a human face. In this example, a person's unique facial features are digitally stored in a face recognition system. The face recognition system then compares the facial features with a captured image of the person to determine the identity of that person.
In another application, digital image processing is used in the field of virtual reality where an image of one object such as the human face in an image is manipulated or replaced with another object of another human face. In this manner, a face of a figure in a role-playing game is customizable with a gamer own personalized face.
However, conventional digital image processing systems are susceptible to undesirable errors in identifying the human face or replacing the human face with another human face.
This is notably due to variations in face orientation, pose, facial expression and imaging conditions. These variations are inherent during capturing of the human face by an image-capturing source.
Hence, in view of the foregoing limitations of conventional digital image processing systems, there is a need to provide more desirable performance in relation to face detection and replacement.
Embodiments of the invention disclosed herein provide a method and a system for replacing a first object in a 2D image with a second object based on a synthesized three-dimensional (3D) model of the second object.
In accordance with a first embodiment of the invention, a method for replacing an object in an image is disclosed. The method comprises obtaining a first image having a first object, the first image being two-dimensional and the first object having a plurality of feature portions. The method also comprises generating first image reference points on the first object and extracting object properties of the first object from the first image, the object properties comprising object orientation and dimension of the first object. The method further comprises providing a three-dimensional model being representative of a second image object, the three-dimensional model having model control points thereon, and at least one of manipulating and displacing the three-dimensional model based on the object properties of the first object. The method yet further comprises capturing a synthesized image containing a synthesized object from the at least one of manipulated and displaced three-dimensional model, the synthesized object having second image reference points derived from the model control points, the second image reference points being associated with a plurality of image portions of the synthesized object, and registering the second image reference points to the first image reference points for subsequent replacement of the first object in the first image with the synthesized object.
In accordance with a second embodiment of the invention, a machine readable medium for replacing an object in an image is disclosed. The machine readable medium has a plurality of programming instructions stored therein, which when execute, the instructions cause the machine to obtain a first image having a first object, where the first image being two-dimensional and the first object having a plurality of feature portions. The programming instructions also cause the machine to generate first image reference points on the first object and extracts object properties of the first object from the first image, where the object properties comprises object orientation and dimension of the first object. The programming instructions also cause the machine to provide a three-dimensional model being representative of a second image object, where the three-dimensional model has model control points thereon, and at least one of manipulating and displacing the three-dimensional model based on the object properties of the first object. The programming instructions further cause the machine to capture a synthesized image containing a synthesized object from the at least one of manipulated and displaced three-dimensional model, where the synthesized object has second image reference points derived from the model control points, and registers the second image reference points to the first image reference points for subsequent replacement of the first object in the first image with the synthesized object.
Embodiments of the invention are disclosed hereinafter with reference to the drawings, in which:
a and 1b show a graphical representation of a first 2D image having a first object;
a and 2b shows a graphical representation of a second 2D image having a second object;
A method and a system for replacing a first object in a 2D image with a second object based on a synthesized three-dimensional (3D) model of the second object are described hereinafter for addressing the foregoing problems.
For purposes of brevity and clarity, the description of the invention is limited hereinafter to applications related to object replacement in 2D images. This however does not preclude various embodiments of the invention from other applications that require similar operating performance. The fundamental operational and functional principles of the embodiments of the invention are common throughout the various embodiments.
Exemplary embodiments of the invention described hereinafter are in accordance with
a shows a graphical representation of a first 2D image 100. The first 2D image 100 is preferably obtained from a first image frame, such as a digital photograph taken by a digital camera or a screen capture from a video sequence. The first 2D image 100 preferably contains at least a first object 102 having first image reference points 104 as shown in
The first object 102 of the first 2D image 100 has a plurality of object properties that defines the characteristics of the first face. Examples of the object properties include object orientation or pose, dimension, facial expression, skin colour and lighting of the first face. The system preferably extracts the properties of the first object 102 through methods well known in the art such as knowledge-based methods, feature invariant approaches, template matching methods and appearance-based methods.
a shows a graphical representation of a second 2D image 100. The second 2D image 200 is preferably obtained from a second image frame. The second 2D image preferably contains at least a second object 202 having second image reference points, as shown in
Similar to the first object 102, the second object 202 has a plurality of object properties, such as the foregoing ones relating to object orientation, dimension, facial expression, skin colour and lighting. The plurality of object properties defines the characteristics of the face of the second human subject. The system extracts the object properties of the second object 202 for subsequent replacement of the face of the first human subject with the face of the second human subject.
Alternatively, the second 2D image 200 is obtained from the same image frame as the first image frame. In this case, the second 2D image 200 contains two or more objects. More specifically, the second object 202 corresponds to one of the two or more objects contained in the first 2D image 100.
The system preferably stores the respective properties of the first and second objects 102, 202 in a memory. In particular, the system preferably generates the first image reference points 104 on the first 2D image 100, as shown in
The second image reference points 204 of
Next, in order to improve the sharpness of the response of the extraction by the feature extractor around an image feature point (x, y), counter solutions around the region of the image feature point (x, y) are collected and the feature extractor is taught to reject these solutions. All extracted feature vectors (also known as positive samples) of a feature point are then stored in a stack “A” while the feature vectors of counter solutions (also known as negative samples) are stored in a corresponding stack “B”. Both stack “A” and stack “B” are preferably stored in the memory of the system. With the forty-eight dimensional feature vector being produced, dimensionality reduction is required and performed using principal component analysis (PCA). Hence, dimensionality reduction is performed for both the positive samples (PCA_A) and the negative samples (PCA_B).
The separability between the positive samples and the negative samples is optimized using linear discriminant analysis (LDA). The computation of the linear discriminant analysis of the positive samples is performed by first using the positive samples and negative samples as training sets. Two different sets, PCA_A(A) and PCA_A(B), are then created by using the projection of PCA_A. The set PCA_A(A) is then assigned to class “0” while the set PCA_A(B) is assigned to class “1”. The best linear discriminant is defined using the fisher linear discriminant analysis on the basis of a two-class problem. The linear discriminant analysis of the set PCA_A(A) is obtained by computing LDA_A(PCA_A(A)) as the set must generate a “0” value. Similarly, the linear discriminant analysis of the set PCA_A(B) is obtained by computing LDA_A(PCA_A(B)) as the set must generate a “1” value. The separability threshold present between the two classes is then estimated.
Separately, a similar process is repeated for LDA_B. However, instead of using the sets, PCA_A(A) and PCA_A(B), the sets PCA_B(A) and PCA_B(B) are used. Two scores are then obtained by subjecting an unknown feature vector, X, through the following two processes:
X
PCA
—
A
LDA
—
A (1)
X
PCA
—
B
LDA
—
B (2)
Ideally, the unknown feature vector, X, gets accepted by the process LDA_A(PCA_A(X)) and gets rejected by the process LDA_B(PCA_B(X)). The proposition is that two discriminant functions are defined for each class using a decision rule that is based on the statistical distribution of the projected data:
f(x)=LDA—A(PCA—A(x)) (3)
g(x)=LDA—B(PCA—B(x) (4)
Set “A” and set “B” are defined as the “feature” and “non-feature” training sets respectively. Further, four one-dimensional clusters are defined: GA=g(A), FB=f(B), FA=f(A) and GB=f(b). The derivation of the mean,
For a given vector Y, the projections of the vector Y using the two discriminant functions are obtained:
yf=f(Y) (5)
yg=g(Y) (6)
The vector Y is classified as to class “A” or “B” according to the pseudo-code expressed as:
if(min(yfa,yga)<min(yfb,ygb))
then
label=A;
else
label=B;
RA=RB=0;
if(yfa>3.09)or(yga>3.09)RA=1;
if(yfb>3.09)or(ygb>3.09)RB=1;
if(RA=1)or(RB=1)label=B;
if(RA=1)or(RB=0)label=B;
if(RA=0)or(RB=1)label=A;
The system subsequently generates a first 3D model or head object of the second 2D image 200. The first 3D model is generated based on the object properties of the first and second objects 102, 202. This is achieved by using a 3D mesh 300, which comprises vertices tessellated for providing the 3D mesh 300 that is deformable either globally or locally.
The first 3D mesh 300 has predefined mesh reference points 302 and model control points 304 located at predetermined mesh reference points 302. Each of the model control points 304 is used for deforming a predetermined portion of the first 3D mesh 300. More specifically, the system manipulates the model control points 304 based on the orientation and dimension properties of the first object 102.
Global deformation involves, for example, a change in the orientation or dimension of the 3D mesh 300. Local deformation, on the other hand, involves localised changes to a specific portion within the 3D mesh 300.
In this first embodiment of the invention, the system extracts object properties of the first object 102. Global deformation preferably involves object properties that are associated with object orientation and dimension. The system preferably deforms the first 3D mesh 300 for generating the first 3D model based on the global deformation properties of the first object 102.
The object orientation of the first object in the first 2D image 100 is estimated prior to deformation of the first 3D mesh 300. The first 3D mesh 300 is initially rotated along the azimuth angle. The edges of the first 3D mesh 300 are extracted using an edge detection algorithm such as the Canny edge detector. Edge maps are then computed for the first 3D mesh 300 along the azimuth angle from −90 degrees to +90 degrees in increments of 5 degrees. Preferably, the first 3D mesh-edge maps are computed only once and stored in the memory of the system.
To estimate the object orientation in the first 2D image 100, the edges of the 2D image 100 is extracted using the foregoing edge detection algorithm to obtain an image edge map (not shown) of the 2D image 100. Each of the 3D mesh-edge maps is compared to the image edge map to determine which object orientation results in the best overlapping of the 3D mesh-edge maps. To compute the disparity between the 3D mesh-edge maps, the Euclidean distance-transform (DT) of the image edge map is computed. For each pixel in the image edge map, the distance-transform assigns a number that is the distance between that pixel and the nearest nonzero pixel of the image edge map.
The value of the cost function, F, of each of the 3D mesh-edge maps is then computed. The cost function, F, which measures the disparity between the 3D mesh-edge maps and the image edge map is expressed as:
where AEM≅{(i, j):EM(i, j)=1} and N is the cardinality of set AEM (total number of nonzero pixels in the 3D mesh-edge map EM). F is the average distance-transform value at the nonzero pixels of the image edge map. The object orientation for which the corresponding 3D mesh-edge map results in the lowest value of F is the estimated object orientation for the first 2D image 100.
Typically, an affine deformation model for the global deformation of the first 3D mesh 300 is used and the image reference points are used for determining a solution for the affine parameters. A typical affine model used for the global deformation is expressed as:
where (X, Y, Z) are the 3D coordinates of the vertices of the first 3D mesh 300, and subscript “gb” denotes global deformation. The affine model appropriately stretches or shrinks the first 3D mesh 300 along the X and Y axes and also takes into account the shearing occurring in the X-Y plane. The affine deformation parameters are obtained by minimizing the re-projection error of the mesh reference points on the rotated deformed first 3D mesh 300 and the corresponding first image reference points 104 in the first 2D image 100. The 2D projection (xf, yf) of the 3D mesh reference points (Xf, Yf, Zf) on the deformed first 3D mesh 300 is expressed as:
where R12 is the matrix containing the top two rows of the rotation matrix corresponding to the property relating to object orientation for the first 2D image 100. Using the 3D coordinates of the first image reference points 104, equation (3) can then be reformulated into a linear system of equations. The affine deformation parameters P=[α11, α12, α21, α22, b1, b2]T are then determinable by obtaining a least-squares (LS) solution of the system of equations.
The first 3D mesh 300 is globally deformed according to these parameters, thus ensuring that the resulting 3D model conforms to the approximate shape of the first object 102.
The system then proceeds to deform the first 3D mesh 300 based on object properties of the second object 202 relating to local deformation. The system first identifies and locates the feature portions 206 of the second object 202, as shown in
The system subsequently compensates the mesh reference points 302 of the first 3D mesh 300 towards the image reference points.
Alternatively, the system manipulates the first 3D mesh 300 based on the local deformation properties prior to the global deformation properties. This means that the sequence of manipulation is variable for obtaining the first 3D model 600.
The system then captures a synthesized image from the first 3D model 600. The synthesized image contains a synthesized object 700 that has the second image reference points 204. The second image reference points 204 correspond to the first image reference points 104 of the first object 102.
The system then registers the second image reference points 204 to the first image reference points 104. The system subsequently replaces the first object 102 from the first image 100 with the synthesized object 700 that corresponds to the second object 202 to obtain a replaced face within the first image 100.
In applications where local deformation properties of the first image 100 are desirable to be present in the replaced face, the system preferably provides a second 3D mesh (not shown) for generating a second 3D model based on the local deformation properties of the first object 102. The second 3D model is then used in the foregoing image processing method based on local deformation for generating the synthesized image containing the synthesized object 700. The synthesized object 700 therefore includes local deformation properties of the first image 100.
Furthermore, the system is capable of processing multiple image frames of a video sequence for replacing one or more object in the video image frames. Each of the multiple image frames of the video sequence is individually processed for object replacement. The processed image frames are preferably stored in the memory of the system. The system subsequently collates the processed image frames to obtain a processed video sequence with the one or more object in the video image frames being replaced.
In the foregoing manner, a method and a system for replacing a first object in a 2D image with a second object based on a synthesized 3D model of the second object are described according to embodiments of the invention for addressing at least one of the foregoing disadvantages. Although only an embodiment of the invention is disclosed, it will be apparent to one skilled in the art in view of this disclosure that numerous changes and/or modification can be made without departing from the spirit and scope of the invention.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/SG2008/000202 | 6/3/2008 | WO | 00 | 8/19/2011 |