Read a printer test chart using an instrument, to create a .ti3 data file. The type of instrument is determined by the communication port selected.

chartread can also be used to read transmission values, and to read display values manually.


chartread [-options] outfile
 -v                 Verbose mode
 -c listno          Set communication port from the following list (default 1)
 -t                 Use transmission measurement mode
 -d                 Use display measurement mode (white Y relative results)
-y X               Display type - instrument specific list to choose from.
 -e                 Use emissive  measurement mode (absolute results)
 -p                 Measure patch by patch rather than strip
  -x [lx]            Take manually entered values, either L*a*b* (-xl) or XYZ (-xx).
 -n                 Don't save spectral information (default saves spectral)
 -l                 Save CIE as D50 L*a*b* rather than XYZ
 -L                 Save CIE as D50 L*a*b* as well as XYZ
 -r                 Resume reading partly read chart
 -I file.cal        Override calibration info from .ti2 in resulting .ti3
-F filter          Set filter configuration:
  n                  None
  p                  Polarising filter
  6                  D65
  u                  U.V. Cut

  -A N|A|X|G         XRGA conversion (default N)
 -N                 Disable initial calibration of instrument unless essential
 -B                 Disable auto bi-directional strip recognition
 -b                 Force enable auto bi-directional strip recognition
 -H                 Use high resolution spectrum mode (if available)
 -X file.ccmx          Apply Colorimeter Correction Matrix
 -X file.ccss          Use Colorimeter Calibration Spectral Samples for calibration
 -Q observ             Choose CIE Observer for spectral data or CCSS instrument:
1931_2 (def.), 1964_10, 2012_2, 2012_10, S&B 1955_2, shaw, J&V 1978_2 or file.cmf
 -T ratio           Modify strip patch consistency tolerance by ratio (if available)
 -S                 Suppress wrong strip & unexpected value warnings
 -W n|h|x           Override serial port flow control: n = none, h = HW, x = Xon/Xoff
 -D [level]         Print debug diagnostics to stderr
 inoutfile          Base name for input[.ti2]/output[.ti3] file

Usage Details

The -v flag causes extra information to be printed out during chartread operation.

Normally instruments are connected via a serial communication port, and the port used should be selected by supplying the correct parameter to the -c flag. If you invoke chartread so as to display the usage information (i.e. "chartread -?" or "chartread --"), then the discovered serial ports will be listed on Windows and Mac OSX systems.

If using an Xrite DTP41T, and printing onto transparent or back lit media, use the -t flag to operate the instrument in transparency mode. If using a Spectrolino or Eye-One Pro (handheld), this triggers a fake transparency mode, that uses a separate backlight (such as a light box). The  instrument will be used to calibrate the level of backlight, and use this to compute the transparency of the test chart samples. Note that for good transparency values, the backlight level needs to be neither too bright not too dark, should ideally be incandescent rather than fluorescent (since fluorescent lights often have big dips in their spectrum), and ideally should be of uniform brightness over the measurement area. If using the SpectroScanT, the -t flag operates the instrument in transparency mode, each reading being manually triggered.

The -d flag allows measuring in display mode using instruments that support this mode, with the brightness normalized to the white patch value in the test chart. While the brightness values are then relative to the white, the readings are otherwise absolute. This corresponds to the raw ICC absolute readings created by dispread, and is the mode that should be used for creating a normal display ICC profile using manual, spot by spot readings. This can be useful if the display cannot be driven directly by the computer, but can be made manually to display the test charts.

  The -y flag allows setting the Display Type. The selection typically determines two aspects of of the instrument operation: 1) It may set the measuring mode to suite refresh or non-refresh displays. Typically only LCD (Liquid Crystal) displays have a non-refresh nature. 2) It may select an instrument calibration matrix suitable for a particular display type. The selections available depends on the type and model of instrument, and a list of the options for the discovered instruments will be shown in the usage information. For more details on what particular instruments support and how this works, see Operation of particular instruments. 3) Any installed CCSS files (if applicable), or CCMX files. These files are typically created using ccxxmake, and installed using oeminst. The default and Base Calibration types will be indicated in the usage.

