1. Field of the Invention
The present invention relates to an image processing apparatus, an image processing method, and an image display apparatus. In particular, it relates to methods of reducing the occurrence of false edges in a digital image by gray scale interpolation when the gray scale of a digital image is expanded by bit extension.
2. Description of the Related Art
In recent years, the brightness of the display screens of television sets and monitors has been increasing. As brightness increases, the amount of change in brightness per gray level in the gray scale increases. Ten-bit liquid crystal panels and other display devices with high gray-scale resolution are being developed, but digital television broadcasting uses an eight-bit gray scale, so despite the ten-bit resolution of the latest display devices, the effective resolution of the gray scale in a television picture remains eight bits. Not only does this prevent full utilization of the features of these new display devices; picture signals that should grade smoothly in color or brightness, such as pictures of a sunset or the surface of the sea, may instead grade in a staircase pattern, skipping one or more intermediate gray levels at each step and thereby producing visible false edges.
When only one level is skipped, the false edge can be eliminated by an averaging process. To deal with jumps between two gray levels that differ by N levels, where N is any integer greater than one, Japanese Patent Application Publication No. 10-84481 (Paras. 0002 to 0006 and 0025 to 0028, FIGS. 1 and 2) defines an interpolation region around the jump, separates the interpolation region into (N+1) discrete subregions, and assigns sequential gray levels to the subregions.
A general problem of such methods is that they fail to distinguish between true image edges and false edges caused by bit extension. If used to smooth out false edges, these methods also smooth out real edges, leading to a loss of sharpness, as if the picture were slightly out of focus.
An object of the present invention is to provide an image processing apparatus that eliminates false edges due to bit extension of image data without impairing the sharpness of real edges.
The invention provides an image processing apparatus comprising a bit extender and an edge-preserving smoothing filter. The bit extender receives n-bit image data, carries out an α-bit bit extension, and outputs resulting basic (n+α)-bit image data, where n and α are positive integers. The edge-preserving smoothing filter smoothes the basic (n+α)-bit image data by using the additional gray levels provided by the bit extension. The edge-preserving smoothing filter may be an epsilon filter with a threshold value ε equal to 2α. Such a filter smoothes out jumps of 2α gray levels caused by the bit extension without smoothing out larger jumps, thereby eliminating false edges from regions of gradual change while preserving the sharpness of real edges.
The bit extender and the edge-preserving smoothing filter may be combined into a bit-extending edge-preserving smoothing filter.
The invention also provides an image display apparatus including the above image processing apparatus. One example is a television receiver that receives an eight-bit digital broadcast picture signal and displays a smooth, vivid, and sharp picture on a ten-bit display unit.
In the attached drawings:
Embodiments of the invention will now be described with reference to the attached drawings, in which like elements are indicated by like reference characters.
Referring to
In this embodiment, the receiver 2 will be described as an analog-to-digital converter for converting an analog image signal to n-bit digital image data, but this is not a restriction; the receiver 2 may include a tuner, in which a composite signal may be demodulated into luminance and chrominance signals and then converted to digital image data, or the receiver 2 may be a digital interface that receives digital data through the input terminal 1 and outputs n-bit image data DI.
An analog image signal SA is input from the input terminal 1 to the receiver 2, converted to n-bit image data DI, and output to the gray scale expansion processor 3. The gray scale expansion processor 3 converts the n-bit image data to (n+α)-bit data, filters the data, and outputs the filtered data to the display unit 4. The gray scale expansion processor 3 includes a bit extender 5 and a one-dimensional m-order epsilon filter (ε-filter) 6. The bit extender 5 outputs (n+α)-bit image data obtained by extending the n-bit image data DI by a bits to the one-dimensional m-order epsilon filter 6.
The image data DS (and image data DI) represent the values of pixels arranged in a matrix; pixel position is represented by a pair of coordinates (i, j) with the origin (0, 0) at the upper left corner of the display; the value of increases in the horizontal direction in steps of one per column to the right; the value of j increases in the vertical direction in steps of one per one row downward. The image data DS thus represent a row-column matrix of data representing the values of the pixels aligned from top to bottom and from left to right on the display screen.
The conversion of the image signal SA to the image data DI in the receiver 2, the supplying of image data DI from the receiver 2 to the bit extender 5, the bit extension in the bit extender 5, the supply of the image data D from the bit extender 5 to the one-dimensional m-order epsilon filter 6, and the operation of the one-dimensional m-order epsilon filter 6 are synchronized with a pixel clock signal supplied by a control unit (not shown).
The one-dimensional m-order epsilon filter 6 is an edge-preserving smoothing filter that processes pixels aligned one-dimensionally so as to preserve large abrupt changes (edges) while smoothing out small abrupt changes as if they were noise. The one-dimensional m-order epsilon filter 6 in
The image data DO are output to the display unit 4, which is capable of displaying (n+α)-bit image data.
The epsilon filter is a known device described in, for example, Hisenkei dijitaru shingo shori (Non-linear signal processing) by Hinamoto et al., Asakura shoten, 1999, pp. 106-107 (in Japanese).
The one-dimensional processing by the epsilon filter is represented by equation (1), where x(i) indicates an input gray level, y(i) indicates an output gray level, ak is a coefficient, k indicates pixel position relative to the pixel of interest, and ε is a threshold value.
The function f(u) in equation (1) is represented by the graph in
In the example above, u is equal to x(i−k)−x(i), that is, the difference between the gray level x(i) at pixel position i and the gray level x(i−k) at a pixel position (i−k) near pixel position i. When the difference x(i−k)−x(i) is small, f(u)=f{x(i−k)−x(i)} is the identity function, and if the sum of the coefficients ak is unity, equation (1) can be replaced with equation (2), which is the equation of a weighted-average filter.
When the sum of the coefficients ak is unity, equation (1) can also be rewritten as equation (3).
The quantity x′(i−k) is defined by the expression in brackets in equation (3). From this expression and
The operation of the epsilon filter will be described with reference to
When the pixel at point A in
In this embodiment, the epsilon filter is designed to treat jumps caused by the bit extension process as noise. That is, when n-bit data are extended to (n+α)-bit data, the threshold value ε is set equal to 2α. This enables the epsilon filter to increase the number of effective gray levels while retaining abrupt changes at edges and other such points in an image.
The case in which α equals two (α=2), so that n-bit image data are expanded to (n+2)-bit image data, will now be described with reference to
In
The operation of the receiver 2 will be described with reference to
The image signal SA shown in
The data storage unit 7 in
More specifically, the data held by-flip-flop FF_2 are output as the gray level DM(c) of the pixel of interest c; the data held by flip-flop FF_3 are output as the gray level DM(l1) of the pixel l1 immediately preceding the pixel of interest c, that is, the first adjacent pixel to the left of pixel c (with a difference of one in the horizontal coordinate value i); the data held by flip-flop FF_4 are output as the gray level DM(l2) of the pixel l2 preceding pixel l1, that is, the second pixel to the left of the pixel of interest (with a difference of two in the horizontal coordinate value i); the data held by flip-flop FF_1 are output as the gray level DM(r1) of the pixel r1 immediately following the pixel of interest c, that is, the first adjacent pixel to the right of pixel c (with a difference of one in the horizontal coordinate value i).
The operation of the data storage unit 7 is illustrated in
The first difference calculator 8-1 in
The output of the first difference calculator 8-1 is:
ED(l2)=DM(l2)−DM(c)=4Y−4Y=0
The output of the second difference calculator 8-2 is:
ED(l1)=DM(l1)−DM(c)=4Y−4Y=0
The output of the third difference calculator 8-3 is:
ED(c)=DM(c)−DM(c)=4Y−4Y=0
The output of the fourth difference calculator 8-4 is:
ED(r1)=DM(r1)−DM(c)=(4Y+4)−4Y=4
The epsilon decision units 9-1 to 9-4 receive the difference values ED(k), decide whether each value is greater than ε or not, and output the decision results as the decision data EE(k) shown in
The first epsilon decision unit 9-1 thus generates ‘0’ output when the difference ED(l2) is greater than ε, and generates ‘1’ output when the difference ED(l2) is equal to or less than the ε.
Epsilon decision units 9-2 to 9-4 generate similar decision data EE(l1) to EE(r1) based on the difference data ED(l1) to ED(r1). The generated decision data are supplied to the conditional weighted averager 10. In this example, since a equals two (α=2), the threshold value ε is set to four (ε=4).
In the example shown in
The conditional weighted averager 10 calculates the weighted average of the difference data ED(l2) to ED(r1) conditional on the decision data EE(l2) to EE(r1) and outputs the resulting weighted average value. When the decision data are ‘1’, the difference data are multiplied by respective coefficients ak and the products are summed; when the decision data are ‘0’, the products are not included in the sum. In effect, the conditional weighted averager 10 transforms the difference data ED(k) according to the function f{ED(k)} shown in
If the coefficients ak (al2, al1, ac, ar1) are all one-fourth (0.25), then since the decision data EE(l2) to EE(r1) are all ‘1’, the output EM of the conditional weighted averager 10 is given by equation (5).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (5) is carried out for each successive pixel.
The operation of the data adder 11 will now be described with reference to
DO(ia)=DS(ia)+EM(ia)=4Y+1
As described above, this embodiment can increase the number of effective gray levels in a region with gradually changing gray levels. When n-bit image data are converted to (n+2)-bit image data, if the analog image signal SA changes gradually and the gray level of the bit-extended image data DS jumps from 4Y to (4Y+4), changing abruptly by four gray levels (4=22) as shown in
The operation when the epsilon filter receives a signal with a large jump in gray level will now be described with reference to
The analog image signal SA illustrated in
The bit extender 5 converts the gray level Y in the image data DI in
The data storage unit 7 outputs DM(l2)=4Y, DM(l1)=4Y, DM(c)=4Y, and DM(r1)=4Y+16 to the difference calculators 8-1 to 8-4.
The output of the first difference calculator 8-1 is:
ED(l2)=DM(l2)−DM(c)=4Y−4Y=0
The output of the second difference calculator 8-2 is:
ED(l1)=DM(l1)−DM(c)=4Y−4Y=0
The output of the third difference calculator 8-3 is:
ED(c)=DM(c)−DM(c)=4Y−4Y=0
The output of the fourth difference calculator 8-4 is:
ED(r1)=DM(r1)−DM(c)=(4Y+16)−4Y=16.
Accordingly, zero (0) is input to the epsilon decision units 9-1 to 9-3 and sixteen (16) is input to the second epsilon decision unit 9-4. If the threshold value ε is equal to four (ε=4), since ED(l2), ED(l1), and ED(c) are equal to or less than ε, the corresponding decision data EE(l2), EE(l1), and EE(c) are ‘1’; since ED(r1) is greater than ε, EE(r1) is ‘0’.
The conditional weighted averager 10 multiplies the difference data having decision data of ‘1’ by coefficients ak and sums the results, excluding difference data with decision data of ‘0’ from the sum.
If the coefficients ak (al2, al1, ac, ar1) are all one-fourth (0.25), then since only the decision data EE(l2), EE(l1), and EE(r1) are ‘1’, the output EM of the conditional weighted averager 10 is given by equation (5).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (6) is carried out for each successive pixel.
The data adder 11 adds the image data DS shown in
As shown in
As described above, when n-bit image data are extended to (n+α)-bit data, if changes in lower a bits are treated as small-amplitude noise and the threshold value ε is set equal to 2α, gray level jumps due to the difference in bit resolution between the input and output image are eliminated by increasing the number of gray levels represented in regions with gradually changing gray levels, while the sharpness of the image is preserved by leaving larger jumps unchanged. That is, the number of effective gray levels is increased without blurring the image.
In the above example, the order m of the epsilon filter is set equal to 2α. This is not a limitation, but the use of values of m less than 2α raises the problem described below, so m is preferably equal to or greater than 2α. The case where m equals 2α−1, a equals two, and accordingly m equals three (m=2α−1, α=2, m=3) will now be described.
The operation of the image display apparatus in
The analog image signal SA illustrated in
The bit extender 5 converts the gray level Y in the image data DI in
The data storage unit 7 in
The output of the first difference calculator 8-1 is:
ED(l1)=DM(l1)−DM(c)=4Y−4Y=0
The output of the second difference calculator 8-2 is:
ED(c)=DM(c)−DM(c)=4Y−4Y=0
The output of the third difference calculator 8-3 is:
ED(r1)=DM(r1)−DM(c)=(4Y+4)−4Y=4
Accordingly, zero (0) is input to the epsilon decision units 9-1 to 9-2 and four (4) is input to the third epsilon decision unit 9-3. If the threshold value ε is equal to four (ε=4), then ED(l1), ED(c), and ED(r1) are all equal to or less than the threshold value ε, and the decision data EE(l1), EE(c), and EE(r1) are all ‘1’.
The conditional weighted averager 10 multiplies the difference data having decision data of ‘1’ by coefficients ak and sums the results, excluding difference data with decision data of ‘0’ from the sum.
If the coefficients ak (al2, ac, ar1) are all one-third (approximated as 0.3325), then the output EM of the conditional weighted averager 10 is given by equation (7).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (7) is carried out for each successive pixel.
The data adder 11 adds the image data DS shown in FIG. 16BC to the weighted average data EM shown in FIG. 16BD and outputs the image data DO shown in
As described above, when n-bit image data are extended to (n+2)-bit data, producing gray level jumps of size 22 from 4Y to (4Y+4) in regions with gradually changing gray levels, a third-order epsilon filter (m=3) cannot produce the middle gray level (4Y+2), leaving a gap between gray levels (4Y+1) and (4Y+3), resulting in insufficient smoothing.
Therefore, it is necessary to set the number of taps of the epsilon filter to 2α or more (m≧2α).
The operation of an eighth-order order epsilon filter (m=8), shown in
The analog image signal SA illustrated in
The bit extender 5 converts the gray level Y in the image data DI in
The data storage unit 7 in
The output of the first difference calculator 8-1 is:
ED(l4)=DM(l4)−DM(c)=4Y−4Y=0
The output of the second difference calculator 8-2 is:
ED(l3)=DM(l3)−DM(c)=4Y−4Y=0
The output of the third difference calculator 8-3 is:
ED(l2)=DM(l2)−DM(c)=4Y−4Y=0
The output of the fourth difference calculator 8-4 is:
ED(l1)=DM(l1)−DM(c)=4Y−4Y=0
The output of the fifth difference calculator 8-5 is:
ED(c)=DM(c)−DM(c)=4Y−4Y=0
The output of the sixth difference calculator 8-6 is:
ED(r1)=DM(r1)−DM(c)=(4Y+4)−4Y=4
The output of the seventh difference calculator 8-7 is:
ED(r2)=DM(r2)−DM(c)=(4Y+4)−4Y=4
The output of the eighth difference calculator 8-8 is:
ED(r3)=DM(r3)−DM(c)=(4Y+4)−4Y=4
Accordingly, zero (0) is input to epsilon decision units 9-1 to 9-5 and four (4) is input to epsilon decision units 9-6 to 9-8. If the threshold value ε is equal to four (ε=4), then the difference data ED(l4) to ED(r3) are all equal to or less than the threshold value ε, so the corresponding decision data EE(l4) to EE(r3) are all ‘1’.
The conditional weighted averager 10 multiplies the difference data having decision data of ‘1’ by coefficients ak and sums the results, excluding difference data with decision data of ‘0’ from the sum. If the coefficients ak (al4, al3, al2, al1, ac, ar1, ar2, ar3) are all one-eighth (0.125), then the output EM of the conditional weighted averager 10 is given by equation (8).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (8) is carried out for each successive pixel.
The data adder 11 adds the image data DS shown in
As described above, when n-bit image data are converted to (n+2)-bit image data, an epsilon filter of order eight (m=8), like an epsilon filter of order four (m=4), can interpolate gray levels with values of (4Y+1), (4Y+2), and (4Y+3) to fill in a jump (of size 22) from a gray level 4Y to a gray level (4Y+4) produced by bit extension in a region with gradually changing gray levels, but as shown in
Cases in which the orders of the epsilon filter were four and eight (m=4 and m=8) have been described. As the order m is increased from 2α to 2×2α, and then to 22×2α, an image with gray levels that change increasingly gradually is obtained. When m is a power of two (such as 2α, 2×2α, or 22×2α), the epsilon filter can carry out division by bit shifting, which eliminates the need for a divider circuit.
The processing steps carried out by the image display apparatus in the first embodiment will be described with reference to the flowchart in
First, an image signal SA is input to the input terminal 1; the receiver 2 receives the image signal SA and outputs the n-bit image data DI (step ST1).
The image data DI output from the receiver 2 are input to the bit extender 5 in the gray scale expansion processor 3. The bit extender 5 extends the image data DI by a bits and outputs (n+α)-bit image data DS to the data storage unit 7 (step ST2).
The data storage unit 7 receives the (n+α)-bit image data DS, holds the data for m horizontally consecutive pixels, and outputs the pixel data as DM(1) to DM(m) to the difference calculators 8-1 to 8-m (step ST3).
The difference calculators 8-1 to 8-m receive the successive pixel data DM(1) to DM(m), take differences between the m successive pixels and the pixel of interest DM(c), and output the difference data ED(1) to ED(m) to the epsilon decision units 9-1 to 9-m (step ST4).
The epsilon decision units 9-1 to 9-m receive the difference data ED(1) to ED(m), and output decision data EE(1) to EE(m) that indicate which difference data to select (step ST5).
The conditional weighted averager 10 receives the difference data ED(1) to ED(m) and the decision data EE(1) to EE(m), takes a weighted average of the difference data selected by the decision data, and outputs the weighted average value EM (step ST6).
The data adder 11 receives the weighted average value EM and the basic (n+α)-bit data DM(c) for the pixel of interest, adds EM and DM(c), and outputs the result as the image data DO (step ST7). The output image data DO are input to the display unit 4, which displays the image (step ST8).
Another exemplary structure of the image display apparatus in the first embodiment will be described with reference to
The difference calculators 8-1 to 8-m and the epsilon decision units 9-1 to 9-m process n-bit data. The threshold value for the epsilon decision units 9-1 to 9-m is set to ‘1’, because there is no bit extender preceding the epsilon filter 27.
The conditional weighted averager 30 calculates a conditional weighted average as described in the examples above (e.g.,
The data adder 31 extends the n-bit input data DM(c) to (n+α) bits and adds the result to the EM data.
Although the image display apparatus in
Referring to
An analog image signal SA is input from the input terminal 1 to the receiver 2, converted to n-bit image data DI, and output to the gray scale expansion processor 3. The gray scale expansion processor 3 includes a bit extender 5 and a two-dimensional m-order epsilon filter 12, which convert the n-bit image data to (n+α)-bit data and output the data to the display unit 4. The bit extender 5 outputs (n+α)-bit image data obtained by extending the n-bit image data DI by a bits to the two-dimensional m-order epsilon filter 12.
The two-dimensional m-order epsilon filter 12 carries out processing on a two-dimensional region measuring h pixels horizontally by v pixels vertically (where h and v are integers equal to or greater than 2α. The two-dimensional m-order epsilon filter 12 is an edge-preserving smoothing filter that processes pixels aligned two-dimensionally so as to preserve large abrupt changes (edges) while smoothing out small abrupt changes as if they were noise. The two-dimensional m-order epsilon filter 12 in
The image data DO are output to the display unit 4, which is capable of displaying (n+α)-bit image data.
The two-dimensional processing carried out by the epsilon filter 12 is described by equation (9).
In this equation, x(i, j) is the gray level of the input; y(i, j) is the gray level of the output; ak is a coefficient; k indicates relative horizontal pixel position from the pixel of interest (i, j); k′ indicates relative vertical pixel position from the pixel of interest (i, j); ε is a threshold value.
A case in which α equals two (α=2) and n-bit image data are expanded to the (n+2)-bit data will now be described.
First, the operation when a signal with gray levels that change gradually in the horizontal direction is input to the epsilon filter 12 will be described.
The receiver 2 converts the analog image signal SA to n-bit image data DI and outputs the image data DI to the bit extender 5 in the gray scale expansion processor 3.
The operation of the bit extender 5 will be described with reference to
The bit extender 5 extends the n-bit image data as shown in
The two-bit extension of the image data DI in
The data storage unit 37 in
The data storage unit 37 includes four line memories LM1 to LM4 and four sets of four cascaded flip-flops FFt2_1 to FFt2_4, FFt1_1 to FFt1_4, FFc_1 to FFc_4, and FFb1_1 to FFb1_4. The image signal DS is input through the line memories LM1 to LM4 to the four sets of flip-flops.
Each of the line memories LM1 to LM4 can store one horizontal line of image data; the four line memories LM1 to LM4 hold four consecutive lines of data.
Starting from the left ends of the lines and proceeding in sequence to the right, data for pixels aligned vertically in the same column are simultaneously read from the line memories LM1 to LM4 and supplied to the first flip-flops FFt2_1, FFt1_1, FFc_1, and FFr1_1 in the four sets of flip-flops. The supplied data are then transferred sequentially through the four flip-flops in each set.
As a result, data in a (4×4)-pixel region as illustrated in
The data storage unit 37 outputs data in the region TL surrounded by the bold line in
The first difference calculator 8-1 takes the difference ED(l2, t2) between the value of the pixel of interest DM(c, c) and the value of the data of the left-top neighboring pixel DM(l2, t2), and outputs the difference data to the first epsilon decision unit 9-1 and the conditional weighted averager 10. Difference calculators 8-2 to 8-16 similarly generate difference data ED(l2, t1) to ED(r1, b1) based on neighboring pixel data DM(l2, t1) to DM(r1, b1), and output the difference data to epsilon decision units 9-2 to 9-16 and the conditional weighted averager 10.
The output of the first difference calculator 8-1 is:
ED(l2,t2)=4Y−(4Y+4)=−4
The output of the second difference calculator 8-2 is:
ED(l2,t1)=4Y−(4Y+4)=−4
The output of the third difference calculator 8-3 is:
ED(l2,c)=4Y−(4Y+4)=−4
The output of the fourth difference calculator 8-4 is:
ED(l2,b1)=4Y−(4Y+4)=−4
The output of the fifth difference calculator 8-5 is:
ED(l1,t2)=4Y−(4Y+4)=−4
The output of the sixth difference calculator 8-6 is:
ED(l1,t1)=4Y−(4Y+4)=−4
The output of the seventh difference calculator 8-7 is:
ED(l1,c)4Y−(4Y+4)=−4
The output of the eighth difference calculator 8-8 is:
ED(l1,b1)=4Y−(4Y+4)=−4
The output of the ninth difference calculator 8-9 is:
ED(c,t2)=(4Y+4)−(4Y+4)=0
The output of the tenth difference calculator 8-10 is:
ED(c,t1)=(4Y+4)−(4Y+4)=0
The output of the eleventh difference calculator 8-11 is:
ED(c,c)=(4Y+4)−(4Y+4)=0
The output of the twelfth difference calculator 8-12 is:
ED(c,b1)=(4Y+4)−(4Y+4)=0
The output of the thirteenth difference calculator 8-13 is:
ED(r1,t2)=(4Y+4)−(4Y+4)=0
The output of the fourteenth difference calculator 8-14 is:
ED(r1,t1)=(4Y+4)−(4Y+4)=0
The output of the fifteenth difference calculator 8-15 is:
ED(r1,c)=(4Y+4)−(4Y+4)=0
The output of the sixteenth difference calculator 8-16 is:
ED(r1,b1)=(4Y+4)−(4Y+4)=0
The detailed operation of the epsilon decision units is the same as in the first embodiment. The first epsilon decision unit 9-1 generates ‘1’ when the difference ED(12, t2) is greater than ε, and generates ‘0’ when the difference ED(l2, t2) is equal to or less than E. Epsilon decision units 9-2 to 9-16 similarly generate decision data EE(l1, t2) to EE(r1, b1) conditional on the difference data ED(l1, t2) to ED(r1, b1), and output the decision data to the conditional weighted averager 10.
In the example shown in
The conditional weighted averager 10 calculates the weighted average of the difference data ED(l2, t2) to ED(r1, b1) conditional on the decision data EE(l2, t2) to EE(r1, b1). When the decision data are ‘1’, the difference data are multiplied by respective coefficients ak and the products are summed; when the decision data are ‘0’, the products are not included in the sum.
If the coefficients ak (al2t2, al1t2, . . . , ar1b1) are all one-sixteenth (0.0625), then since the decision data EE(l2, t2) to EE(r1, b1) are all ‘1’ in the example above, the output EM of the conditional weighted averager 10 is given by equation (10).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (10) is carried out for each consecutive pixel.
The data adder 11 adds the image data DS shown in
The operation when the epsilon filter 12 receives a signal with gray levels that change gradually in the vertical direction will now be described.
The receiver 2 converts the analog input signal SA to n-bit digital image data DI and outputs the result to the gray scale expansion processor 3, more specifically to the bit extender 5 in the gray scale expansion processor 3.
The operation of the bit extender 5 will be described with reference to
The bit extender 5 extends the n-bit image data shown in
The two-bit extension of the image data DI in
DM(l2,t2)=4Y,
DM(l2,t1)=4Y,
DM(l2,c)=4Y+4,
DM(l2,b1)=4Y+4,
DM(l1,t2)=4Y,
DM(l1,t1)=4Y,
DM(l1,c)=4Y+4,
DM(l1,b1)=4Y+4,
DM(c,t2)=4Y,
DM(c,t1)=4Y,
DM(c,c)=4Y+4,
DM(c,b1)=4Y+4,
DM(r1,t2)=4Y,
DM(r1,t1)=4Y,
DM(r1,c)=4Y+4,
DM(r1,b1)=4Y+4.
The output of the first difference calculator 8-1 is:
ED(l2,t2)=4Y−(4Y+4)=−4.
The output of the second difference calculator 8-2 is:
ED(l2,t1)=4Y−(4Y+4)=−4.
The output of the third difference calculator 8-3 is:
ED(l2,c)=(4Y+4)−(4Y+4)=0
The output of the fourth difference calculator 8-4 is:
ED(l2,b1)=(4Y+4)−(4Y+4)=0
The output of the fifth difference calculator 8-5 is:
ED(l1,t2)=4Y−(4Y+4)=−4.
The output of the sixth difference calculator 8-6 is:
ED(l1,t1)=4Y−(4Y+4)=−4.
The output of the seventh difference calculator 8-7 is:
ED(l1,c)=(4Y+4)−(4Y+4)=0
The output of the eighth difference calculator 8-8 is:
ED(l1,b1)=(4Y+4)−(4Y+4)=0
The output of the ninth difference calculator 8-9 is:
ED(c,t2)=4Y−(4Y+4)=−4.
The output of the tenth difference calculator 8-10 is:
ED(c,t1)=4Y−(4Y+4)=−4.
The output of the eleventh difference calculator 8-11 is:
ED(c,c)=(4Y+4)−(4Y+4)=0
The output of the twelfth difference calculator 8-12 is:
ED(c,b1)=(4Y+4)−(4Y+4)=0
The output of the thirteenth difference calculator 8-13 is:
ED(r1,t2)=4Y−(4Y+4)=−4.
The output of the fourteenth difference calculator 8-14 is:
ED(r1,t1)=4Y−(4Y+4)=−4.
The output of the fifteenth difference calculator 8-15 is:
ED(r1,c)=(4Y+4)−(4Y+4)=0
The output of the sixteenth difference calculator 8-16 is:
ED(r1,b1)=(4Y+4)−(4Y+4)=0
The first epsilon decision unit 9-1 generates ‘1’ when the difference ED(l2, t2) is greater than ε, and generates ‘0’ when the difference ED(l2, t2) is equal to or less than ε. Epsilon decision units 9-2 to 9-16 generate similar decision data EE(l1, t2) to EE(r1, b1) conditional on the difference data ED(l1, t2) to ED(r1, b1). The decision data are output to the conditional weighted averager 10.
In the example shown in
The conditional weighted averager 10 calculates the weighted average of the difference data ED(l2, t2) to ED(r1, b1) conditional on the decision data EE(l2, t2) to EE(r1, b1). When the decision data are ‘1’, the difference data are multiplied by respective coefficients ak and the products are summed; when the decision data are ‘0’, the products are not included in the sum.
If the coefficients ak (al2t2, al1t2, . . . ar1b1) are all one-sixteenth (0.0625), then since the decision data EE(l2, t2) to EE(r1, b1) are all ‘1’ in the example above, the output EM of the conditional weighted averager 10 is given by equation (11).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (11) is carried out for each consecutive pixel.
The data adder 11 adds the image data DS shown in
As described above, this embodiment can increase the number of gray levels in a region in which the gray levels change gradually in at least the horizontal or vertical direction. That is, when the order m of the epsilon filter 12 is sixteen (22×22), jumps by four (a power of two) gray levels from 4Y to (4Y+4) in a region with gradually changing gray levels as shown in
As in the first embodiment, if the order m of the epsilon filter 12 is greater than (2α×2α), an image with gray levels that change more gradually can be obtained. If m is a power of two such as 2α×2α, (2×2α)×2α, 2+×(2×2α), or (2×2α)×(2×2α), the epsilon filter 12 can carry out division by bit shifting, which eliminates the need for a divider circuit.
The processing steps carried out by the image display apparatus in the second embodiment will be described with reference to the flowchart in
First, an image signal SA is input to the input terminal 1; the receiver 2 receives the image signal SA and outputs n-bit image data DI (step ST11).
The image data DI output from the receiver 2 are input to the bit extender 5 in the gray scale expansion processor 3. The bit extender 5 extends the image data DI by a bits and outputs (n+α)-bit image data DS to the data storage unit 37 (step ST12).
The data storage unit 37 receives the (n+α)-bit image data DS, holds pixels in an (h×v)-pixel (an m-pixel) region (where h≧2α, v≧2α, h×v=m, m≧2α×2α), and outputs the pixel data as DM(1) to DM(m) to the difference calculators 8-1 to 8-m (step ST13).
The difference calculators 8-1 to 8-m receive the consecutive pixel data DM(1) to DM(m) in the (h×v)-pixel region, take differences between the m pixels and the pixel of interest DM(c), and output the difference data ED(1) to ED(m) to the epsilon decision units 9-1 to 9-m (step ST14).
The epsilon decision units 9-1 to 9-m receive the difference data ED(1) to ED(m) and output decision data EE(1) to EE(m) that indicate which difference data to select (step ST15).
The conditional weighted averager 10 receives the difference data ED(1) to ED(m) and the decision data EE(1) to EE(m), takes a weighted average of the difference data selected by the decision data, and outputs the weighted average value EM (step ST16).
The data adder 11 receives the weighted average value EM and the basic (n+α)-bit data DM(c) for the pixel of interest, adds EM and DM(c), and outputs the result as the image data DO (step ST17). The image data DO are input to the display unit 4, which displays the image (step ST18).
Another exemplary structure of the image display apparatus in the second embodiment will be described with reference to
The difference calculators 8-1 to 8-m and the epsilon decision units 9-1 to 9-m process n-bit data. The threshold value for the epsilon decision units 9-1 to 9-m is set to ‘1’, because there is no bit extender preceding the epsilon filter 28.
The conditional weighted averager 30 calculates a conditional weighted average as described in the examples above (
The data adder 31 extends the n-bit input data DM(c) to (n+α) bits and adds the result to the EM data.
Although the image display apparatus in
Referring to
An analog image signal SA is input from the input terminal 1 to the receiver 2, converted to n-bit image data DI, and output to the gray scale expansion processor 3. The gray scale expansion processor 3 includes a bit extender 5, a one-dimensional v-order vertical epsilon filter 13, and a one-dimensional h-order horizontal epsilon filter 14, which convert the n-bit image data to (n+α)-bit data and output the data to the display unit 4.
The bit extender 5 outputs (n+α)-bit image data DS obtained by extending the n-bit image data DI by a bits to the one-dimensional v-order vertical epsilon filter 13 and one-dimensional h-order horizontal epsilon filter 14.
The one-dimensional v-order vertical epsilon filter 13 carries out processing on the basic (n+α)-bit data in the vertical direction, operating as an edge-preserving smoothing filter that processes pixels aligned vertically with the pixel of interest so as to preserve large abrupt changes (edges) while smoothing out small abrupt changes as if they were noise. The one-dimensional v-order vertical epsilon filter 13 shown in
The one-dimensional h-order horizontal epsilon filter 14 carries out processing on the (n+α)-bit data VDO received from the one-dimensional v-order vertical epsilon filter 13 in the horizontal direction, operating as an edge-preserving smoothing filter that processes pixels aligned in the horizontal direction with the pixel of interest so as to preserve large abrupt changes (edges) while smoothing out small abrupt changes as if they were noise. The one-dimensional h-order horizontal epsilon filter 14 shown in
The case in which α equals two (α=2), so that n-bit image data are expanded to (n+2)-bit data, will now be described.
First, the operation when a signal with gray levels that change gradually in the horizontal direction is input to the epsilon filter will be described.
The receiver 2 converts the analog image signal SA to n-bit image data DI and outputs the image data DI to the bit extender 5 in the gray scale expansion processor 3.
The operation of the bit extender 5 will be described with reference to
The bit extender 5 extends the n-bit image data shown in
The two-bit extension of the image data DI in
The operation of the one-dimensional v-order vertical epsilon filter 13 will now be described.
The vertical data storage unit 15 in
The vertical data storage unit 15 in
Each of the line memories LM1 to LM4 can store one horizontal line of image data; the four line memories LM1 to LM4 hold four consecutive lines of data.
Starting from the left ends of the lines and proceeding in sequence to the right, data for pixels aligned vertically in the same column are simultaneously read from the line memories LM1 to LM4 and supplied to the flip-flops FFt2_1, FFt1_1, FFc_1, FFb1_1. Accordingly, data for a region consisting of four vertically consecutive pixels as shown in
The data held by the flip-flops FFt2_1, FFt1_1, FFc_1, and FFb1_1 are output simultaneously as data VDM(t2), VDM(t1), VDM(c), and VDM (b1).
For example, the vertical data storage unit 15 holds the data for the region surrounded by the bold line TL in
VDM(t2)=4Y+4
VDM(t1)=4Y+4
VDM(c)=4Y
VDM(b1)=4Y
In this way, the vertical data storage unit 15 simultaneously outputs the image data VDM(c) of the pixel of interest P(c) at pixel position c together with the image data VDM(t2), VDM(t1), and VDM(b1) of three adjacent pixels aligned vertically with the pixel of interest.
The first vertical difference calculator 16-1 generates the difference VED(t2) between the value of the pixel of interest VDM(c) and the value of the data of the top neighboring pixel VDM(t2), and outputs the difference data to the first epsilon decision unit 9-1 and the conditional weighted averager 10. The difference calculators 8-2 to 8-16 generate similar differences VED(t1), VED(c), and VED(b1) from the pixel data VDM(t1), VDM(c), and VDM(b1), and output the difference data to the epsilon decision units 9-2 to 9-16 and the conditional weighted averager 10.
The output of the first vertical difference calculator 16-1 is:
VED(t2)=VDM(t2)−VDM(c)=(4Y+4)−4Y=4.
The output of the second vertical difference calculator 16-2 is:
VED(t1)=VDM(t1)−VDM(c)=(4Y+4)−4Y=4.
The output of the third vertical difference calculator 16-3 is:
VED(c)=VDM(c)−VDM(c)=4Y−4Y=0
The output of the fourth vertical difference calculator 16-4 is:
VED(b1)=VDM(b1)−VDM(c)=4Y−4Y=0
Like the epsilon decision units described in the first embodiment, the first vertical epsilon decision unit 17-1 generates ‘0’ when the difference VED(t2) is greater than ε and generates ‘1’ when the difference VED(t2) is equal to or less than ε. The vertical epsilon decision units 17-2 to 17-4 generate similar decision data VEE(t1), VEE(c), and VEE(b1) based on the difference data VED(t1), VED(c), and VED(b1). The generated decision data are output to the vertical conditional weighted averager 18.
In the example shown in
The vertical conditional weighted averager 18 calculates the weighted average of the difference data VED(t2) to VED(b1) conditional on the decision data VEE(t2) to VEE(b1). When the decision data are ‘1’, the difference data are multiplied by respective coefficients ak and the products are summed; when the decision data are ‘0’, the products are not included in the sum.
If the coefficients ak (at2, at1, ac, ab1) are all one-fourth (0.25), then since the decision data VEE(t2) to VEE(b1) are all ‘1’, the output VEM of the vertical conditional weighted averager 18 is given by equation (12).
The above processing is carried out sequentially on the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (12) is carried out for each successive pixel.
The vertical data adder 19 adds the image data DS shown in
The operation of the one-dimensional h-order horizontal epsilon filter 14 will now be described. The basic data storage unit 20 in the one-dimensional h-order horizontal epsilon filter 14 has the same structure as the data storage unit 7 in the first embodiment, holds data for four horizontally consecutive pixels such as the data in the region surrounded by the bold line TL in
In the example shown, the basic data storage unit 20 outputs 4Y as BDM(l2) and BDM(l1), and (4Y+4) as BDM(c) and BDM(r1), to the basic data difference calculators 21-1 to 21-4. In this way, the basic data storage unit 20 simultaneously outputs the image data BDM(c) of the pixel of interest P(c) and the image data BDM(l2), BDM(l1), and BDM(r1) of neighboring pixels aligned horizontally and consecutively with the pixel of interest.
The output of the first basic data difference calculator 21-1 is:
BED(l2)=BDM(l2)−BDM(c)=4Y−(4Y+4)=−4.
The output of the second basic data difference calculator 21-2 is:
BED(l1)=BDM(l1)−BDM(c)=4Y−(4Y+4)=−4.
The output of the third basic data difference calculator 21-3 is:
BED(c)=BDM(c)−BDM(c)=(4Y+4)−(4Y+4)=0
The output of the fourth basic data difference calculator 21-4 is:
BED(r1)=BDM(r1)−BDM(c)=(4Y+4)−(4Y+4)=0
In this way, the basic data difference calculators 21-1 to 21-4 calculate the differences between the image data BDM(c) for the pixel of interest and the image data for the four horizontally consecutive pixels surrounding and including the pixel of interest, and output the results to the horizontal epsilon decision units 22-1 to 22-4.
Like the epsilon decision units described in the first embodiment, the first horizontal epsilon decision unit 22-1 generates ‘0’ when the difference BED(l2) is greater than ε and generates ‘1’ when the difference BED(l2) is equal to or less than ε. Horizontal epsilon decision units 22-2 to 22-4 generate similar decision data HEE(l1), HEE(c), and HEE(r1) from the difference data BED(l1), BED(c), and BED(r1). The generated decision data are output to the horizontal conditional weighted averager 25.
In the example shown in
The operation of the horizontal data storage unit 23 will be described with reference to
In the example shown, the horizontal data storage unit 23 outputs 4Y as HDM(l2) and HDM(l1), and (4Y+3) as HDM(c) and HDM(r1), to the horizontal difference calculators 24-1 to 24-4.
The output of the first horizontal difference calculator 24-1 is:
HED(l2)=HDM(l2)−HDM(c)=4Y−(4Y+3)=−3.
The output of the second horizontal difference calculator 24-2 is:
HED(l1)=HDM(l1)−HDM(c)=4Y−(4Y+3)=−3.
The output of the third horizontal difference calculator 24-3 is:
HED(c)=HDM(c)−HDM(c)=(4Y+3)−(4Y+3)=0
The output of the fourth horizontal difference calculator 24-4 is:
HED(r1)=HDM(r1)−HDM(c)=(4Y+3)−(4Y+3)=0
In this way, the horizontal difference calculators 24-1 to 24-4 calculate the differences between the image data HDM(c) for the pixel of interest and the image data for four horizontally consecutive pixels surrounding and including the pixel of interest, and output the difference data as HED(l2), HED(l1), HED(c), and HED(r1) to the horizontal conditional weighted averager 25.
Concurrent with the output of the difference data with respect of the pixel of interest, the horizontal epsilon decision units 22-1 to 22-4 output horizontal epsilon decision data HEE(l2), HEE(l1), HEE(c), and HEE(r1) with respect to the same pixel of interest to the horizontal conditional weighted averager 25.
The horizontal conditional weighted averager 25 calculates the weighted average of the difference data HED(l2) to HED(r1) conditional on the decision data HEE(l2) to HEE(r1). When the decision data are ‘1’, the difference data are multiplied by respective coefficients ak and the products are summed; when the decision data are ‘0’, the products are not included in the sum.
If the coefficients ak (al2, al1, ac, ar1) are all one-fourth (0.25), then since the decision data HEE(l2) to HEE(r1) are all ‘1’, the output HEM of the horizontal conditional weighted averager 25 is given by equation (13).
The above processing is carried out sequentially on the image data VDO supplied from the vertical data adder 19 and the image data DS supplied from the bit extender 5, each pixel becoming the pixel of interest in turn, so an operation similar to equation (13) is carried out for each successive pixel.
The horizontal data adder 26 adds the image data VDO shown in
As described above, this embodiment can increase the number of effective gray levels in a region with gradually changing gray levels in at least the horizontal or vertical direction. When the order h of the horizontal epsilon filter is equal to 22 (h=4) and the order v of the vertical epsilon filter is equal to 22 (h=4), jumps by four (a power of two) gray levels from 4Y to (4Y+4) in a region with gradually changing gray levels as shown in
As in the first embodiment, if the orders h and v of the epsilon filters are set to values greater than 2α, an image with gray levels that change more gradually can be obtained. If h and v are powers of two such as 2α, (2×2α) or (22×2α), the epsilon filters can carry out division by bit shifting, which eliminates the need for a divider circuit.
In the above description, the thresholds ε of the epsilon filters were equal to 2α, but this is not a limitation. Using thresholds ε greater than 2α can not only increase the number of gray levels but also reduce noise.
The processing steps carried out by the image display apparatus in the third embodiment will be described with reference to the flowchart in
First, an image signal SA is input to the input terminal 1; the receiver 2 receives the image signal SA and outputs n-bit image data DI (step ST21).
The image data DI output from the receiver 2 are input to the bit extender 5 in the gray scale expansion processor 3. The bit extender 5 extends the image data DI by a bits and outputs (n+α)-bit image data DS to the data storage unit 37 (step ST22).
The vertical data storage unit 15 in the one-dimensional v-order vertical epsilon filter 13 receives the (n+α)-bit image data DS, holds data for v vertically consecutive pixels (v≧2α), and outputs the pixel data as VDM(1) to VDM(v) to the vertical difference calculators 16-1 to 16-v (step ST23).
The vertical difference calculators 16-1 to 16-v receive the vertically consecutive pixel data VDM(1) to VDM(v), take differences between the v pixels and the pixel of interest VDM(c), and output the difference data VED(1) to VED(v) to the vertical epsilon decision units 17-1 to 17-v (step ST24).
The vertical epsilon decision units 17-1 to 17-v receive the difference data VED(1) to VED(v) and output decision data VEE(1) to VEE(v) that indicate which difference data to select (step ST25).
The vertical conditional weighted averager 18 in the one-dimensional v-order vertical epsilon filter 13 receives the difference data VED(1) to VED(v) and the decision data VEE(1) to VEE(v), takes a weighted average of the difference data selected by the decision data, and outputs the weighted average value VEM (step ST26).
The vertical data adder 19 in one-dimensional v-order vertical epsilon filter 13 receives the weighted average value VEM and the basic data VDM(c) for the pixel of interest, adds VEM and VDM(c), and outputs the result as image data VDO (step ST27).
The basic data storage unit 20 in the one-dimensional h-order horizontal epsilon filter 14 receives the (n+α)-bit image data DS, holds data for h horizontally consecutive pixels (h≧2α), and outputs the data as BDM(1) to BDM(h) (step ST28).
The basic data difference calculators 21-1 to 21-h in the one-dimensional h-order horizontal epsilon filter 14 receive the horizontally consecutive data BDM(1) to BDM(h), take differences between the h pixels and the pixel of interest BDM(c), and output the difference data BED(1) to BED(h) (step ST29).
The horizontal epsilon decision units 22-1 to 22-h in the one-dimensional h-order horizontal epsilon filter 14 receive the difference data BED(1) to BED(h) and output decision data HEE(1) to HEE(h) that indicate which difference data to select (step ST30).
The horizontal data storage unit 23 in the one-dimensional h-order horizontal epsilon filter 14 receives the (n+α)-bit image data VDO, holds data for h horizontally consecutive pixels (h≧2α), and outputs the data as HDM(1) to HDM(h) (step ST31).
The horizontal difference calculators 24-1 to 24-h in the one-dimensional h-order horizontal epsilon filter 14 receive the horizontally consecutive data HDM(1) to HDM(h), take differences between the h pixels and the pixel of interest HDM(c), and output the difference data HED(1) to HED(h) (step ST32).
The horizontal conditional weighted averager 25 in the one-dimensional h-order horizontal epsilon filter 14 receives the difference data HED(1) to HED(h) and the decision data HEE(1) to HEE(h), takes a weighted average of the difference data selected by the decision data, and outputs the weighted average value HEM (step ST33).
The horizontal data adder 26 in the one-dimensional h-order horizontal epsilon filter 14 receives the weighted average value HEM and the basic (n+α)-bit data HDM(c) for the pixel of interest, adds HEM and HDM(c), and outputs the result as the image data DO (step ST34).
The output image data DO are input to the display unit 4, which displays the image (step ST18).
Another exemplary structure of the image display apparatus in the third embodiment will be described with reference to
The bit-extending one-dimensional v-order vertical epsilon filter 29 shown in
The vertical difference calculators 16-1 to 16-v and the vertical epsilon decision units 17-1 to 17-v process n-bit data. The threshold value for vertical epsilon decision units 17-1 to 17-v is set to ‘1’, because there is no bit extender preceding the epsilon filter 29.
The vertical conditional weighted averager 38 calculates a conditional weighted average as described in the example above (
The vertical data adder 39 extends the n-bit input data VDM(c) to (n+α) bits and adds the result to the VEM data.
The one-dimensional h-order horizontal epsilon filter 14 in
Although the image display apparatus in
Examples in which a was equal to two (α=2) and n-bit image data were extended to (n+2) bits were described in the first to third embodiments. These examples are useful when eight-bit digital broadcast television pictures are displayed on a display unit with ten-bit gray-scale resolution, but the present invention is not limited to any particular value of the parameter α.
Similarly, it was assumed that the threshold ε is 2α in the first to third embodiments, but the present invention is not limited to this threshold value. Using values of ε greater than 2α can improve the interpolation performance at edges that are not perfectly sharp, and enables the image processing apparatus to remove more noise that may have been present in the original image.
Since the differences ED(c), ED(c, c), VED(c), and BED(c) between the pixel of interest and itself are always zero and accordingly the results of the epsilon decisions EE(c), EE(c, c), VEE(c), and HEE(c) based on these differences are always ‘1’, it is possible to omit the difference calculators (such as the third difference calculator 8-3 in
Similarly, the third horizontal difference calculator 24-3 in
The present invention can be applied to image display apparatus in a liquid crystal, plasma, or other type of television set.
The conditional weighted averages in the examples above were all simple conditional averages, that is, all weights were equal, but unequal weights may also be used.
Those skilled in the art will recognize that further variations are possible within the scope of the invention, which is defined in the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2007-142878 | May 2007 | JP | national |