1. Field of the Invention
The present invention relates to conversion of a color data value in a rectangular color coordinate system such as CIELab color coordinate system to a corresponding color data value in a cylindrical or polar coordinate system such as CIELCh coordinate system, and to in particular the use of one-dimensional look-up tables to facilitate the conversion.
2. Description of the Related Art
Recent efforts in implementation of color science into computer software have resulted in increasingly sophisticated and accurate applications, particularly at the consumer level. Correspondingly, end users of the software have increased expectations as to the accuracy and fidelity of color data reproduced thereby. For example, it is now commonplace for users to expect a color management system to accurately processes computerized color data such as color image data so as to maintain fidelity of the color data over a wide variety of viewing environments, and over a wide variety of output devices.
As a result of these increased expectations by users and the increased sophistication of applications, it is common for such applications to engage in significant manipulation of color data. One frequently encountered manipulation involves a transformation of color data from a rectangular coordinate system such as CIELab to cylindrical or polar coordinates such as CIELCh. For example, there are some manipulations such as gamut matching or mapping which is performed more easily and/or more accurately in cylindrical CIELCh coordinates, whereas there are other manipulations such as forward- and reverse-transforms based on device profiles that are better performed in rectangular coordinates such as CIELab.
Mathematically, the conversion of data values between CIELab and CIELCh coordinates involves the following equations (hereinafter, CIELab will be used as a representative example of rectangular coordinates and CIELCh will be used as a representative example of cylindrical or polar coordinates:
These equations are computationally costly, particularly since the equations must be evaluated for each and every pixel in a color image. Other techniques have therefore been considered for evaluation of these equations in a less costly manner.
One such technique involves use of two-dimensional look-up tables, a first look-up table to evaluate the “C” value of equation (1) above, and a second look-up table to look up the “h” value in equation (2) above. Since each of these values depends on the “a” and “b” coordinates, a two-dimensional look-up table is required for each of equations (1) and (2).
This approach has significant disadvantages, particularly for look-up tables of reasonable size. For example, with a two-dimensional look-up table of 32×32 grid size, which requires 1,024 entries, an unacceptably large error value of nearly 10 degrees is obtained for the “h” value of equation (2). Although interpolation can help reduce this error, the error is still significant for table values of reasonable size, resulting in correspondingly significant color inaccuracies.
The present invention addresses the foregoing disadvantage of two-dimensional look-up tables by instead employing one-dimensional look-up tables that are indexed with a single input parameter γ, where γ is defined as the absolute value of the ratio of the a and b coordinates, such as:
Thus, in one aspect, the invention involves conversion of a color data value (a, b) in rectangular coordinates to a corresponding color data value (c, h) in polar coordinates, in which a variable, γ, is calculated as the absolute value of the ratio of b and a. For example, a first one-dimensional look-up table is accessed using the γ value to obtain a first look-up value, with the first one-dimensional look-up table implementing the values √{square root over (1+γ2)} for values of γ in the range [0 to 1]. The first look-up value is ambiguous with respect to the diagonal quadrant of the C value, and the diagonal quadrant is therefore resolved based on the ratio γ, after which the value of C is calculated based on the resolved diagonal quadrant and the first look-up value. The diagonal quadrants are formed by the orthogonal lines defined by a=b and by a=(−b). A second one-dimensional look-up table is accessed so as to obtain a second look-up value, with the second look-up table implementing the values of arctan (γ) on the range [0 to 1]. The second look-up value is ambiguous with respect to the octant for the value h, and the octant is therefore resolved based on the values of a and b and further based on the ratio γ. Thereafter, the h value is calculated based on the resolved octant and the second look-up value.
Because the invention defines a ratio γ of the b and a values, one-dimensional look-up tables can be used (one for each of the “C” and the “h” coordinates), instead of the previously required two-dimensional tables. Moreover, because a one-dimensional table is used, a table with the same number of entries as the previously required two-dimensional table can yield results of much greater accuracy. For example, with respect to the aforementioned 32×32=1,024 entry table, a one-dimensional look-up table with nearly the same number of entries (n=1,000) can yield an acceptably small error for h of 10−5 degrees.
In more specific aspects of the invention, the ratio γ is defined differently based on the relative values of a and b, so that in some circumstances γ=b/a and in other circumstances γ=a/b. Alternatively, γ can be consistently defined as γ=|a/b| (or |b/a|), with the look-up tables being accessed based on either γ or 1/γ depending on the size of γ. Moreover, when resolving the diagonal quadrant for C and the octant for h, special cases can be defined for particular values of a and b, so as to avoid singularities (such as arctan (90°)) and undefined conditions (such as a=b=0).
This brief summary has been provided so that the nature of the invention may be understood quickly. A more complete understanding of the invention can be obtained by reference to the following detailed description of the preferred embodiment thereof in connection with the attached drawings.
The present invention utilizes one-dimensional look-up tables for the conversion of a color data value in a rectangular color coordinate system, such as CIELab color coordinate system, to a corresponding color data value in a cylindrical or polar coordinate system, such as CIELCh coordinate system. The use of one-dimensional look-up tables for the conversion allows for precise and efficient conversion of image data, thereby conserving computing resources, such as computational processing time and memory. In one embodiment discussed below, the present invention is particularly useful in converting color image data coordinates during color management of color image data.
Turning to
Computing equipment 40 includes a computer-readable memory medium such as computer fixed disk 45 and/or floppy disk drive 44. Floppy disk drive 44 provides a means whereby computing equipment 40 can access information, such as image data, computer-executable process steps, application programs, etc. stored on removable memory media. A similar CD-ROM interface (not shown) may be provided for computing equipment 40 through which computing equipment 40 can access information stored on removable CD-ROM media.
Printer 50 is a printer, preferably a color bubble jet printer, which forms color images on a recording medium such as paper or transparencies or the like. The invention is usable with other printers, however, so long as the printer is capable of being interfaced to computing equipment 40. In addition, digital camera 60 is depicted and can be used to transfer color image data corresponding to one or more images to computing equipment 40. Of course, computing equipment 40 may acquire digital image data from other sources such as a scanner (not shown) or from a local area network or the Internet via network interface bus 80.
Main memory 116 interfaces with computer bus 114 so as to provide RAM storage to CPU 113 during execution of software programs such as an operating system, application programs and device drivers. More specifically, CPU 113 loads computer-executable process steps from fixed disk 45, another storage device, or some other source such as a network, into a region of main memory 116. CPU 113 then executes the stored process steps from main memory 116 in order to execute software programs such as an operating system, application programs and device drivers. Data such as color images can be stored in main memory 116, where the data can be accessed by CPU 113 during the execution of computer-executable process steps which use or alter the data.
As also shown in
Color management module 145 obtains color space transform 152 from source color profile 151 which corresponds to the source device from which source image data 150 was obtained. For example, if source image data 150 is obtained from monitor 43, then monitor color profile 140 is used as source color profile 151. Typically, a standardized color profile for a given device contains a transform, such as a matrix or look-up table, which describes the transformation of color image data from the color space of the given device to a device-independent color space. For example, in the case that source image data 151 is obtained from monitor 43, then monitor color profile 140 contains a color space transform for converting from RGB, which is the color space of the monitor, to CIELab, which is a standardized device-independent color space. Color space transform 152 from source color profile 152 therefore allows source image data 150 to be converted from RGB to device-independent color space CIELab so that source image data 151 can then be converted into the color space of another output device, such as the CMYK color space for output on printer 50.
Color management module 145 performs gamut mapping in order to map source image data 151 into the color gamut for a given output device, such as for printer 50. The color gamut of a given device is generally a description of the outer limits of color reproduction capabilities of a given device. For example, printer 50 may not have the capability to produce a printed image having a light green color. Accordingly, color management module 145 uses the gamut boundary description for printer 50, usually obtained from a corresponding color profile such as printer color profile 141, to compress the range of light green colors for the pixels of source image data 151 into the gamut boundary for printer 50. In this manner, printer 50 can print an image corresponding to source image data 151 in which the range of colors are represented to the best capability of printer 50.
Returning to
In
As mentioned above, the conversion from rectangular coordinates Lab to polar coordinates LCh is represented by the equations:
Unfortunately, the implementation of equations (1) and (2) through two-dimensional look-up tables based on a and b requires a large number of entries in each two-dimensional look-up table in order to achieve acceptable accuracy. Such large two-dimensional look-up tables require significant memory and require significant processing time to manipulate. Accordingly, the present invention utilizes two one-dimensional look-up tables, one for use in calculating C, and the other for use in calculating h. Both of these one-dimensional look-up tables are indexed by a single common variable, γ, which is defined as:
By using γ, the foregoing equation (1) is redefined as:
In this manner, a look-up table can be accessed during the calculation of C based on a single variable γ, instead of being based on two variables a and b, where γ is precalculated based on a and b. C is then calculated based on the result from the look-up table and on a or b, as the case may be. In other words, both Equations 4(a) and 4(b) use the function:
f(γ*)=(1.0+(γ*)2)1/2 where γ*=γ if 0.0≦γ≦1.0 (Equation 4(a)), and
where γ*=1/γ if γ>1.0 (Equation 4(b))
Note that the function “f” always operates on a value which is between 0.0 and 1.0, regardless of the relative values of a and b (e.g. γ), because in the case that γ is greater than one, the function “f” operates on 1/γ. Accordingly, a one-dimensional look-up table can be generated based on values of (1.0+(i)2)1/2 for values of i between 0.0 and 1.0. The one-dimensional look-up table can then be accessed based on a given value of γ, or 1/γ as the case may be, to calculate C according to either Equation 4(a) or Equation 4(b), as the case may be, depending on the value of γ.
In this manner, a one-dimensional look-up table can be used to calculate C during conversion from rectangular to polar coordinates, thereby achieving computational efficiency while still maintaining accuracy during the conversion. The determination of which one of Equations 4(a) and 4(b) to use during conversion is summarized in
Similarly, the h value of LCh coordinates can be determined by using a one-dimensional look-up table for H(γ) for values of γ between 0.0 and 1.0 according to:
H(γ*)=arctan(γ*) where γ*=γ for [0.0≦γ≦1.0] and
where γ*=1/γ for [γ>1.0]
Based on simple trigonometry, the h value can then be calculated from H(γ*) by a simple addition or subtraction step, depending on which octant of a-b plane 161 of
As seen in
Based on the above, a one-dimensional look-up table can be generated for arctan(i) for values of i between 0.0 and 1.0. The one-dimensional look-up table can then be accessed based on γ or 1/γ, depending on the value of γ, in order to calculate h according to the appropriate trigonometric equation which is selected based on the values of a, b and γ, as depicted in
Turning to
As discussed above, “f” one-dimensional look-up table 147 is populated for f(γ*) which is represented by (1.0+(γ*)2)1/2 for values of γ* between 0.0 and 1.0, such that the values for f(γ*) range from 0.0 to 2.01/2. Accordingly, where “f” one-dimensional look-up table 147 has n entries, the values for each entry i are populated according to:
FT[i]=f(i/(n−1))=(1.0+(i/(n−1))2)1/2 where i=0, 1, 2, . . . (n−1)
Similarly, “H” one-dimensional look-up table 148 is populated for H(γ*) which is represented by arctan(γ*) for values of γ* between 0.0 and 1.0, thereby resulting in values of H(γ*) in the range of 0.0 to 45.0. Accordingly, where “H” one-dimensional look-up table 148 has n entries, the values for each entry i are populated according to:
HT[i]=H(i/(n−1))=arctan(i/(n−1)) where i=0, 1, 2, . . . (n−1)
It can be appreciated that each of one-dimensional look-up tables 147 and 148 can be accessed based on the given value of γ*, which is between 0.0 and 1.0, by multiplying γ* by (n−1) to determine the nearest entry point(s) in the one dimensional look-up table. In the case where γ*(n−1) does not have a fractional component, the value of γ* falls directly on a particular entry point and the corresponding value for that entry point is returned. In the case where γ*(n−1) does have a fractional component, the value of γ* falls in between two entry points and interpolation is performed between the corresponding values for the two entry points to obtain a return value. One possible set of interpolation equations is:
f(γ*)=x*FT[i+1]+(1−x)*FT[i]
H(γ*)=x*HT[i+1]+(1−x)*HT[i]
where i is the integer portion of γ*(n−1), and where x is the fractional portion of γ*(n−1).
The value of γ, or 1/γ as the case may be, is used to access “f” one-dimensional look-up table 147 in order to obtain f(γ), or f(1/γ) as the case may be according to the determined equation for C (step S804). In step S805, the value of C is then calculated according to the determined equation for C from step S803 based on the obtained value of f(γ), or f(1/γ) as the case may be, from step S804. In step S806, the values of a, b and γ are compared and then used in step S807 to resolve the h (hue) octant to determine which one of the trigonometric equations depicted in
In step S810, it is determined whether more image pixel data remains to be converted for the input image data. If there is more image pixel data to be converted, flow passes to step S801 in which steps S801 to S810 are repeated. If there is no more image pixel data to be converted, flow passes to end in step S811. In this manner, one-dimensional look-up tables 147 and 148 are used to perform the conversion of image data from rectangular to polar coordinates in a computationally efficient manner without requiring the processor to perform complex mathematical calculations, and without requiring large cumbersome two-dimensional look-up tables, while still maintaining precise conversion with low error.
Once the group of either
The value of γ, or 1/γ as the case may be, is used to access “f” one-dimensional look-up table 147 in order to obtain f(γ), or f(1/γ) as the case may be according to the determined equation for C (step S1005). In step S1006, the value of C is then calculated according to the determined equation for C from step S1004 based on the obtained value of obtain f(γ), or f(1/γ) as the case may be, from step S1005. In step S1007, the value of γ or 1/γ, as the case maybe, is used to access “H” one-dimensional look-up table 148 in order to obtain H(γ) or H(1/γ), as the case may be according to the determined equation for h. In step S1008, the value of h is then calculated according to the determined equation for h from step S1004 based on the obtained value of H(γ) or H(1/γ), as the case may be, from step S1007.
In step S1009, it is determined whether more image pixel data remains to be converted for the input image data. If there is more image pixel data to be converted, flow passes to step S1001 in which steps S1001 to S1009 are repeated. If there is no more image pixel data to be converted, flow passes to end in step S1010. In this manner, one-dimensional look-up tables 147 and 148 are used to perform the conversion of image data from rectangular to polar coordinates in a computationally efficient manner without requiring the processor to perform complex mathematical calculations, and without requiring large cumbersome two-dimensional look-up tables, while still maintaining precise conversion with low error.
It can be appreciated that the invention may be implemented in a manner other than the embodiments described above. For example, the conversion of image data using one-dimensional look-up tables according to the present invention may be directly implemented in a device driver, such as a printer driver or scanner driver, or may be directly implemented in embedded software of an image device, such as a printer, scanner or camera. In addition, the functional steps described above for the conversion of image data using one-dimensional look-up tables do not necessarily have to be performed by a coordinate conversion module, but could be coded directly within color management software, or another application or program which operates in image data.
Although the invention has been described with particular illustrative embodiments, the invention is not limited to the above-described embodiments and various changes and modifications may be made by those of ordinary skill in the art without departing from the spirit and scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
5309258 | Kouno et al. | May 1994 | A |
5519401 | Farmer et al. | May 1996 | A |
5860925 | Liu | Jan 1999 | A |
5904652 | Gilbert et al. | May 1999 | A |
6125304 | Suzuki | Sep 2000 | A |
6151136 | Takemoto | Nov 2000 | A |
6279393 | McLaughlin | Aug 2001 | B1 |
6345117 | Klassen | Feb 2002 | B1 |
6408109 | Silver | Jun 2002 | B1 |
6778185 | Moroney | Aug 2004 | B1 |
6894806 | Woolfe et al. | May 2005 | B1 |
Number | Date | Country | |
---|---|---|---|
20040075852 A1 | Apr 2004 | US |