If using an instrument that supports an emissive measurement mode (such as the Spectrolino), then the -e flag enables this measurement mode, and the values recorded will be absolute XYZ values. This can be used for media such as backlit film, measuring it on a lightbox, so as to capture the actual illumination characteristics of that particular media. An adaptive integration time will be used in devices that support it.

The -p flag causes chartread to use a spot read mode for an instrument, even if it is capable of faster chart reading modes such as strip reading. This can be useful if strip measurement patch recognition is not reliable for certain media.

The -x flag causes chartread to expect values to be manually entered for each reading, rather than using an instrument to do the measurements.  This mode is ideal if your instrument is not supported by Argyll. Either XYZ or L*a*b* values can be entered, depending on what option follows -l, -lx to specify XYZ values, or -ll to specify L*a*b* values. XYZ values are expected to be scaled to a maximum of 100. It is possible to navigate about the test values being measured, so as to do them in any order, as well as re-do values, in case of any mistakes.

-n By default spectral information as well as D50 standard observer XYZ values will be recorded for each test patch, when such readings are available from a device. The spectral readings allow for choosing a non-standard viewing illuminant, a non-standard observer model, or the use of the Fluorescent Paper Whitener Additive compensation when creating the profile. If the spectral readings are not needed, then prinread operation can be speeded up by specifying the -n flag.

-l By default D50 standard observer XYZ values will be recorded for each test patch, but if the -l flag is used, D50 L*a*b* values will be recorded instead.

-L By default D50 standard observer XYZ values will be recorded for each test patch, but if the -L flag is used, XYZ and D50 L*a*b* values will be recorded.

-r By default chartread reads the chart from scratch each time. When reading a chart using a strip instrument or patch by patch you can choose to finish chartread without reading all the patches, and whatever patches have been read will be saved to the output .ti3 file. You can then resume reading the patches by using the -r flag, in which case chartread will read the .ti3 file and set the patches to those previously read values, allowing any unread patches to then be read, or to re-read previously read patches.

-I file.cal  Normally per channel calibration curves are added to the .ti2 file using the printtarg -K or -I options, so that they will be passed on to the .ti3 file by  chartread, so that colprof is able to correctly compute total ink limits. Where the calibration is being applied in a workflow with native calibration capability though, it is sometimes convenient to re-use a profile chart with different calibration curves without going through the process of using printtarg to re-create it. This would mean though, that the calibration information and subsequent ink limit calculations wouldn't be accurate. To overcome this and allow such a scenario, the chartread -I parameter allows overriding the .ti2 calibration curves placed in the resulting .ti3 file with the actual calibration that was used for that particular print.

The -F options allows configuring the instrument to have a particular filter fitted to it. Some instruments (i.e. the Gretag Spectrolino) allow the fitting of various filters, such as a polarizing filter, D65 illuminant simulation, or Ultra Violet Cut filter, and this option allows the instrument to be configured appropriately.

The -A options allows overriding the default or environment variable set XRGA conversion:

    -A N|A|X|G

        The N argument sets the calibration to Native (default).
        The A argument sets the calibration to XRGA.
        The X argument sets the calibration to XRDI.
        The G argument sets the calibration to GMDI.

-N Any instrument that requires regular calibration will ask for calibration on initial start-up. Sometimes this can be awkward if the instrument is being mounted in some sort of measuring jig, or annoying if several sets of readings are being taken in quick succession. The -N suppresses this initial calibration if a valid and not timed out previous calibration is recorded in the instrument or on the host computer. It is advisable to only use this option on the second and subsequent measurements in a single session.

