File: xyTouv.m

package info (click to toggle)
psychtoolbox-3 3.0.17.9.dfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 84,408 kB
  • sloc: ansic: 171,572; cpp: 20,885; objc: 5,164; sh: 1,878; python: 1,366; php: 384; makefile: 193; java: 113
file content (35 lines) | stat: -rw-r--r-- 1,271 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
function uv = xyTouv(xy,compute1960)
% uv = xyTouv(xy,[compute1960])
%
% Convert CIE xy chromaticity to CIE u'v' chromaticity.
%
% These are u',v' chromaticity coordinates in notation
% used by CIE.  See CIE Colorimetry 2004 publication, or Wyszecki
% and Stiles, 2cd, page 165.
%
% Note that there is an obsolete u,v chromaticity diagram that is similar
% but uses 6 in the numerator for v rather than the 9 that is used for v'.
% See CIE Colorimetry 2004, Appendix A, or Judd and Wyszecki, p. 296. If
% you want this (maybe to compute correlated color temperatures), you can
% pass this as 1.  It is 0 by default.
%
% 7/15/03  dhb, bx  Wrote it.
% 3/17/04  dhb      Fixed typos.  This must not have been tested previously.
% 5/06/11  dhb      Added optional 1960 computation, and improved comments.

%% Handle optional arg
if (nargin < 2 || isempty(compute1960))
    compute1960 = 0;
end

xyY = [xy ; ones(1,size(xy,2))];
XYZ = xyYToXYZ(xyY);
uvY = XYZTouvY(XYZ,compute1960);
uv = uvY(1:2,:);

% One could check with direct computation from
% published formulae (CIE, Colorimetry, p. 54.)
% We checked for a few values and then commented this out.
% uvCheck = zeros(size(uv));
% uvCheck(1) = 4*xy(1)/(-2*xy(1)+12*xy(2)+3);
% uvCheck(2) = 9*xy(2)/(-2*xy(1)+12*xy(2)+3);