The present invention relates to the field of colour measurement.
The present invention relates more particularly to a method of spectrometry for measuring the colour of an object that makes use of an electronic device, and to the associated device.
A colour is a luminous flux perceived by the human eye. It involves a spectral distribution of energy C(λ) on a band of wavelengths, in this case λ ranging from 380 to 780 nm in the visible range (standard observer as defined by the Commission Internationale de I'Eclairage—CIE/International Commission on Illumination 1931). In the following sections, the function that describes this spectral energy distribution shall be denoted by a letter and a λ within brackets.
On account of the additive synthesis approach, any colour may be expressed by its chromaticity coordinates in three primary colours. While there are several primary colour systems, those adopted in the following sections will be the two standardised systems which are the CIE XYZ colorimetric space (and its variant CIE Yxy with chromaticity plane at constant luminance) and the CIE L*a*b space which provides the ability to estimate a colour difference with Euclidean norm known as “deltaE”, which is representative of the differences in colour perceived by the human eye. The “gamut” (limits) of these two spaces covers the entire human visible range. Reference will also be made to the trichromatic sRGB space corresponding to the reference gamut of most of the electronic equipment currently available. The gamut of sRGB does not cover the entire human visible range, especially in the blue-green spectrum.
The colour of an object results from the interactions between an incident luminous flux and the surface of the said object. Three phenomena vie with each other to give the material the appearance by which it is known: absorption, specular reflection and diffuse reflection. Specular reflection occurs on the surface of the object. There is little interaction of light with the material of the object—and in particular with its pigments. The colour of the light reflected is thus close to the light received, but the energy reflected is concentrated in a lobe centred in the theoretical direction defined by the Snell-Descartes laws. In contrast, diffuse reflection occurs at greater depth. The light emitted is tinged with the colour of the pigments and the energy reflected is independent of the direction of observation. In other words, the specular reflection is the shining component of a surface and the diffuse reflection is the matte and coloured component of a surface.
Consequently, the colour of an object thus depends on two independent factors: the illumination to which the object is subjected and the nature of the surface of the object. This latter is characterised by the “bidirectional spectral reflectance” function. It is defined as the ratio between the luminance reflected from the surface and the illumination of the latter. The value of this function depends on the wavelength λ, on the direction of the incident light and the direction of observation. The uniform diffuse reflectance of the object ROBJ(λ), corresponding to the diffuse reflection, depends only on the wavelength λ. It is this that gives the colour information in the chromatic sense, outside of the shine phenomenon.
This is why the colour of an object may be characterised 1) by the light reflected under a given illuminant (for example the CIE L*a*b chromaticity coordinates under an illuminant D50 in a dark room), or better still, 2) by its spectral reflectance ROBJ(λ). The first method requires relatively simple measuring devices (including colour charts, tri-stimulus colorimeters, among others), but with a high risk of metamerism (this method is not very accurate). Its use is generally restricted to the monitoring of deviations from a standard or benchmark colour along a manufacturing process (printing, textile, graphic arts, etc). The second method requires more sophisticated devices (including among others, diffraction spectrometer, spectrometer with dual photoreceptors in parallel); it is not affected by metamerism (this method is very accurate) and makes it possible to simulate the perception of colour under different illuminants (interior, exterior). It is designed for use by demanding professionals and in design activities.
All these devices are not compatible with mobile, hand held and unplanned use as with a mobile phone or a tablet computer that can be taken anywhere. Their use is relatively complicated, not to mention the significant additional cost that they represent.
In contrast, applications for measurement of colour currently available on mobile phones and tablets (iOS, Android, etc) do not require additional specialised equipment, but these applications do not provide for an accurate measurement of colours. Indeed, they rely solely on the use of the colour image sensor of the device (array of tri-stimulus photodetectors, Bayer red-green-blue matrix) with a programme for the computing of white balance. Their perception of the colours of objects is thus distorted by the unknown variability of ambient light.
Known techniques from the prior art include the emissive diffraction spectrometer and a method for determination of the function of spectral reflectance of the object: the device produces a standardised white illuminant S(λ) in the direction of the target, the illuminant is reflected on the object, then passes through a prism to be diffracted towards several dozens of photodetectors (one for each sub-spectrum) which provides the ability to interpolate E(λ), where ROBJ(λ)=E(λ)/S(λ). The operation of measuring the colour of an object with this method of the prior art is carried out with a specially developed boxed unit and with a process requiring a cover for masking any unknown external illuminant. In addition, this type of spectrometer cannot be used to perform spectrometric photography.
The prior art also provides knowledge from the U.S. Pat. No. 5,963,333, of a spectrometer with LED and two photoreceptors arranged in parallel, a spectrometer detection unit and a method for determining the function of spectral reflectance of the object. The measurement of colour of an object with this method of the prior art is carried out by means of a specially developed boxed unit and with a process requiring a cover for masking any unknown external illuminant. In addition, this type of spectrometer cannot be used to perform spectrometric photography.
The prior art also provides knowledge through the patent application PCT No WO 2004/079314, of a colorimeter, a colorimeter detection unit and a method for determining the colour of an object by calculating a deviation from a standard colour. The operation of measuring the colour of an object with this method of the prior art is carried out with a specially developed boxed unit, a process requiring a cover for masking any unknown external illuminant, and a method that is incapable of measuring a spectral reflectance function in the strictest sense.
The prior art also provides knowledge through the UK patent application No GB2474701A, of a colorimeter, a colorimeter detection unit and a method for determining the colour of an object by calculating a deviation from a standard colour. The operation of measuring the colour of an object with this method of the prior art is carried outby means of a telephone equipped with a screen for emitting flashes of colour and a camera unit on the opposite face. The measurement of colour with this method of the prior art is performed with specially developed waveguides (sets of mirrors, optical fibres, etc), a process requiring a cover or waveguides for masking any unknown external illuminant, and a method that is incapable of measuring a spectral reflectance function in the strictest sense.
The present invention seeks to overcome the drawbacks of the prior art by providing a method for measuring the colour of an object through spectrometry by using as a transmitter a means capable of emitting colour illuminants, and as a receiver, an electronic colour image sensor, the two situated side by side, with or without the presence of an unknown external illuminant (but constant for all the flashes).
In principle, the present invention operates contrary to a diffraction emission spectrometer: instead of generating a single standardised illuminant and analysing it with several dozens of photodetectors, the present invention generates several dozens of standardised illuminants and analyses them with only three photodetectors.
To this end, the present invention relates, in its most general sense, to a method for measuring the uniform diffuse reflectance ROBJ(λ) at least at one point of an object by using a device comprising a means capable of emitting coloured illuminants expressed in the form of luminous flux and an electronic colour image sensor, characterised in that it comprises the following steps:
Thus, the method according to the present invention provides the ability to precisely measure the uniform diffuse reflectance of an object at least at one point, and this in an optimised manner compared to the solutions described in the prior art. In addition, the present invention works very well with daily use mobile or handheld devices.
Advantageously, the said method further includes a step of determining the value of the external illuminant Iext(λ).
Preferably, the said method includes in addition, a step of transcription of the function ROBJ(λ) of uniform diffuse reflectance at least at one point of the object into the CIE XYZ coordinates for a given illuminant.
According to one embodiment, the number of flashes is of the same order of magnitude as the number of interpolation points for determining the values of the uniform diffuse reflectance ROBJ(λ) at least at at one point of the object and of the external illuminant Iext(λ).
According to one variant, the said method includes a step of determining the values of the uniform diffuse reflectance ROBJ(λ) at least at one point of the object and the external illuminant Iext(λ) in several spectral bands.
According to one embodiment, the said device makes use of a screen for emitting flashes of colour and an electronic image sensor for sensing and capturing the light reflected by the target object.
According to a particular mode of implementation, the said device is a camera unit or a camera with in built or removable flash.
Advantageously, the said device implements waveguides for ensuring effective transiting of the emission and reception of flashes of colours.
According to one variant, the said method is implemented in order to take spectrometric photographs of objects and to make chromatic adjustments (balancing of whites) at will.
According to another variant, the said method according to one of the preceding claims, characterised in that it is implemented in order to measure the colour of an element included in the following group: materials, solids, liquids, gases, paintings, tapestries, graphics, textiles, plastics, woods, metals, soils, minerals, plants and foods.
According to one embodiment, the method is implemented for the measurement of colours, for medical or cosmetic purposes with respect to humans and living beings/organisms, of at least one element included in the following group: skin, pimples, moles, hair, fur/hair coat, makeup, and teeth.
According to a variant, the said method is implemented for the use of colour barcodes, of one or more dimensions.
According to a particular mode of implementation, the method is implemented with a view to assisting people having colour blindness and/or who are blind.
The present invention also relates to a device comprising the means capable of emitting colour illuminants in the form of luminous flux of colours and an electronic colour image sensor, for measuring the uniform diffuse reflectance ROBJ(λ) at least at one point of an object placed in a zone located opposite and substantially perpendicular to the said means capable of emitting colours and located in the field of vision of the said electronic colour image sensor, and also being subjected to an external illuminant in the form of a constant and unknown external environmental luminous flux denoted as Iext(λ), characterised in that it comprises the means for:
The invention will be better understood with the aid of the description, provided here below for purely explanatory purposes, of an embodiment of the invention, with reference to the Figures in which:
By way of a preliminary remark, it should be noted that the notations in this section are as follows: sensor=electronic colour image sensor (the video function is not used in the context of calibration and benchmarking, only the taking of static images is used), source=source of illuminants/flashes of colours (screen, diode(s), laser(s), etc). (R, G, B)sourcei=non-linear input chrominance parameters of the source of colour illuminants (RGBWsource i or RGBYsource i for the devices with 4 and more primaries), BLsource i=non-linear input luminance parameter of the source of colour illuminants (for example the back lighting of a LCD screen); (R, G, B)capteur i=non linear output chrominance parameters of the luminous flux captured by the colour image sensor, BVcapteur i=non linear output luminance parameter of the luminous flux captured by the colour image sensor (for example Brightness Value of Japanese standardEXIF—Exchangeable Image File Format); OBJ=colour object to be measured; EXT=external environmental illuminant; R/G/B=equation valid for each primaryred (red) or green (green) or blue (blue); OBJ/EXT=equation valid for the coloured objector foroutside external illuminant; x/y/z(λ)=equation valid for each spectralsensitivity X(λ), y(λ) and z(λ); spectralsensitivities of the CIE 1931 standard observer=xEC_CIE_1931 (λ), yEC_CIE_1931 (λ), zEC_CIE_1931 (λ) for λε [380 nm; 780 nm]; spectral sensitivities of the electronic colour image sensor: xEC_capteur (λ) yEC_capteur (λ), zEC_capteur (λ), The superscript notations EC_XXX signify that it is situated in the XXX colorimetric space.
In the figures and the exemplary embodiment described here below, the means 11 capable of emitting colours is an emissive display screen. It is understood that this means 11 capable of emitting colours may also be one or more multicolour diode(s), one or more multicolour laser(s), one or more coloured flash(es) or any other means capable of emitting “colours” (a “colour”=a spectral energy function in the range of wavelength considered). Moreover, in the figures and the exemplary embodiment described here below, the colour of the object is reduced to the uniform diffuse reflectance. It is understood that the said method is capable of capturing the other components of reflectance, in particular specular reflectance for objects with high shine and satin like shine via the display on the screen of a white figure on a black background and the detection of the resultant specular reflection lobe by a gradient analysis in the image focal plane of the colour image sensor.
In one embodiment, the computer application 13 is partially or totally distributed in the network or “cloud” (“cloud” in Anglo-Saxon terminology).
A consequence of
Now a description will be provided of the treatment process for determining the unknowns ROBJ(λ) and IEXT(λ) from the N flashes of colour.
In the embodiment shown in
Then the source 11 successively emits a succession of flashes of colours based on the flashing algorithm described in the Annexe 1 which seeks to optimise the conditioning of the matrix A, while remaining within the screen and camera gamuts and ensuring that the external illuminant remains constant over the course of the flashes.
This algorithm takes as input a valid number of flashes N required. N depends on the number n of interpolation points required to determine the functions ROBJ(λ) and Iext(λ). At a minimum, 3*N≧(2n+2) in order for the system A*X=B to be property determined (see the end of the Detailed Description), thus N≧2/3*(n+1).
The flashing algorithm returns as output a sequence of N valid flashes, with for each flash, the input parameters of the source and the output parameters of the sensor. The index of the sequence of flashes is denoted as i.
Note: If the accuracy required in order to determine the functions ROBJ(λ) and Iext(λ) is of the order of 10 nm, N≈n≈30. Taking into account the reactivity of present day common electronic components, the entire flashing cycle takes about ten seconds at a maximum. For a non-uniform target (for example a texture), the method uses an algorithm for image stabilisation with at least one point of contrast.
Note: If the source of the flashes of colours 11 is an emissive display screen, it is capable of generating a large number of flashes of colours, typically N being able to reach 224=16.7 million for 3×8 bit RGB systems.
For each flash i, the light emitted by the source 11 is reflected on the coloured target 30 and then it enters in the image sensor 12 which gives the equation (Ei): Ecapteur(λ)i=ROBJ (λ)*(Ssource(λ)i+Iext(λ)).
Developing the equation (Ei): Ecapteur(λ)i=ROBJ(λ)*[Ssource(λ)i+Iext(λ)]=ROBJ(λ)*Ssource(λ)i+ROBJ(λ)*Iext(λ);
Let's write IEXT REF(λ)=ROBJ(λ)*Iext(λ)
The equation (Ei) becomes: Ecapteur(λ)i=ROBJ(λ)*Ssource(λ)i+IEXT REF(λ)
Firstly, the method will interpolate the functions ROBJ(λ) and IEXT REF (λ) with the use of a sealed cubic spline function and (nOBJ/EXT REF+1) interpolation points of coordinates [xk=λOBJ/EXT REFk: yk=yOBJ/EXT REFk] for k=0 to nOBJ/EXT REF such that:
the zero slope of the splines is zero at the ends: p0=p nOBJ/EXT REF=0
The yOBJ/EXT REFk are the unknowns that the method will determine.
As the functions ROBJ(λ) and IEXT REF(λ) are sealed spline functions with zero slope at the ends, ROBJ(λ) and IEXT REF(λ) can be written in a linear form:
with:
These α αl,kOBJ/EXT REF are calculated by the inversion (by pivot) of the following linear system, characteristic of sealed cubic spline functions; they are only a function of λl (l=0 to nOBJEXT REF):
Secondly, the method knows the transfer function of the source of flashes of colours fsource that gives the functions Ssource (λ)l based on input parameters of the source of chrominance (R, G, B)source (Csource R/G/B i) and the source of luminance BLsource i=Csource BL i. This transfer function is determined based on the “factory” theoretical output values of the electronic device and/or from a calibration done prior to the measurement. It is unuseful to necessarily redo this calibration prior to each measurement of colour. This transfer function is also available for devices with 4 and more primary colours (red-green-blue-white, red-green-blue-yellow, etc).
By way of Illustration, one form of the transfer function of the source is the following it being clarified that general consumer electronic devices usually seek to comply with the sRGB standard:
Thirdly, the method knows the transfer function of the electronic colour image sensor fcapteur that gives the chromaticity coordinates (X, Y, Z)EC_mesure i in the colorimetric space of measurement of the luminous flux Ecapteur(λ)i entering in the sensor, as a function of its output parameters of chrominance (R, G, B)capteur i=(Ccapteur R/G/B i) and of luminance BVcapteur i=(Ccapteur BV i). This transfer function is determined based on the “factory” theoretical output values of the electronic device and/or from a calibration done prior to the measurement. It is unuseful to necessarily redo this calibration prior to each measurement of colour.
By way of Illustration, one form of the transfer function of the electronic colour image sensor is the following it being clarified that general consumer electronic devices usually seek to comply with the sRGB standard:
Now developing the equations (E) by integrating them on the intersection of the spectra of the sensor and the source [λ1mesure; λ2mesure] (see
By interchanging the order of summations, the equations (Ei integrated) become:
Let's write nOBJ+EXT REF=(nOBJ+1)+(nEXT+1);
Let's write the vector XOBJ+EXT REF of dimension nOBJ+EXT REF such that: (XOBJ+EXT REF)T=(yOBJ 0, . . . , yOBJ nOBJ, yEXT REF 0, . . . , yEXT REF nEXT REF); (XOBJ+EXT REF)T=XOBJ+EXT REF 1, . . . , XOBJ+EXT REF nOBJ+EXT REF);
Let's write the variables φOBJ+EXT REF (i,k*, X/Y/ZEC_mesure) such that:
The equations (Ei integrated) may be written in the form of the following 3*N equations with the only unknowns being the XOBJ+EXT REF k:
fcapteur(Ccapteur R/G/B/BVi)X/Y/ZEC_mesure=Σk=1n
Let's write the Jacobian matrix A of dimension (3*N, nOBJ+EXT REF):
Let the vector B equal to fcapteur (Ccapteur R/V/B/BV i) X/Y/ZEC_mesure of dimension 3*N (i comprised between 1 and N).
The equations (Ei integrated) then form the linear system A*X=B.
The method will use the linear least squares algorithm for minimizing ∥A·X−B∥2. The minimum is reached for: Xmin=(AT·A)−1·AT·B, hence the values of the interpolation points of ROBJ(λ) and IEXT REF (λ) and thus IEXT(λ)=ROBJ(λ)/IEXT REF (λ).
There are three conditions to be met: it is shown that the matrix AT·A is invertible if and only if A is injective, which is true with
Σl=1NSsource(λ)i>0 over the interval [λ1mesure; λ2mesure] and with h=max (λk+1−λk) sufficiently small. The mathematical demonstration is described in Annexe 2. In addition, XOBJ+EXT REF k≧0 for all the k because they are the ordinates of energy flow.
The first condition is satisfied by the construction of [λ1mesure, λ2mesure] as the intersection of the source and sensor spectra (see
As regards the third condition, the search to find Xmin is performed under the constraining condition XOBJ+EXT REF k≧0 for all the k, by using, among others, the NLLS (Non Linear Least Squares) algorithm of Lawson and Hanson (Jet Propulsion Laboratory of the National Aeronautics and Space Administration—NASA, Solving Least Squares Problems; SIAM Editions) or, more generally, a quadratic optimisation algorithm.
Note: The process is possible with other interpolation functions in linear or non-linear mode. The non-linear mode is also to be considered for moving from a system of 3*N equations based on the X/Y/ZEC_mesure components to a system of N equations in the form of Euclidean type standards (∥ . . . ∥2) or of deltaE type of coordinates (X, Y, Z)EC_mesure.
Note: The method works on the one hand, with sensors that provide access to the coordinates (R,G,B_raw) and, on the other hand, with the sensors that do not provide access to the coordinates (R, G, B_raw), that do not provide access to the values of the white balance matrix, but provide the ability to lock the white balance values during the flashing process. In this second case, the values of the white balance matrix become additional unknowns to be determined (9 at the maximum). In order to solve this A′X=B system with increased white balance unknowns, the technique consists of increasing the number of flashes so as to have available an over-determined system, and then to solve either in the non-linear mode or in the linear iterative mode in the following manner (inter alia, when the possible values of parameters of the white balance are comprised within a finite set of discrete values): QR decomposition of the system with 2 blocks (X | White Balance), determination of X with the first block by developing a hypothesis with respect to the parameters of white balance, injection of values of X into the second block, determination of the parameters of white balance, and then reinjection into the first block in order to iterate X, and so on.
Two embodiments for viewing are possible for the invention in “colorimeter” mode in order to enrich the user experience and to improve the accuracy of the “colour chart” mode of the invention:
The screen 11 displays a white figure on a black background (round/bands/square . . . ) so as to materialise the place to be viewed, then the user presses on the shutter release button normally used to take a photo (see button on the side for an iPhone S or at the bottom of the screen away from the position of the video conference camera).
A particular point of interest of this first embodiment is to be insensitive to the light environment which ensures the operation of the invention in virtually all the usual places, even those very brightly lit (interiors, exteriors). This quality is based on the very short distance between the target, the screen 11 and the image sensor 12, on the high brightness of the field emission display screens and on the fact that there are several “barriers” indeed serving as blocks to the surrounding light rays: the support for the display screen and the image sensor, hand/finger(s) of the user on the sides.
The display screen 11 is placed facing towards the external illuminant, typically facing the sky. The user then comes to place on the top of the screen the coloured object to be measured (part close to the image sensor). In order to facilitate the manoeuvre, the screen 11 is divided into two parts, the upper part close to the image sensor 12 is used to emit the luminous flux for the measurement, the lower part serves to provide a feedback loop to the user on the place that is pointed (wysiwyg).
A particular point of interest of this second embodiment is the ability to measure the reflectance of the screen Recran (λ).
The device 10 according to the present invention makes it possible to transform into a spectrometer any electronic equipment unit having a field emission display screen 11 and an image sensor 12 located on the side, including amongst others, phones, tablets, PDAs (personal digital assistants), computers and monitors/TVs equipped with a video conferencing camera. It is also intended for example for cameras and camcorders having a swivel/removable screen.
The device 10 according to the present invention offers the possibility of opening up new avenues for mobile or hand held uses for accurate measurement of absolute colour in a daily context, without requiring a dedicated device. The following list is not exhaustive:
The invention is described in the foregoing sections solely by way of example. It is understood that the person skilled in the art is capable of developing different variants of the invention without however in any way departing from the scope of the patent.
Introduction
The present annexe defines a flashing algorithm that is aimed at optimising the conditioning of the matrix A by seeking to exclude to the maximum possible degree the said flashes and to distribute them in as homogeneous a manner as possible in the colorimetric measurement space, while remaining within the gamuts of the source and the electronic image sensor and while also ensuring that the exterior illuminant remains constant during flashes.
Description of the Flashing Algorithm
The said algorithm takes as input a number of required valid flashes N.
The said algorithm returns as output a sequence of N valid flashes (with for each flash, the input parameters of the source and the output parameters of the sensor. The index of this sequence of flashes is denoted as i (flash_i).
The said algorithm interacts with the method and the device according to the invention that emit flashes of colours towards a target object and that capture the reflected light with an electronic image sensor (including among others, a smartphone with the screen that emits flashes and the video conferencing camera which captures light reflected by the target object).
The said algorithm works in the presence of an external illuminant Iext (λ).
The algorithm is broken down into 4 main “phases”, and each phase into “steps”:
Notation: In the sections that follow, the coordinates (dispR %, dispG %, dispB %) denote the chrominance input parameters of the source of the flashes of colours as a percentage ([0, 1]). DispBL % denotes the luminance input parameter of the source of the flashes of colours as a percentage ([0;1]). In practice, they are binary values, generally ranging between 0 and 255 (dispECMY, dispECMx, dispECMy) denote the coordinates of the luminous flux emitted by the source in the colourimétrique space YxyEC_mesure.
Notation: In the sections that follow, the coordinates (camR %_k, camG %_k, camB %_k) denote the chrominance output parameters of the electronic image sensor as a percentage ([0;1]). In practice, they are binary values, generally ranging between 0 and 255. camBv denotes the Brightness Value which is the luminance output parameter of the electronic image sensor (see standard EXIF). (camECMX, camECMY, camECMZ) and (camECMY, camECMx, camECMy) denote the coordinates of the luminous flux emitted by the source respectively in the colorimetric space XYZEC_mesure and in the chromaticity diagram thereof.
Notation: In the sections that follow, the values dispEps and camEps signify that the values of the threshold below which the input values of the source and the output values of the sensor shall be considered to be nil.
Phase 1: Emission of a Flash “black 1”
The objective of Phase 1 is twofold: to check whether the external illuminant is compatible with the physical limitations of the device and to check to ensure that external illuminant is constant during the flashing.
The algorithm outputs a “black” flash, that is to say, it performs a measurement with the source switched off, that is dispR %=dispG %=dispB %=0 (and dispBL=0 if possible).
The algorithm is faced with two possible cases:
Note: In this present Annexe 1, there is mention of only two black flashes for checking the constancy of the external illuminant, a first one at the beginning of the flashing and a second one at the end. Depending on the conditions of use of the device according to the invention, it is quite possible to reduce or increase the number of black flashes to check the constancy of the external illuminant.
Phase 2: Finding the 3 Vertices that Maximise the “Flashing Triangle”
The objective of Phase 2 is to build a “flashing sub-gamut” of maximum size for a given precision, while remaining compatible with the colour gamut of the source of light flashes and that of the electronic image sensor.
Let's define the function f: (dispECMx, dispECMy)→(camECMx, camECMy) of the gamut of the source of the flashes of colours to the gamut of electronic image sensor.
The “source-sensor sub-gamut” is defined as being the intersection of the gamut of the sensor and the image by f of the gamut of the source. The source sub-gamut is defined as being the inverse image by f of the sensor sub-gamut.
In other words, the objective of Phase 2 is to determine a triangle included in the “sensor-source sub-gamut” of maximum size for a given precision. This triangle is called “flashing triangle”.
Step 1: Finding a Pivot
The purpose of Step 1 is to define a flash pivot within the sensor gamut.
The algorithm goes to step 1.1 by using a pre-defined flash pivot value for the iteration k=1, for example a white flash of maximum luminance (dispR %_1=dispG %_1=dispB %_1=dispBL %_1=1).
Step 1.1: Testing of a Flash Pivot of Index k
The purpose of step 1.1 is to test whether the proposed flash pivot of index k is within the sensor gamut.
The algorithm asks the source to generate the flash pivot k and it retrieves the output coordinates of the sensor (camR %_k, camG %_k, camB %_k, camBv_k).
The algorithm is faced with two possible cases:
Step 1.2: Generation of a New Flash-Pivot of Index k+1
The purpose of Step 1.2 is to generate a new flash pivot of index k+1 that is within the sensor gamut unlike the previous flash pivot of index k.
The algorithm is faced with two possible cases depending upon (camR %_k, camG %_k, camB %_k)
The algorithm proceeds to step 1.1 with this flash pivot k+1
The algorithm goes to step 1.1 with this flash pivot k+1.
Step 2: Shortcut for Going from the Flash Pivot to a First Flashing Triangle of a Lane Size
The purpose of Step 2 is to save on flashes so as to cause the increase in size of the flashing triangle around the flash pivot.
To do this, the algorithm has available a database with the input of the input and output values of reference flashes and with the outputting of the coordinates of the associated flash triangles. This database is thus a shortcut for causing the flashing triangle to grow.
More specifically, the algorithm frames the flash pivot with the 3 closest reference flashes (in the sense of a Euclidean norm in the measurement space). Then it mixes the coordinates of the reference flashing triangles by using the barycentric coordinates of the flash pivot in the triangle of the 3 reference flashes. The algorithm thus obtains a flashing triangle of large size around the flash pivot. It then performs a homothetic transformation or homogeneous dilation of ratio K<1 on this triangle with respect to the flash pivot so as to take a safety margin and it asks the source to emit the 3 flashes of colour corresponding to the three vertices of the said triangle. The algorithm then goes to the step 4.1 for analysing the results.
If the algorithm is not able to frame the flash pivot with 3 reference flashes, it selects the closest reference flash from the database (if this latter is sufficiently close in relation to an adjustable threshold) then it causes the 3 flashes to be emitted as before and it goes to the step 4.
If there is no reference flash sufficiently close in the database, the algorithm proceeds to step 3.
Step 3: Passage from the Flash Pivot to a First Flashing Triangle of Small Size
The purpose of the Step 3 is to create a first flashing triangle of small size by using three points, the first being the sensor output for the flash pivot (camR %_k, camG %_k, camB %_k).
The algorithm orders the values (camR %_k, camG %_k, camB %_k), and then generates two new flashes, the first having more (in proportion) of the lowest component, the second having more of the two lowest components.
By way of illustration, if camG %_k<camR %_k<camB %_k, the algorithm outputs a first flash having more (in proportion) of the green component, and then a second flash having more of the green component and more of the red component.
Step 3.1: Testing of the Flashing Triangle of Small Size
The purpose of step 3.1 is to test whether the small sized flashing triangle is included in the sensor gamut.
The algorithm is faced with 3 possible cases:
Step 3.2: Generation of a New Flashing Triangle of Small Size
The purpose of step 3.2 is to generate a new small sized flashing triangle by replacing the flashes whose sensor output has exited out of the sensor gamut.
The algorithm replaces the flash or flashes that have failed by adding less of the components added. The algorithm proceeds to step 3.1 with this new base.
Step 4: Maximisation of the Size of the Flashing Triangle
The purpose of step 4 is to construct the flashing triangle of the maximum size for a given precision.
The transformation f is assumed to be linear and the algorithm determines this transformation by using the data from the three points of the base of the sensor gamut. The algorithm infers therefrom the source-sensor sub-gamut and then determines the flashing triangle with maximum surface area included in this sub-gamut. It then performs a homothetic transformation or homogeneous dilation of ratio K<1 on this triangle with respect to the flash pivot so as to take a safety margin and it asks the source to emit the 3 flashes of colour corresponding to the three vertices of the said triangle. The algorithm then goes to the step 4.1 for analysing the results.
Step 4.1: Testing of a Flashing Triangle of Order k
The purpose of step 4.1 is to test whether the flashing triangle is included in the sensor gamut.
The algorithm is faced with two possible cases:
Step 4.2: Generation of a New Vertex of Index k+1 of the Flashing Triangle Following the Exit from the Sensor Gamut of the Vertex of Index k
The purpose of step 4.2 is to generate a new vertex of index k+1 of the flashing triangle within the sensor gamut unlike the vertex of index k and with coordinates (camR %_k, camG %_k, camB %_k).
The algorithm is faced with two possible cases depending upon (camR %_k, camG %_k, camB %_k):
The algorithm proceeds to the step 1.1 with this flash pivot of k+1.
The algorithm proceeds to the step 1.1 with this flash pivot k+1.
Step 4.3: Generation of a New Vertex for the Flashing Triangle Because of the Insufficient Size of the Flashing Triangle
The purpose of step 4.3 is to enlarge the flashing triangle because at least one of its vertices is too far from the vertex of the closest sensor gamut and the flash flash_k_1 corresponding to this vertex is also too far from the vertex of the closest source gamut.
To be noted are flash_k_2 and flash_k_3 the two flashes whose sensor outputs are the other two vertices of the flashing triangle.
The algorithm generates two flashes respectively barycentre of the system {(flash flash_k_1, a), (flash flash_k_2, 1−α)} and barycentre of the system {(flash flash_k_1, α), (flash flash_k_3, 1−α)} (for example: α=0.2). These two flashes and the flash flash_k_1 form a triangle on which the transformation f is assumed affine. The algorithm determines this transformation by using the data from the three points and infers therefrom the source-sensor sub-gamut and then determines the vertex that provides the ability to obtain the flashing triangle with maximum surface area included in this sub-gamut. It then performs a homothetic transformation or homogeneous dilation of ratio K<1 on this point with respect to the preceding vertex so as to take a safety margin and it asks the source to emit the flash of colour corresponding to the said point. If the sensor output exits out of the sensor gamut, the algorithm repeats the operation with a higher margin (smaller K), otherwise the sensor output replaces the preceding vertex and forms along with the other vertices a new flashing triangle. The algorithm proceeds to the step 4.1 with this new flashing triangle.
Phase 3: Homogeneous Completion of the Number of Valid Flashes Required
The objective of Phase 3 is to generate a sequence of N flashes whose sensor outputs are distributed in a homogenous manner within the flashing triangle defined during the Phase 2.
The algorithm thus has available the coordinates of the vertices of the flashing triangle as well as a certain number of intermediate flashes that were used to determine the flashing triangle during the phase 2 (at least one: the flash pivot). These points are denoted as (camECMx_k, camECMy_k).
Step 1: Generation of a Grid of N Points in the Flashing Triangle
The purpose of step 1 is to generate a grid of N points distributed in a homogeneous manner within the flashing triangle.
The algorithm generates a grid of N points distributed as described in
The algorithm proceeds to the Step 2 with this grid of N points within the flashing triangle, denoted as (camECMx_g_k, camECMy_g_k).
Step 2: Generation of a Flash
The purpose of this step 2 is to generate flashes whose sensor output approximates ideal points located on the grid defined during the step 1.
For each point (camECMx_g_k, camECMy_g_k), the algorithm determines the triangle with vertices of three unaligned points(camECMx_k, camECMy_k) which minimizes the sum of squares of the distances from the point (camECMx_g_k, camECMy_g_k) to the vertices of the triangle. This sum is referred to as the distance to the triangle.
The algorithm chooses the point (camECMx_g_k, camECMy_g_k) whose distance to the triangle is the smallest.
The transformation f is assumed to be linear on this triangle and its neighbouring triangles, and it is determined using the data from the 3 vertices of the triangle. The algorithm thus determines the flash (dispECMx_g_k, dispECMy_g_k) the sensor output of which will be (camECMx_g_k, camECMy_g_k).
If the sensor output for the flash (dispECMx_g_k, dispECMy_g_k) exits out of the sensor gamut, the flash is not retained.
The point (camECMx_g_k, camECMy_g_k) is removed from the list of points to be brought close.
The algorithm is faced with two possible cases:
Step 3: Selection of Flashes to be Returned
The algorithm selects only the flashes whose sensor output is sufficiently close to a point of the grid generated in step 1 (in the sense of the Euclidean distance in the colorimetric space of measurement). If two points are sufficiently close to a point in the grid, then only the closest point is selected. The algorithm then passes on to the phase 4.
Note: if at least one flash whose sensor output is strictly included within the sensor gamut is selected, then the condition Σi (i=1)TN≡(Ssource (λ)i)>0 over the interval [λ1mesure; λ2mesure] used in the demonstration of the invertibility of AT*A in Annexe 2 is satisfied.
Phase 4: Emission of a Flash “black 2”
The objective of this Phase 4 is to check to ensure that external illuminant is constant during the flashing.
The algorithm outputs a “black” flash, that is to say that it proceeds to perform a measurement with the source switched off, that is dispR %=dispG %=dispB %=0 (and dispBL=0 if possible).
The algorithm is faced with two possible cases:
It is shown that AT*A is invertible in the case where Σl=1NSsource(λ)i>0 over the interval [λ1mesure; λ2mesure] (the flashes cover all of the wavelengths considered for determining ROBJ(λ) and Iext(λ)), and for h=max(λi+1−λi) that is sufficiently small.
Let x be an eigen vector associated with the eigen value μ
There is on the one hand (AT*A·x, x)=(μ·x, x)=μ·(x, x)=μ∥x∥2
And on the other hand (AT*A·x, x)=(A·x, A·x)=∥A·x∥2
Thus μ=∥A·x∥2/∥x∥2
Thus μ is positive and it is so strictly if A is injective.
Thus if A is injective, all the eigen values of AT*A are strictly positive, therefore AT*A is invertible.
Conversely, if A is not injective, there exists non zero x such that A·x=0. Thus one then gets AT*Ax=0 therefore AT*A is not invertible.
Finally, AT*A is invertible if and only if A is injective.
Lemma 1: The Integral of a Sealed Cubic Spline S(λ) with Zero Slopes at the Ends [S(λ)*d λ is Always Positive when all the yi are Positive
Case No 1: If all the yi=0,
Then s(λ)=0 for all the λ due to the zero slopes at the edges, hence Int{S(λ)*dλ}=0
Case 2: If there Exists One y>0 and if all the Other yi are Zero:
y_i creates a “positive belly” over [λi−1; λi]∪[λi; λi+1] (area >0) and “negative bellies” over [λi−2; λi−1] and [λi+1; λi+2] (area <0), and so on up to the edges. As the spline function minimizes the energy of the tongue, the surface area of the positive belly [λi−1; λi]∪[λi; λi+1] is greater than those of the negative bellies [λi−2; λi−1] and [λi+1; λi+2]. This is due to the fact that |pi+1|>|pi+2|> . . . >|pn|=0 and |pi−1|>|pi−2|> . . . >|p0|=0. As a result, the surface area of the positive bellies is greater than the negative bellies and therefore ∫S(λ)*dλ>0
Case 3: If there Exist Two yi>0:
Case no 3.1: yi and yi+1>0 (contiguous): This creates a “large” positive belly. The reasoning given for the case no 2 is applicable.
Case no 3.2: yi and yi+2>0 (yi+1=0): there are 2 positive contiguous bellies. The reasoning given for the case no 2 is applicable.
Case no 3.3: yi and yi+3>0 (yi+1=yi+2): there is 1 positive belly, 1 negative belly, 1 positive belly. The reasoning given for the case no 2 is applicable.
Case no 3.4: yi and yi+k>0 with k>3. Same as previously given for Case no 3.3.
Case 4: If there Exist at Least 3 yi>0 (General Case)
Thus the reasoning given for the cases under Case no 3 is applicable. QED
Lemma 2: The Integral of a Sealed Cubic Spline S(λ) with Zero Slopes at the Ends Multiplied by a Function K(λ)>0 ([S(λ)*K(λ)*dλ) is Always Positive when all the yi are Positive
Lemma 1 (case no 2) is not directly applicable because the term K(λ) can greatly reduce the area of the positive bellies and increase that of the negative bellies.
The trick is to increase the number of interpolation points in order to reduce the surface area of the negative bellies.
Let us be positioned in the scenario of case no 2 of the Lemma 1. The error of a sealed spline is bounded by the following formula: |f(x)−s (x|≦a*h^4 with a=5/384*max[a; b]{|f(4)(E)|}>0 (constant value), and h=max{|xi−xi−1|)}.
That is to say that: f(x)−a*h≦s(x)≦f(x)+a*h
Since f(x)≧0 (ROBJ(λ) and IEXT(λ) are the energy flows), s(x)≧−a*h, thus the maximum surface area of the negative bellies [λi−2; λi−1]∪[i+2] is equal to −2*a*h^2.
The surface area of the positive bellies remains constant because the increase in the number of interpolation points will create multiple contiguous yi>0.
As a consequence, there is an h for which the surface area of the positive bellies is strictly greater than that of the negative bellies.
Returning to the Demonstration
Let x be such that A*x=0 with x formed of the ordinates of the sealed cubic spline with zero slopes at the ends representing ROBJ(λ) and Iext(λ).
Showing that x=0
We get for all i=1, . . . , N and for any sensitivity x/y/z(λ):
∫ROBJ(λ)*Ssource(λ)i*x/y/z(λ)*dλ+∫Iext(λ)*x/y/z(λ)*dλ=0
where ROBJ(λ) and Iext(λ) are the sealed cubic spline functions with zero slopes at the ends.
Summing for the 3*N equations, we obtain:
With x(λ)+y(λ)+z(λ)>0 and Σi=1NSsource(λ)i>0 for all λ, it is deduced from Lemma 2 that there exists a sufficiently small h such that:
and
∫Iext(λ)*(x(λ)+y(λ)+z(λ))*dλ=0
Since ROBJ(λ)=0 and Iext(λ)=0 for all λ,
ie x=0. A is injective. Therefore AT*A is invertible. QED
Number | Date | Country | Kind |
---|---|---|---|
12 51484 | Feb 2012 | FR | national |
12 54559 | May 2012 | FR | national |
12 57403 | Jul 2012 | FR | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2013/053000 | 2/14/2013 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2013/120956 | 8/22/2013 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5659397 | Miller | Aug 1997 | A |
20100067004 | Nagashima | Mar 2010 | A1 |
Number | Date | Country |
---|---|---|
2474701 | Apr 2011 | GB |
2004079314 | Sep 2004 | WO |
Entry |
---|
International Search Report dated Jul. 10, 2013, corresponding to PCT/EP2013/053000. |
Stephen K. Park, et al.; “Estimation of Spectral Reflectance Curves from Multispectral Image Data”; vol. 16, No. 12, Dec. 1, 1977, p. 3107. |
Number | Date | Country | |
---|---|---|---|
20150062584 A1 | Mar 2015 | US |