The present disclosure relates to an image processing apparatus, an image processing method, and a computer readable recording medium.
In the related art, there is a known technology, in which variation in spectral sensitivity of a pixel due to variation in a spectral transmittance of a color filter arranged on a light receiving surface of an imaging element, such as a charge coupled device (CCD) or a complementary metal oxide semiconductor (CMOS), in an imaging apparatus, such as a digital camera, is adjusted for each imaging element (see JP 2010-193378 A). In this technology, a value of each of color components of red (R), green (G), and blue (B) is calculated for each wavelength from image data that is provided as a combination of R, G, and B components by causing an imaging element to perform photoelectric conversion on visible light that is obtained through spectral dispersion using a prism; a correction coefficient to be multiplied by the value of each of R, G, and B is calculated such that a difference between the calculated value of each of R, G, and B and a reference value that is calculated in advance for each wavelength can be reduced; and thereafter, variation in spectral sensitivity of each imaging element is corrected using the correction coefficient.
An image processing apparatus according to one aspect of the present disclosure includes: an acquiring unit configured to acquire image data generated by an imaging element, in which a predetermined arrangement pattern is formed using color filters of a plurality of colors with different spectral transmittances and each of the color filters is arranged at a position corresponding to one of pixels, and acquire a correction coefficient, which is for correcting a pixel value difference that corresponds to a difference between spectral sensitivity of a pixel of interest and reference spectral sensitivity set in advance in a predetermined wavelength region, from a recording unit that records the correction coefficient for each of the pixels; a correction amount calculating unit configured to calculate an estimated value of a color component to be corrected in the pixel of interest, and calculate a correction amount of a pixel value of the pixel of interest based on the estimated value and the correction coefficient of the pixel of interest; and a pixel value correcting unit configured to correct the pixel value of the pixel of interest based on the correction amount calculated by the correction amount calculating unit, wherein the correction amount calculating unit changes a method of calculating the estimated value and a method of calculating the correction amount depending on a predetermined condition.
The above and other features, advantages and technical and industrial significance of this disclosure will be better understood by reading the following detailed description of presently preferred embodiments of the disclosure, when considered in connection with the accompanying drawings.
Modes for carrying out the present disclosure (hereinafter, referred to as “embodiments”) will be described below with reference to the drawings. The present disclosure is not limited by the embodiments described below. The same components are denoted by the same reference signs throughout the drawings.
Configuration of Imaging System
Configuration of Imaging Apparatus
First, a configuration of the imaging apparatus 10 will be described. The imaging apparatus 10 includes an optical system 101, a diaphragm 102, a shutter 103, a driver 104, an imaging element 105, a color filter 106, an analog processing unit 107, an analog-to-digital (A/D) converter 108, a first operating unit 109, a memory interface (I/F) unit 110, a recording medium 111, a volatile memory 112, a non-volatile memory 113, a bus 114, an imaging control unit 115, and a first external I/F unit 116.
The optical system 101 is constituted by one or more lenses. The optical system 101 is constituted by, for example, a focus lens and a zoom lens.
The diaphragm 102 adjusts exposure by limiting an incident amount of light collected by the optical system 101. The diaphragm 102 limits the incident amount of light collected by the optical system 101 under the control of the imaging control unit 115. It may be possible to control the incident amount of light by using the shutter 103 or an electronic shutter in the imaging element 105 without using the diaphragm 102.
The shutter 103 sets a state of the imaging element 105 to an exposure state or a light blocking state under the control of the imaging control unit 115. The shutter 103 is constituted by, for example, a focal plane shutter or the like. It may be possible to use the electronic shutter in the imaging element 105 without using the shutter 103.
The driver 104 drives the optical system 101, the diaphragm 102, and the shutter 103 under the control of the imaging control unit 115 to be described later. For example, the driver 104 moves the optical system 101 along an optical axis O1 to change a zoom magnification or adjust a focus position of the imaging apparatus 10.
The imaging element 105 receives light collected by the optical system 101, converts the light into image data (electrical signal), and outputs the image data under the control of the imaging control unit 115 to be described later. The imaging element 105 is constituted by an image sensor, such as a complementary metal oxide semiconductor (CMOS) or a charge coupled device (CCD), having a plurality of pixels arranged two-dimensionally. Further, the imaging element 105 has an electronic shutter function capable of electronically controlling the amount of light received.
The color filter 106 is arranged on a light receiving surface of the imaging element 105 in a laminated manner. The color filter 106 is configured such that a plurality of color filters that transmit light in mutually different wavelength ranges constitute a predetermined arrangement pattern, and each of the color filters constituting the arrangement pattern is arranged in a position corresponding to one of the pixels of the imaging element 105. As illustrated in
The analog processing unit 107 performs predetermined analog processing on an analog signal output from the imaging element 105, and outputs the analog signal to the A/D converter 108. Specifically, the analog processing unit 107 performs noise reduction processing, gain-up processing, or the like on the analog signal input from the imaging element 105. For example, the analog processing unit 107 performs reset noise reduction or the like on the analog signal, subsequently performs waveform shaping, and then performs gain-up to obtain desired brightness.
The A/D converter 108 performs A/D conversion on the analog signal input from the analog processing unit 107 to generate digital image data (hereinafter, referred to as “RAW image data”), and outputs the RAW image data to the volatile memory 112 via the bus 114. The A/D converter 108 may directly output the RAW image data to each of units of the imaging apparatus 10 to be described later. It may be possible to provide the color filter 106, the analog processing unit 107, and the A/D converter 108 as described above in the imaging element 105, and cause the imaging element 105 to directly output the digital RAW image data.
The first operating unit 109 gives an instruction to each of the units of the imaging apparatus 10. Specifically, the first operating unit 109 includes a power switch for changing a power supply state of the imaging apparatus 10 to an ON-state or an OFF-state, a release switch for giving an instruction on imaging of a still image, an operation switch for changing various settings of the imaging apparatus 10, a moving image switch for giving an instruction on imaging of a moving image, and the like.
The recording medium 111 is constituted by a memory card attached from outside the imaging apparatus 10, and detachably attached to the imaging apparatus 10 via the memory I/F unit 110. Further, the recording medium 111 may output each of programs and various kinds of information to the non-volatile memory 113 via the memory I/F unit 110 under the control of the imaging control unit 115.
The volatile memory 112 temporarily stores therein image data that is input from the A/D converter 108 via the bus 114. For example, the volatile memory 112 temporarily stores image data that is sequentially output for one frame by the imaging element 105 via the analog processing unit 107, the A/D converter 108, and the bus 114. The volatile memory 112 is constituted by a synchronous dynamic random access memory (SDRAM) or the like.
The non-volatile memory 113 records various programs for operating the imaging apparatus 10 and various kinds of data used during execution of the programs. Further, the non-volatile memory 113 includes a program recording unit 113a and a correction coefficient recording unit 113b that records a correction coefficient for correcting variation in the spectral sensitivity of each of the pixels of the imaging element 105 input via the first external I/F unit 116. Here, the correction coefficient is a coefficient for correcting a pixel value difference that corresponds to a difference between spectral sensitivity of a pixel of interest and reference spectral sensitivity set in advance in a predetermined wavelength region. Further, the reference spectral sensitivity is average spectral sensitivity of pixels of the same color in the color filters in a case where light is uniformly applied to the imaging element 105. The correction coefficient is calculated in advance by a device (not illustrated) and recorded in the correction coefficient recording unit 113b.
The bus 114 is constituted by a channel or the like that connects each of the components of the imaging apparatus 10, and transfers various kinds of data generated inside the imaging apparatus 10 to each of the components of the imaging apparatus 10.
The imaging control unit 115 is constituted by a central processing unit (CPU) or the like, and comprehensively controls operation of the imaging apparatus 10 by transferring instructions, data, and the like to each of the components of the imaging apparatus 10 in accordance with an instruction signal or a release signal from the first operating unit 109. For example, when a second release signal is input from the first operating unit 109, the imaging control unit 115 causes the imaging apparatus 10 to start imaging operation. Here, the imaging operation of the imaging apparatus 10 is operation in which the analog processing unit 107 and the A/D converter 108 perform predetermined processing on an analog signal output by the imaging element 105. The image data subjected to the processing as described above is recorded in the recording medium 111 via the bus 114 and the memory I/F unit 110 under the control of the imaging control unit 115.
The first external I/F unit 116 outputs information input from an external apparatus via the bus 114 to the non-volatile memory 113 or the volatile memory 112, and outputs information stored in the volatile memory 112, information stored in the non-volatile memory 113, and image data generated by the imaging element 105 to an external apparatus via the bus 114. Specifically, the first external I/F unit 116 outputs the image data generated by the imaging element 105 and the correction coefficient recorded by the correction coefficient recording unit 113b to the image processing apparatus 40 via the bus 114.
Configuration of Image Processing Apparatus
Next, a configuration of the image processing apparatus 40 will be described.
The image processing apparatus 40 includes a second external I/F unit 41, a second recording unit 42, a bus 43, a spectral sensitivity variation correcting unit 44, and an image processing unit 45.
The second external I/F unit 41 acquires the image data generated by the imaging element 105 and the correction coefficient recorded by the correction coefficient recording unit 113b via the first external I/F unit 116 of the imaging apparatus 10, and outputs the acquired image data and correction coefficient to the spectral sensitivity variation correcting unit 44 or a second buffer unit 422. The second external I/F unit 41 and the first external I/F unit 116 are connected to each other via a control cable, a wireless channel, or the like that enables bi-directional transmission and reception of information, for example. The second external I/F unit 41 functions as an acquiring unit according to the first embodiment.
The second recording unit 42 is constituted by a volatile memory and a nonvolatile memory, and records the image data, the correction coefficient, various programs for operating the image processing apparatus 40, and various kinds of data used during execution of the programs, which are input from the imaging apparatus 10 via the second external I/F unit 41. Further, the second recording unit 42 includes a second program recording unit 421 that records a program for driving the image processing apparatus 40, and the second buffer unit 422 that temporarily stores therein image data and a correction coefficient of a pixel of interest, which are input from the imaging apparatus 10.
The bus 43 is constituted by a channel or the like that connects each of the components of the image processing apparatus 40, and transfers various kinds of data generated inside the image processing apparatus 40 to each of the components of the image processing apparatus 40.
The spectral sensitivity variation correcting unit 44 corrects variation in the spectral sensitivity of each of pixels of an image corresponding to the image data acquired by the second external I/F unit 41, and outputs the corrected spectral sensitivity to the image processing unit 45. The spectral sensitivity variation correcting unit 44 includes a correction amount calculating unit 441 and a pixel value correcting unit 442. When the image data includes an optical black value (OB value), the spectral sensitivity variation correcting unit 44 may perform OB subtraction processing.
The correction amount calculating unit 441 calculates an estimated value of a color component to be corrected in the pixel of interest, and calculates a correction amount of the pixel value of the pixel of interest based on the estimated value and the correction coefficient of the pixel of interest. Further, the correction amount calculating unit 441 changes a method of calculating the estimated value or a method of calculating the correction amount depending on a predetermined condition. Here, the predetermined condition is that pixel values of different-color pixels are saturated, where the different-color pixels are pixels which are present on the periphery of the pixel of interest and for which color filters of a certain color different from a color of the color filter arranged on the pixel of interest are arranged. That is, the correction amount calculating unit 441 changes the method of calculating the estimated value depending on whether the pixel values of the different-color pixels, which are present on the periphery of the pixel of interest and for which color filters of a certain color different from the color of the color filter arranged on the pixel of interest is arranged, is saturated.
The pixel value correcting unit 442 corrects the pixel value of the pixel of interest using the correction amount calculated by the correction amount calculating unit 441. Specifically, the pixel value correcting unit 442 corrects the pixel value of the pixel of interest by subtracting the correction amount calculated by the correction amount calculating unit 441 from the pixel value of the pixel of interest, and outputs the corrected pixel value to the image processing unit 45.
The image processing unit 45 performs predetermined image processing on the image data for which variation in the spectral sensitivity has been corrected by the spectral sensitivity variation correcting unit 44, and outputs the image data to the display device 50. Here, the predetermined image processing is basic image processing including white balance adjustment processing and, in a case where the imaging element 105 has Bayer arrangement, includes image data synchronization processing, color matrix calculation processing, gamma correction processing, color reproduction processing, edge enhancement processing, noise reduction processing, and the like. Further, the image processing unit 45 performs image processing for reproducing a natural image based on pre-set parameters of each image processing. Here, the parameters of each image processing are values of contrast, sharpness, saturation, white balance, and tone. It may be possible to record the image data subjected to the predetermined image processing in the non-volatile memory 113 or the recording medium 111 of the imaging apparatus 10 via the second external I/F unit 41.
Configuration of Display Device
Next, a configuration of the display device 50 will be described. The display device 50 displays an image corresponding to image data input from the image processing apparatus 40. The display device 50 is constituted by a display panel made of liquid crystal, organic electro luminescence (EL), or the like.
In the imaging system 1 having the configuration as described above, the image processing apparatus 40 acquires each of the image data and the correction coefficient from the imaging apparatus 10, calculates the correction amount for correcting a pixel value of a pixel of interest of the image data using the acquired correction coefficient, and then corrects the pixel value of the pixel of interest using the correction amount. Thereafter, the display device 50 displays an image corresponding to the image data subjected to the image processing by the image processing apparatus 40.
Process Performed by Image Processing Apparatus
Next, a process performed by the image processing apparatus 40 will be described.
As illustrated in
Subsequently, the pixel value correcting unit 442 corrects a pixel value of each of pixels by subtracting the correction amount of each of the pixels calculated by the correction amount calculating unit 441 (Step S2). After Step S2, the image processing apparatus 40 terminates the process.
Correction Amount Calculation Process
Next, details of the correction amount calculation process explained at Step S1 in
As illustrated in
Subsequently, the correction amount calculating unit 441 performs an R-component correction amount calculation process for calculating a correction amount of an R component of a pixel value of a pixel of interest (x, y) (Step S13). Here, the R component is a pixel value that is generated upon reception of light in an R wavelength band. Details of the R-component correction amount calculation process will be described later.
Thereafter, the correction amount calculating unit 441 performs a G-component correction amount calculation process for calculating a correction amount of a G component of the pixel value of the pixel of interest (x, y) (Step S14). Here, the G component is a pixel value that is generated upon reception of light in a G wavelength band. Details of the G-component correction amount calculation process will be described later.
Subsequently, the correction amount calculating unit 441 performs a B-component correction amount calculation process for calculating a correction amount of a B component of the pixel value of the pixel of interest (x, y) (Step S15). Here, the B component is a pixel value that is generated upon reception of light in a B wavelength band. Details of the B-component correction amount calculation process will be described later.
Thereafter, the correction amount calculating unit 441 performs a correction amount calculation process for calculating a correction amount for the pixel value of the pixel of interest (x, y) based on the correction amounts of the R component, the G component, and the B component calculated through Step S13 to Step S15 described above (Step S16). Details of the correction amount calculation process on the pixel of interest (x, y) will be described later.
Subsequently, the correction amount calculating unit 441 increments the counter x (x=x+1) (Step S17).
Thereafter, if the counter x is smaller than the width of the image corresponding to the image data (Step S18: Yes), the correction amount calculating unit 441 returns to Step S13. In contrast, if the counter x is not smaller than the width of the image corresponding to the image data (Step S18: No), the correction amount calculating unit 441 proceeds to Step S19 as described below.
At Step S19, the correction amount calculating unit 441 increments the counter y (y=y+1).
Thereafter, if the counter y is smaller than the height of the image corresponding to the image data (Step S20: Yes), the image processing apparatus 40 returns to Step S12 described above. In contrast, if the counter y is not smaller than the height of the image corresponding to the image data (Step S20: No), the image processing apparatus 40 returns to the main routine in
R-Component Correction Amount Calculation Process
Next, details of the R-component correction amount calculation process explained at Step S13 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates a correction amount of the R component of the pixel value of the pixel of interest (x, y) by multiplying the estimated value of the R-component of the pixel of interest (x, y) calculated at Step S31 described above by the correction coefficient of the R component of the pixel of interest (x, y) (Step S32). After Step S32, the image processing apparatus 40 returns to the sub routine of the correction amount calculation process in
G-Component Correction Amount Calculation Process
Next, details of the G-component correction amount calculation process explained at Step S14 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates a correction amount of the G component of the pixel value of the pixel of interest (x, y) by multiplying the estimated value of the G-component of the pixel of interest (x, y) calculated at Step S33 described above by the correction coefficient of the G component of the pixel of interest (x, y) (Step S34). After Step S34, the image processing apparatus 40 returns to the sub routine of the correction amount calculation process in
B-Component Correction Amount Calculation Process
Next, details of the B-component correction amount calculation process explained at Step S15 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates a correction amount of the B component of the pixel value of the pixel of interest (x, y) by multiplying the estimated value of the B-component of the pixel of interest (x, y) calculated at Step S35 described above by the correction coefficient of the B component of the pixel of interest (Step S36). After Step S36, the image processing apparatus 40 returns to the sub routine of the correction amount calculation process in
As described above with reference to
R-Component Estimated Value Calculation Process
Next, details of the R-component estimated value calculation process explained at Step S31 in
As illustrated in
At Step S51, if the pixel values of the R pixels on the periphery of the pixel of interest (x, y) are saturated (Step S51: Yes), an R-component estimated value calculation process based on similarity is performed, which is for calculating the estimated value of the R component based on similarity to the pixel value of the pixel of interest (x, y) (Step S53). Details of the R-component estimated value calculation process based on similarity will be described later. After Step S53, the image processing apparatus 40 returns to the sub routine of the R-component correction amount calculation process in
R-Component Estimated Value Calculation Process Based on Average
Next, details of the R-component estimated value calculation process based on average explained at Step S52 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates the average value AveR calculated at Step S61 described above, as the R-component estimated value of the pixel of interest (x, y) (Step S62). After Step S62, the image processing apparatus 40 returns to the R-component estimated value calculation process in
R-Component Estimated Value Calculation Process Based on Similarity
Next, details of the R-component estimated value calculation process based on similarity explained at Step S53 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates an average value AvePix of pixel values of the same-color pixels that are present on the periphery of the pixel of interest (x, y) and that have the same color as the pixel of interest (x, y) (Step S72). In this case, the correction amount calculating unit 441 calculates the average value AvePix from the pixel values of the reference pixels as described above.
Thereafter, the correction amount calculating unit 441 initializes a candidate value Est (Est=Est0) (Step S73). In this case, it is preferable for the correction amount calculating unit 441 to set the candidate value Est to a possible maximum value Est0 of pixel values that are input to the spectral sensitivity variation correcting unit 44.
Subsequently, the correction amount calculating unit 441 initializes a similarity Sim (Sim=Max) (Step S74). In this case, the correction amount calculating unit 441 sets a possible maximum value of the similarity Sim. Here, the similarity Sim is defined such that a value decreases with an increase in the similarity (the similarity is higher), and the value increases with a decrease in the similarity (the similarity is lower).
Thereafter, the correction amount calculating unit 441 initializes a counter Step to zero (Step=0) (Step S75).
Subsequently, the correction amount calculating unit 441 calculates two large and small candidate values Estp and Estm (Step S76). Specifically, as illustrated in
Estp=Est+(Est0/2Step) (1)
Estm=Est−(Est0/2Step) (2)
Thereafter, the correction amount calculating unit 441 performs a similarity calculation process on each of R-component candidate values to calculate a similarity of the estimated value of each of the R components (Step S77).
Similarity Calculation Process on Each R-Component Estimated Value
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates a theoretical value Ideal for each of the pixels (Step S92). Specifically, the correction amount calculating unit 441 calculates, as a theoretical value Ideal(x+Δx, y+Δy), a value by multiplying a difference between an R-component correction coefficient CoefR(x+Δx, y+Δy) and the average value AveCoef of the R-component correction coefficients calculated at Step S71 in
Ideal(x+Δx,y+Δy)=(CoefR(x+Δx,y+Δy)−AveCoef)×Est (3)
Thereafter, the correction amount calculating unit 441 calculates a measurement value Val for each of the pixels (Step S93). Specifically, the correction amount calculating unit 441 calculates, for each pixel in the reference pixels (x+Δx, y+Δy), a difference between a pixel value Pix(x+Δx, y+Δy) and the average value AvePix of the pixel values calculated at Step S72 in
Val(x+Δx,y+Δy)=Pix(x+Δx,y+Δy)−AvePix (4)
Subsequently, the correction amount calculating unit 441 calculates an absolute difference value Diff between the theoretical value Ideal and the measurement value Val for each of the pixels (Step S94). Specifically, the correction amount calculating unit 441 calculates an absolute difference value Diff(x+Δx, y+Δy) between the theoretical value Ideal(x+Δx, y+Δy) and the measurement value Val(x+Δx, y+Δy) for each of the pixels (x+Δx, y+Δy). More specifically, the correction amount calculating unit 441 calculates the absolute difference value Diff(x+Δx, y+Δy) for each of the pixels based on Equation (5) below.
Diff(x+Δx,y+Δy)=|(Val(x+Δx,y+Δy)−Ideal(x+Δx,y+Δy)| (5)
The correction amount calculating unit 441 may calculate a squared difference value as the value Diff(x+Δx, y+Δy) by Equation (6) below, instead of the absolute difference value Diff(x+Δx, y+Δy).
Diff(x+Δx,y+Δy)=((Val(x+Δx,y+Δy)−Ideal(x+Δx,y+Δy))2 (6)
Thereafter, the correction amount calculating unit 441 calculates a sum value of the absolute difference values Diff of all of the reference pixels as the similarity Sim (Step S95). The correction amount calculating unit 441 may calculate a weighted sum instead of a simple sum of the absolute difference values of all of the reference pixels. For example, when performing weighting, the correction amount calculating unit 441 may calculate a sum of the absolute difference values of all of the reference pixels while changing a weight coefficient depending on a distance to each of the pixels from the pixel of interest (x, y). Further, when performing weighting, the correction amount calculating unit 441 may calculate a sum of the absolute difference values of all of the reference pixels while changing a weight coefficient such that the weight is increased with an increase in the absolute difference value Diff (which is equivalent to calculating a sum of the absolute difference values while converting the absolute difference values Diff using a monotonically increasing function). After Step S95, the image processing apparatus 40 returns to the R-component estimated value calculation process based on similarity in
In this manner, the correction amount calculating unit 441 employs the degree of similarity between the distribution of the pixel values and the distribution of the theoretical values by employing the sum of the absolute difference values or the squared difference values as an evaluation value in the similarity calculation process on each of the R-component estimated values; however, the evaluation value may be calculated by other methods. For example, the correction amount calculating unit 441 may calculate the evaluation value by using normalized cross-correlation (NCC), zero-mean normalized cross-correlation (ZNCC), or the like. As for the G component and the B component, it is possible to calculate the similarity for the estimated value of each of the G components and the similarity for the estimated value of each of the B components by performing the same process as described above by replacing the R component with the G component and the B component; therefore, explanation of the similarity calculation process on each of the G-component estimated values and the similarity calculation process on each of the B-component estimated values will be omitted. This process is performed for each of the candidate values Est, Estp, and Estm to calculate three similarities Sim, Simp, and Simm.
Referring back to
At Step S78, the correction amount calculating unit 441 selects the candidate value whose similarity is the minimum value (the most similar candidate value). Specifically, the correction amount calculating unit 441 calculates (selects) the candidate value (any of Est, Estp, and Estm) corresponding to the lowest similarity from among the three similarities Sim, Simp, and Simm. Specifically, as illustrated in
At Step S79, the correction amount calculating unit 441 updates the candidate value calculated at Step S78 with the candidate value Est. For example, if the candidate value calculated at Step S78 is Estp, the correction amount calculating unit 441 sets Est to Estp (Est=Estp).
Thereafter, the correction amount calculating unit 441 increments the counter Step (Step=Step+1) (Step S80).
Subsequently, if the counter Step is smaller than n (Step <n) (Step S81: Yes), the image processing apparatus 40 returns to Step S76 described above. In contrast, if the counter Step is not smaller than n (Step S81: No), the image processing apparatus 40 proceeds to Step S82. Here, it is preferable that n is set such that Est0/2n becomes equal to or larger than one.
At Step S82, the correction amount calculating unit 441 outputs the candidate value Est as the R-component estimated value. After Step S82, the image processing apparatus 40 returns to the R-component estimated value calculation process in
As described above, according to the R-component estimated value calculation process based on similarity, the pixel values of the different-color pixels that are present on the periphery of the pixel of interest are not used; therefore, even when the different-color pixels are saturated, the correction amount calculating unit 441 can calculate an estimated value of a color component that is different from the pixel of interest in the pixel of interest.
Further, in the first embodiment, the correction amount calculating unit 441 selects the candidate value having the minimum value while comparing the three similarities, such as the two large and small similarities and the current similarity, and repeats this process to search for the candidate value whose similarity is the minimum value in the R-component estimated value calculation process based on similarity. With this operation, the correction amount calculating unit 441 does not use the pixel values of the different-color pixels that are present on the periphery of the pixel of interest, so that even when the different-color pixels are saturated, it is possible to calculate an estimated value of a color component that is different from the pixel of interest in the pixel of interest. The correction amount calculating unit 441 may search for a candidate value having the highest similarity by other methods. For example, the correction amount calculating unit 441 may employ a method of searching for a value having the highest similarity by comprehensively distributing the candidate values, a well-known hill climbing method, a local search method, or the like. Further, as for a G-component estimated value calculation process based on similarity, which is included in the G-component estimated calculation process at Step S33 in
Correction Amount Calculation Process on Pixel Value of Pixel of Interest (x, y)
Next, the correction amount calculation process on the pixel value of the pixel of interest (x, y) explained at Step S16 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates the sum value Sumc calculated at Step S101 described above as the correction amount of the pixel of interest (x, y) (Step S102). After Step S102, the image processing apparatus 40 returns to the correction amount calculation process in
According to the first embodiment as described above, when the pixel values of the different-color pixels are saturated, the correction amount calculating unit 441 calculates similarities from the candidate values, from the theoretical values of pixel values of neighboring same-color pixels that are present on the periphery of the pixel of interest (x, y) and that are calculated based on correction coefficients of the respective pixels of the neighboring same-color pixels for which color filters having the same color as the color filter arranged on the pixel of interest (x, y) are arranged, and from the measurement values of the pixel values of the neighboring same-color pixels; and calculates a candidate value with a high similarity as the estimated value. In contrast, when the pixel values of the different-color pixels are not saturated, the correction amount calculating unit 441 calculates the estimated value of the color component to be corrected in the pixel of interest (x, y) by using the pixel values of the respective pixels of the neighboring pixels including the neighboring same-color pixels that are present on the periphery of the pixel of interest (x, y). Therefore, even when the different-color pixels are saturated, the correction amount calculating unit 441 can calculate the estimated value of a color component that is different from the pixel of interest in the pixel of interest (x, y). Consequently, it is possible to perform correction by taking into account the conditions of the neighboring pixels. As a result, it is possible to correct variation in the spectral sensitivity with high accuracy.
Next, a modification of the first embodiment will be described. In the modification of the first embodiment, an imaging system has the same configuration as that of the imaging system 1 according to the first embodiment described above, but an image processing apparatus performs a different correction amount calculation process on a pixel value of a pixel of interest (x, y). Specifically, in the modification of the first embodiment, overcorrection and erroneous correction are prevented. In the following, the correction amount calculation process performed on the pixel value of the pixel of interest (x, y) by the image processing apparatus according to the modification of the first embodiment will be described. The same components as those of the imaging system 1 according to the first embodiment described above are denoted by the same reference signs, and explanation thereof will be omitted.
Correction Amount Calculation Process on Pixel Value of Pixel of Interest (x, y)
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates an average value Ave of pixel values of same-color pixels that are present on the periphery of the pixel of interest (x, y) and that have the same color as the pixel of interest (x, y) (Step S112). In this case, it is preferable that the correction amount calculating unit 441 uses the same pixels as the same-color pixels for which the average value Ave is calculated at Step S72 in
Thereafter, the correction amount calculating unit 441 calculates a difference Delta between the average value Ave calculated at Step S112 and the pixel value Pix of the pixel of interest (x, y) (Delta=Pix−Ave) (Step S113).
Subsequently, if the signs of the difference Delta and the sum value Sumc are the same (Step S114: Yes), and if it is determined that |Delta|<|Sumc| (Step S115: Yes), the correction amount calculating unit 441 sets the sum value Sumc to the difference Delta (Sumc=Delta) (Step S116). After Step S116, the image processing apparatus 40 proceeds to Step S118 to be described later.
At Step S114, if the signs of the difference Delta and the sum value Sumc are the same (Step S114: Yes), and if it is not determined that |Delta|<|Sumc| (Step S115: No), the image processing apparatus 40 proceeds to Step S118 to be described later.
At Step S114, if the signs of the difference Delta and the sum value Sumc are not the same (Step S114: No), the correction amount calculating unit 441 sets the sum value Sumc to “0” (Sumc=0) (Step S117). After Step S117, the image processing apparatus 40 proceeds to Step S118 to be described later.
Subsequently, the correction amount calculating unit 441 calculates the sum value Sumc as the correction amount of the pixel of interest (x, y) (Step S118). After Step S118, the image processing apparatus 40 returns to the correction amount calculation process in
According to the modification of the first embodiment as described above, when the sings of the difference Delta and the sum value Sumc are not the same, the correction amount calculating unit 441 sets the sum value Sumc to “0”, and, when the sings of the difference Delta and the sum value Sumc are the same and if it is determined that |Delta|<|Sumc|, the correction amount calculating unit 441 sets the sum value Sumc to the difference “Delta”. Therefore, it is possible to prevent overcorrection and erroneous correction.
In the modification of the first embodiment, the corrected pixel value is limited between the pixel value Pix and the average value Ave by comparing the sign of the difference Delta and the sign of the sum value Sumc and determining whether |Delta|<|Sumc|; however, other methods may be employed. For example, when Ave<Pix, the correction amount calculating unit 441 may clip the value obtained by subtracting the sum value Sumc from the pixel value Pix so as to be equal to or larger than the average value Ave and equal to or smaller than the pixel value Pix, and, when Ave Pix, the correction amount calculating unit 441 may clip the value obtained by subtracting the sum value Sumc from the pixel value Pix so as to be equal to or larger than the pixel value Pix and equal to or smaller than the average value Ave.
Next, a second embodiment will be described. An imaging system according to the second embodiment has the same configuration as the imaging system 1 according to the first embodiment described above, but an image processing apparatus performs a different estimated value calculation process. Specifically, in the first embodiment described above, the correction amount calculating unit changes the method of calculating the estimated value depending on whether neighboring pixel values are saturated as a predetermined condition; however, in the second embodiment, the correction amount calculating unit changes the method of calculating the estimated value depending on flatness of neighboring pixels as a predetermined condition. The same components as those of the imaging system 1 according to the first embodiment described above are denoted by the same reference signs, and explanation thereof will be omitted. Further, in the following description, processes on the R component will be described, and the same processes are also performed on the G component and the B component; therefore, explanation of the processes on the G component and the B component will be omitted.
R-Component Estimated Value Calculation Process
As illustrated in
Subsequently, the correction amount calculating unit 441 determines whether the R pixel values of the neighboring pixels calculated at Step S121 are larger than a threshold set in advance, and determines whether the R pixel values of the neighboring pixels are flat (Step S122). Here, the neighboring pixels are pixels that are present on the periphery of the pixel of interest (x, y) (for example, in a range of m×n centered at the pixel of interest). Further, the threshold may be appropriately set depending on conditions. If the R pixel values of the neighboring pixels are not flat (Step S122: No), the image processing apparatus 40 proceeds to Step S123 to be described later. In contrast, if the R pixel values of the neighboring pixels are flat (Step S122: Yes), the image processing apparatus 40 proceeds to Step S124 to be described later.
At Step S123, the correction amount calculating unit 441 performs an R-component estimated value calculation process based on consideration of a flat direction for calculating an estimated value of the R component by taking into account the flat direction. Details of the R-component estimated value calculation process based on consideration of the flat direction will be described later. After Step S123, the image processing apparatus 40 returns to the R-component correction amount calculation process in
At Step S124, the correction amount calculating unit 441 performs the R-component estimated value calculation process based on average (see
R-Component Estimated Value Calculation Process Based on Consideration of Flat Direction
Next, details of the R-component estimated value calculation process based on consideration of the flat direction explained at Step S123 in
As illustrated in
Subsequently, the correction amount calculating unit 441 calculates the average value of the pixel values acquired at Step S131 as the estimated value (Step S132). The correction amount calculating unit 441 may calculate a different statistical value other than the average value as the estimated value. For example, the correction amount calculating unit 441 may calculate, as the estimated value, any of statistical values, such as a weighted average value, a median value, and an absolute value, except for a correction coefficient with the statistical values having predetermined values or larger. After Step S132, the image processing apparatus 40 returns to the R-component estimated value calculation process in
R-Component Flatness Calculation Process
Next, details of the R-component flatness calculation process explained at Step S121 in
As illustrated in
Moreover, in
Subsequently, the correction amount calculating unit 441 initializes a variable Δdir, which indicates the degree of correlation in the dir direction, to zero (Δdir=0) (Step S202), and initializes a counter that counts the number added to Δdir to zero (Num=0) (Step S203).
Thereafter, the correction amount calculating unit 441 initializes a counter d that indicates a line for obtaining the degree of correlation (d=1) (Step S204), and initializes a counter i indicating a pixel for obtaining the degree of correlation (i=2) (Step S205).
Subsequently, the correction amount calculating unit 441 acquires a pixel value of an i−1th pixel on a d-line in the dir direction (for example, pixels used for the direction determination are defined as a first pixel, a second pixel, . . . , and an iMaxth pixel starting from the pixel located closest to the start point of the arrow A1 in each of the directions 1 to 4 in
Thereafter, the correction amount calculating unit 441 acquires a pixel value of an ith pixel on the d-line in the dir direction from the second buffer unit 422 (Step S207). The correction amount calculating unit 441 copies the acquired pixel value of the ith pixel to a variable Curr.
Subsequently, the correction amount calculating unit 441 calculates an absolute value of a difference between the variable Prevl and the variable Curr (Step S208).
Thereafter, the correction amount calculating unit 441 adds the absolute value of the difference calculated at Step S208 to a variable Δdir(d) (Δdir(d)=Δdir(d)+the absolute value of the difference) (Step S209).
Subsequently, the correction amount calculating unit 441 increments the counter i indicating a pixel for obtaining the degree of correlation (i=i+1) (Step S210).
Thereafter, the correction amount calculating unit 441 determines whether the counter i indicating the pixel for obtaining the degree of correlation is equal to or smaller than iMax (Step S211). If the correction amount calculating unit 441 determines that the counter i is equal to or smaller than iMax (Step S211: Yes), the image processing apparatus 40 returns to Step S206 described above. In contrast, if the correction amount calculating unit 441 determines that the counter i is not equal to or smaller than iMax (Step S211: No), the image processing apparatus 40 proceeds to Step S212 as described below.
At Step S212, the correction amount calculating unit 441 calculates an average of the absolute values of the differences (Δdir(d)=Δdir(d)/(iMax−1)). In the second embodiment, the correction amount calculating unit 441 calculates the average value of the absolute values of the differences as an evaluation value, but the embodiments are not limited to this example, and it may be possible to use a value calculated by other calculation methods as the evaluation value. For example, the correction amount calculating unit 441 may use a difference between a maximum and a minimum of the target pixels present on the d-line as the evaluation value, or use a standard deviation of the target pixels present on the d-line as the evaluation value.
Subsequently, the correction amount calculating unit 441 increments the counter d indicating a line for obtaining the degree of correlation (d=d+1) (Step S213).
Thereafter, the correction amount calculating unit 441 determines whether the counter d indicating a line for obtaining the degree of correlation is equal to or smaller than dMax (Step S214). Here, dMax is a numeral that depends on dir. Specifically, in
At Step S215, the correction amount calculating unit 441 calculates an average value Δdir of the average values Δdir(d) of the differences calculated for each of the lines (1, 2, . . . , dMax) (Δdir is an average value of Δdir(1), . . . , Δdir(dMax)).
Subsequently, the correction amount calculating unit 441 increments the variable dir indicating the direction for calculating the degree of correlation (dir=dir+1) (Step S216).
Thereafter, the correction amount calculating unit 441 determines whether the variable dir indicating the direction for calculating the degree of correlation is equal to or smaller than 4 (Step S217). If the correction amount calculating unit 441 determines that the variable dir indicating the direction for calculating the degree of correlation is equal to or smaller than 4 (Step S217: Yes), the image processing apparatus 40 returns to Step S202 described above. In contrast, if the correction amount calculating unit 441 determines that the variable dir indicating the direction for calculating the degree of correlation is not equal to or smaller than 4 (Step S217: No), the image processing apparatus 40 proceeds to Step S218 as described below.
At Step S218, the correction amount calculating unit 441 calculates flatness. Specifically, the correction amount calculating unit 441 calculates a difference between the maximum and the minimum of the above-described Δ1 to Δ4 as the flatness, and calculates the direction dir corresponding to Δdir that is the minimum among Δ1 to Δ4 as a flat direction dir. After Step S218, the image processing apparatus 40 returns to the R-component estimated value calculation process in
According to the second embodiment as described above, if the pixel values of the neighboring pixels are flat, the correction amount calculating unit 441 calculates an estimated value of the color component to be corrected in the pixel of interest by using the pixel values of the neighboring pixels present on the periphery of the pixel of interest (x, y) or calculates an estimated value of the color component to be corrected in the pixel of interest by using the pixel values of the neighboring pixels present on the periphery of the pixel of interest (x, y) and by using a correction coefficient. In contrast, if the pixel values of the neighboring pixels are not flat, the correction amount calculating unit 441 changes a pixel range to be referred to in accordance with an edge direction of the neighboring pixels, and calculates an estimated value of the color component to be corrected in the pixel of interest (x, y) by using the pixel values of the neighboring pixels of the pixel of interest or calculates an estimated value of the color component to be corrected in the pixel of interest (x, y) by using the pixel values of the neighboring pixels of the pixel of interest and by using the correction coefficient. That is, according to the second embodiment, the correction amount calculating unit 441 calculates the estimated value using pixels that are highly correlated with the pixel value of the pixel of interest (x, y). Therefore, even when an edge is present near the pixel of interest (x, y), it is possible to prevent erroneous calculation of the estimated value due to the influence of the edge. Consequently, it is possible to calculate the estimated value with high accuracy.
Next, a third embodiment will be described. An imaging system according to the third embodiment has the same configuration as the imaging system 1 according to the first embodiment described above, but an image processing apparatus performs a different estimated value calculation process. Specifically, in the third embodiment, the correction amount calculating unit changes the method of calculating the estimated value (a reference range for calculating an estimated value) depending on a size of random noise (a size of the standard deviation of neighboring pixels) as a predetermined condition. The same components as those of the imaging system 1 according to the first embodiment described above are denoted by the same reference signs, and explanation thereof will be omitted. Further, in the following explanation, processes on the R component will be described, and the same processes are also performed on the G component and the B component; therefore, explanation of the processes on the G component and the B component will be omitted.
R-Component Estimated Value Calculation Process
As illustrated in
At Step S302, the correction amount calculating unit 441 calculates an average value of R pixels among N1×M1 pixels as an estimated value of an R component. The correction amount calculating unit 441 may calculate a different statistical value other than the average value as the estimated value. For example, the correction amount calculating unit 441 may calculate, as the estimated value, any of statistical values, such as a weighted average value, a median value, and an absolute value, except for a correction coefficient with the statistical values having predetermined values or larger. After Step S302, the image processing apparatus 40 returns to the R-component correction amount calculation process in
At Step S303, the correction amount calculating unit 441 calculates an average value of R pixels among N2×M2 pixels as an estimated value of an R component. The correction amount calculating unit 441 sets the ranges of N1×M1 and N2×M2 such that the total number of pixels of N2×M2 becomes larger than the total number of pixels of N1×M1 used at Step S302 described above ((total number of N1×M1 pixels)<(total number of N2×M2 pixels)). Further, the correction amount calculating unit 441 may calculate a different statistical value other than the average value as the estimated value. For example, the correction amount calculating unit 441 may calculate, as the estimated value, any of statistical values, such as a weighted average value, a median value, and an absolute value, except for a correction coefficient with the statistical values having predetermined values or larger. After Step S303, the image processing apparatus 40 returns to the R-component correction amount calculation process in
According to the third embodiment as described above, the correction amount calculating unit 441 changes the reference range for calculating the estimated value depending on the size of the standard deviation (random noise) of the neighboring pixels of the pixel of interest (x, y), and, if the variation is large, the reference range is increased and an average value is employed; therefore, it is possible to reduce the influence of variation to the estimated value. Consequently, it is possible to calculate the estimated value with high accuracy.
In the embodiment, the correction amount calculating unit 441 changes the reference range for calculating the estimated value depending on the size of the standard deviation (random noise) of the neighboring pixels of the pixel of interest (x, y), but it may be possible to change a shape of the reference range for calculating the estimated value depending on the size of the standard deviation of the neighboring pixels of the pixel of interest (x, y), for example.
Next, a modification of the third embodiment will be described. In the modification of the third embodiment, an imaging system has the same configuration as the imaging system 1 of the third embodiment described above, but an image processing apparatus performs a different estimated value calculation process. Specifically, in the modification of the third embodiment, a weight coefficient is calculated based on the standard deviation, and an estimated value is calculated using the weight coefficient. In the following, the estimated value calculation process performed by the image processing apparatus according to the modification of the third embodiment will be described. The same components as those of the imaging system 1 according to the third embodiment described above are denoted by the same reference signs, and explanation thereof will be omitted. Further, in the following description, processes on the R component will be described, and the same processes are also performed on the G component and the B component; therefore, explanation of the processes on the G component and the B component will be omitted.
R-Component Estimated Value Calculation Process
As illustrated in
As illustrated in
Referring back to
At Step S402, the correction amount calculating unit 441 calculates an estimated value Est1 of an R component from R pixels among N1×M1 pixels. Specifically, an average value of the R pixels in the range of the N1×M1 pixels is calculated as the estimated value of the R component. The correction amount calculating unit 441 may calculate a different statistical value other than the average value as the estimated value. For example, the correction amount calculating unit 441 may calculate, as the estimated value, any of statistical values, such as a weighted average value, a median value, and an absolute value, except for a correction coefficient with the statistical values having predetermined values or larger.
Subsequently, the correction amount calculating unit 441 calculates the average value of the R pixels among the N2×M2 pixels as an estimated value Est2 of the R component (Step S403). The correction amount calculating unit 441 sets the ranges of N1×M1 and N2×M2 such that the total number of pixels of N2×M2 becomes larger than the total number of pixels of N1×M1 used at Step S402 described above ((total number of N1×M1 pixels)<(total number of N2×M2 pixels)). Further, the correction amount calculating unit 441 may calculate a different statistical value other than the average value as the estimated value. For example, the correction amount calculating unit 441 may calculate, as the estimated value, any of statistical values, such as a weighted average value, a median value, and an absolute value, except for a correction coefficient with the statistical values having predetermined values or larger.
Thereafter, the correction amount calculating unit 441 calculates an estimated value Est from the weight coefficient W calculated at Step S401 and the estimated value Est1 and the estimated value Est2 calculated at Step S402 and Step S403 (Step S404). Specifically, the correction amount calculating unit 441 calculates the estimated value Est based on Equation (7) below.
Est=Est2×W+Est1×(1−W) (7)
After Step S404, the image processing apparatus 40 returns to the R-component correction amount calculation process in
According to the modification of the third embodiment as described above, the estimated value is calculated using the weight coefficient that is based on the standard deviation of the pixel values of the neighboring pixels of the pixel of interest (x, y). Therefore, when variation of the pixel values of the neighboring pixels is large, it is possible to reduce the influence of the variation to the estimated value by increasing the weight coefficient and employing an average value. Consequently, it is possible to calculate the estimated value with high accuracy.
In the embodiment, the correction amount calculating unit 441 calculates the estimated value Est using the weight coefficient W, the estimated value Est1, and the estimated value Est2. However, it may be possible to set a coefficient for each of the pixels in the range of N2×M2 pixels and calculate an average value (that is, a weighted average) by multiplying each of the pixel values by the corresponding coefficient. In this case, it is sufficient that a coefficient set for a pixel present on the periphery of the pixel of interest (x, y) is constantly maintained high, and a coefficient for a pixel present distant from the pixel of interest (x, y) is set so as to increase in accordance with the standard deviation as illustrated in
Next, a fourth embodiment will be described. An imaging system according to the fourth embodiment employs a different kind of color filter from the color filter employed in the imaging apparatus 10 of the imaging system 1 according to the first embodiment described above, and an image processing apparatus performs a different correction amount calculation process. Specifically, in the fourth embodiment, a calculation method for calculating a correction amount is changed depending on arrangement (type) of the color filter. The same components as those of the imaging system 1 according to the first embodiment described above are denoted by the same reference signs, and explanation thereof will be omitted.
Correction Amount Calculation Process
At Step S503, the correction amount calculating unit 441 determines whether an image corresponding to image data stored in the second buffer unit 422 of the second recording unit 42 is generated using the color filter 106 with arrangement A (RGB). For example, the correction amount calculating unit 441 determines whether the image is generated using the color filter 106 with the arrangement A (RGB) based on header information included in the image data stored in the second buffer unit 422 of the second recording unit 42. If the correction amount calculating unit 441 determines that the image corresponding to image data stored in the second buffer unit 422 of the second recording unit 42 is generated using the color filter 106 with the arrangement A (RGB) (Step S503: Yes), the image processing apparatus 40 proceeds to Step S504 to be described later. In contrast, if the correction amount calculating unit 441 determines that the image corresponding to image data stored in the second buffer unit 422 of the second recording unit 42 is not generated using the color filter 106 with the arrangement A (RGB) (Step S503: No), the image processing apparatus 40 proceeds to Step S512 to be described later.
Step S504 to Step S511 respectively correspond to Step S13 to Step S20 in
At Step S512, the correction amount calculating unit 441 determines whether an image corresponding to image data stored in the second buffer unit 422 of the second recording unit 42 is generated using the color filter 106 with arrangement B (RGBMg).
Step S513 to Step S515 respectively correspond to Step S13 to Step S15 in
At Step S516, the correction amount calculating unit 441 performs an Mg-component correction amount calculation process for calculating a correction amount of the Mg component in the pixel value of the pixel of interest (x, y). In the fourth embodiment, it is possible to calculate the correction amount of the Mg component by the Mg-component correction amount calculation process at Step S516 by performing the same process as described above by replacing the R component with the Mg component; therefore, explanation of the Mg-component correction amount calculation process will be omitted. Further, Step S517 corresponds to Step S16 in
Step S518 to Step S520 respectively correspond to Step S13 to Step S15 in
At Step S521, the correction amount calculating unit 441 performs a W-component correction amount calculation process for calculating a correction amount of the W component in the pixel value of the pixel of interest (x, y). In the fourth embodiment, it is possible to calculate the correction amount of the W component by the W-component correction amount calculation process at Step S521 by performing the same process as described above by replacing the R component with the W component; therefore, explanation of the W-component correction amount calculation process will be omitted. Further, Step S522 corresponds to Step S16 in
According to the fourth embodiment, even when the imaging element is changed to the imaging element 105 having a color filter with different arrangement, it is possible to correct variation in the spectral sensitivity.
While the color filter 106 according to the first to fourth embodiments is a color filter with Bayer arrangement including the R filters, the G filters, and the B filters, the present disclosure is applicable to other color filters. As illustrated in
Moreover, in the embodiments, a plurality of color filters having different spectral transmittances are provided on a single imaging element. However, the present disclosure may be applied to, for example, an imaging apparatus of a two-chip system that uses an imaging element, in which only the G filter for transmitting a wavelength range of green is arranged on the light receiving surface of each of the pixels or arranged on the whole surface of the imaging element, and an imaging element, in which the R filter for transmitting a wavelength range of red and the B filter for transmitting a wavelength range of blue are arranged on the light receiving surfaces of the pixels in a checkered pattern. Alternatively, the present disclosure may be applied to an imaging apparatus of a three-chip system that uses imaging elements, in each of which only the R filter, the G filter, or the B filter is arranged. In this case, when calculating a correction coefficient of a G pixel in one of the imaging elements, it is possible to calculate a correction amount by using a pixel value of an R pixel or a B pixel, which corresponds to the coordinates of the G pixel, in the other one of the imaging elements.
Furthermore, in the embodiments, the correction amount calculating unit changes the method of calculating the estimated value or the method of calculating the correction amount by switching between a plurality of methods depending on various conditions. However, it may be possible to calculate the estimated value or the correction amount by synthesizing calculation results obtained through a plurality of methods depending on various conditions, instead of switching. It is of course possible for the correction amount calculating unit to change a synthesis ratio for synthesizing the calculation results depending on various conditions (for example, the conditions in the first to fourth embodiments described above), and calculate the estimated value or the correction amount by synthesizing the calculation results in accordance with the synthesis ratio.
The present disclosure is not limited to the embodiments as described above, and various modifications and applications may be made without departing from the scope. For example, the image processing apparatus may be provided, as an image processing engine, in any of the following apparatuses capable of imaging a subject: a mobile apparatus, such as a mobile phone or a smartphone, that includes an imaging element; and an imaging apparatus, such as a video camera, an endoscope, a security camera, or a microscope, that images a subject through an optical device, instead of the imaging system used in the description.
In the description of the flowchart of the operation in this specification, the operation has been described using “first”, “thereafter”, and “subsequently”, for the sake of convenience, but this does not mean that the operation needs to be performed in this order.
Further, the method of each of the processes performed by the image processing apparatus according to the embodiments described above, that is, the process illustrated in each of the flowcharts, may be stored as a program that is executable by a control unit, such as a CPU. In addition, the program may be stored in a storage medium of an external storage device, such as a memory card (a ROM card, a RAM card, or the like), a magnetic disk (a flexible disk, a hard disk, or the like), an optical disk (a CD-ROM, a DVD, or the like), or a semiconductor memory. The control unit, such as a CPU, reads the program stored in the storage medium of the external storage device, and controls the operation by the read program, so that the above-described processes can be executed.
Furthermore, the present disclosure is not limited to the above-described embodiments and modifications as they are. In the implementation stage, the present disclosure may be embodied with various modifications of the constituent elements within the scope not departing from the gist of the disclosure. In addition, variations may be made by appropriately combining a plurality of constituent elements disclosed in the above embodiments. For example, some constituent elements may be deleted from all of the constituent elements described in the embodiments and the modifications described above. Furthermore, the constituent elements described in the embodiments may be appropriately combined.
Moreover, in the specification or the drawings, a term that is at least once described together with a different term having a broader meaning or the same meaning may be replaced with the different term at any point in the specification or the drawings. Thus, various modifications and applications may be made without departing from the scope of the disclosure.
According to the present disclosure, it is possible to correct variation in spectral sensitivity in accordance with conditions of neighboring pixels.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the disclosure in its broader aspects is not limited to the specific details and representative embodiments shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.
This application is a continuation of International Application No. PCT/JP2016/050572, filed on Jan. 8, 2016, the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2016/050572 | Jan 2016 | US |
Child | 16026284 | US |