/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
|