This file is indexed.

/usr/share/psychtoolbox-3/PsychTests/MakeTextureTimingTest.m is in psychtoolbox-3-common 3.0.9+svn2579.dfsg1-1.

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
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
% MakeTextureTimingTest
%
% Screen 'MakeTexture' both allocates memory to hold an OpenGL texture and
% loads a MATLAB matrix into the OpenGL texture. TestMakeTextureTiming
% times those two steps separately, reporting the fraction of time which
% MakeTexture spends allocating memory.   
%
% On 1GHz G4, MakeTexture spends less than 3% of its time allocating memory.
% Providing separate Screen subfuntions to allocate and fill textures would
% gain little.
%
% see also: PsychTests

% HISTORY
%
% mm/dd/yy
%
% 1/26/05   awi     wrote it.


try
    %test for a variety of texture sizes up to the screen size. 
    screenNumber=max(Screen('Screens'));
    w=Screen('OpenWindow', screenNumber, [], [], [], 2);
    screenRect=Screen('Rect', screenNumber);
    screenDimensions=[RectWidth(screenRect), RectHeight(screenRect)];
    maxTextureSize=min(screenDimensions);
    numTextures=floor(log2(maxTextureSize));
    textureSizes=2.^([1:numTextures])+1;
    numSamples=10;
    %turn on the debugging switch for 'MakeTexture' to record internal
    %timing.  See the C source to MakeTexture to see at where times are recorded. 

    %The preference call tells MakeTexture to record timestamps marking internal events into the time list. 
    Screen('Preference','DebugMakeTexture', 1);
    for i=1:numTextures
        fprintf(['Step ' int2str(i) ' of ' int2str(numTextures) ': ']);
        fprintf(['Timing generation of a ' int2str(textureSizes(i)) 'x' int2str(textureSizes(i)) ' texture:\n']);
        fprintf(['Repeating measurement ' int2str(numSamples) ' times; counting ']);
        for s=1:numSamples
            fprintf(int2str(s));
            if s<numSamples
                fprintf('.. ');
            else
                fprintf('.');
            end
            Screen('ClearTimeList');
            t=Screen('MakeTexture',w,magic(textureSizes(i)));
            rawTimes=Screen('GetTimeList');  %index by texture, sample, timestamp
            zeroRefTimes=rawTimes-rawTimes(1);
            timeList(i,s,:)=zeroRefTimes;
            %no reason to accumulate textures except to investigate memory loading vs allocation time.
            Screen('Close', t);
        end
        fprintf('\n\n');
    end
    Screen('Preference','DebugMakeTexture', 0);
catch 
    Screen('Preference','DebugMakeTexture', 0);
    Screen('CloseAll');
    psychrethrow(psychlasterror);
end

%Verify that turning off DebugMakeTexture causes values not to accumulate in
%the timing list.
Screen('ClearTimeList');
tFoo=Screen('MakeTexture',w,magic(textureSizes(1)));
if Screen('GetTimeList') > 0
    error('Turning off DebugMakeTexture failed to disable debugging in MakeTexture');
end %if


Screen('CloseAll')


%Average measurements and plot results

%When DebugMakeTexture is enabled, each call to MakeTexture generates four
% timestamps at these events:
% timestamp 1: Upon entering the SCREENMakeTexture C function
% timestamp 2: Immediatly before the valloc call to allocate texture memory
% timestamp 3: Immediatly before the valloc call to allocate texture memory
% timestamp 4: Immediatly before exit from SCREENMakeTexture.

%the indices into our result array are:
%timeList( texture size index,  repetition index, timestamp index)

[foo, bar, numTimestamps]=size(timeList);
if numTimestamps ~= 4
    error('MakeTexture stores more than the expected four timestamps.');
end


%first average across repeated measurements
for tex=1:numTextures
    for ts=1:numTimestamps
        avgTimes(tex, ts)=mean(timeList(tex, :, ts));
    end %for ts
end %for tx

allocationTimes=avgTimes(:,3) - avgTimes(:,2);
meanAllocationTimes=mean(allocationTimes);
copyTimes=avgTimes(:,4) - avgTimes(:,3);
meanCopyTimes=mean(copyTimes);

fprintf('Result:\n');
fprintf(['Average time to allocate texture memory: ' num2str(meanAllocationTimes) ' Secs.\n']);
fprintf(['Average time to copy the MATLAB matrix into the OpenGL texture: ' num2str(meanCopyTimes) ' Secs\n']);
fprintf(['Average proportion of time which MakeTexture spends allocating memory: ' num2str(meanAllocationTimes/meanCopyTimes) '\n']);