Inheritance diagram for DiDisplayFunction:
Public Types | |
enum | E_DeviceType { EDT_Monitor, EDT_Camera, EDT_Printer, EDT_Scanner } |
output device type More... | |
Public Member Functions | |
DiDisplayFunction (const char *filename, const E_DeviceType deviceType=EDT_Monitor, const signed int ord=-1) | |
constructor, read device characteristics file. | |
DiDisplayFunction (const double *val_tab, const unsigned long count, const Uint16 max=255, const E_DeviceType deviceType=EDT_Monitor, const signed int ord=0) | |
constructor, use given array of luminance/OD values. | |
DiDisplayFunction (const Uint16 *ddl_tab, const double *val_tab, const unsigned long count, const Uint16 max=255, const E_DeviceType deviceType=EDT_Monitor, const signed int ord=0) | |
constructor, use given array of DDL and luminance/OD values. | |
DiDisplayFunction (const double val_min, const double val_max, const unsigned long count=256, const E_DeviceType deviceType=EDT_Monitor, const signed int ord=0) | |
constructor, compute luminance/OD values automatically within the specified range. | |
virtual | ~DiDisplayFunction () |
destructor | |
int | isValid () const |
check whether DisplayFunction is valid | |
E_DeviceType | getDeviceType () const |
get output device type (monitor, camera, printer or scanner) | |
Uint16 | getMaxDDLValue () const |
get maximum DDL value. | |
double | getMinValue () const |
get minimum luminance/OD value from the characteristic curve. | |
double | getMaxValue () const |
get maximum luminance/OD value from the characteristic curve. | |
double | getValueforDDL (const Uint16 ddl) const |
get the luminance/OD value for a given DDL. | |
Uint16 | getDDLforValue (const double value) const |
get the DDL for a given luminance/OD value. | |
const DiDisplayLUT * | getLookupTable (const int bits, unsigned long count=0) |
create look-up table with specified number of entries | |
int | deleteLookupTable (const int bits) |
delete specified LUT | |
virtual int | writeCurveData (const char *filename, const OFBool mode=OFTrue)=0 |
write curve data to a text file (abstract method) | |
double | getAmbientLightValue () const |
get (reflected) ambient light value. | |
virtual int | setAmbientLightValue (const double value) |
set (reflected) ambient light value. | |
double | getIlluminationValue () const |
get illumination value. | |
virtual int | setIlluminationValue (const double value) |
set illumination value. | |
double | getMinDensityValue () const |
get minimum optical density value "Dmin". | |
virtual int | setMinDensityValue (const double value) |
set minimum optical density value "Dmin". | |
double | getMaxDensityValue () const |
get maximum optical density value "Dmax". | |
virtual int | setMaxDensityValue (const double value) |
set maximum optical density value "Dmax". | |
double | getMinLuminanceValue () const |
get minimum luminance value "Lmin". | |
double | getMaxLuminanceValue () const |
get maximum luminance value "Lmax". | |
signed int | getPolynomialOrder () const |
get order of the polynomial curve fitting algorithm. | |
double | convertODtoLum (const double value, const OFBool useAmb=OFTrue) const |
convert the given OD value to luminance. | |
Static Public Member Functions | |
static double | convertODtoLum (const double value, const double ambient, const double illum) |
convert the given OD value to luminance. | |
Protected Member Functions | |
virtual DiDisplayLUT * | getDisplayLUT (unsigned long count)=0 |
create display LUT with specified number of entries (abstract method) | |
int | readConfigFile (const char *filename) |
read the given device characteristics file | |
int | createSortedTable (const Uint16 *ddl_tab, const double *val_tab) |
create a sorted (by DDL) table from the given DDL and luminance/OD tables | |
double * | convertODtoLumTable (const double *od_tab, const unsigned long count, const OFBool useAmb) |
create a table with luminance values from the given OD table. | |
int | interpolateValues () |
interpolate device characteristic curve by means of a cubic spline interpolation | |
int | calculateMinMax () |
calculate minimum and maximum luminance/OD values | |
int | checkMinMaxDensity () const |
check whether Dmin and Dmax are properly specified. | |
Protected Attributes | |
int | Valid |
status flag, indicating whether display function is valid | |
const E_DeviceType | DeviceType |
output device type (monitor, camera, printer or scanner) | |
unsigned long | ValueCount |
number of DDL and luminance/OD values | |
Uint16 | MaxDDLValue |
maximum DDL value (usually 255) | |
signed int | Order |
order of the polynomial curve fitting algorithm | |
double | AmbientLight |
(reflected) ambient light value | |
double | Illumination |
illumination value | |
double | MinDensity |
minimum optical density (-1 if unset) | |
double | MaxDensity |
maximum optical density (-1 if unset) | |
Uint16 * | DDLValue |
pointer to array of DDL values | |
double * | LODValue |
pointer to array of corresponding luminance/OD values | |
double | MinValue |
minimum luminance/OD value | |
double | MaxValue |
maximum luminance/OD value | |
DiDisplayLUT * | LookupTable [MAX_NUMBER_OF_TABLES] |
array with pointer to the different lookup tables (here: 8-16 bits) | |
Static Protected Attributes | |
static const int | MinBits |
constant defining minimum value for number of bits for LUT input (here: 8) | |
static const int | MaxBits |
constant defining maximum value for number of bits for LUT input (here: 16) | |
Private Member Functions | |
DiDisplayFunction (const DiDisplayFunction &) | |
DiDisplayFunction & | operator= (const DiDisplayFunction &) |
Definition at line 58 of file didispfn.h.
|
output device type
Definition at line 65 of file didispfn.h. |
|
constructor, read device characteristics file. Keywords: "max" for maximum DDL (device driving level, required at first position) "amb" for ambient light and "lum" for illumination (both optional) "ord" for the order of the polynomial curve fitting algorithm used to interpolate the given base points (0 or absent = use cubic spline interpolation)
|
|
constructor, use given array of luminance/OD values. UNTESTED Values must be sorted and complete (i.e. there must be an entry for each DDL). The given arrays are copied internally.
|
|
constructor, use given array of DDL and luminance/OD values. UNTESTED Values will be automatically sorted and missing values will be interpolated. The given arrays are copied internally.
|
|
constructor, compute luminance/OD values automatically within the specified range. Initial values for hardcopy: "lum" = 2000, "amb" = 10, for softcopy: "amb" = 0.
|
|
calculate minimum and maximum luminance/OD values
|
|
check whether Dmin and Dmax are properly specified. report a warning message if "Dmin >= Dmax".
|
|
convert the given OD value to luminance. This function uses the specified ambient light and illumination values.
|
|
convert the given OD value to luminance. This function uses the currently set ambient light and illumination values.
|
|
create a table with luminance values from the given OD table. Uses the currently set ambient light and illumination value. The resulting luminance table has to be deleted by the caller.
|
|
create a sorted (by DDL) table from the given DDL and luminance/OD tables
|
|
delete specified LUT
Referenced by DiMonoImage::deleteDisplayLUT(). |
|
get (reflected) ambient light value. measured in cd/m^2.
Definition at line 254 of file didispfn.h. References AmbientLight. |
|
get the DDL for a given luminance/OD value. Determines the DDL from the device's characteristic curve which is mapped to the closest possible luminance/OD value. Please note that neither ambient light/illumination nor min/max densitity are used.
|
|
get output device type (monitor, camera, printer or scanner)
Definition at line 161 of file didispfn.h. References DeviceType. |
|
create display LUT with specified number of entries (abstract method)
Implemented in DiCIELABFunction, and DiGSDFunction. |
|
get illumination value. measured in cd/m^2.
Definition at line 275 of file didispfn.h. References Illumination. |
|
create look-up table with specified number of entries
Referenced by DiMonoOutputPixelTemplate< T1, T2, T3 >::createDisplayLUT(), and DiMonoOutputPixelTemplate< T1, T2, T3 >::overlay(). |
|
get maximum DDL value. The minimum DDL value is always 0.
Definition at line 171 of file didispfn.h. References MaxDDLValue. |
|
get maximum optical density value "Dmax". measured in optical density (OD).
Definition at line 316 of file didispfn.h. References MaxDensity. |
|
get maximum luminance value "Lmax". measured in cd/m^2. value is computed from "Dmin".
|
|
get maximum luminance/OD value from the characteristic curve. In case of a usually monotonous characteristic curve the value is equivalent to the last/first entry of the array.
Definition at line 193 of file didispfn.h. References MaxValue. |
|
get minimum optical density value "Dmin". measured in optical density (OD).
Definition at line 296 of file didispfn.h. References MinDensity. |
|
get minimum luminance value "Lmin". measured in cd/m^2. value is computed from "Dmax".
|
|
get minimum luminance/OD value from the characteristic curve. In case of a usually monotonous characteristic curve the value is equivalent to the first/last entry of the array.
Definition at line 182 of file didispfn.h. References MinValue. |
|
get order of the polynomial curve fitting algorithm. used to interpolate the given base points.
Definition at line 350 of file didispfn.h. References Order. |
|
get the luminance/OD value for a given DDL. Looks up a luminance/OD value in the device's characteristic curve. Please note that neither ambient light/illumination nor min/max densitity are used.
|
|
check whether DisplayFunction is valid
Definition at line 152 of file didispfn.h. References Valid. Referenced by DiMonoOutputPixelTemplate< T1, T2, T3 >::createDisplayLUT(), and DiMonoOutputPixelTemplate< T1, T2, T3 >::overlay(). |
|
read the given device characteristics file
|
|
set (reflected) ambient light value. measured in cd/m^2. applicable to softcopy and hardcopy devices. typical values: 0.5-5 for softcopy devices, 10 for transmissive hardcopy printer and 0 for reflective hardcopy printers.
Reimplemented in DiGSDFunction. |
|
set illumination value. measured in cd/m^2. applicable to hardcopy devices only. typical values: 2000 for transmissive hardcopy printer and 150 for reflective hardcopy printers.
Reimplemented in DiGSDFunction. |
|
set maximum optical density value "Dmax". measured in optical density (OD). applicable to printers only. typical value: 3.0
Reimplemented in DiGSDFunction. |
|
set minimum optical density value "Dmin". measured in optical density (OD). applicable to printers only. typical value: 0.2
Reimplemented in DiGSDFunction. |
|
write curve data to a text file (abstract method)
Implemented in DiCIELABFunction, and DiGSDFunction. |