/usr/share/psychtoolbox-3/PsychTests/BitsPlusPlusTLockBlitterTest.m is in psychtoolbox-3-common 3.0.12.20160126.dfsg1-1ubuntu1.
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 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | function BitsPlusPlusTLockBlitterTest(screenId)
% BitsPlusPlusTLockBlitterTest([screenId])
%
% Test if the old style Bits++ T-Lock code generation and the new style
% built-in T-Lock code generation yield identical results.
%
% 'screenId' == Display screen to test. Defaults to max(Screen('Screens')).
%
% This test should pass on all graphics hardware. If it fails on some
% setup, we're interested in hearing from you.
%
% History:
% 03/11/08 Written. (MK)
%
if nargin < 1
screenId = max(Screen('Screens'));
end
oldlut = Screen('ReadNormalizedGammatable', screenId);
try
% Enable built-in Bits++ support:
w = BitsPlusPlus('OpenWindowBits++', screenId, 0);
% Create all zero CLUT for Bits++
newclut = 0 * ones(256,3);
% Load it via PTB support:
Screen('LoadNormalizedGammaTable',w,newclut, 2);
Screen('Flip',w);
% Retrieve generated T-Lock framebuffer image:
img1 = Screen('GetImage', w, [0 0 524 2]);
chk1 = sum(sum(sum(double(img1))));
% Do T-Lock again manually, disable PTB's built-in support:
Screen('Hookfunction', w, 'Disable', 'LeftFinalizerBlitChain');
clutRow = BitsPlusEncodeClutRow(floor(newclut * (2^16 - 1) + 0.5));
Screen('PutImage',w,clutRow,[0 0 524 1]);
Screen('Flip',w);
% Retrieve generated T-Lock framebuffer image:
img2 = Screen('GetImage', w, [0 0 524 2]);
chk2 = sum(sum(sum(double(img2))));
% Compute differences between both T-Lock images. They should be
% identical if the GPU is rasterizing properly:
dimg = abs(double(img1) - double(img2));
diff = sum(sum(sum(dimg)));
dimg2 = abs(double(img2(1,:,:)) - double(clutRow));
diff2 = sum(sum(sum(dimg2)));
fprintf('\n\nTest results of T-Lock blitter test:\n\n');
if chk1==0 || chk2==0
error('Framebuffer readout error or black image!');
end
if diff2 > 0
fprintf('Difference between "PutImage" T-Lock and Matlab T-Lock! BAD.\n');
end
if diff > 0
fprintf('T-Lock codes not identical! BAD.\n');
ptbtlock = img1(1, 1:10, :)
bpptlock = img2(1, 1:10, :)
else
fprintf('T-Lock codes are identical! GOOD.\n');
end
% Restore Bits++ Identity CLUT so it can be used as normal display:
Screen('Hookfunction', w, 'Enable', 'LeftFinalizerBlitChain');
BitsPlusPlus('LoadIdentityClut', w);
Screen('Flip', w);
Screen('CloseAll');
% Clean up: Restore LUT's, close window:
Screen('LoadNormalizedGammatable', screenId, oldlut);
catch
% Clean up: Restore LUT's, close window:
Screen('LoadNormalizedGammatable', screenId, oldlut);
Screen('CloseAll');
psychrethrow(psychlasterror);
end
|