spectro/ccxxmake
    Summary
    For Colorimeters that rely on a calibration matrix, ccxxmake allows creation of a
    correction matrix file (ccmx)
    for a particular Colorimeter &
      Display combination, by making use a reference Spectrometer or Colorimeter
    instrument. This can then be used to improve the accuracy of
    subsequent measurements with that Colorimeter on that Display by
    using it with the dispcal, dispread and spotread
    -X option. A ccmx file can also be installed,
    and will then appear in the available display type selection (-y
    option). See Wide Gamut Displays
      and Colorimeters for more information on why this may be
    useful. [ Note that to make
    use of a colorimeter as a CCMX reference, you will have to
    provide two .ti3 files rather than using interactive measurement-
    see -f. ]
    
    For Colorimeters that have sensor spectral sensitivity calibration
    information built into them  (ie. the X-Rite i1d3, and
    DataColor Spyder4 & Spyder5),
    ccxxmake allows a creation
    of a calibration spectral sample (ccss)
    for a particular Display,
    by making use a reference Spectrometer
    instrument. This can then be used to improve the accuracy of
    subsequent measurements on that Display using such Colorimeters, by
    using it with the dispcal, dispread and spotread
    -X option, or it can be installed, and
    will then appear in the available display type selection (-y
    option).
    
    The instrument manufacturer may supply spectral sample files (see oeminst).
    
    There is a list of contributed ccss (Colorimeter Correction
    Spectral Sample) files for some displays.
    There is a list of contributed ccmx (Colorimeter Correction
    Matrix) files.
    Usage Summary
    ccxxmake -t dtech [-options]
      correction.ccmx
     -v             
            Verbose mode
      -S                   
      Create CCSS rather than CCMX
     -f ref.ti3[,targ.ti3]
      Create from one or two .ti3 files rather than measure.
     -display
        displayname  [X11 only] Choose X11 display name
     -d
        n[,m]
                  
      [X11 only] Choose the display from the following list (default 1),
                          
and
optionally
choose
a
different
display
m
      for VideoLUT access.
     -d
        n                 
Choose
the
display
from
the
following
list
      (default 1)
     -d
        web[:port]        
      Display via a web server at port (default 8080)
     -d cc[:n]            
      Display via n'th ChromeCast (default 1, ? for list)
        -d madvr
                  
      [MSWin] Display via MadVR Video Renderer
      -d dummy
                    
        Dummy (non-existant, invisible) display
     -p                   
      Use telephoto mode (ie. for a projector, if available)
     -a
                          
        Use ambient mode (ie. for a projector, if available)
      -y X
                      
 
        Display type - instrument specific list to choose from.
      (CCMX)
     -z disptype          
      Different display type for spectrometer (see -y)
      -P ho,vo,ss[,vs]     
      Position test window and scale it
                          
ho,vi:
0.0
=
left/top,
0.5
=
center,
      1.0 = right/bottom etc.
                          
ss:
0.5
=
half,
1.0
=
normal,
      2.0 = double etc.
                          
        ss,vs: = optional horizontal, vertical scale.
     -F
                        
      Fill whole screen with black background
     -n             
     
[X11
only]
Don't
set
override
redirect
on
      test window
     -N                   
      Disable initial calibration of instrument if possible
     -H
                        
      Use high resolution spectrum mode (if available)
     -C
        "command"         
      Invoke shell "command" each time a color is set
     -M
          "command"         
      Invoke shell "command" each
            time a color is measured
     -o
        observ       
           Choose CIE Observer for CCMX spectral
      data:
                 
                   1931_2  (def.), 1964_10, 2012_2, 2012_10, S&B
      1955_2, shaw, J&V 1978_2 or file.cmf
     -s steps             
Override
default
patch
sequence
      combination steps (default 3)
     -W
        n|h|x             
Override
serial
port
flow
control:
n
=
      none, h = HW, x = Xon/Xoff
     -D [level]
                 Print
      debug diagnostics to stderr
     -E "description"     
