FIELD OF THE INVENTION

[0001]
The invention relates generally to the field of digital image processing, and in particular to a method and apparatus for finding objects in an image, where the method applies regardless of the inplane rotational orientation of objects in the image.
BACKGROUND OF THE INVENTION

[0002]
Much recent research in the computer vision field concerns the abilities to find “regularly configured objects” (also referred to hereafter by the shorter term “objects”) in digital images. Objects can be defined as classes of realworld entities that obey consistent rules with respect to geometric shape and appearance. Examples of objects includes human faces, whole people, cars, animals, and buildings.

[0003]
The ability to computationally find objects in images varies directly with the extrinsic and intrinsic consistency of the class appearance. “Extrinsic consistency” refers to factors, such as lighting and pose, that can vary dramatically and are independent of the physical properties of the objects. “Intrinsic consistency” refers to factors due to the physical properties of the objects. Clearly, some types of objects present more variation in their appearance than others. For example, the class of human faces obeys fairly tight geometric constraints on overall physical shape and the relative placement of component parts, such as eyes, nose, and mouth. The class of whole people, on the other hand, exhibits far more variation in appearance due to the articulated nature of the limbs and the bending abilities of the human body.

[0004]
Past applications of object detection have tended to focus on tightlydefined object classes with limited appearance variability, such as the set of human faces. Successful object detectors, including face detectors, have been constructed and commercially deployed. One common weakness of such detectors is a capability to deal with only a limited range of object poses or viewpoints.

[0005]
There can be many sources of variation in the appearance of human faces in images: personal identity, pose, illumination, deformation, and imaging process parameters, to name the most important. Surprisingly, of the sources mentioned, changing specific individual identity may contribute a smaller amount to the change in appearance of an imaged face than do the other factors. This statement is true when using almost any noncognitive measure of appearance similarity. This may seem surprising and even counterintuitive in light of the great facility of the human observer's identification of individual persons. Such facility might seem to imply that there are substantial invariant aspects of the appearance of individual persons over disparate viewing conditions. But this conclusion is not true. The situation here resembles to some extent the cognitive process of color constancy. There, highly sophisticated physiological and psychological mechanisms of eye, retina, and brain combine to create the perceptual illusion of color constancy that can be easily dispelled with a roll of color film and some variety of illuminants. (The film serves the role of a much more primitive imaging system than that of the human observer.) Similarly here, in the domain of facial appearance, there is widespread physiological evidence that exceedingly sophisticated visual and mental processes, including tailored neuronal support, necessarily underlay the seemingly effortless recognition of human individuals.

[0006]
The situation is otherwise when considering quantitative (i.e. mathematical) measures of appearance similarity of faces. The effects of illumination and pose can produce much greater changes to the appearance of faces than are caused by identity difference. The difference referenced here is that of a quantitative measure, such as mean square error, Mahalanobis distance, or the like.

[0007]
In many applications of face detection to commercial tasks, finding the faces serves as an enabling technology to subsequent processing steps. Depending on the speed requirements of that processing, it may be true that insufficient speed in the face detection portion of the processing would render the overall tasks unsuccessful. For this reason, many recent approaches have concentrated on producing algorithms that operate in the most rapid possible manner. These approaches tend to have the disadvantage of a large false positive rate, particularly when outofplane rotation is present. A further problem of many of the above approaches is dependence upon correction orthogonal orientation of images prior to object location. An example of such is face location limited to a nominal upright image orientation and small ranges of rotation away from the nominal orientation. Possible ameliorative measures, such as multiple passes, additional training, and use of multiple classifiers add complexity and require additional time.

[0008]
To handle inplane rotation without multiple applications of a classifier trained for upright frontal faces, and hence with the attendant performance penalties, some researchers have prefaced their classifiers with a module that can determine the inplane rotational orientation of a face candidate in a window. These approaches have been referred to as “invariancebased methods”, since the face detector examines image data rotated to make the purported face appear in nominal upright position.

[0009]
In “Face Detection using the 1storder RCE Classifier”, Proc. IEEE Int'l Conf. Image Processing, Jeon, B., Lee, S., and Lee, K., 2002; an orientation module acts on test windows before examination by the main classifier. The module estimates the most likely orientation of a face, should a face happen to be present, returning a meaningless indication otherwise. The orientation module first binarizes a test window using an adaptive threshold, and then searches for bestfit rotational orientation of the purported eye lines (judging the eyes to be the most reliable facial feature) in one degree increments. The subsequent classifier, based on firstorder reduced Coulomb energy, examines the test window explicitly rotated based on the estimation of the orientation module.

[0010]
Similarly, in “Rotation Invariant Neural NetworkBased Face Detection”, Proc. IEEE Conf. Computer Vision and Pattern Recognition, Rowley, H., Baluja, S., and Kanade, T., 1998, 3844 a neuralnetwork based rotationestimation module is provided prior to the main classifier, which also happens to be implemented with a receptivefield neural network architecture.

[0011]
The approaches of these publications have the shortcoming of a risk that the time cost of the rotation estimation would approach that of the face classification decision, leading to a substantial speed loss in the overall detection system. An additional shortcoming is that these approaches are not extended to situations, in which both inplane and outofplane rotation are substantial.

[0012]
Use of integral images in fast computational methods is disclosed in “Robust RealTime Object Recognition”, Proc. Second International Workshop on Statistical and Computational Theories of Vision—Modeling Learning, Computing, and Sampling, Viola, P. and Jones, M., 2001.

[0013]
Dimensionality reduction has been widely applied to machine learning applications, as well as many other data processing tasks such as noise reduction, data modeling, and data transformation as a solution to some types of overtraining.

[0014]
Solutions to the problem of estimation of probability distribution in data are well known and can be divided broadly into three categories—parametric, nonparametric, and a midground semiparametric category.

[0015]
Many different kinds of face detectors are known in the computer vision literature. Common methods involve neuralnetwork based detectors Rowley, H., Baluja, S., and Kanade, T., “Rotation Invariant Neural NetworkBased Face Detection”, Proc. IEEE Conf. Computer Vision and Pattern Recognition 1998, 3844, domaindivision cascaded classifier Viola, Paul, and Jones, Michael, “Robust RealTime Object Recognition”, Proc. Second International Workshop on Statistical and Computational Theories of Vision—Modeling, Learning, Computing, and Sampling, 2001, and heterogeneous cascaded classifiers Feraud, Raphael, et al., “A Fast and Accurate Face Detector Based on Neural Networks”, IEEE Trans. Pattern Analysis and Machine Intelligence, 23(1), 4253. Another example of an object detector that can be used as a face detector is provided in Schneiderman, H., and Kanade, T., “Probabilistic Modeling of Local Appearance and Spatial Relationships for Object Recognition”, Proc. CVPR 1998, 4551.

[0016]
It would thus be desirable to provide improved methods, computer systems, and computer program products, in which the most likely inplane orientation of objects can be rapidly estimated and in which substantial outofplane rotation is tolerated.
SUMMARY OF THE INVENTION

[0017]
The invention is defined by the claims. The invention, in broader aspects, provides methods, systems, and computer program products for locating a regularly configured object within a digital image. In the method, a plurality of primary rotated integral images of the digital image are computed. Each primary rotated integral image has a different inplane rotation. A set of secondary rotated integral images are derived from each of the primary rotated integral images. The secondary rotated integral images have further inplane rotations relative to the respective primary rotated integral image. A window is defined within the digital image and corresponding windows of the rotated integral images. The values of convolution sums of a predetermined set of feature boxes within the window, in each of the rotated integral images are extracted. The dimensionality of the convolution sums is reduced to provide a set of reduced sums. A probability model is applied to the reduced sums to provide a best estimated derotated image of the window.

[0018]
It is an advantageous effect of the invention that improved methods, computer systems, and computer program products are provided, in which the most likely inplane orientation of objects can be rapidly estimated and in which substantial outofplane rotation is tolerated.
BRIEF DESCRIPTION OF THE DRAWINGS

[0019]
The abovementioned and other features and objects of this invention and the manner of attaining them will become more apparent and the invention itself will be better understood by reference to the following description of an embodiment of the invention taken in conjunction with the accompanying figures wherein:

[0020]
FIG. 1 is a diagrammatical view of an embodiment of the method of the invention. The letter I indicates an integral image.

[0021]
FIG. 2 is a perspective diagram of a computer system for implementing the present invention.

[0022]
FIG. 3 is a diagrammatical view of a series of facial images illustrating head pose. Top two rows show inplane rotation. Bottom two rows show outofplane (indepth) rotation.

