US 6873432 B1
A color printing/display system includes a representation for approximating color space transformation comprising a set of piecewise homeomorphisms for enhancing accuracy of parametric models associated with the homeomorphisms. The homeomorphisms and parametric models are selectively adjustable in accordance with printer/display calibrating data. Preferably the piecewise sub-spaces comprise corresponding simplices with domain and co-domain color spaces. The simplices are adjusted by calculating new locations for the vertices having a consequence of converging parametric model performance in accordance with the predetermined objective of the system.
1. A method of representing a transformation from a domain to a co-domain for a color reproducing device by constructing a piecewise set of invertable, functional approximations of the transformation, comprising steps of:
parameterizing the approximations;
generating an initial set of parameters for the approximations;
tessellating the domain and co-domain in accordance with the parameters for partitioning the domain and co-domain into corresponding sets of domain pieces and co-domain pieces;
assigning predetermined transformation data to the corresponding sets of domain pieces and co-domain pieces and computing respective, functional approximations comprising an invertable parametric model for the transformation data for each of the corresponding sets;
evaluating an accuracy of the respective approximations against a preselected objective representative of a desired accuracy of the transformation;
adjusting selected ones of the parameters for moving the evaluated accuracy to the desired accuracy; and,
selectively iterating said steps in accordance with the adjusted selected ones of the parameters until the evaluating satisfies a termination condition relative to the objective wherein the evaluated accuracy at least approximates the desired accuracy whereby the respective approximations cumulatively represent the transformation.
2. The method as defined in
3. The method as defined in
4. The method as defined in
5. The method as defined in
6. The method as defined in
7. The method as defined in
8. The method as defined in
9. The method as defined in
10. A method of determining a functional approximation of a transformation between color spaces of a desired color and a color printer wherein the color spaces are segregated into a plurality of sub-spaces and the transforming of data values between associated ones of the sub-spaces is represented by corresponding invertable parametric models, comprising the steps of:
selecting a set of parameters for determining the sub-spaces;
computing the corresponding invertable parametric model for each of the determined sub-spaces based upon predetermined sample data values;
assessing a performance of the parametric model against a preselected objective of the determining of the functional approximation; and,
adjusting the parameters for altering a mathematical representation of the sub-spaces and recomputing the parametric models until the assessing satisfies the preselected objective, whereby the corresponding parametric models cumulatively comprise the functional approximation.
11. The method as defined in
12. The method as defined in
13. The method as defined in
14. A color printing/display system including a representation for approximating color space transformation comprising a set of piecewise sub-spaces including invertable parametric models for enhancing an accuracy of the parametric models associated with the piecewise sub-spaces, wherein the piecewise sub-spaces and parametric models are selectively adjustable in accordance with printer/display calibrating data; and,
wherein the sub-spaces comprise corresponding simplices having corner and interior vertices within domain and co-domain color spaces, the simplices being selectively adjustable by calculating new locations for the vertices.
15. The color printing/display system as claimed in
The subject invention pertains to the art of color management and image/text printing or display systems, and is especially applicable to a method and apparatus for accurately representing color space transformations between input and output gamuts of a color reproducing device with invertable functional models. More particularly, the invention relates to algorithmically approximating the color space transformation with a set of parametric models each associated with a piecewise homeomorphism (PH) wherein the model may be readily inverted and sampled to yield a desired color rendition dictionary (CRD) for the device operation.
Color correction and/or control should not be confused with color registration systems and sensors for insuring that colors are positioned properly, printed accurately, superposed correctly and/or adjacent to one another.
Color perception is a psychological and physiological phenomenon that involves three elements: light, object and observer. Color changes as light, medium (i.e., paper, monitor) and observer interact. Color may be perceived differently under different types of lighting. Light sources that affect color include incandescent and fluorescent light. The first makes color seem more red and orange while the second emphasizes green and yellow tones. Different types of media also affect color perception. Observers view images on paper using reflection. In other cases the medium can be transmissive or emissive. Transparencies are an example of a transmissive medium while a computer monitor is emissive. The third element in the phenomenon is the observer. Different people may see the same color slightly differently. In order to characterize color image quality, the interaction of these elements must be understood so that when colors are intended to be matched, i.e., monitor to printer, scanner to printer, etc., acceptable appearance results.
For automatic control systems spectral data is often used to represent color perception as a pattern of wavelengths that leave the object before being interpreted by a viewer. Spectral data defines color independent of observer influence. Spectrophotometers and calorimeters are sensing devices used to measure spectral data.
There are different ways of representing color. One way color is described consists of the following parameters: hue, lightness and saturation. Hue represents the actual color wavelength (red, blue, etc.), lightness corresponds to the white content while saturation captures the richness or amplitude in color. Another way of describing color uses the three dominant primary colors red, blue and green (RGB). By combining these primary colors, in different intensities, most colors visible to humans can be reproduced. Monitors and scanners use the additive RGB color process. Printers use the subtractive CMYK (cyan, magenta, yellow and black) color process based on light reflected from inks coated on a substrate. To the extent that the color representations described above fail to reproduce color predictably, it is because they are observer or device dependent.
In today's business and scientific world, color has become essential as a component of communication. Color facilitates the sharing of knowledge and ideas. Companies involved in the development of digital color print engines are continuously looking for ways to improve the accuracy and total image quality of their products. One of the elements that affects image quality is the ability to consistently produce the same quality image output on a printer from one day to another, from one week to the next, month after month. Colors on a printer tend to drift over time. The variations arise from changes in the properties of the marking process (toner tribo, photoreceptor charge, transfer variations, temperature, humidity, and other marking and environmental factors). Maintaining an accurate printer operation requires regular recalibration, usually a time consuming, and accordingly undesirable task of sampling large numbers of test patches which are additionally interpolated to construct the CRD describing the printer transforming process. As electronic marketing has placed more importance on the accurate representation of merchandise in illustrative print or display media, consistent and accurate printer operation becomes more important, and regular recalibrating becomes more necessary.
Customers will usually specify their color demands in a device independent color space as part of a page description language (PDL). L*, a*, b* are the independent space representations of the CIE (Commission Internationale de L'éclairage) for color standards utilized in the functional modeling of these color demands. L* defines lightness, a* corresponds to the red/green value and b* denotes the amount of yellow/blue. Accurate transformation between L*, a*, b* representations and CMYK representations and vise versa are the principal applications of the subject invention.
When customers specify colors in device independent color coordinates, it is incumbent upon the printing/display device to determine which combination of available colorants (typically cyan, magenta, yellow and black) will yield the colors specified by the customer. This determination is frequently embodied in a look-up table (LUT) called the color rendition dictionary (CRD). Calculation of the CRD involves making patches in the printer's input space and examining the output thus yielding the forward transfer function which is then inverted to give the recipes for making the colors available in the printer's gamut.
These recipes are typically formulated using a large number of sampled data patches that are then interpolated to describe the transformation between the input and output spaces of the printing device. Because of the nature of the printer, these recipes are non-linear, time varying functions and thus are prone to inaccuracies if not updated at least occasionally. The updating process is tedious for customers and service representatives and is thus performed infrequently. If the process could be streamlined, it might be performed more frequently leading to improved color accuracy. With proper color calibration, customers could specify colors at document creation time and have an increased assurance that the printed colors would “match” (i.e. appear similar to) the desired colors.
The input space (domain) describes all the possible ways of mixing the three printer colorants (for example, cyan, magenta, and yellow but many other triplets are possible.) Typically the halftone density of a colorant is specified by an 8 bit integer (a whole number between 0 and 255). For the 3-space of inputs, the domain of the transformation consists of a three dimensional cube, 255 units on a side with one corner at the origin. The co-domain space of the transformation is the color gamut of the printer, the three dimensional volume that indicates all the L*, a*, b* values which are accessible by mixing the three colorants. This co-domain volume is of irregular shape and represents a sampled non-linear function of the input space. Since customers specify their desired colors in this space, the problem is to accurately print/display them and therefore derive the reverse transformation by inversion of the functional relationship between the domain and co-domain spaces detailed above.
No accurate functional representation of this transformation exists. The situation is complicated by the fact that the relationship between the digital inputs (domain) and the color outputs (co-domain) of the printer is not fixed for all time. If it were, the calibration could be performed once and always yield correct results. The variations in the appropriate calibration are due to variations in the printer's transfer function. Thus the transformation is at the same time non-linear (it requires a complex representation) and dynamic (varying in time).
On-line model prediction is also known as “system identification” in automatic controls literature. It is the terminology used for the process of characterizing a given system under control. Characterization of the system can be done in two ways; non-parametric and parametric. In non-parametric system identification, the profile of the device can be measured by printing specific target colors as specified by the ICC standards. This profile is used as it is (without constructing any model of the device) while making rendering decisions/viewing of the customer colors on the monitor. This is a one time measurement and does not use the historical information to construct any model. Whereas in the parametric system identification, target colors can be printed part of the banner sheet/header sheet or else the target colors can be extracted from the customer image and measured either by measuring straight from the output image or by rendering a subset of customer colors as target color patches. The intention in the parametric system identification is to adjust the parameters of the model and refine it over time by using past and present color data so that the model is accurate.
There is a continuing need for improved on-line modeling and convenient calibrating of color printing devices. Current needs are better served with model processing in a way that accurate parameters of a parametric model can be quickly identified through an interactive computation scheme. By “homeomorphism” in the context of this subject invention is meant the properties of the functions that are chosen to describe the transformations between sub-spaces in corresponding domains and co-domains where a particular parametric model defines the transformation from a domain value to a co-domain value. The homeomorphic transformations concerning a color marking device operation comprise the transformation function for data value conversion between the domain and co-domain. The subject invention deals with altering the defining boundary space of each of a set of sub-spaces, so that the parametric models associated with each sub-space are varied to a set which cumulatively most accurately estimates the non-linear printer transforming process, and further can be updated or recalibrated much more easily than could be done in the past.
The subject invention exploits a key enabling factor for these operational advantages by constructing and maintaining a current model of the reproducing device operation (also known as the device profile or characteristic, input-output model of reproducible color). The new and improved method constructs a dynamic model by segregating color spaces into a set of homeomorphisms each having an associated parametric model. When a customer has a need to accurately match the colors displayed or printed on various output devices, such as monitors (CRT, LCD, etc.) and printers (xerographic, ink jet, ionographic, etc.), he/she can recalibrate the existing model with a minimal number of new data patches and avoid having to build an entire new model and corresponding CRD.
In accordance with the present invention, there is provided a method and apparatus for determining an invertable functional approximation of a transformation between color spaces of a color printer. The color spaces are segregated into a plurality of sub-spaces and the transforming of data values between associated sub-spaces is represented by corresponding parametric models. The identification of the best choice for these sub-spaces is determined by first selecting a set of parameters effectively defining the number of these sub-spaces which will comprise the input and output color space domains. In the preferred embodiment in three dimensions the sub-spaces comprise tetrahedra. The transformation of data values between an input sub-space and the corresponding output sub-space is first estimated by computing an invertable functional parametric model of the transforming process based upon a set of predetermined sampled data values. The parametric model then gives estimates of the output values in the co-domain for each given input value in the domain. The performance of the initial set of parametric models is assessed against a preselected objective function, such as minimal error between the predetermined data and the estimate from the parametric model. The assessment will usually indicate that an adjustment of the tetrahedra, i.e., a relocating of boundary points defining the space for each tetrahedra, will facilitate better and more accurate functional parametric models. In other words, the tetrahedra are relatively arranged so that the parametric models associated with each tetrahedron individually are designed to more accurately represent the transformation of a sub-space contained by a tetrahedron. Taken collectively then, the cumulative configuration of tetrahedra describe an improved and more accurate representation of the color transforming process.
In accordance with another aspect of the present invention, the assessing the performance of the estimation comprises minimizing a mean squared error of the approximations, forcing continuity across the tetrahedra or minimizing a maximum approximation error between the approximations and the predetermined transformation data.
In accordance with another aspect of the present invention, the adjusting the parameters for the sub-spaces comprises recomputing different locations for vertices of the tetrahedra within the color space until a predetermined termination condition for the adjusting occurs. Such a termination condition can comprise defining a minimum total step distance for the adjusting, a minimum of the mean squared error for the approximations or maximum number of adjusting steps.
In accordance with the present invention, a color printing/display system is provided which includes a representation for approximating color space transformation comprising a set of piecewise homeomorphisms configured for enhancing an accuracy of parametric models associated with the homeomorphisms, wherein the homeomorphisms and parametric models are selectively adjustable in accordance with printer/display calibrating data. In the preferred embodiment in 3 dimensions the homeomorphisms comprise corresponding tetrahedra having vertices within domain and co-domain color spaces. The tetrahedra are selectively adjustable in configuration by calculating new locations for the vertices. The tetrahedra configurations are adjusted until the parametric models associated with the tetrahedra are cumulatively a more accurate estimation of the printing/display color space transformation process. Recalibration over time can be effected by merely sampling tetrahedra vertices data values—a greatly reduced number than what is required for an operational LUT.
One advantage obtained by use of the present invention is an algorithm and process for estimating a functional representation of the transformation process between color spaces.
Another advantage of the subject invention is that the functional representation is adjustable and can automatically converge to a better estimation in accordance with the predetermined objective criteria for the representation process.
Another advantage of the subject invention is that after the piecewise homeomorphisms are adjusted to an acceptable set, a recalibration of the printing/display device can be affected with a lesser number of sampled test patch data values.
Other benefits and advantages for the subject new methods and systems will become apparent to those skilled in the art upon a reading and understanding of this specification.
The invention may take physical form in certain parts and steps and arrangements of parts and steps, the preferred embodiments of which will be is described in detail in the specification and illustrated in the accompanying drawings, which form a part hereof and wherein:
Referring now to the drawings wherein the showings are for purposes of illustrating the preferred embodiments of the invention only and not for the purposes of limiting same, the figures show a method and apparatus for generating a parametric model of a color reproducing device color transforming process comprising a set of piecewise homeomorphisms. The invention has principal and practical applications in a color printing system where a customer is desirous of a readily recalibratable system requiring minimal time for the recalibration process in a convenient manner. Both the model and homeomorphisms are intended to be updated over time for recalibration of the system.
The subject invention deals with complex multi-dimensional mathematical representations of a physical process of converting an input signal defining a desired color into an accurate printing of that color. As noted above, the representation of the process is both complex and dynamic. With reference to
With reference to
Corresponding tetrahedra must also be assigned to the co-domain space. For the cubic input domain of CMY space the eight points assigned to the co-domain cube will also be vertices of the tetrahedra partitions that fill the domain space. The domain space is either completely filled or enclosed by the tetrahedral sub-spaces. The remainder of the chosen points will also be vertices that will be assigned to the interior or some end wall of the cube. The parameterization step essentially determines how many vertices are chosen to represent the input domain. It must also be kept in mind though, that the corresponding tetrahedra in the co-domain or output space (L*, a*, b* ) which is, as noted above, not normally cubic, will enclose the co-domain. More importantly, the transforming of data values from the input domain to the output co-domain is nonlinear so that any linear, invertable approximation will not be completely accurate. However, it is a feature of the invention that each set of corresponding tetrahedra will have a parametric linear or non-linear model that will define a transformation process.
After the degree of parameterization is chosen, an initial definition of the coordinate positions of the interior vertices is generated 42. As will be later appreciated, the actual initial conditions will not be optimal and the convergence process is designed to effect the best available representation using the given parameterization. Accordingly, the generation step merely requires some definition of coordinates in the domain and co-domain for the tetrahedral vertices within the corners of the domain cube.
Tessellation 44 comprises defining the domain and co-domain volumes into a plurality of tetrahedra with a standard tessellation protocol program. Such a known program is a Delaunay tessellation, but of course other choices are possible. The objective of tessellation is to take the vertices defined by the parameterization step and connect them into tetrahedra so that the sub-spaces are defined. Ideally, the tessellation program not only deals with uniform tessellation of the domain and co-domain spaces but also may acknowledge a nonuniform distribution of data within the domain and co-domain spaces. The tessellation in the domain is the same as the tessellation in the co-domain in that the domain tessellation is translated to the co-domain tessellation. The tessellation must fill or enclose the domain space leaving no region uncounted.
Assigning 46 data points to the tetrahedra comprises assigning predetermined transformation data obtained from a large number of sampled test patches to corresponding domain and co-domain tetrahedra. The transformation data is acquired by specifying many input values, printing the values as color patches and reading the corresponding output value coordinates of the output color in the co-domain space. Such acquisition of sample data is similar to prior art calibration methods used for building an LUT and a conventional CRD. The data values are then assigned to the tetrahedra by determining which tetrahedron encloses the data point in the domain and co-domain. Known computational geometric techniques are available for determination of which points are in which tetrahedral volumes.
The transformation process of a set of data values within a domain tetrahedron to corresponding output data values in the co-domain space is approximated with a functional parametric model, for example for a linear approximant, mathematically represented by
where y represents the co-domain data value, x represents the domain value, A is the conversion matrix and b is the compensating offset value. Such a linear approximation will of course have some inaccurate representations of the transforming process, just as the individual segments illustrated in
An objective function must be assigned to the performance of the cumulative set of functional models. For example, if the objective were that the functional models are exactly accurate with the predetermined transformation data, i.e., no error, then an objective function would measure the error between the models and the actual data. The least squares analysis above is such an objective function for error minimization. Other objectives could be chosen such as forcing continuity across the tetrahedra or minimizing the maximum approximation error. Of course other objectives are also possible. In any event, the error or discrepancy between the performance of the parametric model, and the actual test data value can be used as an important criterion for determining if the PHs should be altered for purposes of achieving a new and more accurate PH better satisfying the selected objective for the system. More particularly, for the subject embodiment, new vertex locations can be calculated 50 for the corresponding tetrahedra. Each vertex serves as a corner of some number of tetrahedra. Moving the vertex to a new location may better achieve the objective. One way to effect such moving is by calculating the average A matrix parameters and b vector parameters over the tetrahedra in which the vertex participates. These values are then used to determine a new value of the vertex position that will accordingly change the parametric model for that particular domain and co-domain tetrahedron set. This particular calculation scheme for adjusting vertex locations is particularly useful because using the average A and b values encourages continuity across the piecewise linear volumes, an important factor in color rendition. The other predetermined objects, noted above, could also be used individually or in combination for selectively moving the vertex points. The new vertex location effects a changing of the tetrahedron, and consequent redefinition of the parametric model based upon the change in data values within the tetrahedral volume. The new models which when compared against the objective function, will determine if yet another iteration 52 of the subject algorithm, and consequent adjusting of the tetrahedral sets, is appropriate until convergence is achieved wherein the cumulative set of parametric models best satisfy the objective in approximating the device transformation process. In other words, the algorithm will iterate 52 until some predetermined set of convergence criteria is met. Such criteria may include a minimum total step distance covered by all the interior grid points, a mean squared error for the approximation or a maximum number of iterations. In addition, the motion of the vertices may have resulted in a mesh tangle. In this case, the iteration also requires retessellation to resolve the mesh tangle but, of course, alternatively, a retessellation may occur in each iteration anyway.
The result of this algorithm is a piecewise representation of the transformation that minimizes some objective function—the one used to determine vertex motion in step 50. With this function in hand an assessment of the precision of the approximation may be made by examination of the errors between the approximation and the data values taken during the initial data collection. If the approximation meets the application's requirements, the sequence terminates. If not, additional parameterization is performed and the sequence begun again but omitting the data collection exercise.
The subject representation of the transformation process with a PH is particularly useful for recalibrating of device operation with minimal supplemental test data values. After initial thorough calibration of such a device, adjustments to compensate for the time variation of a printer may be characterized using less than 100 readings (typically 50 or less). The invention proposes an algorithmic method for choosing these points and also a means to determine how many are necessary to achieve a desired accuracy. For example, one could recalibrate with only the newly positioned tetrahedral vertices.
The typical full calibration exercise is performed by printing 1000 or more test patches using known values of the domain coordinates. The prior art describes printer calibration methods using many data points. When a recalibration is required because of the time varying nature of the printing process, this tedious procedure must be performed again and frequently the tedious procedure is omitted with the consequent errors in the color printing process. This greatly reduced parameterization method reduces the recalibration procedure to specifying a small number (less than 50) domain coordinate values to be printed and read. Once this greatly reduced effort is completed, the interpolation process proceeds to use the transformations obtained using the techniques of the present invention to calculate the recipes for forming all the colors that may be requested with more accuracy than what would have occurred if the recalibration had not been performed. The resulting improvement in color printing accuracy is insured by the simplicity of the recalibration process.
This method has been shown to converge for many actual test cases. Test data cases where the “calibration” data are in fact piecewise linear with known parameters have been tried to exercise the algorithm. Small and large nonlinearities have been tested. Both single and multiple interior vertices have been tried. Multiple, widely spaced initial conditions converge to the same point. Noise in the data (up to is accurately dealt with and the algorithm still achieves the same terminal values—equal within round-off error to the known correct ones. Even when the tessellation for the approximant is different from that under which the data were generated, the algorithm converges to the neighborhood of the correct answer. Current work includes cases of continuous functions and multiple interior vertices. Color calibration data have likewise been tried with success.
The invention has been described with reference to the preferred embodiments. Obviously, modifications and alterations will occur to others upon the reading and understanding of the specification. It is my intention to include all such modifications and alterations in so far as they come within the scope of the appended claims or the equivalents thereof.