The present invention relates to a technology for adjusting a profile used to convert coordinate values of a color space.
When an ink jet printer is used to calibrate printing such as offset printing, color reproduction precision to be requested (the degree of accurately color reproduction) is very high. As a mechanism for realizing the color reproduction precision, there is a color management system that uses an international color consortium (ICC) profile. The ICC profile is data indicating a correspondent relation between device-independent color and a device-dependent color of a color device such as a printer (for example, an offset printer) or an ink jet printer. The device-dependent color of a printer or an ink jet printer is expressed by, for example, CMYK values indicating use amounts of cyan (C), magenta (M), yellow (Y), and black (K). The device-dependent color is expressed by, for example, saturation values of a CIE (international commission on illumination) L*a*b* color space (“*” is omitted and Lab values are used) or saturation values of a CIE XYZ color space which is a device-independent color space.
Here, an ICC profile of a printer is referred to as an input profile and an ICC profile of an ink jet printer is referred to as an output profile. When CMYK values (referred to as CMYKt values) in a printer are converted into saturation values (for example, Lab values) of a profile connection space (PCS) according to an input profile, the saturation values can be converted into CMYK values (referred to as CMYKp values) of the ink jet printer according to an output profile. When printing is executed by an ink jet printer according to the CMYKp values, colors closes to colors of a printer can be reproduced with the ink jet printer. Actually, expected colors may not be reproduced due to an error of a profile, a color measurement error, a variation in a printer, or the like in some cases. In these cases, conversion precision of target colors is improved by correcting the ICC profile.
JP-A-2003-87589 discloses a method of adjusting input values (Lab values) of an output profile for a CMYK printer to adjust color reproduction of the CMYK printer using a calibrator as a target device. In this method, a user selects colors to be adjusted (adjustment points) and sets adjustment amounts for the colors to be adjusted.
Some users desire to adjust not only a certain color point (which is assumed to be a point P1) but also all the colors continuous from this color (for example, white) to another color (which is assumed to be a point P2 and, for example, is red) in some cases. When adjustment amounts are set at only the adjustment points P1 and P2, a gradation property of an output image deteriorates in some cases. In this case, it is necessary to also set many adjustment points and adjustment amounts between the adjustment points P1 and P2. In particular, when the adjustment points P1 and P2 are separate from each other, it is necessary to execute setting to that degree. This setting is very troublesome.
The above-described problem is not limited to an adjustment case of a profile targeting an inkjet printer and may also arise even when a profile targeting various color devices is adjusted.
An advantage of some aspects of the invention is that it is provides a technology for easily improving a gradation property of an output image.
According to an aspect of the invention, there is provided a profile adjustment method of adjusting a profile defining a correspondent relation between input coordinate values of an input color space and output coordinate values of an output color space. The profile adjustment method includes: accepting setting of a first adjustment point of first coordinates and a second adjustment point of second coordinates; setting a third adjustment point of third coordinates based on the first and second coordinates; generating third adjustment data indicating degree of adjustment at the third adjustment point based on first adjustment data indicating degree of adjustment at the first adjustment point and second adjustment data indicating degree of adjustment at the second adjustment point; and adjusting the profile based on the first adjustment data, the second adjustment data, and the third adjustment data.
According to another aspect of the invention, there is provided a profile adjustment program causing a computer to realize functions corresponding to the steps of the above-described profile adjustment method.
According to still another aspect of the invention, there is provided a profile adjustment system including units corresponding to the steps of the above-described profile adjustment method.
In this case, it is possible to provide a technology for easily improving a gradation property of an output image.
The invention will be described with reference to the accompanying drawings, wherein like numbers reference like elements.
Hereinafter, embodiments will be described. Of course, the following embodiments are merely examples of the invention and all the characteristics described in the embodiments are not necessarily resolutions of the invention.
First, an overview of a technology included in the invention will be described with reference to examples illustrated in
According to an aspect of the technology, a profile adjustment method is a profile adjustment method of adjusting a profile 500 defining a correspondent relation between input coordinate values of an input color space CS4 and output coordinate values of an output color space CS5. The profile adjustment method includes an adjustment point acceptance step ST1, an adjustment point addition step ST2, an adjustment data generation step ST3, and a profile adjustment step ST4. In the adjustment point acceptance step ST1, setting of a first adjustment point P1 of first coordinates and a second adjustment point P2 of second coordinates is accepted. In the adjustment point addition step ST2, a third adjustment point Q of third coordinates is set based on the first and second coordinates. In the adjustment data generation step ST3, third adjustment data (for example, a third target T3 and a third adjustment range A3) indicating degree of adjustment at the third adjustment point Q is generated based on first adjustment data (for example, a first target T1 and a first adjustment range A1) indicating the degree of adjustment at the first adjustment point P1 and second adjustment data (for example, a second target T2 and a second adjustment range A2) indicating the degree of adjustment at the second adjustment point P2. In the profile adjustment step ST4, the profile 500 is adjusted based on the first adjustment data, the second adjustment data, and the third adjustment data.
In the foregoing Aspect 1, when the user sets the first adjustment point P1 of the first coordinates and the second adjustment point P2 of the second coordinates, the third adjustment point Q of the third coordinates is automatically further set, the third adjustment data indicating the degree of adjustment at the third adjustment point Q is generated, and the third adjustment data is used to adjust the profile 500. Accordingly, this aspect can provide the profile adjustment method of easily improving the gradation property of an output image.
Here, the input color space includes a CMYK color space, a CMY color space, an RGB color space, a CIE Lab color space, and a CIE XYZ color space. R stands for red, G stands for green, and B stands for blue.
The output color space also includes a CMYK color space, a CMY color space, an RGB color space, a CIE Lab color space, and a CIE XYZ color space.
The coordinates (first, second, and third coordinates) of the adjustment points (the first, second, and third adjustment points) may be coordinates of the input color space, may be coordinates of the output color space, may be coordinates of the profile connection space, or may be coordinates of a color space different from the color space. For the first adjustment point, a plurality of second adjustment points may be set. For the second adjustment point, a plurality of first adjustment points may be set.
The adjustment data (the first adjustment data, the second adjustment data, and the third adjustment data) includes a target of adjustment at an adjustment point and an adjustment range in which the adjustment point is a base point. The target may be expressed with coordinate values of a color space or may be expressed with differences from current coordinate values of the color space.
The additional remarks of the foregoing Aspect 1 are the same in the following aspects.
As exemplified in
As exemplified in
As exemplified in
As exemplified in
As exemplified in
As exemplified in
As exemplified in
As exemplified in
As exemplified in
As exemplified in
The foregoing Aspect 11 can provide the technology suitable for easily improving the gradation property of an output image since the output profile is combined with the input profile to be adjusted.
Incidentally, the profile adjustment program PRO according to an aspect of the technology causes a computer to realize functions corresponding to the steps of Aspect 1, that is, an adjustment point acceptance function FU1 corresponding to the adjustment point acceptance step ST1, an adjustment point addition function FU2 corresponding to the adjustment point addition step ST2, an adjustment data generation function FU3 corresponding to the adjustment data generation step ST3, and a profile adjustment function FU4 corresponding to the profile adjustment step ST4. This aspect can provide a profile adjustment program easily improving the gradation property of an output image.
A profile adjustment system (for example, the host device 100) according to an aspect of the technology includes units corresponding to the steps of Aspect 1, that is, an adjustment point acceptance unit U1 corresponding to the adjustment point acceptance step ST1, an adjustment point addition unit U2 corresponding to the adjustment point addition step ST2, an adjustment data generation unit U3 corresponding to the adjustment data generation step ST3, and a profile adjustment unit U4 corresponding to the profile adjustment step ST4. This aspect can provide a profile adjustment system easily improving the gradation property of an output image.
Further, the technology can be applied to a method of controlling the profile adjustment system, a complex system including the profile adjustment system, a method of controlling the complex system, a program controlling the profile adjustment system, a program controlling the complex system, a profile adjustment program, and a computer-readable medium recording the control program. The above-described device may be configured with a plurality of distributed portions.
The storage device 114 stores an operating system (OS) (not illustrated), a profile adjustment program PRO, and the like. The operating system, the profile adjustment program PRO, and the like are appropriately read to the RAM 113 to be used for adjustment process for a profile 500. Here, the profile 500 is a generic term of an input profile 610, an output profile 620, and a device link profile 630. At least one of the RAM 113 and the storage device 114 stores various kinds of information, for example, the input profile 610, the output profile 620, the device link profile 630, and an adjustment history 700. A nonvolatile semiconductor memory such as a flash memory or a magnetic storage device such as a hard disk can be used as the storage device 114.
A liquid crystal panel or the like can be used as the display device 115. A pointing device, a hard key including a keyboard, a touch panel attached on the surface of a display panel, or the like can be used as the input device 116. The color measurement device 117 can measure each color patch formed on a print substrate which is an example of a medium on which a color chart is formed and can output the color measurement values. The patch is also called a color chart. Color measurement values are considered as, for example, values indicating lightness L and chromaticity coordinates a and b in a CIE Lab color space. The color measurement device 117 may be installed out of the host device 100. The host device 100 acquires color measurement data including a plurality of color measurement values from the color measurement device 117 and executes various processes. The communication I/F 118 is connected to a communication I/F 210 of a printer 200 and inputs and outputs information such as printing data to the printer 200. As the standard of the communication I/F 118 and the communication I/F 210, a universal serial bus (USB), a short-range radio communication standard, or the like can be used. The communication of the communication I/F 118 and the communication I/F 210 may be wired or wireless or may be network communication such as a local area network (LAN) or the Internet.
The profile adjustment program PRO illustrated in
The host device 100 includes a computer such as a personal computer (including a tablet terminal). The host device 100 may include all the constituent elements 111 to 118 within a single casing and may also be configured as a plurality of devices separated to be able to communicate with each other. Even when the printer is the host device 100, the technology can be embodied.
The printer 200 illustrated in
Next, an example of a color management system to which the technology can be applied will be described with reference to
In the color management system illustrated in
The target printer 300 is assumed to be an offset printer, but a gravure printer, a flexographic printer, or the like may be used. The target color Ct is expressed with, for example, coordinate values (Lab values) of the CIE Lab color space.
The RIP 400 includes the input profile 610, the output profile 620, and a color library 640. The input profile 610 is a file that describes color characteristics of ink used by the target printer 300. The output profile 620 is a file that describes color characteristics of ink used by the ink jet printer 200. For both the profiles 610 and 620, for example, a data format of an ICC profile can be used. The process colors CMYKin of the printing document data D0 are converted into colors Labs of the Lab color space according to the input profile 610 and are converted into printing colors cmykp according to the output profile 620. When the printer 200 uses ink of a total of four colors of CMYK, the printing colors cmykp are output to the printer 200 to be reproduced on a printing matter.
When the names of colors are set in the printing document data D0, the RIP 400 converts the names of the colors into the colors Labs of the Lab color space with reference to the color library 640 in some cases.
The RIP 400 has not only the process colors CMYKin but also, for example, process colors expressing use amounts of color materials of only the three primary colors CMY (referred to as CMYin) which are subtractive mixture of colors or process colors expressing intensities of the three primary colors red (R), green (G), and blue (B) (referred to as RGBin) which are additive mixture of colors, and an input profile for converting coordinate values of the Lab color space. Accordingly, the RIP 400 can convert the process colors CMYin or the process colors RGBin into the printing colors cmykp via the Lab color space. In addition, the RIP 400 can also input the colors Labs of the Lab color space and convert the colors Labs into the printing colors cmykp.
As described above, colors close to colors of the target printer 300 can be reproduced by the ink jet printer 200. However, actually, expected colors may not be reproduced due to an error of a profile, a color measurement error, a variation in a printer, or the like in some cases. In these cases, conversion precision of target colors is improved by correcting the profiles 610 and 620. When the output profile 620 is corrected, it is considered that Labs values in a profile connection space (PCS) are set as target values, color differences between both the colors are calculated using results (Labp) obtained by measuring colors printed by the printer 200 as current values, and the output profile 620 is corrected to reduce the color differences. When the input profile 610 is corrected, it is considered that data of the color chart is converted into the input profile 610 and the output profile 620, the color chart is printed, color differences between color measurement results (Labp) of each patch and target saturation values (Labt) are calculated, and the input profile 610 is corrected to reduce the color differences.
Here, expected colors may not be obtained or it takes some time due to the following reasons.
Reason 1: Since it is necessary to measure colors of printed results, a measurement instrument is necessary and color matching countermeasure may not be taken visually.
Reason 2: When the input profile 610 is corrected, a calculation result of the color differences is fed back to the input profile 610. However, when it is considered that there is a reason of an error in the output profile 620, it is necessary to also correct another input profile. (In this case, by feeding the calculation result back to the output profile 620 and correcting the output profile 620, it is not necessary to correct another output profile.)
In the specific example, the functions FU1 to FU4 realized by the profile adjustment program PRO improve convenience of work for adjusting a profile used to convert coordinate values of the color space and realize further higher color reproduction precision or a gradation property.
As illustrated in
The output profile 620 is data that defines a correspondent relation between Lab values (Lj, aj, bj) of the Lab color space (CS3) and cmyk values (cj, mj, yj, kj) of the cmyk color space (which is example of a second color space CS2) suitable for ink used by the ink jet printer 200. In this case, lattice points GD2 of a B2A table are normally arranged at a substantially equal interval 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 for identifying the lattice points GD2 set in the Lab color space (CS3). The reason for expression as the “cmyk color space” is to distinguish a color space suitable for ink used by the printer 200 from a color space suitable for ink used by the target printer 300. The cmyk values are examples of second coordinate values. In the output profile 620, the Lab color space (CS3) is an example of an input color space CS4 and the cmyk color space (CS2) is an example of an output color space CS5.
The device link profile 630 is data that defines a correspondent relation between CMYK values (Ci, Mi, Yi, Ki) of the CMYK color space (CS1) and cmyk values (ci, mi, yi, ki) of an cmyk color space (CS2). Here, the variable i is a variable for identifying the lattice points GD1 set in the CMYK color space (CS1). The device link profile 630 can be obtained by linking the input profile 610 and the output profile 620. In the input profile 610, the CMYK color space (CS1) is an example of an input color space CS4 and the cmyk color space (CS2) is an example of an output color space CS5.
An A2Bx tag (x is 0, 1, or 2 illustrated in
The A2B0 tag and the B2A0 tag illustrated in
When the profile adjustment process illustrated in
The host device 100 ends the profile and parameter setting process when the input device 116 accepts an operation on the above-described fields and the buttons (S210) and an operation on the adjustment execution button 870 is accepted. The process of S210 includes the following processes S211 to S216:
(S211) a process of accepting selection of one of a combination of the profiles to be used for the change from the CMYK values to the cmyk values and one profile which is an adjustment target profile 550 to be used for the conversion from the CMYK values to the cmyk values;
(S212) a process of receiving one of the profiles 610, 620, and 630 as the adjustment target profile 550;
(S213) a process of accepting one of two or more kinds of color spaces among the CMYK color space (CS1), the cmyk color space (CS2), and the Lab color space (CS3) as an adjustment target color space CS6;
(S214) a process of accepting an input of the adjustment target T0 at coordinates expressing the adjustment point P0 (which is an example of the adjustment target color);
(S215) a process of accepting designation of an adjustment range in which a profile is adjusted based on the target T0 is the adjustment target profile 550 in the CMYK color space (CS1); and
(S216) a process of accepting one of a plurality of rendering intents for defining a correspondent relation of the adjustment target profile 550 as a designated intent.
First, the process of S211 will be described with reference to
The host device 100 accepts an operation of selecting a profile from the profiles 500 stored in the storage device 114 when the input device 116 accepts an operation on the selection fields 811 to 813.
In the input profile selection field 811, an input profile to be used for color conversion can be selected from the input profile 610 stored in the storage device 114 when the input profile 610 is used for the color conversion. When the input profile 610 is not used for the color conversion, the input profile selection field 811 may be set as a blank.
In the output profile selection field 812, an output profile to be used for the color conversion can be selected in the output profile 620 stored in the storage device 114 when the output profile 620 is used for the color conversion. When the output profile 620 is not used for the color conversion, the output profile selection field 812 may be set as a blank.
In the device link profile selection field 813, a device link profile to be used for the color conversion can be selected in the device link profile 630 stored in the storage device 114 when the device link profile 630 is used for the color conversion. When the device link profile 630 is not used for the color conversion, the device link profile selection field 813 may be set as a blank.
As illustrated in
As illustrated in
As illustrated in
As illustrated in
As described above, one of the combination of the profiles to be used for the color conversion and one profile which is the adjustment target profile 550 to be used for the color conversion is selected in the selection fields 811 to 813.
Next, the process of S212 will be described with reference to
The host device 100 executes a process of changing a designated item of the adjustment target profile designation profile 820 in response to the selection in the above-described selection fields 811 to 813.
As illustrated in
As illustrated in
As illustrated in
As illustrated in
As described above, when the combination of the input profile 610 and the output profile 620 is selected, one of the profiles 610, 620, and 630 is designated as the adjustment target profile 550 in the adjustment target profile designation field 820.
In the adjustment target profile designation field 820, validation or invalidation of an operation on the above-described selection fields 811 to 813 may be controlled in response to the selection so that the input profile 610, the output profile 620, and the device link profile 630 can all be selected as the adjustment target.
Further, the process of S213 will be described with reference to
The host device 100 executes a process of changing a selection item of the adjustment target color space selection field 830 in response to selection on the above-described selection fields 811 to 813.
As illustrated in
As illustrated in
As illustrated in
As illustrated in
As described above, one color space of two or more kinds of color spaces among the CMYK color space (CS1), the cmyk color space (CS2), and the Lab color space (CS3) is selected as the adjustment target color space CS6.
Further, the process of S214 will be described with reference to
The host device 100 executes a process of changing an input item of the target acceptance region 840 in response to selection in the above-described fields 811 to 813 and 830. The host device 100 executes a process of changing an input item of the target acceptance region 840 in response to selection in the adjustment data selection field 845.
As illustrated in
When the “absolute value” is selected in the adjustment data selection field 845, as illustrated in
When the “relative value” is selected in the adjustment data selection field 845, as illustrated in
As illustrated in
For example, when an operation on the button 841 of “designate from image” on the UI screen 800 illustrated in
When an operation on the history load button 881 is accepted, the host device 100 reads the adjustment history 700 of the adjustment stored in the storage device 114 and adds the adjustment history 700 in the target acceptance region 840. When an operation on the history save button 882 is accepted, the host device 100 stores information regarding the target acceptance region 840 as the adjustment history 700 in the storage device 114.
The adjustment target T0 accepted in the target acceptance region 840 is changed as follows depending on selected content of the adjustment target color space selection field 830 and selected content of the adjustment data selection field 845.
(Selected Content 1) The CMYK color space is selected as the adjustment target color space CS6 and the “absolute value” is selected as an input of the adjustment target T0. In this case, the input of the adjustment target T0 is the CMYK values (which are assumed to be T_C, T_M, T_Y, T_K). The CMYK values are expressed in, for example, 0 to 100%.
(Selected Content 2) The CMYK color space is selected as the adjustment target color space CS6 and the “relative value” is selected as an input of the adjustment target T0. In this case, the input of the adjustment target T0 is differences (which are assumed to be ΔC, ΔM, ΔY, ΔK) of the target values (T_C, T_M, T_Y, T_K) of the current values (C_C, C_M, C_Y, C_K) of the CMYK values.
(Selected Content 3) The Lab color space is selected as the adjustment target color space CS6 and the “absolute value” is selected as an input of the adjustment target T0. In this case, the input of the adjustment target T0 is the Lab values (which are assumed to be T_L, T_a, T_b).
(Selected Content 4) The Lab color space is selected as the adjustment target color space CS6 and the “relative value” is selected as an input of the adjustment target T0. In this case, the input of the adjustment target T0 is differences (which are assumed to be ΔL, Δa, and Δb) of the target values (T_L, T_a, T_b) of the current values (C_L, C_a, C_b) of the Lab values.
(Selected Content 5) The cmyk color space is selected as the adjustment target color space CS6 and the “absolute value” is selected as an input of the adjustment target T0. In this case, the input of the adjustment target T0 is the cmyk values (which are assumed to be T_c, T_m, T_y, T_k). The cmyk values are expressed in, for example, 0 to 100%.
(Selected Content 6) The cmyk color space is selected as the adjustment target color space CS6 and the “relative value” is selected as an input of the adjustment target T0. In this case, the input of the adjustment target T0 is differences (which are assumed to be Δc, Δm, Δy, Δk) of the target values (T_c, T_m, T_y, T_k) of the current values (C_c, C_m, C_y, C_k) of the cmyk values.
As described above, the adjustment target T0 is accepted at the coordinates indicating the adjustment point P0 in the adjustment target color space CS6.
The target acceptance region 840 illustrated in
For example, when an operation on the pair designation region 844 illustrated in
Here, the target T0 at the first adjustment point P1 illustrated in
As described above, the first target T1 and the second target T2 are set.
Further, the process of S215 will be described with reference to
The host device 100 accepts designation of whether the adjustment range A0 adjusted based on the adjustment target T0 is the whole color space in the adjustment range designation field 850. A plurality of designation items of the adjustment range designation field 850 illustrated in
Here, the radius at the first adjustment point P1 illustrated in
As described above, the first adjustment range A1 and the second adjustment range A2 are set in the adjustment target profile 550 in the first color space CS1.
Further, the process of S216 will be described with reference to
The host device 100 accepts designation of a rendering intent for defining a correspondent relation of the adjustment target profile 550 in the intent designation field 860. A plurality of designation items of the intent designation field 860 illustrated in
As described above, one of the plurality of rendering intents for defining the correspondent relation of the adjustment target profile 550 is accepted as a designation intent.
When the operation on the adjustment execution button 870 illustrated in
The added third adjustment point Qx is assumed to be generated on a line connecting the adjustment points P1 and P2 in the input color space CS4 of the adjustment target profile 550. The number of added third adjustment points Qx is a number N0 based on the interval ΔGD between the lattice points GD0 of the input color space CS4. Here, the number NO is set as small as possible in a range in which a minimum of one third adjustment point Qx is entered between the lattice points of the adjustment target profile 550.
For example, it is assumed that the input color space CS4 is the CMYK color space, the coordinates of the first adjustment point P1 at which the interval ΔGD between the lattice points GD0 is the unit are (C1, M1, Y1, K1), and the coordinates of the second adjustment point P2 at which the interval ΔGD between the lattice points GD0 is the unit are (C2, M2, Y2, and K2). In this case, the position of the third adjustment point Qx can be set as follows, for example.
First, of the C, M, Y, and K axes of the CMYK color space, coordinate axes are selected on which a distance between the first adjustment point P1 and the second adjustment point P2 at which the interval ΔGD between the lattice points GD0 is the unit is the longest. The coordinate axis which has the largest value among |C2−C1|, |M2−M1|, |Y2−Y1|, and |K2−K1| may be selected. The example of
Next, the number N0 of third adjustment points Qx at which the interval is equal to or less than the interval ΔGD between the lattice points GD0 is set in the direction of the selected coordinate axis.
The reason why the number N0 of third adjustment points Qx is reduced as much as possible is that a time taken to execute the processes of S104 to S120 in
Even when the input color space CS4 is the Lab color space, the third adjustment point Qx can be added in the same way. Here, it is assumed that the coordinates of the first adjustment point P1 at which the interval ΔGD between the lattice points GD0 is the unit are (L1, a1, b1) and the coordinates of the second adjustment point P2 at which the interval ΔGD between the lattice points GD0 is the unit are (L2, a2, b2). First, the coordinate axis which has the largest value among |L2−L1|, |a2−a1|, and |b2−b1| may be selected from the L, a, and b axes of the Lab color space. Subsequently, the N0 of third adjustment points Qx at which the interval is equal to or greater than the interval ΔGD between the lattice points GD0 may be set in the direction of the selected coordinate axis.
In the (b-2) case illustrated in
Here, as illustrated in
When the coordinates (which are assumed to be L3, a3, b3) of the third adjustment point Qx in the Lab color space are set, the coordinates (L3, a3, b3) of the third adjustment point Qx may be converted into CMYK values (C3, M3, Y3, K3) with reference to the B2A table of the input profile 610. This conversion is indicated by ficc(InputProfile, B2A, Input).
After the third point Q is added, the host device 100 determines the third target T3 of the third adjustment point Qx based on the first target T1 of the first adjustment point P1 and the second target T2 of the second adjustment point P2 (S222). In the process of S222, the third target T3 at the third coordinates of the third adjustment point Qx is interpolated based on the first target T1 at the first coordinates of the first adjustment point P1 and the second target T2 at the second coordinates of the second adjustment point P2.
For example, it is assumed that the adjustment amounts AdjustData are CMYK values and the adjustment amounts AdjustData (which are an example of the first target T1) of the first adjustment point P1 is (ΔC1, ΔM1, ΔY1, ΔK1) and the adjustment amounts AdjustData (which are an example of the second target T2) of the second adjustment point P2 is (ΔC2, ΔM2, ΔY2, ΔK2). When the adjustment amounts AdjustData (which are an example of the third target T3) of the third adjustment point Qx is expressed as (ΔC3x, ΔM3x, ΔY3x, ΔK3x), the adjustment amounts AdjustData of the third adjustment point Qx can be calculated by the following interpolation expressions:
ΔC3x=ΔC1+x·(ΔC2−ΔC1)/(N0+1);
ΔM3x=ΔM1+x·(ΔM2−ΔM1)/(N0+1);
ΔY3x=ΔY1+x·(ΔY2−ΔY1)/(N0+1); and
ΔK3x=ΔK1+x·(ΔK2−ΔK1)/(N0+1).
Even when the adjustment amounts AdjustData are Lab values or cmyk values, the adjustment amounts AdjustData of the third adjustment point Qx can be calculated similarly. The adjustment amounts AdjustData of the third adjustment point Qx are not limited to the interpolated values of the adjustment amounts AdjustData of the adjustment points P1 and P2, but can also be values deviating from the interpolated values.
The host device 100 determines the third adjustment range A3 in which the third adjustment point Qx is set as the base point based on the first adjustment range A1 in which the first adjustment point P1 is set as the base point and the second adjustment range A2 in which the second adjustment point P2 is set as the base point (S224) and ends the profile and the parameter setting process. The process of S224 may be executed before the process of S222. In S224, the third adjustment range A3 for the third coordinates of the third adjustment point Qx is interpolated based on the first adjustment range A1 for the first coordinates of the first adjustment point P1 and the second adjustment range A2 for the second coordinates of the second adjustment point P2.
Radius_3x=Radius_1+x·(Radius_2−Radius_1)/(N0+1).
The third adjustment range A3 in which the third adjustment point Qx is set as the base point is not limited to the interpolated values of the adjustment ranges A1 and A2 in which the adjustment points P1 and P2 are set as the base points, but can also be values deviating from the interpolated values.
The host device 100 performs a process subsequent to S104 of
First, the host device 100 obtains current output values CurrentOut according to the color conversion profile (including a combination of the profiles) designated in the profile selection fields 811 to 813 at each adjustment point P0 input in the target acceptance region 840 and the added third adjustment point Qx (S104). This is because the adjustment is executed using the output colors cmykp corresponding to the colors of the output image IM0 formed on the print substrate ME1 as a reference. When there is information appropriate for the designation intent in the profile, the color conversion is executed according to the information appropriate for the designation intent.
In the following description, the third adjustment point Qx is assumed to be included in the adjustment point P0 when the adjustment point P0 is merely described.
For example, as illustrated in
Here, as described above, conversion according to a profile is assumed to be indicated by ficc (first, second, and third arguments). Here, the first argument indicates a profile to be used. In the first argument, InputProfile indicates an input profile and OutputProfile indicates an output profile. DLProfile indicates a device link profile. In the second argument, A2B0 indicates conversion from device colors to device-independent colors and B2A indicates conversion from device-independent colors to device colors. In the third argument, Input indicates input values (CMYK, RGB, Lab, or the like) of the adjustment point P0.
In the foregoing (a-1) case, the adjustment target profile 550 automatically becomes the input profile 610 and the current output values CurrentOut can be calculated by the following expression (see
CurrentOut=ficc(InputProfile,A2B,Input).
As illustrated in
In the foregoing (a-2) case, the adjustment target profile 550 automatically becomes the output profile 620 and the current output values CurrentOut can be calculated by the following expression (see
CurrentOut=ficc(OutputProfile,B2A,Input).
As illustrated in
In the foregoing (a-3) case, the adjustment target profile 550 automatically becomes the device link profile 630 and the current output values CurrentOut can be calculated by the following expression (see
CurrentOut=ficc(DLProfile,A2B0,Input).
As illustrated in
In the foregoing (b-1) and (b-2) cases, when the adjustment target profile 550 is the input profile 610 or the output profile 620, the current output values CurrentOut can be calculated by the following expression (see
CurrentOut=ficc(OutputProfile,B2A,ficc(InputProfile,A2B,Input)).
After the current output values CurrentOut are calculated, the host device 100 obtains the target output values TargetOut according to the color conversion profile (including the combination of the profiles) designated in the profile selection fields 811 to 813 and the adjustment target color space CS6 designated in the adjustment target color space selection field 830 at each adjustment point P0 (including the third adjustment point Qx) (S106). This is because the adjustment is executed using the output colors cmykp corresponding to the colors of the output image IM0 formed on the print substrate ME1 as a reference. When there is the information appropriate for the designation intent in the profile, the color conversion is executed according to the information in accordance with the designation intent.
For example, as illustrated in
In the foregoing (a-1-1) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(InputProfile,A2B,Input+AdjustData).
As illustrated in
In the foregoing (a-1-2) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(InputProfile,A2B,Input)+AdjustData.
As illustrated in
In the foregoing (a-2-1) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(OutputProfile,B2A,Input+AdjustData).
As illustrated in
In the foregoing (a-2-2) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(OutputProfile,B2A,Input)+AdjustData.
When the device link profile 630 is designated for the color conversion and the input color space CS4 is designated in the adjustment target color space CS6 (a-3-1), the adjustment amounts AdjustData is added to the CMYK values (Cp, Mp, Yp, Kp) in the CMYK color space. The adjustment amounts AdjustData are expressed with relative values (ΔCp, ΔMp, ΔYp, ΔKp). In the CMYK color space, the CMYK values after the adjustment are expressed as (Cp+ΔCp, Mp+ΔMp, Yp+ΔYp, Kp+ΔKp).
In the foregoing (a-3-1) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(DLProfile,A2B0,Input+AdjustData).
When the device link profile 630 is designated for the color conversion and the output color space CS5 is designated in the adjustment target color space CS6 (a-3-2), the adjustment amounts AdjustData are added to the cmyk values (cp, mp, yp, kp) in the cmyk color space. The adjustment amounts AdjustData are expressed with relative values (Δcp, Δmp, Δyp, Δkp). In the cmyk color space, the cmyk values after the adjustment are expressed as (cp+Δcp, mp+Δmp, yp+Δyp, kp+Δkp).
In the foregoing (a-3-2) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(DLProfile,A2B0,Input)+AdjustData.
Although not illustrated, the Lab colors space may also be assumed to be designated in the adjustment target color space CS6. In this case, the Lab color space is the output color space CS5 in the input profile 610 and is the input color space CS4 in the output profile 620. The target output values TargetOut can be calculated, for example, by referring to the output profile used to generate the device link profile 630.
As illustrated in
In the foregoing (b-1-1) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(OutputProfile,B2A,ficc(InputProfile,A2B,Input+AdjustData)).
The foregoing expression is the same even when the adjustment target profile 550 is the output profile 620.
As illustrated in
In the foregoing (b-1-2) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(OutputProfile,B2A,ficc(InputProfile,A2B,Input))+AdjustData.
The foregoing expression is the same even when the adjustment target profile 550 is the output profile 620.
As illustrated in
In the foregoing (b-1-3) case, the target output values TargetOut can be calculated by the following expression (see
TargetOut=ficc(OutputProfile,B2A,ficc(InputProfile,A2B,Input)+AdjustData).
The foregoing expression is the same even when the adjustment target profile 550 is the output profile 620.
The calculation of the target output values TargetOut can be omitted when the adjustment target T0 is expressed with the output coordinate values. The calculation of the target output values TargetOut can be executed when the adjustment target T0 is not expressed with the output coordinate values.
After the target output values TargetOut are calculated, the host device 100 acquires the input values Input_P and the adjustment target values TargetOut_P at each adjustment point P0 in the adjustment target profile 550 (S108). This is because the correspondent relation between the input values and the output values in the adjustment target profile 550 is adjusted. When there is information regarding the designation intent in the profile, the color conversion is executed according to the information appropriate for the designation intent.
In the (a-1), (a-2), and (a-3) cases illustrated in
Input_P=Input; and
TargetOut_P=TargetOut.
The current output values CurrentOut_P in the adjustment target profile 550 are the current output values CurrentOut of the designated profile:
CurrentOut_P=CurrentOut
When the relative value of the adjustment target T0 is expressed in the output color space CS5 of the adjustment target profile 550, TargetOut_P−CurrentOut_P is set.
As illustrated in
Input_P=Input; and
TargetOut_P=ficc(OutputProfile,A2B,TargetOut).
The reason why the adjustment target values TargetOut_P (the Lab values) of the adjustment target profile 550 are obtained from the target output values TargetOut (the cmyk values) is to execute the adjustment using the output colors cmykp corresponding to the colors of the output image IM0 as a reference.
The current output values CurrentOut_P (the Lab values) in the adjustment target profile 550 are expressed in the following expression:
CurrentOut_P=ficc(InputProfile,A2B,Input).
The relative values of the adjustment target T0 are expressed in the output color space CS5 of the adjustment target profile 550, TargetOut_P−CurrentOut_P is set.
As illustrated in
Input_P=ficc(InputProfile,A2B,Input); and TargetOut_P=TargetOut.
The current output values CurrentOut_P (the cmyk values) in the adjustment target profile 550 are the current output values CurrentOut of the combination of the profiles 610 and 620:
CurrentOut_P=CurrentOut.
When the relative values of the adjustment target T0 are expressed in the output color space CS5 of the adjustment target profile 550, TargetOut_P−CurrentOut_P is set.
After the input values Input_P in the adjustment target profile 550 and the adjustment target values TargetOut_P are acquired, the host device 100 adjusts the adjustment range A0 of the adjustment target profile 550 based on the adjustment target T0 in S110 to S112.
First, the concept that the adjustment target profile 550 is adjusted in the adjustment range A0 will be described with reference to
The adjustment range A0 is set in the adjustment amounts AdjustData through an input to the adjustment range designation field 850 and the target acceptance region 840 illustrated in
The above-described correction is executed on all the coordinate axes of the input color space CS4 and all the coordinate values of the output color space CS5.
Next, an example in which the adjustment amounts AD is set at each lattice point GD0 of the adjustment range A0 will be described with reference to
As illustrated in
After the host device 100 determines the adjustment amounts AD1 of the output values at the nearest lattice point GDnearest, as illustrated in
Of course, the technology is not limited to the spline functions used for the interpolation calculation.
Some users want to adjust all the colors of gradation continuous from the first adjustment point P1 to the second adjustment point P2 as in the gradation image IM1 illustrated in
In the specific example, the third adjustment point Qx is automatically added between the pair of designated adjustment points P1 and P2, the adjustment amounts AdjustData and the adjustment range A3 of the third adjustment point Qx are also automatically determined, and such adjustment data is also reflected in the adjustment of the profile 500. Accordingly, the work for improving the gradation property of the output image is reduced.
After the adjustment amounts AD of the output values at each lattice point of the adjustment range A0 is determined, the host device 100 reflects the determined adjustment amounts AD in the adjustment target profile 550 (S114 of
In this way, the correspondent relation of the adjustment target profile 550 is adjusted so that the current output values CurrentOut in the second color space CS2 are close to the target output values TargetOut. When there is the information appropriate for the designation intent in the adjustment target profile 550, the adjustment target profile 550 is adjusted in the correspondent relation appropriate for the designation intent.
After the adjustment target profile 550 is updated, the host device 100 obtains the current output values CurrentOut using the adjustment target profile 550 after the updating or the combination of the profiles including the adjustment target profile 550 after the updating at each adjustment point P0 (including the third adjustment point Qx) (S116). The current output values CurrentOut after the updating can be calculated using the same expression as the process of S104 described with reference to
The host device 100 obtains differences d between the current output values CurrentOut after the updating and the target output values TargetOut at each adjustment point P0 (including the third adjustment point Qx) (S118). For example, the differences can be Euclid distances between points corresponding to the output values CurrentOut in the output color space CS5 of the adjustment target profile 550 and points corresponding to the target output values TargetOut.
In addition, the host device 100 determines whether an end condition of the repeated processes of S108 to S120 is established (S120). When the end condition is not established, the processes of S108 to S120 are repeated. When the end condition is established, the profile adjustment process ends. For example, when the differences d at all the adjustment points P0 are equal to or less than predetermined thresholds, the end condition can be established. When the repeated process reaches a specified number of times, the end condition may be established.
As described above, the adjustment target profile 550 is adjusted so that the current output values CurrentOut obtained from the input coordinate values corresponding to the adjustment point P0 according to the current adjustment target profile 550 or the combination of the profiles including the adjustment target profiles 550 are closed to the target output values TargetOut. In this way, since the adjustment target profile 550 is adjusted using the coordinate values indicating the output colors cmykp as the reference, the profile used to convert the coordinate values of the color space can be adjusted with good color reproduction precision in the specific example. At this time, since the adjustment target profile 550 or the adjustment target color space CS6 can be designated, the specific example can flexibly correspond to a use environment of a user.
The third adjustment point Q is automatically added between the pair of designated adjustment points P1 and P2, the adjustment range A3 and the third target T3 of the adjustment of the third adjustment point Q are automatically added, and thus adjustment data is used to adjust the profile 500. Accordingly, the specific example can provide the technology for easily improving the gradation property of an output image.
Various modification examples of the invention can be considered.
For example, an output device is not limited to an ink jet printer, but may be an electrographic printer such as a laser printer, a 3-dimensional printer, a display device, or the like.
The kinds of color materials for forming an image are not limited to C, M, Y, and K, but may include Lc, Lm, dark yellow (Dy) with higher density than Y, orange (Or), green (Gr), light black (Lk) with lower density than K, unpigmented color materials for image quality improvement, or the like in addition to C, M, Y, and K.
Of course, the second color space is not limited to the cmyk color space, but may be the CMY color space, the RGB color space, or the like.
A target device is not limited to a target printer, but may be a display device or the like.
Of course, the first color space is not limited to the CMYK color space, but may be the CMY color space, the RGB color space, or the like.
The color spaces which can be selected as the adjustment target color space are not limited to the three kinds of color spaces, the first color space, the second color space, and the profile connection space, but may be two kinds of color spaces, the first color space and the second color space, may be two kinds of color spaces, the first color space and the profile connection space, or may be two kinds of color spaces, the second color space and the profile connection space.
The third adjustment point Q is not limited to the line connecting the adjustment points P1 and P2, but may be set at a position deviating from the line connecting the adjustment points P1 and P2.
Even when the adjustment range A0 is constant, the third target T3 at the third adjustment point Qx can be determined based on the first target T1 of the adjustment at the first adjustment point P1 and the second target T2 of the adjustment at the second adjustment point P2. Even when the targets T1 and T2 are determined in advance, the third adjustment range A3 can be determined based on the first adjustment range A1 in which the first adjustment point P1 is set as the base point and the second adjustment range A2 in which the second adjustment point P2 is set as the base point.
As illustrated in
As described above, the user can select priority between the processing time and the improvement in the gradation property according to his or her preference.
As illustrated in
Referring to
In the process of S220, the host device 100 sets the third adjustment points Qx of the third coordinates expressing the Lab values based on the first adjustment point P1 (L1, a1, b1) and the second adjustment point P2 (L2, a2, b2) in the Lab color space (CS3). The third adjustment points Qx to be added are assumed to be generated on a line connecting the adjustment points P1 and P2 in the Lab color space (CS3). The third adjustment points Qx to be added is assumed to be the number N0 based on the lattice points GD0 of the output profile 620 which is the adjustment target profile 550, that is, the interval ΔGD of the lattice points GD0 of the Lab color space (CS3). Here, the number N0 is set to be as small as possible in a range in which a minimum of one third adjustment point Qx is entered between the lattice points of the output profile 620.
For example, a coordinate axis on which a distance between the first adjustment point P1 and the second adjustment point P2 is the longest in units of the interval ΔGD of the lattice points GD0 is selected from the L axis, the a axis, and the b axis of the Lab color space. The example of
In the process of S222, the host device 100 may first convert the targets T1 and T2 of the adjustment points P1 and P2 at which the coordinates of the CMYK color space (CS1) are a reference into targets in which the coordinates of the Lab color space (CS3) are a reference according to the input profile 610. For example, it is assumed that the adjustment amounts AdjustData are the CMYK values, the adjustment amounts AdjustData (an example of the first target T1) of the first adjustment point P1 are (ΔC1, ΔM1, ΔY1, ΔK1), and the adjustment amounts AdjustData of the second adjustment point P2 (an example of the second target T2) are (ΔC2, ΔM2, ΔY2, ΔK2). The adjustment amounts (ΔC1, ΔM1, ΔY1, ΔK1) may be converted into the adjustment amounts (ΔL1, Δa1, Δb1) of the Lab values according to the input profile 610, and the adjustment amounts (ΔC2, ΔM2, ΔY2, ΔK2) may be converted into the adjustment amounts (ΔL2, Δa2, Δb2) of the Lab values according to the input profile 610. The adjustment amounts (ΔL1, Δa1, Δb1) are an example of fourth adjustment data and the adjustment amounts (ΔL2, Δa2, Δb2) are an example of the fifth adjustment data.
The host device 100 may determine the adjustment amounts (which are assumed to be ΔL3, Δa3, Δb3) of the third adjustment point Qx based on the adjustment amounts (ΔL1, Δa1, Δb1) of the first adjustment point P1 and the adjustment amounts (ΔL2, Δa2, Δb2) of the second adjustment point P2. For example, this process can be executed as a process of interpolating the adjustment amounts (ΔL3, Δa3, Δb3) of the third adjustment point Qx based on the adjustment amounts (ΔL1, Δa1, Δb1) of the first adjustment point P1 and the adjustment amounts (ΔL2, Δa2, Δb2) of the second adjustment point P2 using the coordinates of the Lab color space (CS3) as a reference.
In the process of S224, the host device 100 may convert the adjustment ranges A1 and A2 of the adjustment points P1 and P2 at which the coordinates of the CMYK color space (CS1) as a reference into adjustment ranges in which the coordinates of the Lab color space (CS3) are a reference according to the input profile 610. The first adjustment range A1 after the conversion is an example of the fourth adjustment data and the second adjustment range A2 after the conversion is an example of the fifth adjustment data.
The host device 100 may determine third adjustment range amounts A3 of the third adjustment point Qx based on the first adjustment range A1 of the first adjustment point P1 and the second adjustment range A2 of the second adjustment point P2. For example, this process can be executed as a process of interpolating the third adjustment amounts A3 of the third adjustment point Qx based on the first adjustment range A1 of the first adjustment point P1 and the second adjustment range A2 of the second adjustment point P2 using the coordinates of the Lab color space (CS3) as a reference.
When the process of S224 of
In this way, it is possible to easily improve the gradation property of an output image when the output profile and the input profile are combined for adjustment.
As described above, according to the various aspects of the invention, it is possible to provide the technology or the like for easily improving the gradation property of an image output. Of course, even in a technology realized by only constituent factors according to the independent claims, it is possible to obtain the above-described basic operational effects and advantages.
It is also embody configurations in which configurations disclosed in the above-described examples are substituted or combinations thereof are changed and configurations in which configurations disclosed in the known technologies and the above-described examples are substituted or combinations thereof are changed. The invention also includes such configurations.
This application claims priority under 35 U.S.C. § 119 to Japanese Patent Application No. 2017-111411, filed Jun. 6 2017. The entire disclosure of Japanese Patent Application No. 2017-111411 is hereby incorporated herein by reference.
Number | Date | Country | Kind |
---|---|---|---|
2017-111411 | Jun 2017 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5909291 | Myers | Jun 1999 | A |
10455122 | Yamashita | Oct 2019 | B2 |
20020126302 | Fukao | Sep 2002 | A1 |
20030053097 | Ohga et al. | Mar 2003 | A1 |
20030164968 | Iida | Sep 2003 | A1 |
20030165267 | Tamagawa | Sep 2003 | A1 |
20040183813 | Edge | Sep 2004 | A1 |
20080007784 | Tsuji | Jan 2008 | A1 |
20080158579 | Ohga et al. | Jul 2008 | A1 |
20080216695 | Ozaki | Sep 2008 | A1 |
20100002246 | Ozaki | Jan 2010 | A1 |
20120057781 | Morovic | Mar 2012 | A1 |
20120057785 | Morovic | Mar 2012 | A1 |
20120218574 | Fukuda | Aug 2012 | A1 |
20120274958 | Hoshino | Nov 2012 | A1 |
20130003089 | Morovic et al. | Jan 2013 | A1 |
20130100157 | Morovic | Apr 2013 | A1 |
20170111551 | Morovic | Apr 2017 | A1 |
20180352114 | Fukasawa et al. | Dec 2018 | A1 |
20180352117 | Fukasawa | Dec 2018 | A1 |
20180376030 | Yamashita | Dec 2018 | A1 |
20190068840 | Fujino | Feb 2019 | A1 |
20190124233 | Fukasawa | Apr 2019 | A1 |
20190139511 | Yamashita | May 2019 | A1 |
Number | Date | Country |
---|---|---|
3796422 | Jul 2006 | JP |
2018-207327 | Dec 2018 | JP |
2019-087834 | Jun 2019 | JP |
Entry |
---|
The Extended European Search Report for the corresponding European Patent Application No. 18176155.2 dated Oct. 19, 2018. |
Number | Date | Country | |
---|---|---|---|
20180352116 A1 | Dec 2018 | US |