This file is indexed.

/usr/share/psychtoolbox-3/PsychHardware/PR705Toolbox/PR705parsespdstr.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
function spd = PR705parsespdstr(rawspd, S)
% PR705parsespdstr - Parses the spectral power distribution string returned by the PR-705.
%
% Syntax:
% spd = PR705parsespdstr(rawspd [, S])
%
% Description:
% Parse the spectral power distribution string returned by the PR-705. The
% results are splined to the desired wavelength sampling defined by the 'S'
% input parameter.
%
% Input:
% rawspd (1xN char) - Raw data returned from a meter measurment.
% S (1x3) - Wavelength sampling.  Default: [380 5 81]
%
% 12/06/12    zlb   Wrote it based on the PR670Toolbox.

if nargin < 2 || isempty(S)
    S = [380 5 81];
end

spd = [];
if ~isempty(rawspd)
    C = textscan(rawspd, '%d,%f', 'HeaderLines', 1);
    wls = double(C{1});
    spd = double(C{2});
    
    if isempty(wls) || isempty(spd)
        return
    end
    
    if numel(wls) ~= 201 % 201 is the PR-705 default
        error('Unexpected number of wavelength samples for PR-705!');
    elseif wls(2) - wls(1) ~= 2 || ~all(diff(wls) == 2)
        error('Unexpected wavelength sampling for the PR-705!');
    end
    
    % We _don't_ multiply the amplitudes by the bin spacing (2 nm in this 
    % case) because the data given by the meter are in units, not units/nm,
    % as per the documentation.
    
    if S(3) ~= 201
        S0 = [wls(1) wls(2)-wls(1) length(wls)];
        spd = SplineSpd(S0, spd, S);
    end
end