Override
the
default
overall
      description
     -I
        "displayname"      Set display make and model
      description
      (optional)
       -t
        dtech
                  
      Set display technology type
         
      c                  
      CRT
         
      m                  
      Plasma
         
      l                  
      LCD
         
      1                  
      LCD CCFL
         
      2              
        LCD
      CCFL IPS
         
      3              
        LCD
      CCFL PVA
         
      4              
        LCD
      CCFL TFT
         
      L              
        LCD
      CCFL Wide Gamut
         
      5              
        LCD
      CCFL Wide Gamut IPS
         
      6              
        LCD
      CCFL Wide Gamut PVA
         
      7              
        LCD
      CCFL Wide Gamut TFT
         
      e              
        LCD
      White LED
         
      8              
        LCD
      White LED IPS
         
      9              
        LCD
      White LED PVA
         
      a              
        LCD
      White LED TFT
         
      b              
        LCD
      RGB LED
         
      b              
        LCD
      RGB LED IPS
         
      c              
        LCD
      RGB LED PVA
         
      d              
        LCD
      RGB LED TFT
         
      h              
        LCD
      RG Phosphor
         
      e              
        LCD
      RG Phosphor IPS
         
      f              
        LCD
      RG Phosphor PVA
         
      g              
        LCD
      RG Phosphor TFT
         
      r                  
      LCD PFS Phosphor
         
      s                  
      LCD PFS Phosphor IPS
         
      t                  
      LCD PFS Phosphor PVA
         
      v                  
      LCD PFS Phosphor TFT
         
      i                  
      LCD GB-R Phosphor
         
      x                  
      LCD GB-R Phosphor IPS
         
      y                  
      LCD GB-R Phosphor PVA
         
      z                  
      LCD GB-R Phosphor TFT
         
      o              
        LED
      OLED
         
      a              
        LED
      AMOLED
         
      w                  
      LED WOLED
         
      p              
        DLP
      Projector
         
      h              
        DLP
      Projector RGB Filter Wheel
         
      i              
        DPL
      Projector RGBW Filter Wheel
         
      j              
        DLP
      Projector RGBCMY Filter Wheel
         
      u              
        Unknown
      -U c                 
      Set UI selection character(s)
     -Y
        r|n          
             Override refresh, non-refresh display
        mode
     -Y R:rate            
      Override measured refresh rate with rate Hz
     -YA
                    
             Use non-adaptive integration time mode
        (if available).
     correction.ccmx | calibration.ccss
                      
            File to save result to.
    Usage Details and Discussion
    The -v flag causes extra information to be
    printed out during chartread operation.
    
    -S By
    default a Colorimeter Correction Matrix (CCMX) will be created from both Colorimeter and Spectrometer readings, which
    allows correction for errors with a particular Colorimeter and
    Display combination. If the -S
    flag is used, then instead a Colorimeter Calibration Spectral Set (CCSS) file is created from just
    the Spectrometer readings,
    that allows calibrating any suitable Colorimeter to the Display.
    
    -f ref.ti3[,targ.ti3] By
    default ccxxmake creates a CCMX file by displaying test
    patches on the screen, and then prompting you to measure them
    interactively with the two instruments. An alternative is to create
    a small number of test values using targen suitable for display profiling (or use the ref/ccxx.ti1 file provided with
    ArgyllCMS), and then measure them with the two instruments using dispread to create a reference
    and target .ti3 files, and then provide the two files as arguments
    to ccxxmake -f. Normally
    the reference file will be created using a spectral instrument and
    you will want to use the -s
    flag with dispread for this. If you want to use a colorimeter as a
    reference instrument, then make sure that it is the first file
    provided to the ccxxmake -f
    option. The filenames should be concatenated with a "," separator without spaces.
    You will also have to supply a display name using the -I option and/or technology
    description using -T.
    When creating a CCSS file,
    only spectral readings from the display measured with the reference
    instrument are needed, and a single .ti3 file should be provided.
    
    When running on a UNIX based system that used
    the X11 Windowing System, ccxxmake will by default use the
    $DISPLAY environment variable to determine which display and screen
    to read from. This can be overridden by supplying an X11 display
    name to the -display
    option. Note that if Xinerama is active, you can't select the screen
    using $DISPLAY or -display, you have to select it using the -d parameter.
    
     By default the main display will be the location of
    the test window. If the system has more than one display or screen,
    an alternate display/screen can be selected with the -d parameter. If you invoke ccxxmake
    so as to display the usage information (i.e. "dispcal -?" or
    "dispcal --"), then the discovered displays/screens will be listed.
    Multiple displays may not be listed, if they appear as a single
    display to the operating system (ie. the multi-display support is
    hidden in the video card driver). On UNIX based system that used the
    X11 Windowing System, the -d
    parameter will override the screen specified by the $DISPLAY or
    parameter.
    
    Because of the difficulty cause by TwinView and
    MergedFB in X11 based systems, you can optionally specify a separate
    display number after the display that is going to be used to present
    test patches, for accessing the VideoLUT hardware. This must be
    specified as a single string, e.g. -d
      1,2 . Some experimentation may be needed using dispwin on such systems, to discover what
    screen has access to the VideoLUT hardware, and which screens the
    test patches appear on.
    
    -dweb or
    -dweb:port starts a
    standalone web server on your machine, which then allows a local or
    remote web browser to display the the color test patches. By default
    port 8080 is used, but this
    can be overridden by appending a :
    and the port number i.e. -dweb:8001.
    The URL will be http://
    then name of the machine or its I.P. address followed by a colon and
    the port number - e.g something like http://192.168.0.1:8080. If you use the verbose
    option (-v) then a likely
    URL will be printed once the server is started, or you could run ipconfig (MSWin) or /sbin/ifconfig (Linux or OS X)
    and identify an internet address for your machine that way. You may
    have to modify any firewall to permit port 8080 to be accessed on
    your machine.
    
    -dcc or -dcc:no
    causes test patches to be displayed using and available ChromeCast to
    your TV. Use -dcc:? to display a list of ChromeCasts on your
    local network. You may have to modify any firewall to permit port
    8081 to be accessed on your machine if it falls back to the Default
    receiver.
    
    -dmadvr
    [MSWin only] causes test patches to be displayed using the MadVR
    video renderer. Note that will have to start MadTPG before
    running ccxxmake, and that while you can adjust the "Test Pattern
    Configuration" controls, you should not normally alter the
    "Existing Calibration" controls, as ccxxmake will set these
    appropriately. 
    
    -ddummy
    causes test patches not to be displayed at all. This is useful when
    used with the these appropriately. This is useful when patch values
    are going to be displayed via the -C option.
    
    The -p flag
    allows measuring in telephoto mode, using instruments that support
    this mode, e.g. the ColorMunki. Telephoto mode is one for taking
    emissive measurements from a distance (ie. telespectometer,
    tele-colorimeter) mode, and typically would be used for measuring
    projector type displays. If a device does not support a specific
    telephoto mode, then the normal emissive mode may be suitable for
    measuring projectors.
    
    The -a flag
    allows measuring in ambient mode, using instruments that support
    this mode. This typically would be used for measuring projector type
    displays when the light levels reflected from the projection surface
    are very low. Note that this means that the color value will not be
    quite as accurate, because the effect the projection surface has on
    the color is not taken into account.
    
     The -y
    flag allows setting the Display Type used as a base for color
    correction matrix CCMX creation. Only base calibration display types
    will be listed. 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 internal 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. Any CCMX created will work on top of
    the selected Display Type, so to be valid, the same Display Type
    must be selected whenever the CCMX is used with this instrument.
    Installed CCMX files will automatically select the appropriate base
    type.
    
    The -z flag allows setting a different
    Display Type for the reference spectral instrument, such as refresh
    or non-refresh type, if it supports it. You may have to use this if
    you are setting a specific base type for the colorimeter using -y,
    and the spectrometer doesn't have this display type.
    
     The -P
    parameter allows you to position and size the test patch window. By
    default it is places in the center of the screen, and sized
    appropriately for the type of instrument. The ho and vo values govern the horizontal
    and vertical offset respectively. A value of 0.0 positions the
    window to the far left or top of the screen, a value of 0.5
    positions it in the center of the screen (the default), and 1.0
    positions it to the far right or bottom of the screen. If three
    parameters are provided, then the ss
    parameter is a scale factor for the test window size. A value of 0.5
    for instance, would produce a half sized window. A value of 2.0 will
    produce a double size window. If four parameters are provided, then
    the last two set independent horizontal and vertical scaling
    factors. Note that the ho,vo,ss or ho,vo,hs,vs numbers must be
    specified as a single string (no space between the numbers and the
    comma). For example, to create a double sized test window at the top
    right of the screen, use -P 1,0,2
    . To create a window twice as wide as high: -P 1,0,2,1.
    
     The -F
    flag causes the while screen behind the test window to be masked
    with black. This can aid black accuracy when measuring CRT displays
    or projectors.
    
    -n When
    running on a UNIX based system that used the X11 Windowing System, dispcal
    normally selects the override redirect so that the test window will
    appear above any other windows on the display. On some systems this
    can interfere with window manager operation, and the -n
    option turns this behaviour off.
    
    -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.
    
     The -H
    option on high resolution spectral mode, if the instrument supports
    it, such as the Eye-One Pro. See Operation
      of particular instruments for more details. This may give
    better accuracy for display measurements.
    
     The -C "command" option allows a
    method of relaying each test value to some other display than that
    on the system running dispcal (for instance, a photo frame, PDA
    screen etc.), by causing the given command to be invoked to the
    shell, with six arguments. The first three arguments are the RGB
    test color as integers in the range 0 to 255, the second three
    parameters are the RGB test color as floating point numbers in the
    range 0.0 to 1.0. The script or tool should relay the given color to
    the screen in some manner (e.g. by generating a raster file of the
    given color and sending it to the display being profiled), before
    returning. Note that a test window will also be created on the
    system running ccxxmake.
    
    The -M "command" option allows a
    method of gathering each test value from some external source, such
    as an instrument that is not directly supported by Argyll. The given
    command is invoked to the shell, with six arguments. The first three
    arguments are the RGB test color as integers in the range 0 to 255,
    the second three parameters are the RGB test color as floating point
    numbers in the range 0.0 to 1.0. The script or tool should create a
    file called "command.meas"
    that contains the XYZ values for the given RGB (or measured from the
    test window) in cd/m^2 as three numbers separated by spaces, before
    returning. If the command returns a non-zero return value, cxxmake
    will abort. Note that a test window will also be created on the
    system running ccxxmake.
    
     (CCMX creation) The -o flag allows
    specifying a tristimulus observer, and is used to compute
    tristimulus values from spectral readings.  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 steps
    parameter overrides the default number of test patch combination
    steps used in measuring a colorimeter & display combination.  The steps are those out
    of every combination of R,G & B values of the given number of
    steps that have at least one colorant at 100%. So 2 steps gives 7
    test patches, 3 gives 19, 4 gives 37, 5 gives 61, 6 gives 91 etc.
    Note that typically this won't make much difference to the resulting
    calibration, since it depends primarily on the underlying spectral
    characteristics of the display.
    
    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 -E parameter allows overriding the ccmx/ccss files overall
    description tag. Normally this is not necessary. With most command
    line shells, it will be necessary to enclose the parameter with
    double quotes, so that spaces and other special characters are
    included in the parameter, and not mistaken for the start of another
    flag, or as a final command line parameter. 
    
    The -I parameter allows optional setting of
    the display description string in the resulting ccmx/ccss file. Since the
    default display description is probably very generic, it is highly recommended that a
    description of the make and model of the display be provided here.
    The default or given display description will be printed before the
    menu. With most command line shells, it will be necessary to enclose
    the parameter with double quotes, so that spaces and other special
    characters are included in the parameter, and not mistaken for the
    start of another flag, or as a final command line parameters.
    
    The -t parameter allows setting of the
    display technology type from the available list. You can get a usage
    that includes the list using "ccxxmake -??". This is a required
    parameter, since it conveys information about the refresh type and
    settling time of the display. If the specific details of the display
    are not known (i.e. backlight type, pannel type etc.), then choose
    the next most generic type. If none of these are applicable, choose
    "Unknown".
    
    The -U parameter allows setting of the user
    interface selection character this display type can be selected by,
    if installed. This character will only be used if there is no clash
    with any preceding selections. Characters in the range 0-9, A-Z a-z
    can be used.
    
    The -Y r and
    -Y n options overrides the refresh display mode set by the -y display type selection, with -Y r forcing refresh display mode,
    and -Y n forcing a non-refresh display mode. Not all
    instruments support a display measurement refresh mode, or the
    ability to override the mode set by the display type selection.
    
     The -Y R:rate
    options overrides calibration of the instrument refresh rate. This
    may be useful if the instrument supports this function and the
    refresh rate cannot be accurately calibrated from the display
    itself.
    
     The -Y A
    option uses a non-adaptive integration time emission measurement
    mode, if the instrument supports it, such as the Eye-One Pro or
    ColorMunki. By default an adaptive integration time measurement mode
    will be used for emission measurements, but some instruments support
    a fixed integration time mode that can be used with display devices.
    This may give increased consistency and faster measurement times,
    but may also give less accurate low level readings.
    
    The correction.ccmx is the name of the file to save
    the resulting Colorimeter
      Correction Matrix to. It is best to give it a short but
    informative name that includes the Colorimeter model and the display
    make and model. By convention it should have a .ccmx file extension.
    
    The correction.ccss is the name of the file to save
    the resulting Colorimeter
      Calibration Spectral Samples to. It is best to give it a short
    but informative name that includes the display technology or model.
    By convention it should have a .ccss
    file extension.
    
    If you are going to use the same CCMX or CCSS file all the time,
    then you may want to set the ARGYLL_COLMTER_CAL_SPEC_SET
    environment variable.
    
    
    Instrument Communications:
    Unlike the other measurement utilities, ccxxmake doesn't connect to the instrument until it
    is about to make a measurement. This allows for the possibility of
    using a different instrument for each measurement.
    
    It will display a menu:
    
    Press 1 .. 4:
    1) Select an instrument, Currently 1 'usb:/bus4/dev2/ (GretagMacbeth
    i1 Pro)'
    2) Measure test patches with current instrument
    3) [ Compute Colorimeter Correction Matrix & save it ]
    4) Exit
    
    For creating a CCMX there are two measurements to be made, after
    which the correction matrix can be computed and saved. Before each
    measurement, the instrument may need calibrating. For creating a
    CCSS a single measurement is needed.
    
     A spectral measurement using a spectral instrument is always
    needed.
    
     A measurement using the Colorimeter that the correction matrix
    is being created for is needed in the case of creating a CCMX, but not needed when creating a CCSS.
    
    There will be a message before the menu indicating which of the
    measurements has been completed.
    
    
    Display Setup:
    Because ccmx/ccss is measuring spectral matching, the exact levels
    of each channel is not important, so the display settings or
    calibration state shouldn't make any difference to the result, as
    long as it is the same for the readings of both instruments.
    Similarly, the number and variety of test patches shouldn't make a
    huge difference, as long as there is at least Red, Green, Blue and
    White test patches.