[0023]
FIG. 4 is a diagrammatical view of the “average face” and its masked central region.

[0024]
FIG. 5 is the same view as FIG. 4 showing feature boxes of a particular embodiment. The masked central region is not indicated.

[0025]
FIG. 6 is a diagrammatical view of an inplane rotated digital image of a human face (first row), a convolution sum of a horizontal line of pixels through the image center (second row), a convolution sum of a vertical line of pixels through the image center (third row), and convolution sum of the feature boxes from FIG. 5 (fourth row).

[0026]
FIG. 7 is a diagram of rotation vs. log of likelihood and shows a typical pattern of likelihood at different orientations for a face whose true orientation was 230°.

[0027]
FIG. 8 is a diagram of the computed likelihood of upright face presence from the Gaussian model, by subsequent derotation angle.

[0028]
FIG. 9 is a diagram of the computed likelihood of upright face presence from the Gaussian mixture model, by subsequenct derotation angle.

[0029]
FIG. 10 is a diagram of tested intermediate rotation positions. The plots show the rotation estimation made by the Gaussian model as function of the actual rotation. Solid line—estimated 40° orientation; dashed line 50°; dotted lines 30° (left) and 60° (right).

[0030]
FIG. 11 is another diagram of tested intermediate rotation positions. The plots show the rotation estimation made by the Gaussian mixture model as function of the actual rotation. Solid line—estimated 40 degrees orientation; dashed line 50 degrees; dotted lines 30 degrees (left) and 60 degrees (right) degrees.

[0031]
FIG. 12 is a diagram of the procedure of using an integral image to compute rectangular convolution sums.
DETAILED DESCRIPTION OF THE INVENTION

[0032]
In the following description, a preferred embodiment of the present invention will be described in terms that would ordinarily be implemented as a software program. Those skilled in the art will readily recognize that the equivalent of such software may also be constructed in hardware. Because image manipulation algorithms and systems are well known, the present description will be directed in particular to algorithms and systems forming part of, or cooperating more directly with, the system and method in accordance with the present invention. Other aspects of such algorithms and systems, and hardware and/or software for producing and otherwise processing the image signals involved therewith, not specifically shown or described herein, may be selected from such systems, algorithms, components and elements known in the art. Given the system as described according to the invention in the following materials, software not specifically shown, suggested or described herein that is useful for implementation of the invention is conventional and within the ordinary skill in such arts.

[0033]
Still further, as used herein, the computer program may be stored in a computer readable storage medium, which may comprise, for example; magnetic storage media such as a magnetic disk (such as a hard drive or a floppy disk) or magnetic tape; optical storage media such as an optical disc, optical tape, or machine readable bar code; solid state electronic storage devices such as random access memory (RAM), or read only memory (ROM); or any other physical device or medium employed to store a computer program.

[0034]
Before describing the present invention, it facilitates understanding to note that the present invention is preferably utilized on any wellknown computer system, such a personal computer. Referring to FIG. 1, there is illustrated a computer system 110 for implementing the present invention. Although the computer system 110 is shown for the purpose of illustrating a preferred embodiment, the present invention is not limited to the computer system 110 shown, but may be used on any electronic processing system such as found in home computers, kiosks, retail or wholesale photofinishing, or any other system for the processing of digital images. The system 110 includes a microprocessorbased unit 112 for receiving and processing software programs and for performing other processing functions. A display 114 is electrically connected to the microprocessorbased unit 112 for displaying userrelated information associated with the software, e.g., by means of a graphical user interface. A keyboard 116 is also connected to the microprocessor based unit 112 for permitting a user to input information to the software. As an alternative to using the keyboard 116 for input, a mouse 118 may be used for moving a selector 120 on the display 114 and for selecting an item on which the selector 120 overlays, as is well known in the art.

[0035]
A compact diskread only memory (CDROM) 124, which typically includes software programs, is inserted into the microprocessor based unit for providing a means of inputting the software programs and other information to the microprocessor based unit 112. In addition, a floppy disk 126 may also include a software program, and is inserted into the microprocessorbased unit 112 for inputting the software program. The compact diskread only memory (CDROM) 124 or the floppy disk 126 may alternatively be inserted into externally located disk drive unit 122 which is connected to the microprocessorbased unit 112. Still further, the microprocessorbased unit 112 may be programmed, as is well known in the art, for storing the software program internally. The microprocessorbased unit 112 may also have a network connection 127, such as a telephone line, to an external network, such as a local area network or the Internet. A printer 128 may also be connected to the microprocessorbased unit 112 for printing a hardcopy of the output from the computer system 110.

[0036]
Images may also be displayed on the display 114 via a personal computer card (PC card) 130, such as, as it was formerly known, a PCMCIA card (based on the specifications of the Personal Computer Memory Card International Association) which contains digitized images electronically embodied in the card 130. The PC card 130 is ultimately inserted into the microprocessor based unit 112 for permitting visual display of the image on the display 114. Alternatively, the PC card 130 can be inserted into an externally located PC card reader 132 connected to the microprocessorbased unit 112. Images may also be input via the compact disk 124, the floppy disk 126, or the network connection 127. Any images stored in the PC card 130, the floppy disk 126 or the compact disk 124, or input through the network connection 127, may have been obtained from a variety of sources, such as a digital camera 134 or a scanner (not shown). Images may also be input directly from the digital camera 134 via a camera docking port 136 connected to the microprocessorbased unit 112 or directly from the digital camera 134 via a cable connection 138 to the microprocessorbased unit 112 or via a wireless connection 140 to the microprocessorbased unit 112. In accordance with the invention, the algorithm disclosed in the preferred embodiment of the invention may be stored in any of the storage devices heretofore mentioned and applied to images for object detection and location of specific objects.

[0037]
The object detection algorithm disclosed in the preferred embodiment of the present invention may be employed in a variety of user contexts and environments. Exemplary contexts and environments include, without limitation, wholesale digital photofinishing (which involves exemplary process steps or stages such as film in, digital processing, prints out), retail digital photofinishing (film in, digital processing, prints out), home printing (home scanned film or digital images, digital processing, prints out), desktop software (software that applies algorithms to digital prints to make them better—or even just to change them), digital fulfillment (digital images in—from media or over the web, digital processing, with images out—in digital form on media, digital form over the web, or printed on hardcopy prints), kiosks (digital or scanned input, digital processing, digital or hard copy output), mobile devices (e.g., PDA or cellphone that can be used as a processing unit, a display unit, or a unit to give processing instructions), and as a service offered via the World Wide Web.

[0038]
In each case, the algorithm may stand alone or may be a component of a larger system solution. Furthermore, the interfaces with the algorithm, e.g., the scanning or input, the digital processing, the display to a user (if needed), the input of user requests or processing instructions (if needed), the output, can each be on the same or different devices and physical locations, and communication between the devices and locations can be via public or private network connections, or media based communication. Where consistent with the foregoing disclosure of the present invention, the algorithm itself can be fully automatic, may have user input (be fully or partially manual), may have user or operator review to accept/reject the result, or may be assisted by metadata (metadata that may be user supplied, supplied by a measuring device (e.g. in a camera), or determined by an algorithm). Moreover, the algorithm(s) may interface with a variety of workflow user interface schemes.

[0039]
The performance of an object detection system is constrained by multiple and often counterbalancing dimensions of true and false detection rates, speed, and algorithm size. Two predominant engineering considerations come into play. First, the system detection statistics, both true and false, should not be impacted too adversely by the introduction of rotation tolerance. Second, system speed decline should not be too large.

[0040]
With respect to the effect of rotation tolerance to detection performance, a concern arises that introduced errors might counterbalance benefits of improved detection. For example, this is an issue with frontal face detection algorithms, since those algorithms exhibit good detection performance and extreme poses with rotated faces are relatively rare.

[0041]
The second practical consideration concerning algorithm choice relates to the speed impact of inplane rotation tolerance. For many applications of face detection, algorithm speed carries great weight. If the rotation intolerance comes at the cost of examination of several rotated versions of the image, then system speed will decrease by a factor equal to the number of orientations to be examined. (It is possible that some shared computation might reduce the speed penalty slightly.) If a rotation preestimator is applied, then the computational cost of the estimator is added to the computational cost of the subsequent face detector, and could easily halve the overall system speed. It is most important, then, that speed loss be kept to a minimum while still obtaining the desired performance invariance.

