This disclosure relates to sensor calibration methods for providing robust cross-process registration measurement, and more specifically relates to calibrating individual sensors to ensure a more robust cross-process registration of print heads in a color printing system.
Most printing systems now have the ability to calibrate print head positions to determine the proper alignment of each print head. In a typical print head calibration system, a test pattern is printed and an image-reading sensor reads the pattern and analyzes the response. The test pattern can consist of a series of dashes or printed out bars and the sensors can be any type of image-reading sensor. After the system reads in the test pattern, the system analyzes the pattern to determine if a print head is misaligned based upon the position of the printed pixel compared to the ideal position that the pixel should have been printed at.
In certain solid ink architecture printing systems, full width array image sensors are used, for example, to register a population of print heads in a color printing system. The full width array image sensors are comprised of a series of chips butted together to form the required process width of a given image. These sensors determine the average position of each print head.
A repeatable problem occurs, however, when the full width array sensors read the printed test pattern. Specifically, each full width array sensor typically has been found to have a signature error occurring in the cross process direction of ±20 μm. The errors are unique to each full width array sensor and repeat over the scanning of a particular test pattern. For example, the sensor may be a 600 dpi image sensor array formed from 32 chips butted together and bonded to form an array of a length to match or exceed the cross-process width of the print head array. Because of the multiple units and bondings, errors may be introduced in the sensor array itself. As such, this full width array sensor signature error affects the calibration of each print head. It should be noted that the bulk of the signature error is optically induced having additional chip gap effect.
One possible solution for accounting for this signature error is to modify the printed test pattern. Specifically, the control and algorithm for the test patterns can be modified to minimize the signature effect. However, this process increases the overall financial cost and/or the overall time cost.
U.S. Pat. No. 7,154,110, hereby incorporated by reference, describes an image reading sensor calibration process that uses sensor signature look-up tables to account for sensor signature error. U.S. Pat. No. 7,154,110 describes a calibration process where multiple test patterns having random line patterns are measured by an image reading sensor. The test patterns are sampled multiple times at multiple x-positions as the system processes in the cross-process direction. The test patterns used in U.S. Pat. No. 7,154,110 are from lower cost printers. U.S. Pat. No. 7,154,110 determines sensor error by solving an over-determined matrix equation using relative positions of neighboring lines. However, the techniques of U.S. Pat. No. 7,154,110 are time consuming and not very cost effective because of the repeated calibration of the image reading sensors as they are sampled multiple times at multiple x-positions over the test patterns.
In order to address the drawbacks to the above-described calibration apparatus, a system and method for calibrating sensors for robust cross-process registration measurement are provided. The system and method provides a correction process in which the system may provide a registration target consisting of a series of bar patterns, the location of the bar patterns are determined, and the corrected position is determined by subtracting the positional error from the measured position. In exemplary embodiments, the test pattern is a high quality lithographic test pattern that helps calibrate the image reading sensors. The image reading sensors sample the test pattern once to determine the sensor signature error in each individual sensor. In an exemplary embodiment, sensor calibration is performed offline on a bench using a stationary sensor. It should also be appreciated that in an exemplary embodiment, an absolute measurement technique is used to determine the sensor error by subtracting the intended position of the sensor from the actual measured position. The absolute measurement technique is advantageous over previous technology because it reduces the time spent calibrating the sensors and the overall cost associated for calibrating each sensor.
In accordance with various aspects of the disclosure, a method for calibrating print heads to account for signature error of an image reading sensor, comprises the steps of providing a first test pattern having a series of bars, the bars having known centroid locations; reading each bar of the first test pattern using the image reading sensor; computing the centroid location of each bar pattern using the sensor; calculating the signature error of each image reading sensor by comparing the sensor read centroid location to the corresponding known centroid location; and creating a signature error look-up table containing the signature error for each individual sensor at N pixel intervals.
In other aspects of the disclosure, there is a printing apparatus, comprising a test pattern providing device that provides a first test pattern having a series of bars, the bars having known centroid locations; an image reading sensor that reads each bar of the first test pattern and computes a centroid location of each bar pattern; a signature error calculation part that calculates the signature error of each image reading sensor by comparing the sensor read centroid location to the corresponding known centroid location; and a signature error look-up table containing the signature error for each individual sensor at N pixel intervals.
These and other features and advantages of this disclosure are described in, or apparent from, the following detailed description of various exemplary embodiments of the systems and methods according to this disclosure.
Various exemplary details of systems and methods are described, with reference to the following figures, wherein:
As can be seen in
Although not limiting to this particular embodiment, it should be noted that the process direction is the direction in which the paper is moving (i.e. processing) along the course of printing. In a standard printing device, the paper moves along what most would traditionally consider the y-axis. As such, the process direction refers to movement of the paper along the y-axis. A direction perpendicular to the process direction is referred to as the cross-process direction. In this embodiment, the cross-process direction is along the x-axis and corresponds to a longitudinal axis of the print heads.
A particular calibration sensor 150, such as a full width sensor array formed from an array of butted sensor chips, is provided to sense alignment of the print head 100. The chips may be butted together in sufficient quantity to extend at least as wide as the print head array, as shown.
After the ladder chart test pattern has been provided, the system will proceed to step S420 and use the array of calibration sensors to capture the test pattern across the length of the sensor array bar. Although not limited to this embodiment, the sensor array may be a full width array sensor consisting of a series of chips butted together to form a certain process width of sensor elements of a given resolution (DPI). In exemplary embodiments, the scan line average of the test pattern image results in a 1-D gray level profile across the sensor array,
For each ladder, the system will perform an iteration of steps characterized in steps S430 to S450. Steps 8430 to S450 are performed as a loop for i=1 to n iterations. Starting with the first ladder (i=1), the system will compute the centroid location of the ladder.
In an exemplary embodiment, the centroid is calculated by providing a sample ladder chart test pattern having alternating light and dark portions creating a reflective profile. The sensors will then read the center portions between each rising and falling edge of each alternating light and dark pattern. The centroid location is the area closest to the center of either the light portion or the dark portion. In its most simple embodiment, the centroid will be the exact center portion of the light or dark portion of the ladder chart pattern. However, due to the sensor signature error of the image reading sensors, the centroid location read in by the sensor may be off by several ems. In some cases, the centroid readings were found to be off center anywhere in the range of ±20 μm.
After the system calculates the centroid position of the ladder, the system proceeds to step S440. In step S440, the system will calculate the error of the sensor relative to the ideal position of the ladder test pattern. The system calculates the error using the equation E(i)=X(i)−(i−1)*dX. E(i) is the error amount that the particular sensor is off from the ideal position. In essence, E(i) is actually the calculated signature for the particular sensor. X(i) is the position of the centroid read in by the sensor. The portion of the equation, (i−1)*dX denotes the location of the previous iteration, (i−1), times a constant dX which is the period of distance between the test bars. In an exemplary embodiment, dX is 200 μm. As such, the positional error E(i) is calculated by the actual position X(i) minus the previous iteration, (i−1), times a constant dX.
After the positional error is calculated for a particular iteration, the system will proceed to step S450. In step S450, the system will simply determine if the number of iterations has reached its finish at n. If i=n, the system will proceed to step S460. If i does not equal n, the system will go back to step S430 and increment i by a value of 1 and repeat steps S430 to S450 until i=n.
Once the system has computed the relative positional error for each sensor at every ladder position, the system will proceed to step S460. At step 8460, the system will create a signature error look-up table, SIG_LUT, that is constructed at N-pixel intervals for each image-reading sensor. As such, each image-reading sensor will know the signature error at every pixel in the sensor, and SIG_LUT will contain the sensor signatures for every sensor in the sensor array. For example, one typical full width array sensor alone may have 13392 values for the pixels in the full width array sensor. After the SIG_LUT table is constructed, the system then ends the image-reading sensor characterization process at step S465 and proceeds to perform the correction process for the print head calibration,
After the test pattern is printed out by each of the print heads, the system will proceed to step S480 to scan the dashes and determine the overall alignment and calibration of the individual print heads. In step S480, the image reading sensors scan each dash. For every dash scanned by the sensor, the sensor determines the x-position of the dash. The x-position in an exemplary embodiment is along the x-axis (cross-process direction) and the y-position in an exemplary embodiment is along the y-axis (process direction).
The x-position of the dash may be in fractional pixels. As such, linear interpolation of the sensor signature from the SIG_LUT look-up table may be required. For example, a sensor may read a pixel at position 74.5. However, the SIG_LUT look-up table is constructed for each pixel. Therefore, the system would have to interpolate the error at pixel 74 and at pixel 75 to determine the signature error for pixel 74.5. The x-position at a given pixel is represented by xdash.
After the system determines xdash for a particular dash, the system will proceed to step S490. In step S490, the system will access SIG_LUT for each pixel, and, as explained above, in some instances using linear interpolation, will determine the amount of error of the given sensor to determine the appropriate calibration for a particular print head that takes into account the “signature” of error attributed to the image sensor itself. The amount of error at a given pixel is denoted by edash. The value of edash is the amount in which the given sensor is misreading the pixel alignment at a particular location. In essence, it is the sensor's signature for that particular value. As such, the system can correct for the misreading of the sensor by simply adjusting for edash.
Once the system determines edash for a given pixel, the system proceeds to step S500. At step S500, the system will adjust for the sensor's signature by offsetting xdash by the error value in edash. As such, the system will determine xdash
The image processing apparatus 800 includes a print head calibration unit 860, a bus 870, a memory 880, and a controller 890. In an exemplary embodiment, the print head calibration unit 860 has image reading sensors 835, a second test pattern printer 865, and a signature error look-up table 855.
The sensor calibration apparatus includes a sensor calibration unit 810, a bus 875, a memory 885, and a controller 895. In an exemplary embodiment, the sensor calibration unit 810 has a first test pattern provider 820, image reading sensors 830, a signature error calculation unit 840, and a signature error look-up table 850.
The memory 880 may serve as a buffer for information coming into or going out of the image processing apparatus 800, may store the signature error look-up table 855, may store any necessary programs and/or data for implementing the functions of the image processing apparatus 800, and/or may store data at various stages of processing. Furthermore, it should be appreciated that the memory 880, while depicted as a single entity, may actually be distributed. Alterable portions of the memory 880 are, in various exemplary embodiments, implemented using RAM. However, the memory 880 may also be implemented using disk storage, optical storage, flash memory or the like.
The memory 885 may serve as a buffer for information coming into or going out of the sensor calibration apparatus 805, may store the signature error look-up table 850, may store any necessary programs and/or data for implementing the functions of the sensor calibration apparatus 805, and/or may store data at various stages of processing. Furthermore, it should be appreciated that the memory 885, while depicted as a single entity, may actually be distributed. Alterable portions of the memory 885 are, in various exemplary embodiments, implemented using RAM. However, the memory 885 may also be implemented using disk storage, optical storage, flash memory or the like.
The controller 890 controls the operation of other components of the image processing apparatus 800, performs any necessary calculations and executes any necessary programs for implementing the process of the image processing apparatus 800 and its individual components, and controls the flow of data between other components of the image processing apparatus 800 as needed.
The controller 895 controls the operation of other components of the sensor calibration apparatus 805, performs any necessary calculations and executes any necessary programs for implementing the process of the sensor calibration apparatus 805 and its individual components, and controls the flow of data between other components of the sensor calibration apparatus 805 as needed.
Within the sensor calibration unit 810, the first test pattern provider device 820 provides a first test pattern having a series of bars, where for each bar, the sensor calibration unit 810 knows the ideal centroid location of the bar. The first test pattern can consist ladder charts printed out for a known period. As can be seen in
After the first test pattern provider 820 provides the test pattern, the sensor calibration unit 810 will activate the image reading sensors 830 to read the test pattern. Although not limited to this embodiment, the image reading sensors 830 may be a full width array of sensors consisting of a series of chips butted together to form a defined process width. In exemplary embodiments, the scan line average of the test pattern image results in a 1-D gray level profile across the sensor array. It should also be appreciated that, in an exemplary embodiment, the image reading sensors 830 are the same image reading sensors 835 that are placed in the printhead calibration unit 860.
Once the image reading sensors 830 starts reading the test pattern, the sensor calibration unit 810 will calculate the signature error of each sensor using the signature error calculating unit 840. For each ladder of the test pattern, the signature error calculating unit 840 will perform an iteration of steps for i=1 to n iterations. Starting with the first ladder (i=1), the signature error calculating unit 840 will compute the centroid location of the ladder.
In an exemplary embodiment, the centroid is calculated by printing out a sample ladder chart test pattern having alternating light and dark portions creating a reflective profile. The sensors will then read the center portions between each rising and falling edge of each alternating light and dark pattern. The centroid location is there area closest to the center of either the light portion or the dark portion. In its most simple embodiment, the centroid will be the exact center portion of the light or dark portion of the ladder chart pattern. However, due to the sensor signature error of the image reading sensors, the centroid location read in by each sensor may be off by several μms. In some cases, the centroid readings were found to be off center anywhere in the range of ±20 μm.
After the signature error calculating unit 840 calculates the centroid position of the ladder, the signature error calculating unit 840 can calculate the error of the sensor relative to the ideal position of the ladder test pattern. The signature error calculating unit 840 calculates the error using the equation E(i)=X(i)−(i−1)*dX. E(i) is the error amount that the particular sensor is off from the ideal position. In essence, E(i) is actually the calculated signature for the particular sensor. X(i) is the position of the centroid read in by the sensor. The portion of the equation, (i−1)*dX denotes the location of the previous iteration, (i−1), times a constant dX which is the period of distance between the test bars. In an exemplary embodiment, dX is 200 μm. As such, the positional error E(i) is calculated by the actual position X(i) minus the previous iteration, (i−1), times a constant dX.
After the positional error is calculated for a particular iteration, the signature error calculating unit 840 will simply determine if the number of iterations has reached its finish at n. If i=n, the sensor calibration unit 810 will create the signature error look-up table 850, otherwise the sensor calibration unit 810 will continue the process of signature error calculation.
Once the system has computed the relative positional error for each sensor at every ladder position, the sensor calibration unit 810 will create a signature error look-up table 850, SIG_LUT, that may be constructed at N-pixel intervals for each image-reading sensor in the array. As such, the signature error profile will encompass every pixel in the sensor, and SIG_LUT will contain the sensor signatures for every sensor in the sensor array. For example, one full width array sensor alone may have 13392 values for the pixels in the full width array sensor. After the signature error look-up table is created, the image processing apparatus no longer utilizes the sensor calibration unit 810, and in operation, uses the print head calibration unit 860 to calibrate an array of print heads. It should be appreciated that in an exemplary embodiment, after the signature error look-up table 850 (SIG13 LUT) is created, the signature error look-up table 850 is placed within the image processing unit 800 as the signature error look-up table 855 (SIG_LUT).
The print head calibration unit 860 will print out a test pattern using a second test pattern printer 865 consisting of a series of CMYK dashes to quantify x-direction, y-direction, and roll of the print head system. The test pattern is periodic in the cross-process direction in order to sample jets in the same row within a given print head. Printed dash pattern parameters, such as dash length and the number of repeated dashes may be dependent upon sensor contrast and noise. Other considerations, such as image size and ink usage are weighed when determining the optimization of the test pattern design.
After the test pattern is printed out by each of the print heads, the print head calibration unit 860 will scan the dashes using the image reading sensors 835 and determine the overall alignment and calibration of the individual print heads. For every dash scanned by the image reading sensor 835, the sensor determines the x-position of the dash. The x-position in an exemplary embodiment is along the x-axis (cross-process direction) and the y-position in an exemplary embodiment is along the y-axis (process direction).
The x-position of the dash may be in fractional pixels. As such, linear interpolation of the sensor signature from the SIG_LUT look-up table is required. For example, a sensor may read a pixel at position 74.5. However, the SIG_LUT look-up table is constructed for each pixel. Therefore, the print head calibration unit 860 would have to interpolate the error at pixel 74 and at pixel 75 to determine the signature error for pixel 74.5. The x-position at a given pixel is represented by xdash.
After the print head calibration unit 860 determines xdash for a particular dash, the print head calibration unit 860 will access SIG_LUT for each pixel, and, as explained above, in some instances using linear interpolation, will determine the amount of error of the given image reading sensor 835 to help determine the appropriate calibration for a particular print head. The amount of error at a given pixel is denoted by edash. The value of edash is the amount in which the given sensor is misreading the pixel alignment at a particular location. In essence, it is the sensor's signature for that particular value. As such, the print head calibration unit 860 can correct for the misreading of the image reading sensor 835 by simply adjusting for edash.
Once the print head calibration unit 860 determines edash for a given pixel, the print head calibration unit 860 will adjust for the image reading sensor's signature by offsetting xdash by the error value in edash. As such, the print head calibration unit 860 will determine xdash
It will be appreciated that various of the above-disclosed and other features and functions, or alternatives thereof may be desirably combined into many other different systems or applications. Also, various presently unforeseen or unanticipated alternatives, modifications, variations or improvements therein may be subsequently made by those skilled in the art, and are also intended to be encompassed by the following claims.