spectro/fakeread

Summary

Simulate the measurement of a devices response, using an existing device profile, or measured test point data set. The device profile can be either an ICC or MPP profile, or the data set can be a .ti3 file. A device link separation or color space conversion can be applied before the print/measure simulation.

Usage

fakeread [-v] [-s] [separation.icm] profile.[icm|mpp|ti3] inoutfile
 -v                        Verbose mode
 -s                        Lookup MPP spectral values
 -p                        Use separation profile
 -l                        Output Lab rather than XYZ
 -k file.cal               Apply calibration (after sep.) and include in .ti3
 -i file.cal               Include calibration in .ti3 (but don't apply it)
 -r level                  Add average random deviation of <level>% to input device values (after sep. & cal.)
 -0 pow                    Apply power to input device chanel 0-9 (after sep. cal. & rand.)
  -R level                  Add average random deviation of <level>% to output PCS values
 -u                        Make random deviations have uniform distributions rather than normal
 -S seed                   Set random seed
 -b L,a,b                  Scale black point to target Lab value
 -I intent                 r = relative colorimetric, a = absolute (default)
 [separation.icm]          Device link separation profile
 profile.[icm|mpp|ti3]     ICC, MPP or .ti3 profile/file to use
  inoutfile                 Base name for input[.ti1]/output[.ti3] file


Examples


fakeread profile.icm testvalues
fakeread -p separation.icm profile.icm testvalues

Comments

The -v flag does nothing at the moment.
The -s flag works only with MPP profiles that contain spectral model information.
The -p flag enables a device to device value conversion before converting to expected PCS values.
The -l flag causes the CIE output values to be L*a*b* rather than the default XYZ values.

The -k file.cal parameter specifies a printer calibration file created by printcal, and the supplied calibration curves will be applied to the chart device values after any separation. This allows emulating a system that uses per device channel calibration. The calibration curves will also be included in the resulting .ti3 file, so that they can be passed through to the ICC profile allowing accurate computation of ink limits.

The -i file.cal parameter specifies a printer calibration file created by printcal, and the calibration curves will be included in the included in the resulting .ti3 file, so that they can be passed through to the ICC profile, to allow accurate computation of ink limits. The calibration is not applied to tchart values. Note that if the supplied ICC profile contains calibration curves, that these will be included in the resulting .ti3 by default.

The -r parameter is a way of simulating instability in the behaviour of the simulated printing system. The parameter supplied to the flag will be used to scale a random offset added to the device values (after any separation and calibration is applied). The offset will be a normally distributed error with an average deviation of level%. A typically value supplied might be 1.0 to simulate 1% randomness.

The -0, -1, -2 .. -9 parameters are a way of simulating changes in the behaviour of the simulated printing system. The parameter supplied to the flag will be used to modify the device values (after any separation, calibration and device randomness is applied) by raising them to the power of the parameter. This applies a transfer curve to the simulated device response.

The -R parameter is a way of simulating instability in the behaviour of the simulated measuring system. The parameter supplied to the flag will be used to scale a random offset added to the PCS values. The offset will be a normally distributed error with an average deviation of level%. A typically value supplied might be 1.0 to simulate 1% randomness.

The -u flag changes the distribution of the random offsets applied using the -r or -R flags, from the default standard deviation, to a uniform deviation distribution. The level is still specified as an average deviation.

The -S parameter lets a particular random seed be used when generating random offsets, so that the randomness can be made repeatable. Normally a different seed will be used for each run.

The -b parameter is a way of simulating devices that have a different black point to the profile used. This only works if an ICC profile is used, and scales the black point to the parameter value. This will be done in XYZ space by default, and in L*a*b* space if the -l flag is used.

The -I parameter allows changing the intent used in looking up the ICC profile colors to relative colorimetric. This would not be used if you intend to make a profile from the resulting .ti3 file, since profiles are always made from absolute colorimetric measurement values. Note that this flag does nothing if the profile is an MPP or .ti3 file.

Fakeread is useful in creating artificial test value for testing colprof, as well as providing one path for turning an MPP profile into an ICC profile. If a .ti3 file is specified instead of an ICC or MPP profile, then the closest matching measured points in the ..ti3 are substituted for the test values in the .ti1 file on output. If the .ti1 file is a monochrome test file with a White device value, then an RGB ICC profile, MPP or .ti3 may be used, and the White values will be translated to equal RGB values. If the .ti1 file is a monochrome test file with a Black device value, then a CMYK ICC profile, MPP or .ti3 may be used, and the Black values will be translated to equal CMY = 0, K = grey values. Note that any calibration within a supplied ICC profile is not applied during the conversion, although it will be included in the .ti3 output (see -k and -i flags for how apply calibration curves during the conversion and/or include a specific calibration curves in the output).

If a separation device profile is provided (e.g. from CMY -> CMYK, or perhaps CMYK->CMYK, to simulate a color correction step before "printing"), then this will be applied to the .ti1 device values, before converting the the device values into .ti3 PCS values.