1. Field of the Invention
This invention relates to a technique for printing images on a print medium by ejecting ink thereon.
2. Background Art
In recent years, color printers of a type that ejects inks of several colors from a print head have come to enjoy widespread use as computer output devices, and are widely used for multi-color, multi-tone printing of computer-processed images. To achieve high image quality in such printers, it is necessary to accurately reproduce tone values for each color.
To accurately reproduce tone values for each color, it is required to make the ink amount ejected per unit of area accurate. To meet this requirement, it has been proposed, for example, in JP 11-99672A disclosed by the Applicant, to compensate for individual print head errors in ink ejection amount due to print head manufacture error.
However, with a method of compensating for errors in ink ejection amount for individual print heads, in the event that error differs among several kind of ink drops in different size formed by a given print head, it was not possible to compensate for errors in ink amount in a detailed manner with respect to each of ink drops in different kind.
Accordingly, an object of the present invention is to provide a technique for compensating for the ink amount error of ink drops in different size in order to improve reproducibility of the color.
In order to attain the above and the other objects of the present invention, there is provided a printing control apparatus for generating print data to be supplied to a print unit capable of forming one of N types of dots having different sizes at one pixel area by a selective ejection of any of the N types of ink drops onto a print medium. The N types of ink drops are different in an ink amount. N is an integer of at least 2. The apparatus comprises an error information receiver and a dot data generator. The error information receiver is configured to receive error information indicative of an ink amount error of at least one specific type of ink drop among the N types of ink drops. The dot data generator is configured to process input image data for generating dot data representing a state of dot formation at each pixel in a printed image. The dot data generator is configured to generate the dot data compensated for the ink amount error with respect to each of the specific type of ink drops in response to the error information data.
According to the present invention, for at least one specific type of ink drops from among a plurality of types of ink drops of different amounts of ink, dot data can be generated in such a way as to compensate for error of ink amount for each of the specific types of ink drops, so even if there is deviation in error of ink amount for each of the specific types of ink drops, color can be reproduced more accurately.
In a preferred embodiment of the invention, the dot data generator comprises a color converter and a halftone processor. The color converter is configured to convert a color system of the input image data with a color conversion table for generating color-converted image data. The color-converted image data is represented with a plurality of color components available for the print unit. The halftone processor is configured to convert a tone value of the color-converted image data to any of the N tones with respect to each pixel based on a compensated relationship between an input and an output. The input is the tone value of the color-converted image data. The output is a combination of dot recording rates for each of the N dots. The compensated relationship is compensated with the error information. The halftone processor is configured to generate the compensated relationship using a reference relationship and the error information. The reference relationship is a relationship between the combination of dot recording rates for each of the N dots and a provided tone value of the color-converted image data assuming no ink amount error.
By so doing, ink amount can be compensated by means of compensating a correspondence relationship having tone values of color-converted image data as input and a combination of recording rates for each of N types of dots as output, so a combination of recording rates for each of N types of dots prepared in advance on the assumption that there is no error of ink amount can be used as is to perform halftone processing. As a result, even where a combination of dot recording rates has been set so as to minimize graininess (deviation of image) and banding (band-like image degradation), the features of the combination of dot recording rates will not be excessively diminished, and color can be reproduced more accurately.
In a preferred embodiment of the invention, the halftone processor is configured to calculate a first ink amount and a second ink amount with respect to each of the tone values of the color-converted image data based on the reference relationship, and also to multiply a value of the first ink amount divided by the second ink amount for generating the compensated relationship. The first ink amount is an ink amount ejected per unit of area excluding the ink amount error. The second ink amount is an ink amount ejected per unit of area including the ink amount error. By so doing, a corrected correspondence relationship can be determined quickly by means of a simple arrangement.
In a preferred embodiment of the invention, the halftone processor is configured to calculate a first ink amount with respect to each of the tone values of the color-converted image data based on the reference relationship, and also to adjust the reference relationship for a second ink amount to approximate to the first ink amount. The first ink amount is an ink amount ejected per unit of area excluding the ink amount error. The second ink amount is an ink amount ejected per unit of area including the ink amount error. By so doing, a corrected correspondence relationship can be generated more accurately.
In a preferred embodiment of the invention, the dot data generator comprises a color converter and a halftone processor. The color converter is configured to convert a color system of the input image data with a compensated color conversion table for generating color-converted image data. The color-converted image data is represented with a plurality of color components available for the print unit. The compensated color conversion table is compensated with the error information. The halftone processor configured to convert a tone value of the color-converted image data to any of the N tones with respect to each pixel based on a relationship between an input and an output. The input is the tone value of the color-converted image data. The output is a combination of dot recording rates for each of the N dots. The color converter is configured to generate the compensated color conversion table using a reference color conversion table and the error information. The reference color conversion table is set assuming no ink amount error.
Even if ink amount error is compensated in color conversion processing of this kind, tone values can be represented using a preset combination of dot recording rates, so the features of the combination of dot recording rates will not be excessively diminished, and color can be reproduced more accurately.
The present invention can be realized in various forms such as a method and apparatus for printing, a method and apparatus for producing print data for a printing unit, and a computer program product implementing the above scheme.
a) and 10(b) are explanatory diagrams showing a compensating method of a dot recording rate table performed in the first embodiment of the present invention.
a) and 11(b) are explanatory diagrams showing a dot recording rate table and ink ejection amount in the second embodiment of the present invention.
a) and 12(b) are explanatory diagrams showing a compensation method for error of ink amount in the second embodiment of the present invention.
a) and 13(b) are explanatory diagrama showing a method of calculating a compensation coefficient for use in compensating ink amount error in the second embodiment of the present invention.
a) and 15(b) are explanatory diagrams showing dot recording rate table DT and ink ejection amount in the third embodiment of the present invention.
Embodiments of the present invention will now be described through embodiments in the following sequence.
Application program 95 operates on computer 88 under a specific operating system. Video driver 94 and printer driver 96 are incorporated in the operating system, and print data PD to be sent to color printer 20 is output via these drivers from application program 95. Application program 95 performs the desired processing on the image to be processed, and displays the image on CRT 21 with the aid of video driver 94.
When application program 95 issues a print command, printer driver 96 of computer 88 receives image data from application program 95, and converts this to print data PD to supply to color printer 20. In the embodiment shown in
Printer driver 96 is a program for realizing a function that generates print data PD. A program for realizing the functions of printer driver 96 is supplied in a format recorded on a recording medium that can be read by a computer. As this kind of recording medium, any variety of computer readable medium can be used, including floppy disks, CD-ROMs, opt-magnetic disks, IC cards, ROM cartridges, punch cards, printed items on which a code such a bar code is printed, a computer internal memory device (memory such as RAM or ROM), or external memory device, etc.
Print head unit 60 has a memory, not shown, that stores error information indicating ink ejection amount error. Control circuit 40 reads out error information from this memory, and transmits it to computer 88 via connector 56. The transmitted error information is received by error information receiver 102 (
The sub-scan feed mechanism for transporting printer paper P comprises a gear train (omitted from the drawing) that transfers rotation of paper feed motor 22 to sub-scan feed mechanism 27 and a paper transport roller (not shown). The main scan feed mechanism for reciprocating carriage 30 comprises a slide rail 34 extending perpendicular to axis of sub-scan feed mechanism 27, for slidably retaining carriage 30; a pulley 38 around which is passed an endless belt 36 that extends between it and the carriage motor 24; and a position sensor 39 for sensing the home position of carriage 30.
Color heads 61 are provided with a plurality of nozzles Nz for each color, and a piezo element PE which is one kind of electrostriction device and has excellent response is installed for each nozzle. Details of the structure of a piezo element PE and a nozzle Nz are shown in
In this embodiment, by applying electrical voltage for a predetermined time interval across electrodes provided to either end of piezo element PE, the piezo element PE expands for the time interval that electrical voltage is applied, and deforms one side wall of ink passage 68 as shown in the bottom portion of
The size of ink drop Ip can vary due to manufacturing error of ink passage 68 and individual differences among piezo elements PE as well. The amount of this variation is stored as error information in memory provided to print head unit 60. Error information is information for each ink drop Ip for forming each dot of large, medium, or small size. The example described later has the object of compensating this variation amount for each type of ink drop Ip to perform correct color reproduction.
Printer 20 having the hardware arrangement described hereinabove transports paper P by means of paper feed motor 22 (hereinafter termed “sub-scanning”) while reciprocating carriage 30 by means of carriage motor 24 (hereinafter termed “main scanning”), and at the same time driving the piezo elements PE of color heads 61 of print head 28 to perform ejection of each color ink, to form dots and form a multicolor image on paper P.
B. Dot Formation Control Process
In Step S105, resolution conversion module 97 converts the resolution of the input image data to the resolution in the printer 20. In the event that image data is lower than the print resolution, resolution conversion is performed by generating new data between adjacent original image data by means of linear interpolation. Conversely, the event that image data is higher than the print resolution, resolution conversion is performed by thinning out data at a predetermined rate.
In Step S110, color conversion module 98 performs a color conversion process. The color conversion process is a process for converting image data consisting of R, G, B tone values into multi-tone data representing tone values for each of the colors C, M, Y, K used by printer 20. This process is performed using a color conversion table LUT (see
In Step S200, halftone module 99 performs a halftone process on the image data that has been color converted in this way. Halftone process refers to a decrease process to decrease tone values of the original image data (in this embodiment, 256 tone values) to a number of tone values that can represented in each pixel by printer 20. Here, “decrease process” refers to reducing the number of tone values representing colors. In this embodiment, decrease to four tone values, namely, “no dot formation”, “small dot formation”, “medium dot formation”, and “large dot formation”, is performed.
In Step S220, level data LVL corresponding to tone value is read out from the large dot curve LD. For example, as shown in
In Step S230, a determination is made as to whether level data LVL set in this way is greater than a threshold value THL. Here, dot on/off determination is performed by means of a dither method, for example. Threshold values THL are different values set for each pixel using a so-called dither matrix. In this embodiment, a matrix representing values of 0–254 in a 16×16 square pixel block is used.
Where level data LVL is greater than threshold value THL, halftone module 99 determines that a large dot should be made ON, and substitutes a variable RE indicating the result value with a binary value 11 (Step S300). Result value RE is a variable representing the size of the dot to be formed on a pixel. Where this variable is 11, a large dot will be formed.
On the other hand, in Step S230, if level data LVL is smaller than threshold value THL, halftone module 99 determines that a large dot should not be formed, and proceeds to Step S240. In Step S240, medium dot level data LVM is set. Medium dot level data LVM is set on the basis of tone value, by means of the recording rate table DT described previously. The setting method is the same as for large dot level data LVL.
In Step S250, the relative magnitude of medium dot level data LVM and threshold value THM are compared, and medium dot ON/OFF determination is performed. The method of ON/OFF determination is the same as in the case of large dots, but the threshold value LVM used for the determination is a different value from the threshold value LVL in the case of large dots, as indicated below.
Where ON/OFF determination for both large dots and medium dots is performed using the same dither matrix, pixels in which dots easily go ON coincide between the two. That is, when a large dot goes OFF, there is a high likelihood that a medium dot will go OFF as well. As a result, there is a possibility that the medium dot recording rate will be lower than the desired recording rate. In this embodiment, in order to avoid such a phenomenon, the dither matrix is changed between the two. That is, by changing locations of pixels that easily go ON between large dots and medium dots, appropriate formation in each is assured.
In Step S250, in the event that level data LVM of a medium dot is greater than threshold value THM, a determination is made that a medium dot should go ON, and a binary value 10 is substituted in result value RE (Step S290). On the other hand, in Step S250 if level data LVM of a medium dot is smaller than threshold value THM, a determination is made that a medium dot should not be formed, and proceeds to Step S255.
In Step S255, small dot level data LVS is set in the same manner as setting of level data for large dots and medium dots. In Step S260, halftone module 99, in the event that level data LVS is greater than threshold value THS, makes a determination that a small dot should go ON, and substitutes a binary value 01 in result value RE (Step S280). On the other hand, in Step S260, if level data LVS of a small dot is smaller than threshold value THS, a determination that no dot should be formed is made, and a binary value 00 is substituted in result value RE (Step S270). In preferred practice, to suppress the reduction in small dot recording rate mentioned earlier, the small dot dither matrix should be different from those for medium dots and large dots.
Until halftone module 99, which determines whether or not any dot should be formed in a single pixel by means of the processes described hereinabove, has completed processing for all pixels (Step S310), the processes of Steps S220–S300 are repeated. Once processing for all pixels has been completed, the halftone process routine is concluded for the time being, and returns to the dot formation control process routine.
In Step S400, print data generating module 100 performs generation of print data PD from halftone data generated in this manner. Print data PD is data that includes raster data indicating dot recording status during each main scan, and data indicating sub-scan feed distance, and is output to printer 20 (S410). Printer 20 receives this data and forms large, medium, and small dots on pixels to print an image. The aforementioned halftone process is performed on the assumption that there is no ink amount error contained in ink drops, so if error is included in ink amount, color will not be reproduced correctly.
C. Compensation of Ink Quantity in the First Embodiment
b) shows target values of ink amount of ink drops for forming dots of each size, error information, estimated values of ink weight, compensation coefficients, and compensated ink amount. Target values of ink amount are ink weight of ink drops when it is assumed that ink drops are ejected without error. Error information is information representing error in ink weight of ink drops ejected by print head unit 60 used in printing. For example, in the case of an ink drop for forming a small dot, the target value for ink weight is 10 ng (nanograms), and the error information is 0.1. As a result, the ink weight of the ink drop ejected by print head unit 60 can be estimated to be 11 ng (=10 ng+10 ng×0.1). Compensation coefficients are determined such that multiplying by the estimated value of ink weight brings ink weight in approximation with the target value.
Compensation in the present embodiment is performed by adjusting the dot recording rate of dots of each size depending on the compensation coefficient. Specifically, it is performed by directly adjusting numbers of dots formed per unit of area. As shown in concrete terms in
The printing process in this embodiment is carried out as follows. When application program 95 issues a print command, first, computer 88 reads out error information from the memory of print head unit 60 via control circuit 40 of printer 20. The error information is received by error information receiver 102 in computer 88, and sent to ink amount compensator 101. Ink amount compensator 101 calculates a compensation coefficient from the error information, and multiplies the compensation coefficient by the level data in the dot recording rate table DT provided to halftone module 99. In this way, dot recording rates for large, medium, and small dots are adjusted. When adjustment of dot recording rate is completed, printer driver 96 receives the image data from application program 95 in the manner described previously, and this is converted to print data PD for supply to color printer 20.
In this way, in the present embodiment, ink amount error can be compensated for each of several kinds of ink drops having different ink weights, so even in cases where there is deviation in error of ink amount among several kinds of ink drops, color can be reproduced accurately. By performing such compensation for each color of ink, accurate color balance can be achieved.
In the present embodiment, resolution conversion module 97, color conversion module 98, halftone module 99, and ink amount compensator 101 correspond to the dot data generator in the Claims.
D. Compensation of Ink Quantity in the Second Embodiment
In the second embodiment, a point of difference with the first embodiment, in which compensation is done by multiplying level data for dots of each size by compensation coefficients, is that compensation is done by adjusting tone values of multi-tone data.
As will be understood from
In the present embodiment, this profile is generated as a result of tradeoffs such as the following.
Thus, in the present embodiment, there is set a profile having an upper limit for dot recording rate of small dots of 25%, and an upper limit for dot recording rate of medium dots of 50%.
In the present embodiment, tone value of multi-tone data is adjusted in the following manner. For example, where tone value is G, the theoretical ink ejection amount assuming no ink amount error will be Rt on dotted line Wi, but since in actuality ink amount error is estimated, estimated ink ejection amount is Re. As a result, at tone value G, a difference between theoretical ink ejection amount Rt and estimated ink ejection amount Re can be predicted to occur. This difference is the ink amount error to be compensated.
b) is an explanatory diagram showing a formula for adjusting tone value in order to compensate for error. In the present embodiment, theoretical ink ejection amount Rt is divided by estimated ink ejection amount Re, and the resultant value is multiplied by tone value G to calculate an adjusted tone value Gc. The ink ejection amount corresponding to tone value Gc calculated in this way is Rc. As will be understood from the diagram, the compensated ink ejection amount Rc more closely approximates the theoretical ink ejection amount Rt than does the estimated ink ejection amount Re, so it will be understood that ink amount error is held down. Theoretical ink ejection amount Rt corresponds to first ink amount in the Claims, and estimated ink ejection amount Re corresponds to second ink amount in the Claims.
This distribution can be calculated by the method indicated hereinbelow, on the basis of theoretical ink ejection amount. Specifically, distributions of dots of each size can be calculated from the product of the weight of each ink drop (for example, 10 ng in the case of a small dot) and the dot recording rate. For example, where tone value is G2, the product of ink drop weight and dot recording rate for small dots is 10 ng×25%, and for medium dots is 20 ng×50%. On the other hand, the dot recording rate for large dots is 0%, so the ratio of ink amount for small, medium, and large dots is 250:1000:0. From this result, an ink amount distribution of 20% (=250÷(250+1000)) for small dots and 80% for medium dots can be calculated. Using this distribution, a compensation coefficient for adjusting tone value can be calculated by the method indicated hereinbelow.
b) is an explanatory diagram showing a relationship between tone value and compensation coefficient for adjusting tone value. This compensation coefficient can be calculated from ink amount distribution and compensation coefficient for dots of each size shown in
For example, where tone value is G1, ink amount distribution for small dots is 100%, so the compensation coefficient is the same as the compensation coefficient for small dots, i.e., 0.91. Where tone value is G2, the compensation coefficient for small dots is 0.18, which is the product of the ink amount distribution for small dots, i.e. 20%, and the coefficient for small dots, i.e., 0.91; and the compensation coefficient for medium dots is 0.94, which is the product of the ink amount distribution for medium dots, i.e. 80%, and the coefficient for medium dots, i.e., 1.18. As a result, the compensation coefficient is 1.12. Adjustment of tone value is performed using this value. For example, assuming that the tone value of G2 is 100, the tone value will be substituted by the product of this compensation coefficient. i.e., 112. By generating level data with this substituted tone value as the input value, ink amount error can be compensated.
In this way, in the present embodiment, compensation can be done by adjusting tone value, so the combination of dot recording rates for each size of dot does not change per se. As a result, there is the advantage that even where a combination of dot recording rates has been set so as to minimize graininess (deviation of image) and banding (band-like image degradation), the features of the combination of dot recording rates will not be excessively diminished, and color can be reproduced more accurately.
E. Compensation of Ink Quantity in the Third Embodiment
The third embodiment has in common with the second embodiment the point that ink amount can be compensated by adjusting tone value, without changing the combination of dot recording rates for each size of dot per se. However, the method for adjusting tone value in this embodiment is different from the second embodiment.
In the present embodiment, tone value is adjusted in the following manner. For example, where the inputted input tone value is G, the theoretical ink ejection amount will be Rt, corresponding to point Pt on dotted line Wi. Point Pc is determined by searching on solid line We for the tone value capable of ejecting the ink amount closest to this ink ejection amount Rt. The tone value Gc corresponding to this point Pc is the adjusted output tone value. In this way, an input tone value G is converted to an output tone value Gc.
b) is a dot recording rate table DT generated using estimated values for ink amount. From error information it is understood that ink drop weight is 11 ng for a small dot and 17 ng for a medium dot. As a result, if tone value is not adjusted, it is estimated that 704 ng (=11 ng×64) of ink is ejected to form small dots and 2176 ng (=17 ng×128) to form medium dots, for a total of 2880 ng of ink. It will be understood that since this value is smaller than ink amount desirable for accurate color reproduction, unless compensated, color of lower tone value than the color desired to be reproduced will be reproduced.
In this way, the present embodiment is similar to the second embodiment described hereinabove in respect of the point of compensating by adjusting tone value, but permits input tone values to be associated arbitrarily with output tone values, which has the advantage that error in ink ejection amount can be minimized.
F. Variations
This invention is not limited to the examples and embodiments described hereinabove, and can be worked in various modes without departing from the spirit thereof; for example, variations such as the following are possible as well.
By so doing, in instances where it is known in advance that error is great for small ink drops only, a simple arrangement such that only small ink drops are compensated will be possible. Also, a type of ink drop having large error may be selected with reference to error information, and compensation performed only for the type of ink drop having large error, so that the compensation process is accelerated.
Color conversion table LUT may be generated in memory at the time of printer selection or when the printer driver is run, or may be generated when the printer driver is installed or when the print head unit is replaced, and stored in the computer's hard disk. The former has the advantage that where it is possible to utilize a plurality of printers, confusion regarding printer-color conversion table associations may be avoided, whereas the latter has the advantage that the time required for printer selection and printer driver running can be reduced.
Processes in the printing device described hereinabove can be realized by means of a computer program. As storage media having such a computer program recorded thereon, there may be employed flexible disks, CD-ROM, magneto-optical disks, IC cards, ROM cartridges, punch cards, printed matter imprinted with bar codes or other symbols, computer internal memory devices (RAM, ROM, and other memory) and external memory devices, and other such computer-readable media. The form of a program supplying device that supplies computer program for performing image processing and the like described hereinabove on a computer via a communications path is also possible.
This invention is applicable to computer output devices.
Number | Date | Country | Kind |
---|---|---|---|
2001-384968 | Dec 2001 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP02/12987 | 12/11/2002 | WO | 00 | 10/17/2003 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO03/051636 | 6/26/2003 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6042211 | Hudson et al. | Mar 2000 | A |
6799824 | Nunokawa | Oct 2004 | B1 |
6943918 | Kakutani | Sep 2005 | B1 |
20020140748 | Kanaya et al. | Oct 2002 | A1 |
Number | Date | Country |
---|---|---|
04-028561 | Jan 1992 | JP |
06-320796 | Nov 1994 | JP |
07-242004 | Sep 1995 | JP |
10-138509 | May 1998 | JP |
11-099672 | Apr 1999 | JP |
2000-198202 | Jul 2000 | JP |
2001-001570 | Jan 2001 | JP |
2001-158085 | Jun 2001 | JP |
2001-158116 | Jun 2001 | JP |
Number | Date | Country | |
---|---|---|---|
20040119765 A1 | Jun 2004 | US |