The present invention relates to an image processing device which makes area determination (area separation) of a target pixel of inputted image data in a scanner, a digital copying machine, a fax machine and so on, and which performs image processing for each area.
In a conventional image processing device, as disclosed in Japanese Unexamined Patent Publication no. 125857/1996 (Tokukaihei 8-125857, published on May 17, 1996), first and second characteristic parameters are found and inputted to a determination circuit using a nerve circuit network so as to perform area determination (area separation) of a target pixel. Here, the nerve circuit network is a non-linear type and has been learned in advance. Besides, the non-linear type means that inputs of first and second characteristic parameters are respectively converted to coordinates on a vertical axis and a horizontal axis, and a separating state is shown on the coordinates.
When performing area separation using the above non- linear separating method, it is necessary to widely memorize coordinates. These coordinates are called a lookup table, which is adopted for converting an output based on an input axis. Therefore, such a lookup table uses a memory for storing data. Further, the conventional arrangement has required considerably large memory.
The objective of the present invention is to provide an image processing device capable of making fast area determination with high accuracy at low cost in a simple manner, without the necessity for memory with a large capacity.
In order to attain the above objective, the image processing device of the present invention is characterized in that upon area determination of a target pixel in inputted image data, total densities are computed for at least four kinds of sub pixel groups provided in a main pixel group, which is constituted by a plurality of pixels including a target pixel, and area determination is made based on these total densities.
According to this arrangement, total densities of the four kinds of sub pixel groups are computed and area determination is made based on these total densities, so that memory with large capacity is not necessary for area determination. Further, the total densities are computed only by addition so as to provide an image processing device capable of fast area determination with high accuracy at low cost in a simple manner.
For a fuller understanding of the nature and advantages of the invention, reference should be made to the ensuing detailed description taken in conjunction with the accompanying drawings.
Referring to
As shown in
In an image processing of the image processing device, firstly, image data is inputted from a CCD (Charge Coupled Device) section 1 to the input density changing section 2. In the input density changing section 2, the inputted image data is changed to density data, and the image data changed to density data is transmitted to the area separating section 3.
In the area separating section 3, as will be described later, regarding inputted image data, a variety of area separation parameters such as a total density and a complication degree of a sub mask, and an area of a target pixel in image data is determined based on a computing result. The determined area is transmitted as area data to the filter processing section 4, the gamma correcting section 6, and the error diffusing section 7.
Image data from the area separating section 3 is transmitted to the filter processing section 4 as it is. In the filter processing section 4, as will be described later, a filter processing is performed on each area of image data based on a predetermined filter coefficient. The image data which has been subjected to a filter processing is transmitted to the scaling section 5.
In the scaling section 5, a scaling operation is performed based on a predetermined scaling rate. The image data which has been subjected to a scaling operation is transmitted to the gamma correcting section 6. In the gamma correcting section 6, as will be described later, a gamma changing operation is performed on a gamma correcting table which has been prepared in advance for each area of the image data. The image data which has been subjected to a gamma changing operation is transmitted to the error diffusing section 7.
In the error diffusing section 7, as will be described later, an error diffusing operation is performed based on an error diffusing parameter, which has been set in advance for each area of the image data. The image data processed in the error diffusing section 7 is transmitted to the external device 8. The external device 8 includes a memory, a printer, a PC, and so on.
The following discusses area separation processing performed by the area separating section 3.
Two sub masks are prepared as sub masks used in a main scanning direction. First sub masks in a main scanning direction are indicated by i0, i1, i2, i3, i4, i5, and i6. Second sub masks in a main scanning direction are indicated by i21, i22, i23, i24, i25, i26, and i27. The first and second sub masks in a main scanning direction make a pair.
Besides, two sub masks are prepared as sub masks used in the sub scanning direction. First sub masks in the sub scanning direction are indicated by i0, i7, i14, and i21. Second sub masks in the sub scanning direction are indicated by i6, i13, i20, and i27. The first and second sub masks in the sub scanning direction make another pair.
The following Table 1 shows the names of the first and second sub masks in the main scanning direction and the first and second sub masks in the sub scanning direction.
As mentioned above, in an area separation processing of the area separating section 3, the main masks and the sub masks are set and a total density is computed for each of the sub masks.
First, when a total density of the sub mask ‘mask-m1’ is represented by sum-m1, the total density is computed as follows.
sum-m1=i0+i1+i2+i3+i4+i5+i6
In the same manner, when a total density of the sub mask ‘mask-m2’ is represented by sum-m2, the total density is computed as follows.
sum-m2=i21+i22+i23+i24+i25+i26+i27
Furthermore, a total density is computed in the same manner regarding the sub masks in a sub scanning direction. When a total density of the sub mask ‘mask-s1’ is represented by sum-s1, the total density is computed as follows.
sum-s1=i0+i7+i14+i21
In the same manner, when a total density of the sub mask ‘mask-s2’ is represented by sum-s2, the total density is computed as follows.
sum-s2=i6+i13+i20+i27
The four kinds of sub masks and two pairs of total densities are computed by the above equations. Subsequently, a sum S of total density differences of the pairs, i.e., a sum of a) a total density difference between two sub masks in a main scanning direction and b) a total density difference of two sub masks in a sub scanning direction is computed by the following equation.
S=|sum-m1−sum-m2|+(|sum-s1−sum-s2|)×α (1)
Here, α of the equation (1) is a coefficient for normalizing a difference in size (number of pixels) between a sub mask in a main scanning direction and a sub mask in a sub scanning direction. In this case, a is set at 7/4.
The sum S of total density differences is computed as above and is compared with a predetermined threshold value. When the sum S is larger than a threshold value, the area is determined as an edge area; otherwise, the are is determined as a non-edge area. The following Table 2 shows determination results of the area separation processing with a threshold value set at “150”.
As described above, it is possible to perform area separation between picture continuous tone part and a 10- point character part simply by computing the sum S of total density differences. Additionally, a range of a threshold value is not particularly limited.
Moreover, in the area separation, a size (number of pixels) in a sub scanning direction is relatively small so as to save line memory. Furthermore, in the area separation, the sub masks are disposed on the right, left, upper, and bottom ends of the main mask. A position of the sub mask can be arbitrarily changed according to a size of the main mask, a detected image, and an input resolution.
Here, in the area separation, the sub mask differs in shape (size) between a main scanning direction and a sub scanning direction, so that a normalization coefficient is multiplied. However, a normalization coefficient does not need to be multiplied as long as the shape remains the same.
Regarding the area separation, the following describes an example using a complication degree.
Together with a sum S of total density differences regarding each pair of sub masks, a total of density differences is computed regarding pixels adjacent in a main scanning direction in the main mask and pixels adjacent in a sub scanning direction. Here, a total of density differences is referred to as a complication degree. However, in the area separation, a total of density differences is computed in a main scanning direction for every other pixel, not adjacent pixels. A complication degree also includes a total of density differences between pixels disposed with a predetermined interval.
Firstly, referring to
Regarding computing of a complication degree in a sub scanning direction, as shown in
As described above, in the area separation processing, density differences are summed for every other pixel so as to compute a complication degree in a main scanning direction. Meanwhile, density differences between adjacent pixels are summed so as to compute a complication degree in a sub scanning direction.
Here, a complication degree computed in a main scanning direction is represented by busy-m, and a complication degree computed in a sub scanning direction is represented by busy-s. In this case, a differential value ‘busy-gap’ of these complication degrees is computed as follows.
busy-gap=|busy-m−busy-s|
And then, in contrast to a non-edge area detected by the sum S of total density differences, when the differential value busy-gap of the total complication values is larger than a predetermined threshold value (‘120’ in the following example), the area is determined as an edge area; otherwise, the area is determined as a non-edge area. Hence, a differential value busy-gap makes it possible to extract an edge area on a part which is hardly detected by the sum S of total density differences.
Subsequently, a total value busy-sum, which is a total of complication degrees in a main scanning direction and a sub scanning direction, is computed as follows.
busy-sum=busy-m+busy-s
In contrast to a non-edge area detected by the sum S of total density differences and a differential value busy-gap of complication degrees; when a total value busy-sum of complication degrees is larger than a predetermined threshold value (‘180’ in the following example), the area is determined as a mesh dot area; otherwise, the area is determined as a non-edge area. Table 3 shows each characteristic quantity of a mesh dot area and the determination results when area determination is made by the above area separation processing. Here, a range of each threshold value is not particularly limited.
“Black and white 175 lines, 30% line density” of Table 3 indicates that a printed matter has a resolution of 175 lines and black and white ratio is 30%. As shown above, the mesh area is determined as a non-edge area in determination made by a sum S of total density differences and a differential value busy-gap of complication degrees. However, based on a computing result of a characteristic quantity of a busy-sum, which is a total value of complication degrees, the area can be determined as a mesh dot area.
The following describes an example of the area separation using an average density or a total density of the main mask. A complete average density, a simplified average density, and a total density in the main mask of
complete average density=(total of i0 to i27)/28
simplified average density=(total of i0 to i27)/32
32 is 25 (5-bit shift)
total density=(total of i0 to i27)
In the area separation, any one of the complete average density, the simplified average density, and the total density is applicable. These densities have the following characteristics.
With the complete average density, an average density of the main mask can be computed without an error; however, a coefficient of division is “28”, so that the speed is not high as the simplified average density. Thus, another division circuit is necessary.
The simplified average density causes an error of “28/32” relative to the complete average density. However, when an image has a density of 8 bits and 256 levels of gradation, a density value may be increased to 13 bits to a maximum by computing a total density. In this case, the maximum value can be shifted by 5 bits. Thus, area determination is possible with a comparator having a maximum density of 8 bits.
The total density is the most simple. In the case of an image density of 8 bits and 256 levels of gradation, a comparator with a maximum density of 13 bits is necessary.
In the area separation processing, area determination using one of the complete average density, the simplified average density, and the total density is performed before computing characteristic quantities such as the sum S of total density differences, a differential value busy-gap of a complication degree, and a total value busy-sum of a complication degree. Further, in the area determination using one of the complete average density, the simplified average density, and the total density, a computed density value is compared with a predetermined threshold value. When the density value is not less than the threshold value, an area is determined as a non-edge area. Additionally, the determined non-edge area remains the same in the area determination thereafter. This arrangement makes it possible to prevent an edge area from being detected on a high-density part.
If a high-density part is determined as an edge area, an error such as a contour may appear on a high-density part and a halftone area in a filter processing thereafter (described later). To prevent such a problem, as described above, area determination using one of the complete average density, the simplified average density, and the total density is performed so as to prevent the appearance of an edge area on a high-density part.
And then, referring to
In the area separation processing shown in
When the simplifed average density is smaller than the threshold value ave, a sum S of total density differences of the foregoing sub mask (sub matrix) is computed (S4), and the sum S is compared with a threshold value delta (delta=150) (S5). When the sum S of total density differences is larger than the threshold value dalta, the area is determined as a character area (edge area), and the determination result remains the same in area determination thereafter (S6). Further, when the area is determined as a character area in S6, a feedback count is increased by “1”. The feedback count is compared with a threshold value fb1 when the sum S of total density differences is at the threshold value ‘delta’ or less in S5 (S7). A threshold value fb1 is provided for determining a degree of the occurrence of a character area in a predetermined history. In the area separation processing, the predetermined history is a previous history of eight pixels and a threshold value fb1 is set at “2”.
Therefore, relative to a previous history of eight pixels, when an edge determination result regarding the sum S of total density differences has three pixels or more (namely, when a feedback count is larger than a threshold value fb1), the edge determination threshold value ‘delta’ is reduced by a predetermined amount fb2 (fb2=80). The reduced threshold value delta-fb2 is compared with the sum S of total density differences (S8). When the sum S of total density differences is larger than the threshold value delta-fb2, the area is determined as a character area, and the determination result remains the same in area determination thereafter (S9).
As described above, a threshold value of edge determination is changed based on an edge determination result of the previous history, and feedback correction is carried out so as to improve accuracy of edge determination based on the previous history.
When a feedback count is determined as a threshold value fb1 or less in S7, or when the sum S of total density differences is determined as a threshold value delta-fb2 or less, area separation processing is performed based on a complication degree.
A differential value busy-gap is computed between complication degrees in a main scanning direction and in a sub scanning direction, and a total value busy-sum is computed between complication degrees in a main scanning direction and in a sub scanning direction (S10). And then, the differential value busy-gap of complication degrees is compared with a predetermined threshold value busy-g (busy-g=120) (S11).
When the differential value busy-gap of complication degrees is not less than the threshold value busy-g, the area is determined as a character area (edge area), and the determination result remains the same in area determination thereafter (S12). When the differential value busy-gap of complication degrees is smaller than the threshold value busy-g, a total value busy-sum of complication degrees is compared with a predetermined threshold value busy-s (busy-s=180) (S13). When the total value busy-sum of complication degrees is not less than the threshold value busy-s, the area is determined as a mesh dot area (S14). When the total value busy-sum of complication degrees is smaller than the threshold value busy-s, the area is determined as a picture area (S15).
When an area is determined in S3, S6, S9, S12, S14, or S15, the step returns to {circle around (1)}of
As earlier mentioned, the area separation processing is carried out in the order of: determination based on an average density in the main mask, determination based on a sum S of total density differences of sub masks, determination based on feedback correction, determination based on a differential value busy-gap of complication degrees, and determination based on a total value busy-sum of complication degrees. In each determination, each of the above characteristic quantities (area separation parameters) is compared with each threshold value, and the area is determined. With this arrangement, the area separation processing does not require large memory, and three kinds of an edge area, a non-edge area, and a mesh area can be detected only by comparing characteristic quantities with threshold values.
Further, in a hardware arrangement, the operation based on the above characteristic quantities is not carried out in the above order but the characteristic quantities (an average density, a sum S of total density differences, a differential value busy-gap, a total value busy-sum) are computed and processed in parallel through a so-called pipeline operation so as to provide a simple hardware system with higher speed.
Besides,
As described above, an area is determined as shown in the truth table of
The following describes the filter processing which is performed in the filter processing section 4 of
In the filter processing section 4, the filter processing is carried out using a filter coefficient previously set for each area.
In this filter processing, a mask in a sub scanning direction is identical in size to a mask used in the area separation processing. Actually, in the case of a hardware construction, even when a mask size (particularly the number of lines in a sub scanning direction) is reduced in the area separation, the larger a filter processing mask is, the larger line memory is necessary.
Moreover, in the filter processing, an emphasizing level of the filter is the highest on an edge area and is the lowest on a non-edge area. Hence, based on detection results of the area separation processing, a filter coefficient is changed for each area so as to achieve an image processing with high picture quality.
Here, another coefficient is applicable as a filter coefficient for each area.
Next, the following describes the gamma changing operation performed in the gamma correcting section 6 based on the detection result of the area separation processing.
In the gamma correcting section 6, the gamma changing operation is performed on each area by using a gamma correcting table which has been previously prepared.
An actual hardware construction uses memory such as SRAM (static RAM) and ROM with an input of 8 bits and an output of 8 bits and 256 bytes, and after data is inputted to an address of SRAM and ROM on the input axis, image data subjected to γ changing is outputted from the output.
In comparison of γ correction graphs of
The following describes an error diffusing operation performed in the error diffusing section 7 of FIG. 1.
In the error diffusing section 7, an error diffusion parameter is switched based on a result of the area separation processing, and an error diffusing operation is performed on each area by using a predetermined error diffusion parameter.
First, the following discusses an error diffusing operation. In this example, a binary error diffusing operation is carried out. The error diffusion is a kind of presentation of a dummy halftone and has been used as an image processing technique these days.
Dp<Th→quantized by 0 Er=Dp
Dp≧Th→quantized by 255 Er=Dp−255
An error amount Er computed as above is diffused on the pixels a to d of
As described above, an error occurred in the target pixel is distributed to a predetermined pixel with a predetermined coefficient so as to quantize the target pixel. The quantized pixel is set at 0 or 255. Thus, assuming that 0 corresponds to 0, and 255 corresponds to 1, binary error diffusion is possible.
As shown in Table 4 below, in the image processing, a quantization threshold value Th serving as an error diffusion parameter is changed based on the result of the area separation processing.
As shown above, a quantization threshold value Th on an edge area is set smaller than other areas so as to clearly reproduce an edge area. Namely, based on detection results of the area separation processing, error diffusion is performed using different error diffusion parameters respectively for the areas, so that image processing is possible with higher image processing.
Additionally, in the above example, a quantization threshold value Th is changed as an error diffusion parameter. However, a parameter to be changed is not particularly limited, so that other error diffusion parameters can be changed.
Besides, when area determination is made based on a total density of the four kinds of sub masks, the following area determination is possible in addition to the foregoing examples. Assuming that the four kinds of sub masks have total densities sum1, sum2, sum3, and sum4, a maximum value and a minimum value are computed for each of sum1 to sum4. The resultant values are respectively referred to as max and min. It is possible to make area determination based on a difference between max and min, i.e., a computing result of max−min. Namely, according to the area determination, when a computing result of max−min is larger than a predetermined threshold value, the area is determined as an edge area; otherwise, the area is determined as a non-edge area.
In the image processing device of the present invention, when making area determination on a target pixel of an image data to be inputted, a total density is computed regarding at least the four kinds of sub pixel groups, that are provided in a main pixel group constituted by a plurality of pixels including a target pixel, and area determination is made based on these total densities.
In the above area determination, it is preferable to determine if the target pixel is on an edge area or not. Hence, based on total densities of the four kinds of the sub pixel groups, an area can be divided into two kinds of areas, an edge area and a non-edge area. Here, an edge area is an area having a large difference in density. A character area is included in an edge area.
Further, when the sub pixel groups are different in size from one another, it is preferable to carry out normalization according to a coefficient. Therefore, even in the case of different sizes of sub pixel groups, area separation is possible with high accuracy. Moreover, this arrangement makes it possible to reduce the number of lines in a sub scanning direction. A size in a sub scanning direction affects the number of lines of line memory. Hence, the number of lines in a sub scanning direction is reduced so as to provide an inexpensive image processing device.
Also, it is preferable to dispose the sub pixel groups on or around the ends of the main pixel group. For example, the four kinds of sub pixel groups are respectively disposed on the upper, bottom, left, and right ends or around the ends of the main pixel group, so that information can be widely collected relative to a size of the main pixel group, thereby improving accuracy of area separation.
Further, it is preferable to categorize the total densities of the four kind sub pixel groups into two groups, to compute a value S by adding total density differences of the two groups, and to make area determination based on the value S. Hence, an adder for computing a total density, a subtracter for computing a difference in total density of the groups, and a comparator are used for area determination. Consequently, it is possible to provide an image processing device which can readily make fast area determination with high accuracy at low cost.
Also, it is preferable to compute a complication degree which is a total of density differences between adjacent pixels or pixels disposed with a fixed interval in a main scanning direction, and a complication degree which is a total of density differences between adjacent pixels or pixels disposed with a fixed interval in a sub scanning direction, and it is preferable to make area determination based on the computing results. This arrangement makes it possible to further improve accuracy of area separation.
Additionally, after determination is made based on the value S if a target pixel is an edge area or not, it is preferable to compute a difference between a complication degree in a main scanning direction and a complication degree in a sub scanning direction regarding a non-edge area, and to determine again if the target pixel is an edge area or not based on the computing result. Thus, it is possible to detect an edge area which has not been detected using the value S.
Further, after determination is made if a target pixel is an edge area or not, it is preferable to compute a total of a complication degree in a main scanning direction and a complication degree in a sub scanning direction regarding a non-edge area, and to determine if the target pixel is a mesh dot area or a non-edge area based on the computing result. Hence, the area is divided into three areas of an edge area, a non-edge area, and a mesh dot area.
Furthermore, a complication degree in a main scanning direction is preferably a total of density differences of every other pixel, and a complication degree in a sub scanning direction is preferably a total of density differences of adjacent pixels. Hence, it is possible to compute a complication degree suitable for an input resolution and a size of the main pixel group (mask size).
Additionally, it is preferable to include the step of computing an average density or a total density in the main pixel group and determining if a target pixel is an edge area or not based on the computing results. Thus, it is possible to prevent a high-density part from being detected as an edge area. Particularly when a filter processing is performed on a high-density part of a halftone image, it is possible to prevent a problem such as a boundary on an image. Besides, determination is made based on a total density of the main pixel group so as to determine if a target pixel is an edge area or not without the necessity for a division circuit.
Also, when an average density in the main pixel group is computed, it is preferable to divide a total density by a power of 2, which is the closest to the number of pixels, not by the number of pixels. Hence, in a hardware construction, division is made by a bit shift, so that a value close to an average density can be computed without the necessity for a division circuit.
Besides, when determination is made if a target pixel is an edge area or not based on a total density of the sub pixel groups, after determination of an edge area is successively made for a predetermined times or with a predetermined frequency, it is preferable to change a threshold value for determining if a target pixel is an edge area or not. Thus, it is possible to further improve accuracy of determining an edge area.
Further, upon area determination, it is preferable to perform a plurality of determination operations in a predetermined order. For example, the order of priority is used in area determination, and an area is determined based on the order so as to perform area separation only by determination using a threshold value, without the necessity for a complicated lookup table and circuit.
Furthermore, the following order is preferable: determination based on a computing result of an average density or a total density in the main pixel group, determination based on the value S, determination based on a difference between complication degrees in the main scanning direction and the sub scanning direction, and determination based on a total of complication degrees in the main scanning direction and the sub scanning direction. Hence, a desirable result can be achieved in the area separation.
Moreover, it is preferable to change a coefficient of filter processing based on an area determined in the area determination processing. This arrangement makes it possible to provide an image processing device with high picture quality.
Also, it is preferable to change a gamma correction table based on an area determined in the area determination processing. This arrangement makes it possible to provide an image processing device with high picture quality.
Besides, it is preferable to change an error diffusion parameter based on an area determined by the area determination processing. This arrangement makes it possible to provide an image processing device with high picture quality.
The invention being thus described, it will be obvious that the same may be varied in many ways. Such variations are not to be regarded as a departure from the spirit and scope of the invention, and all such modifications as would be obvious to one skilled in the art are intended to be included within the scope of the following claims.
Number | Date | Country | Kind |
---|---|---|---|
11-291947 | Oct 1999 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5659402 | Fujita et al. | Aug 1997 | A |
5892592 | Adachi et al. | Apr 1999 | A |
5982946 | Murakami | Nov 1999 | A |
6052484 | Kobayashi | Apr 2000 | A |
6111975 | Sacks et al. | Aug 2000 | A |
6111982 | Adachi | Aug 2000 | A |
6473202 | Kanata et al. | Oct 2002 | B1 |
6631210 | Mutoh et al. | Oct 2003 | B1 |
Number | Date | Country |
---|---|---|
0 902 585 | Mar 1999 | EP |
5-50187 | Jul 1993 | JP |
10-271326 | Apr 1998 | JP |
11-027517 | Jan 1999 | JP |
11-069150 | Mar 1999 | JP |
11-096372 | Apr 1999 | JP |