This application is based on and claims priority under 35 U.S.C. § 119 to Russian Patent Application No. 2017115447, filed on May 3, 2017, in the Russian Patent and Trademark Office, and Korean Patent Application No. 10-2018-0042920, filed on Apr. 12, 2018, in the Korean Intellectual Property Office, the disclosures of which are incorporated by reference herein in their entirety.
The disclosure relates to a method of processing an image, an apparatus for processing an image, and a non-transitory computer-readable recording medium having embodied thereon a program for executing the method of processing the image.
As user's interest in high-resolution images has increased, various techniques for high-resolution images having high image quality have been developed. Related arts for increasing the quality of an image may be classified into image processing through an iterative approach and image processing through a non-iterative approach. The iterative approach of the related arts requires high calculation complexity, which causes a large calculation cost and a low processing speed. The non-iterative approach of the related arts requires relatively low calculation complexity. However, the non-iterative approach does not take into account fractional pixel movement, and thus, the quality of an obtained image is deteriorated. Accordingly, an image processing technique configured to improve these problems of the related arts needs to be developed.
Provided are a method and an apparatus for processing an image, whereby the loss of image data is minimized and the quality of an image is improved.
Additional aspects will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the presented embodiments.
In accordance with an aspect of the disclosure, a method of processing an image includes: obtaining a pixel shift set indicating information of movement of a plurality of pixels included in coinciding portions among a plurality of low-resolution images with respect to a single scene; dividing the pixel shift set into an integer portion and a fractional portion and generating an integer pixel shift set and a fractional pixel shift set; selecting a filter set corresponding to the plurality of pixels from among a plurality of pre-stored filter sets including a filter weight value applied to the pixels, based on the fractional pixel shift set; and obtaining a high-resolution image with respect to the single scene, based on the plurality of low-resolution images, the selected filter set, and the integer pixel shift set.
The generating of the fractional pixel shift set may include selecting fractional shift values corresponding to a value within a pre-set range, from among fractional shift values of the plurality of pixels and generating the fractional pixel shift set by combining the selected fractional shift values.
The selecting of the filter set may include selecting the filter set corresponding to the plurality of pixels from among the plurality of pre-stored filter sets, based on the fractional filter shift set and a pre-set regularizer.
A number of the plurality of pre-stored filter sets may be determined based on at least one pixel shift coincidence property of the plurality of pixels included in the coinciding portions among the plurality of low-resolution images.
The plurality of pre-stored filter sets may include a non-directional filter set and a directional filter set, and the selecting of the filter set may include selecting the filter set based on the fractional pixel shift set and whether or not a texture of the coinciding portions among the plurality of low-resolution images has directionality.
The method may further include: determining a noise-reduction parameter with respect to the pixels of the plurality of low-resolution images, wherein the noise-reduction parameter includes a noise model, a size of the coinciding portions, a search radius with respect to adjacent image portions, and a relationship between a pixel brightness and a pixel noise standard deviation; obtaining a texture-dependent noise-reduction coefficient based on a change in brightness of the pixels of the plurality of low-resolution images; determining an estimated value of the pixel noise standard deviation, by using the relationship between the pixel brightness and the pixel noise standard deviation, the texture-dependent noise-reduction coefficient, and a noise-reduction coefficient pre-set by a user; and obtaining a plurality of noise-reduced low-resolution images by performing a three-dimensional noise-reduction operation on the plurality of low-resolution images, based on the noise-reduction parameter and the estimated value of the pixel noise standard deviation, wherein the pixel shift set is obtained from the plurality of noise-reduced low-resolution images.
The method may further include: generating a fallback map indicating a fidelity of pixel shift values included in the pixel shift set, based on the pixel shift set; and determining a texture direction of the plurality of noise-reduced low-resolution images, wherein the selecting of the filter set includes selecting the filter set corresponding to the plurality of pixels from among the plurality of pre-stored filter sets, based on the fallback map, the fractional pixel shift set, and the texture direction.
The plurality of low-resolution images with respect to the single scene may include RGB images.
The plurality of low-resolution images with respect to the single scene may include Bayer images.
The method may further include: converting the high-resolution image having a format of an RGB image into a YUV image; obtaining a pixel standard deviation map with respect to channel Y, with respect to the YUV image; performing cross bilinear filtering on channel U and channel V, based on a reference channel obtained by performing smoothing on the pixel standard deviation map; and obtaining the high-resolution image post-processed by converting the YUV image, to which the cross bilinear filtering is applied, into the format of the RGB image.
In accordance with another aspect of the disclosure, an apparatus for processing an image may include: at least one processor; and a memory storing one or more instructions that, when executed by the at least one processor, cause the apparatus to: obtain a pixel shift set indicating information of movement of a plurality of pixels included in coinciding portions among a plurality of low-resolution images with respect to a single scene; divide the pixel shift set into an integer portion and a fractional portion and generate an integer pixel shift set and a fractional pixel shift set; select a filter set corresponding to the plurality of pixels from among a plurality of pre-stored filter sets including a filter weight value applied to the pixels, based on the fractional pixel shift set; and obtain a high-resolution image with respect to the single scene, based on the plurality of low-resolution images, the selected filter set, and the integer pixel shift set.
In accordance with another aspect of the disclosure, a method of processing an image includes obtaining a pixel shift set indicating information of movement of a plurality of pixels included in coinciding portions among a plurality of low-resolution images with respect to a single scene; dividing the pixel shift set into an integer portion and a fractional portion; generating an integer pixel shift set and a fractional pixel shift set; selecting a filter set corresponding to the plurality of pixels from among a plurality of pre-stored filter sets including a filter weight value applied to the pixels; and obtaining a high-resolution image with respect to the single scene, based on the plurality of low-resolution images, the selected filter set, and the integer pixel shift set.
In accordance with yet another aspect of the disclosure, an apparatus for processing an image includes at least one processor; and a memory storing one or more instructions that, when executed by the at least one processor, cause the apparatus to: obtain a pixel shift set indicating information of movement of a plurality of pixels included in coinciding portions among a plurality of low-resolution images with respect to a single scene; divide the pixel shift set into an integer portion and a fractional portion; generate an integer pixel shift set and a fractional pixel shift set; select a filter set corresponding to the plurality of pixels from among a plurality of pre-stored filter sets including a filter weight value applied to the pixels; and obtain a high-resolution image with respect to the single scene, based on the plurality of low-resolution images, the selected filter set, and the integer pixel shift set.
The above and other aspects, features, and advantages of certain embodiments of the disclosure will be more apparent from the following description taken in conjunction with the accompanying drawings, in which:
Hereinafter, embodiments will be described in detail by referring to the accompanying drawings, so that one of ordinary skill in the art may easily execute the embodiments. However, the disclosure may be embodied in different forms and should not be construed as limited to the embodiments set forth herein. In the drawings, portions not related to the descriptions are omitted to clearly describe the disclosure, and like reference numerals refer to like elements throughout the specification. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items. Expressions such as “at least one of,” when preceding a list of elements, modify the entire list of elements and do not modify the individual elements of the list.
The embodiments described in the disclosure and the accompanying drawings are presented to describe the disclosure, as examples of various embodiments, and the disclosure is not limited to the described embodiments and the accompanying drawings.
The terms used in the specification may be understood to describe various components. However, the components are not limited by the terms. The terms are only used to distinguish one component from another component.
It will be understood that although the terms “first,” “second,” etc. may be used herein to describe components of the specification, these components should not be limited by these terms. The terms are only used to distinguish one component from another.
Also, the term “comprise,” “include,” or the like used in this specification does not exclude addition of a characteristic, a value, an operation, a component, and a group thereof.
The accompanying drawings may be schematically illustrated to describe an embodiment. Several sizes may be exaggerated for clear representations. Similarly, a great portion of the drawings may be represented arbitrarily.
The term “unit,” or “module,” used in this specification should be interpreted to include software, hardware or a combination thereof according to context in which the term is used. For example, software may include a machine language, firmware, an embedded code, and application software. As another example, hardware may include a circuit, a processor, a computer, an integrated circuit, an integrated circuit core, a sensor, a micro-electro-mechanical system (MEMS), a manual device, or a combination thereof.
Assuming that an original high-resolution image X is known, low-resolution images Y1, Y2, . . . YN may be derived by performing conversion and continuous down-sampling on an input image. Here, the conversion may include projective transformation or affine transformation. However, this is only an example. The conversion may include other continuous coordinate transformations. The conversion may be caused by motion of a camera between moments of capturing low-resolution input images. Also, the conversion may partially be caused by movement of objects in a frame. When capturing a low-resolution image via an actual optical system, smoothing of the optical system may be performed based on a point spread function (PSF), when the conversion and the down-sampling are applied to an ideal high-resolution image. The low-resolution images may be obtained from the high-resolution image based on Equation 1 as follows.
Y
k
=DGM
k
X+v [Equation 1]
In Equation 1, D is a down-sampling operator, G is a smoothing operator, Mk is a conversion operator for obtaining a kth image, and v is noise. The operator G may be experimentally or theoretically estimated based on a detailed description of the optical system, or may be approximately calculated based on a quality reference for a result image.
The conversion operator Mk may be derived by using a shift estimation method. In this case, a vectorized low-resolution image is assumed as X and Y1. When a two-dimensional original image is represented as a matrix
the vectorized image may be represented as X=|x11 x21 x31 x41 x12 x22 x32 x42 x13 x23 x33 x43 x14 x24 x34 x44|T.
The down-sampling matrix D, which is obtained by compressing an n×n sized image by k times in a height direction and m times in a width direction, may have the form of
wherein ⊗ is a Kronecker product, In is a unit matrix of an n×n sized matrix, and em,n is an mth column of a matrix In*. Thus, in order to decrease the matrix by two times and obtain a matrix
a vectorized original matrix X has to be multiplied by a matrix
and a vector of a length 4 has to be converted to a 2×2 sized matrix.
Thus, with respect to an m×n sized high-resolution image and an
sized low-resolution image, the matrices G and Mk may have an mn×mn size and the matrix D may have an
size. Also, in order not to lose the generality, the high-resolution image may be limited to a square image having an n×n size.
With respect to a low-resolution image formation model, an operation of obtaining a high-resolution image may be defined as minimizing a function according to Equation 2 below.
The operation may be defined based on other principles. However, one of the easiest methods of obtaining the value is a square law, which is to be used hereinafter.
According to an embodiment, the smoothing operator G may be the same as the embodiment described above (that is, smoothing is not performed), and the conversion operator may be a circulation shift based on a pixel yk in a height direction and a pixel xk in a width direction. Here, the matrix of this operator may be formed as M(xk,yk)=(In ⊗ Pny
In order to shift the matrix
the conversion may be performed by one pixel in the height direction and two pixels in the width direction, thereby obtaining a matrix
The converted matrix may be obtained as follows.
According to the embodiment, it is assumed that four low-resolution images Y0,Y1,Y2,Y3 are obtained from a high-resolution image by using a shift x0=0, y0=0; x1=1; x2=1, y2=0; x3=1, y3=1 and two down-sampling operations. The original image may be simply “combined” from pixels of the low-resolution images.
When a movement of some images is repeated, the whole reconstruction may be impossible. When the whole reconstruction is impossible or the operation is defective, additional constraints may be added to obtain a high-resolution image. According to the disclosure, the additional constraints may be applied by using a regularizing term R (also, referred to as a “regularizer”). The additional constraints, which may be defined as the reguralizing term R, may be applied to Equation 2 above, and Equation 3 below may be derived.
A method of processing an image according to an embodiment may obtain a high-resolution image from a low-resolution image set with respect to a single scene, without using an iterative method. Here, a regularizer Tikhonov may be used. For example, the regularization operation may be performed based on a regularizer R(X)=λ∥HX∥2. Here, λ is a scalar regularization parameter and H is an operator. In this case, an optimized function may be composed based on the following equation.
f=∥WX−Ŷ∥
2
+λ∥HX∥
2 [Equation 4]
In Equation 4 above,
The optimization of this type may have an analysis value represented by Equation 5.
X=A·Ŷ, A=(WTW+λ2·HTH)−1·WT. [Equation 5]
Through the analysis value of Equation 5, it may be identified that each pixel of the high-resolution image having a coordinate i,j may be derived by a linear combination of pixels of an input low-resolution image based on Equation 6.
In Equation 6, ylmk is a pixel having a coordinate l,m in a kth input low-resolution image, and s is an integer (indicating by how many times a size of a high-resolution image is different from a size of a low-resolution image) corresponding to a down-sampling coefficient. A value wi,j,l,mk of a weight coefficient may be derived from an element having a coordinate
in a matrix A. That is, the value wi,j,l,mk of the weight coefficient may be represented as Equation 7.
In Equation 7, the parentheses indicate sampling of the corresponding element in the matrix.
It may be inefficient to store solutions of all probable problems with respect to all possible shifts. In particular, it is problematic since a storage space is needed for a method not currently used. Accordingly, a method according to an embodiment may assign two constraints to provide a solution. First, according to the disclosure, only the conversion operator Mk corresponding to the same shift of all pixels of the high-resolution image will be considered. Second, according to the disclosure, only an operator H indicating a convolution having a non-zero core h, with respect to which a sum of elements is 0, will be considered. Here, for example,
Based on the first constraint, a solution parameter wlmk(M0,M1, . . . Mk) may be specified with respect to k shift pairs in height and width directions, rather than with respect to k matrices having an n×n size. The solution parameter wlmk(M0,M1, . . . Mk) may be represented based on Equation 8 as follows.
w
lm
k(M0,M1, . . . Mk)=wlmk(u0,u1, . . . uk,v0,v1, . . . vk) [Equation 8]
The reconstruction of the high-resolution image may be performed based on a matrix A(u0,u1, . . . uk,v0,v1, . . . vk) pre-calculated and stored with respect to all possible combinations of the shift u0,u1, . . . uk,v0,v1, . . . vk.
According to the disclosure, a very precise approximate value A may be provided by storing only several elements from the matrix A(u0,u1, . . . uk,v0,v1, . . . vk). That is, by storing a result with respect to only a set ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k, such as
the approximate value A which is very precise may be obtained. In addition, via this, it may be identified that an initial assumption that a shift related between pixels of the low-resolution image is equal, with respect to all pixels of the low-resolution image, may not be necessary.
According to the disclosure, the high-resolution image may be obtained from a set of the low-resolution images by assuming that only an adjacent pixel having an approximate size ε×ε in the low-resolution image has the same shift with respect to a corresponding pixel of another low-resolution image.
Hereinafter, embodiments of the disclosure will be described in more detail by referring to the accompanying drawings.
Referring to
The shift estimator 101 may receive a low-resolution image set 10 including a plurality of low-resolution images with respect to a single scene. The shift estimator 101 may obtain a pixel shift set with respect to all pixels of the low-resolution image set 10. The pixel shift set may include information about movement of pixels included in coinciding portions among the plurality of low-resolution images.
The shift estimator 101 according to an embodiment may assume a shift value with respect to pixels included in a first low-resolution image as 0, and may determine a shift value with respect to pixels included in other low-resolution images based on the first low-resolution image. When the low-resolution image set 10 of a single scene includes RGB images, the following operation may be performed on each s×s pixel of an output image having a coordinate i=i0..i0+s,j=j0..j0+s: (s indicates a down-sampling coefficient.)
calculate a coordinate
of each pixel of the first low-resolution image
calculate a shift û1, . . . ûk,{circumflex over (v)}1, . . . {circumflex over (v)}k with respect to a pixel of the first low-resolution image, the pixel having a coordinate î,ĵ, with respect to pixels of other low-resolution images corresponding to portions of the first low-resolution image
Thereafter, the shift estimator 101 may obtain an integer pixel shift set by calculating an integer pixel shift with respect to each pixel shift. The integer pixel shift set may correspond to the pixel shift set with respect to the low-resolution image.
Also, the shift estimator 101 may obtain a fractional pixel shift set by calculating a fractional pixel shift with respect to each pixel shift. According to an embodiment, values included in the fractional pixel shift may be between 0 and 1. Here, the fractional pixel shift set may correspond to the pixel shift set with respect to the low-resolution image. For example, when a shift value of a pixel is 7.3, an integer shift value may be 7, and a fractional shift value may be 0.3. As another example, when the shift value of the pixel is −4.5, the integer shift value may be −5 and the fractional shift value may be 0.5.
An integer shift ûtintegert=[ût], {circumflex over (v)}integert=[{circumflex over (v)}t] may be calculated and a fractional shift ûfranctionalt=ût−ûintegert,{circumflex over (v)}fractionalt={circumflex over (v)}t−{circumflex over (v)}integert may be calculated with respect to each pixel shift of the low-resolution images û1, . . . ûk,{circumflex over (v)}1, . . . {circumflex over (v)}k, wherein a square bracket may indicate an operation to induce an integer portion.
The filter bank 103 may store a pre-calculated filter set. The filter set may be a set of values obtained from the matrix A uniquely reconstructed with respect to a shift set u0,u1, . . . uk,v0,v1, . . . vk. Based on the first constraint and the second constraint described above, ε×ε pixels of an input image may be used to reconstruct each pixel of an output image. The filter bank 103 may include a combination of calculated filter sets with respect to every possible combination ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k, such as
wherein k indicates the number of low-resolution images that are used.
The filter selector 102 may select a filter set from the filter bank 103 based on the fractional pixel shift set. The filter set FΔi,Δj0,FΔiΔj1, . . . FΔi,Δjk corresponding to each fractional shift ûfractionalt,{circumflex over (v)}fractionalt of the low-resolution image may be selected, and each filter FΔi,Δjt may include a ε×ε value (a filter weight coefficient). The filter FΔi,Δjt may be represented as Equation 9 as follows:
In Equation 9, wt,Δi,Δjl,m is the filter weight coefficient.
The high-resolution image obtainer 104 may obtain an RGB high-resolution image 20 by calculating pixels of a high-resolution image, based on the set of low-resolution images, the set of selected filters, and the set of integer pixel shifts. The operation of obtaining the RGB high-resolution image 20 may be performed as follows.
First, a set P0, . . . Pk of pixels may be selected as represented in Equation 10, based on the low-resolution images.
In Equation 10, Plmt indicates a pixel having a coordinate î+ûintegert+l,j+{circumflex over (v)}integert+m in an input image t. Then, each pixel having a coordinate i+i0+Δi,j=j0+Δj,Δi=0..s. Δj=0..s in an output image block may be calculated as a sum of scalar multiplification of Pt and FΔi,Δjt with respect to t=0..k, as represented in Equation 11.
The image processing apparatus 100 according to an embodiment may not use an iterative method, and may determine the value of the pixels included in a high-resolution image by using the method described above, thereby obtaining the high-resolution image in real time.
According to another embodiment, when a high-resolution image is obtained from a plurality of low-resolution Bayer images with respect to a single scene, operations of the image processing apparatus 100 may be different in the following aspects from the operations of the image processing apparatus 100 obtaining the high-resolution image from the RGB format low-resolution.
The processing of a set of the plurality of low-resolution Bayer images may be different from the processing of the RGB low-resolution image, in that the processing of the set of the plurality of low-resolution Bayer images is performed with respect to a group of 2s×2s×3 pixels, rather than s×s pixels, wherein s is a down-sampling coefficient. Here, 3 indicates the number of output color channels.
Calculation of the fractional pixel shift with respect to the low-resolution Bayer images may be different from calculation of the fractional pixel shift with respect to the RGB image. In the case of the Bayer images, the calculation of the fractional pixel shift may be performed based on the Lucas-Kanade optical flow method.
The Lucas-Kanade optical flow method is as follows.
First, the image processing apparatus 100 may calculate time ∇t and gradients ∇x and ∇y in a height direction and a width direction in order to obtain a shift (y(i, j),u(i, j)) between points having a coordinate (i, j) with respect to an image I1 and an image I0, based on Equation 12.
The shift may be obtained from the equation
The time ∇t may be dependent on u and v derived from an iterative process. A zero shift may be used as a zero approximate value.
When forming matrices A and b, in order to obtain a more precise result, the adjacent points (i, j) may be used, rather than a sum of individual gradient values in p. Thus, A and b may be obtained based on Equation 13.
In order to derive an appropriate result in an area having a low image quality, by using the method described above, regularization may be applied as represented in Equation 14.
As another improving method, smoothing based on a Gaussian window may be applied as represented in Equation 15.
The Lucas-Kanade method is designed to determine a shift of an amplitude of maximum one pixel, and thus, another method may be applied in order to estimate a shift corresponding to an amplitude of a plurality of pixels in an actual image. For example, a multi-scale method not using anisotropic filtering may be used. As another example, the image processing apparatus 100 may estimate a shift by using three levels including a ¼ resolution of a YCbCr format, a ½ resolution of a YCbCr format, and an entire image of a Bayer format.
When the image processing apparatus 100, according to an embodiment, forms the matrices A and b with respect to three channels, gradients with respect to all of the three channels may be added. In order to calculate the gradients of the Bayer image, Equation 16 may be used.
In Equation 16, the value I1(i+v, j+u) may be obtained by bilinear interpolation of the Bayer image using a pixel I1(└i+v┘,└j+u┘),I1(└i+v+2,└j+u┘)I1(└i+v┘,└j+u┘+2)I1(└i+v┘+2└j+u┘+2) having the same color, with respect to a blue color and a red color. Here, |·| indicates a rounding down operator. With respect to green pixels, the bilinear interpolation may be applied to pixels I1(]i+v[−1,]j+u[),I1(]i+v[+1,]j+u[(,I1(]i+v[,]j+u]−1)I1(]i+v[+2,]j+u[+1). Here, ]·[ indicates a rounding to the nearest integer operator.
An operation of selecting a set of filters for the Bayer image may be different from an operation of selecting a set of filters for the RGB image. In the case the Bayer image, the filter selector 102 may select a set F0,ChΔi,Δj,F1,ChΔi,Δj, . . . Fk,ChΔi,Δj of filters stored in the filter bank 103. Here, Ch is the number of colors corresponding to a set ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k of shifts, and each filter Ft,ChΔi,Δj may include ε×ε values (a filter weight coefficient) as represented in Equation 17.
In Equation 17, wt,Δi,Δll,m is the filter weight coefficient.
The pixel calculation of the high-resolution image using the set of low-resolution Bayer images may be different from the pixel calculation of the high-resolution image using the set of RGB low-resolution images described above, in that according to the pixel calculation of the high-resolution image using the set of low-resolution Bayer images, each pixel of an output image block having a coordinate i=i0+Δi,j=j0+Δj,Δi=0..2s,Δj=0..2s with respect to each of the color channels Ch=1..3 is calculated as a sum of scalar multiplication of Pt and FΔi,Δjt,Ch with respect to t=0..k, as represented in Equation 18.
Prior filter calculation with respect to the filter bank 103 may be performed by a high performance computer according to the following procedure:
wherein c is an involution of 2, set a limited number of shift sets in order to obtain the high-resolution image from a random shift set. Here, ũ0={tilde over (v)}0=0, and remaining shifts may have one of c values,
This group of the shift sets may be set as a basic set.
and a matrix A=(WTW+λ2·HTH)−1
select elements corresponding to elements of filters, from the matrix; select a set FΔi,Δjt(ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k) of filters with respect to t=0..k,Δi=0..s,Δj=0..s based on the following operation
select a middle pixel having coordinates i0,j0 from the n×n sized image, wherein i0 and j0 correspond to multiples of the down-sampling coefficient s
with respect to Δi=0..s,Δj=0..s, select a row i0+Δi−1)·n+j0+Δj from the matrix A and determine the selected row as zΔi,Δj
define k continuous sub rows zt,Δi,Δj each having a length
from each row zΔi,Δj
convert each sub-ordinate row zt,Δi,Δj into a matrix z{circumflex over (z)}t,Δi,Δj so that a vector element having the number m becomes a matrix element having an index
wherein └·┘ indicates the rounding down operator
select a ε×ε coefficient wt,Δi,Δjl,m of the filter FΔi,Δjt such as
from each matrix {circumflex over (z)}t,Δi,Δj
The prior filter calculation of the filter bank 103 for the set of the low-resolution Bayer images may be different from the prior filter calculation of the filter bank 103 for the set of the RGB low-resolution images, in terms of the following operations:
when the previous method of determining the fractional pixel shift has a fidelity of
the basic set of shifts is analyzed and each shift has one of 2·c values available between −1 and
form the matrix
wherein DRGB is a down-sampling operator of the RGB image, GRGB is a smoothing operator of the RGB image, and MRGBk is a conversion operator for obtaining a kth RGB image. In this case, the operators of the RGB images may be obtained from corresponding operators of a one channel-image, based on Equation 19.
However, a down-sampling operator B of the Bayer image may be formed as represented in Equation 20.
In Equation 20, D2,2 is an operator performing two times down-sampling in both height and width directions, and Pu,v is an operator of a circulation shift corresponding to a column u in the width direction and a column v in the height direction.
form the matrix A=(WTW+λ2·(HRGB)t·HRGB)−1. The regularizer of a cross channel with respect to the RGB image may be formed based on Equation 21.
In Equation 21 above, Hc=γ·H, γ=3.
with respect to each of Δi=0..s,Δj=0..s, select three rows (i0+Δi−1)·n+j0+Δj, (i0+Δi−1)·n+j0+Δj+n2, and (i0+Δi−1)·n+j0+Δj+2n2 corresponding to three color channels of an output image, from the matrix A, and refer to the selected rows as ZΔi,ΔjCh, Ch=1..3
divide ZΔi,ΔjCh into k same continuous sub rows Zt,Δi,ΔjCh from each row
in order to convert a vector element of the number m into a matrix element having an index
divide each sub-ordinate row Zt,Δi,ΔjCh into four same continuous parts ZCh,g1t,Δi,Δj,ZCh,g2t,Δi,Δj,ZCh,rt,Δi,Δj.ZCh,bt,Δi,Δj and convert each part into matrices (matrices having an
size) {circumflex over (Z)}Ch,g1t,Δi,Δj,{circumflex over (Z)}Ch,g2t,Δi,Δj,{circumflex over (Z)}Ch,rt,Δi,Δj and {circumflex over (Z)}Ch,bt,Δi,Δj, wherein └·┘ indicates a rounding-down operator
select a weight coefficient wl,m,Cht,Δi,Δj of
filters Ft,ChΔi,Δj having a ε×ε size from the four matrices {circumflex over (Z)}Ch,g1t,Δi,Δj,{circumflex over (Z)}Ch,g2t,Δi,Δj,{circumflex over (Z)}Ch,rt,Δi,Δj{circumflex over (Z)}Ch,bt,Δi,Δj
In the case of a c shift quantization level, k input images and s times magnification, and k·s2 filter sets of c2(k−1) sets may be required. Based on a result of an experiment, it is identified that in order to obtain the high-resolution image from the RGB image, it is sufficient to use a filter having an 11×11 size.
Just as only the fractional pixel shift has a value for reconstruction of a minute detail in the high-resolution operation, a shift between pixels of input images has to be less for reliable reconstruction. For example, in the case of a camera of a cellular phone without a tripod, bust capturing may be realized from a less number of input images (equal to or less than 4). The reliable estimation fidelity of the fractional pixel shift is less than a
pixel. Table B01 shows numerical values calculated and stored with respect to a fidelity of shift estimation practically implementable, the number of input images, and a combination of magnification coefficients.
of pixel shift estimation
In order to obtain the high-resolution image from an input Bayer image with respect to the c shift quantization level, the k input images, and the s times magnification, (2c)2(k−1) sets of 3·k·(2s)2 filters may be needed. Here, factor 3 may occur when there are three color channels, that is, R (red), G (green), and B (blue), in the image. There is an experimental result showing that a filter of a 16×16 size or a 12×12 size having a slight loss of precision is sufficient to obtain the high-resolution image from the Bayer image. Table B02 represents numerical values calculated and stored in order to obtain the high-resolution image from the Bayer image with respect to a fidelity of pixel shift estimation practically implementable, the number of input images, and a combination of magnification factors.
of pixel shift estimation
It is identified in Table B02 that the stored numerical values are high. The image processing apparatus 100 may apply pixel shift coincidence properties disclosed as follows, in order to reduce the number of filters stored in the filter bank 103.
The pixel shift coincidence property (1): when two shift sets coincide with each other, up to a change in an order of input images, calculated filters may coincide with each other, up to the order of the input images.
The pixel shift coincidence property (2): when shifts of two sets of shifts u0,u1, . . . uk,v0,v1, . . . vk and ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k coincide with each other, up to a change ui={tilde over (v)}i, vi=ũi in a coordinate, calculated filters may coincide with each other, up to an order of a coordinate axis.
The pixel shift coincidence property (3): when shifts of two sets of shifts u0,u1, . . . uk,v0,v1, . . . vk and ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k coincide with each other, up to integer shifts Δxi and Δyi, ui=ûi+Δxi, vi={tilde over (v)}i+Δyi, and calculated filters may coincide with each other, and when the filters are applied, pixels of the low-resolution images taking into account the integer shifts Δxi and Δyi may be used.
The pixel shift coincidence property (4): when, in two sets of shifts u0,u1, . . . uk,v0,v1, . . . vk and ũ0,ũ1, . . . ũk,{tilde over (v)}0,{tilde over (v)}1, . . . {tilde over (v)}k, signs coincide ui=sx·ũi, vi=sy·{tilde over (v)}i), wherein sx=±1,sy=±1, calculated filters may coincide with respect to a mirror display with respect to a horizontal axis and a vertical axis.
The pixel shift coincidence property (5): when some shifts of two sets of shifts coincide with one another, for example, when ui=uj,vi=vj, a filter set corresponding to one of values of the coinciding shifts may be stored.
The following example shows how these principles are applied to filter bank compression in the RGB image of Table B01, when k=3, c=2, s=2. The number of filters of an original filter bank may be calculated as 22(3−1)·3·22=192. With respect to c=2, the following shift set may be taken into account (assuming u0=v0=0).
According to the property (3), values
may not be included in the shift set according to an analysis. Also, in 6th through 8th rows in the table, sets, which may be obtained from a current set based on the properties (1) and (2), are arranged. In this example, the property (4) is not applied. However, when the condition c=4, s=4 is taken into account, the analyzed number of shifts may be decreased from 256 to 34, when the property (4) is applied.
In the s times image magnification for obtaining each s×s sized output image block, a filter for obtaining each point may be parameterized by a fractional shift between an interpolated point and a point most adjacent to the low-resolution image. Each pixel of the block may be defined as a fractional shift in relation to an upper left corner of the block in a low-resolution coordinate. For example, with respect to s=2, a shift of pixels of a 2×2 block may correspond to Δx0=0,
Assuming that there is a set of shifts Ua=|u0 v0 u1 v1 . . . uk vk|, wherein a indicates the number of current sets from among all available shifts which may be renumbered, each filter of a corresponding set may be defined by a shift Ûam=|u0am v0am u1am v1am . . . ukam vkam|=Ua=|Δx0m Δy0m Δx1m Δy1m . . . Δxkm Δykm|. Here, m=1 . . . s2, and Δx and Δy are values available between 0 and
In this case, filters corresponding to shifts Ûam and Ûbn may satisfy properties substantially the same as the properties (1) through (5).
The pixel shift coincidence property (6) when the shifts Ûam and Ûbn coincide with each other up to an integer shift, calculated filters may coincide, and when the filters are applied, pixels of low-resolution images taking into account the shifts may be used.
The pixel shift coincidence property (7) when the shifts Ûam and Ûbn coincide with each other up to a change in an order of input images, calculated filters coincide with the order of the input images.
The pixel shift coincidence property (8) when the shifts Ûam and Ûbn coincide with each other up to a change in a coordinate uiam=vibn, viam=uibn, calculated filters may coincide, up to an order of a coordinate axis.
The pixel shift coincidence property (9) when the shifts Ûam and Ûbn coincide with each other up to a sign, calculated filters may coincide, up to a mirror display with respect to a horizontal axis and a vertical axis.
The pixel shift coincidence property (10) when, in the shift Ûam, elements of some pairs coincide with one another, for example, when uiam=ujam,viam=vjam, values corresponding to i and j in an image may be stored in the set of filters.
The application of these properties may be verified by the same example. Shift sets may be formed as follows, with respect to 7 shift sets included in the reduced shift sets in Table B03, and s=2.
The range of Table B04 may be converted to a range of 0 . . . 1, when the property (6) is used.
For convenience of further analysis, elements of Table B05 may be divided into groups according to the number of 0s as follows.
Some of elements arranged in a 6th column in Table B07 may be reduced based on the properties (6) and (7).
The property (8) is completely identical to the property (4), and thus, may be used as a large magnification factor. In Table B08, shifts which may be obtained from all shifts based on the properties (6) to (8) are arranged. To summarize, the analysis may be limited to 13 shifts. Only some filters corresponding to each shift may be stored by using the property (10). The number of filters with respect to each shift is indicated in a 4th column of Table B08. As disclosed in Table B08, it is identified that it is sufficient to store 26 filters, rather than original 192 filters, in order to obtain all pixels of the high-resolution image.
Table B09 discloses a result of a compression method with respect to three input images.
The image processing apparatus 100 according to the embodiment illustrated in
Also, the filter selector 102 may select any one of the non-directional filter set 110 and the directional filter set 120 based on a fractional pixel shift and a texture direction of the low-resolution image determined by the texture direction estimator 105.
The texture direction estimator 105 may determine the texture direction of the low-resolution image by using the following method. The texture direction estimator 105 according to an embodiment may estimate a local direction by using a structural tensor. To this end, a symmetric matrix of a 2×2 sized structural tensor may be formed. The symmetric matrix may be formed by a sum of squares of brightness gradients (changes in brightness of a pixel) of vertical and horizontal pixels, and a sum of multiplication of the brightness gradients of the vertical and horizontal pixels, the brightness gradients being calculated in some adjacent areas, as represented in Equation 22.
An eigen value λ+/− and an eigen vector θ+/− of the symmetric matrix of the structural tensor may be calculated as represented in Equation 23.
In Equation 23, D=(A11−A22)2+4A122. Based on the calculated intrinsic values, a coherence
may be calculated.
The image processing apparatus 100 may estimate information about a texture area via the coherence. For example, when the coherence does not exceed a certain critical value, the image processing apparatus 100 may estimate that an analyzed point belongs to any one of a weakly textured area and a highly textured area and does not have a texture of one dominant direction. However, this is only an example. As another example, the dominant texture direction may be calculated with respect to a corresponding point. In this case, when a maximum module value is λ+, the direction may be calculated based on an equation Drs=arctan2(2A12,A22−A11+√{square root over (D)}. Otherwise, the direction may be calculated based on an equation Drs=arctan2(2A12,A22−A11−√{square root over (D)}).
When processing an RGB image, a gradient may be calculated based on Equation 24.
∇x=l(y,x+1)−l(y,x−1), ∇y=l(y+1,x)−l(y−1,x) [Equation 24]
In Equation 24, l(y,x) indicates a pixel in an image l, the pixel having coordinates x and y.
According to the disclosure, the gradient may be calculated based on the following formula, in order to calculate the structural tensor with respect to the Bayer image.
The gradient of a green channel at points of r and b-types Bayer patterns may be calculated as represented in Equation 25.
∇xG=l(y,x+1)−l(y,x−1)
∇yG=l(y+1,x)−l(y−1,x) [Equation 25]
The gradient of a blue channel at a point of the r-type Bayer pattern may be calculated as represented in Equation 26.
The gradient of a red channel at a point of the r-type Bayer pattern may be calculated as represented in Equation 27.
The gradient of the red channel at a point of the b-type Bayer pattern may be calculated as represented in Equation 28.
The gradient of the blue channel at a point of the b-type Bayer pattern may be calculated as represented in Equation 29.
The horizontal gradient of the red channel and the vertical gradient of the blue channel at a point of a g1-type Bayer pattern may be calculated as represented in Equation 30.
∇xR=l(y,x+1)−l(y,x−1)
∇yB=l(y+1,x)−l(y−1,x) [Equation 30]
The horizontal gradient of the blue channel and the vertical gradient of the red channel at a point of a g2-type Bayer pattern may be calculated as represented in Equation 31.
∇xB=l(y,x+1)−l(y,x−1)
∇yR=l(y+1,x)−l(y−1,x) [Equation 31]
The horizontal gradient of the blue channel and the vertical gradient of the red channel at a point of the g1-type Bayer pattern may be calculated as represented in Equation 32.
The horizontal gradient of the red channel and the vertical gradient of the blue channel at a point of the g2-type Bayer pattern may be calculated as represented in Equation 33.
The gradient of the green channel at points of the g1 and g2-type Bayer patterns may be calculated as represented in Equation 34.
The gradient of each point of an input image may be calculated as represented in Equation 35.
∇x=max(∇xR,∇xG,∇xB), ∇y=max(∇yR,∇yG,∇yB) [Equation 35]
Forming the matrix T and searching the intrinsic vector and the intrinsic value λ± thereof may be performed based on substantially the same method as the method with respect to the RGB image. However, before calculating the dominant direction, the image processing apparatus 100 may reduce the vector. This aspect will be described in detail by referring to
As illustrated in
Referring to
In order to obtain the high-resolution image, additional constraints, such as noise in the input low-resolution image, an inaccurate estimated value of a pixel shift in some areas of the input low-resolution image, or a significant change (for example, due to an illumination change and residual color artifacts) of an image, may be taken into account. Also, a parameter corresponding to a characteristic of a specific apparatus used to capture the low-resolution image may be taken into account to obtain the high-resolution image.
Referring to
The image processing apparatus 100 including the pre-processor 106 and the fallback map estimator 107 may process both an RGB image and a Bayer image.
The shift estimator 101 may not use data obtained after the 3DNR, in order to obtain a more reliable result. The filter bank 103 may be corrected to reconstruct the high-resolution image from k input low-resolution images. For example, the filter bank 103 may be corrected to store filters calculated with respect to k, k−1, k−2, and k1 row resolution images.
When a shift with respect to a current pixel is not reliably calculated with respect to all input low-resolution images included in the low-resolution image set 10 having a single scene, the filter selector 102 may be corrected to select at least one of a plurality of filter sets stored in the filter bank 103, from the low-resolution image, based on a fractional pixel shift, for the reliable calculation of the shift. The filter bank 103 may store the non-directional filter set 110 and the directional filter set 120.
The high-resolution image obtainer 104 may apply a method of obtaining a high-resolution image to a low-resolution image pre-processed by taking into account an image area with respect to a pixel shift is inaccurately calculated. The image area with respect to which the fidelity of the pixel shift is low may be indicated in the fallback map.
When the pixel shift is reliably calculated with respect to all k input low-resolution images, the high-resolution image obtainer 104 may calculate pixels of the high-resolution image from the k low-resolution images, to which the 3DNR is applied, by using a filter with respect to the k images and pixels of the input image.
When it is not the case that the pixel shift is reliably calculated with respect to all k input low-resolution images, the high-resolution image obtainer 104 may select input pixels with respect to which an integer pixel shift is accurately calculated, from the low-resolution image. The high-resolution image obtainer 10 may calculate the pixels of the high-resolution image by applying, to the selected input pixels, the filters obtained by the filter selector 102 for the reconstruction of the high-resolution image from the low-resolution image.
The pre-processor 106 may determine noise-reduction parameters including a noise model, a size of an image portion, a search radius with respect to adjacent image portions, and a relationship between pixel brightness and pixel noise standard deviation, with respect to all pixels in the low-resolution image. Also, the pre-processor 106 may calculate a texture-dependent noise-reduction coefficient based on a change in pixel brightness. Each texture-dependent noise-reduction coefficient may be calculated with respect to each pixel in the low-resolution images.
Also, the pre-processor 106 may estimate a value of the pixel noise standard deviation, by using the relationship between the pixel brightness and the pixel noise standard deviation, the texture-dependent noise-reduction coefficient, and a noise-reduction coefficient set by a user. The pre-processor 106 may execute 3DNR on the low-resolution image set 10 based on the noise-reduction parameters and the estimated value of the pixel noise standard deviation, in order to obtain the low-resolution images having reduced noise.
The texture-dependent noise-reduction coefficients may indicate an estimated image textured level and may indicate areas potentially including high-frequency details which may be reconstructed by a high-resolution operation. In order to guarantee the best visual quality, 3DNR has to be performed on a non-texture area and an area smaller than an area having a dominant direction.
The 3DNR may be performed based on a noise model, such as Gaussian or Poisson, a size of an image portion which is an object of comparison and on which averaging is performed, a search radius R with respect to adjacent portions, and an estimated value of the pixel noise standard deviation at an image point σ(i,j). The search radius R with respect to the adjacent portions may be used to determine a maximum distance at which a current portion and a averaged image portion may be arranged. Also, the estimated value of the pixel noise standard deviation may be used to calculate filter weight coefficients applied to calculate a averaged pixel value.
A noise model m, an image portion size r, the search radius R with respect to adjacent portions, and the relationship σ({tilde over (l)}(i,j)) between the pixel brightness and the pixel noise standard deviation may be determined based on an exposure time and a gain coefficient GAIN. Here, a relatively greater exposure time and a relatively greater gain coefficient may be applied to the Gaussian model and a smaller radius, and a relatively smaller exposure time and a relatively smaller coefficient may be applied to the Poisson model and a greater radius. However, this is only an example. Detailed application methods may be experimentally derived or may be determined based on correction table data recorded by a camera manufacturer.
The texture-dependent noise-reduction coefficients may be calculated by the following operations.
The estimated value of the pixel noise standard deviation σ(i,j) with respect to each pixel having a coordinate i,j according to an embodiment may be calculated by multiplying a noise-reduction coefficient kg set by a user, the texture-dependent noise-reduction coefficient k(i,j), and the relationship σ({tilde over (l)}(i,j)) between the pixel brightness and the pixel noise deviation. Also, an average brightness {tilde over (l)}(i,j) may be calculated based on a previous low-frequency filter.
The noise-reduction coefficient kg may be used to determine a user preference in terms of a noise-reduction level, storage of a high frequency detail of an image, and a trade off between reconstruction levels. According to an embodiment, the determination of the noise-reduction parameters and the calculation of the texture-dependent noise-reduction coefficients may be performed in the same manner between the RGB low-resolution images and the low-resolution Bayer images.
The 3DNR with respect to the RGB input image may be performed according to a previous method using noise estimation.
With respect to each pixel P0 of the input low-resolution image, a final pixel of the low-resolution image to which the 3DNR is applied may be calculated as a sum of weights of the corresponding pixel and an adjacent pixel not distanced from the corresponding pixel by more than R. Also, a separate weight of each pixel Pt adjacent to the pixel P0 may be calculated by an operation, whereby an opposite sign is applied to an exponential function of a square of a distance D(P0,Pt) between portions of the low-resolution image in which the pixels P0 and Pt are arranged, and this is divided by the pixel noise standard deviation σ(i,j) and then is divided by a sum of standardized separate weights with respect to all pixels.
When the Gaussian noise model is used according to an embodiment, the distance D(P0,Pt) may be calculated as a sum of a square of a difference between a pixel not distanced from the current pixel P0 by more than 2r and a corresponding pixel arranged at the same distance from the current pixel.
When the Poisson model is used according to another embodiment, the distance D(P0,Pt) may be calculated as a sum of each pixel arranged at the same distance from two factorization functions fP(x,y) and Pt, with respect to the pixel not distanced from the current pixel P0 by more than 2r. Here,
The pixel Pt may be obtained from both the current low-resolution image and the input low-resolution image including the low-resolution image from which the pixel P0 is obtained.
The implementation of the 3DNR with respect to the Bayer image may be different from the implementation of the 3DNR with respect to the RGB image in that in the 3DNR with respect to the Bayer image, only pixels included in the same color channel are standardized. In particular, the implementation of the 3DNR with respect to the Bayer image may be different from the implementation of the 3DNR with respect to the RGB image in that in the 3DNR with respect to the Bayer image, only the pixels included in the same color channel are taken into account when calculating the distance D(P0,Pt).
The implementation of the 3DNR with respect to the Bayer image may be different from the implementation of the 3DNR with respect to the RGB image in that in the 3DNR with respect to the Bayer image, only pixels included in the same color channel as the current pixel are used to calculate the average brightness {tilde over (l)}(i,j). In the calculation of the average brightness according to an embodiment, filtering using a filter
may be used, and then, smoothing may be performed by a previous disc-type filter.
The fallback map estimator 107 may generate a fallback map based on a set of low-resolution images and a set of pixel shifts. The fallback map may indicate a fidelity of calculation of the pixel shift.
The image processing apparatus 100 according to an embodiment may use the fallback map, in order to compensate for an error obtained when calculating a pixel shift or a change of a scene, with respect to a scene having a big difference between adjacent low-resolution images. When using the fallback map, only the shift values of the pixels, reliably calculated, may be used to calculate a high-resolution image.
The fallback map M according to an embodiment may have a W×H×k size. Here, W and H indicate the number of pixels in a width direction and a height direction of the high-resolution image, respectively. Here, the high-resolution image may be obtained from input low-resolution images having a W/s×H/s size. Also, k indicates the number of input low-resolution images. Each element of the fallback map may have a value 1 with respect to pixels, when the shift is reliably calculated, and may have a value 0 with respect to pixels, when it is difficult to assure the reliability of the shift. The shift of all pixels of a first low-resolution image may have the value 0, and this may be considered to be reliable.
The fallback map with respect to the input RGB low-resolution images may be calculated by the following operations.
with respect to all compensated low-resolution images, wherein the white balance, gamma correction, and Gaussian filtering may be performed based on the previous method.
The calculation of the fallback map with respect to the Bayer image may include the following different operations in terms of the compensation of the pixel shift, compared to the calculation of the fallback map with respect to the RGB image.
For example, as illustrated in
sum the pixels of the color channels G1 and G2 having the same location in all of the input low-resolution images, and divide the sum of the pixels of the color channels G1 and G2 by 2 to obtain a channel G.
The rest of the operations for calculating the fallback map with respect to the Bayer image may be the same as the operations for calculating the fallback map with respect to the RGB image.
The texture direction estimator 105 according to an embodiment may determine the texture direction of the noise-reduced low-resolution image obtained from the pre-processor 106.
The filter selector 102 according to an embodiment may select any one of the non-directional filter set and the directional filter set based on the fallback map, the fractional pixel shift set, and the texture direction in the noise-reduced low-resolution image.
Also, the high-resolution image obtainer 104 according to an embodiment may obtain the RGB high-resolution image by calculating the pixel of the high-resolution image by using the fallback map, the noise-reduced low-resolution image set, the selected filter set, and the integer pixel shift set.
The operation of obtaining the high-resolution image by using the fallback map and the noise-reduced (3DNR-applied) low-resolution image set may correspond to the operation of the high-resolution image obtainer 104 described above.
In order to filter a color artifact remaining in the high-resolution image, the image processing apparatus 100 configured to process high-resolution data may further include the post-processor 108. The post-processor 108 may convert the RGB high-resolution image obtained by the high-resolution image obtainer 104 into a YUV image.
Also, the post-processor 108 may process the YUV image as follows.
calculate a map of pixel standard deviations of a channel Y based on a sliding window method
calculate a reference channel Ref with respect to cross bilateral filtering by performing smoothing on the map of pixel standard deviations by using Gaussian filtering and perform cross bilateral filtering on a channel U and a channel V by using the reference channel Ref
reversely convert the processed YUV image into the post-processed RGB high-resolution image
The image processing method according to an embodiment aims to obtain a high-resolution image from a set of low-resolution images with respect to a single scene. The image processing method according to an embodiment may be performed on both the input RGB image and the input Bayer image and may not require a demosaicing operation to convert the Bayer image into the RGB image. The image processing method may be performed by the image processing apparatus 100 described above. The operations performed by the image processing apparatus 100 may correspond to the operations performed in an image processing method to be described below by referring to
In operation S610, the image processing apparatus may obtain a pixel shift set indicating information of movement of a plurality of pixels included in coinciding portions among a plurality of low-resolution images with respect to a single scene.
The image processing apparatus according to an embodiment may obtain a pixel shift set with respect to both of a plurality of low-resolution images having an RGB format and a plurality of low-resolution images having a Bayer format.
Also, the image processing apparatus according to another embodiment may obtain the pixel shift set from a plurality of noise-reduced low-resolution images. Here, a method of obtaining the plurality of noise-reduced low-resolution images via the image processing apparatus may correspond to the method of obtaining the plurality of noise-reduced low-resolution images via the image processing apparatus 100 described above with reference to
In operation S620, the image processing apparatus may divide the pixel shift set into an integer portion and a fractional portion, and may generate an integer pixel shift set and a fractional pixel shift set.
The image processing apparatus according to an embodiment may select a limited number of fractional shifts having values within a predetermined range, from among a plurality of fractional shifts of a plurality of pixels. The image processing apparatus may generate the fractional pixel shift set by combining the selected fractional pixel shifts.
In operation S630, the image processing apparatus may select a filter set corresponding to a plurality of pixels from among a pre-stored plurality of filter sets including filter weight values applied to pixels, based on the fractional pixel shift set.
The image processing apparatus according to an embodiment may select the filter set corresponding to the plurality of pixels from among the pre-stored plurality of filter sets, based on the fractional pixel shift set and a pre-set regularizer. The regularizer may be used to apply constraints added for obtaining the high-resolution image. Also, the plurality of filer sets according to an embodiment may be stored in a filter bank. The number of the pre-stored filter sets may be determined based on at least one pixel shift coincidence property of the plurality of pixels included in the coinciding portions among the plurality of low-resolution images. Here, the coincidence property may correspond to each of the coincidence properties of the plurality of pixel shifts, described above with reference to
The image processing apparatus according to another embodiment may select the filter set based on whether or not a texture of the coinciding portions among the plurality of low-resolution images has directionality, and based on the fractional pixel shift set.
The image processing apparatus according to another embodiment may select the filter set corresponding to the plurality of pixels from among the pre-stored filter sets, based on the fallback map, the fractional pixel shift set, and the texture direction.
In operation S640, the image processing apparatus may obtain the high-resolution image with respect to the single scene, based on the plurality of low-resolution images, the selected filter set, and the integer pixel shift set.
The image processing apparatus according to an embodiment may perform post-processing to remove color artifacts remaining in the obtained high-resolution image of the RGB format. For example, the image processing apparatus may convert the high-resolution image having the RGB image format into an YUV image. The image processing apparatus may obtain a pixel standard deviation map with respect to a channel Y with respect to the YUV image. The image processing apparatus may perform cross bilinear filtering on a channel U and a channel V based on a reference channel obtained by performing smoothing on the pixel standard deviation map. The image processing apparatus may obtain the post-processed high-resolution image by converting the YUV image, on which cross bilinear filtering is performed, into the format of the RGB image.
Referring to
For example, the image processing apparatus 700 may display, on a display thereof, a list 710 on which an effect corresponding to each of a plurality of filter sets is disclosed, so that the user may select any one of the plurality of filter sets, which corresponds to the fractional pixel shift. Here, based on each effect, at least one of a color, edge, saturation, brightness, color temperature, blur, sharpness, and contrast may be different. When the user selects one of the plurality of effects disclosed on the list 710 in order to apply the effect preferred by the user when obtaining the high-resolution image, a filter set corresponding to the selected effect may be selected.
However, this is only an example. Identification information of the filter set may be directly displayed or a pre-view image with respect to the high-resolution image to be generated when each of the filter sets is applied may be displayed, on the list 710.
The image processing apparatus 700 may determine at least one filter set which is appropriate to obtain the high-resolution image by taking into account attributes of the plurality of low-resolution images, and may display the determined at least one filter set on the list 710. The image processing apparatus 700 may recommend at least one filter set by taking into account the fractional pixel shift set in the plurality of low-resolution images, and ultimately select the filter set based on the selection of the user, thereby selecting the filter set reflecting both the user preference and the attributes of the low-resolution images.
Also, according to another example, the image processing apparatus 700 may recommend at least one filter set based on the fractional pixel shift set and texture directionality.
According to another example, the image processing apparatus 700 may display, on the list 710, the filter set selected based on history information of at least one filter set previously selected by the user. For example, the image processing apparatus 700 may display the filter set, the selected number of which is equal to or greater than a predetermined value, on the list 710. Here, the filter set which is selected many times by the user may be located on a top end of the list 710.
Also, the image processing apparatus 700 may determine the filter set displayed on the list 710 by using history information with respect to each low-resolution image set. The low-resolution image sets may include a sports image, a drama image, a game image, etc. The low-resolution image sets may be classified according to a type, motion, etc. of an object included in the low-resolution image sets. However, the low-resolution image sets are not limited thereto. The image processing apparatus 700 may display the filter set previously selected many times by the user on the top end of the list 710, with respect to the low-resolution image sets. For example, when the obtained low-resolution image set corresponds to a sports image, the image processing apparatus 700 may display a filter set, the selected number of which is equal to or greater than a predetermined value, based on history information of filter sets previously selected by the user with respect to the sports image, on the top end of the list 710.
The image processing apparatus 700 according to an embodiment may display the high-resolution image obtained from the plurality of low-resolution images based on the filter set selected by the user, on a screen of the image processing apparatus 700 or a screen of an external apparatus.
Referring to
The image processing apparatus obtains the high-resolution image 830 from the low-resolution images 810 having the single scene by using the learning network model 820 may denote that the image processing apparatus determines a filter set applied to a fractional pixel shift set, based on a result of using the learning network model 820. To this end, the image processing apparatus may train the learning network model 820 by repeatedly training the learning network model 820 with respect to the filter set corresponding to the fractional pixel shift set, and/or analyzing and/or evaluating non-instructed learned results.
Also, as another example, the image processing apparatus may train the learning network model 820 according to the method described above, by taking into account texture directionality in addition to the fractional pixel shift.
When there is a high-resolution image, a plurality of low-resolution images for training the learning network model 820 may be obtained from the high-resolution image by performing conversion and continuous down-sampling. For example, the plurality of low-resolution images for the training may be obtained from the high-resolution image pre-obtained based on Equation 1 described above.
The image processing apparatus according to an embodiment may output a probability of each filter set appropriate to obtain the high-resolution image 830 from the plurality of low-resolution images 810, via the learning network model 820. The image processing apparatus may display the filter sets having the output probability values equal to or higher than a critical value, on a screen. Here, a user may select any one of the filter sets displayed on the screen. However, this is only an example. According to another example, the image processing apparatus may generate the high-resolution image by using the filter set having the highest output probability value, and may display the generated high-resolution image on the screen.
According to another embodiment, the image processing apparatus may train the learning network model 820 to determine the filter set by taking into account types of the plurality of low-resolution images 810. For example, the image processing apparatus may input each low-resolution image set in the learning network model 820 and train the learning network model 820 to output a filter set preferred by a user. Accordingly, the image processing apparatus may obtain the output filter set preferred by the user with respect to a newly obtained low-resolution image set, by using the learning network model 820.
Referring to
The at least one processor 910 according to an embodiment may perform the operations of the shift estimator 101, the filter selector 102, the filter bank 103, and the high-resolution image obtainer 104, described above with reference to
Also, according to another embodiment, the at least one processor 910 may perform the operations of the shift estimator 101, the filter selector 102, the filter bank 103, the high-resolution image obtainer 104, and the texture direction estimator 105, described above with reference to
According to another embodiment, the at least one processor 910 may perform the operations of the shift estimator 101, the filter selector 102, the filter bank 103, the high-resolution image obtainer 104, the texture direction estimator 105, the pre-processor 106, the fallback map estimator 107, and the post-processor 108, described above with reference to
For example, the at least one processor 910 may obtain a pixel shift set indicating information of movement of a plurality of pixels included in coinciding portions among the plurality of low-resolution images having the single scene. Also, the at least one processor 910 may generate an integer pixel shift set and a fractional pixel shift set by dividing the pixel shift set into an integer portion and a fractional portion. The at least one processor 910 may select a filter set corresponding to the plurality of pixels from among a plurality of pre-stored filter sets including a filter weight value applied to the pixels, based on the fractional pixel shift set. Also, the at least one processor 910 may obtain the high-resolution image with respect to the single scene, based on the plurality of low-resolution images, the selected filter set, and the integer pixel shift set.
The memory 920 may store programs (one or more instructions) for processing and controlling of the at least one processor 910. The programs stored in the memory 920 may be divided into a plurality of modules based on functions.
The memory 920 according to an embodiment may include a software module including a data learner 1010 and a data recognizer 1020 to be described below with reference to
Referring to
The data learner 1010 may learn a reference to determine the filter set with respect to the fractional pixel shift of the plurality of low-resolution images. Also, according to another embodiment, the data learner 1010 may learn the reference to determine the filter set corresponding to the fractional pixel shift set based on information about a filter set selected by a user to obtain a high-resolution image from the plurality of low-resolution images and information of attributes of the plurality of low-resolution images. Here, the attribute information may include a color, edge, a polygon, saturation, brightness, color temperature, blur, sharpness, contrast, etc., included in an image, but the attribute information is not limited thereto.
The data recognizer 1020 may determine the filter set corresponding to the fractional pixel shift set of the plurality of low-resolution images, based on the reference learned by the data learner 1010.
At least one of the data learner 1010 and the data recognizer 1020 may be manufactured in the form of at least one hardware chip and may be mounted in the image processing apparatus. For example, at least one of the data learner 1010 and the data recognizer 1020 may be manufactured as an exclusive hardware chip for artificial intelligence (AI) or may be manufactured as part of a previous general processor (for example, a central processor (CPU) or an application processor) or a graphics exclusive processor (for example, a graphics processor (GPU)) and mounted in various image processing apparatuses described above.
In this case, the data learner 1010 and the data recognizer 1020 may be mounted in one image processing apparatus, or may be mounted in each different image processing apparatus. For example, one of the data learner 1010 and the data recognizer 1020 may be included in an image processing apparatus and the other may be included in a server. Also, the data learner 1010 and the data recognizer 1020 may be connected wirelessly or via wires, so that model information generated by the data learner 1010 may be provided to the data recognizer 1020, or data input in the data recognizer 1020 may be provided to the data learner 1010 as additional learning data.
At least one of the data learner 1010 and the data recognizer 1020 may be implemented as a software module. When at least one of the data learner 1010 and the data recognizer 1020 is implemented as a software module (or a program module including instructions), the software module may be stored in a non-transitory computer readable recording medium. Also, in this case, one or more software modules may be provided by an operating system (OS) or by a certain application. Alternatively, some of the one or more software modules may be provided by the OS and the others may be provided by a certain application.
Referring to
The data obtainer 1110 may obtain a plurality of low-resolution image sets as learning data. For example, the data obtainer 1110 may obtain at least one image from an image processing apparatus including the data learner 1010 or an external apparatus capable of communicating with the image processing apparatus including the data learner 1010.
The pre-processor 1120 may perform pre-processing, such as removing noise of each of the plurality of low-resolution image sets. Also, the pre-processor 1120 may process the obtained low-resolution image sets in a pre-set format, so that the model learner 1140 to be described below may use the obtained low-resolution image sets for learning.
The learning data selector 1130 may select a low-resolution image which is necessary for learning, from among the pre-processed data. The selected low-resolution image may be provided to the model learner 1140. The learning data selector 1130 may select the image which is necessary for learning, from the pre-processed image, based on a reference which is set.
The model learner 1140 may learn a reference with respect to which information to use in the low-resolution image, by a plurality of layers in a learning network model, in order to determine the filter set with respect to the fractional pixel shift set.
Also, the model learner 1140 may train a data recognition model, for example, through reinforcement learning using feedback with respect to whether an image quality of an obtained high-resolution image is proper.
Also, when the data recognition model is learned, the model learner 1140 may store the learned data recognition model.
The model evaluator 1150 may input evaluation data in the learning network model, and when a recognition result output from the evaluation data does not satisfy a certain reference, may cause the model learner 1140 to learn again. In this case, the evaluation data may be data that is pre-set to evaluate the learning network model.
At least one of the data obtainer 1110, the pre-processor 1120, the learning data selector 1130, the model learner 1140, and the model evaluator 1150 in the data learner 1010 may be manufactured in the form of at least one hardware chip and mounted in the image processing apparatus. For example, at least one of the data obtainer 1110, the pre-processor 1120, the learning data selector 1130, the model learner 1140, and the model evaluator 1150 may be manufactured as an exclusive hardware chip for AI or may be manufactured as part of a previous general processor (for example, a CPU or an application processor) or a graphics exclusive processor (for example, a GPU) and mounted in various image processing apparatuses described above.
Also, the data obtainer 1110, the pre-processor 1120, the learning data selector 1130, the model learner 1140, and the model evaluator 1150 may be mounted in one image processing apparatus, or may be mounted in each different image processing apparatus. For example, some of the data obtainer 1110, the pre-processor 1120, the learning data selector 1130, the model learner 1140, and the model evaluator 1150 may be included in the image processing apparatus and the others may be included in a server.
Also, at least one of the data obtainer 1110, the pre-processor 1120, the learning data selector 1130, the model learner 1140, and the model evaluator 1150 may be implemented as a software module. When at least one of the data obtainer 1110, the pre-processor 1120, the learning data selector 1130, the model learner 1140, and the model evaluator 1150 is implemented as a software module (or a program module including instructions), the software module may be stored in a non-transitory computer readable recording medium. Also, in this case, one or more software modules may be provided by an OS or by a certain application. Alternatively, some of the one or more software modules may be provided by the OS and the others may be provided by a certain application.
Referring to
The data obtainer 1210 may obtain a plurality of low-resolution image sets and the pre-processor 1220 may pre-process the obtained plurality of low-resolution image sets. The pre-processor 1220 may process the obtained low-resolution image sets in a pre-set format, so that the recognition result provider 1240 to be described below may use the obtained plurality of low-resolution image sets in order to determine a filter set with respect to a fractional pixel shift set. The recognition data selector 1230 may select a low-resolution image which is necessary to determine the filter set with respect to the fractional pixel shift set, from the pre-processed data. The selected low-resolution image may be provided to the recognition result provider 1240.
The recognition result provider 1240 may determine the filter set with respect to the fractional pixel shift set used to obtain the high-resolution image, based on the selected low-resolution image. Also, the recognition result provider 1240 may provide information about the determined filter set to the model renewer 1250.
The model renewer 1250 may provide the information about evaluation of the determined filter set to the model learner 1140 described above with reference to
At least one of the data obtainer 1210, the pre-processor 1220, the recognition data selector 1230, the recognition result provider 1240, and the model renewer 1250 in the data recognizer 1020 may be manufactured in the form of at least one hardware chip and mounted in an image processing apparatus. For example, at least one of the data obtainer 1210, the pre-processor 1220, the recognition data selector 1230, the recognition result provider 1240, and the model renewer 1250 may be manufactured as an exclusive hardware chip for AI or may be manufactured as part of a previous general processor (for example, a CPU or an application processor) or a graphics exclusive processor (for example, a GPU) and mounted in various image processing apparatuses described above.
Also, the data obtainer 1210, the pre-processor 1220, the recognition data selector 1230, the recognition result provider 1240, and the model renewer 1250 may be mounted in one image processing apparatus, or may be mounted in each different image processing apparatus. For example, some of the data obtainer 1210, the pre-processor 1220, the recognition data selector 1230, the recognition result provider 1240, and the model renewer 1250 may be included in the image processing apparatus and the others may be included in a server.
Also, at least one of the data obtainer 1210, the pre-processor 1220, the recognition data selector 1230, the recognition result provider 1240, and the model renewer 1250 may be implemented as a software module. When at least one of the data obtainer 1210, the pre-processor 1220, the recognition data selector 1230, the recognition result provider 1240, and the model renewer 1250 is implemented as a software module (or a program module including instructions), the software module may be stored in a non-transitory computer readable recording medium. Also, in this case, one or more software modules may be provided by an OS or by a certain application. Alternatively, some of the one or more software modules may be provided by the OS and the others may be provided by a certain application.
Referring to
When a user uses the plurality of image processing apparatuses 1320 and 1330, the user may download the learning network model 1315 from a learning network model stored in the server 1310 or receive information about the filter set determined based on the learning network model 1315, so as to obtain the high-resolution image 1334 from the plurality of low-resolution images 1332.
The server 1310 may train the learning network model 1315 to reflect a user preference when determining the filter set based on information about filter sets previously selected by the user. Accordingly, both when the user determines the filter set by using the first image processing apparatus 1320 and when the user determines the filter set by using the second image processing apparatus 1330, the user may use the learning network model 1315 stored in the server 1310, so as to determine the filter set reflecting the user preference, even when the apparatus is changed.
Also, according to another embodiment, the server 1310 may store configuration information for removing noise described above with reference to
The server 1310 may include a computing device configured to provide service to the first and second image processing apparatuses 1320 and 1330. For example, the server 1310 may include a personal computer (PC), a laptop, a micro server, and other mobile or non-mobile devices. However, the server 1310 is not limited thereto, and may include all types of apparatuses having a communication function and a data processing function.
The image processing method according to an embodiment may be applied to various image capturing systems having one or more cameras including a system configured to support a bust shot function. Embodiments may be applied for “digital zooming” and mega pixel image multiplication (Mpx) in a general camera use scenario. The embodiments may be applied in application fields requiring optical character recognition (OCR). Also, the embodiments may be implemented as a general-purpose processor, software using a digital signal processor (DSP) and/or a CPU, or partially as a system on chip (SoC). As another example, the embodiments may be implemented as an additional device or part of an image signal processor (ISP).
The method according to an embodiment may be implemented as computer instructions which may be executed by various computer means, and recorded on a non-transitory computer-readable recording medium. The non-transitory computer-readable recording medium may include program commands, data files, data structures, or a combination thereof. The program commands recorded on the non-transitory computer-readable recording medium may be specially designed and constructed for the disclosure or may be known to and usable by one of ordinary skill in a field of computer software. Examples of the non-transitory computer-readable medium include storage media such as magnetic media (e.g., hard discs, floppy discs, or magnetic tapes), optical media (e.g., compact disc-read only memories (CD-ROMs), or digital versatile discs (DVDs)), magneto-optical media (e.g., floptical discs), and hardware devices (e.g., ROMs, RAMs, or flash memories) which are specially configured to store and carry out program commands. Examples of the program commands include a high-level programming language code to be executed in a computer by using an interpreter as well as a machine language code made by a compiler.
For the purposes of promoting an understanding of the principles of the disclosure, reference has been made to the example embodiments illustrated in the drawings, and specific language has been used to describe these embodiments. However, no limitation of the scope of the disclosure is intended by this specific language, and the disclosure should be construed to encompass all embodiments that would normally occur to one of ordinary skill in the art.
The disclosure may be described in terms of functional block components and various processing steps. Such functional blocks may be realized by any number of hardware and/or software components configured to perform the specified functions. For example, the disclosure may employ various integrated circuit components, e.g., memory elements, processing elements, logic elements, look-up tables, and the like, which may carry out a variety of functions under the control of one or more microprocessors or other control devices. Similarly, where the elements of the disclosure are implemented using software programming or software elements, the disclosure may be implemented with any programming or scripting language such as C, C++, Java, assembler, or the like, with the various algorithms being implemented with any combination of data structures, objects, processes, routines or other programming elements. Functional aspects may be implemented in algorithms that execute on one or more processors. Furthermore, the disclosure could employ any number of conventional techniques for electronics configuration, signal processing and/or control, data processing and the like. The words “mechanism” and “element” are used broadly and are not limited to mechanical or physical embodiments, but can include software routines in conjunction with processors, etc.
The particular implementations shown and described herein are illustrative examples of the disclosure and are not intended to otherwise limit the scope of the disclosure in any way. For the sake of brevity, conventional electronics, control systems, software development and other functional aspects of the systems (and components of the individual operating components of the systems) may not be described in detail. Furthermore, the connecting lines, or connectors shown in the various figures presented are intended to represent exemplary functional relationships and/or physical or logical couplings between the various elements. It should be noted that many alternative or additional functional relationships, physical connections or logical connections may be present in a practical device. Moreover, no item or component is essential to the practice of the disclosure unless the element is specifically described as “essential” or “critical.”
It should be understood that embodiments described herein should be considered in a descriptive sense only and not for purposes of limitation. Descriptions of features or aspects within each embodiment should typically be considered as available for other similar features or aspects in other embodiments.
While one or more embodiments have been described with reference to the figures, it will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from the spirit and scope as defined by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
2017115447 | May 2017 | RU | national |
10-2018-0042920 | Apr 2018 | KR | national |