-B Some strip instruments (i.e.. Eye-One Pro, Color Munki) when used with Argyll will automatically recognize a strip when read in the reverse direction by matching the patch readings against their expected values. If the expected values are not known accurately enough, this may cause erroneous reverse recognition, so the -B flag allows this to be turned off, forcing strips to only be read in the forward direction. (Note that the DTP20 always allows bi-directional strip reading.) If the randomized patch layout has not been used, then  bi-directional strip recognition will automatically turned off, and a warning issued if the -B flag is not used.

-b By default chartread will disable bi-directional strip reading if a randomized layout hasn't been used. The -b flag forces bi-directional strip reading on even for charts that don't use a randomized layout. If the chart strips have a distinct patch order, then this will be reliable, but for other patch layouts, the direction may be guessed wrongly, so this option should be used with care.

The -H option turns on high resolution spectral mode, if the instrument supports it. See Operation of particular instruments for more details.

The -X file.ccmx option reads a Colorimeter Correction Matrix from the given file, and applies it to the colorimeter instruments readings. This can improve a colorimeters accuracy for a particular type of display. A list of contributed ccmx files is here.

The -X file.ccss option reads a Colorimeter Calibration Spectral Sample from the given file, and uses it to set the colorimeter instruments calibration. This will only work with colorimeters that rely on sensor spectral sensitivity calibration information (ie. the X-Rite i1d3, or the DataColor Spyder4 & Spyder 5).This can improve a colorimeters accuracy for a particular type of display. A list of contributed ccss files is here.

The -T ratio argument modifies the patch consistency tolerance threshold for some strip reading instruments (ie. the Eye-One Pro). In recognizing patches in a strip, an instrument may take multiple readings as the strip is read, and then divide the readings up into each patch. It may then check the consistency of the multiple readings corresponding to each patch, and reject the measurement if they are too inconsistent. For some media (ie. a coarser screens, fabric etc.) the default tolerance may be unreasonably tight, so the -T ratio argument can be used to modify this criteria. To loosen the tolerance, use a number greater than 1.0 (ie. 1.5, 2.0).

The -Q flag allows specifying a tristimulus observer for a colorimeter when using CCSS instrument calibration capability. The following choices are available:
  1931_2 selects the standard CIE 1931 2 degree observer. The default.
  1964_10 selects the standard CIE 1964 10 degree observer.
  2012_2 selects the proposed CIE 2012 2 degree observer.
  2012_10 selects the proposed CIE 2012 10 degree observer.
  1955_2 selects the Stiles and Birch 1955 2 degree observer
  1978_2 selects the Judd and Voss 1978 2 degree observer
  shaw selects the Shaw and Fairchild 1997 2 degree observer
  file.cmf selects an observer specified by the given .cmf file.

The -S flag causes the normal "wrong strip" and "unexpected value" warnings to be suppressed. There may be a lot of these warnings if the expected patch value in the .ti2 file is in fact far from the values actually being measured. It is probably advisable to also use the -B flag if warnings are turned off, since many warnings indicate that the expected values are not to be relied on. With warnings suppressed, greater care must be taken to read the correct strip. If the randomized patch layout has not been used, then "wrong strip" warnings will automatically be suppressed, and bi-directional strip recognition turned off.

The -W n|h|x parameter overrides the default serial communications flow control setting. The value n turns all flow control off, h sets hardware handshaking, and x sets Xon/Xoff handshaking. This commend may be useful in workaround serial communications issues with some systems and cables.

The -D flag causes communications and other instrument diagnostics to be printed to stdout. A level can be set between 1 .. 9, that may give progressively more verbose information, depending on the instrument. This can be useful in tracking down why an instrument can't connect.

The inoutfile parameters should be the base name of the .ti2 file, and chartread will output an .ti3 that has the same basename and the .ti3 extension. If the incoming .ti2 file contains per-channel calibration curves, these will be passed through to the .ti3 so that accurate ink limits can be computed during profiling.


For information about the operation of different instruments, see Operation of particular instruments.