This file is indexed.

/usr/share/psychtoolbox-3/PsychCal/MaximizeGamutContrast.m is in psychtoolbox-3-common 3.0.14.20170103+git6-g605ff5c.dfsg1-1build1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
function [s,sPos,sNeg] = MaximizeGamutContrast(dir,white)
% [s,sPos,sNeg] = MaximizeGamutContrast(dir,white)
% 
% Find the scalar that maximizes the contrast around
% the white point.  Input should be specified in device
% primary coordinates.
% 
% 2/22/94  dhb    Wrote it.
% 4/3/94   dhb    Analytic version.
% 4/4/94   dhb    Avoid divide by zero problem.
% 8/17/94  dhb    Handle small values of useWhite.
% 8/23/94  dhb    Fix 8/17 fix to handle negative numbers.  Sigh.
% 2/16/98  dgp    Renamed from MaxGmtCon to MaximizeGamutContrast.
% 12/3/98  dhb    Add directional return values.
%          dhb    Remove redundant calculations.
% 9/7/00   mpr    Made zero handling code more compact; did away with unnecessary variable.
% 1/31/10  dhb    Range check on input white point.
%          dhb    Remove calls to find as per MATLAB lint checker.

% Expand out dir to handle all inputs together.
n = size(dir,2);
useWhite = white*ones(1,n);

% Make sure useWhite is in range [0,1]. Otherwise this routine
% will not behave right.
if (any(useWhite > 1) || any(useWhite < 0))
    error('Passed white point must be in range [0,1] for all primaries\n');
end

% Set any dir entry that are zero to something very small
% This avoids a printed divide by zero error.
verySmall = 1e-15;
index = find(abs(dir) < verySmall);
dir(index) = verySmall*ones(size(index)).*sign(dir(index));
dir(~dir) = verySmall*ones(size(find(~dir)));

% Deal with small values of useWhite as well
index = find(abs(useWhite) <= verySmall);
useWhite(index) = 2*verySmall*ones(size(index)).*sign(useWhite(index));
useWhite(~useWhite) = 2*verySmall*ones(size(find(~useWhite)));

% Find all of the candidate s values
s1 = (1-useWhite) ./ dir;		% white + s1*dir = 1
s2 = (-useWhite) ./ dir;		% white + s2*dir = 0	

% Get all of the s values together
allS = [s1 ; s2];
indexPos = allS >= 0;
indexNeg = allS < 0;

% Return the minimum absolute value
s = min(abs(allS));
sPos = min(abs(allS(indexPos)));
sNeg = min(abs(allS(indexNeg)));