The present application is based on and claims priority from Japanese Patent Application No. 2012-204474, filed on Sep. 18, 2012 and No. 2013-141549, filed on Jul. 5, 2013.
1. Field of the Invention
The present invention relates to an image adjuster which is able to properly adjust the condition of captured images, an image adjusting method executed by such an image adjuster and a program to realize such an image adjusting method.
2. Description of the Related Art
The white balance correction of a camera is a function to adjust white color so that a white object appears white in an image under various kinds of illuminants. Without white balance correction, a natural white color the human eyes see may appear unnatural on a captured image and an image in proper color shades cannot be generated. It is known that a digital camera comprises a function to acquire a good white balance from a captured image.
There is a known omnidirectional imaging system which includes multiple wide-angle lenses such as fisheye lens or super wide-angle lens to capture an image in omnidirections at once. It is configured to project images from the lenses onto a sensor surface and combine the images through image processing to thereby generate an omnidirectional image. For example, by use of two wide-angle lenses with angle of view of over 180 degrees, omnidirectional images can be generated.
However, such a known white balance adjustment cannot apply to panorama or omnidirectional photographing with an imaging system including multiple imaging units since it is difficult to acquire proper white balance while connecting the captured images appropriately due to different optical conditions of the imaging units.
Japanese Patent Application Publication No. 2009-17457 discloses a fly-eye imaging device with white balance correction which calculates the RGB gains of sub imaging units virtually equivalent to the white balance adjustment of a main unit according to a calculated white balance evaluation value of the main unit, relative sensitivity values to RGB pre-stored in the imaging device, and a sensitivity constant.
However, it cannot acquire a proper white balance value if the optical conditions of the imaging units vary, because it calculates the color gains of the sub imaging units from the white balance evaluation value of the main imaging unit.
In particular, with an omnidirectional camera having an omnidirectional imaging area, the scene captured with two cameras is often illuminated with different illuminants, which is likely to cause a difference in the colors of image connecting portions. Setting a proper white balance for the individual imaging units cannot resolve a difference in the brightness of the connecting portions, which may impair the quality of an omnidirectional image.
The present invention aims to provide an image adjuster and image adjusting control method and program which can abate a discontinuity at the connecting points of images in synthesizing the images.
According to one aspect of the present invention, an image adjuster which provides an adjustment condition to an image, comprises an area evaluator to calculate an area evaluation value for each color in each of divided areas of each of images captured by a plurality of imaging units, a brightness adjuster to calculate a brightness adjustment value for overlapping divided areas between photographic areas of the images on the basis of the area evaluation value for each color, and an adjustment value calculator to calculate a balance adjustment value for each of the overlapping divided areas from the area evaluation value for each color on the basis of the brightness adjustment value.
Features, embodiments, and advantages of the present invention will become apparent from the following detailed description with reference to the accompanying drawings:
Hereinafter, an embodiment of an image adjuster will be described in detail with reference to the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings to refer to the same or like parts. By way of example, the present embodiment describes an omnidirectional imaging system 10 which comprises a function to decide an image adjusting condition on the basis of images captured by two fisheye lenses. Alternatively, the omnidirectional imaging system can comprise a camera unit including three or more lenses to determine an image adjusting condition according to the images captured by the three or more lenses. By use of three or more lenses, the angle of view can be set so that the imaging areas of these lenses overlap. Herein, a fisheye lens can include a wide-angle lens or a super wide-angle lens.
Referring to
The camera unit 12 in
The optical elements as lenses, prisms, filters, aperture stops of the lens systems 20A, 20B are positioned relative to the solid-state image sensors 22A, 22B so that the optical axes of the optical elements are orthogonal to the centers of the light receiving areas of the corresponding solid-state image sensors 22 as well as the light receiving areas become the imaging planes of the corresponding fisheye lenses. The solid-state image sensors 22 are area image sensors on which photodiodes are two-dimensionally arranged, to convert light gathered by the lens systems 20 to image signals.
In the present embodiment the lens systems 20A, 20B are the same and disposed opposite to each other so that their optical axes coincide. The solid-state image sensors 22A, 22B convert light distribution to image signals and output them to a not-shown image processor on the controller. The image processor combines images from the solid-state image sensors 22A, 22B to generate a synthetic image with solid angle of 4π in radian or an omnidirectional image. The omnidirectional image is captured in all the directions which can be seen from a shooting point. Instead of the omnidirectional image, a panorama image which is captured in a 360-degree range only on a horizontal plane can be generated.
To form an omnidirectional image with use of the fisheye lenses with total angle of view of more than 180 degrees, an overlapping portion of the captured images by the imaging units is used for connecting images as reference data representing the same image. Generated omnidirectional images are output to, for instance, a display provided in or connected to the camera unit 12, a printer, or an external storage medium such as SD Card®, Compact Flash®.
The processor 100 comprises ISPs (image signal processors) 108A, 108B, a DMAC (direct memory access controller) 110, an arbiter (ARBMEMC) 112 for memory access, a MEMC (memory controller) 114 for memory access, and a distortion correction and image synthesis block 118. The ISPs 108A, 108B perform automatic exposure control to and set white balance and gamma balance of image data signal-processed by the solid-state image sensors 22A, 22B.
The MEMC 114 is connected to an SDRAM 116 which temporarily stores data used in the processing of the ISPs 108A, 108B and distortion correction and image synthesis block 118. The distortion correction and image synthesis block 118 performs distortion correction and vertical inclination correction on the two images from the two imaging units on the basis of information from a triaxial acceleration sensor 120 and synthesizes them.
The processor 100 further comprises a DMAC 122, an image processing block 124, a CPU 130, an image data transferrer 126, an SDRAMC 128, a memory card control block 140, a USB block 146, a peripheral block 150, an audio unit 152, a serial block 158, an LCD (Liquid Crystal Display) driver 162, and a bridge 168.
The CPU 130 controls the operations of the elements of the imaging system 10. The image processing block 124 performs various kinds of image processing on image data. A resize block 132 enlarges or shrinks the size of image data by interpolation. A JPEG block 134 is a codec block to compress and decompress image data in JPEG. A H.264 block 136 is a codec block to compress and decompress video data in H.264. The image data transferrer 126 transfers the images processed by the image processing block 124. The SDRAMC 128 controls the SDRAM 138 connected to the processor 100 and temporarily storing image data during image processing by the processor 100.
The memory card control block 140 controls data read and write to a memory card and a flash ROM 144 inserted to a memory card throttle 142 in which a memory card is detachably inserted. The USB block 146 controls USB communication with an external device such as personal computer connected via a USB connector 148. The peripheral block 150 is connected to a power switch 166.
The audio unit 152 is connected to a microphone 156 for receiving an audio signal from a user and a speaker 154 for outputting the audio signal, to control audio input and output. The serial block 158 controls serial communication with the external device and is connected to a wireless NIC (network interface card) 160. The LCD driver 162 is a drive circuit for the LCD 164 and converts the image data to signals for displaying various kinds of information on an LCD 164.
The flash ROM 144 contains a control program written in readable codes by the CPU 130 and various kinds of parameters. Upon power-on of the power switch 166, the control program is loaded onto a main memory. The CPU 130 controls the operations of the units and elements of the image processor in compliance with the control program on the main memory, and temporarily stores necessary control data in the SDRAM 138 and a not-shown local SRAM.
Then, the ISPs 108A, 108B in
The optical black correction is a processing in which an output signal from an effective pixel area is subjected to clamp correction, using the output signals of optical black areas of the solid-state image sensors as a black reference level. A solid-state image sensor such as CMOS may contain defective pixels from which pixels values are not obtainable because of impurities entering a semiconductor substrate in the manufacturing of the image sensor. The defective pixel correction is a processing in which the value of a defective pixel is corrected according to a combined signal from neighboring pixels of the defective pixel.
The linear correction is for each of RGBs. Brightness unevenness occurs on the sensor surface due to the characteristic of an optical or imaging system, for example, peripheral light extinction of an optical system. The shading correction is to correct a distortion of shading in an effective pixel area by multiplying the output signal of the effective pixel area by a certain correction coefficient so as to generate an image with uniform brightness. Sensitivity of each area can be corrected by applying different coefficients thereto depending on a color.
Preferably, in the linear correction, shading correction, or the other process sensitivity correction for each of RGB can be additionally conducted on the basis of a gray chart captured under a certain illuminant (D65, for example) with a reference camera, for the purpose of adjusting individual differences between the image sensors. The adjustment gains (TRi, TGi, TBi) of an i-th image sensor (iε{1, 2}) are calculated by the following equations:
T
Ri
=P
Ri
/P
R0
T
Gi
=P
Gi
/P
G0
T
Ri
=P
Bi
/P
B0
where PR0, PG0, PB0 are RGB gains when gray color is shot under D65 with a reference camera. The solid-state image sensors 22A, 22B are represented by indexes 1 and 2, respectively, for example.
By applying the adjustment gains to the obtained pixel values and adjusting a difference in the sensitivities of the image sensors, plural images can be dealt with as a single image. In the area division each image is divided into small areas and an integrated value or integrated average value is calculated for each divided area.
Returning to
The amount of light transmitting through the color filters of the image sensors differs depending on the color of the filter. The white balance correction is to correct a difference in sensitivity to the three colors R (red), G (green), and B (blue) and set a gain for appropriately representing white color in an image. Also, the color of a subject changes depending on an illuminant as sunlight, fluorescent light. In white balance correction an appropriate gain is set even with a change of an illuminant. A WB (white balance) calculator 220 calculates a white balance parameter according to the RGB integrated value or integrated average value calculated in the area division process. The gamma correction is to correct a gamma value of an input signal so that the output linearity of an output device is maintained with the characteristic thereof taken into account.
Further, in the CMOS each pixel is attached with any of RGB color filters. The Bayer interpolation is to interpolate insufficient two colors from neighboring pixels. The YUV conversion is to convert RAW data in RGB format to data in YUV format of a brightness signal Y and a color difference signal UV. The edge enhancement is to extract the edges of an image according to a brightness signal, apply a gain to the edges, and remove noise from the image in parallel to the edge extraction. The color correction includes chroma setting, hue setting, partial hue change, and color suppression.
After the various kinds of processing to the captured images under a certain condition, the images are subjected to distortion correction and image synthesis. A generated omnidirectional image is added with a tag properly and stored in a file in the internal memory or an external storage. Vertical inclination correction can be additionally performed on the basis of the information from the triaxial acceleration sensor 120 or a stored image file can be subjected to compression when appropriate. A thumb-nail image can be generated by cropping or cutting out the center area of an image.
In omnidirectional photographing with the omnidirectional imaging system 10, the two imaging units generate two images. In a photographic scene including a high-brightness object as the sun, a flare may occur in one of the images as shown in
In the imaging unit using fisheye lenses with total angle of view of over 180 degrees most of photographic areas do not overlap except for a partial overlapping area. Because of this, it is difficult to acquire a proper white balance for the above scene by adjusting a white balance based only on the overlapping area. Further, even with the proper white balance obtained for the individual imaging units, a discontinuity of color may occur at the connecting positions of a synthetic image.
In view of avoiding insufficient white balance adjustment, in the imaging system 10 the white balance calculator 220 is configured to calculate a brightness adjustment value according to the RGB integrated values of each overlapping divided area and determine a WB adjustment value for each divided area on the basis of the calculated brightness adjustment value. Specifically, the white balance calculator 220 comprises a brightness adjuster 222, an adjustment value calculator 224, and an adjustment value determiner 226, and can be realized by the ISPs 108 and CPU 130.
The entire image captured by each solid-state image sensor is divided into small areas in circular polar coordinate system with radius r and argument θ in
In the area division of the ISPs 108, each image is divided into small areas as shown in
The brightness adjuster 222 receives the integrated data obtained by the ISPs 108A, 108B, and calculates a brightness adjustment value for an overlapping divided area (hereinafter, may be referred to as overlapping area) between the images according to each of RGB integrated values. Herein, the integrated value for each divided area corresponds to the overlapping area and satisfies a certain criteria.
The brightness adjuster 222 calculates a brightness value of each overlapping area on the basis of each RGB integrated value and calculates a gain value for each image sensor as the brightness adjustment value according to a difference in the largest brightness values of all the overlapping areas of the two images. Moreover, it calculates an offset correction value as the brightness adjustment value for each image sensor on the basis of a difference in the smallest brightness values of the overlapping areas of the two images.
The adjustment value calculator 224 adjusts each RGB integrated value for each overlapping area according to the brightness adjustment values as gain value and offset correction value and calculates a candidate of WB adjustment value for each overlapping area, as described later.
The adjustment value determiner 226 applies weighted averaging to the WB adjustment value in the periphery of each overlapping area including a non-overlapping area on the basis of the candidate of WB adjustment value, to determine a smoothed WB adjustment value. It can change the weights of the weighted averaging in accordance with a difference in the WB adjustment values between the overlapping area and a non-overlapping area. Since the overlapping area is a relatively small area, there is a limitation to the accuracy of the WB adjustment value. It is made possible to avoid extremely different adjustment values from being set for the overlapping divided areas by applying a smaller weight to the divided areas having a large difference.
Now, the white balance adjustment executed by the imaging system 10 is described referring to
Referring to
Referring to
m
1(x,y)=wbR0*avR1(x,y)+wbG0*avG1(x,y)+wbB0*avB1(x,y), where (x,y)εoverlapping area &thL<avR1(x,y),avG1(x,y),avB1(x,y)<thU (1)
m
2(x,y)=wbR0*aR2(x,y)+wbG0*avG1(x,y)+wbB0*avB2(x,y), where (x,y)εoverlapping area &thL<avR2(x,y),avG2(x,y),avB2(x,y)<thU (2)
By these equations, weighted average is calculated for the divided area (x, y) of each image sensor which satisfies the condition that it is an overlapping area and the integrated value falls within a certain range of over a lower limit value thL and less than an upper limit value thU.
The predefined white balance gains wbR0, wbG0, wbB0 can be prepared depending on the characteristic of an imaging unit on the basis of a gray chart shot under a certain illuminant (D65, for example). Assumed that the pixel value obtained from the gray chart is sk (kε{R,G,B}), white balance gain wbk (kε{R,G,B}) is calculated by the following equation:
Thus, the found white balance gain wbk (kε{R,G,B}) is set as the predefined white balance gains wbR0, wbG0, wbB0.
Alternatively, the predefined white balance gains wbR0, wbG0, wbB0 can be determined by a known automatic white balance processing such as gray world algorithm, algorithm (Max-RGB) based on Retinex theory, or algorithm based on illuminant estmation.
Gray world algorithm is based on the assumption that the average of the R, G, and B components of the image should be achromatic color. It determines a white balance gain such that the average signal levels of RGB become equal in a certain image area. The white balance gain wbk (kε{R,G,B}) can be calculated by the following equations from the average value avek (kε{R,G,B}) of the pixel values sk (kε{R,G,B}) of the entire image (M*N[pix]). Herein, the entire image captured by the fisheye lens refers to the whole area in the image circle illuminated with light.
By gray world algorithm appropriate white balance gains can be found for most of common scenes according to a minimal value wbBLim of a blue gain wbB. In the omnidirectional imaging system 10 it is unlikely that the entire image (4π steradian) turns a certain color. Therefore, the gray world algorithm will hold true for the most scenes by adding a limit to a blue color as follows:
The algorithm based on Retinex theory is based on the theory that white color perceived by the human eyes is determined by a maximal cone signal. An image is captured on a solid-state image sensor without saturation, and white balance gain can be calculated by the following equation from a pixel value (sR, sG, sB) at a position having a maximal value of any of RGB.
The algorithm based on illuminant estimation is to obtain illuminant information by extracting an estimated achromatic region from a subject image on the basis of known illuminant information. For instance, a known illuminant with a closest center of gravity is decided by the observation of a distribution of pixel values on the Cr-Cb plane.
Further, the dispersion of general illumination is distributed around blackbody radiation trajectory. Therefore, an illuminant can be estimated from data in an illuminant frame surrounding blackbody radiation trajectory in a color space.
The white balance gain can be decided from a result of illuminant estimation. A fixed value of white balance gain can be decided for each of estimated illuminants or an intermediate value can be interpolated from the distribution of data in the illuminant frame. For simplicity the pixel values inside the area (illuminant frame) surrounded by the chain and dot line and broken line can be averaged.
The wbk (kε{R,G,B}) obtained by any of the known algorithms can be set as the predefined white balance gain wbR0, wbG0, wbB0. The white balance gain can be separately determined for the solid-state image sensors 22A, 22B by the above equations (1) and (2) instead of commonly.
In step S202 the brightness adjuster 222 calculates an OB correction value (o1′, o2′) for each of the image sensors from the OB value (o1, o2) given from the brightness adjuster 222 and the brightness values m1(x, y) and m2(x, y) for each overlapping area of each image sensor (iε{1,2}). The OB correction value (o1′, o2′) is suitably used if the brightness of the imaging units cannot be sufficiently adjusted by automatic exposure control, and calculated by the following equations:
The function min is to find a minimal value of a given set while the function max is to find a maximal value of a given set.
By the equations (3), the OB value for one of the image sensors with a smaller smallest brightness value of the overlapping area is increased to that for the other image sensor with a larger smallest brightness value according to a difference in the smallest brightness values of the overlapping areas of the captured images. For example, if the smallest brightness value of the solid-state image sensor 22A is larger than that of the solid-state image sensor 22B (min (m1(x, y))>min (m2(x,y))), the OB correction value o2′ for the solid-state image sensor 22B is increased by the difference and the OB correction value o1′ for the solid-state image sensor 22A is not changed.
In step S203 the brightness adjuster 222 further calculates a gain value (g1, g2) for each image sensor from the brightness values m1(x, y) and m2(x, y) of the overlapping areas by the following equations (4):
By the above equations (4), the gain value for one of the image sensors which has captured the overall overlapping area with a smaller largest brightness value (subtracted of min (m1(x, y))) is increased to be larger than that for the other image sensor with a larger largest brightness value according to a difference in the largest brightness values of the overlapping divided areas of the captured images. For example, if the largest brightness value of the solid-state image sensor 22A is larger than that of the solid-state image sensor 22B (max (mt1(x, y))>max (mt2(x,y))), the gain value g2 for the solid-state image sensor 22B is increased by the ratio and the gain value g1 for the solid-state image sensor 22A is 1.
In step S204 the adjustment value calculator 224 adjusts the brightness value mi(x, y) on the basis of the above brightness adjustment value. The adjusted brightness value mi′(x, y) is calculated by the following equations:
In step S205 the adjustment value calculator 224 calculates candidates of the WB adjustment value for each overlapping area from the adjusted brightness value mi′(x, y). The candidates (wbri(x, y), wbgi(x, y), wbbi(x,y)) are calculated by the following equations:
In step S206 the adjustment value determiner 226 applies weighted averaging to the calculated candidates (wbri(x, y), wbgi(x, y), wbbi(x,y)) in the periphery of each divided area including the non-overlapping area to determine the WB adjustment value (wbRi(x, y), wbGi(x, y), wbBi(x,y)) for each overlapping areas. The WB adjustment value is calculated by the following equation, taking a red gain wbRi(x, y) for example:
In the equation (7) u and v identify a surrounding area around a divided area (x, y). The range of u and v for weighted averaging can be arbitrarily set. Further, the WB adjustment value (wbri(x, y), wbgi(x, y), wbbi(x, y); iε{1,2}) for each non-overlapping divided area can be the predefined WB value found by the known automatic white balance processing. However, it should not be limited thereto.
For instance, in a wide area excluding the overlapping area a set of WB adjustment values for a single correction point for each image sensor can be determined by the gray world algorithm, and interpolated to be suitable for the mesh form of the divided areas. Thereby, the WB adjustment value for each divided area (x, y) can be calculated. In replace of the gray world algorithm, the algorithms based on Retinex theory and illuminant estimation can be used. Alternatively, multiple correction points can be set for each image sensor. Preferably, in adjusting the sensitivities of the individual image sensors, the light receiving areas of the image sensors are collectively regarded as one image and one or more target points can be set therefor.
In the weighed averaging of the equation (7) Gauss function gives a smaller weight r to the candidate in the peripheral divided areas when the difference between the WB adjustment values of the overlapping area and non-overlapping area is large. A gain for the overlapping area extremely different from that for the non-overlapping area is likely to be inaccurate. By setting a small weight to that area, an anomaly value can be properly adjusted.
The operation completes when the WB adjustment value for each divided area is determined. Returning to step S103 in
As described above, it is made possible to provide an image adjuster and imaging adjusting method and program which can abate a discontinuity of color at the connecting points of the images captured by the imaging units in synthesizing the images.
In view of the occurrence of flares in one of the images as shown in
Further, the adjustment gains are preferably calculated for each image sensor and the adjustment gains (TRi, TGi, TBi) are added to the pixel values using a reference camera as a reference. Thus, a difference in the sensitivities of the image sensors can be adjusted, reducing the discontinuity of color at the connecting positions of the captured images.
The above embodiment has described an example where two images captured with the two image sensors via the lens systems having angle of view of over 180 degrees are overlapped for synthesis. Alternatively, three or more images captured with three or more image sensors can be overlapped for synthesis. Further, an omnidirectional imaging system having multiple lenses and solid-state image sensors can be realized instead of the imaging system with the fisheye lenses.
Moreover, the above embodiment has described the imaging system 10 to capture an omnidirectional still image as an example of the image adjuster.
The present invention should not be limited to such an example. Alternatively, the imaging adjuster can be configured as an omnidirectional video imaging system or unit, a portable data terminal such as a smart phone or tablet having an omnidirectional shooting function, or a digital still camera processor or a controller to control a camera unit of an imaging system.
The functions of the omnidirectional imaging system can be realized by a computer-executable program written in legacy programming language such as assembler, C, C++, C#, JAVA® or object-oriented programming language. Such a program can be stored in a storage medium such as ROM, EEPROM, EPROM, flash memory, flexible disc, CD-ROM, CD-RW, DVD-ROM, DVD-RAM, DVD-RW, blue ray disc, SD card, or MO and distributed through an electric communication line. Further, a part or all of the above functions can be implemented on, for example, a programmable device (PD) as field programmable gate array (FPGA) or implemented as application specific integrated circuit (ASIC). To realize the functions on the PD, circuit configuration data as bit stream data and data written in HDL (hardware description language), VHDL (very high speed integrated circuits hardware description language), and Verilog-HDL stored in a storage medium can be distributed.
Although the present invention has been described in terms of exemplary embodiments, it is not limited thereto. It should be appreciated that variations or modifications may be made in the embodiments described by persons skilled in the art without departing from the scope of the present invention as defined by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
2012-204474 | Sep 2012 | JP | national |
2013-141549 | Jul 2013 | JP | national |