Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
GENERATION OF HALFTONE PARAMETERS
Document Type and Number:
WIPO Patent Application WO/2018/063349
Kind Code:
A1
Abstract:
A method of generating a set of halftone parameters. The method comprises assigning a first set of halftone parameters to a first location in a color space, the first location in the color space corresponding to a first color, and assigning a second set of halftone parameters to a second location in the color space, the second location in the color space corresponding to a second color. An interpolating between the first set of halftone parameters and the second set of halftone parameters is performed, based on the first location and the second location, to determine a third set of halftone parameters corresponding to a third location in the color space. The result of the interpolation is output data associating the third set of halftone parameters with a third color corresponding to the third location in the color space. The first set of halftone parameters may represent a relative area coverage of a first colorant combination and the second set of halftone parameters may represent a relative area coverage of a second colorant combination.

Inventors:
MAESTRO GARCIA JAVIER (ES)
MOROVIC PETER (ES)
MOROVIC JAN (GB)
Application Number:
PCT/US2016/054849
Publication Date:
April 05, 2018
Filing Date:
September 30, 2016
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
HEWLETT PACKARD DEVELOPMENT CO (US)
International Classes:
H04N1/405
Domestic Patent References:
WO2016066202A12016-05-06
WO2015161898A12015-10-29
Foreign References:
US7304770B22007-12-04
US20160080612A12016-03-17
EP1787811A22007-05-23
EP1507404A12005-02-16
Other References:
KUO YAN-FU ET AL.: "Model-Based Calibration Approach to Improve Tone Consistency for Color Electrophotography", JOURNAL OF IMAGING SCIENCE AND TECHNOLOGY, vol. 55, no. 6, 2011, pages 1 - 9, XP055501222
Attorney, Agent or Firm:
GARDINER, Austin W. et al. (US)
Download PDF:
Claims:
CLAIMS

What is claimed is:

1. A method of generating halftone parameters, the method comprising: assigning a first set of halftone parameters to a first location in a color space fie first location in the color space corresponding to a first color;

assigning a second set of halftone parameters to a second location in the color space, the second location in the color space corresponding to a second color;

interpolating between tie first set of halftone parameters and the second set of halftone parameters, based: on the first location and the second location, to determine a third set of halftone parameters corresponding to a third locaion in the color space; and

generating output data associating the third set of halftone parameters with a third color, the third color corresponding to the third location in tie color space:

wherein the first set of halftone parameters represents a relative area coverage of a first colorant combination and the second set of halftone parameters represents a relative area coverage of a second colorant combination.

2. The method of claim 1 , wherein the color space corresponds to an image color space.

3. The method of claim 1 , wherein:

the first set of halftone parameters comprising a first area coverage coefficient associated with a combination of colorants;

the second set of halftone parameters comprises a second area coverage coefficient associated with the combination of colorants; and the third set of halftone parameters comprises a third area coverage coefficient associated with toe combination of co!orants.

4. The method of claim 3, wherein interpolating between the first set of halftone parameters and the second set of halftone parameters comprises: interpolating between the first area coverage coefficient and the second area coverage coefficient to determine the third area coverage coefficient, based on the first location, the second location and the third location.

5. The method of claim 1 , wherein:

the first set of halftone parameters comprising a first area coverage coefficient associated with a first combination of colorants;

the second set of halftone parameters comprises a second area coverage coefficient associated with a second combination of colorants: and the third set of halftone parameters comprises a third area coverage coefficient associated with a third combination of colorants.

6. The method of claim 5, wherein interpolating between the first set of halftone parameters and the second set of halftone parameters comprises: converting the first set of halftone parameters to a first set of colorant quantities based on the first area coverage coefficient and the first combination of colorants:

converting the second set of halftone parameters to a second set of colorant quantities based on the second area coverage coefficient and the second combination of colorants; and

interpolating between the first set of colorant quantities and the second set of colorant quantities to determine a third set of colorant quantities based on the first location, the second location and the third location.

7. The method of claim 6, comprising: determining the third area coverage coefficient and the third combination of coiorants based on the third set of coiorant quantities.

8. The method of claim 1 , wherein the first location corresponds to a irst vertex in the coior space and the second location corresponds to a second vertex in the coior space.

9. The method of claim 1 , wherein the first location and the second location are located on an edge of the coior space.

