The invention relates to a technique for adjusting a profile used in conversion of coordinate values in a color space.
When using an ink jet printer for calibration applications of printing such as offset printing, an extremely high level of color reproduction accuracy (a degree to which colors are accurately reproduced) is required. A color management system using an International Color Consortium (ICC) profile is one system for accomplishing this. The ICC profile is data expressing a correspondence relationship between device-dependent colors of a color device such as a printing press (for example, an offset printer) or an ink jet printer, and device-independent colors. The device-dependent colors of the printing press, the ink jet printer, and the like are expressed as coordinate values in a device-dependent color space, for example, as CMYK values expressing usage amounts of C (cyan), M (magenta), Y (yellow), and K (black). The device-independent colors are expressed as, for example, color values in the International Commission on Illumination (CIE) L*a*b* color space (abbreviated as Lab values, omitting the “*”), color values in a CIE XYZ color space, and the like, which are device-independent color spaces.
Here, the ICC profile of the printing press is assumed as an input profile and the ICC profile of the ink jet printer is assumed as an output profile. When the CMYK values of the printing press are converted into color values (for example, Lab values) in a Profile Connection Space (PCS) in accordance with the input profile, the color values can be converted into CMYK values of the ink jet printer (called CMYKp values) in accordance with the output profile. When the ink jet printer performs printing using the CMYKp values, the ink jet printer can reproduce colors close to the colors of the printing press. In practice, however, there are cases where expected colors cannot be reproduced due to profile error, color measurement error, fluctuations in the printer, and the like. In such a case, spot color adjustment is carried out, where an adjustment point expressing a spot color to be adjusted is designated, an adjustment target of the adjustment point is designated, and the ICC profile is modified based on the adjustment target.
In a case of using a colorimetric device, when a color chart containing a spot color patch is printed by the ink jet printer, and the formed spot color patch is measured by the colorimetric device, a colorimetric value (PCS value) before adjustment can be obtained. Additionally, when a color chart containing the spot color patch is printed by the printing press, and the formed spot color patch is measured, a target colorimetric value can be obtained. In this case, it is conceivable to feed back the adjustment target into the ICC profile using coordinates in PCS as a reference.
JP-A-2005-348210 discloses a technique, which is not spot color adjustment, for determining correction information for correcting color output characteristics of a second color output apparatus to color output characteristics of a first color output apparatus. According to this technique, first, CMYK values of first evaluation data are converted into a plurality of pieces of second evaluation data respectively in accordance with a plurality of pieces of correction information. The correction information achieving the lowest difference in color output characteristics between the first color output apparatus, which performs output using the first evaluation data, and the second color output apparatus, which performs output using the second evaluation data, is then selected.
When feeding back the adjustment target into the ICC profile using coordinates in PCS as a reference, the color of material printed by the ink jet printer (as numerical values, the colorimetric values) may not match the intended adjustment result.
Note that this issue is not limited to the adjustment of profiles suitable for ink jet printers, and also arises when adjusting the profiles suitable for a variety of color devices.
An advantage of the invention is to provide a technique capable of improving color reproduction accuracy of a profile used in conversion of coordinate values in a color space.
To achieve one of the above-described advantages, the invention has as one aspect a profile adjustment method that carries out, by a computer, a process of adjusting an adjustment target profile among a plurality of profiles including an input profile expressing a correspondence relationship between first coordinate values in a first device-dependent color space and device-independent coordinate values in a profile connection space and an output profile expressing a correspondence relationship between the device-independent coordinate values and second coordinate values in a second device-dependent color space, the profile adjustment method including:
the output profile including a first conversion table for converting the device-independent coordinate values into the second coordinate values and a second conversion table for converting the second coordinate values into the device-independent coordinate values,
receiving an adjustment target at an adjustment point, using coordinates in a profile connection space as a reference,
converting the device-independent coordinate values at the adjustment point into the second coordinate values in accordance with the first conversion table, and converting the second coordinate values into adjustment target PCS values as the device-independent coordinate values, in accordance with the second conversion table,
when values obtained by adding relative values of the adjustment target using the coordinates in the profile connection space as a reference to the adjustment target PCS values are assumed as target PCS values, the second coordinate values at the adjustment point are assumed as adjustment target color values, and values added to the adjustment target color values are assumed as adjustment color values, obtaining an optimal solution of the adjustment color values through an optimization process including an element that brings provisional PCS values, obtained by converting, according to the second conversion table, provisional color values obtained by adding the adjustment color values to the adjustment target color values, closer to the target PCS values, and
adjusting the adjustment target profile based on the optimal solution of the adjustment color values.
Additionally, the invention has as another aspect a profile adjustment program that causes a computer to execute functions corresponding to the steps of the above-described profile adjustment method.
Furthermore, the invention has as another aspect a profile adjustment apparatus including units corresponding to the steps of the above-described profile adjustment method.
Further still, the invention has as another aspect a profile adjustment system including units corresponding to the steps of the above-described profile adjustment method.
The above-described aspects can provide a profile adjustment method that improves the color reproduction accuracy of the profile used to convert the coordinate values in the color space.
The invention will be described with reference to the accompanying drawings, wherein like numbers reference like elements.
Exemplary embodiments of the invention will be described hereinafter. Of course, the following exemplary embodiments are merely examples of the invention and not all of the characteristics described in the exemplary embodiments are required to address the issue discussed in the disclosure.
First, an overview of the technique described in the invention will be given with reference to the examples illustrated in
Aspect 1
As illustrated in
In the target reception step ST2, an adjustment target T0 at an adjustment point P0, which uses coordinates in the profile connection space CS3 as a reference, is received. In the conversion step ST3, the device-independent coordinate values at the adjustment point P0 (for example, LabS1) are converted into the second coordinate values (for example, cmykp) in accordance with the first conversion table (621), and the second coordinate values are then converted into adjustment target PCS values (for example, LabS2) as device-independent coordinate values, in accordance with the second conversion table (622).
Here, values obtained by adding relative values of the adjustment target T0 using the coordinates in the profile connection space CS3 as a reference (for example, ΔLabT-p) to the adjustment target PCS values (LabS2) are assumed as target PCS values (for example, LabST). Additionally, the second coordinate values at the adjustment point P0 are assumed as adjustment target color values (cmykp). Furthermore, values added to the adjustment target color values (cmykp) for matching the adjustment target T0 are assumed as adjustment color values (for example, Δcmyk). In the optimization step ST4, an optimal solution (for example, Δcmykb) of the adjustment color values (Δcmyk) is obtained through an optimization process including an element that brings provisional PCS values (for example, LabS3), obtained by converting, according to the second conversion table (622), provisional color values (for example, cmykpp) obtained by adding the adjustment color values (Δcmyk) to the adjustment target color values (cmykp), closer to the target PCS values (LabST). In the profile adjustment step ST5, the adjustment target profile 550 is adjusted based on the optimal solution (Δcmykb) of the adjustment color values (Δcmyk).
In the above-described conversion step ST3, the second coordinate values (cmykp) obtained from the device-independent coordinate values (LabS1) at the adjustment point P0 in accordance with the first conversion table (621) of the output profile 620 express output colors of a second device (for example, a printer 200) having the second device-dependent color space CS2. The adjustment target PCS values (LabS2) obtained from the second coordinate values (cmykp) in accordance with the second conversion table (622) of the output profile 620 are device-independent coordinate values expressing the output colors of the second device (200). Values obtained by adding the relative values (ΔLabT-p) of the adjustment target T0 using the coordinates in the profile connection space CS3 as a reference to the adjustment target PCS values (LabS2) are the target PCS values (LabST). According to this aspect, the adjustment target profile 550 is adjusted based on the optimal solution (Δcmykb) of the adjustment color values (Δcmyk) obtained through the optimization process, which includes an element that brings the provisional PCS values (LabS3) closer to the target PCS values (LabST), and thus an adjustment result with respect to the output colors of the second device (200) is closer to an intended color.
Accordingly, this aspect provides a profile adjustment method that improves the color reproduction accuracy of a profile used to convert the coordinate values in a color space.
Here, the profile connection space includes color spaces such as the CIE Lab color space, the CIE XYZ color space, and the like.
The first device-dependent color space includes the CMYK color space, the CMY color space, the RGB color space, and the like. Note that R stands for red, G for green, and B for blue.
The second device-dependent color space includes the CMYK color space, the CMY color space, the RGB color space, and the like. In the exemplary embodiments described below, when the second device-dependent color space is the CMYK color space, the second device-dependent color space will be referred to as a cmyk color space to distinguish the color space from the CMYK color space corresponding to the first device-dependent color space.
The plurality of profiles that can be adjustment target profiles may be two types, that is, the input profile and the output profile, or may further include a device link profile.
The adjustment target at the adjustment point may be expressed as coordinate values in a color space, or may be expressed as a difference from current coordinate values in the color space.
An optimization process using a quasi-Newton method, an optimization process using a Newton method, an optimization process using a conjugate gradient method, and the like can be used as the optimization process.
Obtaining an optimal solution through an optimization process includes determining an optimal solution from among a plurality of solutions obtained by carrying out a plurality of optimization processes, and obtaining an optimal solution from a single optimization process.
Note that the additional remarks made above in Aspect 1 also apply to the other aspects.
Aspect 2
As illustrated in
Aspect 3
As illustrated in
Here, the color difference includes the color difference ΔE00 expressed by the CIEDE 2000 color difference type, a color difference ΔE*94 expressed by the CIE 1994 color difference type, a color difference ΔE*ab according to the CIE L*a*b* color system proposed in 1976 (also known as ΔE*76), a color difference ΔE*uv according to the CIE L*u*v* color system, and the like.
Although not included in Aspect 3, a case where the square root included in the color difference is calculated is also included in this technique.
Aspect 4
As illustrated in
Although not included in Aspect 4, a case where the magnitude of the vectors of the adjustment color values is not included in the target function is also included in this technique.
Aspect 5
As illustrated in
In this application, “from Min to Max” means greater than or equal to a minimum value Min and less than or equal to a maximum value Max.
Although not included in Aspect 5, a case where the above-described restriction conditions are not present is also included in this technique.
Aspect 6
As illustrated in
Although not included in Aspect 6, the adjustment color values having a single initial value is also included in this technique.
Aspect 7
As illustrated in
Aspect 8
Incidentally, a profile adjustment program PR0 according to one aspect of this technique causes a computer (for example, a host device 100) to implement a target reception function FU2 corresponding to the target reception step ST2, a conversion function FU3 corresponding to the conversion step ST3, an optimization function FU4 corresponding to the optimization step ST4, and a profile adjustment function FU5 corresponding to the profile adjustment step ST5. Accordingly, this aspect provides a profile adjustment program that improves the color reproduction accuracy of a profile used to convert the coordinate values in a color space. The profile adjustment program PR0 may cause the computer (for example, the host device 100) to implement an adjustment target profile reception function FU1 corresponding to the adjustment target profile reception step ST1.
Aspect 9
A profile adjustment apparatus (for example, the host device 100) according to an aspect of this technique includes a target reception unit U2 corresponding to the target reception step ST2, a conversion unit U3 corresponding to the conversion step ST3, an optimization unit U4 corresponding to the optimization step ST4, and a profile adjustment unit U5 corresponding to the profile adjustment step ST5. Accordingly, this aspect provides a profile adjustment apparatus that improves the color reproduction accuracy of a profile used to convert the coordinate values in a color space. The profile adjustment apparatus (100) may include an adjustment target profile reception unit U1 corresponding to the adjustment target profile reception step ST1.
Aspect 10
Furthermore, a profile adjustment system SY1 according to an aspect of this technique includes a printing device (for example, a printer 200) configured to print a color chart including a patch, a colorimetric device 120 configured to measure the patch, and the units of Aspect 9. Accordingly, this aspect provides a profile adjustment system that improves the color reproduction accuracy of a profile used to convert the coordinate values in a color space. This profile adjustment system SY1 may include the adjustment target profile reception unit U1.
This technique can furthermore be applied in a control method of a profile adjustment apparatus, a multifunction system including a profile adjustment apparatus, a control method of a multifunction system, a control program of a profile adjustment apparatus, a control program of a multifunction system, a computer-readable medium in which is recorded a profile adjustment program, and the control program, and the like. The above-described apparatuses may include a plurality of separate parts.
The storage device 114 stores an operating system (OS; not illustrated), a profile adjustment program PR0, and the like. These may be loaded into the RAM 113 and used in the processing for adjusting the profiles 500. Here, “profiles 500” collectively refers to the input profile 610, the output profile 620, and a device link profile 630. Various types of information, for example, the input profile 610, the output profile 620, the device link profile 630, an adjustment history (not illustrated), and the like, are stored in at least one of the RAM 113 and the storage device 114. Non-volatile semiconductor memory such as flash memory, a magnetic storage device such as a hard disk, and the like can be used as the storage device 114.
A pointing device, hardware keys including a keyboard, a touch panel affixed to a surface of a display panel, and the like can be used as the input device 115. The communication I/F 118 is connected to a communication I/F 210 of the printer 200, and inputs/outputs information such as print data to/from the printer 200. The colorimetric device I/F 119 is connected to the colorimetric device 120, and obtains colorimetric data, including colorimetric values, from the colorimetric device 120. Universal Serial Bus (USB), a near-field wireless communication standard, and the like can be used as the standard of the I/Fs 118, 119, and 210. The communication by the communication I/Fs 118, 119, and 210 may be hard-wired, may be wireless, or may be network communication over a local area network (LAN), the internet, and the like.
The colorimetric device 120 can measure respective color patches formed on a print substrate, which is an example of a medium on which a color chart is formed, and output colorimetric values. The patch is also called a “color chart”. The colorimetric values are values expressed as a lightness L and color component coordinates a and b in the CIE Lab color space, for example. The host device 100 obtains the colorimetric data from the colorimetric device 120 and carries out various processes.
The profile adjustment program PR0 illustrated in
The CPU 111 of the host device 100 carries out various processes by reading out information stored in the storage device 114 into the RAM 113 and executing the read-out programs as appropriate. The CPU 111 carries out processes corresponding to the aforementioned functions FU1 to FU5 by executing the profile adjustment program PR0 read out into the RAM 113. The profile adjustment program PR0 causes the host device 100, which is a computer, to function as the adjustment target profile reception unit U1, the target reception unit U2, the conversion unit U3, the optimization unit U4, and the profile adjustment unit U5. Additionally, the host device 100 executing the profile adjustment program PR0 carries out the adjustment target profile reception step ST1, the target reception step ST2, the conversion step ST3, the optimization step ST4, and the profile adjustment step ST5. A computer-readable medium storing the profile adjustment program PR0 that causes a computer to implement the aforementioned functions FU1 to FU5 is not limited to a storage device within the host device, and may be a recording medium external to the host device.
Note that the host device 100 includes computers such as personal computers (including tablet-type terminals). For example, when a main unit of a desktop-type personal computer is employed as the host device 100, the display device 130, the colorimetric device 120, and the printer 200 are normally connected to that main unit. When a computer with an integrated display device, such as a laptop-type personal computer, is employed as the host device 100, the colorimetric device 120 and the printer 200 are normally connected to that computer. Even in a case where the host device includes an integrated display device, display data is still output to that internal display device. Additionally, the host device 100 may include all of the constituent elements 111 to 119 within a single housing, or may include a plurality of separate devices that can communicate with each other. Furthermore, this technique can be implemented even in a case where at least one of the display device 130, the colorimetric device 120, and the printer 200 is provided in the host device 100.
The printer 200 illustrated in
Next, an example of a color management system in which this technique can be applied will be described with reference to
The color management system illustrated in
Although the target printing press 300 assumes an offset printing press, the target printing press 300 may be a gravure printing press, a flexography printing press, and the like. The target colors CT are expressed, for example, by the coordinate values (Lab values) in CIE Lab color space.
The RIP 400 illustrated in
Furthermore, when color names are set in the print document data D0, the RIP 400 can convert the color names into the Lab color space colors LabS1 by referring to the color library 640.
Note that in addition to the process colors CMYKin, the RIP 400 also includes input profile for converting process colors expressing usage amounts of the color materials of only three primary colors CMY, which is a subtractive color mixture (CMYin), process colors expressing intensities of three primary colors R (red), G (green), and B (blue), which is an additive color mixture (RGBin), and the like, and the coordinate values in the Lab color space. Accordingly, the RIP 400 can also convert process colors CMYin, process colors RGBin, and the like into the print colors cmykp through the Lab color space. Additionally, the RIP 400 can also input the Lab color space colors LabS1 and convert the colors to the print colors cmykp.
Through the foregoing, the ink jet printer 200 can reproduce colors close to the colors of the target printing press 300. In practice, however, there are cases where the expected colors cannot be reproduced, due to profile error, color measurement error, fluctuations in the printer, and the like. In such a case, the conversion accuracy of the target colors is increased by modifying the profiles 610 and 620. When modifying the output profile 620, it is conceivable to take the LabS1 values in a profile connection space (PCS) as target values, take the results of measuring colors printed by the printer 200 (Labp) as current values, calculate a color difference between the two, and modify the output profile 620 so as to reduce that color difference. Additionally, when modifying the input profile 610, it is conceivable to convert color chart data with the input profile 610 and the output profile 620 and print the color charts, calculate a color difference between the measurement results of the respective patches (Labp) and the target color values (LabT), and modify the input profile 610 so as to reduce that color difference.
However, when feeding back the adjustment targets into the adjustment target profile, with the PCS coordinates serving as a reference, there are situations where the colors of the printed material from the printer 200 (as numerical values, the colorimetric values Labp) do not provide the intended adjustment result. One reason for this is that colors adjusted in the PCS sometimes become colors out of the color reproduction range of the output profile 620 and are mapped to the color reproduction range. Additionally, there are cases where even in a case where the colors adjusted in the PCS are in the color reproduction range of the output profile 620, error dependent on the accuracy of the B2A table 621 of the output profile 620 arises. This can also result in the intended adjustment result not being obtained.
In this specific example, the color reproduction accuracy of a post-adjustment profile is improved by using the A2B table 622 (an example of a second conversion table) of the output profile 620.
As illustrated in
Note that the first device-dependent color space may also be referred to as a first color space.
The output profile 620 is data defining a correspondence relationship between Lab values (Lj, aj, bj) in the Lab color space (CS3) and cmyk values (cj, mj, yj, kj) in the cmyk color space (an example of the second device-dependent color space CS2) matching the ink used by the ink jet printer 200. In this case, grid points GD2 in the B2A table 621 are normally arranged at substantially equal intervals in an L axis direction, an a axis direction, and a b axis direction in the Lab color space. Here, the variable j is a variable identifying the grid points GD2 set in the Lab color space (CS3). The term “cmyk color space” is used to distinguish the color space matching the ink used by the printer 200 from the color space matching the ink used by the target printing press 300. The cmyk values are examples of the second coordinate values. In the output profile 620, the Lab color space (CS3) is an example of the input color space CS4, and the cmyk color space (CS2) is an example of the output color space CS5. The color reproduction range of the output colors expressed by the cmyk values (cmykp) is dependent on the printer 200. Accordingly, even in a case where the Lab values (Lj, aj, bj) of the B2A table 621 are values expressing out of the color reproduction range of the printer 200, the cmyk values (cj, mj, yj, kj) obtained through mapping to the color reproduction range of the printer 200 are associated with the Lab values (Lj, aj, bj).
Note that the second device-dependent color space may also be referred to as a second color space.
The device link profile 630 is data defining a correspondence relationship between the CMYK values (Ci, Mi, Yi, Ki) in the CMYK color space (CS1) and the cmyk values (ci, mi, yi, ki) in the CMYK color space (CS2). Here, the variable i is a variable identifying the grid points GD1 set in the CMYK color space (CS1). The device link profile 630 is obtained by linking the input profile 610 and the output profile 620. In the device link profile 630, the CMYK color space (CS1) is an example of the input color space CS4, and the cmyk color space (CS2) is an example of the output color space CS5.
Note that the conversion tables included in the profiles 610, 620, and 630 are not limited to single conversion tables, and may be combinations of a plurality of conversion tables, such as a combination of a one-dimensional conversion table, a three-dimensional or four-dimensional conversion table, and a one-dimensional conversion table. Accordingly, the conversion tables illustrated in
The “grid point” refers to a virtual point disposed in the input color space, and it is assumed that the output coordinate values corresponding to positions of the grid points in the input color space are held in the grid points. In addition to a plurality of grid points being disposed uniformly throughout the input color space, this technique also includes disposing a plurality of grid points non-uniformly throughout the input color space.
A2Bx tags (where x is 0, 1, or 2 in
The A2B0 tag and the B2A0 tag indicated in
As illustrated in
Upon the target setting process illustrated in
The host device 100 receives operations to the aforementioned fields and buttons through the input device 115 (S110), and moves the process to S120 upon receiving an operation to the execute adjustment button 870. The process of S110 includes the following processes S111 to S114.
(S111) A process of receiving one or more profiles to be used in color conversion from among the profiles 610, 620, and 630, and of receiving the adjustment target profile 550. Note that a combination of the profiles 610 and 620 for the color conversion, or color conversion in which the device link profile 630 is designated, indicate conversion from CMYK values to cmyk values. Color conversion in which only the output profile 620 is designated indicates conversion from Lab values to cmyk values.
(S112) A process of receiving the input of the adjustment target T0 at the adjustment point P0, using the coordinates of the PCS CS3 as a reference.
(S113) A process of receiving the designation of an adjustment range A0 in the CMYK color space (CS1) (see
(S114) A process of receiving one designated intent, from among a plurality of rendering intents for defining a correspondence relationship of the adjustment target profile 550.
First, the process of S111 will be described with reference to
The host device 100 receives an operation for selecting a profile from among the profiles 500 stored in the storage device 114 by receiving operations to the selection fields 811 to 813 through the input device 115.
In the input profile selection field 811, an input profile to be used in the color conversion can be selected from input profiles 610 stored in the storage device 114 when the input profile 610 is to be used for the color conversion. When the input profile 610 is not to be used in the color conversion, the input profile selection field 811 may be left blank.
In the output profile selection field 812, an input profile to be used in the color conversion can be selected from output profiles 620 stored in the storage device 114 when the output profile 620 is to be for the color conversion. When the output profile 620 is not to be used in the color conversion, the output profile selection field 812 may be left blank.
In the device link profile selection field 813, a device link profile to be used in the color conversion can be selected from device link profiles 630 stored in the storage device 114 when the device link profile 630 is to be used in the color conversion. When the device link profile 630 is not to be used in the color conversion, the device link profile selection field 813 may be left blank.
As a reference example, when the input profile 610 has been selected in the input profile selection field 811 only (a-1), only the input profile 610 is used in the color conversion, as illustrated in
When the output profile 620 is selected in the output profile selection field 812 only (a-2), only the output profile 620 is used in the color conversion, as indicated in
When the device link profile 630 is selected in the device link profile selection field 813 only (a-3), the device link profile 630 is used in the color conversion, as indicated in
When the input profile 610 is selected in the input profile selection field 811 and the output profile 620 is furthermore selected in the output profile selection field 812, the input profile 610 and the output profile 620 are used in combination in the color conversion, as indicated in
The host device 100 carries out a process for changing the designated items in the adjustment target profile reception field 820 in accordance with the selections made in the selection fields 811 to 813 described above.
When the output profile 620 has been selected in the output profile selection field 812 only, only the output profile 620 can be designated in the adjustment target profile reception field 820 as a target for adjustment. When the device link profile 630 has been selected in the device link profile selection field 813 only, only the device link profile 630 can be designated in the adjustment target profile reception field 820 as a target for adjustment.
When the input profile 610 has been selected in the input profile selection field 811 and the output profile 620 has furthermore been selected in the output profile selection field 812, one designated item can be selected from the profiles 610, 620, and 630 in the adjustment target profile reception field 820. A situation where the input profile 610 has been selected in the adjustment target profile reception field 820 corresponds to “(b-1) input profile designated in combination with input/output profiles”, indicated in
As a reference example, a single designated item can be selected in the adjustment target color space selection field 830 from among the CMYK color space (CS1), the cmyk color space (CS2), and the PCS CS3. When the adjustment target T0 is set based on the colorimetric values Labp of a patch printed by the printer 200, a user may select the PCS CS3 in the adjustment target color space selection field 830.
Furthermore, the process of S112 will be described with reference to
The host device 100 carries out a process for changing input items in the target reception area 840 in accordance with the selections made in the aforementioned fields 811 to 813, and 830. The host device 100 carries out a process for changing the input items in the target reception area 840 in accordance with the selection made in the adjustment data selection field 845. One of “absolute value” and “relative value” can be selected in the adjustment data selection field 845. “Absolute value” is an option in which an adjustment target T0 is received as the coordinate values in a color space. “Relative value” is an option in which the adjustment target T0 is received as a difference from the current coordinate values in the color space. When “relative value” is selected in the adjustment data selection field 845, an input field for coordinate values (ΔL, Δa, Δb) of the adjustment target T0, as the relative values ΔLabT-p from the current coordinate values in the color space, is displayed in the target reception area 840, as indicated in
As illustrated in
Additionally, upon receiving an operation of the chart print button 846, the host device 100 generates print data of a color chart CH1, which has color patches expressing the colors at the respective adjustment points P0, and sends the print data to the printer 200. Having received this print data, the printer 200 prints the color chart CH1, which has color patches expressing the colors at the respective adjustment points P0, onto the print substrate ME1.
Furthermore, upon receiving an operation of the measure color button 847, the host device 100 instructs the colorimetric device 120 to measure the color of the respective patches in the color chart CH1. Having received this instruction, the colorimetric device 120 measures the color of the respective patches in the color chart CH1, and sends the colorimetric values Labp of the patches to the host device 100. Having received the colorimetric values Labp, the host device 100 may display the colorimetric values Labp in the display device 130, or may cause the printer 200 to print the values. The user can view the output colorimetric values Labp and input the adjustment target T0 in the target reception area 840. Additionally, the host device 100 may automatically input the colorimetric values Labp of the patches into the target T0 input field. When the adjustment target T0 is the relative values (ΔL, Δa, Δb), the host device 100 may calculate differences of the L, a, and b components in the target colorimetric values LabT from the current colorimetric values Labp and automatically input the differences into the target T0 input field.
Furthermore, upon receiving an operation of the load history button 881, the host device 100 reads out the adjustment history stored in the storage device 114 and adds the history to the target reception area 840. Upon receiving an operation of the save history button 882, the host device 100 stores the information in the target reception area 840 as the adjustment history in the storage device 114.
Furthermore, the process of S113 will be described with reference to
The host device 100 receives, in the adjustment range designation field 850, the input of a radius taking the adjustment point P0 as a base point. This radius is expressed as a relative value of 0 to 100% of a Euclidian distance in the first color space CS1. Accordingly, the adjustment range A0 of the adjustment target profile 550 is designated in the first color space CS1.
Furthermore, the process of S114 will be described with reference to
The host device 100 receives, in the intent designation field 860, the designation of a rendering intent for defining a correspondence relationship of the adjustment target profile 550. Although not illustrated in
Upon receiving an operation of the execute adjustment button 870 indicated in
First, in S120, the host device 100 acquires the PCS values LabS1 of the adjustment point P0. As described above, when the coordinates (CMYKin) of the adjustment point P0 are received, with the CMYK color space (CS1) as a reference, the CMYK values CMYKin is to be converted into the PCS values LabS1. The host device 100 converts the CMYK values CMYKin at the adjustment point P0 into the PCS values LabD1 in accordance with the A2B table of the input profile 610.
Here, color conversion according to a profile (for example, an ICC profile) will be expressed as ficc (first argument, second argument, third argument). The first argument expresses the profile to be used. In the first argument, InputProfile represents the input profile, OutputProfile represents the output profile, DLProfile represents the device link profile, and OrOutputProfile represents an output profile used to create the device link profile. The second argument expresses the color conversion tables used in the profile expressed by the first argument. In the second argument, A2B represents conversion from device colors to device-independent colors, B2A represents conversion from device-independent colors to device colors, and A2B0 represents conversion through a device link table. The third argument expresses the input values (CMYK, RGB, Lab, and the like) of the adjustment point P0.
The conversion from CMYK values CMYKin to PCS values LabS1 is expressed by the following equation.
LabS1=ficc(InputProfile,A2B,CMYKin)
Note that when the coordinates of the adjustment point P0 are received with the Lab color space (CS3) used as a reference, the coordinates are the PCS values LabS1. Accordingly, in S120, the host device 100 may acquire the coordinates (LabS1) of the adjustment point P0.
Next, in S122, the host device 100 converts the above-described PCS values LabS1 into the adjustment target color values cmykp, which are cmyk values (the second coordinate values), in accordance with the B2A table 621 of the output profile 620. This conversion is expressed through the following equation.
cmykp=ficc(OutputProfile,B2A,LabS1)
The above-described adjustment target color values cmykp express output colors of the printer 200 before the adjustment of the adjustment point P0.
Next, in S124, the host device 100 converts the above-described adjustment target color values cmykp into the adjustment target PCS values LabS2, in accordance with the A2B table 622 of the output profile 620.
LabS2=ficc(OutputProfile,A2B,cmykp)=ficc(OutputProfile,A2B,ficc(OutputProfile,B2A,LabS1))
The above-described adjustment target PCS values LabS2 are device-independent coordinate values expressing the output colors of the printer 200. Note that the calculation of the adjustment target PCS values LabS2 corresponds to converting the PCS values LabS1 into the adjustment target color values cmykp in accordance with the B2A table 621 of the output profile 620, and then converting the adjustment target color values cmykp into the adjustment target PCS values LabS2 in accordance with the A2B table 622 of the same output profile 620. As such, this calculation can be called a “round-trip computation” of the output profile 620.
After the process of S124, the host device 100 carries out the optimization process illustrated in
Upon the optimization process illustrated in
LabST=LabS2+ΔLabT-p
Next, in S204, the host device 100 sets initial values Δcmyki of the adjustment color values Δcmyk added to the adjustment target color values cmykp for matching the adjustment target T0. As illustrated in
Of course, the initial value Δk of k can be shifted by an interval value Sk (Sk>0).
Note that the range that the c values, m values, y values, and k values, which are the second coordinate values, can take on in the cmyk color space (CS2) is not particularly limited, but can be set to be from 0 to 100 (0≤c≤100, 0≤m≤100, 0≤y≤100, and 0≤k≤100). In the cmyk color space (CS2), the coordinates of the grid points GD3 in the A2B table 622 (see
0.5×Gc≤Sc≤2×Gc
0.5×Gm≤Sm≤2×Gm
0.5×Gy≤Sy≤2×Gy
When a plurality of initial values Δk are set for k as well, the interval value for the initial values Δk (represented by Sk) can also be set to be approximately from 0.5 to 2 times the interval of the grid points GD3 in the k axis direction (represented by Gk), for example.
0.5×Gk≤Sk≤2×Gk
When the interval values Sc, Sm, Sy, and Sk are set to be approximately from 0.5 to 2 times the intervals Gc, Gm, Gy, and Gk of the grid points GD3, the optimal solution Δcmykb can be determined efficiently.
After the initial values Δcmyki have been set, the host device 100 carries out the solution searching process (S210). The processes of S212 to S224 are repeated in this solution searching process.
First, in S212, the host device 100 calculates the provisional color values cmykp, in which the adjustment color values Δcmyk are added to the adjustment target color values cmykp. First, the adjustment color values Δcmyk when carrying out the process of S212 are the initial values Δcmyki.
Next, in S214, the host device 100 converts the provisional color values cmykpp to provisional PCS values LabS3 in accordance with the A2B table 622. As equations, this is expressed as follows.
LabS3=ficc(OutputProfile,A2B,cmykpp)
Next, in S216, the host device 100 calculates the square of a color difference ΔE00 between the provisional PCS values LabS3 and the target PCS values LabST. Use of the color difference square ΔE002 eliminates the calculation of the square root included in the color difference ΔE00, which accelerates the solution searching process. The color difference square ΔE002 is included in the target function y=f(Δcmyk). Accordingly, the target function y=f(Δcmyk) includes an element for bringing the provisional PCS values LabS3 closer to the target PCS values LabST=LabS2+ΔLabT-p.
Although taking more time for the solution searching process, the color difference ΔE00 itself may be included in the target function y=f(Δcmyk) instead of the color difference square ΔE002. Additionally, a color difference ΔE*ab, a sum of the absolute value of an L-value difference, the absolute value of an a-value difference, the absolute value of a b-value difference, and the like may be used instead of the color difference ΔE00.
Next, in S218, when the adjustment color values Δcmyk are expressed as the vectors in the cmyk color space (CS2), the host device 100 calculates the square of magnitudes V of the vectors, separate from the color difference ΔE00, to calculate the target function y=f(Δcmyk). Assuming the components of the adjustment color values Δcmyk are expressed by (Δc, Δm, Δy, Δk), the magnitudes V of the vectors when the adjustment color values Δcmyk are expressed as the vectors in the cmyk color space (CS2) are as expressed in the following equation.
V=(Δc2+Δm2+Δy2+Δk2)1/2
By including the magnitudes V of the vectors of the adjustment color values Δcmyk in the target function y=f(Δcmyk), a situation where the absolute value of one of Δc, Δm, Δy, and Δk in the adjustment color values Δcmyk becomes prominently greater is suppressed.
The color difference square ΔE002 is included in the target function y=f(Δcmyk), and thus the magnitudes V of the vectors of the adjustment color values Δcmyk can also be included in the target function y=f(Δcmyk).
V2=Δc2+Δm2+Δy2+Δk2
This eliminates the calculation of the square root included in the magnitudes V of the vectors, which accelerates the solution searching process.
Although taking more time for the solution searching process, the magnitudes v of the vectors of the adjustment color values Δcmyk themselves may be included in the target function y=f(Δcmyk) instead of the squares V2 of the magnitudes of the vectors of the adjustment color values Δcmyk. Additionally, a sum of the absolute values of Δc, Δm, Δy, and Δk and the like may be used instead of the magnitudes V of the vectors of the adjustment color values Δcmyk.
Next, in S220, the host device 100 calculates a cost C based on restriction conditions of the range from 0 to 100 which the CMYK values (an example of the second coordinate values) can take on. This is because the provisional color values cmykpp=cmykp+Δcmyk preferably fall within the range from 0 to 100 that the cmyk values can take on. Here, the components of the provisional color values cmykpp will be expressed as (cpp, mpp, ypp, and kpp). The cost C can be calculated according to the following equations, for example.
When cpp<0, then C=−cpp×Cco
When cpp>100, then C=(cpp−100)×Cco
When mpp<0, then C=−mpp×Cco
When mpp>100, then C=(mpp−100)×Cco
When ypp<0, then C=−ypp×Cco
When ypp>100, then C=(ypp−100)×Cco
When kpp<0, then C=−kpp×Cco
When kpp>100, then C=(kpp−100)×Cco
Aside from the above, C=0.
Note that the coefficient Cco is a positive number, and is desirably approximately 103≤Cco≤109, which is a number sufficiently greater than the range from 0 to 100 that the CMYK values can take on.
When the above-described cost C is included in the target function y=f(Δcmyk), the optimization process is carried out having applied the range from 0 to 100 that the CMYK values can take on to the restriction conditions for the range of the provisional color values cmykpp.
Of course, the cost C can be calculated in the same manner even in a case where the range that the second coordinate values can take on is out of the range from 0 to 100. For example, the second coordinate values are assumed as RGB values and a range that the second coordinate values can take on is assumed as from 0 to 255, and the components of provisional color values RGBpp are assumed as (Rpp, Gpp, and Bpp). The cost C of a target function y=f(ΔRGB) can be calculated according to the following equations, for example.
When Rpp<0, then C=−Rpp×Cco
When Rpp>255, then C=(Rpp−255)×Cco
When Gpp<0, then C=−Gpp×Cco
When Gpp>255, then C=(Gpp−255)×Cco
When Bpp<0, then C=−Bpp×Cco
When Bpp>255, then C=(Bpp−100)×Cco
Aside from the above, C=0.
Here too, the coefficient Cco is a positive number, and is approximately 103≤Cco≤109, which is a number sufficiently greater than the range from 0 to 255 that the RGB values can take on.
Additionally, the cost C may include an element aside from the range that the second coordinate values can take on. For example, when an error arises upon the processing of S212 to S220 being carried out for given adjustment color values Δcmyk, a value of approximately from 103 to 109 may be added to the cost C.
Next, in S222, the host device 100 calculates the target function y=f(Δcmyk) including the color difference square ΔE002, the square V2 of the magnitudes of the vectors of the adjustment color values Δcmyk, and the cost C. The target function y=f(Δcmyk) is expressed by the following equation, for example.
y=ΔE002+w×V2+C
Note that the coefficient w is a positive number, and is approximately 1≤w≤10, from a standpoint of suppressing a situation where any one of the absolute values of Δc, Δm, Δy, and Δk of the adjustment color values Δcmyk becomes prominently greater.
The above-described processing of S212 to S222 is repeated until a solution causing the target function y=f(Δcmyk) to be a minimum value (an optimal solution candidate Δcmykpb) is found. When the process of S224 is carried out first, it cannot be determined whether the target function y=f(Δcmyk) is the minimum value, and thus the host device 100 returns the process to S212 after changing the adjustment color values Δcmyk by a minute amount. The host device 100 then repeats the processing of S212 to S224 while changing the adjustment color values Δcmyk by minute amounts. Upon finding a solution causing the target function y=f(Δcmyk) to be the minimum value, the host device 100 takes the solution as the optimal solution candidate Δcmykpb and ends the solution searching process of S210.
The host device 100 repeats the processing of S204 to S210 until all of the initial values Δcmyki of the adjustment color values Δcmyk are set (S230). Through this, an optimal solution candidate Δcmykpb is found for the respective initial values Δcmyki.
Next, in S232, the host device 100 obtains the optimal solution Δcmykb based on the plurality of optimal solution candidates Δcmykpb. In S210, target function y=E002+w×V2+C is calculated for the respective initial values Δcmyki in the solution searching process. For example, in S232, the host device 100 may determine an optimal solution candidate Δcmykpb in a case that the value of the target function y for the respective initial values Δcmyki is lowest, as the optimal solution Δcmykb.
The obtained solution Δcmykb is an optimal solution that brings the provisional PCS values LabS3 as close as possible to the target PCS values LabST=LabS2+ΔLabT-p. When obtaining the optimal solution Δcmykb, a situation where the absolute value of any of Δc, Δm, Δy, and Δk of the adjustment color values Δcmyk become prominently greater is suppressed, and the provisional color values cmykpp=adjustment target color values cmykp+adjustment color values Δcmyk are restricted to the range that the CMYK value can take on. The color reproduction accuracy of the adjustment target profile can be improved by adjusting the adjustment target profile 550 using the optimal solution Δcmykb.
After the process of S232, the host device 100 carries out the profile adjustment process illustrated in
First, the host device 100 acquires the adjustment target color values cmykp, which are the current output values, for the respective adjustment points P0 input in the target reception area 840 (S304). This is in order to carry out adjustment using, as a reference, the output colors (cmykp) corresponding to the colors of the output image IMO formed on the print substrate ME1.
For example, when only the output profile 620 is designated for color conversion as indicated in
cmykp=ficc(OutputProfile,B2A,Input)
When only the device link profile 630 is designated for color conversion as indicated in
cmykP=ficc(DLProfile,A2B0,Input)
When the combination of the profiles 610 and 620 is designated for color conversion as indicated in
cmykp=ficc(OutputProfile,B2A,ficc(InputProfile,A2B,Input))
After the adjustment target color values cmykp have been obtained, the host device 100 finds target output values TargetOut for the adjustment points P0 input in the target reception area 840 (S306). Here, the adjustment target color values cmykp and the optimal solution Δcmykb obtained through the optimization process illustrated in
TargetOut=cmykp+Δcmykb
After calculating the target output values TargetOut, the host device 100 acquires input values Input_P in the adjustment target profile 550 and adjustment target values TargetOut_P for the adjustment points P0 (S308). This is in order to adjust the correspondence relationship between the input values and the output values in the adjustment target profile 550. When information based on the designated intent is in the profile, color conversion is carried out according to the information based on the designated intent.
With (a-2) and (a-3) indicated in
Input_P=Input
TargetOut_P=TargetOut
Current output values CurrentOut_P in the adjustment target profile 550 are adjustment target color values cmykp, which are the current output values in the designated profile.
CurrentOut_P=cmykp
When the relative values of the adjustment target T0 are expressed by the output color space CS5 of the adjustment target profile 550, it becomes TargetOut_P−CurrentOut_P.
As illustrated in
Input_P=Input
TargetOut_P=ficc(OutputProfile,A2B,TargetOut)
Finding the adjustment target values TargetOut_P (Lab values) of the adjustment target profile 550 from the target output values TargetOut (cmyk values) is in order to carry out adjustment taking the output colors cmykp, corresponding to the colors of the output image IMO, as a reference.
The current output values CurrentOut_P (Lab values) in the adjustment target profile 550 are expressed by the following equation.
CurrentOut_P=ficc(InputProfile,A2B,Input)
When the relative values of the adjustment target T0 are expressed by the output color space CS5 of the adjustment target profile 550, it becomes TargetOut_P−CurrentOut_P.
As illustrated in
Input_P=ficc(InputProfile,A2B,Input)
TargetOut_P=TargetOut
Additionally, the current output values CurrentOut_P (cmyk values) in the adjustment target profile 550 are adjustment target color values cmykp, which are the current output values in the combination of the profiles 610 and 620.
CurrentOut_P=cmykp
When the relative values of the adjustment target T0 are expressed by the output color space CS5 of the adjustment target profile 550, it becomes TargetOut_P−CurrentOut_P.
After acquiring the input values Input_P in the adjustment target profile 550 and the adjustment target values TargetOut_P, in S310 to S312, the host device 100 adjusts the adjustment range A0 of the adjustment target profile 550 based on the adjustment target T0.
First, referring to
The adjustment range A0 is set in the adjustment amounts AdjustData through inputs made in the adjustment range designation field 850, the target reception area 840, and the like illustrated in
The correction described above is performed for all coordinate axes in the input color space CS4 and all the coordinate values in the output color space CS5.
Next, an example of setting the adjustment amounts AD at the grid points GD0 of the adjustment range A0 will be described with reference to
First, as illustrated in
It should be noted that the nearest grid point GDnearest of a plurality of adjustment points near each other may be the same. In this case, for example, the adjustment amounts AdjustData of the adjustment points may be averaged at a ratio inversely proportional to the distance from the nearest grid point GDnearest to the respective adjustment points in the input color space CS4.
After determining the adjustment amounts AD1 of the output values with respect to the nearest grid point GDnearest, the host device 100 determines adjustment amounts AD2 of the output values with respect to grid points (the grid points indicated by the triangles) in the periphery of the nearest grid point GDnearest in the adjustment range A0, as illustrated in
Of course, this technique is not limited to using a spline function for the interpolation operation.
Because the targets of the adjustment amounts AD are the grid points, when a plurality of adjustment points are nearby, there are situations where the same grid points are referred to when color-converting the input colors of the adjustment points in accordance with the adjustment target profile 550. With such grid points, the adjustment amounts AdjustData of the respective adjustment points are averaged and then adjusted.
After the adjustment amounts AD of the output values with respect to the grid points in the adjustment range A0 have been determined, the host device 100 reflects the determined adjustment amounts AD in the adjustment target profile 550 (S314 of
As described above, in the second color space CS2, the correspondence relationship of the adjustment target profile 550 is adjusted so that the current adjustment target color values cmykp become closer to the target output values TargetOut. When information based on a designated intent is present in the adjustment target profile 550, the adjustment target profile 550 is adjusted with the correspondence relationship based on the designated intent.
After the adjustment target profile 550 has been updated, the host device 100 finds, for the respective adjustment points P0 input to the target reception area 840, the current adjustment target color values cmykp, using the updated adjustment target profile 550 or a combination of profiles including the updated adjustment target profile 550 (S316). The updated adjustment target color values cmykp can be calculated using the same equations as in the process of S304, described with reference to
Additionally, the host device 100 finds a difference d between the updated adjustment target color values cmykp and the target output values TargetOut, for the respective adjustment points P0 input in the target reception area 840 (S318). This difference can be, for example, a Euclidean distance between points corresponding to the adjustment target color values cmykp in the output color space CS5 of the adjustment target profile 550 and points corresponding to the target output values TargetOut.
Then, the host device 100 determines whether conditions for ending the repeated processing of S308 to S320 have been satisfied (S320), and repeats the processing of S308 to S320 when the conditions for ending have not been satisfied. When the conditions for ending have been satisfied, the host device 100 stores the adjusted adjustment target profile 550 in the storage device 114, and terminates the profile adjustment process. For example, the conditions for ending can be considered to be satisfied when the difference d is less than or equal to a prescribed threshold for all of the adjustment points P0. Alternatively, the conditions for ending may be considered to be satisfied upon a prescribed number being reached.
According to the foregoing, the adjustment target profile 550 is adjusted so that the adjustment target color values cmykp obtained from the input coordinate values corresponding to the adjustment points P0, in accordance with the current adjustment target profile 550 or a combination of profiles including the adjustment target profile 550, become closer to the target output values TargetOut. In this manner, the adjustment target profile 550 is adjusted using coordinate values expressing the output colors (cmykp) as a reference, and thus the specific example can adjust the profile used to convert the coordinate values in the color space so that the profile has good color reproduction accuracy. At this time, the solution Δcmykb of the adjustment color values Δcmyk, optimized so that a difference (relative value ΔLabT-p) of the adjustment target T0, which uses the Lab color space (CS3) expressing the colors of the patches in the color charts CH0 and CH1 as a reference, becomes as low as possible, is used. Accordingly, the profile can be adjusted so that the color reproduction accuracy is even better.
Various modified examples are conceivable in the disclosure.
For example, the output device is not limited to an ink jet printer, and may be an electrophotographic-type printer such as a laser printer using toner as the color materials, a three-dimensional printer, a display device, and the like.
The types of the color materials forming the images are not limited to C, M, Y, and K. In addition to C, M, Y, and K, Dy (dark yellow), Or (orange), and Gr (green) which are darker than Lc, Lm, and Y, Lk (light black) which is lighter than K, colorless color materials for improving image quality, and the like may be included as well.
Of course, the second color space is not limited to the cmyk color space, and may be the CMY color space, the RGB color space, and the like.
The target device is not limited to a target printing press, and may be a display device and the like.
Of course, the first color space is not limited to the CMYK color space, and may be the CMY color space, the RGB color space, and the like.
The above-described processes can be changed as appropriate, such as by rearranging the order. For example, in the optimization process of
Additionally, the process of calculating the cost C in S220 may be omitted, and the target function y=ΔE002+w×V2 may be calculated in the calculation process of S222. In this case too, the color reproduction accuracy of the adjustment target profile 550 can be improved by setting, as the optimal solution Δcmykb, the optimal solution candidates Δcmykpb in a case that the values of the target functions y obtained from the plurality of initial values Δcmyki are the lowest, in the optimal solution determination process of S232.
Furthermore, the process of calculating the square V2 of the magnitudes of the vectors of the adjustment color values Δcmyk in S218 may be omitted, and the target function y=ΔE002, or y=ΔE002+C may be calculated in the calculation process of S222. In this case too, the color reproduction accuracy of the adjustment target profile 550 can be improved by setting, as the optimal solution Δcmykb, the optimal solution candidates Δcmykpb in a case that the values of the target functions y obtained from the plurality of initial values Δcmyki are the lowest, in the optimal solution determination process of S232.
Furthermore, even in a case where the initial values Δcmyki of the adjustment color values Δcmyk are consolidated as (Δci, Δmi, Δyi, Δki)=(0, 0, 0, 0) and the like, the optimal solution Δcmykb of the adjustment color values Δcmyk at which the difference (relative value ΔLabT-p) of the adjustment target T0, using the PCS CS3 as a reference, becomes the lowest, can be obtained. The color reproduction accuracy of the profile can be improved by adjusting the profile using the optimal solution Δcmykb.
Even in a case where the device link profile is removed from the adjustment target profiles, the basic actions and effects of this technique can be achieved.
Additionally, even in a case where the adjustment target profile is limited to the output profile, the basic actions and effects of this technique can be achieved.
Furthermore, even in a case where a combination of the input profile and the output profile are used in the color conversion and the adjustment target profile is limited to the input profile, the basic actions and effects of this technique can be achieved.
As described thus far, according to the invention a technique and the like that improve the color reproduction accuracy of a profile used to convert coordinate values in a color space can be provided through various aspects. Of course, the above-described basic actions and effects are achieved by techniques implemented using only the constituent elements of the independent claims.
Additionally, configurations in which the configurations disclosed in the above-described examples are replaced with each other, or the combinations thereof are changed, configurations in which known techniques and the configurations disclosed in the above-described examples are replaced with each other, or the combinations thereof are changed, and the like are also possible. The invention also includes these configurations.
This application claims priority under 35 U.S.C. § 119 to Japanese Patent Application No. 2017-189322, filed Sep. 29, 2017. The entire disclosure of Japanese Patent Application No. 2017-189322 is hereby incorporated herein by reference.
Number | Date | Country | Kind |
---|---|---|---|
2017-189322 | Sep 2017 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
20130128289 | Sawatzki | May 2013 | A1 |
20170208216 | Sawada | Jul 2017 | A1 |
Number | Date | Country |
---|---|---|
2005-348210 | Dec 2005 | JP |
Number | Date | Country | |
---|---|---|---|
20190104234 A1 | Apr 2019 | US |