The invention relates to the field of image reproduction, and in particular, to digital halftoning.
Halftoning is a process by which continuous tone images are approximated by a pattern of pixels that can achieve only a limited number of discrete intensities. An example of this is the rendering of gray tones with black and white pixels, such as in a newspaper photograph. A halftone pattern is made up of a region of pixels referred to as a halftone cell. In conventional digital halftoning (e.g., halftoning that uses rational tangent angles), a halftone cell includes a specific, repeatable pattern. The discrete number of tonal levels of a halftone pattern depends upon the number of pixels in the halftone cell and the number of exposure levels or dot sizes for each pixel.
Imaging systems often require some type of calibration to achieve a desired target response. Halftone calibrations typically involve converting the halftone description from a threshold basis that is most commonly used to a system that includes the halftone patterns for all gray levels. This can be visualized as a three-dimensional (3-D) lookup table (LUT) in which a calibrated version of the 3-D LUT can be created by rearranging the halftone patterns based on a transfer function LUT. This reorders the patterns of the halftone such that some patterns are replicated while others are deleted. The final calibrated 3-D LUT is then converted back into a threshold representation that is commonly used. This is a very time consuming process, especially if the array is very large (e.g., as is the case of stochastic halftones with full page width threshold arrays).
Accordingly, an improved halftone calibration mechanism is desired.
In one embodiment, a printing system is disclosed. The printing system includes a halftone calibration module to receive one or more un-calibrated halftones, transform un-calibrated threshold values in the one or more un-calibrated halftones via an inverse transfer function to generate calibrated halftone threshold values and generate one or more calibrated halftones based on the calibrated halftone threshold values.
In a further embodiment, a method is disclosed including receiving one or more un-calibrated halftones, transforming un-calibrated threshold values in the one or more un-calibrated halftones via an inverse transfer function to generate calibrated halftone threshold values and generating one or more calibrated halftones based on the calibrated halftone threshold values.
A better understanding of the present invention can be obtained from the following detailed description in conjunction with the following drawings, in which:
A halftone calibration mechanism is described. In the following description, for the purposes of explanation, numerous specific details are set forth to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without some of these specific details. In other instances, well-known structures and devices are shown in block diagram form to avoid obscuring the underlying principles of the present invention.
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
A portion of the disclosure of this patent document may include material that is subject to (copyright or mask work) protection. The (copyright or mask work) owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all (copyright or mask work) rights whatsoever.
The sheet image 120 may be any file or data that describes how an image on a sheet of print medium 180 should be printed. For example, the sheet image 120 may include PostScript data, Printer Command Language (PCL) data, and/or any other printer language data. The print controller 140 processes the sheet image to generate a bitmap 150 for printing to the print medium 180 via the printer 160. The printing system 130 may be a high-speed printer operable to print relatively high volumes (e.g., greater than 100 pages per minute). The print medium 180 may be continuous form paper, cut sheet paper, and/or any other tangible medium suitable for printing. The printing system 130, in one generalized form, includes the printer 160 that presents the bitmap 150 onto the print medium 180 (e.g., via toner, ink, etc.) based on the sheet image 120.
The print controller 140 may be any system, device, software, circuitry and/or other suitable component operable to transform the sheet image 120 for generating the bitmap 150 in accordance with printing onto the print medium 180. In this regard, the print controller 140 may include processing and data storage capabilities. In one embodiment, measurement module 190 is implemented as part of a halftone calibration system to obtain measurements of the printed medium 180. The measured results are communicated to print controller 140 to be used in the halftone calibration process. The measurement system may be a stand-alone process or be integrated into the printing system 130.
The interpreter module 212 is operable to interpret, render, rasterize, or otherwise convert images (i.e., raw sheetside images such as sheet image 120) of a print job into sheetside bitmaps. The sheetside bitmaps generated by the interpreter module 212 are each a 2-dimensional array of pixels representing an image of the print job (i.e., a Continuous Tone Image (CTI)), also referred to as full sheetside bitmaps. The 2-dimensional pixel arrays are considered “full” sheetside bitmaps because the bitmaps include the entire set of pixels for the image. The interpreter module 212 is operable to interpret or render multiple raw sheetsides concurrently so that the rate of rendering substantially matches the rate of imaging of production print engines.
The halftoning module 214 is operable to represent the sheetside bitmaps as halftone patterns of ink or toner. For example, the halftoning module 214 may convert the pixels to halftone patterns of CMYK ink or toner for application to the paper. Thus, halftoning module 214 converts a contone image to a binary/multi-bit level image at the same dots per inch (dpi). The resulting image is used to drive a printhead mechanism of the printer 160, which operates at the same dpi as the image data.
Print controller 140 also includes a halftone calibration module 216. Calibration module 216 performs a calibration process on an un-calibrated halftone 218 received at print controller 140 in order to generate a calibrated halftone 220. Calibrated halftone 220 is then received at halftoning module 214 along with the sheetside bitmap.
Conventional calibration mechanisms implement a transfer function to generate a calibrated halftone. A transfer function uses a one-dimensional (1D) LUT to convert an 8 bit input to an 8 bit output level. Thus, conventional calibration systems print using an identity transfer function to obtain a measured response and compute the transfer function to achieve a target response based on the measured response. An identify transfer function is a case where the output level of the LUT equals the input level. Printing using the identity transfer function is effectively printing using only the un-calibrated halftone.
The target response is frequently linear and the calibration process is called “Linearizing”. A 3D LUT representation of the halftone can be ordered to generate a calibrated 3D LUT that combines the effect of the transfer function and the halftone. As discussed above, implementation of a 3D LUT requires converting a halftone that usually is described by its threshold array into a 3D LUT, transforming it employing the transfer function and then converting the LUT back into a new threshold array.
According to one embodiment, halftoning calibration module 216 generates the appropriate threshold values for the calibrated threshold array based on an un-calibrated threshold array and transfer function. Thus, halftoning module 214 generates a calibrated halftone directly from the un-calibrated halftone and the transfer function by transforming the un-calibrated threshold values to new calibrated halftone threshold values. This process is performed without having to convert to a different halftone representation (e.g. 3D LUT), calibrate and subsequently convert back to a threshold representation.
At processing block 610, an inverse transfer function is generated. In order to produce a calibrated halftone threshold array, the inverse transfer function is computed for every gray level (J), processing block 612, in which the highest gray level achievable is defined. However only one less than the highest value is allowed. Thus at processing block 614, the new J value is calculated. Subsequently, the inverse transfer function at this J value is determined from a target response and measured response and saved, processing block 616. This operation continues until J equals zero. Thus at decision block 635, a determination is made as to whether J equals 0.
Once J equals zero, the non-singular values are processed to obtain ITF′(J), processing block 640. In one embodiment, ITF′ represents the inverse transform result after non-singular value processing. In other embodiments, this process could be performed at processing block 616. At processing block 660, the un-calibrated threshold array is processed. In a further embodiment, converting the continuous function result to a discrete integer representation can be performed at this stage.
At processing block 670, the calibrated threshold array is generated.
In one embodiment, halftoning module 214 compares the image data (I) at each pixel for the sheetside bitmap to the respective threshold data for each plane, where each plane defines thresholds for a particular drop size (e.g., Planes 1, 2, and 3 represent the thresholds for the drop size determination). To obtain threshold values for the entire sheetside bitmap the threshold array is tiled to at least cover the entire bitmap. In one embodiment, the multi-bit halftoning relationship is represented as Large drop: I>MTA_array(:,:,1); Medium drop: I>MTA_array(:,:,2) & I<=MTA_array(:,:,1); Small drop: I>MTA_array(:,:,3) & I<=MTA_array(:,:,2); and None: I<=MTA_array(:,:,3).
Assuming calibration using the transfer function in the image path followed by halftoning with an un-calibrated halftone, the halftoned image is to be identical to the result using halftoning employing a calibrated halftone without a transfer function operation. The image data I is transformed using the calibration transfer function.
As discussed above with reference to processing block 660, calibrated thresholds (CAL_MTA_array) are calculated. The calculations result in the final set of Calibrated MTA threshold values: CAL_MTA_array(:,:,1)=TF−1(MTA_array(:,:,1)); CAL_MTA_array(:,:,2)=TF−1(MTA_array(:,:,2); and CAL_MTA_array(:,:,3)=TF−1(MTA_array(:,:,3)). Therefore, generalizing for any set of threshold data having any number of drop sizes or planes results in CAL_MTA_array=TF−1(MTA_array). In one embodiment, for a Large drop, I>TF−1(MTA_array(:,:,1)). Similarly, for Medium, Small and None thresholds I>TF−1(MTA_array(:,:,2)) & I<=TF−1(MTA_array(:,:,1)); I>TF−1(MTA_array(:,:,3)) & I<=TF−1(MTA_array(:,:,2)); and None: I<=TF−1(MTA_array(:,:,3)), respectively.
Transforming threshold array values using an inverse of the transfer function may result in calibration with fewer gray levels because inverse transfer functions are not single valued functions. This reduced number of gray levels occurs where “flat spots” in the function exist, having the same output value for multiple input values. As discussed above with reference to processing block 640, non-single values are processed to produce the same results as the LUT halftone calibration method. This would be the case where it is desired to match the results of the LUT halftone calibration method, which is not always a requirement.
In conventional calibration mechanisms, a calibrated halftone must be generated to understand the number of gray levels resulting from calibration. However, the above-described inverse transfer function mechanism provides a framework to understand the number of levels without generating a calibrated halftone. The inverse transfer function mechanism also provides insight into the number of gray levels after calibration. Limitations to the number of gray levels after calibration may occur due to limited gray levels in the un-calibrated halftone or the transfer function. Therefore the inverse transfer function reduces the number of levels. An exception to this is the case where the transfer function and the inverse transfer function, is the identity function. For the case where the transfer function and inverse is identity the number of gray levels is not reduced.
Calibration may also be employed to correct for non-uniformities in the direction along the array width. In this case compensation can correct for variations in the printing performance between each nozzle of an array system, so as to produce consistent printing from each nozzle to a target response. In this case transfer functions are generated for each nozzle, which corresponds to a column and multiple planes of threshold data. The inverse transfer function for each nozzle is computed, based on the transfer function and target as previously described. The inverse transfer function is used to modify threshold values for all planes for each column of the threshold array, thus creating a uniformity compensated array width size threshold array. Where each column corresponds to a specific nozzle and planes correspond to thresholds for different drop sizes. The inverse transfer function method is very efficient at computing a calibrated threshold array, since a transfer function exists for each column of data. One can appreciate that an array having 25600 columns and three planes would benefit from this improved method of deriving a uniformity calibrated halftone threshold array.
Further, the number of gray levels in the un-calibrated TA provide an upper limit for the number of calibrated levels. Using the variables described by the algorithm in
Computer system 1000 further comprises a random access memory (RAM) or other dynamic storage device 1025 (referred to herein as main memory), coupled to bus 1020 for storing information and instructions to be executed by processor 1010. Main memory 1025 also may be used for storing temporary variables or other intermediate information during execution of instructions by processor 1010. Computer system 1000 also may include a read only memory (ROM) and or other static storage device 1026 coupled to bus 1020 for storing static information and instructions used by processor 1010.
A data storage device 1025 such as a magnetic disk or optical disc and its corresponding drive may also be coupled to computer system 1000 for storing information and instructions. Computer system 1000 can also be coupled to a second I/O bus 1050 via an I/O interface 1030. A plurality of I/O devices may be coupled to I/O bus 1050, including a display device 1024, an input device (e.g., an alphanumeric input device 1023 and or a cursor control device 1022). The communication device 1021 is for accessing other computers (servers or clients). The communication device 1021 may comprise a modem, a network interface card, or other well-known interface device, such as those used for coupling to Ethernet, token ring, or other types of networks.
Embodiments of the invention may include various steps as set forth above. The steps may be embodied in machine-executable instructions. The instructions can be used to cause a general-purpose or special-purpose processor to perform certain steps. Alternatively, these steps may be performed by specific hardware components that contain hardwired logic for performing the steps, or by any combination of programmed computer components and custom hardware components.
Elements of the present invention may also be provided as a machine-readable medium for storing the machine-executable instructions. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnetic or optical cards, propagation media or other type of media/machine-readable medium suitable for storing electronic instructions. For example, the present invention may be downloaded as a computer program which may be transferred from a remote computer (e.g., a server) to a requesting computer (e.g., a client) by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
Whereas many alterations and modifications of the present invention will no doubt become apparent to a person of ordinary skill in the art after having read the foregoing description, it is to be understood that any particular embodiment shown and described by way of illustration is in no way intended to be considered limiting. Therefore, references to details of various embodiments are not intended to limit the scope of the claims, which in themselves recite only those features regarded as essential to the invention.
Number | Name | Date | Kind |
---|---|---|---|
5170257 | Burns | Dec 1992 | A |
5245443 | Burns | Sep 1993 | A |
5296935 | Bresler | Mar 1994 | A |
5457541 | Burns | Oct 1995 | A |
5568572 | Shu | Oct 1996 | A |
5898820 | Borg et al. | Apr 1999 | A |
5978506 | Murayama | Nov 1999 | A |
6055071 | Kuwata | Apr 2000 | A |
6181445 | Lin | Jan 2001 | B1 |
6185004 | Lin | Feb 2001 | B1 |
6185007 | Hayashi | Feb 2001 | B1 |
6191867 | Shor et al. | Feb 2001 | B1 |
6418281 | Ohki | Jul 2002 | B1 |
6459825 | Lippincott | Oct 2002 | B1 |
6462835 | Loushin | Oct 2002 | B1 |
6463227 | Denton | Oct 2002 | B1 |
6554388 | Wong et al. | Apr 2003 | B1 |
6633408 | Rozzi | Oct 2003 | B1 |
6766263 | Stokes | Jul 2004 | B1 |
6825944 | Noda | Nov 2004 | B1 |
7139087 | Hayashi | Nov 2006 | B2 |
7190490 | Cooper et al. | Mar 2007 | B2 |
7304482 | Kay | Dec 2007 | B1 |
7321448 | Nishida et al. | Jan 2008 | B2 |
7424169 | Viassolo et al. | Sep 2008 | B2 |
7545536 | Hayashi | Jun 2009 | B2 |
7626614 | Marcu | Dec 2009 | B1 |
7692832 | Klassen | Apr 2010 | B2 |
7729015 | Mizes et al. | Jun 2010 | B2 |
7791760 | Shimada | Sep 2010 | B2 |
7798588 | Arazaki | Sep 2010 | B2 |
8179576 | Hayashi | May 2012 | B2 |
8189243 | Borg | May 2012 | B1 |
8322811 | Chandu et al. | Dec 2012 | B2 |
8368978 | Qiao | Feb 2013 | B2 |
8395831 | Qiao | Mar 2013 | B2 |
8542418 | Chandu et al. | Sep 2013 | B2 |
8559061 | Kuo et al. | Oct 2013 | B2 |
8681379 | Nakamura | Mar 2014 | B2 |
8817329 | Satoh | Aug 2014 | B2 |
20020113984 | Nakajima | Aug 2002 | A1 |
20030048464 | Yamada et al. | Mar 2003 | A1 |
20030048478 | Cheng | Mar 2003 | A1 |
20030058460 | Denton | Mar 2003 | A1 |
20030128378 | Cooper et al. | Jul 2003 | A1 |
20030164960 | Housel | Sep 2003 | A1 |
20030231785 | Rhoads | Dec 2003 | A1 |
20030234946 | Saito | Dec 2003 | A1 |
20040002023 | Sowinski | Jan 2004 | A1 |
20040145758 | Lamy et al. | Jul 2004 | A1 |
20040150844 | Sanger | Aug 2004 | A1 |
20040190092 | Silverbrook | Sep 2004 | A1 |
20040263911 | Rodriguez | Dec 2004 | A1 |
20060012809 | Shimada | Jan 2006 | A1 |
20070053003 | Loce | Mar 2007 | A1 |
20070223064 | Ichitani | Sep 2007 | A1 |
20090002530 | Arai | Jan 2009 | A1 |
20090189928 | Ino et al. | Jul 2009 | A1 |
20100110461 | Hallam | May 2010 | A1 |
20100245620 | Arai | Sep 2010 | A1 |
20100245867 | Murata | Sep 2010 | A1 |
20110013210 | Yamaguchi | Jan 2011 | A1 |
20110148968 | Chandu | Jun 2011 | A1 |
20110211008 | Teshigawara et al. | Sep 2011 | A1 |
20110235060 | Tai et al. | Sep 2011 | A1 |
20110292417 | Miyagi | Dec 2011 | A1 |
20120081436 | Yamada | Apr 2012 | A1 |
20120133962 | Kondo | May 2012 | A1 |
20120147389 | Ishihara | Jun 2012 | A1 |
20130063740 | Mochizuki | Mar 2013 | A1 |
20130063785 | Miyazaki | Mar 2013 | A1 |
20130176600 | Chandu et al. | Jul 2013 | A1 |
20130250312 | Miyazaki | Sep 2013 | A1 |
20140029020 | Murakata | Jan 2014 | A1 |
20140071497 | Kuno | Mar 2014 | A1 |
20140111832 | Hayashi | Apr 2014 | A1 |
20150015923 | Hayashi | Jan 2015 | A1 |
20160044207 | Kobayashi | Feb 2016 | A1 |
20160100079 | Gerrits et al. | Apr 2016 | A1 |
Number | Date | Country |
---|---|---|
0741488 | Nov 1996 | EP |
2003118133 | Apr 2003 | JP |
93-17867 | Sep 1993 | WO |
Entry |
---|
Vrhel, M.J., et al., “Color Device Calibration: A Mathematical Formulation”, IEEE Transactions on Image Processing, 8(12), (Dec. 1999), 1796-1806. |
Vantram, et al., “Fully Automated Calibration Procedure to Compensate Print Non-Uniformities Incurred in Fixed Print-Head Array Structures”, Ricoh Technical Report No. 39, Jan. 2014, pp. 154-160. |
Vantram et al., Fully Automated Calibration Procedure to Compensate Print Non-Uniformities Incurred in Fixed Print-Head Array Structures, Jan. 2014, pp. 1-7. |
Anonymous, “Halftone Definition”, XP055380937, Retrieved from: https://techterms.com/definition/halftone, retrieved on Jun. 13, 2017. |
EP Search Report, 17152824.3-1903, 10 pages, dated Jun. 22, 2017. |
Number | Date | Country | |
---|---|---|---|
20170236041 A1 | Aug 2017 | US |