This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2017-128475, filed on Jun. 30, 2017, the entire contents of which are incorporated herein by reference.
One embodiment of the present invention is related to an image processing device, an image processing method and a display system mounted with these.
For example, a liquid crystal display panel for monochrome display or color display, an electroluminescence display panel using the electroluminescence of an inorganic material or an organic material, and a plasma display panel and the like are used in the display part of a mobile electronic device such as a mobile phone and a mobile information terminal, or a display part such as a personal computer and a television receiver.
In the case where the gradation display capability of pixels of the display part is low, in other words, when the number of gradations of the pixels is small, a contour-like line is generated in the gradation part of the image, and image quality deteriorates. In such a case, it is known that image quality is improved by using an error diffusion method.
For example, a technique has been developed in which a display surface is divided into a plurality of sections (error diffusion blocks), and error diffusion is performed only in each section. The transmission range of a change in error diffusion on the display surface is limited by this technique. Therefore, flickering on the screen on the display surface is reduced by this technique.
An image processing device includes a storage part storing an error value corresponding to at least one of second pixels in an image display device, the image display device having a display screen, the display screen having a plurality of pixels, the plurality of pixels having a first pixel and the second pixels, the second pixels surrounding the first pixel, a pixel data calculator calculating pixel data corresponding to the first pixel based on a coefficient in response to a gradation of an input data in the second pixel and the error value corresponding to the second pixel, a quantized data calculator quantizing the calculated pixel data and calculating quantized data, and an error value calculator corresponding the calculated pixel data and an error value with the quantized data and storing in the storage part.
An image processing method includes dividing a display screen into a plurality of regions and performing an error diffusion process on input data input to an image processing device including the display screen having a plurality of pixels, storing an error value corresponding to the pixel in a storage part, calculating pixel data corresponding to a first pixel based on a coefficient in response to a gradation of the input data in a second pixel and the error value corresponding to the second pixel surrounding a first pixel included in the plurality of pixels, quantizing the pixel data and calculating quantized data, calculating an error value based on the pixel data and the quantized data, and corresponding the error value with the first pixel and storing in the storage part.
An image display system includes the image processing device and an image display device including a display screen having a plurality of pixels, and a gradation of the pixel is controlled based on data on which the image processing device has performed an error diffusion processing.
The embodiments of the present invention are explained below while referring to the drawings. However, the present invention can be carried out in many different modes and is not to be interpreted as being limited to the description of the embodiments exemplified herein. In addition, although the structure of each part may be schematically represented compared with their actual form in order to make the explanation clearer, such explanation is only an example and does not limit an interpretation of the present invention. Furthermore, in the present specification and each diagram, elements similar to those described above with reference to a previously mentioned figure are denoted with the same reference numerals (or reference numerals followed by numerals such as a and b) and a detailed explanation may be omitted as appropriate.
Furthermore, letters added with “first” and “second” with respect to each element are convenience signs used to distinguish each element and do not have a further meaning unless otherwise specified.
In the present embodiment, the structure of an image processing device, an image processing method, and an image display device mounted with the same according to one embodiment of the present invention is explained.
The display part 20 is formed by, for example, a liquid crystal display panel of a monochrome display. However, the structure and method of the display part 20 are not particularly limited. In addition to the liquid crystal display panel, the display part 20 may be formed from a well-known display device such as an electroluminescence display panel or a plasma display panel. In addition, the display part 20 may be formed by a display medium such as electrically rewritable electronic paper. Furthermore, the display part 20 may be a monochrome display or a color display. Herein, in order to promote understanding of the present embodiment, the display part 20 is explained assuming it is a monochrome display. Therefore, only one input data vd_in is input for one pixel PX in during one frame.
On a display surface 21 of the display part 20, a total of M×N pixels PX are arranged in a two-dimensional matrix in which M number of pixels are arranged in a horizontal direction and N number of pixels are arranged in a vertical direction. In the present specification, it is sometimes described as X (n, m). This indicates that it is a structure X corresponding to a pixel PX located at the nth row and the mth column among a plurality of structures X arranged for each pixel PX. Furthermore, X is an arbitrary structure, n is an integer of 1 to N, and m is an integer of 1 to M.
In the case when the display part 20 is a transmission type display panel, the display part 20 is formed so as to control the light transmittance of each pixel PX based on a value of the output data vd_out supplied from the gradation converter 10. By this control, the amount of light which is transmitted from a light source device not shown in the diagram is controlled, and an image is displayed on the display part 20 as a result. In the case when the display part 20 is a reflection type display panel, the display part 20 is formed to control the light reflectance ratio of each pixel PX based on the value of the output data vd_out supplied from the gradation converter 10. By this control, the amount of reflected external light is controlled, and an image is displayed on the display part 20 as a result.
The gradation converter 10 includes an error diffusion processor 11 which performs gradation processing by the error diffusion method. In addition, the gradation converter 10 is formed to convert input data vd_in(n, m) to output data vd_out(n, m) using the error diffusion processor 11. The output data vd_out(n, m) obtained by this conversion is supplied to the display part 20. Details of conversion processing are described in detail later wile referring to
In addition, the gradation converter 10 stores a plurality of error diffusion blocks BL (see
The error diffusion block BL according to one embodiment of the present invention has a rectangular shape each of the same size as is shown in
Input data vd_in(n, m) is supplied to the gradation converter 10 in order from the first row (order where n increases by 1 from the top to the bottom). Within each row, the input data vd_in(n, m) is supplied in order along the arrow OR shown in the diagram (order where m increases by 1, from left to right). The error diffusion processor 11 inside the gradation converter 10 is configured to convert the input data vd_in(n, m) supplied sequentially in this way into output data vd_out(n, m) on a pixel PX by a pixel PX at a time and supply the output data vd_out(n, m) to the display part 20. The order along the arrow OR shown in the diagram may also be described as the scanning order. That is, the order along the arrow OR shown in
The storage part 41 is formed to store a first error value Err1(n, m) and corrected error value Err2′(n, m) for each pixel PX. The first error value Err1(n, m) is calculated by the first error value calculator 36 in the process of sequentially performing gradation processing for each pixel PX. The corrected error value Err2′(n, m) is calculated by the corrected error value calculator 40.
The first pixel data calculator 30 calculates the first pixel data vd1_mod(n, m) according to the gradation of the input data vd_in(n, m). Specifically, the first pixel data vd1_mod(n, m) is calculated based on the input data vd_in(n, m) and the first error value Err1. Here, the first error value Err1 is stored in the storage part 41 with respect to each of those belonging to the same error diffusion block BL as the pixel PX(n, m) among a predetermined number of pixels adjacent to the pixel PX(n, m) in a predetermined direction in the pixel PX(n, m) (target pixel) corresponding to the input data vd_in. Details are described later while referring to
The second pixel data calculator 31 calculates the second pixel data vd2_mod(n, m) according to the gradation of the input data vd_in(n, m). Specifically, the second pixel data vd2_mod(n, m) is calculated based on the input data vd_in(n, m) and the corrected error value Err2′. Here, the corrected error value Err2′ is stored in the storage part 41 for each of a predetermined number of pixels adjacent to the pixel PX(n, m) in the predetermined direction described above. Unlike the first pixel data calculator 30, the second pixel data calculator 31 does not limit the range referring to the corrected error value Err2′ to [those belonging to the same error diffusion block BL as the pixel PX(n, m)]. Therefore, the second pixel data vd2_mod(n, m) is calculated without limiting the error diffusion range to within the error diffusion block BL.
The first quantized data calculator 32 calculates first quantized data LV1(n, m) obtained by quantizing the first pixel data vd1_mod(n, m) which is calculated by the first pixel data calculator 30. In addition, the first output pixel data calculator 33 calculates the first output pixel data vd1_out(n, m) by converting the first quantized data LV1(n, m) into 3 bit data. Details of these processes are explained later while referring to
The second quantized data calculator 34 calculates second quantized data LV2(n, m) obtained by quantizing the second pixel data vd2_mod(n, m) which is calculated by the second pixel data calculator 31. In addition, the second output pixel data calculator 35 calculates the second output pixel data vd2_out(n, m) by converting the second quantized data LV2(n, m) into 3 bit data. Details of these processes are explained later while referring to
The first error value calculator 36 calculates a first error value Err1(n, m) based on the difference between the first pixel data vd1_mod(n, m) and the first quantized data LV1(n, m). Specifically, as is shown in the following equation (1), a value obtained by subtracting the first quantized data LV1(n, m) from the first pixel data vd1_mod(n, m) is calculated as the error value Err1(n, m).
Err1(n,m)=vd1_mod(n,m)−LV1(n,m) (1)
The first error value Err1(n, m) calculated by the first error value calculator 36 is supplied to the storage part 41 and is stored in the storage part 41 as the first error value Err1 corresponding to the pixel PX(n, m) while the error diffusion processor 11 carries out processing in the same frame.
The second error value calculator 37 calculates the second error value Err2(n, m) based on the difference between the second pixel data vd2_mod(n, m) and the second quantized data LV2(n, m). Specifically, as is shown in the following equation (2), a value obtained by subtracting the second quantized data LV2(n, m) from the second pixel data vd2_mod(n, m) is calculated as the error value Err2(n, m).
Err2(n,m)=vd2_mod(n,m)−LV2(n,m) (2)
The limit error value calculator 38 calculates a limit error value Err1_mux by limiting the first error value Err1 (nm) according to the values of the first quantized data LV1(n, m) and the second quantized data LV2(n, m). The limit error value Err1_mux is used later when the corrected error value calculator 40 calculates the corrected error value Err2′(n, m). Details of the processing of the limit error value calculator 38 are explained later while referring to
The judgment part 39 judges whether or not the pixel PX(n, m) is within a predetermined range from the boundary of a plurality of error diffusion blocks BL. Specifically, the judgment described above is caied out by performing a threshold judgment of a horizontal direction distance H and a vertical direction distance V shown in
The corrected error value calculator 40 calculates a corrected error value Err2′(n, m) of the pixel PX(n, m) by correcting the second error value Err2(n, m) in a direction approaching the first error value Err1(n, m) according to the judgment result of the judgment part 39. More specifically, the corrected error value calculator 40 corrects the second error value Err2(n, m) in a direction approaching the first error value Err1 (n, m) in the case where a pixel PX(n, m) is within a predetermined range from the boundary of a plurality of error diffusion blocks BL based on the judgment result of the judgment part 39. As described above, the corrected error value calculator 40 calculates the corrected error value Err2′(n, m) of the pixel PX(n, m) which is the corrected second error value Err2(n, m). On the other hand, in the case when the judgment result of the judgment part 39 shows that the pixel PX(n, m) is not within the predetermined range from the boundary of a plurality of error diffusion blocks BL, the corrected error value calculator 40 sets the corrected error value Err1_mux calculated by the limit value calculator 38 as the corrected error value Err2′(n, m) of the pixel PX(n, m).
The corrected error value Err2′(n, m) calculated by the corrected error value calculator 40 is supplied to the storage part 41 and is stored in the storage part 41 as the corrected error value Err2′ corresponding to a pixel PX(n, m) while the error diffusion processor 11 carries out processing n the same frame.
The output data vd_out(n, m) is calculated from the first pixel data vd1_mod(n, m) which is calculated based on the first error value Err1. The first error value Err1 changes discontinuously when it oversteps the boundary B. As described above, the boundary of an error diffusion block becomes apparent due to a discontinuous change of the first error value Err1. In the present embodiment, the output data vd_out(n, m) is generated from the second pixel data vd2_mod(n, m) which is calculated based on the corrected error value Err2′. Next, the corrected error value Err2′ continuously changes including the boundary B. Therefore, according to the present embodiment, it is possible to suppress the boundary B of the error diffusion block BL becoming apparent.
Processing performed by each part in the error diffusion processor 11 is explained in more detail below while referring to the flow chart shown in
When the input data vd_in(n, m) is supplied, the first pixel data calculator 30 performs a process (process of calculating vd1_mod(n, m)) for calculating the first pixel data vd1_mod(n, m) (step S4).
vd1_mod(n,m)=α×Err1(n−1,m−1)+b×Err1(n−1,m)+c×Err1(n−1,m+1)+d×Err1(n,m−1)+vd_in(n,m) (3)
Here, the constants a, b, c, and d in the equation (3) are normalization coefficients of diffusion errors and are determined in advance so that a+b+c+d=1. There are a number of methods for selecting each specific value. For example, in the Floyd-Steinberg method, a= 1/16, b= 5/16, c= 3/16, and d= 7/16. In addition, in the Sierra Filter Lite method, a=0, b=¼, c=¼, and d=½. Which method is adopted may be decided considering the quality required for the image display system 1.
vd1_mod(n,m)=vd_in(n,m) (4)
vd1_mod(n,m)=b×Err1(n−1,m)+c×Err1(n−1,m+1)+vd_in(n,m) (5)
vd1_mod(n,m)=d×Err1(n,m−1)+vd_in(n,m) (6)
In one embodiment of the present invention, the first pixel data vd1_mod(n, m) calculated by the first pixel data calculator 30 is calculated according to the gradation of the input data vd_in(n, m). Therefore, the coefficient to be multiplied by the first error value Err1 changes according to the gradation of the input data vd_in(n, m).
The operation of the circuit for calculating the first pixel data vd1_mod(n, m) is explained. The first error value Err1, the input data vd_in(n, m) and (n, m) are input to the first pixel data calculator 30. The first error value Err1 is input to the first boundary judgment circuit 103 and the second boundary judgment circuit 104. The first boundary judgment circuit 103 and the second boundary judgment circuit 104 perform a process for judging the relationship between the pixel PX(n, m) and the boundary.
Specifically, in the first boundary judgment circuit 103 and the second boundary judgment circuit 104, the relationship between the pixel PX(n, m) and the boundary is judged and the first error value Err1 corresponding to a pixel in each direction surrounding the pixel of interest PX (n, m) is multiplied by the diffusion error normalization coefficient.
The input data vd_in(n, m) is input to the latch circuit 107. The latch circuit 107 stores the input data vd_in(n, m) and outputs the input data vd_in(n, m) for each input data vd_in(n, m) to be processed. Data 129 output from the latch circuit is input to the selection signal generation circuit 108. The selection signal generation circuit 108 judges whether or not the gradation of the data 129 outputted from the latch circuit is below 25 gradations, and outputs a selection signal 130.
Next, data 127 which is multiplied by the diffusion error normalization coefficient and the selection signal 130 are input to the selection circuit 109. According to the selection signal 130, the selection circuit 109 selects either the data obtained by multiplying the diffusion error normalization coefficient of less than 25 gradations or data obtained by multiplying the diffusion error normalization coefficient of 25 or more gradations and outputs the result. For example, in the case when the gradation of the data 129 output from the latch circuit is less than 25 gradations, the selection signal 130 is a signal for selecting data which is multiplied by a diffusion error normalization coefficient of less than 25 gradations, and the selection circuit 109 outputs data obtained by multiplying the diffusion error normalization coefficient of less than 25 gradations.
Next, the data 128 which is output from the selection circuit 109 and the data 129 which is output from the latch circuit are input to the data synthesis circuit 110. The data synthesis circuit 110 adds the data 128 output from the selection circuit 109 and the data 129 output from the latch circuit, and outputs the result. The data output from the data synthesis circuit 110 is the first pixel data vd1_mod(n, m). In the case where there are a plurality of first error values Err1 to be input, the first pixel data calculator 30 may add data obtained by multiplying by the diffusion error normalization coefficient according to each error value Err1, and then may add the data 129 output from the latch circuit. Details are explained while referring to
Here, in the case when the gradation of the input data vd_in(n, m) is equal to or more than 25 gradations, the constants a, b, c, and d which express the diffusion error normalization coefficient shown in equation (3) are respectively a is 0, b is ¼, c is ¼, and d is ½.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL in both the horizontal direction and the vertical direction, vd1— mod(n, m) is the equation (4) mentioned previously.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the vertical direction, vd1_mod(n, m) is given by the following equation (7).
vd1_mod(n,=¼Err1(n−1,m)+¼Err1(n−1,m+1)vd_in(n,m) (7)
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the horizontal direction, vd1_mod(n, m) is given by the equation (8).
vd1_mod(n,m)=½Err1(n,m−1)+vd_in(n,m) (8)
In the case where the pixel PX(n, m) is not located at the block boundary of the error diffusion block BL in either the horizontal or vertical directions, vd1_mod(n, m) is given by the equation (9).
vd1_mod(n,m)=¼Err1(n−1,m)+¼Err1(n−1,m+1)+½Err1(n,m−1)+vd_in(n,m) (9)
On the other hand, in the case when the gradation of the input data vd_in(n, m) is less than 25 gradations, the constants a, b, c, and d which express the diffusion error normalization coefficients shown in equation (3) are a is 0, b is ½, c is 0, and d is ½.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL in both the horizontal direction and the vertical direction, vd1_mod(n, m) is given by the equation (4) described above.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the vertical direction, vd1_mod(n, m) is given by the following equation (10).
vd1_mod(n,m)=½Err1(n−1,m)+0×Err1(n−1,m+1)+vd_in(n,m) (10)
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the horizontal direction, vd1_mod(n, m) is given by the equation (11).
vd1_mod(n,m)=½Err1(n,m−1)+vd_in(n,m) (11)
In the case where the pixel PX(n, m) is not located at the block boundary of the error diffusion block BL in either the horizontal or vertical direction, vd1_mod(n, m) is given by the equation (12).
vd1_mod(n,m)=½Err1(n−1,m+1)+½Err1(n,m−1)+vd_in(n,m) (12)
Returning to
vd2_mod(n,m)=α×Err2′(n−1,m−1)+b×Err2′(n−1,m)+c×Err2′(n−1,m+1)+d×Err2′(n,m−1)+vd_in(n,m) (13)
In addition, even in the case where a process is carried out by the second pixel data calculator 31 for calculating the second pixel data vd2_mod(n, m), it is the same as in the case where a process is carried out by the first pixel data calculator 30 for calculating the first pixel data vd1_mod(n, m). That is, also in the case where the second pixel data calculator 31 calculates the second pixel data vd2_mod(n, m), whether the gradation of the input data vd_in(n, m) is 25 gradations or more or less than 25 gradations, the constants a, b, c, and d that represent the diffusion error normalization coefficient are changed. In the explanation of
In the corrected error value Err2′, in the case when the gradation of the input data vd_in(n, m) is equal to or more than 25 gradations, the constants a, b, c and d expressing the diffusion error normalization coefficient shown in equation (13) are a is 0, b is ¼, c is ¼ and d is ½. In the case when the gradation of the input data vd_in(n, m) is 25 gradations or more, the second pixel data calculator 31 performs processing by the second boundary judgment circuit 104.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL in both the horizontal direction and the vertical direction, vd2_mod(n, m) is given as the equation (4) mentioned above.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the vertical direction, vd2_mod(n, m) becomes the following equation (14).
vd2_mod(n,m)=¼Err2′(n−1,m)+¼Err2′(n−1,m+1)+vd_in(n,m) (14)
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the horizontal direction, vd2_mod(n, m) becomes the following equation (15).
vd2_mod(n,m)=½Err2′(n,m−1)+vd_in(n,m) (15)
In the case where the pixel PX(n, m) is not located at the block boundary of the error diffusion block BL in either the horizontal or vertical direction, vd2_mod(n, m) becomes the following equation (16).
vd2_mod(n,m)=¼Err2′(n−1,m)+¼Err2′(n−1,m+1)+½Err2′(n,m−1)+vd_in(n,m) (16)
On the other hand, in the case when the gradation of the input data vd_in(n, m) is less than 25 gradations, the constants a, b, c, and d which express the diffusion error normalization coefficients shown in equation (13) are a is 0, b is ½, c is 0, and d is ½. In the case when the gradation of the input data vd_in(n, m) is less than 25 gradations, the second pixel data calculator 31 performs processing by the first boundary judgment circuit 103.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL in both the horizontal direction and the vertical direction, vd2_mod(n, m) is the equation (4) mentioned above.
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the vertical direction, vd2_mod(n, m) is given by the following equation (17).
vd2_mod(n,m)=½Err2′(n−1,+0×Err2′(n−1,m+1)+vd_in(n,m) (17)
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the horizontal direction, vd2_mod(n, m) is given by the following equation (18).
vd2_mod(n,m)=Err2′(n,m−1)+vd_in(n,m) (18)
In the case where the pixel PX(n, m) is not located at the block boundary of the error diffusion block BL in either the horizontal or vertical direction, vd2_mod(n, m) is given by the following equation (19).
vd2_mod(n,m)=½Err2′(n−1,m+1)+½Err2′(n,m−1)+vd_in(n,m) (19)
Next, calculation of first quantized data LV1(n, m) is carried out by the first quantized data calculator 32 and calculation of first output pixel data vd1_out(n, m) is carried out by the first output pixel data calculator 33 (process of calculating [LV1(n, m), vd1_out(n, m)] of step S6). In addition, calculation of second quantized data LV2(n, m) is carried out by the second quantized data calculator 34 and calculation of the second output pixel data vd2_out(n, m) is carried out by the second output pixel data calculator 35 (process of calculating [LV2(n, m), vd2_out(n, m)] of step S7).
First, the range of the value of the first pixel data vd1_mod(n, m) is judged by the first quantized data calculator 32 (step S22). In the example of
The first quantized data calculator 32 calculates the first quantized data LV1(n, m) based on the judgement result of step S30. In the example of
When the first quantized data LV1(n, m) is determined in this way, the first output pixel data calculator 33 calculates the value of the first output pixel data vd1_out(n, m), which is 3 bit data. More specifically, in the case when the value of the first quantized data LV1(n, m) is [255], for example, the first output pixel data calculator 33 sets the first output pixel data vd1_out(n, m) as [111b]. Similarly, in the case when the value of the first quantized data LV1(n, m) is [219, the value of the first output pixel data vd1_out(n, m) is set as [110 b]. In the case when the value of the first quantized data LV1(n, m) is [182, the value of the first output pixel data vd1_out(n, m) is set as [101b]. In the case when the value of the first quantized data LV1(n, m) is [146], the value of the first output pixel data vd1_out(n, m) is set as [100b]. In the case when the value of the first quantized data LV1(n, m) is [109], the value of the first output pixel data vd1_out(n, m) is set as [011b]. In the case when the value of the first quantized data LV1(n, m) is [73], the value of the first output pixel data vd1_out(n, m) is set as [010b]. In the case when the value of the first quantized data LV1(n, m) is [36], the value of the first output pixel data vd1_out(n, m) is set as [001b]. In the case when the value of the first quantized data LV1(n, m) is [0], the value of the first output pixel data vd1_out(n, m) is set as [000b].
Returning to
Next, calculation of the first error value Err1(n, m) by the first error value calculator 36 and calculation of the second error value Err2(n, m) by the second error value calculator 37 are carried out (step S9 and step S10). Specific methods of these calculations are as shown in the equations (1) and (2) described above. As described above, the first error value Err1(n, m) calculated by the first error value calculator 36 is stored in the storage part 41 shown in
Here, the first pixel data vd1_mod and the first quantized data LV1 which are used when calculating the first error value Err1 are limited to within the error diffusion block BL (that is, as explained while referring to
Finally, a process is carried out for calculating the corrected error value Err2′(n, m) by the limit error value calculator 38, the judgement part 39, and the corrected error value calculator 40 ([Err2′(n, m) calculation process] in step S11).
In the case when the first output pixel data vd1_out(n, m) is larger than the second output pixel data vd2_out(n, m), the limit error value calculator 38 sets the numerical value [152] to the limit error value Err1_mux. On the other hand, in the case when the first output pixel data vd1_out(n, m) is smaller than the second output pixel data vd2_out(n, m), the limit error value calculator 38 sets the numerical value [−152] to the limit error value Err1_mux. In other cases, that is, in the case when the first output pixel data vd1_out(n, m) and the second output pixel data vd2_out(n, m) are equal, the limit error value calculator 38 sets the first error value Err1(n, m) to the limit error value Err1_mux.
Next, the judgment part 39 makes a threshold value judgement of a horizontal direction distance H and vertical direction distance V shown in
The judgment part 39 stores in advance the threshold value reg_bdr_h_size as the threshold value of the horizontal direction distance H. In addition, the threshold value reg_bdr_v_size is stored in advance as a threshold value of the vertical direction distance V. Next, by comparing these with the horizontal direction distance H and the vertical direction distance V, the threshold value judgment described above is carried out (step S41 and step S42).
In the case when the judgment part 39 judges that the horizontal direction distance H is smaller than the threshold value reg_bdr_h_size or the vertical direction distance V is smaller than the threshold value reg_bdr_v_size, that is, in the case when the pixel PX(n, m) is located within a predetermined range from the upper end or the left end of the error diffusion block BL, the corrected error value calculator 40 corrects the second error value Err2(n, m) in the direction approaching the first error value Err1(n, m), and thereby the corrected error value Err2′(n, m) of the pixel PX(n, m) is calculated. Specifically, as is shown in the following equation (20), a value based on a value obtained by subtracting the second error value Err2(n, m) from the limit error value Err1_mux (more specifically, a value obtained by dividing a value obtained by subtracting the second error value Err2(n, m) from the limit error value Err1_mux by a predetermined number N) is added to the second error value Err2(n, m) to calculate the corrected error value Err2′(n, m) (step S44). Furthermore, [16] is preferred as a specific value of the predetermined number N.
In addition, instead of the reciprocal of the predetermined number N described above, a function of the number of pixels from the boundary of the error diffusion block or a function of n and m may be used. In addition, the second term of equation (20) may be a nonlinear function of Err2(n, m) and Err1_mux.
On the other hand, in the case when the judgment part 39 judges that the horizontal direction distance H is equal to or larger than the threshold value reg_bdr_h_size and the vertical direction distance V is equal to or larger than the threshold value reg_bdr_v_size, that is, in the case when the pixel PX(n, m) is not located within the predetermined range from the upper end or the left end of the error diffusion block BL, the corrected error value calculator 40 sets the limit error value Err1_mux as the corrected error value Err2′(n, m) (step S43).
Err2′(n,m)=Err1_mux (21)
As described above, the corrected error value Err2′(n, m) calculated by the corrected error value calculator 40 is stored in the storage part 41 as the corrected error value Err2′ corresponding to the pixel PX(n, m). Next, it is used when calculating the second pixel data vd2_mod with respect to other pixels adjacent to the pixel PX(n, m) (specifically, the four pixels such as PX(n, m+1), PX(n+1, m−1), PX(n+1, m) and PX(n+1, m+1)).
Returning to
As explained above, according to the image display system 1 of the present embodiment, the output data vd_out(n, m) is generated from the second pixel data vd2_mod(n, m) which is calculated based on the corrected error value Err2′. Next, since the corrected error value calculator 40 calculates the corrected error value Err2′ by the process described above, the corrected error value Err2′ continuously changes including the boundary B. Therefore, according to the image display system 1 of the present embodiment, it is possible to suppress conspicuousness of the boundary of the error diffusion block.
Although the preferred embodiment according to one embodiment of the present invention was explained above, the present invention is not limited to this embodiment, and the present invention can be applied in various modes without departing from the concept thereof.
For example, in the embodiment described above, the structure according to one embodiment of the present invention was explained on the premise of using the display part 20 in a monochrome display. As described above, the structure according to one embodiment of the present invention can also be applied to the case of using the display part 20 in a color display. In this case, input data vd_in(n, m) is input to the gradation converter 10 for each color (for example, red (R), green (G), blue (B), and white (W)). Therefore, in the structure according to one embodiment of the present invention, in the case of using the display part 20 in a color display, the processes described above may be performed for each color.
In the case of using the display part 20 in a color display, the arrangement of the error diffusion blocks BL may be the same regardless of color or may be different for each color. An arrangement that can obtain an optimum display result may be appropriately selected.
In addition, in the embodiment described above, although each individual error diffusion block BL is formed by a rectangle configured by four sides parallel to each in a horizontal direction and a vertical direction, it is also possible to configure individual error diffusion blocks BL using other shapes. The shape of each individual error diffusion block BL is arbitrary and may be appropriately selected so as to obtain an optimum display result.
In addition, the input data vd_in input to the error diffusion process part 11 in the embodiment described above may be dithered by a dithering process part not shown in the diagram of the gradation converter 10. For example, the dithering process part sets the originally 8 bit image data to 6 bits by dithering 8, and data of the 6 bit image is converted to 4 bits by dithering 6 and the result may be input to the error diffusion process part 11 as the input data vd_in.
In addition, an effect of one embodiment of the present invention is that it is particularly effective in the case where video is embedded in a region of one par in a screen and the other regions are still images. Furthermore, when the error diffusion process part 11 performs processing, it judges whether the input data vd_in to be displayed indicates that video is embedded in a region of one part in the screen and the other regions are still images, and processing may be changed according to the result. Specifically, in the case when the judgment result is affirmative (YES), the processing described in the present embodiment is performed. On the other hand, in the case when the judgement result is negative (NO), for example, the first pixel data vd1_mod(n, m) which is calculated in step S4 of
As explained above, by performing a gradation process using the error diffusion method in which the constants a, b, c, and d representing the diffusion error normalization coefficient are changed by the gradation of the input data vd_in(n, m), it is possible to continuously change the block boundary of an error diffusion block BL. Therefore, the block boundary of the error diffusion block BL is not apparent, and it is possible to provide a high quality image. By utilizing one embodiment of the present invention, it is possible to make the block boundary of the error diffusion block BL which is particularly apparent on the low gradation side less apparent.
In the present embodiment, another image processing device according to one embodiment of the present invention is explained. Furthermore, explanations of the same structure as in the first embodiment may be omitted.
In
Specifically, in step 52, in the case when the gradation of the input data vd_in(n, m) is 65 gradations or more, the constants a, b, c and d which represent the diffusion error normalization coefficient shown in the equation (3) are a is 0, b is ¼, c is ¼, and d is ½. Since step 52 performs the same processes as step S23 which was explained using
In step 53 in the case when the gradation of the input data vd_in(n, m) is less than 65 and 25 or more, processing is performed according to the flowchart shown in
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL in both the horizontal direction and the vertical direction, vd1_mod(n, m) is given as the equation (4) described above.
In the case where the pixel PX(n, m) is located positioned at the block boundary of the error diffusion block BL only in the vertical direction, vd1_mod(n, m) is given by the following equation (22).
vd1_mod(n,m)=⅜Err1(n−1,m)+⅛Err1(n−1,m+1)+vd_in(n,m) (22)
In the case where the pixel PX(n, m) is located at the block boundary of the error diffusion block BL only in the horizontal direction, vd1_mod(n, m) is given by the equation (23).
vd1_mod(n,m)=½Err1(n,m−1)+vd_in(n,m) (23)
In the case where the pixel PX(n, m) is not located at the block boundary of the error diffusion block BL in either the horizontal direction or the vertical direction, vd1_mod(n, m) is expressed by the equation (24).
vd1_mod(n,m)=⅜Err1(n−1,m)+⅛Err1(n−1,m+1)+½Err1(n,m−1)+vd_in(n,m) (24)
On the other hand, in step S54 in the case when the gradation of the input data vd_in(n, m) is less than 25 gradations, processing is performed according to the flow chart shown in
In addition, even in the case where the second pixel data calculator 31 performs a process for calculating the second pixel data vd2_mod(n, m), similar to the case where first pixel data calculator 30 performs a process for calculating the first pixel data vd1_mod(n, m), the constants a, b, c, and d representing the diffusion error normalization coefficient are changed between 65 gradations or more, 25 gradations or more and less than 65 gradations, and less than 25 gradations. The second pixel data calculator 31 includes a second pixel data calculator 31A (not shown in the diagram) in the case where the gradation of the input data vd_in(n, m) is less than 25 gradations, a second pixel data calculator 31C (not shown in the diagram) in the case where the gradation of the input data vd_in(n, m) is 25 gradations or more and less than 65 gradations, and a second pixel data calculator 31D (not shown in the diagram) in the case where the gradation of the input data vd_in(n, m) is 65 gradations or more. In the case where a process is performed for calculating the second pixel data vd2_mod(n, m), in the calculation method of the second pixel data vd2_mod(n, m), the first pixel data vd1_mod(n, m) is replaced by the second pixel data vd2_mod(n, m) in each equation in step S23 explained in
In the present embodiment,
As described above, depending on the range of the gradation of the input data vd_in (n, m) in the process of calculating vd1_mod(n, m), the constants a, b, c, and d representing diffusion error normalization coefficients are changed. By performing the gradation processing by the error diffusion method as described above, it is possible to make the block boundary of the error diffusion block BL less apparent. In particular, in the case where the block boundary of the error diffusion block BL is apparent on the low gradation side, by using the image processing device, the image processing method, and the image display system which is mounted with these according to one embodiment of the present invention, a block boundary of a an error diffusion block BL becomes less apparent and it is possible to provide an image processing device capable of displaying a high-quality image, a processing method of the image processing device and an image display system.
In the present embodiment, still another example of the image processing device according to one embodiment of the present invention is explained. Furthermore, explanations of structures similar to those of the first embodiment or the second embodiment may be omitted.
The first quantized data calculator 32 includes a first quantization processor 32A, a second quantization processor 32B, and a selection circuit 209. The first quantized data calculator 32 is input with the first pixel data vd1_mod(n, m) and the input data vd_in(n, m). In addition, the first quantized data calculator 32 outputs the first quantized data LV1(n, m). Furthermore, (n, m) may be input to each functional block and may have a role of linking each data with the coordinates of each data.
The operation of the circuit for calculating the first quantized data LV1(n, m) is explained. The first pixel data vd1_mod(n, m) and input data vd_in(n, m) are input to the first quantized data calculator 32. The first pixel data vd1_mod(n, m) is input to the first quantization processor 32A and the second quantization processor 32B. The first quantization processor 32A performs encoding or quantization of gradation of input data from 8 bits to 3 bits. The second quantization processor 32B performs encoding or quantization of gradation of input data from 6 bits to 3 bits. The first quantization processor 32A and the second quantization processor 32B output encoded or quantized data 227.
According to a selection signal 230, the selection circuit 209 selects either the encoded or quantized data from 8 bits to 3 bits or the encoded or quantized data from 6 bits to 3 bits among the encoded or quantized data 227. The first quantized data calculator 32 outputs the first pixel data vd1_mod(n, m). Furthermore, the selection signal 230 may be a signal externally input or a signal generated internally. The circuit structure and functions may be appropriately examined so that the present invention does not depart from the its concept so that it is possible for the selection signal 230 to select either encoded or quantized data from 8 bits to 3 bits or encoded or quantized data from 6 bits to 3 bits.
First, according to step S60, the first quantized data calculator 32 selects either encoding or quantizing of the gradation of input data from 8 bits to 3 bits or encoding or quantization of the gradation of the input data from 6 bits to 3 bits to be performed on the first pixel data vd1_mod(n, m).
In the case where the gradation of the input data is selected to be encoded or quantized from 8 bits to 3 bits, a quantization process 1 is performed by the first quantization processor 32A according to step S61. In the case where the gradation of the input data is selected to be encoded or quantized from 6 bits to 3 bits, a quantization process 2 is performed by the second quantization processor 32B according to step S62.
Since the process of the quantization process 1 according to step S61 is the same as step S30 explained in
In step S62, the range of values of the first pixel data vd1_mod(n, m) is judged. In the example of
The first quantized data calculator 32 calculates the first quantized data LV1(n, m) based on the judgement result of step S62. In the example of
When the first quantized data LV1(n, m) is determined in this way, the first output pixel data calculator 33 next calculates the value of the first output pixel data vd1_out(n, m) which is 3 bit data. More specifically, in the case when the value of the first quantized data LV1(n, m) is [252], for example, the first output pixel data calculator 33 sets the value of the first output pixel data vd1_out(n, m) as [111b]. Similarly, in the case when the value of the first quantized data LV1(n, m) is [216], the value of the first output pixel data vd1_out(n, m) is set as [110b]. In the case when the value of the first quantized data LV1(n, m) is [180], the value of the first output pixel data vd1_out(n, m) is set as [101 b]. In the case when the value of the first quantized data LV1(n, m) is [144], the value of the first output pixel data vd1_out(n, m) is set as [100b]. In the case when the value of the first quantized data LV1(n, m) is [108], the value of the first output pixel data vd1_out(n, m) is set as [011 b]. In the case when the value of the first quantized data LV1(n, m) is [72], the value of the first output pixel data vd1_out(n, m) is set as [010b]. In the case when the value of the first quantized data LV1(n, m) is [36], the value of the first output pixel data vd1_out(n, m) is set as [001 b]. In the case when the value of the first quantized data LV1(n, m) is [0], the value of the first output pixel data vd1_out(n, m) is set as [000b].
As described above, the first quantized data LV1(n, m), the first output pixel data vd1_out(n, m), the second quantized data LV2(n, m), and the second output pixel data vd2_out(n, m) are calculated.
In the present embodiment, in the process of calculating LV1(n, m), vd1_out(n, m), an example of quantization processing is shown using the first quantized data calculator 32 which includes two processors, a first quantization processor 32A for performing encoding or quantization of the gradation of input data from 8 bits to 3 bits, and a second quantization processor 32B for performing encoding or quantization of the gradation of input data from 6 bits to 3 bits. However, the present invention is not limited to this example. For example, a third quantization processor 32C for performing encoding or quantization of the gradation of input data from 4 bits to 3 bits, and a fourth quantization processor 32D for performing encoding or quantization of the gradation of input data from 12 bits to 3 bits may be included so that it is possible to handle gradation of input data or 4 bits or gradation of input data of 12 bits. The quantization process may be appropriately examined according to the extent to which the block boundary of the error diffusion block BL is desired to be less apparent. Furthermore, the second quantized data calculator 34 is the same.
As is described in the present embodiment, since the first quantized data calculator 32 and the second quantized data calculator 34 have a plurality of quantization processors, it is possible to perform image processing using one image processing device with respect to the gradation of a plurality of input data. That is, even if the signal source changes, image processing can be performed by one image processing circuit by using the image processing device illustrated in this embodiment.
Each embodiment described above as embodiments of the present invention can be implemented in combination as appropriate as long as they do not contradict each other.
In the present specification, although an image processing device, image processing method and an image display system in which the image processing device and the image processing method are mounted have mainly been exemplified as disclosed examples, a display device which displays pixel data processed by an image processing device may use another self-light emitting display device, a liquid crystal display device, or an electronic paper type display device having an electrophoretic element, or what is called a flat panel type display device. In addition, the size of the display device can be applied from a medium to small size to a large size without any particular limitations.
Even other actions and effects different from the action and effect brought about by the aspects of each embodiment described above, those which are obvious from the description of the present specification or those that could easily be predicted by a person skilled in the art should naturally be interpreted as being provided by the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2017-128475 | Jun 2017 | JP | national |