1. Field of the Invention
The present invention relates to an image recording apparatus and a control method therefor.
2. Description of the Related Art
Recently, faster printers have longer printheads. Some full-line printers have a printhead with a width corresponding to a print page to speed up printing. Such printers can print a large area at once and hence can speed up printing as compared with conventional printers of a type designed to reciprocate a recording head. Along with the development of such printers, demands have arisen for higher processing speeds of conversion from print data into recording image data for actual recording by a printhead. Parallelization is one of techniques used for an increase in this processing speed. As a parallelization method, a method of dividing a printing area is known. This method can cope with an increase in printing width by increasing a division number, and hence can provide a system with high scalability with respect to the elongation of the printheads of printers (for example, Japanese Patent No. 4125717).
The above method, however, sometimes causes processing discontinuity between divided areas. When performing print control using adjacent pixels, it is sometime impossible to perform proper control because of a lack of information for the control. For example, such control includes non-discharge complementation control to be performed when a printhead cannot discharge any ink. Conventional non-discharge complementation is performed by assigning recoding image data to adjacent nozzles. When, however, performing processing upon dividing an area, recording image data cannot sometimes be assigned to adjacent nozzles, resulting in image quality deterioration such as white streaking. This problem causes serious image quality deterioration, in particular, in a full multi-printer designed to print on a printing area only once.
As a solution for such discontinuity, a method of sharing a memory is known. In this method, as the number of parallel operations increases, the amount of access to data in the memory per unit time multiplies. This may cause a decrease in processing speed. Consider, for example, a case in which each circuit for quantizing multi-valued image data requires a memory access data amount per unit time as 600 MBytes/sec. In this case, if the number of quantization circuits is increased to three to increase the number of parallel operations, it requires three times the access data amount, that is, 1,800 MBytes/sec. In practice, the accessible band of the memory has its own limit. Even if, therefore, the number of parallel operations is increased, a wait time for data acquisition from the memory occurs. That is, there is a limit to an increase in speed in accordance with an increase in the number of parallel operations.
The present invention has been made in consideration of the above problem. According to an aspect of the invention, there is provided an image recording apparatus comprising: a recording head configured to record an image by discharging ink onto a recording medium; a first processing unit configured to perform processing of generating recording image data of a first area to be recorded by the recording head and processing of performing driving control on a corresponding part of the recording head for recording on the first area; a second processing unit configured to perform processing of generating recording image data of a second area to be recorded by the recording head and processing of performing driving control on a corresponding part of the recording head for recording on the second area, the second processing unit being configured to operate concurrently with the first processing unit; a dividing unit configured to generate, from input data, divided data corresponding to the first area and the second area and partly overlapping each other and supply the respective divided data to the first processing unit and the second processing unit; and a detection unit configured to detect a recording characteristic of the recording head, wherein each of the first processing unit and the second processing unit includes a generation unit configured to generate the recording image data from the divided data based on a characteristic of the recording head corresponding to an area whose processing is assigned to one of the processing units and a partial area whose processing is assigned to the other processing unit, and a control unit configured to perform driving control on the recording head based on data, in generated recording image data, which corresponds to an area whose processing is assigned to one of the processing units.
According to the present invention, it is possible to reduce image deterioration without decreasing a processing speed even in a case in which image data for printing is divided into areas, and each processing unit performs print processing based on print data of each divided area.
Further features of the present invention will become apparent from the following description of exemplary embodiments (with reference to the attached drawings).
The embodiments of the present invention will be described in detail below with reference to the accompanying drawings.
Referring back to
A scanner 107 having reading elements arrayed at a predetermined pitch is arrayed at a position downstream of the recording heads 101 to 104 in the y-axis direction while being arrayed in parallel with the recording heads 101 to 104. The scanner 107 can read an image recorded by the recording heads 101 to 104 and output the read image as RGB multi-valued data (for example, 8 bits=256 tones per color component).
The host PC 200 mainly includes the following elements. A CPU 201 executes processing in accordance with programs held in an HDD 203 and a RAM 202 as storage units. The RAM 202 is a volatile storage which temporarily holds programs and data. The HDD 203 is a nonvolatile storage which holds programs and data, like the RAM. In this embodiment, a data transfer I/F (interface) 204 controls communication of data with the printer 100. As a connection scheme for this data communication, a USB, IEEE1394, LAN, or the like can be used. A keyboard/mouse I/F 205 is an I/F which controls an HID (Human Interface Device) such as a keyboard or mouse. The user can perform an input operation via this I/F. A display I/F 206 controls display on a display (not shown).
The printer 100 includes ASICs (Application Specific Integrated Circuits) 301a, 301b, and 301c as processing units. The ASICs 301a, 301b, and 301c have the same arrangement. For this reason, the ASIC 301a will be described below.
The ASIC 301a mainly includes the following elements. A CPU 211a executes processing in each embodiment (to be described later) in accordance with programs held in a ROM 213a and a RAM 212a. The RAM 212a is a volatile storage which temporarily holds programs and data. The ROM 213a is a nonvolatile storage which can hold table data and programs to be used for processing (to be described later).
A data transfer I/F 214a controls data communication with the host PC 200. In addition, the data transfer I/F 214a also controls data transfer between a data transfer I/F 214b of the ASIC 301b and a data transfer I/F 214c of the ASIC 301c.
As described above, a USB, LAN, IEEE1394, or the like is used for data communication between the host PC 200 and the ASIC 301a. Assume that communication between the ASIC 301a and the ASIC 301c is performed by using a bus, a communication protocol, and a data format which are different from those used for communication with the host PC 200. For example, communication between ASICs is performed by using a bus such as PCI Express having a sufficiently higher speed than a bus used for communication between the host PC and each ASIC. Alternatively, a memory bus may be directly connected to ASICs for communication. Directly connecting the bus can increase the communication speed between the ASICs.
A head controller 215a controls discharging operations of the recording heads 101 to 104 shown in
An image processing accelerator 216a is hardware which can execute image processing at a higher speed than the CPU 211a. More specifically, the image processing accelerator 216a is configured to read parameters and data required for image processing from predetermined addresses in the RAM 212a. When the CPU 211a writes the above parameters and data at the predetermined addresses in the RAM 212a, the image processing accelerator 216a is activated to perform predetermined image processing for the above data. In this embodiment, the image processing accelerator 216a performs image processing by hardware processing when performing a recording operation including quantization processing. Note that the image processing accelerator 216a is not an essential element, and creation processing for the above table parameters and image processing may be executed by only processing by the CPU 211a.
Although the constituent elements 211a to 217a of the ASIC 301a have been described above, the same applies to constituent elements 211b to 217b of the ASIC 301b and constituent elements 211c to 217c of the ASIC 301c. Note however that the data transfer I/F 214b of the ASIC 301b and the data transfer I/F 214c of the ASIC 301c need not have connection functions for the host PC 200. Alternatively, the use of such functions is inhibited. In addition, assume that specialized programs are respectively stored in the ROMs 213a, 213b, and 213c in the ASICs 301a to 301c.
The ASIC 301a receives print data (multi-valued image data in the sRGB format in this embodiment) transmitted from the host PC 200. The ASIC 301a then divides the input data according to predetermined areas, and distributes (transmits) the print data in the respective areas to the ASICs 301b and 301c connected to the recording-head unit 401. In this case, the predetermined areas are printing areas in which image formation is performed by nozzles to be respectively controlled by the ASICs 301b and 301c, and are areas divided in a direction orthogonal to the array direction of nozzles, like areas AREA 402 and AREA 403. The ASICs 301b and 301c respectively receive the divided print data in their charge, and temporarily store the divided print data in local RAMS 212b and 212c. Since the ASICs 301b and 301c are independent of each other, they can concurrently process the divided print data stored in the local RAM 212b and 212c. The ASICs 301b and 301c then generate recording image data to be recorded by the recording-head unit 401 from the stored print data. Image processing accelerators 216b and 216c perform this recording image data generation processing. The image processing accelerators 216b and 216c perform the same processing. For this reason, processing performed by the image processing accelerator 216b will be described, and a description of the image processing accelerator 216c will be omitted.
The image processing accelerator 216b converts print data (print data in the area AREA 402) as multi-valued image data in the sRGB format stored in the RAM 212b into multi-valued image data in a YMCK recording color space. The image processing accelerator 216b quantizes the converted YMCK multi-valued image data, and writes back the quantized YMCK image data as recording image data in the RAM 212b. Each nozzle provided in the recording heads 101 to 104 according to this embodiment is controlled by a binary value indicating whether to discharge ink or not. Therefore, the above quantization processing can be regarded as binarization processing. As typical binarization methods, there are known techniques such as a dither method using a dither matrix and an error diffusion method. The following description is based on the assumption that the dither method is used.
The ASIC 301a functions as a controller which controls communication with the host PC 200 while controlling the remaining ASICs 301b and 301c. In the following description, therefore, the ASIC 301a will be referred to as the controller ASIC and the ASICs 301b and 301c will be referred to the image recording ASICs so as to be discriminated from each other.
The controller ASIC 301a includes a data input unit 601 which receives print data (sRGB multi-valued image data in this embodiment) from the host PC 200 via the data transfer I/F 214a and temporarily stores the data in the RAM 212a. The controller ASIC 301a also includes a data dividing unit 602 which divides the received print data into areas to be respectively processed by the ASICs 301b and 301c and distributes the divided data to the image recording ASICs 301b and 301c. In addition, the controller ASIC 301a includes a communication unit 615 (the data transfer I/F 214a serving the same function) for communication between the ASICs 301b and 301c.
Note that the divided print data supplied from the data dividing unit 602 to the ASICs 301b and 301c include an overlapping area corresponding to two pixels in the horizontal direction, as shown in
Constituent elements 603 to 608 of the image recording ASIC 301b are substantially the same as constituent elements 609 to 614 of the image recording ASIC 301c. Therefore, the image recording ASIC 301b will be described below.
The recording characteristic detection unit 603 acquires information concerning the amounts of ink from the corresponding nozzles of the recording-head unit 401 which has performed recording on the area AREA 402 by making the scanner 107 read the recoding medium 106. The recording characteristic detection unit 603 then specifies the position of a discharge failure nozzle. More specifically, the recording characteristic detection unit 603 records a preset test pattern and reads it with the scanner 107 for each of color components of Y, M, C, and K, determines for each recorded color component whether there is any discharge failure nozzle, and specifies its position, if any. The communication unit 604 notifies the ASIC 301c, via the communication unit 604, the communication unit 615, and a communication unit 610, of the information obtained by the recording characteristic detection unit 603, that is, the information indicating whether there is any discharge failure nozzle and information indicating the recorded color component and the position of the corresponding nozzle, if any. The ASIC 301c also performs similar processing. As a result, all the ASICs (the two ASICs 301b and 301c in this embodiment) associated with the recording processing share the information concerning the discharge failure nozzle. The information obtained by the recording characteristic detection unit 603 and the information notified from another ASIC 301c are stored/held in the RAM 212b. Note that the ASIC 301b may separately incorporate a writable nonvolatile memory and write such information in it. In this case, the information is not lost even if the power supply is turned off unless recording processing for a test pattern is executed again.
As described above, the divided data input unit 605 receives divided print data (sRGB multi-valued image data) supplied from the controller ASIC 301a and temporarily stores the data in the RAM 212b. The divided data conversion unit 606 converts the divided print data stored in the RAM 212b into multi-valued data in a YMCK recording color space. This conversion may be performed by using matrix computation processing for RGB→YMCK conversion or a three-dimensional LUT. The divided data conversion unit 606 then quantizes (binarizes) the multi-valued data of the respective color components of Y, M, C, and K in the recording color space by using a dither matrix, and stores the binarization results as recording image data in the RAM 212b.
Note that the divided data conversion unit 606 may perform part or all of the above processing by using the image processing accelerator 216b. Using the image processing accelerator 216b can more speed up processing than by using the CPU 211b.
The divided data correction unit 607 corrects the recording image data (binary image data) generated by the divided data conversion unit 606 based on the information obtained via the communication unit 604, as needed (this correction processing will be described in detail later).
The RAM 212b stores recording image data corresponding to the area AREA 402 and recording image data corresponding to two pixels from the left end of the area AREA 403. The recording head control unit 608 reads out data corresponding to the area AREA 402, which is stored in the RAM 212b, and supplies the binary data to a head controller 215b, thereby performing drive control of the corresponding nozzles.
Correction processing by the divided data correction unit 607 according to this embodiment will be described next with reference to
Assume that a nozzle 1702 of the recording head 1701 is a discharge failure nozzle. In this case, although dots 1704 and 1705 in the binary pattern 1703 are recording targets for the discharge failure nozzle 1702, no ink is discharged in practice. The dither method is designed to express a density tone by the ratio of an actually recorded area (dot count) to a unit area. If, therefore, the dots 1704 and 1705 are not recorded, the density of the binary pattern 1703 does not reach an intended density.
If, therefore, there are the discharge dots 1704 and 1705 which should have been recorded by the discharge failure nozzle 1702, the divided data correction unit 607 according to this embodiment performs non-discharge complementation processing of moving these discharge dots to the positions of non-discharge dots (non-driving data) in data for nozzles which are adjacent to the discharge failure nozzle and can discharge ink, if any. As a result, the binary pattern 1703 is changed to a binary pattern 1706 in
The above description has been made on correction processing by the divided data correction unit 607. A divided data conversion unit 612 of the ASIC 301c performs correction processing by using the same algorithm as that used by the divided data correction unit 607.
A case in which a discharge failure nozzle is accidentally located at the boundary position between the area AREA 402 and the area AREA 403 will be described below with reference to
As shown in
The divided data input unit 605 of the ASIC 301b receives print data of the area AREA 402 and print data of an area corresponding to two pixels on the left end of the area AREA 403 in the horizontal direction, and temporarily stores the data in the RAM 212b. The divided data conversion unit 606 generates recording image data 802 by performing color space conversion and quantization processing for the print data. The dots in a frame 804 in the recording image data 802 are to be recorded by the discharge failure nozzle 801.
Since the divided data correction unit 607 knows that the recording image data 802 includes dots to be recorded by the discharge failure nozzle 801, the divided data correction unit 607 performs non-discharge complementation processing described above with respect to the frame 804. As a result, the recording image data 802 is corrected into recording image data 806. That is, the dots in the frame 804 which indicate the discharge of ink are moved to arrows 806a and 806b in
A divided data input unit 611 of the ASIC 301c receives the print data of the area AREA 403 and the print data of an area corresponding to two pixels on the right end of the area AREA 402 in the horizontal direction, and temporarily stores the data in the RAM 212c. A divided data conversion unit 612 generates recording image data 803 by performing color space conversion and quantization processing for the print data. The dots in a frame 805 in the recording image data 803 are to be recorded by the discharge failure nozzle 801. A divided data correction unit 613 performs non-discharge complementation processing described above with respect to the frame 805. As a result, the recording image data 803 is corrected into recording image data 807. That is, the dots in the frame 805 which indicate the discharge of ink are moved to arrows 807a and 807b in
In step S1301, the ASIC 301b receives the print data of an assigned area and discharge failure nozzle information. The assigned area is an area divided by the data dividing unit 602. This area corresponds to an area corresponding to two pixels on the left end of the area AREA 403 in addition to the area AREA 402. The discharge failure nozzle information includes discharge failure nozzle information detected by the recording characteristic detection unit 603 and discharge failure nozzle information received by the communication unit 604. In step S1302, the ASIC 301b converts the print data into data in the YMCK color space. In step S1303, the ASIC 301b generates recording image data by quantizing (binarizing in this embodiment) the print data converted in step S1302. The divided data conversion unit 606 performs processing in steps S1302 and S1303. In step S1304, non-discharge complementation processing is performed with respect to the recording image data quantized in step S1303. The divided data correction unit 607 performs this processing in step S1304. In step S1305, the recording image data having undergone non-discharge complementation in step S1304 is transmitted to the recording-head unit 401. The recording head control unit 608 executes this processing in step S1305. The ASIC 301c also performs similar processing.
As a result of the above processing, the ASICs 301b and 301c record a binary pattern 808 in
As is also obvious from the above description, the ASICs 301b and 301c are independent of each other, and can concurrently execute conversion, quantization, and non-discharge complementation without interference. In addition, the ASICs 301b and 301c have already known information concerning the presence and position of a discharge failure nozzle by communicating with each other. Therefore, the ASICs 301b and 301c can reduce the influence of a discharge failure nozzle by only generating recording image data by performing the above processing for overlapping print data and performing recording processing in accordance with the recording image data of the respective assigned print areas.
According to the above description, the divided data correction unit 607 performs non-discharge complementation processing by pattern matching. However, this processing may be implemented by determination processing. An example of non-discharge complementation processing by the divided data correction unit 607 in this case will be described with the flowchart of
Assume that in the following description, recording image data (binary data) generated by the divided data conversion unit 606 has already been stored in the RAM 212b. In addition, a variable i indicates a pixel position in the horizontal direction (the x-axis direction in
First of all, in step S901, the divided data correction unit 607 stores the position of a discharge failure nozzle in the variable i, sets the variable j to initial value 0, and sets the flag FLAG to initial value 0. In step S902, the divided data correction unit 607 determines whether the value of the variable j is equal to or less than N. If the variable i exceeds N, the divided data correction unit 607 terminates the non-discharge complementation processing.
If the variable j is equal to or less than N, it indicates that there is an unprocessed line. The divided data correction unit 607 therefore determines in step S903 whether a target pixel P(i, j) is “1”. If P(i, j)=0, since the target pixel is a non-ink discharge pixel, the variable j is incremented by “1” in step S911, and the process returns to step S902.
In addition, if P(i, j)=1, the process advances to step S904, in which the divided data correction unit 607 determines whether the flag FLAG is 0. If FLAG=0, since the left adjacent pixel of the target pixel is preferentially set as a movement destination, the divided data correction unit 607 determines in step S905 whether a left adjacent pixel P(i−1, j) is “0” (non-ink discharge pixel). If P(i−1, j)=0, the divided data correction unit 607 changes the left adjacent P(i−1, j) of the target pixel to “1” in step S906. The divided data correction unit 607 then sets the flag FLAG to “1” to set the next movement destination pixel to the right adjacent pixel (step S907). The divided data correction unit 607 causes the process to advance to step S911.
Upon determining NO in step S904 or S905, the divided data correction unit 607 causes the process to advance to step S908. In step S908, the divided data correction unit 607 determines whether a right adjacent pixel P(i+1, j) of the target pixel is “0” (non-ink discharge pixel). If P(i+1, j)=0, the divided data conversion unit 606 changes the right adjacent P(i+1, j) of the target pixel to “1” in step S909. The divided data correction unit 607 then sets the flag FLAG to “0” to set the next movement destination pixel to the left adjacent pixel (step S910). The divided data correction unit 607 causes the process to advance to step S911.
According to the above description, the divided data correction unit 607 of the ASIC 301b performs the above processing. However, the divided data correction unit 613 of the ASIC 301c also performs the same processing. This can produce the same effect as that produced by pattern matching. In addition, it is possible to suppress the consumed amount of memory as compared with pattern matching because of unnecessity to store/hold patterns to be compared.
In the above embodiment, if there is a discharge failure nozzle, non-discharge complementation is performed by using nozzles adjacent to the discharge failure nozzle. If, however, there is another nozzle of the same color in the conveying direction of a recording medium, non-discharge complementation may be performed by using the nozzle. This allows another nozzle to land ink at positions where ink should have been landed by the non-discharge nozzle, and hence can further reduce image quality deterioration such as white streaking as well as maintaining tonality as compared with non-discharge complementation using adjacent nozzles. When, in particular, a discharge failure nozzle is a nozzle which discharges a K ink, non-discharge complementation may be performed by using nozzles located in the paper feed direction and designed to discharge C, M, and Y inks. This can increase the coverage of ink on a sheet and reduce image quality deterioration such as white streaking as compared with non-discharge complementation using adjacent nozzles.
In this embodiment, recording is implemented by joining the joint portions of the recording head with a gradation mask. In this case, the gradation mask is designed to reduce pixels to which ink is to be discharged toward the right side on the joint portion of the nozzle array 811. In addition, the gradation mask is designed reduce pixels to which ink is to be discharged toward the left side on the joint portion of the nozzle array 812. Shifting stepwise ink discharge pixels on the joint portion of each nozzle array to the adjacent recording head in this manner can suppress image quality deterioration such as white streaking caused by the density difference between the recording heads.
The image recording ASICs 301b and 301c perform quantization on the joint portions by using the same algorithm. Therefore, the image recording ASIC 301b knows what kind of quantization result is to be generated on the joint portion of the image recording ASIC 301c. On the contrary, the image recording ASIC 301c knows what kind of quantization result is to be generated on the joint portion of the image recording ASIC 301b. Assume that a nozzle 813 of the nozzle array 811 is a discharge failure nozzle. Since the image recording ASICs 301b and 301c exchange information, the ASIC 301c which performs processing on the nozzle array 812 knows that the nozzle array 811 includes the discharge failure nozzle 813.
The image recording ASIC 301b therefore knows that a frame 816 in the quantization result is a recording target for the discharge failure nozzle 813, but is not recorded in practice. The image recording ASIC 301b therefore erases the data in the frame 816. The image recording ASIC 301c can know the specific positions of ink discharge dots in the frame 816 in the data after quantization by the image recording ASIC 301b. The image recording ASIC 301c therefore sets the corresponding dot positions in a frame 817 to be recorded by an alternate nozzle controlled by itself as ink discharge dots. This implements processing equivalent to moving the ink discharge dots in the frame 816 to the corresponding positions in the frame 817.
Subsequently, the image recording ASICs 301b and 301c perform recording processing in accordance with the quantized data after the correction to obtain a result 819 in
As described above, according to this embodiment, the ASICs 301b and 301c share information indicating the presence/absence and position of a discharge failure nozzle by communication and generate recording image data from the print data of an overlapping area. This makes it possible to eliminate or reduce tonality deterioration regardless of the position of a discharge failure nozzle.
Note that in the above embodiment, print data transmitted by the host PC 200 to the printer 100 is sRGB multi-valued image data. However, the format of print data is not limited to this. For example, encoded image data may be used. In this case, the controller ASIC 301a decodes the encoded data, divides the multi-valued image data obtained by decoding, and distributes the resultant data to the ASICs 301b and 301c. Although there is no limitation in terms of format type, JPEG is a representative format.
In addition, print data may be data written in the page description language (vector-format data). When using this format, the controller ASIC 301a may draw image data in the RGB format based on print data in the RAM 212a, divide the drawn data in the same manner as described in the above embodiment, and distribute the resultant data to the ASICs 301b and 301c.
Furthermore, in the above embodiment, the controller ASIC 301a divides print data and distributes the resultant data to the two ASICs 301b and 301c. However, as shown in
Assume that the specifications of a printer do not support printing of vector data, that is, a host PC is designed to transmit multi-value image data. In this case, since no image conversion or correction processing is performed, the load on a controller ASIC is light accordingly. It is therefore possible to use an arrangement like that shown in
As shown in
In addition, the arrangement configured to perform image processing has been described as an ASIC in this embodiment. However, this arrangement is not necessarily limited to an ASIC as long as each arrangement is a processing unit capable of performing parallel processing.
Note that each variation of the embodiment described above can also be applied to other embodiments described below.
The second embodiment will be described below. The constituent elements of an apparatus according to this embodiment are the same as those in the first embodiment, and a description of them will be omitted. Differences from the first embodiment reside in processing by divided data conversion units 606 and 612 in ASICs 301b and 301c and processing by divided data correction units 607 and 613.
According to the first embodiment, if recording image data after quantization (binarization) includes ink discharge dots to be recorded by a discharge failure noise, adjacent non-ink discharge dots are changed to discharge dots. In contrast to this, the second embodiment implements this operation by head shading processing before binarization. Divided data correction units 607 and 612 perform this head shading processing.
As in the first embodiment, a recording characteristic detection unit 603 of the ASIC 301b detects the amounts of ink from the respective nozzles of the respective recording heads by making a scanner 107 read recording processing on test patterns. Detected state information is stored in a RAM 212b and is also notified to an ASIC 301c via a communication unit 604. State information received from the ASIC 301c via the communication unit 604 is also stored in the RAM 212b. The ASIC 301c also performs the same processing as that described above, and the respective ASICs share information concerning the amounts of ink discharged.
Note that the timing of the communication of information concerning the amounts of ink discharged is not the timing of general print processing but is the timing at which the user issues an instruction to record a test pattern with an operation unit (not shown). In addition, in order to hold the information unless new information is detected, the obtained information may be stored in a nonvolatile memory or the like.
In addition, the nozzles controlled by the ASIC 301c are nozzles arranged on the right side of the nozzle 1001 and including it, and the nozzles controlled by the ASIC 301b are nozzles arranged on the left side of the nozzle 1001.
Referring to
Head shading processing for the area data 1005 after conversion to the recording color space, which is performed by the ASIC 301b, will be described next. The divided data correction unit 607 performs head shading processing. The ASIC 301b knows the amounts of ink discharged from the respective nozzles of the recording head from state information 1007 received from the recording characteristic detection unit 603 and the ASIC 301c. The ASIC 301b performs head shading by performing filter processing for the area data 1005. Performing filter processing can reduce image quality deterioration such as color unevenness even in a recording head in which the amounts of ink discharged from the nozzles abruptly change. In this case, an area 1008 which is not printed is used as a marginal portion of filter processing. The ASIC 301c performs similar processing. In head shading processing, an area 1009 which is not printed is used as a marginal portion.
The divided data conversion unit 606 generates quantized recording image data from the print data having undergone the head shading processing. Subsequently, a recording head control unit 608 controls the recording head in accordance with the recording image data for recording with the nozzles controlled by the ASIC 301b. In the case of the ASIC 301b, recording print data sent to the recording head is data excluding an area corresponding to one pixel on the right end. On the other hand, the ASIC 301c performs recording processing by using recording image data excluding an area corresponding one pixel on the left end.
A preferred example of a head shading method for the recording head according to the second embodiment will be described. Referring to
0.9 0.9 1.1
0.9 0.9 1.1
0.9 0.9 1.1
Head shading is performed by performing filter processing while deciding a filter intensity in the above manner.
Note that in the above description, the filter size is 3×3. However, this is not exhaustive. An abrupt change in amount of ink discharged can be effectively absorbed by using a wider filter such as a 5×5 or 7×7 filter. In addition, according to this embodiment, a filter intensity is decided uniquely from a discharge amount rank. However, a filter intensity may be obtained by multiplying a coefficient decided from a discharge amount rank by a coefficient which increases toward the center as in the case of a Gaussian filter. This can minimize the bluntness of an edge portion of an image. Alternatively, a coefficient may be changed in accordance with the value of an ink color density. For example, when an ink color density value of 0 expresses a white point in an image, changing the density color may color each white point, resulting in image quality deterioration. If it is possible to change a filter coefficient in accordance with an ink density value, an optimal filter coefficient can be set in accordance with an ink density value. This can reduce image quality deterioration. As a method of deciding a filter coefficient in accordance with an ink density value, a formula may be used for calculation or a 1D-LUT may be used for calculation.
According to the above description, in the recording head, an area where ink color conversion is redundantly performed at the boundary of areas assigned to the ASICs 301b and 301c is set, and the nozzle discharge amount information 1007 is transmitted. This makes it possible to perform head shading processing even when different ASICs control a recording head, thus reducing image quality deterioration.
The second embodiment has exemplified the case in which head shading processing using areas assigned to both the ASICs 301b and 301c can be performed by making them process an area in a range at the boundary between the areas assigned to the ASICs. An effect similar to that of the second embodiment can be obtained by another implementation method, that is, transmitting ink value increase/decrease information to ASICs in charge of adjacent areas.
As shown in
Head shading processing will be described in a case in which an ASIC 302 controls the nozzle array 1011 and an ASIC 303 controls the nozzle array 1012, as shown in
A preferred example of head shading processing in the printing head joint portions will be described next. Discharge amount ranks are obtained from nozzle discharge amount information as in the case shown in
According to the above description, in the joint portions of the recording head, the amounts of ink discharged from the nozzles of the nozzle arrays 1011 and 1012 are separately detected. However, the amount of ink discharged from one nozzle may be detected while the joint portions of the recording head are joined with a gradation mask. Transmitting the detected amounts of ink discharged to both the ASICs 301b and 301c can obtain the same effect as that in the first embodiment.
The second embodiment has exemplified the case in which an area where ink color conversion is redundantly performed is set at the boundary between the areas assigned to the ASICs 301b and 301c, and the discharge amount information 1014 and the nozzle discharge amount information 1015 are communicated. With this operation, even if different ASICs control the recording head, head shading processing can be performed. This can reduce image quality deterioration.
In the second embodiment, the divided data correction unit 613 performs head shading processing for divided data after ink color conversion. However, head shading processing may be performed for divided data before ink color conversion. Referring to
A preferred example of processing will be described in detail below. A recording characteristic detection unit 603 of an ASIC 301b generates dot count information by counting the number of dots to be discharged by using a dot count filter 1108 with respect to four-line (depending on the size of a dither matrix for quantization processing) recording image data after quantization stored in a RAM 212b. That is, the value of data to be driven within the filter matrix is counted every time the matrix is moved by one pixel. This dot count information is transmitted to an ASIC 301c via the communication unit 604.
A recording characteristic detection unit 609 of the ASIC 301c also generates dot count information in the same manner, and transmits the information to the ASIC 301b via a communication unit 610. As a result, the ASICs 301b and 301c share the dot count information. As described above, since the timing of the communication of dot count information is after the quantization of print data, the communication is performed during printing.
Dot count processing with respect to the area 1104 after quantization, which is performed by the ASIC 301b, will be described next. Dots are counted from quantized print data by using the dot count filter 1108 with a size of, for example, 3×3. All the filter coefficients of the dot count filter are 1. Performing filter processing can generate dot count information 1106. All generated dot count information is transmitted to the ASIC 301c via the communication unit 604. Likewise, the ASIC 301c also generates dot count information 1107 from print data after quantization, and transmits the information to the ASIC 301b via the communication unit 610. With this operation, the ASICs 301b and 301c can share the dot count information of all the areas recorded by the recording head 101. In dot count control, the ASIC 301b compares a count threshold decided for each printer with the pieces of dot count information 1106 and 1107. If there is at least one pixel whose count information exceeds the count threshold, the printing speed is decreased. As the number of dots simultaneously discharged increases, ink cannot be stably discharged, resulting in image quality deterioration such as white streaking and color unevenness. Decreasing the printing speed based on dot count information can reduce the number of dots to be simultaneously discharged, thereby stably discharging ink. This can reduce image quality deterioration such as white streaking and color unevenness.
As a preferred example, therefore, an ASIC 302 and an ASIC 303 need to obtain the same quantization result on the area 1102. This is merely a preferred example, and the obtained quantization results need not perfectly match each other. The present invention can be applied to a case in which quantization results differ from each other within the range in which no image quality deterioration occurs after non-discharge complementation. For example, when dot counts are compared with each other within a predetermined range, the present invention can be applied if the difference falls within a predetermined range.
Printing speeds include a normal speed mode and a low speed mode. In the low speed mode, the number of times of ink discharge from each nozzle per unit time is smaller than that in the normal speed mode. Simply put, the time intervals (or the driving cycle) at which nozzles are continuously driven in the normal speed mode is doubled in the low speed mode. Note however that the conveying speed of a recording medium in the low speed mode is ½ that in the normal speed mode. A simple method of doubling the recording time intervals of nozzles can be implemented by inserting blank dots in the conveying direction as indicated by reference numeral 1109 in
Note that when recording is to be performed at a speed 1/N the normal speed, the driving time intervals of nozzles may be multiplied by N, and the conveying speed of a recording medium may be multiplied by 1/N.
As a result of the above operation, according to the third embodiment, in the recording head, an area to be redundantly quantified is set at the boundary between areas assigned to the ASICs 301b and 301c, and discharge failure nozzle information is communicated. This can perform non-discharge complementation processing between different ASICs and reduce image quality deterioration.
In the third embodiment, all dot count information is communicated. However, comparing a count value obtained at the time of dot counting with a count threshold can implement the same operation by transmitting only the comparison result to an ASIC in charge of an adjacent area. Transmitting only the comparison result can reduce the communication volume of dot count information and hence can speed up the processing.
In the third embodiment, all dot count information is communicated to image processing ASICs. However, such information may be transmitted to only the ASIC 301a. In this case, the controller ASIC may compare the dot count information with the count threshold to determine whether to decrease the printing speed, and notify the image processing ASICs of the determination result. This can reduce the processing loads on the image processing ASICs and prevent a decrease in processing speed.
In this embodiment, on the recording head joint portions, an area to be redundantly quantified is set at the boundary between the areas assigned to the ASIC 302 and the ASIC 303, and dot count information is communicated. This can perform dot count control between different ASICs and reduce image quality deterioration.
The first to third embodiments may be simultaneously executed.
In step S1601, the ASIC 301b receives the print data (sRGB multi-valued image data) of an assigned area, discharge failure nozzle information, and nozzle discharge information. The print data of the assigned area is data divided by a data dividing unit 602. A dividing method used when performing a plurality of types of correction processing matches the area of a margin 701 with correction processing, of the respective types of correction processing, which uses the largest margin. For example, if margins for non-discharge complementation, head shading, and monitor control are respectively one array, three arrays, and five arrays, the margin 701 is five arrays.
In step S1602, the ASIC 301b converts the input data into multi-valued data in the YMCK recording color space. In step S1603, the ASIC 301b performs head shading processing from ink color data and nozzle discharge amount information. In step S1604, the ASIC 301b quantizes the data after the head shading processing. In step S1605, the ASIC 301b performs non-discharge complementation from the data after the quantization and discharge failure nozzle information. In step S1606, the ASIC 301b performs dot count processing for the data after the non-discharge complementation. In step S1607, dot count information is communicated. In step S1608, the ASIC 301b performs monitor control from the received dot count information. In step S1609, the ASIC 301b transmits the generated print data to the recording-head unit 401 to perform printing. The divided data conversion unit 606 performs steps S1602 and S1604. The divided data correction unit 607 performs step S1603 and steps S1605 to S1609. The ASIC 301c also performs similar processing.
Performing correction processing in the above manner makes it possible to simultaneously execute the first to third embodiments, thereby simultaneously reducing image quality deterioration such as white streaking and color unevenness.
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 a ‘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. 2015-081229, filed Apr. 10, 2015, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2015-081229 | Apr 2015 | JP | national |