[0042]
The methods, systems, and computer program products of the invention have an algorithm that provides an accurate and very fast rotation preestimator. In disclosed embodiments, the preestimator locates rotated human faces based upon learning the patterns of rectangular integrals in the face region of a set of upright facial images. The invention is generally described herein in relation to embodiments that detect human faces, but is not limited and can detect other classes of objects that exhibit geometrically consistent three dimensional shapes and predictable patterns of predominantly lighter and darker regions or symmetries.

[0043]
Different types of head rotations are referred to here by the terms “inplane rotation” and “outofplane rotation”. This first two rows of images in FIG. 3 illustrate inplane rotation. The inplane rotation of the head leads to inplane rotation of the face appearance in the image. The “plane” in view here can be visualized as the imaging focal plane or the projection of the focal plane back into 3D space. Rotations inplane result in identical but rotated patterns in a digitized image, that is, the imaging operation can be commuted with the rotation. On the other hand, outofplane rotations, also termed rotations in depth, result in entirely different patterns in the image. The second two rows of FIG. 3 show outofplane rotations.

[0044]
Referring now to FIGS. 1A2, the system 110 has a computational unit 112, which receives a digital image 200 from an image source, such as a digital camera 134, removable memory, or a local or remote communication network. Within the computational unit, the preestimation algorithm is applied. A rotation estimation procedure will necessarily operate as a preliminary step in a global image face detection search. The search process can use a scheme of searching across locations and scales in an image to find faces of different sizes and locations. Alternatively, in a simple case, the search process can zero in on a single position and scale.

[0045]
An integral image module 202 computes one or more primary rotated integral images 204 of the digital image. (FIG. 1A illustrates only a single primary rotated integral image.) Each primary rotated integral image has a different rotation relative to an initial position defined by the inplane rotational position of the digital image.

[0046]
An derivation module 206 derives a set of secondary rotated integral images 208 from each of the primary rotated integral images 204. The set has secondary rotated integral images 208 having further inplane rotations of 90 degrees, 180 degrees, and 270 degrees relative to the respective primary rotated integral image 204. For example, a primary rotated integral image having a rotation of 10 degrees relative to the digital image has corresponding secondary rotated integral images at 100 degrees, 190 degrees, and 280 degrees.

[0047]
A window module 207 defines one or more windows 209 within the primary and secondary rotated integral images. A window 209 is a rectangular array of image pixels. Each window has the same orientation in each of the rotated integral images, in other words, the windows do not rotate with the integral images. In the illustrated embodiment, a human face 211 is represented within a particular image window. The face has an inplane rotation away from the upright position in the original digital image. The search for windows can be exhaustive at all locations and scales. “All scales” refers to windows having a minimum size large enough to accommodate a predefined set of facial characteristics or like characteristics of another class of regularly configured objects.

[0048]
An image measurement module 210 then extracts one or more sets of representative image measurements from each of the windows and summarizes those measurements as one or more numerical data vectors. The multiple data vectors correspond to multiple possible rotational orientations of a human face, should a face be present in the image window. The measurements extracted are convolution sums of feature boxes within each of the windows, in each of the rotated integral images.

[0049]
In an embodiment shown in FIG. 5, the feature boxes are arranged in first and second horizontal rows. Each row has two outer feature boxes 302. Each outer feature box is longer horizontally than vertically. Each row has a single inner feature box 304 disposed between respective outer feature boxes 302. The feature boxes do not touch 302,304, but could do so. The feature boxes 302,304, when aligned with a nominally sized and oriented human face, overlap the eyes and bridge of the nose with the first row of feature boxes and overlap the mouth and part of the cheeks with the second row of feature boxes.

[0050]
Next, a dimensionality reduction module 220 performs a mathematical transformation on the numerical data vectors, resulting in transformed numerical data vectors that are more stable in the data space used to estimate face rotational position. Reduction of the dimensionality of the convolution sums provides a corresponding set of reduced sums.

[0051]
A probability module 230 evaluates a probability density model, using the transformed numerical data vectors, to determine a probability that a face is present at each of the respective potential face orientations. Using the probabilities, a derotation module 240 digitally rotates the extracted image window by an amount to exactly compensate for the most probable face orientation, producing a derotated image. It is expected that a face, if present in the window, will now have the upright orientation. The application of the probability model and derotation algorithm to each of the sets of reduced sums provides a best estimated derotated image of each of the windows. A simple peakfinding algorithm operates on the likelihood data for each test window. Many such algorithms will be known to those skilled in data analysis. The simplest possible algorithm, and the preferred implementation in this invention, is to simply search for the maximum likelihood among the computed likelihoods. However, it will be recognized that more robust schemes might involve lowpass filtering of the data prior to peak searching, to deal with the high noise levels that are apparent in the likelihood computations.

[0052]
An object detection module 250 receives the derotated image 242 (symbolized as a face), is trained to detect human faces and can next examine the derotated images to perform a yes/no classification decision, indicating either the presence of the absence of a face in the original image window.

[0053]
The above steps are repeated on multiple image windows in an image search strategy, thereby performing an exhaustive search of the entire image to find as many faces as are present in the image. The ability to find the human faces in an image stream offers numerous possibilities for enhanced imaging services, including services based upon higherlevel semantic understanding and processing of the images. Examples of servics are: ensuring the correct reproduction of the skin colors of facial regions and provision of optional imaging services related to the thematic category of an image or group of images (such as baby or wedding pictures).

[0054]
Referring now to a particular embodiment, in the preestimation procedure, primary rotated integral images are computed for 90 degrees of rotation and secondary rotated integral images are derived so as to provide rotated integral images at k rotational orientations, spaced at 0°, 360/k°, 2*360/k°, . . . , 350°. In this case, k=36, which provides a 10° spacing was used. Other spacing can be provided in the same manner. It was presumed that during a subsequent image search by the face detection algorithm, a test window centered at (r,c) with scale s, would be examined to determine whether a human face was present. Using the k/4 rotated integral images, the probability model was applied k/4 times by extracting the face region projections and sums at the proper location, taking into account the scale, from each of the rotated integral images. The measured image data (convolution sums) then underwent dimensionality reduction and were plugged (separately) into the probability models (equations (7) and (10)) to obtain the likelihood of the data given face at the respective rotational orientations.

[0055]
The derived secondary rotated integral images, in effect, provide repeats of the procedures for each initial angle between 0 degrees and 90 degrees with the additional orthogonal rotations (relative to the initial angle) of 90°, 180°, and 270°. The same integral images are used, advantage being taken of the periodicity properties of integral image, with access modified using the translations presented in Table 1. In this way, k likelihood values for face presence are estimated, and the rotational angle is judged to be that which gave rise to the highest likelihood (that is, the maximum a posteriori principle). FIG. 7 shows a typical pattern of likelihood at different orientations for a face whose true orientation was 230°. The likelihood peaks around 130°, which is the amount of rotation needed to make the face appear upright. In fact, the face orientation can be estimated as 360° minus the orientation of maximum likelihood response. The response profile also shows a secondary peak 180° away from the primary maximum. This common occurrence led to the introduction of the additional six face regions, shown in FIG. 5, whose sums are also measured and included in the data vector acted upon by the rotation model.

[0056]
The digital image is initially provided as an intensity image. The integral image ℑ of intensity image I(i,j) is defined in the discrete domain with the equation:
$\begin{array}{cc}{\U0001d50d}_{\left(\mathrm{discrete}\right)}\left(i,j\right)=\sum _{r=1}^{i}\sum _{c=1}^{j}I\left(r,c\right)& \left(1\right)\end{array}$
Thus, the intensity image value at pixel (i,j) is the summation of all image pixels above and to the left of (i,j), inclusive (note the use of originunity image coordinates). The integral image can be computed in a single pass over the image I using the recurrence relations:
S(i,j)=S(i,j−1)+I(i,j)
ℑ(i,j)=ℑ(i−1,j)+S(i,j) (2)
with boundary values fixed all at zero.

[0057]
Using the integral image, the value of the convolution sum over any rectangular region of the intensity image can be computed with four memory accesses and three additions. This fixed operation count does not depend on the size or location of the rectangle. Suppose it is desired to compute the sum of a rectangle having upper left pixel (r_{0},c_{0}) and lower right pixel (r_{1},c_{1}). The computation is
$\begin{array}{cc}\begin{array}{c}\sum _{\mathrm{rect}}I=\mathrm{II}\left({r}_{1},{c}_{1}\right)+\U0001d50d\left({r}_{0}1,{c}_{0}1\right)\U0001d50d\left({r}_{0}1,{c}_{0}\right)\\ \U0001d50d\left({r}_{0},{c}_{0}1\right)\end{array}& \left(3\right)\end{array}$
Referring to FIG. 12, the computation can be visualized geometrically as the summation and subtraction of four rectangular areas of the intensity image. To compute the integral of rectangle D of the intensity image, using integral image values perform (A+B+C+D)+(A)−(A+B)−(A+C), totaling four accesses to the integral image.

