This application relates to co-pending U.S. patent application Ser. No. 11/260,636, filed Oct. 27, 2005, by Jonathan Yen et al. and entitled “Detecting and Correcting Peteye,” which is incorporated herein by reference
Systems for automatically classifying images may be used in a wide variety of applications, including computer vision systems and media asset organization and retrieval systems. Many automatic classification systems classify images based at least in part on a content-based analysis of the images. In these systems, an image or a region of an image typically is represented by a set of low-level features (e.g., texture, color, and shape) that are extracted from the image. The images or image regions are classified by applying the corresponding features into a classifier, such as a Support Vector Machine, which has been trained on pre-labeled images or image regions in a target class (e.g., a human face class or a scene type class). Based on the input features, the classifier determines whether or not new image instances should be classified into the target type class.
In some content-based image retrieval approaches, low level visual features are used to group images into meaningful categories that, in turn, are used to generate indices for a database containing the images. In accordance with these approaches, images are represented by low level features, such as color, texture, shape, and layout. The features of a query image may be used to retrieve images in the databases that have similar features. In general, the results of automatic categorization and indexing of images improve when the features that are used to categorize and index the image more accurately capture the target aspects of the content of the images.
As individuals and organizations continue to rapidly accumulate large collections of image content, they increasingly will require systems and methods for organizing and browsing the image content in their collections. Although efforts have been made to detect and classify aspects (e.g., faces and eyes) of human subjects, little effort has been made to detect and classify aspects of nonhuman animals, such as dogs, cats, birds, and reptiles, which constitute a significant fraction of the image content that is captured and maintained in image databases. Accordingly, what are needed are systems and methods that are designed specifically to automatically classify pixels of nonhuman animals in images.
The invention features methods, systems, and machine-readable media for processing an input image.
In one aspect of the invention, values of features in a discriminant space are determined for respective pixels of the input image. The pixels are classified into a nonhuman animal integument class based on the respective feature values and a mapping that segments the discriminant space into one or more regions of feature values representing pixels that are associated with a nonhuman animal integument characteristic and one or more regions of feature values representing pixels that are not associated with the nonhuman animal integument characteristic.
Other features and advantages of the invention will become apparent from the following description, including the drawings and the claims.
In the following description, like reference numbers are used to identify like elements. Furthermore, the drawings are intended to illustrate major features of exemplary embodiments in a diagrammatic manner. The drawings are not intended to depict every feature of actual embodiments nor relative dimensions of the depicted elements, and are not drawn to scale.
The embodiments that are described in detail below provide systems and methods that are capable of classifying pixels of nonhuman animals in an image based on the values of features that are determined for the pixels of the image. The features are designed to capture one or more characteristics of image content depicting nonhuman animal integument (i.e., the outer protective covering, such as fur, hair, or skin, of a nonhuman animal). The embodiments specifically are designed to segment feature values representing pixels that are associated with a nonhuman animal integument characteristic (e.g., the color or texture of fur, hair, or skin of a nonhuman animal) from feature values representing pixels that are not associated with the nonhuman animal integument characteristic. Consequently, these embodiments are expected to more accurately detect image content corresponding to nonhuman animal integument and thereby provide improved automatic categorization and indexing of images of nonhuman animals.
In the illustrated embodiment, the nonhuman animal integument detection module 14 includes a feature value calculation module 16 and a classification module 18. As explained in detail below, the feature value calculation module 16 calculates values of features for respective pixels of the input image 14. The features are designed to capture one or more characteristics of image content depicting nonhuman animal integument. The features define (or span) a discriminant space. The classification module 16 incorporates a mapping that segments the discriminant space into one or more regions (or clusters) of feature values representing pixels that are associated with a nonhuman animal integument characteristic and one or more regions of feature values representing pixels that are not associated with the nonhuman animal integument characteristic. The classification module 16 determines whether to accept pixels of the input image 14 into the specified nonhuman animal integument class or to reject pixels of the image 14 from the specified nonhuman animal integument class based on the mapping and the respective feature values that were calculated for the pixels.
The image processing system 10 may be used in a wide variety of applications, including computer vision systems and media asset organization and retrieval systems. In general, the image processing system 10 (including the feature value calculation module 16 and the classification module 18) is not limited to any particular hardware or software configuration, but rather it may be implemented in any computing or processing environment, including in digital electronic circuitry or in computer hardware, firmware, device driver, or software. For example, in some implementations, the image processing system 10 may be embedded in the hardware of any one of a wide variety of electronic devices, including desktop and workstation computers, digital still image cameras, digital video cameras, printers, scanners, and portable electronic devices (e.g., mobile phones, laptop and notebook computers, and personal digital assistants).
In some implementations, computer process instructions for implementing the image processing system 10 and the data it generates are stored in one or more machine-readable media. Storage devices suitable for tangibly embodying these instructions and data include all forms of non-volatile memory, including, for example, semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices, magnetic disks such as internal hard disks and removable hard disks, magneto-optical disks, and CD-ROM.
In accordance with this method, the feature value calculation module 16 determines values of features in a discriminant space for respective pixels of the input image (
The classification module 18 classifies the pixels of the input image 12 into a nonhuman animal integument class based on the respective feature values that were calculated by the feature value calculation module 16 and a mapping that segments the discriminant space (
Certain color discriminant spaces capture the color characteristics of images of nonhuman animal integument in ways that allow nonhuman animal integument pixels in an image to be segmented from other pixels in the image with relatively high accuracy.
It has been determined from an analysis of a sample of images of animals that animal-fur colors typically can be classified into a small class of possible animal fur colors. In this analysis, each image in the sample was cropped to remove non-fur-coated areas and the resulting cropped images were mapped to a quantized color space defined by a set of twenty-seven color names (or bins).
In some implementations of the pixel classification method of
The classification module 18 may apply one or more predicates that binarize the quantized color map to produce a classification map that labels pixels in the input image 12 as members of the target nonhuman animal integument class or as non-members of the target nonhuman animal integument class. In this process, pixels having color values corresponding to one of multiple specified gray levels, a specified brown color range, and a specified flesh color range are segmented into the target nonhuman animal integument class, whereas pixels having color values that do not correspond to one of the seven possible animal-fur color bins are segmented outside of the target nonhuman animal integument class.
In some embodiments, the classification module 18 produces the classification map directly from the input image in accordance with the process described in the following numbered paragraphs. In this process, the classification module 18 assigns to the animal-fur color class ones of the pixels of the input image 12 having: (i) a chroma value below a chroma threshold, as defined in equation (6); (ii) a chroma value below a chroma threshold, a luminance value below a luminance threshold, and a hue value outside a hue value range defined by a lower hue threshold and an upper hue threshold, as defined in equation (7); or (iii) a chroma value below a chroma threshold, a luminance value above a luminance threshold, and a hue value within a hue value range defined by a lower hue threshold and an upper hue threshold, as defined in equation (8).
1. Convert the input image 12 into the YCrCb color space. For example, in some embodiments, if the input image 12 originally is specified in the RGB color space, the input image pixels are mapped into the YCrCb color space as follows:
Y=0.299·r+0.587·g+0.112·b (1)
Cr=0.713266·(r−Y)+128 (2)
Cb=0.564334·(b−Y)+128 (3)
where r, g, and b are red, green, and blue component pixel values of input image 12, respectively, and Y, Cr, and Cb are the component pixel values in the YCrCb color space.
2. Calculate the chroma and hue for each of the input image pixels as follows:
3. Segment pixels of the input image 12 into the non-peteye class if one of the following conditions is true:
a. the pixel is in a gray color range defined by:
Chroma<25; or (6)
b. the pixel is in a brown color range defined by:
(Chroma<120) AND (Y<120) AND (Hue≧254 OR Hue≦45); or (7)
c. the pixel is in a flesh color range defined by:
(Chroma<115) AND (Y≧120) AND (10≦Hue≦45). (8)
Certain texture discriminant spaces capture the texture characteristics of images of nonhuman animal integument in ways that allow nonhuman animal integument pixels in an image to be segmented from other pixels in the image with relatively high accuracy. In particular, it has been determined that texture discriminant spaces defined by one or more texture metric features that are derived from coefficients of directional multiresolution transformations can be used to segment nonhuman animal integument pixels from other pixels in an image.
In some embodiments, before the directional subbands and the texture metric values are computed, the input image 12 initially is normalized in accordance with the following process:
1. Convert the input image 12 into a grayscale color space. For example, in some embodiments, if the input image 12 originally is specified in the RGB color space, the input image pixels are mapped in accordance with a grayscale mapping G, which is given by:
G=0.299×r+0.587×g+0.114×b (9)
where r, g, and b are red, green, and blue component pixel values of input image 12.
2. Optionally, down-sample the resulting grayscale image to a specified size. For example, in some embodiments, the grayscale image is down-sampled to approximate a standard image size (e.g., four inches high by six inches wide) and a standard viewing distance (e.g., eighteen inches).
After the input image 12 has been normalized, the feature value calculation module 16 calculates one or more resolution levels of a directional multiresolution transform. In general, the feature value calculation module 16 may generate the directional subbands in accordance with any spectral transformation that provides multiresolution (or multiscale) and directional image representations, including the contourlet transform, two-dimensional Gabor wavelets, the context transform, the steerable pyramid, two-dimensional directional wavelets, brushlets, and complex wavelets.
In the exemplary embodiments that are described in detail below, the feature value calculation module 16 generates the directional subbands in accordance with the contourlet transform, which includes a double filter bank structure that uses the Laplacian pyramid to capture point discontinuities followed by a directional filter bank that links point discontinuities into linear structures. The contourlet transform generates a directional multiresolution expansion of the input image 12. Additional details regarding the structure and operation of the contourlet transform may be obtained from, for example, M. Do and M. Vetterli, “The Contourlet Transform: An Efficient Directional Multiresolution Image Representation,” IEEE Transactions on Image Processing, Vol. 14, No. 12 (December 2005).
At each resolution level of the expansion, each pixel of the image 36 is represented by a respective coefficient value of each of the subbands of the level. Thus, for a given resolution level l, each pixel k of the image 36 is represented by a respective set of the subband coefficient values that includes a respective coefficient value dkli from each of the subbands i. That is, in given resolution level l each pixel k may be represented by a vector {right arrow over (d)}kl, which is defined by
{right arrow over (d)}kl≡{dkl1,dkl2, . . . ,dklN} (10)
where Nl is the number of subbands in resolution level l. Therefore, each pixel of the image 36 is represented by four coefficient values in the first and second resolution levels, eight coefficient values in the third resolution level, and sixteen coefficient values in the fourth resolution level.
In some embodiments, the input image 12 computed contourlet transform coefficients are normalized in accordance with the following process:
1. Take the absolute value of the floating-point transform coefficients.
2. For each resolution level, determine the maximum absolute coefficient value across all the subbands.
3. For each resolution level, normalize the coefficient values across all the subbands by the smallest power of 2 larger than the determined maximum absolute coefficient value.
4. For each resolution level, optionally map the normalized coefficient values across all the subbands from [0.0, 1.0] to [0, 255].
5. For each resolution level, optionally scale each of the subbands to the original size of the input image.
After the transform coefficients have been normalized, the feature value calculation module 16 calculates for each pixel k of the input image 36 a respective texture metric value from each of the representative sets of coefficient values {dkli} at each given resolution level l. In some embodiments, the texture metric values correspond to vector norm values computed from the sets of coefficient values. In these embodiments, the feature value calculation module 16 calculates from each of the representative sets of coefficient values of a respective vector norm |{right arrow over (d)}kl|P, which is given by the general expression:
where P corresponds to a positive integer that specifies the type of vector norm. The vector norm for P=1 typically is referred to as the P1-norm, the vector norm for P=2 typically is referred to as the P2-norm, and P=∞ typically is referred to the infinity norm, which is equal to the maximum coefficient value. In some of these embodiments, the computed vector norm values are used as the texture metric values.
In some other embodiments, the texture metric values are derived from the computed vector norm values. For example, in some of these embodiments, the average vector norm values |
where Nl is the number of subbands in resolution level l.
In some embodiments, the classification module 18 classifies pixels of the input image 36 into the nonhuman animal integument class based on a respective thresholding of the corresponding texture metric values at each of one or more of the resolution levels of the expansion of the input image 36. If a pixel satisfies the prescribed thresholding bounds, the pixel is classified as a nonhuman animal integument pixel; otherwise, the pixel is rejected from the nonhuman animal integument class.
In some of these embodiments, the classification module 18 compares the calculated texture metric values to a target range of texture metric values that is defined by an upper texture metric threshold and a lower texture metric threshold. The classification module 18 assigns ones of the pixels of the input image 36 having respective texture metric values within the target range to the nonhuman animal integument class. Thus, with respect to the embodiments in which the computed vector norm values are used as the texture metric values:
dMIN,l≦|{right arrow over (d)}kl|P≦dMAX,l assign pixel k to nonhuman animal integument class (13)
|{right arrow over (d)}kl|P<dMIN,l or reject pixel k from nonhuman animal integument class
|{right arrow over (d)}kl|P>dMAX,l (14)
where dMIN,l is the lower texture metric threshold at resolution level l, and dMAX,l is the upper texture metric threshold at resolution level l. With respect to the embodiments in which the computed vector norm values are used as the texture metric values:
DMIN,l≦|
|
|
where DMIN,l is the lower texture metric threshold at resolution level l, and DMAX,l is the upper texture metric threshold at resolution level l.
In general, the classification module 18 may classify pixels of the input image 36 using one or more of the texture metric values that are calculated for each pixel at each of one or more of the respective resolution levels. In some cases, the classification results are improved, however, by limiting the classification to the one resolution level that provides the highest segmentation accuracy with respect to a sample of pre-labeled images exhibiting the target nonhuman animal integument characteristics (e.g., hair, fur, features, or reptilian skin).
The resulting classification of the input image pixels may be represented by a binary classification map in which pixels that are accepted into the nonhuman animal integument class are colored one color (e.g., white) and pixels that are rejected from the nonhuman animal integument class are colored a different color (e.g., black). In some embodiments, the classification module 18 may apply one or more morphological operations to the binary classification map to smooth the boundaries between the different pixel regions. For example, in some exemplary implementations, the morphological operations of dilation followed by erosion may be applied to the pixels that are rejected from the nonhuman animal integument class in order to smooth the boundaries of these pixel regions.
The embodiments that are described in detail herein provide systems and methods that are capable of classifying pixels of nonhuman animals in an image based on the values of features that are determined for the pixels of the image. The features are designed to capture one or more characteristics of image content depicting nonhuman animal integument (i.e., the outer protective covering, such as fur, hair, or skin, of a nonhuman animal). The embodiments specifically are designed to segment feature values representing pixels that are associated with a nonhuman animal integument characteristic from feature values representing pixels that are not associated with the nonhuman animal integument characteristic. Consequently, these embodiments are expected to more accurately detect image content corresponding to nonhuman animal integument and thereby provide improved automatic categorization and indexing of images of nonhuman animals.
Other embodiments are within the scope of the claims.
Number | Name | Date | Kind |
---|---|---|---|
5432863 | Benati et al. | Jul 1995 | A |
6009209 | Acker et al. | Dec 1999 | A |
6016354 | Lin et al. | Jan 2000 | A |
6292574 | Schildkraut et al. | Sep 2001 | B1 |
6307964 | Lin et al. | Oct 2001 | B1 |
6529630 | Kinjo | Mar 2003 | B1 |
6728401 | Hardeberg | Apr 2004 | B1 |
6766053 | Fan et al. | Jul 2004 | B2 |
6873743 | Steinberg | Mar 2005 | B2 |
6917703 | Steffens et al. | Jul 2005 | B1 |
7023447 | Luo et al. | Apr 2006 | B2 |
7162095 | Chen et al. | Jan 2007 | B2 |
20010046311 | Okano et al. | Nov 2001 | A1 |
20020136450 | Chen et al. | Sep 2002 | A1 |
20020176623 | Steinberg | Nov 2002 | A1 |
20030007687 | Nesterov et al. | Jan 2003 | A1 |
20030044042 | King et al. | Mar 2003 | A1 |
20030202105 | Gaubatz et al. | Oct 2003 | A1 |
20040184670 | Jarman et al. | Sep 2004 | A1 |
20040213476 | Luo et al. | Oct 2004 | A1 |
20050047655 | Luo et al. | Mar 2005 | A1 |
20050047656 | Luo et al. | Mar 2005 | A1 |
20050175227 | Paschalakis | Aug 2005 | A1 |
Number | Date | Country |
---|---|---|
WO9917254 | Apr 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20070297673 A1 | Dec 2007 | US |