10. The method of claim 1 , wherein the first location corresponds to a gray coior in the color space and the second location corresponds to a vertex of the color space, wherein interpolating between tie first set of halftone parameters and the second set of halftone parameters comprises:

reducing the relative area coverage of the first colorant combination to produce a reduced relative area coverage of the first coiorant combination: reducing the relative area coverage of the second colorant combination to produce a reduced relative area coverage of the second colorant

combination: and

combining the reduced relative area coverage of the first coiorant combination and the reduced relative area coverage of the second coiorant combination to produce the third set of halftone parameters.

11. The method of claim 10, wherein, in combination, the reduced relative area coverage of the first colorant combination and the reduced relative area coverage of the second coiorant combination correspond to a colorant limit which specifies the maximum quantity of colorant that can be deposited at a pixel in the halftone.

12. Tbe method of claim 1 , vstfierein int^oSating between the first set of halftone parameters and the second set of halftone parameters is performed based on a Delaunay tessellation.

13. The method of claim 1, wherein the output data comprises a iook-tsp table associating the third set of halftone parameters with the third color corresponding to the third location in tie color space.

14. The method of claim 1 , comprising: using the output data in a color separation process of a printing pipeline.

15. A non-transitory computer-readable storage medium comprising computer-executable instructions which, when executed by a processor, cause a computing device to:

assign a first color space vector to a first location in an image color space, the first location m the image coior space corresponding to a first color; assign a second coior space vector to a second location in the image color space, the second location in the image color space corresponding to a second color

interpolate between the first color space vector and the second color space vector, based on the first location and the second location, to determine a third coior space vector corresponding to a third location m the image coior space:

generate output data associating the third coior space vector with a third coior, the third coior corresponding to the third location in the image coior space;

wherein the first coior space vector defines a first probability distribution for one or more colorant combinations and the second coior space vector defines a second probability distribution for the ore or more coiorant

combinations.

16. A computing device comprising:

a processor, and

a memory storing computer-executable instructions which, when executed by the processor, cause the computing device to:

interpolate between a first set of parameters and a second set of parameters, based on a first iocation in a color space and a second location in the color to determine a third set of parameters corresponding to a third location in the coior space, wherein the first location in the color space corresponds to a first coior, the second iocation in the coior space corresponds to a second color and the third iocation in the coior space corresponds to a third coior; and

generate output data associating the third set of parameters with the third color;

wherein the first set of parameters represents a first probability distribution for one or more materia! combinations and the second set of parameters represents a second probability distribution for the one or more materia! combinations.

Description:
GENERATION OF HALFTONE PARAMETERS BACKGROUND

[0001] A printing system may be associated with a color space (hereinafter termed a "colorant co!or space"), defined by one or more colorants available to the printing system for deposition or application to a print medium. An example of a colorant color space is the Cyan, Magenta, Yeliow, BiacK {CMYK) color space, wherein four variables are used in a subtractive color model to represert respective quantities of colorants. Examples of colorants include inks, dyes, pigments, paints, toners and powders.

BRSEF DESCRIPTION OF THE DRAWINGS

[0002] Various features and advantages of the present disclosure will be apparent from the detailed description which follows, taken in conjunction with the accompanying drawings, which together illustrate, by way of example only, features of the present disclosure, and wherein:

[0003] Figure 1A is a schematic diagram showing a first coior space in accordance with an example.

[0004] Figure 1B is a schematic diagram showing an NP area coverage (NPac) vector in accordance with an example.

[0005] Figure 2 is a flow diagram showing a method of gerserati ng a set of halftone parameters in accordance with an example.

[0008] Figure 3 is a flow diagram showing a method of generating a set of halftone parameters in accordance with an example.

[0007] Figure 4 is a flow diagram showing a method of interpolating between a first set of halftone parameters and a second set of halftone parameters in accordance with an example. [0008] Figure 5 Is a schematic diagram stewing a technique for converting a colorant quantity to an NPac vector in accordance with an example.

[0009] Figure 6 is a flow diagram showing a method of converting a co!orant quantity to an NPac vector in accordance with an example.

[0010] Figure 7 is a schematic diagram showing a technique for generating an NPac vector in accordance with an example.

[0011] Figure 8 is a schematic diagram showing a method of generating an NPac vector in accordance with an example.

[0012] Figure 9 is a schematic diagram showing a printing system in accordance with an example.