[0058]
Image operators such as convolution, differentiation, and integration can be freely commuted. If images f and g have finite support, considering f^{n }to be the nth integral of f (or the nth derivative if n is negative), then the order of integration (or differentiation) and convolution can be freely exchanged:
(f*g)^{n} =f ^{n} *g=f*g ^{n} (4)
Alternatively, integration, differentiation, and convolution can all be combined and freely commuted, as in
f*g=(∫∫f)*g ^{n} (5)
Application in discrete form of equation (5) follows directly when f represents the intensity image I and g is the spatial rectangle of interest. The two summations of I take place along the row and column dimensions, as do likewise the two discrete differences of the rectangle g. The computational advantages of the right hand side of equation (5) over the left hand side occur because the integral image of I can be computed just once, and the second differences of the rectangle g consist of exactly four delta functions in the rectangle corners. Thus, the many summations of the discrete convolution of equation (5) (left hand side) are replaced by four accesses to ΣΣI.

[0059]
The integral image computations exhibit a kind of pseudoperiodicity with respect to 90° rotations that permits computations to be reduced to
$\frac{k}{4}$
integral images. In the context of the rotation preestimator, each rotated integral image is symmetrical to orthogonal (0°, 90°, 180°, 270°) rotations. Given a rotated integral image at an initial angle of rotation relative to the digital image, the rotated integral images of three other orthogonal orientations (also referred to herein as “symmetrical angles”) can be derived from it. This fact can be seen from three observations. (1) The values of an integral image are exactly sums over rectangles, where nominally the rectangles have one corner fixed at the upper left pixel. (2) Arbitrary rectangle sums can be calculated using at most four accesses to an integral image. (3) Rectangles remain rectangles upon orthogonal rotation (albeit in a different pixel position).

[0060]
Table 1 presents translations required to derive three secondary rotated integral images at symmetrical angles from a primary rotated integral image at an initial angle. The transformations in Table 1 allow one to compute primary rotated integral images limited to a 90 degree range of orientations and then derive the secondary rotated integral images, thereby cutting the computational cost of the inplane rotation estimation by essentially a factor of four. In the table, a rectangle anchored at (r
_{0},c
_{0}) of size w×h, rotated about center of rotation c
_{row}, c
_{col}, is transformed with new parameters expressed in the coordinate system of the unrotated integral image.
TABLE 1 


Access translations needed to effect orthogonal 
rotations to primary rotated integral images. 
Rota     
tion  Upper left row  Upper left column  Width  Height 

0  r_{0}  c_{0}  w  h 
90  c_{row }+ c_{col }− c_{0 }− w + 1  c_{col }− c_{row }+ r_{0}  h  w 
180  2 * c_{row }− r_{0 }− h + 1  2 * c_{col }− c_{0 }− w + 1  w  h 
270  c_{col }− c_{row }+ c_{0}  c_{row }+ c_{col }− r_{0 }− h + 1  h  w 


[0061]
In order to build a rotation estimator using rectangular convolution sums, it is necessary to select the specific rectangles, called “features”, to be used when examining the test window. In every case spatially normalized windows are considered. A reference nominal window is defined, of dimensions 56×56 pixels. If a face is present in the window, its reference nominal position is as shown in the FIG. 4, with the eyes centered at row, col (28, 20) and (28, 35), respectively.

[0062]
Faces in digitized images can be of various sizes, and it is desired to find them regardless of their size. One common method of providing size invariance is to perform a multiscale search of the image, examining windows of all sizes. It is only necessary to proportionally adjust the sizes of the nominal features based on the ratio of the size of the test window to the size of the reference window. Since the integral image provides rectangular convolution sums of all rectangles, regardless of size, using constant operation count, it can be seen that the size of the test window has no effect on the feature measurement process with the exception that the convolution sums must be normalized to account for the variable number of pixels in the test window compared to the nominal window.

[0063]
There are many methods of feature selection known in the computer vision literature, broadly divisible into automated and manual means of selection. In automated means of selection, such as in Viola, Paul, and Jones, Michael, “Robust RealTime Object Recognition”, Proc. Second International Workshop on Statistical and Computational Theories of Vision—Modeling, Learning, Computing, and Sampling 2001. and Pudil, P., Novovicova, J, and Kitller, J., “Floating search methods in feature selection”, Pattern Recognition Letters 15, 11191125, a pool of available features is assembled, and features are selected one at a time, according to some selection criteria, until the desired number of features, or the desired classifier performance, is attained. In the context of this invention, the pool of features consists of all possible rectangular convolution sums, with the rectangles being of all sizes and positions, in the nominal 56×56 pixel test window. There are many tens of thousands of such rectangle features.

[0064]
In Viola, Paul, and Jones, Michael, “Robust RealTime Object Recognition”, Proc. Second International Workshop on Statistical and Computational Theories of Vision—Modeling, Learning, Computing, and Sampling, 2001, the authors teach a sequential forward search (SFS) feature selection method consisting of a greedy search algorithm. An overall merit function is defined, typically consisting of the classification error on a set of training image examples. At each step, the available feature is selected that most reduces the merit function. This algorithm suffers from the propensity to move towards local minima in the merit function, as do all greedy optimization algorithms. For this reason, Pudil, P., Novovicova, J, and Kitller, J., “Floating search methods in feature selection”, Pattern Recognition Letters 15, 11191125 invented to concept of sequential forward floating search (SFFS), in which backtracking steps can be taken by discarding previous chosen features if the merit function can be further reduced. In this way, the algorithm can move out of local minima with the hope of finding a better overall feature set.

[0065]
An alternative to automated feature selection algorithms is the process of manual feature selection. In manual selection, the opportunity is presented for a human expert to choose features based on problem domain knowledge or any other factors that might be pertinent. Thus, the elusive quality of “human intelligence” comes into play. Specifically, automated methods can only choose feature sets based on the specifics of the example training sets used as the basis for the optimization. In many computer vision applications, the assemblage of suitable and representative training sets can be the most difficult portion of the undertaking. For this reason, it can be true that manual feature selection will lead to a more parsimonious and powerful feature set, resulting in better generalization performance of the final classifiers.

[0066]
As part of this invention, either automated or manual feature selection methods can be used to determine the specific rectangular convolution sums used. For face orientation, the preferred method is to select feature sets manually to take advantage of human knowledge of the problem domain.

[0067]
It can be noted that the arrangement of human facial features leads to very different profiles of aggregation across the vertical and horizontal directions of the facial region. Using FIG. 5 as a reference, consider the sums of the horizontal and vertical lines of pixel intensity values in the circularly masked face region. FIG. 6, shows the same face along with bar graphs of those directed sums. In the top row are shown nine inplane rotated versions of the central face masked area followed by two rows with bar charts of the horizontal and vertical sums of the intensity pixels, respectively. In each case, the sums have been normalized by the number of pixels in the masked row or column. (The bottom row of bar charts will explained shortly.)

[0068]
The following observations can be made. First, in the upright face position, there is a clear difference in the horizontal and vertical sums. The vertical sum (third row) exhibits a symmetry that reflects the leftright physical symmetry of the face. The horizontal sum shows a strong minimum in the position of the eyes, and a less pronounced minimum at the mouth position. Second, as the face rotates these clear signatures become mixed together until, at the 45° orientation, they are virtually identical. Third, if the next (90° degree) face orientation were shown in the figure, it would be the same as the upright orientation but with the roles of horizontal and vertical sums exchanged. In fact, there is a pseudo 90° symmetry (horizontal and vertical sums exchanged) and true 180° symmetry in the sums. The method here, in effect, trains a machine learning algorithm to recognize the typical pattern of the sums in the upright face orientation (left column of FIG. 6) and distinguish that pattern from the patterns of the other orientations.

[0069]
Now, to explain the bottom row of FIG. 6, a set of six addition convolution sums were also computed, representing the sums of six rectangular facial regions as shown in FIG. 5. The rationale behind the selection of these regions is to overcome a predominant failure mode due to training the learning algorithm using just the horizontal and vertical integrals, namely estimation of the face orientation in error by exactly 180° (and, to a lesser extent, 90°). The six regions, covering the eyes and mouth, yield very different typical sums when rotated 90° and 180°.

