This file is indexed.

/usr/share/psychtoolbox-3/PsychTests/AlphaBlendingTest.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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
function AlphaBlendingTest(screenNumber)

% AlphaBlendingTest([screenNumber])
%
% Perform tests of OpenGL alpha blending by drawing to the screen using
% 'PutImage', reading back the actual values on the Screen using
% 'GetImage' and comparing the actual values to predicted values
% calcualated in MATLAB.
%
% AlphaBlendingTest combines tests implemented separately.  You may perform
% any of these tests individually, or call AlphaBlendingTest to perform
% them all:
%   
% AlphaBlendSettingTest - 
%   Test the Screen('BlendFunction') recalls previously stored
%   alpha values.
%
% AlphaMultiplicationTest -
%   Test that alpha multiplication by values 0 and 1 (Screen 255) works
%   with perfect precision.  OpenGL guarantees perfect precision for those
%   alpha values only.
%
% AlphaMultiplicationAccuracyTest - 
%   Measure the precision of alpha values between 0 and 1 (Screen 0 and 255) by
%   drawing to the screen, then taking the difference between what was
%   drawn to the screen and results of simulated blending done with
%   double-precision floats.    
%
% AlphaAdditionTest - 
%   Test that addition of source and destination terms has perfect
%   precision.    


if nargin==0
    screenNumber=max(Screen('Screens'));
end

resultStrings={'Passed', 'Failed'};

fprintf('AlphaBlendingTest, performaing four tests of alpha blending:\n');

fprintf('    1. Testing that Screen(''BlendFunction'') retains and recalls settings: '); 
failFlag1= AlphaBlendSettingTest(screenNumber);
fprintf([resultStrings{failFlag1 + 1} '\n']);

fprintf('    2. Testing accuracy of OpenGL alpha addition:                         '); 
failFlag2= AlphaAdditionTest(screenNumber);
fprintf([resultStrings{failFlag2 + 1} '\n']);

fprintf('    3. Testing accuracy of OpenGL alpha multiplication by 0 and 1:        '); 
failFlag3= AlphaAdditionTest(screenNumber);
fprintf([resultStrings{failFlag3 + 1} '\n']);

fprintf('    4. Testing accuracy of OpenGL multiplication between 0 and 1:         '); 
[multMaximumError, multRoundTypeStr, multIndependentFlag]=AlphaMultiplicationAccuracyTest(screenNumber);
didPass= multMaximumError < 1 && multIndependentFlag;
fprintf([resultStrings{~didPass + 1} '\n']);
fprintf(['        Maximum descrepancy between MATLAB double and OpenGL integer multiplication: ' num2str(multMaximumError) '\n']);         
if strcmp(multRoundTypeStr,  'round')
    fprintf('        Alpha blending rounds multiplication to the nearest integer.\n');
elseif strcmp(multRoundTypeStr,  'floor')
    fprintf('        Alpha blending truncates multiplication.\n');
elseif strcmp(multRoundTypeStr,  'ceil')
    fprintf('        Alpha blending rounds multiplication up.\n');
elseif strcmp(multRoundTypeStr,  'unknown')
    fprintf('        Alpha blending multiplication rounds result by an unidentified method.\n');
end
if (multIndependentFlag)
    fprintf('        Multiplication rules are independent of the surface (source or destination) and the blending factor string.\n');
else   
    fprintf('        Multiplication rules depend on either the surface or the blending factor string.\n');
end