The present invention relates to an image forming apparatus capable of tone reproduction by a dither method, a dither matrix generation method, and a dither matrix generation apparatus.
As an image printing method used in an image forming apparatus such as a printer or a copying machine, an electrophotographic method is known. In the electrophotographic method, a latent image is formed on a photosensitive drum by using a laser beam, and the latent image is developed by a charged coloring material (hereinafter referred to as toner). The image printing is performed by transferring and fixing the developed toner image onto a transfer sheet. When the output image at this time is multi-tone image data that includes halftones, it is generally necessary to create an image by a pseudo halftone method using a dither method because it is difficult to obtain a halftone image with the aforementioned electrophotographic method, and conversion to achieve the halftone image is necessary. With the aforementioned dither method, dots are grown using a threshold matrix in which dots are concentrated to form stable dots in a low density region, and at that time the dot size is determined in consideration of the trade-off between resolution and graininess, and the reproducibility of the low density region.
Concerning dot growth from a low density region, Japanese Patent Laid-Open No. 10-145593 describes a method of defining dot sizes in a region with less than or equal to a low density and expressing tone in accordance with the density of dots (hereinafter referred to as FM: Frequency-Modulation). In addition, a method of expressing tone by the size of dots (hereinafter referred to as AM: Amplitude-Modulation) in a region with greater than or equal to a low density is described. However, in Japanese Patent Laid-Open No. 10-145593, since dots are caused to appear randomly by using an FM screen in a low density region, an extremely large threshold table is required. In contrast, Japanese Patent No. 4702470 describes the use of sub-matrices into which a threshold matrix is divided. Japanese Patent No. 4702470 describes causing dots adjusted to be adjacent to each other in a second sub-matrix to appear before dots of a first sub-matrix appear (are added).
However, in Japanese Patent No. 4702470, since growth is performed while causing dots to concentrate using a threshold matrix of a sub-matrix method, an anomalous texture occurs at a low period in a low density region, and there is a possibility that the texture will be visually recognized as moire.
The present invention provides an image forming apparatus, a dither matrix generation method, and a dither matrix generation apparatus for suppressing the generation of textures and improving the reproducibility of density.
The present invention in one aspect provides an image forming apparatus comprising: a conversion unit configured to convert multi-valued image data to image data for an output apparatus, using a dither matrix in which a threshold is set for each pixel, wherein, the thresholds are defined in the dither matrix such that: a first dot and a second dot alternately become larger until both of the first dot and the second dot reach a first dot size; after both of the first dot and the second dot reach the first dot size, the first dot becomes larger until the first dot reaches a second dot size while the second dot does not become larger, and thereafter, the second dot becomes larger until the second dot reaches the second dot size while the first dot does not become larger; and after both of the first dot and the second dot reach the second dot size, the first dot and the second dot alternately become larger.
According to the present invention, it is possible to suppress the occurrence of texture and improve the reproducibility of density.
Further features of the present invention will become apparent from the following description of exemplary embodiments with reference to the attached drawings.
Hereinafter, embodiments will be described in detail with reference to the accompanying drawings. Note that the following embodiments are not intended to limit the invention according to the claims. Although a plurality of features are described in the embodiments, not all of the plurality of features are essential to the invention, and the plurality of features may be arbitrarily combined. Furthermore, in the accompanying drawings, the same reference numerals are assigned to the same or similar components, and a repetitive description thereof is omitted.
The configuration of the system according to the present embodiment will be described with reference to
The CPU 101 is a central processing unit that performs overall control and arithmetic processing for the entire image forming apparatus 100, and executes, for example, image processing to be described later based on programs stored in the ROM 102. The ROM 102 is a read-only memory, and is a storage area for a system activation program, a program for controlling the scanner unit 107 and the printer unit 111, character data, character code information, and the like. The RAM 103 is a random access memory, and is used when programs and data stored in the ROM 102 are loaded and executed by the CPU 101 for each of a variety of processes. The RAM 103 is used as a data storage region for image data acquired by the scanner unit 107 or image data received from a network I/F 109. The HDD 104 is configured by, for example, a hard disk, and is used to store results of processing executed by the CPU 101, programs, files, data, image data, and the like. The HDD 104 is also used as a work area when processing is executed by the CPU 101.
The display unit 105 performs a screen display in accordance with, for example, liquid crystal, and is used for display of a setting state of the device, processing of each unit such as the CPU 101, an error state, and the like. The operation unit 106 accepts various user operations such as a change or reset of a setting performed by a user. For example, command information inputted via the operation unit 106 is stored in the RAM 103 and is used by the CPU 101.
The scanner unit 107 has a configuration for irradiating an original placed on an original platen (not shown) with light, converting the reflected light into an electric signal by a CCD or the like having RGB color filters, and receiving the electric signal through a parallel (or serial) cable or the like. With such a configuration, the scanner unit 107 obtains RGB image data corresponding to an original image. The scanner unit 107 transmits the RGB image data to the scanner image processing unit 108. The scanner image processing unit 108 performs image processing such as shading processing and image area separation processing on the RGB image data read by the scanner unit 107.
The network I/F 109 connects the image forming apparatus 100 to a network such as an intranet. In addition, the network I/F 109 inputs PDL data (Page Description Language) from the PC 114. A PDL is a language for writing an output image to the printer unit 111 and instructing the printer unit 111 when printing text, an image or the like, and the PDL is, for example, PostScript of Adobe Inc.
The printer image processing unit 110 executes image processing suitable for the printer unit 111, for example, color space conversion or correction processing, on image data subjected to image processing by the scanner image processing unit 108 or PDL data received via the network I/F 109. The printer unit 111 forms an image on a print medium in accordance with the electrophotographic processes of exposure, latent image formation, development, transfer, and fixing of CMYK image data comprising the four classes of cyan, magenta, yellow, and black, for example, processed by the printer image processing unit 110.
The monitor 113 and the PC 114 are host apparatuses of the image forming apparatus 100. That is, the PC 114 stores image data for printing in order to print, for example, an image displayed on the monitor 113 by the printer unit 111, and transmits the image data to the image forming apparatus 100 at the time of printing.
When the image data to be printed is multi-valued image data, it is difficult for the electrophotographic printer unit 111 (output apparatus) to obtain a halftone image. Therefore, in the present embodiment, image formation is performed by the pseudo halftone method using the dither method.
Next, the configuration of the printer image processing unit 110 will be described.
The CPU 101 receives a print job from the PC 114. Then, the CPU 101 transmits a print instruction based on multi-tone image data (for example, bitmap data whose depth is 8 bits) included in the received print job and the image data that is included in the job to the printer image processing unit 110. The printer image processing unit 110, which has received the instruction from the CPU 101, generates CMYK print data that can be processed by an output apparatus based on the multi-tone image data. An image forming process executed by the printer image processing unit 110 will be described below.
The color conversion unit 201 converts inputted RGB image data into CMYK image data based on a color conversion table. At this time, the color conversion table has, for example, 16×16×16 lattice points defined by RGB values, and CMYK values corresponding to these lattice points are stored as table data. The CPU 101 converts RGB image data into CMYK image data by performing interpolation operations such as tetrahedral interpolation and cubic interpolation on the basis of the table data. With respect to the CMYK image data converted by the color conversion unit 201, the gamma correction unit 202 performs a gamma correction process for keeping the tone characteristics of the printer unit 111 constant, using 1D-LUT data stored in advance.
The order table storage unit 203 stores an order table indicating a number of lines and an angle of the dither, and an order of dot growth. The threshold matrix generation unit 204 loads from the ROM 102 a predetermined dot size corresponding to an environmental sensor or a number of output sheets in the output apparatus. Then, the threshold matrix generation unit 204 generates a threshold matrix using an order table stored in the order table storage unit 203, and stores the generated threshold matrix in the threshold matrix storage unit 205. The threshold matrix storage unit 205 stores the threshold matrix generated by the threshold matrix generation unit 204.
Using the threshold matrix stored in the threshold matrix storage unit 205, the image forming unit 206 converts the CMYK image data gamma-corrected by the gamma correction unit 202 into N-bit (N is an integer) halftone image data for an output apparatus, and sends the halftone image data to the printer unit 111.
Next, a situation of a dither process using a threshold matrix in the present embodiment will be described with reference to
In contrast, in
In the present embodiment, as shown in
In step S501, the CPU 101 reads the order table, a number of sub-matrices (sub), a number of bits (bit) of the threshold, and a number of threshold matrices (a number of planes (plane)) that are stored in the order table storage unit 203. The order table is a table in which the order of appearance (a growth order) of dots in dither method tone reproduction is determined, and represents the tone reproduction of a normal AM screen. A submatrix method is a method of combining a plurality of matrices, in which thresholds at the same position are shifted little-by-little to generate one threshold matrix to thereby reduce an apparent matrix size (pattern). In the example of
The number of threshold matrices (plane) will be further described. When the tones of the printer is reproduced using PWM control, the exposure time of one pixel by a laser is controlled by a pulse width of, for example, 4 bits. In this case, 16 tones are reproduced in the printer. Here, in order to realize a number of tones (e.g., 1024 tones) equal to or larger than the number of tones that the printer can reproduce, area coverage modulation in accordance with the dither method is also used. For example, when the number of tones that can be reproduced by the printer is 4 bits and 16 tones, about 8 bits of tones (e.g., 1024 tones) can be reproduced by using area coverage modulation by the dither method between tones. In this case, since one threshold matrix is used across respective tones, if the number of tones that can be reproduced by the printer is 4 bits which means 16 tones, the number of planes (plane) is 15. As a simpler example, when the number of tones that can be reproduced by the printer is 1 bit which means two tones, the number of tones that can be reproduced by using area coverage modulation together with one threshold matrix between tones is two or more tones. Therefore, if the number of tones reproducible by the printer is 1 bit which means 2 tones, the number of planes is 1. In the present embodiment, description is given assuming that the number of planes is 1.
Next, in step S502, the CPU 101 loads from the ROM 102 the starting dot size, the dot size at which dot concentration starts, and the dot size at which dot concentration ends. Here, the starting dot size (hereinafter referred to as “start”) is a dot size at which dot growth is started in step 709 of
Each of the above-mentioned dot sizes is changed to an appropriate dot size in accordance with a usage environment (temperature and humidity), change over time, and a sheet (print medium) to be used. Therefore, configuration is such that a plurality of patterns of combinations of dot sizes as illustrated in
Next, in step S503, based on the order table read in step S501 and the two dot sizes of “lead” and “end” read in step S502, the CPU 101 determines whether or not a threshold obtained from a respective value of the order table is a threshold to be subjected to dot-concentrated-type growth.
Threshold matrices 601 to 608 correspond to cases where the dot sizes of the halftone dots are less than “lead”, and show a state of in which dots appear at locations corresponding to the thresholds that are targets of growth for increasing the densities of the dots. The growth for increasing the density of dots is growth for sequentially causing all halftone dots to become larger by causing a dot to appear pixel by pixel, and corresponds to step 709 of
In contrast, threshold matrices 609 to 616 correspond to cases where the dot sizes of the halftone dots are greater than or equal to “lead”, and show a state in which locations corresponding to the thresholds that are targets of dot-concentrated-type growth are made to appear. Dot-concentrated-type growth corresponds to step 710 in
Further, the threshold matrices 617 to 620 correspond to the case where the dot size of the halftone dots is greater than or equal to “end”, and show a state in which dots are sequentially made to appear at each halftone dot pixel by pixel, and dots of all pixels are made to appear in the threshold matrix 621. The threshold matrices 617 to 620 correspond to step 712 of
As a determination method in step S503, calculation is performed for “lead_max” which is calculated by the following Equation (1) and “end_max” which is calculated by the following Equation (2).
lead_max=sub×lead×plane (1)
end_max=sub×end×plane (2)
Then, the CPU 101 determines that a threshold that is greater than or equal to “lead_max” and less than “end_max” is a threshold that is the target of dot-concentrated-type growth. Here, “lead_max” indicates a threshold for starting dot-concentrated-type growth, and “end_max” indicates a threshold for ending dot-concentrated-type growth. Also, “sub” indicates the number of sub-matrices, and sub=16 in the example of
Next, in step S504, the CPU 101 performs a modulo operation (mod) on the threshold obtained from the order table by the number of sub-matrices (sub). Next, in step S505, the CPU 101 performs division (div) on the threshold obtained from the order table by the number of sub-matrices (sub).
Next, in step S506, the CPU 101 calculates an updated threshold (mtx) in accordance with the following Equation (3) with respect to the threshold obtained from the order table. Note that
mtx=(plane×end)×mod+div+(plane×lead)×(sub−mod−1) (3)
Here, “mtx” indicates the updated threshold, “mod” indicates a value resulting from performing a modulo operation on the threshold obtained from the order table by the number of sub-matrices, “lead” indicates the dot size at which dot concentration starts, and “end” indicates the dot size at which dot concentration ends. Also, “div” indicates a value obtained by dividing the threshold obtained from the order table by the number of sub-matrices, “sub” indicates the number of sub-matrices (sub=16 in
Next, in step S507, based on the dot size (start) to initially cause to appear at the same time, the CPU 101 determines whether or not the respective thresholds of mtx are thresholds that are targets for initially causing appearance at the same time. As a determination method, the number of dots (start_max) to initially cause to appear at the same time is calculated by the following Equation (4).
start_max=sub×start×plane (4)
A threshold less than “start_max” is changed to 0 from the threshold mtx, whereas start_max is subtracted from the threshold mtx for thresholds greater than or equal to the start_max. Here “start_max” denotes a threshold for initially causing appearance simultaneously, “sub” denotes the number of sub-matrices (sub=16 in
Next, in step S508, the CPU 101 performs normalization on the thresholds updated in step S507 based on the largest value of the threshold and the number of bits (bit) of the threshold. In step S509, the CPU 101 stores the threshold normalized in step S508 as the corrected threshold matrix in the threshold matrix storage unit 205. Through the above-described process, the threshold matrix is generated based on the three dot sizes (“start”, “lead” and “end”) that are determined for the respective colors.
The threshold matrix of
In step S1001, the image forming unit 206 starts an appearance operation in accordance with growth for increasing dot density. Growth for increasing dot density is a growth method in which all halftone dots sequentially become larger by causing a dot to appear pixel by pixel, and corresponds to the appearance states of step 709 in
In step S1002, the image forming unit 206 starts the dot-concentrated-type growth. Dot-concentrated-type growth corresponds to step 710 in
In step S1003, the image forming unit 206 sequentially causes a dot in one pixel to appear at each halftone dot. Step S1003 corresponds to step 712 of
Note that, in the present embodiment, step S1001 to step S1003 are used to describe the process of dot growth, but there is no limitation to this. For example, in accordance with a hardware circuit that the image forming unit 206 has, it is possible to generate halftone image data by comparing an input image (gamma-corrected CMYK image data) with a threshold matrix.
As described above, the image forming apparatus according to the present embodiment uses a plurality of dot sizes in a low density region to generate a threshold matrix for performing the dither process. As a result, it is possible to steadily maintain the stability of the low density region and improve the reproducibility and graininess of the low density region while suppressing the occurrence of an anomalous texture using a small threshold matrix.
Hereinafter, a description will be given of points different from the first embodiment with respect to the second embodiment. In the first embodiment, a configuration has been described in which a threshold matrix for performing dither processing is generated using a plurality of dot sizes in a low density region. As a result, it is possible to steadily maintain the stability of the low density region and improve the reproducibility and graininess of the low density region while suppressing the occurrence of an anomalous texture using a small threshold matrix. In the present embodiment, a threshold matrix for performing dither processing is generated using a plurality of dot sizes in a high density region as well. That is, by combining the present embodiment and the first embodiment, it is possible to steadily maintain stability and improve reproducibility and granularity while suppressing the occurrence of an anomalous texture in extreme density regions including low density regions and high density regions.
Step S1101 is similar to step S501 of
In step S1102, the CPU 101 loads from the ROM 102 a predefined dot size (hereinafter referred to as “lead_dk”) for starting dot concentration, a dot size (hereinafter referred to as “end_dk”) for ending dot concentration, and finally a dot size (hereinafter referred to as “end_dk2”) for simultaneous appearance.
Each of the above-mentioned dot sizes is changed to an appropriate dot size in accordance with a usage environment (temperature and humidity), in accordance with change over time, and in accordance with a sheet (print medium) to be used. Therefore, similarly to the first embodiment, combinations of dot sizes of a plurality of patterns are stored in the ROM 102, and patterns to be read are switched according to a condition.
Next, in step S1103, based on the order table read in step S1101 and the two dot sizes of “lead_dk” and “end_dk” read in step S1102, the CPU 101 determines whether or not a threshold obtained from a respective value of the order table is a threshold to be subjected to dot-concentrated-type growth.
In the threshold matrices 1201 to 1208, since all the dot sizes of remaining pixels are lead_dk or more, dots appear (are added) one pixel at a time for each halftone dot, and each halftone dot is grown with the same dot size. In the present embodiment, the term “remaining pixels” means a group of pixels in which dots have not yet appeared. On the other hand, since at least one of the dot sizes of the remaining pixels is less than lead_dk, the threshold matrices 1209 to 1216 have thresholds that are targets for dot-concentrated-type growth.
Dot-concentrated-type growth is a method in which the size of one halftone dot is grown until the dot size of remaining pixels becomes a dot size (hereinafter referred to as end_dk) at which a predetermined dot concentration is complete, and then the growth proceeds to the next halftone dot, and the size of the dot is similarly grown. Since
Further, in threshold matrices 1217 to 1220, since all the dot sizes of the remaining pixels are end_dk or less, dots are caused to sequentially appear (be added) pixel by pixel at each halftone dot, and dots of all the pixels appear in a threshold matrix 1224.
As a determination method in step S1103, calculation is performed for “lead_max” which is calculated by the following Equation (5) and “end_max” which is calculated by the following Equation (6).
lead_max=max−sub×lead_dk×plane (5)
end_max=max−sub×end_dk×plane (6)
Then, the CPU 101 determines that a threshold that is greater than to “lead_max” and less than or equal to “end_max” is a threshold that is the target of dot-concentrated-type growth. Here, “lead_max” indicates a threshold for starting dot-concentrated-type growth, and “end_max” indicates a threshold for ending dot-concentrated-type growth. In addition, “max” represents the maximum threshold of the threshold matrix. Also, “sub” indicates the number of sub-matrices, and sub=16 in the examples of
Next, since step S1104 and step S1105 are similar to step S504 and step S505 of
Next, in step S1106, the CPU 101 calculates an updated threshold (mtx) in accordance with the following Equation (7) with respect to the threshold obtained from the order table.
mtx=(plane×lead_dk)×mod+div+lead_max−(plane×end_dk×mod) (7)
Here, “mtx” indicates the updated threshold, “mod” indicates a value resulting from performing a modulo operation, by the number of sub-matrices, on a result of subtracting “lead_max” from the threshold obtained from the order table, “lead_dk” indicates the dot size at which dot concentration starts, and “end_dk” indicates the dot size at which dot concentration ends. In addition, “div” represents a value obtained by subtracting “lead_max” from the threshold of the order table and then dividing by the number of sub-matrices, “sub” represents the number of sub-matrices (sub=16 in
Next, in step S1107, based on the dot size (end_dk2) to finally cause to appear at the same time, the CPU 101 determines whether or not the respective thresholds of mtx are thresholds that are targets for finally causing appearance at the same time. As a determination method, the number of dots (end_dk2_max) to finally cause to appear at the same time is calculated by the following Equation (8).
end_dk2_max=max−sub×end_dk2×plane (8)
Then, from the threshold mtx, the CPU 101 replaces thresholds that are end_dk2 _max or more with end_dk2_max. Here, “end_dk2_max” indicates the threshold at which the last simultaneous appearance occurs, “max” indicates the maximum threshold of the threshold matrix, and “sub” indicates the number of sub-matrices (sub=16 in the examples of
The reason why simultaneous appearance is caused at the end is that it is possible that blank dots of one dot will collapse in a high resolution engine such as where the engine resolution is 2400 dpi because of electrophotographic characteristics. Therefore, the size of dots (end_dk2) to ultimately cause to appear simultaneously is determined in advance, and when end_dk2=1, single dots are collectively caused to appear for each halftone dot at the end. That is, in
Next, in step S1108, the CPU 101 performs normalization on the thresholds updated in step S1107 based on the largest value of the threshold and the number of bits (bit) of the threshold. In step S1109, the CPU 101 stores the threshold normalized in step S1108 as the corrected threshold matrix in the threshold matrix storage unit 205. Through the above-described process, the threshold matrix is generated based on the three dot sizes (“lead_dk”, “end_dk” and “end_dk2”) that are determined for the respective colors.
The threshold matrix of
In step S1401, the image forming unit 206 sequentially causes one pixel to appear (is added) at each halftone dot. When the dot sizes of the remaining pixels become lead_dk=4, the process proceeds to step S1402.
In step S1402, the image forming unit 206 starts the dot-concentrated-type growth. Dot-concentrated-type growth is a method in which the size of one halftone dot is grown until the dot size of remaining pixels becomes a dot size (end_dk2) at which a predetermined dot concentration is complete. Step S1402 corresponds to the threshold matrices 1209 to 1216 of
In step S1403, the image forming unit 206 causes dots to appear (add) one pixel at each halftone dot, and grows each halftone dot with equal dot sizes. Step S1403 corresponds to the threshold matrices 1217 to 1223 of
Note that, in the present embodiment, step S1401 to step S1403 are used to describe the process of dot growth, but there is no limitation to this. Halftone image data can also be generated by comparing an input image with a threshold matrix in accordance with a hardware circuit included in the image forming unit 206.
As described above, the image forming apparatus according to the present embodiment uses a plurality of dot sizes in a high density region to generate a threshold matrix for performing the dither process. As a result, it is possible to steadily maintain the stability of the high density region and improve the reproducibility and graininess of the high density region while suppressing the occurrence of an anomalous texture using a small threshold matrix. Further, the third embodiment may be combined with the first embodiment. With such a configuration, it is possible to improve the reproducibility and granularity of density while suppressing the occurrence of an anomalous texture in both a low density region and a high density region.
The present invention is not limited to the embodiments described above, and various modifications and variations are possible without departing from the spirit and scope of the invention. Accordingly, the claims are appended hereto in order to make the scope of the invention public.
Embodiment(s) of the present invention can also be realized by a computer of a system or apparatus that reads out and executes computer executable instructions (e.g., one or more programs) recorded on a storage medium (which may also be referred to more fully as ‘non-transitory computer-readable storage medium’) to perform the functions of one or more of the above-described embodiment(s) and/or that includes one or more circuits (e.g., application specific integrated circuit (ASIC)) for performing the functions of one or more of the above-described embodiment(s), and by a method performed by the computer of the system or apparatus by, for example, reading out and executing the computer executable instructions from the storage medium to perform the functions of one or more of the above-described embodiment(s) and/or controlling the one or more circuits to perform the functions of one or more of the above-described embodiment(s). The computer may comprise one or more processors (e.g., central processing unit (CPU), micro processing unit (MPU)) and may include a network of separate computers or separate processors to read out and execute the computer executable instructions. The computer executable instructions may be provided to the computer, for example, from a network or the storage medium. The storage medium may include, for example, one or more of a hard disk, a random-access memory (RAM), a read only memory (ROM), a storage of distributed computing systems, an optical disk (such as a compact disc (CD), digital versatile disc (DVD), or Blu-ray Disc (BD)™), a flash memory device, a memory card, and the like.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2019-022946, filed Feb. 12, 2019, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2019-022946 | Feb 2019 | JP | national |