[0070]
A linear transformation is used to reduce the dimensionality of the convolution sums. This helps remove the manifold redundancies and noise sources that are present in visual information. This step is especially important in machine learning systems that learn from examples, for at least two reasons. First, it is frequently not possible to provide a large enough set of training examples to fully cover the range of variations possible in the test stimuli. Second, machine learning algorithms frequently have high capacity—that is, high ability to learn the peculiarities of the training data—that will respond and lock into statistical fluctuations of the training data that are not generally true of the object class. These aspects of machine learning tasks presents a risk of overfitting—biasing learning methods to accidents in the training data, and not to general, consistent characteristics of the object class of interest.

[0071]
There are two primary methods for dealing with the problem of overtraining during machine learning. The first method is to reduce the “capacity” of the learning algorithm Vapnik, V., The Nature of Statistical Learning Theory, Springer Verlag, New York, 1995—that is, to reduce its ability to respond to accidents in the training data by restricting the types of data models it can employ. This solution is directly analogous to limiting the degree of polynomial in datamodeling. The second method is to preprocess the data in an attempt to remove the accidents and present only its essential characteristics to the learning algorithm.

[0072]
Dimensionality reduction is a solution of the second type to overtraining. Many methods of dimensionality reduction are known in the literature, usually involving mathematical transformations of measured data. Transformation can range from simple linear transformations (such as principal components analysis (PCA), Fisher analysis, etc.) to arbitrarily complex nonlinear transformations (examples include nonlinear principal components, autoassociative neural networks, kernel components analysis, etc.). Any of these dimensionality reduction methods can be used as part of this invention. Currently preferred is the wellknown linear PCA transformation.

[0073]
The principal components analysis (PCA) creates a linear transformation of data into a related representational space in which the dimensions are statistically independent and orthogonal. Furthermore, the dimensions are arranged such that the first few encode the bulk of the variations present in the training data. The PCA possesses many desirable mathematical properties Magnus, J., and Neudecker, H., Matrix Differential Calculus with Applications in Statistics and Econometrics, John Wiley and Sons, Chichester, 1988. The PCA, being a linear transformation, also has the advantage of fast speed. Inspection of the sum profiles in FIG. 6 immediately reveals the presence of redundancy in the data, as evidenced by the slowly varying nature of the top two rows. A PCA transformation reduces the dimensionality of the data and enables the estimation of more reliable statistical models. In this work, d=20 or d=40 for the dimension of the PCA subspace into which the data were converted, from the original representation of the sums with N=58 dimensions.

[0074]
The evaluation of the probability model is a maximum a posteriori (MAP) estimation of the most likely face orientation using the modeled distribution. The evaluation constructs an estimate of the statistical distributions of the reduced dimension image data observed when (1) the image window contains a face, and (2) the face is upright in rotational orientation. It will be recognized by a person skilled in the art that many different methods of probability density estimation can be used as part of this invention. Described below are two currently preferred implementations: the Gaussian model (a parametric method) and the Gaussian mixture model (a semiparametric method). We choose these two methods because of their simplicity and wellknown, desirable mathematical tractability.

[0000]
Gaussian probability model.

[0075]
A Gaussian probability model was used to estimate the posteriori likelihood of a data observation given the assumption that an upright face was present in an image test window. In this model, starting with the standard Gaussian form
$\begin{array}{cc}P\left(x\Omega \right)=\frac{\mathrm{exp}\left(\frac{1}{2}\left(x\mu \right){\Sigma}^{1}\left(x\mu \right)\right)}{2\text{\hspace{1em}}{\pi}^{\frac{n}{2}}{\uf603\Sigma \uf604}^{\frac{1}{2}}}& \left(6\right)\end{array}$
(having Ω represent the class of faces, Σ the full covariance matrix and μ the mean of the Gaussian) we substitute an approximation for equator (6) in which the principal components y=Φ^{T}(x−μ) are combined with the reconstruction residual to arrive at a twocomponent estimate of likelihood
$\begin{array}{cc}\hat{P}\left(x\Omega \right)=\left[\frac{\mathrm{exp}\left(\frac{1}{2}\sum _{i=1}^{d}\frac{{y}_{i}^{2}}{{\lambda}_{i}}\right)}{2\text{\hspace{1em}}{{\pi}^{\frac{d}{2}}\left(\prod _{i=1}^{d}{\lambda}_{i}\right)}^{\frac{1}{2}}}\right]\left[\frac{\mathrm{exp}\left(\frac{{\varepsilon}^{2}\left(x\right)}{2\text{\hspace{1em}}\rho}\right)}{{\left(2\text{\hspace{1em}}\pi \text{\hspace{1em}}\rho \right)}^{\left(Nd\right)/2}}\right]& \left(7\right)\end{array}$
where ρ is an estimate of the average of the N−d least significant eigenvalues, Φ the matrix of most significant eigenvectors of Σ in the columns, the λ_{i }are the d more significant eigenvalues, and ε^{2}(x) the reconstruction residual of the test datum x. The estimate ρ is conventionally made by fitting the eigenspectrum of Σ. These two components of the probability estimate {circumflex over (P)}(xΩ) have conventionally been termed the “distance in face space” (DIFS) and “distance from face space” (DFFS) in this context. The advantage of this twocomponent formulation is that, by considering the reconstruction residual, the estimate explicitly takes into account the possibility of a different explanation for the observed data other than the presence of the desired object. It has been shown that such a formulation leads to improved density estimations in realworld applications to facial imaging.
Gaussian mixture model.

[0076]
The mixture model has the form
$\begin{array}{cc}P\left(x\Omega \right)=\sum _{j=1}^{M}p\left(xj\right)P\left(j\right)& \left(8\right)\end{array}$
subject to the constraints
$\begin{array}{cc}\sum _{j=1}^{M}P\left(j\right)=1\text{}0\le P\left(j\right)\le 1& \left(9\right)\end{array}$
Each of the M components are themselves diagonalcovariance Gaussian models after
$\begin{array}{cc}P\left(xj\right)=\frac{\mathrm{exp}\left(\frac{1}{2}\sum _{i=1}^{d}\frac{{y}_{i}^{2}}{{\lambda}_{i}^{j}}\right)}{2\text{\hspace{1em}}{{\pi}^{\frac{n}{2}}\left(\prod _{i=1}^{d}{\lambda}_{i}^{j}\right)}^{\frac{1}{2}}}& \left(10\right)\end{array}$
with again y=Φ^{T}(x−μ^{j}) being the reduced dimension representation of x. (Now, subscripts indicate vector components, superscripts identify the vectors associated to the different mixture components). Notice that the second residual term in equation (7) is dropped for the sake of analytical simplicity in the derivative of the parameter estimation algorithm explained later. Even with this simplification, direct training of such a model by density estimation becomes intractable, and resort must be made to an iterated estimate of the parameters of the Gaussian components p(xi) and the prior component probabilities P(j). The expectationmaximization (EM) algorithm uses the analytical derivatives of the training data likelihood with respect to the model parameters (P(j),j=1 . . . M, λ_{i} ^{j}, i=1 . . . d, and μ^{j}) to iteratively improve estimates of the parameters in a gradientdescent framework.
ExpectationMaximization of a Gaussian Mixture Model

