This application claims priority from Japanese Patent Application Nos. 2010-165968, filed on Jul. 23, 2010, and 2010-182677, filed on Aug. 18, 2010, the entire contents of which are hereby incorporated by reference.
1. Field of the Invention
Embodiments described herein relate to an image synthesizing device, an image synthesizing method and a computer readable medium.
2. Description of the Related Art
In a related art, pixels of continuously captured images are added and synthesized, thereby generating an image having a sufficient brightness for recording even in an environment such as a night scene in which the amount of light is not sufficient.
Further, an image synthesizing technique is disclosed in Japanese Unexamined Patent Application Publication No. 2006-148550. As disclosed in this document, in this image synthesizing technique, a fluctuation in image capture angle of view is corrected in performing image synthesis at the time of hand-held image capture in which a user captures an image by holding a camera by hand.
However, in the case of the foregoing image synthesizing technique, when a moving object exists at an image capture angle of view, an image in which an afterimage of the moving object remains will be obtained even with the use of the foregoing image synthesizing technique.
According to one or more illustrative aspects of the present invention, there is provided an image synthesizing device. The device includes: an image capturing unit configured to capture a plurality of images that are temporally continuous; an image generator configured to generate a single synthesized image by adding pixels of the plurality of images; a first difference obtaining unit configured to obtain differences between the plurality of images on pixel-by-pixel basis for each of the plurality images; and a blending unit configured to employ the differences between the plurality of images as transparency information and blend the transparency information into the synthesized image.
According to one or more illustrative aspects of the present invention, there is provided an image synthesizing method. The method includes: (a) capturing a plurality of images that are temporally continuous; (b) generating a single synthesized image by adding pixels of the plurality of images; (c) obtaining differences between the plurality of images on pixel-by-pixel basis for each of the plurality images; and (d) employing the differences between the plurality of images as transparency information and blending the transparency information into the synthesized image.
According to one or more illustrative aspects of the present invention, there is provided a computer-readable medium storing a program for causing the computer to perform operations comprising: (a) capturing a plurality of images that are temporally continuous; (b) generating a single synthesized image by adding pixels of the plurality of images; (c) obtaining differences between the plurality of images on pixel-by-pixel basis for each of the plurality images; and (d) employing the differences between the plurality of images as transparency information and blending the transparency information into the synthesized image.
Other aspects and advantages of the present invention will be apparent from the following description, the drawings and the claims.
Hereinafter, exemplary embodiments of the present invention will be now described with reference to the drawings.
Referring to
The CDS/ADC 3 is a circuit for receiving the analog image capture signal outputted from the image capture unit 1 and responsive to an optical image of an object. The CDS/ADC 3 includes components such as: a CDS for retaining the image capture signal; a gain control amplifier (GCA) for amplifying the image capture signal; and an A/D converter (ADC) for converting the amplified image capture signal into a digital image capture signal. It should be noted that control concerning gain control amplifier adjustment is also carried out in response to an instruction provided from the drive controller 2. Therefore, even when a plurality of images are acquired under the same exposure condition (shutter speed or F-number), generation of a plurality of images, for which conditions are different, is enabled by sequentially changing RGB gain control amplifiers and/or color shades of images.
In the present embodiment, the control concerning the gain control amplifier is carried out by the drive controller 2, but the present invention is not limited thereto. For example, the foregoing control may be carried out by the controller 9.
The key input unit 4 includes, in addition to the foregoing shutter key 41, various keys for detecting switching to an image capture mode for image acquisition/recording according to the present invention, display switching, etc.
The display unit 5 has the function of displaying a synthesized image. After a synthesizing process according to the present invention has been executed, the image recorder 6 stores or holds image data (image file) encoded in a JPEG format. The program memory 7 stores a program executed by the controller 9 and/or the image processor 10, and this program is read by the controller 9 when necessary. The RAM 8 has the function of temporarily retaining data that is generated by each process and is being processed. The controller 9 controls processing operations of the entire image capture device. The image processor 10 includes the synthesizer 11 associated with features of the present invention in addition to image data encoding/decoding processing.
Specifically, the synthesizer 11 synthesizes a single reference image, selected from continuously captured images, with a synthesized image obtained by addition and synthesis of the continuously captured images, and uses, for the resulting synthesized image, an after-mentioned moving object determination map as a transparency map (a map) provided for a difference region, thus reducing an afterimage caused by a moving object.
Next, operations performed in the first embodiment will be described. When a user has operated a mode button provided in the key input unit 4 and set the image capture mode according to the present embodiment, the controller 9 reads the program from the program memory 7, and starts processing as illustrated in a flow chart of
Specifically, the controller 9 determines whether or not pressing of the shutter key 41 is detected (Step S101). Upon detection of the pressing of the shutter key 41, an instruction is provided to the drive controller 2 to execute continuous capture of N images (Step S102). Subsequently, based on image data obtained by the continuous capture, continuously captured images, consisting of YUV images represented by color space information of brightness/color difference, are generated and stored in the RAM 8 (Step S103).
For example, when the number N of the continuously captured images is six, six continuously captured images P1 to P6 consisting of YUV images are stored in the RAM 8 as illustrated in
Note that in the continuous capture of the continuously captured images P1 to P6, an image motion blur caused by camera shake is corrected by a known technique (e.g., a technique for correcting an angle of view by CCD shift or lens shift).
Next, a reference image is selected from the continuously captured images (Step S104). In selecting the reference image, an image in which the amount of motion of the moving object is the smallest is selected from the continuously captured images. Accordingly, from the continuously captured images P1 to P6, the image at a turning point at which the image of the hand H that has moved from a downward position to an upward position starts to move from the upward position to the downward position is selected as the image in which the amount of motion of the moving object (image of the hand H) is the smallest. In other words, the continuously captured image P3, in which the image of the hand H is located at the relatively highest position, is selected as the reference image.
Thereafter, using a LPF (low-pass filter), a noise reduction process is performed on image data of the selected reference image (Step S105). Then, YUV image data of the reference image on which the noise reduction process has been performed is temporarily stored in the RAM 8 (Step S106). Accordingly, in the example illustrated in
Further, a plurality of the continuously captured images are subjected to noise reduction and synthesized (Step S107). Specifically, when the YUV image data of the plurality of continuously captured images is added and averaged on a pixel-by-pixel basis, the images are allowed to be synthesized while being subjected to noise reduction. Equations (1) to (3) for addition and averaging of the YUV image data of the plurality of continuously captured images, i.e., the N continuously captured images, are provided below. It should be noted that Y_result, U_result and V_result represent information of respective pixel brightness/color difference parameters, obtained after the synthesis.
Y_result=(Y[0]+Y[1]+ . . . +Y[N])/N (1)
U_result=(U[0]+U[1]+ . . . +U[N])/N (2)
V_result=(V[0]+V[1]+ . . . +V[N])/N (3)
Naturally, a processing method in this case is not limited to addition and averaging but any other processing method may be used as long as it is a synthesizing method in which a plurality of continuously captured images are used and a noise reduction effect is achieved. Then, the YUV image data of the synthesized image of the whole continuously captured images, on which noise reduction has been performed, is temporarily stored in the RAM 8 (Step S108).
Accordingly, at the time when the process of Step S108 is ended, the following image data is temporarily stored in the RAM 8.
(1) YUV image data of each continuously captured image
(2) YUV image data of the reference image on which the noise reduction process has been performed
(3) YUV image data of the synthesized image on which the noise reduction process has been performed
Then, a process for synthesizing the YUV image data (2) of the reference image with the YUV image data (3) of the synthesized image is performed in such a manner that a moving object determination and α-blending process of the subsequent step, i.e., Step S109, is included.
Referring to the flow chart of
Diff—Y[n]=|Y_Base—Nr−Y[n]| (4)
Diff—U[n]=|U_Base—Nr−U[n]| (5)
Diff—V[n]=|V_Base—Nr−V[n]| (6)
In other words, the foregoing difference absolute values are obtained on a pixel-by-pixel basis for each continuously captured image.
Furthermore, the greater the difference, the more likely it is that a region associated therewith is a region where the object is moved, and therefore, the difference absolute value at which the difference is maximized (at which the difference is maximized for the respective corresponding pixels of the continuously captured images) as indicated by the following equation (7) is selected (Step S202).
Diff[n]=fMax(Diff—Y[n],Diff—U[n],Diff—V[n]) (7)
Next, as indicated by the following equation (8), a process for averaging maximum differences of the respective continuously captured images except the reference image is executed (Step S203).
Ave_Diff=(Diff[0]+Diff[1]+ . . . +Diff[n])/N−1 (8)
Moreover, as indicated by the following equation (9), a smoothing process is executed (Step S204).
Ave_Diff—Lpf=fLpf(Ave_Diff) (9)
As a result of the smoothing process in Step S204, a moving object determination map M is generated as illustrated in
Subsequently, as indicated by the following equation (10), an enhancement process is performed to increase a contrast of the moving object determination map M (Step S205).
Map_Move=fEmphasis(Ave_Diff—Lpf) (10)
As a result of the enhancement process in Step S205, the contrast of a region of the moving object determination map M where the images of the hands H serving as the moving objects are overlapped is increased as illustrated in
Then, finally, using the moving object determination map M (Map_Move [0255]: 0=no moving object) illustrated in
The respective YUV parameters (Y_result, U_result, and V_result) for the respective synthesized pixels are represented by the following equations (11) to (13).
Y_result=(Y—Nr_Mix×(255−Map_Move)+Y_Base—Nr×Map_Move)/255 (11)
U_result=(U—Nr_Mix×(255−Map_Move)+U_Base—Nr×Map_Move)/255 (12)
V_result=(V—Nr_Mix×(255−Map_Move)+V_Base—Nr×Map_Move)/255 (13)
Thus, as illustrated in
For the purpose of comparison,
As illustrated in
Besides, since the smoothing process is performed in Step S204 as mentioned above, a boundary between the moving object (hand H) and the background, which is created by the synthesis, is allowed to be more natural.
In addition, the process for increasing the contrast of the map M is executed in Step S205 described above, thus also enabling a reduction in afterimage (ghost image) caused by a motion blur in the synthesizing process.
The YUV image data representing the synthesized image PM is generated in the above-described manner, thus completing the moving object determination and α-blending process in the flow chart of
In the first embodiment, the case where the influence of a motion blur of the moving object is reduced when a plurality of images obtained by continuous capture are simply synthesized has been described, but the present invention is not limited thereto. The present invention is applicable to other cases as long as images are continuously captured, and is thus also applicable to a case where images, which are continuously captured while an exposure condition is changed, are synthesized and an image with an increased dynamic range is generated.
The following description of the second embodiment will be made on an example in which the invention of the present application is applied to a case where images, which are continuously captured while an exposure condition is changed, are synthesized and an image with an increased dynamic range is generated.
In the following circuit configuration and flow chart, components similar to those of the first embodiment are identified by the same reference characters or numerals in the second embodiment, and the description thereof will be omitted.
The program memory 17 stores a program executed by the controller 9, the image processor 10 and the synthesizer 12, and this program is read by the controller 9 when necessary.
Further, the synthesizer 12 executes synthesis of an overexposure image and a pseudo overexposure image (described later), and uses, for the resulting synthesized image, an moving object determination map as a transparency map (a map) provided for a difference region, thus reducing an afterimage caused by a moving object. Furthermore, pixels of the synthesized image and an underexposure image are added and synthesized, thereby increasing a dynamic range.
Next, operations performed in the second embodiment will be described with reference to
Specifically, the controller 9 determines whether or not pressing of the shutter key 41 is detected (Step S301). Upon detection of the pressing of the shutter key 41, an appropriate exposure is detected; in addition, an instruction is provided to the drive controller 2 to execute image capture at an exposure value of −1 EV, which is reduced by “1” from an exposure value of 0 EV for the appropriate exposure, and an underexposure image obtained by the image capture at −1 EV is temporarily stored in the RAM 8 (Step S302). Subsequently, an instruction is provided to the drive controller 2 to execute image capture at an exposure value of +1 EV, which is increased by “1” from an exposure value of 0 EV for the appropriate exposure, and an overexposure image obtained by the image capture at +1 EV is temporarily stored in the RAM 8 (Step S303).
Accordingly, an underexposure image U illustrated in
The background B of the image U is the same as that of the image O, but the image of the hand H in the previously captured overexposure image O is located at a position lower than that of the image of the hand H in the subsequently captured underexposure image U.
Note that in the continuous capture of the continuously captured images U and O, an image motion blur caused by camera shake is corrected by a known technique (e.g., a technique for correcting an angle of view by CCD shift or lens shift).
Next, a gain of the underexposure image U is increased so that the exposure condition thereof is equivalent to that of the overexposure image O; thus, a pseudo overexposure image thereof is generated and temporarily stored in the RAM 8 (Step S304). Specifically, there is a fourfold difference between an image brightness of the underexposure image U captured at −1 EV and that of the overexposure image O captured at +1 EV, and the brightness of the overexposure image O is four times as high as that of the underexposure image U. Accordingly, the underexposure image U is processed at a fourfold digital gain, thereby generating the pseudo overexposure image whose exposure condition is tentatively equal to that of the overexposure image O.
Subsequently, a moving object determination and α-blending process is performed (Step S305). This moving object determination and/α-blending process is generally similar to that performed in Step S109 in the first embodiment, and a general process flow thereof is similar to that described with reference to
Further, in Step S201 of the flow chart of
Diff—Y=|Y_Under—4−Y_Mid| (14)
Diff—U=|U_Under—4−U_Mid| (15)
Diff—V=|V_Under—4−V_Mid| (16)
In other words, the foregoing difference absolute values are obtained on a pixel-by-pixel basis for both of the images.
Furthermore, the greater the difference, the more likely it is that a region associated therewith is a region where the object is moved, and therefore, the difference absolute value at which the difference is maximized (at which the difference is maximized for the respective corresponding pixels of both of the images) as indicated by the following equation (17) is selected in Step S202.
Diff=fMax(Diff—Y,Diff—U,Diff—V) (17)
Next, as indicated by the following equation (18), a process for averaging maximum differences of both of the images is executed in Step S203.
Ave_Diff=(Diff[0]+++Diff[n])/N−1 (18)
Moreover, as indicated by the following equation (19), a smoothing process is executed in Step S204.
Diff—Lpf=fLpf(Diff) (19)
As a result of the smoothing process in Step S204, a moving object determination map M is generated as illustrated in
Subsequently, as indicated by the following equation [20], an enhancement process is performed to increase a contrast of the moving object determination map M in Step S205.
Map_Move=fEmphasis(Diff—Lpf) (20)
As a result of the enhancement process in Step S205, the contrast of a region of the moving object determination map M where the images of the hands H serving as the moving objects are located is increased as illustrated in
Thereafter, using the moving object determination map M (Map_Move [0{tilde over ( )}255]: 0=no moving object) illustrated in
The respective YUV parameters (Y_result_Over, U_result_Over, and V_result_Over) for the respective pixels of the synthesized image (hereinafter referred to as a “blending image”) are represented by the following equations (21) to (23).
Y_result_Over=(Y_Over×(255−Map_Move)+Y_Under—4×Map_Move)/255 (21)
U_result_Over=(U_Over×(255−Map_Move)+U_Under—4×Map_Move)/255 (22)
V_result_Over=(V_Over×(255−Map_Move)+V_Under—4×Map_Move)/255 (23)
Then, in Step S306 subsequent to Step S305 in the flow chart of
Upon generation of the YUV image data representing the synthesized image PM as described above, the YUV image data of the synthesized image PM serving as a completed image is encoded in a JPEG format and converted into a file, and is recorded and stored in the image recorder 6 (Step S308), thus ending the processing.
Specifically, the controller 9 determines whether or not pressing of the shutter key 41 is detected (Step S401). Upon detection of the pressing of the shutter key 41, an appropriate exposure is detected; in addition, an instruction is provided to the drive controller 2 to execute image capture at an exposure value of −2 EV, which is reduced by “2” from an exposure value of 0 EV for the appropriate exposure, and an underexposure image obtained by the image capture at −2 EV is temporarily stored in the RAM 8 (Step S402).
Furthermore, an instruction is provided to the drive controller 2 to execute image capture at an exposure value of 0 EV for the appropriate exposure, and an appropriate exposure image obtained by the image capture at 0 EV is temporarily stored in the RAM 8 (Step S403). Moreover, an instruction is provided to the drive controller 2 to execute image capture at an exposure value of +2 EV, which is increased by “2” from an exposure value of 0 EV for the appropriate exposure, and an overexposure image obtained by the image capture at +2 EV is temporarily stored in the RAM 8 (Step S404).
Accordingly, the underexposure image, appropriate exposure image and overexposure image, each including a YUV image, are stored in the RAM 8 by the processes of Steps S402, S403 and S404, respectively.
Next, a gain of the underexposure image is increased so that the exposure condition thereof is equivalent to that of the appropriate exposure image, and a first pseudo overexposure image is thus generated and is temporarily stored in the RAM 8; in addition, a gain of the underexposure image is increased so that the exposure condition thereof is equivalent to that of the overexposure image, and a second pseudo overexposure image is thus generated and is temporarily stored in the RAM 8 (Step S405).
Specifically, there is an eightfold difference between an image brightness of the underexposure image captured at −2 EV and that of the appropriate exposure image captured at 0 EV, and therefore, the brightness of the appropriate exposure image is eight times as high as that of the underexposure image. Accordingly, the underexposure image is processed at an eightfold digital gain, thereby generating the first pseudo overexposure image whose exposure condition is tentatively equal to that of the appropriate exposure image.
Further, there is a 16-fold difference between the image brightness of the underexposure image captured at −2 EV and that of the overexposure image captured at +2 EV, and therefore, the brightness of the overexposure image is 16 times as high as that of the underexposure image. Accordingly, the underexposure image is processed at a 16-fold digital gain, thereby generating the second pseudo overexposure image whose exposure condition is tentatively equal to that of the overexposure image. Then, the first and second pseudo overexposure images are temporarily stored in the RAM 8.
Subsequently, it is determined whether or not a first moving object determination and α-blending process is ended (Step S406). When the moving object determination and α-blending process has not yet been executed and the moving object determination and α-blending process to be performed this time is the first one, the determination made in Step S406 is “NO”, and the processing goes to Step S407.
Then, the moving object determination and α-blending process is performed using the first pseudo overexposure image and the appropriate exposure image for which tentatively equal exposure values are used. A process procedure of this moving object determination and α-blending process (Step S407) is similar to that described in the foregoing embodiment with reference to the flow chart of
Then, since the first moving object determination and α-blending process has ended, the determination made in Step S406 is “YES”. Accordingly, the processing goes to Step S409 to perform another moving object determination and α-blending process using the overexposure image and the second pseudo overexposure image for which tentatively equal exposure values are used. A process procedure of this moving object determination and α-blending process (Step S409) is also similar to that described in the foregoing embodiment with reference to the flow chart of
Upon end of the moving object determination and α-blending process performed using the overexposure image and the second pseudo overexposure image, a second blending image obtained as a result of this process is temporarily stored in the RAM 8 (Step S410).
Subsequently, pixels of the first blending image, the second blending image and the underexposure image, which have temporarily been stored in the RAM 8, are added and synthesized, thereby generating YUV image data representing the resulting synthesized image (Step S411).
Thereafter, the YUV image data of the synthesized image PM serving as a completed image is encoded in a JPEG format and converted into a file, and is recorded and stored in the image recorder 6 (Step S412), thus ending the processing.
In this variation, the pixels of the first blending image, the second blending image and the underexposure image are added and synthesized in Step S411 so as to obtain the completed image. However, the pixels of only the first blending image and the underexposure image may be added and synthesized so as to obtain the completed image, or the pixels of the second blending image and the underexposure image may be added and synthesized so as to obtain the completed image.
Although the case where YUV image data is used has been described in the foregoing embodiments, RGB image data may alternatively be used. In that case, a square difference is similarly calculated for each of RGB components.
Number | Date | Country | Kind |
---|---|---|---|
P2010-165968 | Jul 2010 | JP | national |
P2010-182677 | Aug 2010 | JP | national |