The present invention relates to an image processing system and method and, more particularly, to an image processing system and method which control clustering output to a plurality of printers.
A system is known in which one print job is processed by two or more printers in parallel, i.e., clustering output can be executed by connecting a server apparatus and a plurality of color printers through a network. In this system, since a plurality of printers are used, faster output than printing by one printer can be done.
For example, Japanese Patent Laid-Open No. 2001-290622 describes a method of implementing high-speed clustering output. According to this reference, print data is converted into intermediate data and divided for each printer. Then, rasterization to printer-oriented final print data and transmission of the rasterized data to the printers are executed simultaneously in parallel.
In this clustering print system, even when a printer is inoperative, output by the remaining printers is possible. Hence, the system can guarantee a stable printing operation.
Moreover, in a technique described in, e.g., Japanese Patent Laid-Open No. 10-340164, a fault monitoring unit to monitor the status of each machine is provided on a network. When a failure occurs in a printer or machine, print data is diverted to another printer, thereby enabling recovery for each page.
For, e.g., clustering output of print data described in a page description language (PDL) such as PostScript, an optimum intermediate code data is preferably generated in each printer as an output target. In the conventional print system, interpreter processing is executed by preparing a software RIP (Raster Image Processor) with an interpreter for each printer on the server side and creating intermediate code data at a high speed or by executing interpreter processing for each printer one by one and outputting intermediate code data.
In the former case, however, the cost increases because of the software RIP. In the latter case, the processing speed decreases.
In view of the above problems in the conventional art, the present invention has an object to provide an image processing technique which efficiently create an intermediate code corresponding to each of a plurality of image output devices when a server apparatus outputs the same image data to them.
In one aspect of the present invention, an image processing system includes a server apparatus and a plurality of image output apparatuses connected to the server apparatus. The server apparatus comprises an intermediate code generation unit configured to generate an intermediate code on the basis of image data, and an intermediate code transmission unit configured to transmit the intermediate code to each of the plurality of image output apparatuses. Each of the plurality of image output apparatuses comprises an intermediate code reception unit configured to receive the intermediate code from the server apparatus, an output color correction unit configured to execute, for the intermediate code, color correction for output, a rendering unit configured to render an image on the basis of the intermediate code which has undergone the color correction and an image output unit configured to output the rendered image.
The above and other objects and features of the present invention will appear more fully hereinafter from a consideration of the following description taken in connection with the accompanying drawing wherein one example is illustrated by way of example.
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate embodiments of the invention, and together with the description, serve to explain the principles of the invention.
Preferred embodiments of the present invention will be described in detail in accordance with the accompanying drawings. The present invention is not limited by the disclosure of the embodiments and all combinations of the features described in the embodiments are not always indispensable to solving means of the present invention.
In the front-end server A 200 shown in
In the printer engine A 210, a communication I/F unit 30 transmits/receives data to/from the front-end server A 200. An output unit 31 performs print output. A color sensor control unit 32 controls the color sensor 33. The color sensor 33 reads a patch output. A read data storage unit 34 stores the data read by the color sensor 33.
(Color Matching Processing)
Color Matching in Job Management Server
Referring to
Generally, there are three kinds of rendering intents: “Perceptual” to output a photo image, “Colorimetric” to faithfully reproduce, e.g., a logotype, and “Saturation” to clearly output a pie chart or text. As for color matching data for practicing the three schemes, Lab→reference printer CMYK conversion LUTs (lookup tables) are prepared as the destination profile, as shown in
In this embodiment, two cases are assumed, as shown in the table on the lower side of
Color Matching in Front-End Server
Referring to
In this embodiment, “Colorimetric” is assumed as rendering intent in normal output of the front-end server. Hence, a Lab→printer CMYK conversion LUT for “Colorimetric” is prepared as the destination profile, as shown in
In this embodiment, a case is assumed, as shown in the table on the lower side of
In outputting patch data for calibration, CMYK data prepared in advance is directly output without intervening the CMM.
Referring to
Three kinds of rendering intents, i.e., “Perceptual”, “Colorimetric”, and “Saturation” are present in black preservation output of the front-end server. Lab→output printer CMYK conversion LUTs are prepared as the destination profile, as shown in
In this embodiment, a case is assumed, as shown in the table on the lower side of
(Clustering Output)
First, patch data is extracted from the patch data storage unit 15 of the job management server 100 (S100). The patch data is analyzed by the PDL interpreter 12 (S101). Intermediate data as the analysis result is stored in the intermediate data storage unit 13 (S102) and transmitted to the front-end servers A 200 and B 300 (S103).
In the front-end servers A 200 and B 300, patch output is done by the printer engines A 210 and B 310 on the basis of the received intermediate data, and calibration processing based on the colorimetric value is executed. If the spectrophotometer 110 is used to acquire the color value of the patch data, calibration processing using the spectrophotometer 110 is executed in the job management server 100 (S105). If the spectrophotometer 110 is not used, the color sensor is used. Hence, calibration processing using the color sensors 33 of the printer engines A 210 and B 310 is executed in the front-end servers A 200 and B 300 (S106). Details of the calibration processing will be described later.
The client 400 transmits print job data to the job management server 100 (S107). The job control unit 11 of the job management server 100 extracts a job data file in the received Job (S108). The PDL interpreter 12 analyzes the job data file (S109).
Depending on whether to save a black plate (S110) in color matching processing, i.e., when the black preservation flag shown in
Intermediate data generated by the color matching is stored in the intermediate data storage unit 13 (S113) and transmitted to the front-end servers A 200 and B 300 (S114). When the intermediate data is output from the printer engines A 210 and B 310 (S115), the clustering output of this embodiment is ended.
As described above, the following effect can be obtained by the clustering output of this embodiment. The intermediate data of printer reference CMYK created by one PDL interpreter processing (S109) can be subjected to calibration processing (S115 (S602 and S603 in
(Calibration Processing Using Colorimeter)
Intermediate data transmitted from the job management server 100 is stored in the intermediate data storage unit 21 of the front-end server A 200 (S200). The color management processing unit 24 executes processing in patch data output shown in
The rendering unit 23 renders the intermediate data to bitmap image data for printer output (S202). The rendered bitmap image data is transferred to the printer engine A 210 (S203). The patch data is printed (S204).
Color Measurement of the printed patch data is done by the spectrophotometer 110 connected to the job management server 100. The calorimetric result (calorimetric data) is stored in the colorimetric data storage unit 17 of the job management server 100 (S205).
The calibration processing unit 18 of the job management server 100 extracts the calorimetric data from the colorimetric data storage unit 17 (S206) and the printer profile from the profile storage unit 14A (S207). The colorimetric data expressed by the XYZ calorimetric system is converted into Lab data (S208). The printer profile is corrected on the basis of the Lab data (S209). To correct the profile, a correction method based on a small number of patch data colorimetric values as described in, e.g., Japanese Patent Laid-Open No. 10-136219 can be used.
When profile correction is ended, the job management server 100 transmits the calibrated printer profile to the front-end server A 200 (S210). The front-end server A 200 stores the received profile in the profile storage unit 24A (S211).
(Calibration Processing Using Color Sensor)
Intermediate data transmitted from the job management server 100 is stored in the intermediate data storage unit 21 of the front-end server A 200 ($300). The color management processing unit 24 executes processing in patch data output shown in
The rendering unit 23 renders the intermediate data to bitmap image data for printer output (S302). The rendered bitmap image data is transferred to the printer engine A 210 (S303). The patch data is printed (S304).
The printed patch data is read by the color sensor 33 provided in the printer engine A 210. The read data is stored in the read data storage unit 34 of the printer engine A 210 (S305). The read data is transferred to the front-end server A 200 (S306) and stored in the read data storage unit 26 of the front-end server A 200 (S307).
In the front-end server A 200, the read data is extracted from the read data storage unit 26 (S308). The printer profile is extracted from the profile storage unit 24A (S309). The read data is converted into XYZ data (S310). The XYZ data is converted into Lab data (S311). The printer profile is corrected on the basis of the Lab data and set in the profile storage unit 24A (S312). To correct the profile the same method as that in the above-described processing using the spectrophotometer can be used.
(Black Plate Saving Color Matching Processing in Job Management Server (RGB Input))
RGB data in the job data file is extracted (S400). If R=G=B, i.e., the data is black (gray) data, the black flag for the data is turned on (S403), and the RGB values are converted into CMYK values (S404).
C=0, M=0, Y=0, K=255−R
The black flag is set individually for all color data in black preservation color matching processing of this embodiment. The black flag is OFF in the initial state. This flag is used to select normal color matching processing (black flag=OFF) or black preservation color matching processing (black flag=ON) to be executed for the color data.
If NO in step S401, the color management processing unit 14 executes normal color matching processing (S402). The normal color matching processing is executed by using an RGB source profile as the source profile and a printer reference profile (CMYK) as the destination profile shown in
If RGB data remains in the job data file in step S405, the flow returns to step S400. If no RGB data remains, the color matching processing is ended.
With the above-described processing, when the input color space is an RGB space, the color management processing unit 14 in the job management server 100 can create intermediate data having the printer reference CMYK values saved as the black plate.
(Black plate Saving Color Matching Processing in Job Management Server (CMYK Input))
CMYK data in the job data file is extracted (S500). If (C,M,Y,K)=(0,0,0,K), i.e., the data is black (gray) data, the black flag for the data is turned on (S503). Otherwise, the color management processing unit 14 executes normal color matching processing (S502). The normal color matching processing is executed by using a CMYK source profile as the source profile and a printer reference profile (CMYK) as the destination profile shown in
If CMYK data remains in the job data file in step S504, the flow returns to step S500. If no CMYK data remains, the color matching processing is ended.
With the above-described processing, when the input color space is a CMYK space, the color management processing unit 14 in the job management server 100 can create intermediate data having the printer reference CMYK values saved as the black plate.
(Output Processing from Printer Engine)
Intermediate data transmitted from the job management server 100 is stored in the intermediate data storage unit 21 (S600). Depending on whether to save a black plate (S601) in color matching processing, the color management processing unit 24 operates differently. When the black preservation flag shown in
On the other hand, when the black preservation flag is OFF, the color management processing unit 24 executes normal color matching processing (S603). The normal color matching processing is executed by using the printer reference profile as the source profile and a printer profile (CMYK) as the destination profile shown in
The rendering unit 23 renders the intermediate data to bitmap image data for printer output (S604). The rendered bitmap image data is transferred to the printer engine A 210 (S605). The bitmap image data is printed by the printer engine A 210, and the processing is ended (S606).
(Black Plate Saving Color Matching Processing in Front-End Server (RGB Input))
CMYK data in the intermediate data file is extracted (S700). If (C,M,Y,K)=(0,0,0,K), i.e., the data is black (gray) data (S701), and the black flag of the data is ON (S702) the CMYK data is converted into RGB values (S703).
R=255−K, G=255−K, B=255−K
The black flag is set in black preservation color matching processing (S111 in
The color management processing unit 24 executes black preservation color matching processing (S704). The processing is executed by a method described in, e.g., Japanese Patent Laid-Open No. 2004-120566. The processing is executed by using an RGB source profile as the source profile and a printer profile (CMYK) as the destination profile shown in
If the black flag is OFF, or (C,M,Y,K)≠(0,0,0,K), the color management processing unit 24 executes normal color matching processing (S705). The normal color matching processing is executed by using a printer reference profile (CMYK) as the source profile and a printer profile as the destination profile shown in
If CMYK data remains in the job data file, the flow returns to step S700. If no CMYK data remains, the processing is ended.
The printer profile used in the color matching processing in steps S704 and S705 has been corrected by the above-described calibration processing in step S105 or S106 in
With the above-described processing, when the input color space is an RGB space, the color management processing unit 24 in the front-end server A 200 can create intermediate data having the printer CMYK values saved as the black plate.
(Black Plate Saving Color Matching Processing in Front-End Server (CMYK Input))
CMYK data in the intermediate data file is extracted (S800). If (C,M,Y,K)=(0,0,0,K), i.e., the data is black (gray) data, and the black flag of the data is ON (S802), the color management processing unit 24 executes black preservation color matching processing (S803). The black flag is set in black preservation color matching processing (S111 in
If the black flag is OFF, or (C,M,Y,K)≠(0,0,0,K), the color management processing unit 24 executes normal color matching processing (S804). The normal color matching processing is executed by using a printer reference profile (CMYK) as the source profile and a printer profile as the destination profile shown in
If CMYK data remains in the job data file, the flow returns to step S800. If no CMYK data remains, the processing is ended.
The printer profile used in the color matching processing in steps S803 and S804 has been corrected by the above-described calibration processing in step S105 or S106 in
With the above-described processing, when the input color space is a CMYK space, the color management processing unit 24 in the front-end server A 200 can create intermediate data having the printer CMYK values saved as the black plate.
(Effects of Embodiment)
As described above, according to this embodiment, in clustering output using a plurality of color printers through the network, the job management server 100 creates intermediate data by one PDL interpreter processing. Then, each front-end server to control each printer executes, for the intermediate data, calibration suitable for each printer and outputs the data. Hence, efficient clustering output can be done, and cost performance can be improved.
The second embodiment of the present invention will be described below.
In the above-described first embodiment, a printer reference CMYK color space is applied as the color space of intermediate data. As a characteristic feature of the second embodiment, a Lab color space is used. The system and device components in the second embodiment are the same as in the above-described first embodiment, and a description thereof will be omitted.
In the second embodiment, normal color matching processing in the job management server shown in
The processing operations replaced in the second embodiment will be described below.
(Color Matching in Job Management Server)
Referring to
In the second embodiment, a case is assumed, as shown in the table on the lower side of
(Color Matching in Front-End Server)
Referring to
In the second embodiment, a case is assumed, as shown in the table on the lower side of
In outputting patch data for calibration, CMYK data prepared in advance is directly output without intervening the CMM.
(Black Plate Saving Color Matching Processing in Job Management Server (RGB Input))
RGB data in the job data file is extracted (S900). If R=G=B, i.e., the data is black (gray) data, the RGB values are converted into LabK values (S904).
L=0, a=0, b=0, K=255−R
If NO in step S901, the color management processing unit 14 executes normal color matching processing (S902). The normal color matching processing is executed by using an RGB source profile as the source profile and a Lab profile as the destination profile shown in
L=L, a=a, b=b, K=0
If RGB data remains in the job data file in step S905, the flow returns to step S900. If no RGB data remains, the color matching processing is ended.
With the above-described processing, when the input color space is an RGB space, the color management processing unit 14 in the job management server 100 can create intermediate data having the LabK values saved as the black plate.
(Black Plate Saving Color Matching Processing in Job Management Server (CMYK Input))
CMYK data in the job data file is extracted (S1000). If (C,M,Y,K)=(0,0,0,K), i.e., the data is black (gray) data, the CMYK data is converted into LabK data (S1004).
L=0, a=0, b=0, K=K
If (C,M,Y,K)≠(0,0,0,K), the color management processing unit 14 executes normal color matching processing (S1002). The normal color matching processing is executed by using a CMYK source profile as the source profile and a Lab profile as the destination profile shown in
L=L, a=a, b=b, K=0
If CMYK data remains in the job data file in step S1005, the flow returns to step S1000. If no CMYK data remains, the color matching processing is ended.
With the above-described processing, when the input color space is a CMYK space, the color management processing unit 14 in the job management server 100 can create intermediate data having the LabK values saved as the black plate.
(Black Plate Saving Color Matching Processing in Front-End Server (RGB Input))
LabK data in the intermediate data file is extracted (S1100). If (L,a,b,K)=(0,0,0,K). i.e., the data is black (gray) data (S1101), the LabK data is converted into RGB values (S1104).
R=255−K, G=255−K, B=255−K
The color management processing unit 24 executes black preservation color matching processing (S1105). The processing is executed by a method described in, e.g., Japanese Patent Laid-Open No. 2004-120566. The processing is executed by using an RGB source profile as the source profile and a printer profile (CMYK) as the destination profile shown in
If (L,a,b,K)≠(0,0,0,K), the LabK data is converted into Lab data (S1102).
L=L, a=a, b=b
The color management processing unit 24 executes normal color matching processing (S1103). The normal color matching processing is executed by using a Lab profile as the source profile and a printer profile (CMYK) as the destination profile shown in
If LabK data remains in the job data file, the flow returns to step S1100. If no LabK data remains, the processing is ended.
With the above-described processing, when the input color space is an RGB space, the color management processing unit 24 in the front-end server A 200 can create intermediate data having the printer CMYK values saved as the black plate.
(Black Plate Saving Color Matching Processing in Front-End Server (CMYK Input))
LabK data in the intermediate data file is extracted (S1200). If (L,a,b,K)=(0,0,0,K), i.e., the data is black (gray) data, the LabK data is converted into CMYK data (S1204).
C=0, M=0, Y=0, K=K
The color management processing-unit 24 executes black preservation color matching processing (S1205). The black preservation color matching processing is executed by a method in, e.g., Japanese Patent Laid-Open No. 2004-120566. The processing is executed by using a CMYK source profile as the source profile and a printer profile (CMYK) as the destination profile shown in
If (L,a,b,K)≠(0,0,0,K), the LabK data is converted into Lab data (S1202).
L=L, a=a, b=b
The color management processing unit 24 executes normal color matching processing (S1203). The normal color matching processing is executed by using a Lab profile as the source profile and a printer profile (CMYK) as the destination profile shown in
If LabK data remains in the job data file, the flow returns to step S1200. If no LabK data remains, the processing is ended.
With the above-described processing, when the input color space is a CMYK space, the color management processing unit 24 in the front-end server A 200 can create intermediate data having the printer CMYK values saved as the black plate.
(Effects of Second Embodiment)
As described above, according to the second embodiment, the same effects as in the above-described first embodiment can be obtained by using Lab data as intermediate data. In addition, the accuracy of color matching between the plurality of printers can be increased.
<Modifications>
In the above-described first and second embodiments, the front-end server and printer engine are separated so that print processing before printer engine output is done in the front-end server. The present invention can also be applied to a printer in which a printer controller and a printer engine are integrated so that print processing before printer engine output is done in the internal printer controller.
In the first and second embodiments, the profile is updated in calibration processing. However, calibration of the present invention is not limited to this. For example, a one-dimensional density table may be updated without changing the profile.
Note that the present invention can be applied to an apparatus comprising a single device or to system constituted by a plurality of devices.
Furthermore, the invention can be implemented by supplying a software program, which implements the functions of the foregoing embodiments, directly or indirectly to a system or apparatus, reading the supplied program code with a computer of the system or apparatus, and then executing the program code. In this case, so long as the system or apparatus has the functions of the program, the mode of implementation need not rely upon a program.
Accordingly, since the functions of the present invention are implemented by computer, the program code installed in the computer also implements the present invention. In other words, the claims of the present invention also cover a computer program for the purpose of implementing the functions of the present invention.
In this case, so long as the system or apparatus has the functions of the program, the program may be executed in any form, such as an object code, a program executed by an interpreter, or scrip data supplied to an operating system.
Example of storage media that can be used for supplying the program are a floppy disk, a hard disk, an optical disk, a magneto-optical disk, a CD-ROM, a CD-R, a CD-RW, a magnetic tape, a non-volatile type memory card, a ROM, and a DVD (DVD-ROM and a DVD-R).
As for the method of supplying the program, a client computer can be connected to a website on the Internet using a browser of the client computer, and the computer program of the present invention or an automatically-installable compressed file of the program can be downloaded to a recording medium such as a hard disk. Further, the program of the present invention can be supplied by dividing the program code constituting the program into a plurality of files and downloading the files from different websites. In other words, a WWW (World Wide Web) server that downloads, to multiple users, the program files that implement the functions of the present invention by computer is also covered by the claims of the present invention.
It is also possible to encrypt and store the program of the present invention on a storage medium such as a CD-ROM, distribute the storage medium to users, allow users who meet certain requirements to download decryption key information from a website via the Internet, and allow these users to decrypt the encrypted program by using the key information, whereby the program is installed in the user computer.
Besides the cases where the aforementioned functions according to the embodiments are implemented by executing the read program by computer, an operating system or the like running on the computer may perform all or a part of the actual processing so that the functions of the foregoing embodiments can be implemented by this processing.
Furthermore, after the program read from the storage medium is written to a function expansion board inserted into the computer or to a memory provided in a function expansion unit connected to the computer, a CPU or the like mounted on the function expansion board or function expansion unit performs all or a part of the actual processing so that the functions of the foregoing embodiments can be implemented by this processing.
As many apparently widely different embodiments of the present invention can be made without departing from the spirit and scope thereof, it is to be understood that the invention is not limited to the specific embodiments thereof except as defined in the appended claims.
This application claims the benefit of Japanese Patent Application No. 2005-140001 filed on May 12, 2005, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2005-140001 | May 2005 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5489996 | Oku et al. | Feb 1996 | A |
5960110 | Usami | Sep 1999 | A |
6198552 | Nagae | Mar 2001 | B1 |
6348976 | Hayashi | Feb 2002 | B1 |
6396595 | Shimazaki | May 2002 | B1 |
6757076 | Mestha et al. | Jun 2004 | B1 |
6778300 | Kohler | Aug 2004 | B1 |
6798530 | Buckley et al. | Sep 2004 | B1 |
6919972 | Kumada et al. | Jul 2005 | B2 |
7046393 | Zeng | May 2006 | B2 |
7173718 | Iwata et al. | Feb 2007 | B2 |
7333239 | Oshikawa et al. | Feb 2008 | B2 |
20010055129 | Shimizu | Dec 2001 | A1 |
20020054314 | Takahashi | May 2002 | A1 |
20020080373 | Collette et al. | Jun 2002 | A1 |
20020124027 | Krueger et al. | Sep 2002 | A1 |
20030193688 | Namikata | Oct 2003 | A1 |
20030210414 | Kuno | Nov 2003 | A1 |
20040061912 | Ohga | Apr 2004 | A1 |
20040184658 | Inoue | Sep 2004 | A1 |
20050036157 | Takabayashi et al. | Feb 2005 | A1 |
20070103726 | Iwata et al. | May 2007 | A1 |
Number | Date | Country |
---|---|---|
10136219 | May 1998 | JP |
10340164 | Dec 1998 | JP |
2001290622 | Oct 2001 | JP |
2001324846 | Nov 2001 | JP |
2004046339 | Feb 2004 | JP |
2004236174 | Aug 2004 | JP |
2004247914 | Sep 2004 | JP |
2004304773 | Oct 2004 | JP |
Entry |
---|
Japanese Office Action dated Jun. 4, 2010 in corresponding Japanese Application No. 2005-140001. |
Number | Date | Country | |
---|---|---|---|
20060256361 A1 | Nov 2006 | US |