[0077]
Starting from Bishop, C., Neutral Networks for Pattern Recognition, Oxford University Press, Oxford, 1995 the derivation of the expectationmaximization algorithm for estimating the parameters of the Gaussian mixture model
$\begin{array}{cc}P\left(x\Omega \right)=\sum _{j=1}^{M}p\left(xj\right)P\left(j\right)& \left(11\right)\end{array}$
using the diagonalcovariance components
$\begin{array}{cc}P\left(xj\right)=\frac{\mathrm{exp}\left(\frac{1}{2}\sum _{i=1}^{d}\frac{{y}_{i}^{2}}{{\lambda}_{i}^{j}}\right)}{2\text{\hspace{1em}}{{\pi}^{\frac{n}{2}}\left(\prod _{i=1}^{d}{\lambda}_{i}^{j}\right)}^{\frac{1}{2}}}& \left(12\right)\end{array}$
where of course y=Φ^{T}(x−μ^{j}) is the lowdimension representation of x. EM uses the maximumlikelihood principle: parameters are chosen to maximize the joint likelihood of the observed training data. To this end, we minimize the negative log likelihood of the training data given by
$\begin{array}{cc}E\equiv \sum _{n=1}^{N}\mathrm{ln}\text{\hspace{1em}}p\left({x}^{n}\right)=\sum _{n=1}^{N}\mathrm{ln}\left\{\sum _{j=1}^{M}p\left({x}^{n}j\right)P\left(j\right)\right\}& \left(13\right)\end{array}$
We can take analytical derivatives of equation (13) with respect to the model parameters to obtain the following expressions:
$\begin{array}{cc}\frac{\partial E}{\partial {\mu}_{i}^{j}}=\sum _{n=1}^{N}P\left(j{x}^{n}\right)\frac{{\mu}_{i}^{j}{y}_{i}^{n}}{{\lambda}_{i}^{j}}& \left(14\right)\end{array}$
$\begin{array}{cc}\frac{\partial E}{\partial {\lambda}_{j}^{i}}=\sum _{n=1}^{N}P\left(j{x}^{n}\right)\left\{\frac{1}{2\text{\hspace{1em}}{\lambda}_{i}^{j}}+\frac{{\left({y}_{i}^{n}{\mu}_{i}^{j}\right)}^{2}}{2{\left({\lambda}_{i}^{j}\right)}^{2}}\right\}& \left(15\right)\end{array}$
Finding
$\frac{\partial E}{\partial P\left(j\right)}$
while simultaneously enforcing the constraints equation (9) can be effected by introducing M auxiliary variables γ_{j }and the softmax formulation
$\begin{array}{cc}P\left(j\right)\equiv \frac{\mathrm{exp}\left({\gamma}_{j}\right)}{\sum _{k=1}^{M}\mathrm{exp}\left({\gamma}_{k}\right)}& \left(16\right)\end{array}$
which ensures that the constraints are satisfied for any values of the γ_{y}. Then,
$\begin{array}{cc}\frac{\partial E}{\partial {\gamma}_{j}}=\sum _{n=1}^{N}\left\{P\left(j{x}^{n}\right)P\left(j\right)\right\}& \left(17\right)\end{array}$
and the P(j) can be computed using the definitions equation (16). To minimize equation (13), we set derivatives with respect to all adjustable parameters (equations 14, 15, 17) to zero, leading to the following update equations:
$\begin{array}{cc}{\hat{\mu}}^{j}=\frac{\sum _{n=1}^{N}P\left(j{x}^{n}\right){x}^{n}}{\sum _{n=1}^{N}P\left(j{x}^{n}\right)}& \left(18\right)\\ {\lambda}^{j}=\frac{\sum _{n=1}^{N}P\left(j{x}^{n}\right){\uf605{y}^{n}{\hat{\mu}}^{j}\uf606}^{2}}{\sum _{n=1}^{N}P\left(j{x}^{n}\right)}& \left(19\right)\\ \hat{P}\left(j\right)=\frac{1}{N}\sum _{n=1}^{N}P\left(j{x}^{n}\right)& \left(20\right)\end{array}$
Equations (1820) form a coupled set of nonlinear equations, where the parameters on the left hand sides also appear on the right hand sides due to the presence of the posteriori class probabilities P(jx^{n}), and hence the equations cannot be solved directly. The EM must be provided with initial estimates for all parameters (P(j), j=1 . . . M, λ_{i} ^{j}, i=1 . . . d, and μ^{j}) and then it iteratively computes equations (1820) for some desired number of updates, or until a local minimum is achieved. An iteration of the algorithm can never increase the log likelihood equation (13), and hence the algorithm is guaranteed to converge to at least a local minimum.

[0078]
A face detector is used to find the locations in the derotated image of the window that have a high probability of containing faces. The output of this detector consists of estimated pixel locations for the eyes (for frontal faces) or eye and ear center for profile faces.

[0000]
Face Detector

[0079]
An example of a suitable face detector is provided in Schneiderman, H., and Kanade, T., “Probabilistic Modeling of Local Appearance and Spatial Relationships for Object Recognition”, Proc. CVPR 1998, 4551. This detector, called algorithm S, implements a Bayesian classifier that performs maximum a posteriori (MAP) classification using a stored probability distribution that approximates P(faceimage). The method is called Bayesian because of the use of Bayes' theorem to convert the a priori measured training distribution P(imageface) into the posterior probability in the presence of evidence from an image. The evidence consists of the pixel values in a spatial and intensitynormalized image window. The use of Bayes' theorem is mandated by the observation that image evidence can be ambiguous. In some cases, objects and scenes not in the class of interest (i.e. faces, in this context) can give rise to image patterns that can be confused with class (=face) objects. Bayes' theorem requires the collection of representative nonclass images, known as “world” images. The collection of world images proves to be the most difficult and critical process involved with training the algorithm. The difficulty lies in the fact that the world is very diverse. Faces are not diverse (at least when compared to the world), and so collection of training examples of faces is quite straightforward. This difficulty will be discussed at length in the section on training.

[0080]
Algorithm S is discussed in the context of face detection, but it will be understood that the same algorithm can alternatively be trained to detect cars, cakes, and other moderatelyvariable objects such as birthday and wedding cakes.

[0081]
Algorithm S was subject to the following simplifications (described in the sections that follow):

 1) standardize face region size
 2) decompose face region into subregions
 3) ignore dependencies between subregions
 4) project subregions to lower dimension representation using PCA
 5) code projections using sparse coefficients
 6) quantize sparse coefficients
 7) decompose appearance and position
 8) ignore position for uncommon patterns
 9) vector quantize positional dependence for common patterns
 10) apply (1)(9) at multiple resolutions, assuming independence between resolutions
Standardize Object Region Size

[0092]
Spatially normalized faces can be presented in a 56×56 pixel region. This simplification changes P (faceimage) into
P(face56×56 region) (21)
Decompose Object Region into SubRegions

[0093]
Each face region is decomposed into multiple overlapping 16×16 pixel subregions. These subregions can be anchored at every pixel position in the region, or at a subset of these positions, for example, subregions anchored at every third pixel in every third line. With this choice, there are 196 possible anchor positions of a subregion within a face region; this position can therefore be encoded in a single byte. On the right hand side of equation (21), “region” can be replaced with “{subregion}”, an aggregate of subregions.

[0094]
The subregion size is chosen so that individual subregions, when suitably positioned, are large enough to contain facial features (such as eyes, nose, or mouth). This size limits the largest image feature that can be examined as a coherent unit.

[0000]
Ignore Dependencies Between SubRegions

[0095]
No attempt was made to model the statistical dependencies between subregions. This simplification therefore limits the type of object attributes that can be modeled. For example, while a single subregion can contain sufficient pixels to capture an eye, the other eye will fall into a different subregion, and there can be no consideration taken of similarity or dissimilarity between the two eyes. Nor can any reasoning be based on the relative levels of illumination of different parts of the face.