DETAILED DESCRfPTSON

[0013] A printing system may utilize a halftoning process to reproduce a continuous tone image in the colorant color space using a series of shapes (e.g. dots). This enabies the printing system to approximate a continuous tone image by using a discrete number of colorant levels (e.g. a discrete number of ink drops). The result of this process is an output In ' the form of a color separated halftone comprising a halftone plane corresponding to each colorant available to the printing system. The output of any particular printing system is dependent on the characteristics of the particular color halftone processing pipeline that is used by the printing system.

[0014] The colorant content of a print resolution pixel (hereinafter termed

"pixel") may be defined In terms of a Meugebauer Primary (NP) vector, which specifies a combination of colorants to be deposited at a pixel iocation in a deposition process to produce the desired color for the pixel. Each element of an NP vector may specify a quantity of a respective coiorant for the associated pixel in the coiorant space. For example, an NP vector of [2 1 0 0] defined in a CMYK colorant space specifies a pixel comprising two units (e.g. two drops) of cyan colorant and one unit {e.g. one drop) of magenta colorant

[0015] According to some print processes, the halftone may be printed or formed on the print medium in a plurality of deposition orapplcaiion stages. For example, the halftone may be printed using a plurality of static print bars, which print to a movable print medium in at least one print pass, or a plurality of passes of a static print medium, performed by a moveable head unit. Typica!iy, tie maximum colorant quantity that can be deposited at a pixel in a given print process is limited by the number of deposition stages for tie given print process.

[0016] in the following description, for purposes of explanation, numerous specific details of certain examples are set forth. Reference in the description to "an example" or similar language means that a particular feature, structure, or characteristic described in connection with the example is included in at least that one example, but not necessarily in other examples.

