A digital imaging system may include a digital camera that is constructed to electrically capture, or acquire, data that represents a pixel image of a given object. The camera may contain an image signal processor (ISP), which may perform various image processing functions on the acquired image data, such as functions pertaining to autowhite balancing, Bayer transformations, noise attenuation, image sharpening, and so forth.
Referring to
Although electrically connected (via a wired connection 121, a wireless connection, or a combination of wired and wireless connections), the vertical display unit 110 and the horizontal display unit 150 horizontal display unit 150 may or may not be physically connected together (via a hinged connection, for example), depending on the particular implementation. In accordance with some implementations, the vertical display unit 110 may be supported on a vertically extending stand (not shown) that rests on a table, which also supports the horizontal display unit 150. Thus, many implementations are contemplated, which are within the scope of the appended claims.
In accordance with example implementations, the vertical display unit 110 and/or the horizontal display unit 150 may include components of a processor-based system, such as illustrated example processor-based system 114 that is disposed in the vertical display unit 110. Moreover, the processor-based system 110 may be electrically coupled to a built-in camera 112 of the vertical display unit 110. The camera 112 is positioned to capture, or acquire, images of objects that are placed on a surface 152, which, for this example, is formed on a region on the display screen 151 of the horizontal display unit 150. It is noted that the surface 152, in general, refers to a surface that has defined boundaries such that an object to be imaged is placed within the boundaries. The surface 152 may or not be a surface on a horizontal display unit or even a surface of an electronic device, in accordance with further example implementations. For example, in accordance with further example implementations, the surface 152 may be the surface of a mat or the surface of a table top within a certain predefined rectangular or square region of the table top.
As examples, for imaging purposes, a user may place a relatively flat, or planar, object 154 (as depicted in an example in
For purposes of capturing the image of the object 154, the user may position the object 154 on the surface 152 and interact with machine executable instructions, or “software,” of the system 114 via a GUI (for example) to set up the camera 112 and initiate actions by the camera 112 to acquire image data representing one or multiple pixel images of the object 154. The camera 112 generally illuminates the surface 152 (and object 154) during the image capture by triggering an electronic flash unit 111 of the processor-based system 114 to generate a corresponding flash light. As an example, in accordance with example implementations, the flash unit 111 may be part of a projector (not shown) of the system 114; and the camera 112 may trigger the flash light by communicating a general purposes input/output (GPIO) signal to the projector. The flash unit 111 may be part of another component other than a projector; may be a standalone unit; may be triggered using other signals; and so forth, depending on the particular implementation.
In this manner, while the object 154 is illuminated by the flash light, the camera 112 activates its electronic shutter to acquire pixel image data in its imager(s). The camera 112 contains an image signal processor (ISP) to perform image signal processing on the data; and subsequently, the camera 112 may communicate the processed image data to the processor-based system 114, where the data may be processed to further manipulate the captured image(s).
Techniques and systems are disclosed herein for purposes of processing the image data (via post ISP processing by the processor-based system 114, for example) to compensate the image data for non-uniform illumination by the flash light and for purposes of enhancing the image data by applying processing operations that are based on a classified type of the object 154 (e.g., processing operations are selected and performed based on whether the object 154 is classified as being a 3-D object, a photograph or a document).
More specifically, in accordance with example implementations, a processor-based imaging engine 115 of the system 114 receives pixel image data that is provided by the camera 112 and performs such functions as correcting for non-uniform illumination of the surface 152 by the flash flight; identifying, or classifying the type of the object 154; and selectively performing image processing operations based on classified object type.
As a more specific example,
In addition to the imagers 188, the camera 112 may include one or multiple processing cores 184, the flash light unit 111 and a memory 182. The memory 182 may represents the overall system memory of the camera 112 and may, for example, store data indicative of the captured image(s) as well as instructions that are executed by an image signal processor (ISP) 190 of the camera 112. In general, the ISP 190 may perform various functions to enhance the captured image, such as, for example, autowhite balancing, Bayer signal processing, gamma correction, lens distortion compensation, contrast or image sharpening, color matrix processing, lens shading, gamma correction and so forth. The camera 112 may further include, as an example, an input/output (I/O) interface 180 (a Universal Serial Bus (USB) interface, for example) 160 that communicates data (over a USB bus, for example) between the camera 112 and a corresponding I/O interface 162 of the processor-based system 114. Moreover, the I/O interface 180 of the camera 112 may communicate with the flash unit 111, as described above.
In addition to the interface 162, the processor-based system 114 includes other hardware, such as one or multiple central processing units (CPUs) 164 and a memory 166. As illustrated in
Referring to
More specifically, in accordance with example implementations, the image engine 115 performs a technique 200 that is depicted in
In general, the intensity of light attributable to a given light source is proportional to the inverse of the distance squared from the light source. Referring to
For purposes of compensating for this non-uniform illumination, the imaging engine 115 applies the pixel intensities of the captured image; and for this purpose, the engine 115 may use a model that describes how the flash light illuminates the surface 152.
More specifically, referring to
In this manner, pursuant to the technique 400, coefficients are determined (block 408) for a polynomial model that describes the illumination uniformity of the captured base image. For example, in accordance with some implementations, least squares-based fitting may be used to determine the coefficients of the polynomial function that describes the Illumination. With this model, an inverse of the model may then be determined for purposes of guiding the non-uniform illumination compensation. In this regard, the technique 400 includes determining (block 412) a model for the compensation (an inverse of the determined polynomial model, for example) to be applied to future image data to correct for the non-uniform illumination.
In accordance with example implementations, the imaging engine 115 applies post processing applications to the captured image data based on an identified, or classified, object type. The object identification and applied operators occur, in accordance with example implementations, after the illumination uniformity compensation. In this regard, certain image processing operations depend on the type of object that is captured. For example, for a document, operations may be applied to sharpen, or increase the contrast, of the image so that the black text of the image is darkened and the lighter portions of the image are converted into a “page white” color. Moreover, document processing may involve snapping the corners of the document to fit a rectangular page profile. For an image of a 3-D object, shadow compensation may be applied to brighten dark regions of the image. Moreover, for the 3-D object specular compensation may be applied to soften “hot spots” of the image, such as, for example, regions of the image, which are saturated with the red color. For photographs, the degree of white enhancement, as well as an amount of saturation boost to be added, may be determined.
Thus, referring to
As a more specific example, in accordance with example implementations, the imaging engine 115 may perform a technique 300 that is depicted in
Referring to
In this regard, in accordance with example implementations, the captured image may be associated with a certain level of noise such that an image of an entirely planar object may appear to have some height variations, and as such, may incorrectly be perceived as being non-planar. The imaging engine 115 compensates for the noise, as the engine 115 compares the measured height of the object to a threshold that accounts for the presence of noise; and based on this comparison, the imaging engine 115 determines whether to classify the object as being planar (the measured height is below the threshold, for example) or classify (block 512) the object as being a 3-D object (the measured height is at or above the threshold, for example).
If the imaging engine 115 determines that the object is planar, then the imaging engine 115 applies further processing operations, in accordance with example implementations, for purposes of determining whether the object is a photograph, document or another object type. More specifically, pursuant to the technique 500, the imaging engine 115 determines (block 516) whether edges are identified in the infrared (IR) and red green blue (RGB) images that are acquired by the camera 112.
The imaging engine 115 then combines (block 520) the identified edges in the IR and RGB images, such as through a union operation, to derive a composite image that reveals all of the identified edges. If the imaging engine 115 determines (decision block 524) that a rectangular perimeter is present in this composite image, then the imaging engine 115 applies further tests to discriminate between a photograph and a document. Otherwise, the imaging engine 115 classifies (block 544) the object as belonging to a class associated with a planar object that is neither a photograph nor a document.
For purposes of distinguishing between a document and a photograph, in accordance with example implementations, the imaging engine 115 analyzes (block 528) such factors as pixel intensities, intensity gradients and the color of the image; and based on this analysis, the imaging engine 115 determines (decision block 532) whether a photograph has been identified. If so, the imaging engine 115 classifies the object as belonging to the photograph class, pursuant to block 536. Otherwise, the imaging engine 115 classifies (block 540) the object as belonging to the document class.
In accordance with example implementations, a user may guide the specific post processing operations that are applied by the imaging engine 115. In this regard, pursuant to a technique 600 that is depicted in
Using the GUI 117, the imaging engine 115 receives (block 608) user input; and this input may be used to allow all of the recommended post processing operations to be applied; to restrict the set of the recommended post processing operations to be applied; to cancel one or multiple post processing operations; to select additional post processing operations that are not recommended; to modify parameters of selected post processing operations; and so forth. Based on this input, the technique 600 includes processing the image based on the user input and the identified object type, pursuant to block 612.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art, having the benefit of this disclosure, will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2014/049308 | 7/31/2014 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2016/018419 | 2/4/2016 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5758049 | Johnson et al. | May 1998 | A |
5831748 | Tsukada et al. | Nov 1998 | A |
5969795 | Honda | Oct 1999 | A |
6771838 | Fan | Aug 2004 | B1 |
7053939 | Lin et al. | May 2006 | B2 |
7382928 | Wong et al. | Jun 2008 | B2 |
7599561 | Wilson et al. | Oct 2009 | B2 |
7710391 | Bell et al. | May 2010 | B2 |
8121640 | Russ et al. | Feb 2012 | B2 |
8199117 | Izadi et al. | Jun 2012 | B2 |
8554011 | Yuan et al. | Oct 2013 | B2 |
8736583 | Anderson et al. | May 2014 | B2 |
20020113946 | Kitaguchi | Aug 2002 | A1 |
20020145769 | Pollard | Oct 2002 | A1 |
20050078092 | Clapper | Apr 2005 | A1 |
20060043264 | Sakurai | Mar 2006 | A1 |
20060098894 | Dicarlo et al. | May 2006 | A1 |
20070159655 | Cui | Jul 2007 | A1 |
20070262235 | Pertsel | Nov 2007 | A1 |
20080018591 | Pittel et al. | Jan 2008 | A1 |
20110242054 | Tsu | Oct 2011 | A1 |
20130022242 | Cobb et al. | Jan 2013 | A1 |
20130077236 | Becze et al. | Mar 2013 | A1 |
20140176735 | Short | Jun 2014 | A1 |
20140192160 | Chang | Jul 2014 | A1 |
20150325023 | Gross | Nov 2015 | A1 |
Number | Date | Country |
---|---|---|
105122303 | Dec 2015 | CN |
2525559 | Nov 2012 | EP |
2372392 | Aug 2002 | GB |
2006270580 | Oct 2006 | JP |
2009272799 | Nov 2009 | JP |
WO-2013101800 | Jul 2013 | WO |
Entry |
---|
Machine Vision Introduction, Sick IVP, Industrial Sensors, Dec. 2006, pp. 1-56 First 12 pages of 56. |
Shahram Izadi et al., “C-Slate: A Multi-Touch and Object Recognition System for Remote Collaboration using Horizontal Surfaces,” 2007, pp. 3-10, IEEE. |
XP 55656517A—Reducing Low Frequency Interference. |
Number | Date | Country | |
---|---|---|---|
20170223235 A1 | Aug 2017 | US |