[0096]
Using this simplification, equation (21) can now be replaced with
$\begin{array}{cc}\prod _{i=1}^{\#\text{\hspace{1em}}\mathrm{subregions}}P\left(\mathrm{face}{\mathrm{subregion}}_{i}\right)& \left(22\right)\end{array}$
where the statistical independence is reflected in the lack of joint dependencies on multiple subregions.
Project SubRegions to Lower Dimension Representation Using Principal Components Analysis (PCA)

[0097]
Since subregions contain 256 pixels, with 256 gray levels each, the number of possible subregions is huge. The next simplification involves applying the standard technique of linear PCA to reduce the dimensionality of the subregion from 256 to twelve. (The choice of twelve dimensions is somewhat arbitrary. Upwards of 90% of actual subregion variance can be encoded using no more than twelve dimensions.) To perform the PCA, a large training set of face images was processed, with all subregions participating in the data analysis.

[0098]
As to the question of whether separate principal components are necessitated for different image resolutions and multiple face poses it was decided that distinct sets of principal components would be stored for each resolution, but that it was not necessary to keep different sets by face pose.

[0099]
The result of the projection step is that each image subregion becomes represented by the twelve projection coefficients along the principal component axes. This representation amounts to representing each subregion by a linear combination of twelve principal subregions. The projection operation is carried out by a matrix operation
[proj]=A ^{T}[subregion] (23)
where A is the projection matrix whose columns contain the eigenvectors (principal components) of the training subregions. Note that the PCA operates on a training set of face images only. False (nonface) examples are not used since the resulting principal components would likely be subject to wide variability caused by statistically inadequate sampling of the very large set of possible nonface images. As a result of this step, expression equation (22) leads to
$\begin{array}{cc}\prod _{i=1}^{\#\text{\hspace{1em}}\mathrm{subregions}}P\left(\mathrm{face}{\mathrm{proj}}_{i}\right)& \left(24\right)\end{array}$
.
Code Projections Using Sparse Coefficients

[0100]
Rather than retain all twelve projection coefficients, the subregion representation is further compressed by retaining only the six most significant. However, this sparse coding scheme is further complicated by grouping the last six coefficients pairwise into groups and considering their sum square values when selecting the six projection dimensions to retain. In this way, twelve coefficients are reduced to six for subsequent processing.

[0000]
Quantize Sparse Coefficients

[0101]
Further compression of subregion representation occurs through discrete quantization of the nine coefficients using a LloydMax quantizier. This quantizier minimizes the meansquare quantization error under the assumption of a Gaussian distribution of the independent variable. For common values of the number of quantization values, the bin breakpoints and the reconstruction levels of LloydMax quantizers are tabulated in Lim, J., TwoDimensional Signal and Image Processing, PrenticeHall, New Jersey, 1990. To test the validity of the Gaussian distribution assumption, the actual distribution of the projection coefficients of the training set were collected. It was seen that the Gaussian assumption closely matched the actual distribution.

[0102]
The choice of the number of sparse coefficients retained and the number of quantization levels allocated to each coefficient determines the number of possible quantization values that encode image subregions. Based on the choices of six prominent dimensions, with some (arbitrary choices) of 8, 4, or 2 quantization levels for each dimension, the algorithm as implemented can represent each subregion by one of approximately 1,000,000 numbers. These quantized numbers are somewhat inscrutably called “q1” values in the reference. The number of possible q1 values is an algorithm sizing parameter referred to as “n_{q} 1” in Schneiderman, H., and Kanade, T., “Probabilistic Modeling of Local Appearance and Spatial Relationships for Object Recognition”, Proc. CVPR 1998, 4551.

[0103]
The compression advantage of this quantization scheme becomes clear when it is seen that 256^{256 }possible subregion patterns are encoded in 10^{6 }distinct numbers.

[0104]
Following the quantization step, the probability equation (24) is further simplified to
$\begin{array}{cc}\prod _{i=1}^{\#\text{\hspace{1em}}\mathrm{subregions}}P\left(\mathrm{face}{\mathrm{q1}}_{i}\right)& \left(25\right)\end{array}$
.
Decompose Appearance and Position

[0105]
At this point in the chain of simplifications of the probability distribution, equation (25) is expanded to explicitly include both the pixel pattern of a subregion and its position within the face region. Equation (25) is replaced with
$\begin{array}{cc}\prod _{i=1}^{\#\text{\hspace{1em}}\mathrm{subregions}}P\left(\mathrm{face}\u2758q\text{\hspace{1em}}1,{\mathrm{pos}}_{i}\right)& \left(26\right)\end{array}$
where each subregion is now represented by its quantization value and its position within the face region. Interpretation of equation (26) intuitively leads to thoughts like the following: eyelike patterns ought to occur in face regions only in the subregions likely to contain eyes.
Ignore Position for Uncommon Patterns

[0106]
Given that 1,000,000 quantization levels and 196 positions are possible for each subregion, further simplifications of equation (26) must occur. Two more simplifications are made to this expression. First, a decision is taken to encode the positional dependence of only the most commonly occurring q1 patterns. To this end, a large sorting step orders the q1 patterns by decreasing frequency of occurrence in the training set. All q1 patterns that sort below an occurrence threshold will have their positional dependence replaced by a uniform positional distribution. The number of q1 patterns whose positional distribution is to be explicitly learned during training is an algorithm sizing parameter referred to as “n_{est}” in [SCHN98]. For the uncommon patterns, equation (26) becomes
$\begin{array}{cc}\prod _{i=1}^{\#\text{\hspace{1em}}\mathrm{subregions}}\frac{P\left(\mathrm{face}\u2758q\text{\hspace{1em}}{1}_{i}\right)}{\mathrm{npos}}& \left(27\right)\end{array}$
where npos=196 is the number of possible subregion positions.
Vector Quantize Positional Dependence for Common Patterns

[0107]
The second simplification to equation (26) involves a further reduction in the number of positional distributions learned during training. Already, the simplification of the previous section has reduced the number of positional distributions to be learned from n_{q1 }to n_{est}. Now, a further reduction from n_{est }to n_{q2 }will be performed by vector quantizing the n_{est }surviving positional distribution into n_{q2 }representative distributions. For purposes of this quantization, the two dimensional positional distributions of the q1 patterns are rasterized into vectors. The number n_{q2 }is an algorithm sizing parameter.

[0108]
The vector quantization training algorithm is not the standard LBG algorithm, but rather an ad hoc custom algorithm, performed on a single pass through the input vectors. This singlepass nature is important, since the training algorithm will likely be quantizing tens or hundreds of thousands of vectors, and therefore must show concern for speed. The training process is outlined as follows:


For each vector x 
 Find the closest current pattern center 
 Calculate the distance d between x and the closest center. The sum 
 squared error (SSE) metric is used. 
 If d<threshold 
 Add x to cluster; update cluster center 
 else 
 Seed new cluster with x. 
 

[0109]
For this algorithm to function properly, it must of course handle empty clusters gracefully, and also deal with the imposition of a maximum number n_{q2 }of clusters. The cluster centers are computed as the average (ideally, weighted average by occurrence count) of the vectors that map to the cluster. The selection of the distance threshold is problematic and based essentially on empirical observation of the behavior of the quantization training when using different values of the threshold. The goal of this selection is to make full use of the available number of quantization levels while spreading out the distribution vectors as uniformly as possible.

[0110]
Upon application of the vector quantization of positional distributions, the position pos in equation (26) is mapped to one of the VQ pattern centers, identified as pos′. Equation (26) then becomes, for more common patterns,
$\begin{array}{cc}\prod _{i=1}^{\#\text{\hspace{1em}}\mathrm{subregions}}P\left(\mathrm{face}\u2758q\text{\hspace{1em}}1,{\mathrm{pos}}_{i}^{\prime}\right)& \left(28\right)\end{array}$
Apply Detection at Multiple Resolutions, Assuming Independence Between Resolutions

[0111]
Since the statistical dependencies between subregions cannot be captured in the simplified probability model that has been developed, features.

[0112]
Since the statistical dependencies between subregions cannot be captured in the simplified probability model that has been developed, features larger than subregions cannot be considered. To overcome this limitation, multiple levels of image resolution are now introduced. The entire mechanism of the probability estimator in equation (21) will be applied to multiple levels of image resolution, leading to
$\begin{array}{cc}\prod _{j=1}^{\mathrm{nmags}}\prod _{i=1}^{\mathrm{nsubs}}P\text{(}\mathrm{face}\text{\u2758}q\text{\hspace{1em}}{1}_{i}^{j}\text{)}& \left(29\right)\end{array}$
At each resolution, the eyes must reside at standard positions.
Full Form of Simplified Probability Distribution

[0113]
Gathering together equations (28) and (29), and applying Bayes' theorem to relate prior probabilities gathered during training to the posterior probabilities in these expressions leads to the full form of the estimated likelihood of face presence in an image region. Details of the complete derivation of this equation appear in Schneiderman, H., and Kanade, T., “Probabilistic Modeling of Local Appearance and Spatial Relationships for Object Recognition”, Proc. CVPR 1998, 4551.
$\begin{array}{cc}P\left(\mathrm{face}\u2758\mathrm{region}\right)=\prod _{j=1}^{\mathrm{nmags}}\prod _{i=1}^{\mathrm{nsubs}}P\text{(}q\text{\hspace{1em}}{1}_{i}^{j}\text{\u2758}\mathrm{face}\text{)}\frac{P\text{(}{\mathrm{pos}}^{\prime}\u2758q\text{\hspace{1em}}{1}_{i}^{j},\mathrm{face}\text{)}P\left(\mathrm{face}\right)}{\frac{P\text{(}q\text{\hspace{1em}}{1}_{i}^{j}\u2758\mathrm{face}\text{)}}{\mathrm{npos}}P\left(\mathrm{face}\right)+\frac{P\text{(}q\text{\hspace{1em}}{1}_{i}^{j}\u2758\stackrel{\_}{\mathrm{face}}\text{)}}{\mathrm{npos}}P\left(\stackrel{\_}{\mathrm{face}}\right)}& \left(30\right)\end{array}$
In this expression, P(face) and P({overscore (face)}) represent the prior probabilities that an image region either does or does not contain a face. In the absence of this knowledge, uniform priors equal to ½are used, leading to a further simplification in equation (30).
Training and Applying the Detector

[0114]
Representative face images were collected from varied sources. Each face exemplar was multiplied many times by applying small perturbations to the image to produce many more examples. The perturbations include translation, rotation, scaling, and flipping horizontally. Noise processes were not included in the perturbations because the face images came from a variety of sources with varying levels of image quality. Three different resolution versions of each face example are gathered. Expansion of the training set is necessary to reduce the sensitivity of the detector to small variations in imaging parameters (pose, translation, etc.) at testing time.

[0115]
Bootstrap training was used for nonface training. In the bootstrap training methodology, the detector is first trained with a random collection of examples in the difficult class (which is nonfaces, in this case). A poorly performing classifier will result. This classifier is applied to a number of test images and likely produces large numbers of false positives. These nonface examples are then fed back into the training set, and the algorithm is trained again. The whole process is then repeated for a number of training rounds.

[0000]
Training Steps

[0116]
The training divides naturally into two major phases. The goal of the first phase is to obtain specific parameters of the quantization of face subregions. The initial step is to capture the covariance matrix and then principal components of the subregions from the training set. As part of this step, following extraction of the principal components, another pass is made through all the training subregions to gather the statistics of their projections unto those twelve principal dimensions. The projection data are analyzed statistically. The second order statistics are fed back into the training program to enable optimal design of the LloydMax quantizier. Since the variation of face patterns is quite large when considered across different scales of resolution, this process of extracting principal components and the statistical distribution of the training data along those components must be repeated for each image resolution.

[0117]
The second phase of training starts by passing through the training set and performing the quantization of each subregion of each face example. As mentioned above, the training set can be expanded by creating slightly perturbed versions of each training exemplar. The frequency with which quantized values appear is counted in a histogram having roughly 1,000,000 bins. Simultaneously, subregion positions at which each quantized value occurs are accumulated. A sort operation arranges the quantization frequency histogram in decreasing order of occurrence count. For the next most frequency quantized patterns, the positional distributions enter into the vector quantization algorithm. Following vector quantization, only n_{q2 }seminal positional distributions are retained, and each of the nest frequent quantization values will have a positional distribution approximated by the retained distributions.

[0000]
Applying the Object Detector

[0118]
To use the trained face detection algorithm, the computation of equation (30) must be applied to an image region on which spatial and intensity normalization have been conducted. Three different resolution versions of each candidate face region are required. The quantization value for each subregion is computed, and the various probability terms in equation (30) are extracted from the probability tables created during algorithm training.

[0119]
To use equation (30) for face detection, a probability threshold must be selected. When the posterior probability exceeds the threshold, then face detection has occurred. After the algorithm training process has been completed, the threshold is determined using a verification set of about 600 face and nonface images.

[0120]
To obtain reasonable test phase performance, some careful attention must be paid to data structures and data representation. In general, the probability histogram is quite sparse and can therefore be considerably compressed if speed of access is not degraded. Considering equation (30), it can be seen that two basic data structure accesses must be facilitated. First, given a q1 value, it must be determined whether the value is common or rare. If common, there must be a fast way to look up the probability of joint occurrence of that quantization value in a specified subregion position.

[0000]
Image Search

[0121]
The prior discussion has generally shown how a single image window can be tested for the presence of the desired object in a manner insensitive to inplane rotation of the object. The invention is not so limited. An object can be found regardless of its size and position in the image. Those skilled in the art of image understanding and pattern recognition will recognize that there are many standard schemes of image searching to accomplish these goals. Two prominent schema of image searching are attentive and nonattentive (i.e., “brute force”).

[0122]
Attentive schemes use salient image characteristics to focus detailed processing to regions of the image likely to contain interesting information. For example, in the case of faces, image color can be used to focus attention in regions that might contain faces. Solid blue or green regions can be excluded from consideration, since human skin cannot ordinarily take on such color values in a color image. Other attentive mechanisms in the literature include those based on biological vision, using simplified models of retinal processing such as centersurround receptive field neural models. The attraction of attentive methods lies in the speed improvements that occur when large portions of an image can be rejected quickly during image searching.

[0123]
Nonattentive schemes for image search typically examine all possible image windows, at all positions and all scales, to perform an exhaustive search for the target object. Such schemes might be chosen for a number of reasons over the attentive alternatives. Most particularly, if the classification decision itself is very fast (as in the case of this invention), the brute force search can actually be faster than the attentive search.

[0124]
It will be understood that different methods of image search—both attentive and nonattentive—can be used as part of this invention. A nonattentive search is currently preferred for two reasons. First, this approach avoids the use of color information and can thus be used with monochrome images. Second, due to the choice of image feature measurements and probability models in preferred implementations, the classification decisions are made so rapidly that they are computationally competitive with attentive methods in this case. Chosen window sizes range from 28×28 pixel windows to 224×224 pixel windows in a geometric series of sizes, with the ratio constant equal to {cube root}{square root over (2)}.

[0125]
A set of n=4936 facial images was used for training and testing of the algorithms described herein. Each image had resolution 56×56 pixels, with the eyes manually aligned in fixed locations. The images came from a variety of different sources. Some were cut from consumer photographs; some came from credit card pictures; others came from formally posed portraits. In general, algorithms were trained and tested using a fivefold cross validation strategy: fourfifths of the image set was used to train, while the other onefifth was used to test; and the process was repeated five times, so that every individual image served as a test object at least once, and no training image doubled as a test image.

[0126]
The Gaussian modelbased rotation estimator was trained and tested with the fivefold cross validation strategy, with results shown in the following table.
TABLE 2 


Results of fivefold cross validation of Gaussian model. 
Train      
ing      % within 
set  N_{test}  Angle = 0°  Angle = 10°  Angle = −10°  ±10° 

1  988  897  37  29  97.5 
2  987  794  62  87  95.5 
3  989  820  52  63  94.5 
4  988  838  43  61  95.3 
5  987  819  59  67  95.7 
Totals  4939  4168  253  307  95.7 ± 1.1 


[0127]
In the next test, one of the five folds was used to test the rotation estimation algorithm, this time using rotated test images. That is, the test images were all rotated to the 36 angular positions, spaced every 10°, and their rotational orientation was estimated. A further test was run to examine the performance of the Gaussian model when the true image orientation falls between the 10 degree spaced test orientations. In FIG. 10, are plotted the percentages of test images categorized as having the neighboring discrete rotational positions, by 1 degree increments of position.

[0128]
A Gaussian mixture model was trained with three components according to the following strategy. Three groups of faces, each containing 1218 faces, were used to initialize the Gaussian mixture components. The three groups were separated based on head pose, representing leftfacing, frontal, and rightfacing heads, respectively. Following training, the posteriori component probabilities P(j) in (3) were 0.24, 0.50, and 0.26 respectively. The following table shows the results of the fivefold cross validation experiment, specifically counting rotation estimates within ±10° of upright (all training and test images were nominally considered upright with respect to inplane rotation).
TABLE 3 


Results of fivefold cross validation of Gaussian mixture model. 
Train      
ing      % within 
set  N_{test}  Angle = 0°  Angle = 10°  Angle = −10°  ±10° 

1  988  815  62  68  95.6 
2  987  822  43  74  95.1 
3  987  804  57  75  94.8 
4  987  805  68  69  95.4 
5  987  788  64  87  95.1 
Totals  4936  4034  294  373  95.2 ± 0.3 


[0129]
In the next test, one of the five folds was used to test the rotation estimation algorithm, this time using rotated test images. That is, the test images were all rotated to the 36 angular positions, spaced every 10°, and their rotational orientation was estimated. The results are consistent across all 36 angular positions, ranging from 95.6% to 96.6% correct within ±10°, with standard deviation of 0.2%.

[0130]
A further test was run to examine the performance of the mixture model when the true image orientation falls between the 10 degree spaced test orientations. In FIG. 11 are plotted the percentages of test images categorized as having the neighboring discrete rotational positions, by 1 degree increments of position.

[0131]
To generate the data in FIGS. 1011, the test faces (n=988) where rotated in one degree increments and tested against fixed positions at 10 degree increments. Responses were smoothly varying despite the fact that the actual faces fell between the discrete test positions.

[0132]
The invention has been described in detail with particular reference to certain preferred embodiments thereof, but it will be understood that variations and modifications can be effected within the spirit and scope of the invention.