[0017] Image date may comprise color date represented in a first color space (hereinafter termed an 'Image color space"), such as image-level pixel representations in a RGB (red, green, blue) color space. 6i a printing pipeline, a color separation process may be used to map from the image color space to a second color space (hereinafter termed an "intermediate color space") for use in a halftoning process.

[0018] in some examples, the intermediate color space may be an area coverage space, such as the Neugebauer Primary area coverage (NPac) color space. An NPac vector in the NPac cotor space represents a statistical distribution of one or more Neugebauer Primary (NP) vectors over an area of a halftone. In other words, each NPac vector defines the probability distribution for one or more colorant combinations for each pixel in the halftone (e.g. a likelihood that a particular colorant combination is to be placed at each pixel location in the halftone), in this manner, a given NPac vector defines a set of halftone parameters that are used in ins halftoning process to map a color defined In fie image color space to one or more HP vectors to be statistically distributed over the plurality of pixels for a halftone. Moreover, tie statistical distribution of MPs to pixels in the halftone serves to control the colon metry and other print characteristics of the halftone.

[0019] Spatial distribution of the NPs according to the probability distribution specified in the NPac vector may be performed using any suitable halftoning methods as is known in the art. In this respect, examples of suitable halftoning methods include matrix-selector-based PARAWACS (Parallel Random Area Weighted Area Coverage Selection) techniques and techniques based on error diffusion. An example of a printing system that uses area coverage representations for halftone generation is a Halftone Area Neugebauer Separation (HANS) pipeline.

[0020] in some examples, the color separation process may utilize a data structure which stores a pre-computed mapping from a color defined In the image color space to a set of parameters defined in the intermediate color space. For example, the pre-determined mappings may be stored in a look-up table which is referenced by the color separation process to map torn the image color space to the intermediate color space. this respect, determination of the pre-computed mappings may be a complex and time consuming process due to the dimensionality of the intermediate color space. For example, where the intermediate color space is an NPac color space, the corresponding dimensionality is defined by the total number of UP states that are available for a given printing system, which in some cases may be in the order of 100,000 states or more. Accordingly, manual pre-caiculation of mappings for population of the data structure for such printing systems is often impractical and pre-calculafjon of mappings based on simulations of the printing system may require sophisticated computational models which are often prohibitively complex. [0021] Accordingly, certain examples described herein provide techniques for generation of a data structure providing mappings from the image color space to the intermediate color space. In particular, certain examples described herein provide techniques for generating data associating a color defined in the image coior space with a set of halftone parameters defined in the intermediate coior space, for use in a coior separation process.

[0022] Certain exampies described herein utilize an interpolation process in the intermediate color space to determine the set of halftone parameters corresponding to the particular color designated in the image color space, in some exampies, the set of halftone parameters represents a relative area coverage of a colorant combination corresponding to the particular coior designated in the image color space.

[0023] Figure 1 is a schematic diagram showing a first coior space 100 (hereinafter termed an "image color space") in accordance with an example. In this example, the image coior space 100 is an RGB color space which is represented as a cube in a three dimensional space, in other examples, the image color space may be a CMYK color space, which is represented as a hypercube in four dimensional space. The vertices of the cube correspond to the primary colors (red, green, blue) and secondary colors (cyan, magenta, yei!ow) for the RGB color space, in addition to white and black.

[0024] In this example, the RGB coior space is defined as a 24-bit color space. Thus, each color in the RGB color space is defined by a vector (X, Y, Z) where each of X, Y and Z take an 8-bit integer value in the range 0 to 255. Accordingly, black is defined as (0, 0, 0), white is defined as (255, 255, 255), red is defined as (255, 0, 0), green is defined as (0, 255, 0), blue is defined as (0, 0, 255), yellow is defined as (255, 255, 0), magenta is defined as (255, 0, 255) and cyan is defined as (0, 255, 255). [0025] An initial set of NPac vectors are assigned to colors (I.e. locations) deined in the RGB color space 100. For example, the initial set of NPac vectors may be assigned to fie vertices of the RGB color space 100. mis assignment may be performed manually, based one or more empirical measures of printing quality, such as cotorimetry, grain and/or coalescence. Once tie initial set of NPac vectors have been assigned to locations in tie RGB coior space 100, an interpolation process is performed to determine a further mapping for a particular color defined in the image color space by preforming a spatial interpolation in tie NPac coior space from two or more NPac vectors in the initial set of NPac vectors to a location corresponding to the particular coior. For example, an NPac vector corresponding to a coior defined in the image color space at a location 102 may be determined by a spatial interpolation between the NPac vectors defined for the blue and magenta vertices to the location 102. This process may be repeated for a plurality of different locations in the image coior space, to thereby populate a data structure for use in the color separation process.

[0026] Figure 1B is an example of an NPac vector 110 resulting from the interpolation process discussed above, fn this example, the NPac vector 1 10 defines a spatial distribution of NPs for a halftone corresponding to a CMYK colorant space, wherein 25 percent of the pixels are assigned a CCivl (i.e. two cyan and one magenta) NP (defined by first element 1 12-1), 25 percent of the pixels are assigned a CC (i.e. two cyan) NP (defined by second element 112-2), and 50 percent of the pixels are assigned the CY (i.e. one cyan and one yellow) NP (defined by third element 1 12-3). in this manner, the NPac vector 1 10 specifies a set of halftone parameters which control generation of a halftone.

[0027] Figure 2 is a flow diagram showing an example of a method 200 of generating a set of halftone parameters for a halftone. At block 202, input data specifying a first set of halftone parameters for a first coior in an image color space and a second set of halftone parameters for a second color in the image coior space is received. At block 204 the first set of halftone parameters is assigned to a first locators in the image color space corresponding to the first color, arid at block 206 fie second set of halftone parameters is assigned to a second location in the image color space corresponding to the second color. As discussed above, the correspondence between a given set of halftone parameters and a location in the image coior space may be determined manuaiiy based on one or more empirical measures of printing quality, such as colorimetry, grain and/or coalescence. At block 208, an interpolation between the first set halftone parameters and the second set of halftone parameters is performed, based on the first location and the second location, to determine a third set of halftone parameters corresponding to a third location in the image color space. This interpolation process results in a mapping between a third color corresponding to the third location in the image color space and the third set of halftone parameters determined in the interpolation process. At block 210, output data associated the third set of halftone parameters with the third coior is generated for subsequent use in a color separation process in a printing pipeline.

[0028] In some examples, first and second colors received in the input data in block 202 may be defined in the RGB image coior space 100 of Figure 1A.

Similarly, the first and second sets of halftone parameters received in the input data in block 202 may be defined in the NPac intermediate color space, as discussed above with reference to Figures 1A and 1B.

[0029] The method 200 described above wits reference with Figure 2 may be repeated to determine mappings between a plurality of colors defined in the image space and corresponding sets of halftone parameters in the intermediate color space. In this manner, a data structure for use in a color separation process, such as a look-up table, may be populated in a relatively straightforward manner.

[0030] The assignment of the first and second sets of halftone parameters to locations in the image color space at blocks 204 and 206 of Figure 2 serve as initial color mappings for "seeding" the interpolation process. For example, the first and second sets of halftone parameters may correspond to colors defined by the vertices of the image color space. In furfier examples, acfditlonai initial color mappings may be defined to provide additional data points forihe interpolation process, thereby ensuring smooth interpolation within the intermediate color space. The additional initial color mappings may correspond to locations on one or more edges in the image color space, one or more diagonals in ire image color space, one or more internal locations in tie image color space, or any combination thereof.

[0031] Figure 3 is a How diagram showing an example of a method for defining a plurality initial mappings for seeding the interpolation process. In biock 302, one or more initial mappings are defined for one or more vertices of the image color space. In block 304, one or more initial mappings are defined for locations on one or more coior-to-coior edges in the image color space, in biock 306, one or more initial mappings are defined for locations on one or more vvhite- to-co!or edges and diagonals in the image color space. At block 308, one or more initial mappings are deined for locations on the biack-to-white diagonal in the image color space. At block 310, one or more initial mappings are defined for location on the one or more black -to-color edges and diagonals in the image color space. At biock 312, one or more initial mappings are defined for any additional locations of interest in the image color space. Once all initial mappings have been defined, an interpolation process is performed at block 314, based on the initial mappings deined in blocks 302 to 312, to determine mappings for other locations in the image coior space, and thereby populate the data structure for use in the color separation process. In some examples, one or more of blocks 302, 304, 306, 308, 310 and 312 may be omitted or tie order of the blocks may be varied, indeed, according to some examples, only a set of initial mappings corresponding to the vertices of the image coior space may be defined at block 302 for interpolation at block 314.

[0032] According to certain examples, the interpolation process in block 302 may be implemented using a technique that supports an irregular distribution of the initial mappings. For example, a Delaunay tessellation in two steps may be used. Moreover, to avoid the creation of an irregular 3D tessellation in the image color space, a 2D Delaunay interpolation may be performed in tie three pianes delimited by black, white, and two complementary vertices, namely: black- white-red-cyan, biack-white-blue-yeiiow, and biack-wN te-green-magenta . This approach provides a finer sampling Inside the image color space, thereby ensuring that a 3D tessellation is possible without generation of artifacts.

[0033] According to certain examples, the interpolation process in block 302 may be performed in a domain corresponding to the intermediate coior space (e.g. the NPac coior space). Moreover, the interpolation may be performed in a linearized domain that is gamma-corrected to account for particular perceptual non-uniformities along each axis of the domain. The Interpolation may utilize a linear interpolation technique or a higher order technique where a sufficient number of initial mappings are available.

[0034] Figure 4 is a flow chart showing a method 400 of interpolating between a first set of halftone parameters and a second set of halftone parameters in accordance with an example. In this example, the first set of halftone parameters comprises a first area coverage coefficient associated with a particular combination of colorants and the second set of halftone parameters comprises a second area coverage coefficient associated with the particular combination of colorants, in some examples, the first and second area coverage coefficients correspond to the elements of NPac vectors associated with a particular combination of colorants (I.e. a particular NP vector). According to this method 400, the first and second coefficients for the particular colorant combination are received as initial mappings at block 402. At block 404, an interpolation between tie first and second coefficients in the image color space is performed to determine a coefficient corresponding to a third location in the image coior space. At this point, the method determines whether the first and second sets of halftone parameters include further coefficients associated with any other colorant combinations at block 406. If further coefficients are present, the method 400 repeats blocks 402 arid 404 for the further set of coefficients. In this manner, the method 400 interpolates between coefficients corresponding to every colorant combination associated with the irst and/or second sets of haiftone parameters. Once this process has been completed, the method 400 outputs the one or more interpolated coefficients in the form of a third set of halftone parameters (e.g. a third NPac vector) corresponding to the third location in the image coior space, at block 408.

[0035] A characteristic of the method 400 shown in Figure 4 is that the third set of haiftone parameters resulting from the interpoiatson process is limited in structure to tie colorant combinations associated with tie first and second sets of haiftone parameters. For examples where the haiftone parameters are defined as NPac vectors, this means that ire NPac vector corresponding to the third color may only include NPs that are included in tie NPac vectors defined for one or both of the first and second colors. Thus, the method 400 provides limited controi over the structure of the colorant combinations resulting from the interpolation process.

[0036] in some examples, interpolation between the first and second sets of halftone parameters may be performed in a colorant quantity domain, rather than the cobra nt combination domain. According to such methods, the first and second sets of halftone parameters are converted to colorant quantities, on the basis of which an interpolation process is performed. The result of this process is an interpolated ink quantity corresponding to the third color, and the interpolated ink quantity must be converted back into a set of halftone parameters, such as an NPac vector.

[0037] Figure 5 is a schematic diagram showing a technique 500 for converting a set of interpolated colorant quantities 502 into a set of halftone parameters 512. Specifically, Figure 5 shows conversion of the set of interpolated coiorant quantities 502 into an NPac vector. In fills example, the interpolated ink quantities are 1.5 C, 0.5 Y, 0.25 M, which correspond to the average colorant quaniii.es per-pixei for a halftone. The interpolated colorant quantities are "layered" into a theoretical print. ceil 504 corresponding to a pixel in the halftone, tn some examples, tie interpolated colorant quantities are layered into the theoretical print ceil in a predefined colorant order (e.g. G, M, Y, K), as shown in Figure 5. The result of this operation is a plurality of coiorant layers in the theoretical print cell that can be divided into discrete "stacks" 506, 508 and 510. For example, the discrete stacks may be determined based on the boundaries that arise within each layer when the ink quantities are placed in the theoretical print cell {e.g. the boundary between stack 506 and stack 508 is created in the middle layer, and the boundary between stack 508 and stack 510 is created in the top layer). Each stack represents a particular colorant combination (i.e. MP vector) and the relative width of each stack indicates the relative area coverage for the respective colorant combination the corresponding halftone. In the present example the first stack 506 corresponds to a CY colorant combination with 50 percent area coverage; the second stack 508 corresponds to a CC coiorant combination with 25 percent area coverage; and the third stack 510 corresponds to a CCM coiorant combination with 25 percent area coverage. Thus, the result of this layering process is an NPac vector 512 with value [0.5 CY, 0.25 CC, 0.25 CCM] as shown in Figure 5. In other words, the interpolated ink quantities are converted into an NPac vector which specifies that 50 percent of the pixels in the halftone should comprise CY colorants, 25 percent of the pixels in the halftone should comprise CC colorants and 25 percent of the pixels in the halftone should comprise CCM coiorants. Thus, the technique 500 provides a relatively smooth distribution of colorants in the halftone (i.e. no pixeis include large colorant combinations piaced adjacent to white pixels), thereby ensuring improved grain in the printed halftone.

[0038] In some examples, the layering of coiorants in the theoretical print ceil can be controlled to ensure particular properties for the resulting NPac vector. For example, the layering of colorants may be controlled to ensure that different colorants are assigned to different stacks in the theoretical print ceil. An example of such ordering may be ysed to ensure that a stack comprising a black colorant should, as far as possible, only comprise black colorant, to avoid half one pixels which combine black and other (i.e. non-black) colorants.

[0039] Figure 6 is a flow diagram showing a method 600 of converting a colorant quantity to an NPac vector in accordance with an example. In particular, the method 600 corresponds to the technique 500 discussed above with reference to Figure 5. In block 602 a set of interpolated colorant quantities is obtained using, for example, the colorant quantity interpolation process described above. Next, interpolated colorant quantities are layered into the theoretical print eel! in accordance with a predetermined order at block 604. The layers resulting from block 604 are divided into one or more colorant stacks comprising respective colorant combinations at block 606. At block 608 each stack is converted into an area coverage coefficient based on its relative width in the theoretical print cell, and used to form the NPac vector corresponding to the interpolated colorant quantities.

[0040] in some examples, it is desirable to ensure that the interpolation process performed for locations on the coior-to-biack diagonal produces sets of halftone parameters that match the halftone parameters interpolated for the white-to-biack diagonal (hereinafter termed the "gray ramp") in the image color space 100, in terms of properties are! structure. Moreover, it is desirable that the halftone parameters generated for the color-to-black diagonal result in the maximum colorant deposition for the printer system, to avoid any loss of chromaticity for dark colors. These requirements may necessitate additional consideration in the interpolation process, as discussed below with reference to Figures 7 and 8.

[0041] Figure 7 is a schematic diagram showing a technique 700 for generating an NPac vector in accordance with an example. In particular, Figure 7 shows an interpolation technique for colors located on a coior-to-black diagonal, which accounts for the additional considerations discussed above, in this diagram, the NPac vectors are represented schematically, with the gray ramp NPac vectors being represented using solid grayscale colors and the color NPac vectors being represented using cross hatching. According to technique 700. the corresponding NPac vector 710 in the gray ramp is first obtained and depieted by a predetermined percentage to produce a depleted gray NPac vector 712 (process P702). The depletion process may comprise applying a scaling to the NP coefficients in the gray ramp NPac vector 710, thereby ensuring that the NP structure is preserved in the depleted gray NPac vector 712. Next, a colorant amount that can be added to the depleted gray NPac vector 712 to reach the coiorant limit is calculated (process P704) by, for example, converting the depleted gray NPac vector 712 into a set of colorant quantifies for comparison with a coiorant limit associated with a particular printing system. Next a color NPac vector 718 defined for a color on the black-color diagonal is depleted by an amount matching the colorant amount calculated in process 704 to produce a depieted cotor NPac vector 716 (process P706). Finally, the depieted gray NPac vector 712 and the depleted coior NPac vector 716 are combined (i.e. summed) to produce an NPac vector that preserves the structures of the gray ramp NPac vector 710 and the color NPac vector 718, whilst maximizing the colorant quantity.

[0042] Figure 8 is a low diagram showing a method of generating an NPac vector on a black-color diagonal in the image coior space, in accordance with an example. In a particular, method 800 corresponds to the technique discussed above wit) reference to Figure 7. In block 802, the NPac vector 710 for a corresponding location in the gray ramp is obtained and depleted by a predetermined percentage to produce the depieted gray NPac vector 712. At block 804, the colorant amount that can be added to the depieted gray NPac vector 712 to reach the coiorant iimit is calculated. At block 806, the color NPac vector 718 defined for a location on the black-color diagonal is depleted by an amount matching the colorant amount calculated in block 804, to produce the depleted color NPac vector 718. At block 80S, the depleted gray NPac vector 712 and fie depleted color NPac vector 716 are combined to produce an NPac that preserves the NPac structures of the gray ramp NPac 710 and the color NPac 718, whilst maximizing the colorant quantity.

