This file is indexed.

/usr/share/psychtoolbox-3/PsychTests/DeinterlacerTest.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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
function DeinterlacerTest(sf, imgname, method)
% DeinterlacerTest([sf][,imgname][,method])
%
% Tests (and thereby demonstrates) the Psychtoolbox builtin GLSL realtime
% deinterlaceshader, an OpenGL GLSL Fragmentshader for on-the-fly
% deinterlacing of video images which are given as PTB textures and drawn
% via Screen('MakeTexture').
%
% Parameters: 'imgname' is optional. If provided, the routine loads an
% imagefile of that name as test input, otherwise it creates a synthetic
% test pattern in Matlab.
%
% sf - Optional scalefactor, by which the image is scaled in size.
%
% method - Select deinterlace method:
%
% 0 = None. 1 = Replacement of lines, 2 = Averaging of lines.
%
% See the shader sources under Psychtoolbox/PsychOpenGL/PsychGLSLShaders
% for proper definition of the operations.
%
% What you should see (assuming you did not provide an input image file):
%
% First an image with alternating red- and green color gradients. This is
% the interlaced test pattern where even rows contain only red, odd rows
% contain only green gradients.
%
% Press a key.
%
% Then, by pressing and releasing a key, the image should alternate between
% an all red image (only red gradients of twice the thickness), and an all
% green image: This is the alternating deinterlaced even, odd, even, odd
% ... half-fields of the interlaced image.
%
% End the demo by pressing ESCape key twice.
%
% If you see something else, or just a black screen, or it aborts with
% error, then your hardware is probably not capable of running the
% deinterlace-shader and you're out of luck.
%
% Good luck.


AssertOpenGL;
filter=0;

KbName('UnifyKeyNames');
escape=KbName('ESCAPE');

try
    screenid = max(Screen('Screens'));
    [win winrect] = Screen('OpenWindow', screenid, 0);

    if nargin<3
        method=1;
    end

    if nargin<1
        sf = 1;
    end

    if nargin<2
        imgname=[];
    end

    % Image filename provided as input?
    if isempty(imgname)
        % Nope. Create synthetic test image:
        img = uint8(zeros(256,256,3));
        for y=0:size(img,1)-1
            for x=1:256
                % Even row: Red gradient
                img(y+1, x, mod(y,2) + 1)=(x-1);
            end

            if mod(floor(y/2),2)==0
                img(y+1, :, mod(y,2) + 1)=255 - img(y+1, :, mod(y,2) + 1);
            end
        end
    else
        % Read image from filesystem:
        img = imread(imgname);
    end

    for i=1:3
        teximg(:,:,i)=transpose(img(:,:,i));
    end
    
    % Build corresponding texture:
    tex = Screen('MakeTexture', win, teximg);

    dstrect = Screen('Rect', tex);
    dstrect = ScaleRect(dstrect, sf, sf);
    dstrect = CenterRect(dstrect, winrect);

    % Show original (interlaced) image:
    Screen('DrawTexture', win, tex, [], dstrect, 90, filter);
    Screen('Flip', win);

    % Wait for keypress:
    KbWait; while KbCheck; end;

    % Load deinterlace-shader:
    if method == 1
        % Simple line replication:
        deinterlacer = LoadGLSLProgramFromFiles('EXPDeinterlaceShaderLineDouble',1);
    else
        if method ==2
            % Replace line by average of neighbour lines:
            deinterlacer = LoadGLSLProgramFromFiles('EXPDeinterlaceShaderAvg',1);
        end
    end

    if method > 0
        % Bind and initialize it:
        glUseProgram(deinterlacer);
        % Input image will be bound to texture unit zero:
        glUniform1i(glGetUniformLocation(deinterlacer, 'Image1'), 0);
        % Get handle for the field selection parameter:
        useoddfield=glGetUniformLocation(deinterlacer, 'UseOddField');
    end

    glFinish;
    count = 0;
    tstart = GetSecs;

    % Run until user presses ESCape or for 1000 iterations.
    while count < 1000
        % Show the even half-field: Tell deinterlacer we want the even field:
        if method>0
            glUniform1f(useoddfield, 0);
        end

        % Draw it:
        Screen('DrawTexture', win, tex, [], dstrect, 90, filter);
        Screen('Flip', win, 0, 0, 0);

        % Wait for keypress:
        KbWait; while KbCheck; end;

        % Show the odd half-field: Tell deinterlacer we want the odd field:
        if method>0
            glUniform1f(useoddfield, 1);
        end

        % Draw it:
        Screen('DrawTexture', win, tex, [], dstrect, 90, filter);
        Screen('Flip', win, 0, 0, 0);

        % Wait for keypress:
        KbWait;
        [dummy dummy keycode]=KbCheck;
        if keycode(escape)
            break;
        end
        while KbCheck; end;

        count = count + 1;
    end
    glFinish;
    telapsed = GetSecs - tstart
    tavg = telapsed / count / 2 * 1000
    hz = count / telapsed * 2

    % Done. Disable deinterlacer:
    glUseProgram(0);

    % Shut down:
    Screen('CloseAll');
catch
    Screen('CloseAll');
    psychrethrow(psychlasterror);
end