[0043] Certain methods and systems as described herein may be implemented by a processor that processes computer program code that is retrieved from a non-transitory storage medium. Figure 9 shows an example of a computing system 900 comprising a machine-readable storage medium 910 coupled to a processor 920. Machine-readable media 910 can be any non- transitory media that can contain, store, or maintain programs and data for use by or in connection with an instruction execution system. Machine-readable media can comprise any one of many physical media such as, for example, electronic, magnetic, optical, electromagnetic, or semiconductor media. More specific examples of suitable machine-readable media include, but are not limited to, a hard drive, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory, or a portable disc, in Figure 9, the machine-readable storage medium comprises program code to implement generation of halftone parameters using the techniques and methods described above with reference to Figure 1 to 8.

[0044] According to some examples, the second color space may be defined as material volume coverage space for use in an additive manufacturing apparatus. In such examples, the vector components of a material volume coverage vector (MVoc) represent ail materials available to the additive manufacturing apparatus and their combinations, in other words, the MVoc vectors are an enumeration of possible build or deposit states available to the additive manufacturing apparatus. The vector components of the fVIVoc may be considered analogous to the concept of Neugebauer Primaries as discussed above, in this analogy, each vector component may be considered to comprise a volume coverage of a "materia! primary 5 '. As such the material volume coverage vector has a dfmensionaliy representative of these states and contains fie volume coverages (e.g. probabilities) associated .with each state. Or in other words, the MVoc comprises weighted combinations' or probabilities of material ' primaries. Thus, according to some example, the techniques and methods described above with reference to Figures 1 to 9 may be applied to interpolate between parameters defined in an MVoc space to build a mapping for use in the additive manufacturing process.

[0045] The preceding description has been presented to illustrate and describe examples of the principles described. This description is not intended to be exhaustive or to limit these principies to any precise form disdosed. Many modifications and variations are possibie in light of the above teaching. Although the flow diagrams shows a specific order of execution, the order of execution may differ from that which is depicted.