/usr/share/psychtoolbox-3/Quest/QuestTrials.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 | function trial=QuestTrials(q,binsize)
% trial=QuestTrials(q,[binsize])
%
% Return sorted list of intensities and response frequencies.
% "binsize", if supplied, will be used to round intensities to nearest multiple of binsize.
% Here's how you might use this function to display your results:
% t=QuestTrials(q,0.1);
% fprintf(' intensity p fit p trials\n');
% disp([t.intensity; QuestP(q,t.intensity-logC); (t.responses(2,:)./sum(t.responses)); sum(t.responses)]');
%
% See Quest.
% Denis Pelli
% 5/4/99 dgp wrote it
% 10/13/04 dgp Added optional binsize argument
% 10/13/04 dgp The orientations of the returned vectors was inconsistent. They are now rows.
% Copyright (c) 1996-1999 Denis Pelli
% 10/16/09 mk Bugfixes & Improvements to input argument checking, as proposed by Todd Horowitz.
% 10/31/10 mk Allocate q.intensity and q.response in chunks of 10000
% trials to reduce memory fragmentation problems.
if nargin < 1
error('Usage: trial=QuestTrials(q,[binsize])')
end
if nargin < 2
binsize = [];
end
if isempty(binsize) || ~isfinite(binsize)
binsize=0;
end
if binsize < 0
error('binsize cannot be negative')
end
if length(q)>1
for i=1:length(q(:))
trial(i)=QuestTrials(q(i)); %#ok<AGROW>
end
return
end
% sort
inIntensity = q.intensity(1:q.trialCount);
inResponse = q.response(1:q.trialCount);
[intensity,i]=sort(inIntensity);
response(1:length(i))=inResponse(i);
% quantize
if binsize>0
intensity=round(intensity/binsize)*binsize;
end
% compact
j=1;
trial.intensity(1,j)=intensity(1);
trial.responses(1:2,j)=[0 0];
for i=1:length(intensity)
if intensity(i)~=trial.intensity(j)
j=j+1;
trial.intensity(1,j)=intensity(i);
trial.responses(1:2,j)=[0 0];
end
trial.responses(response(i)+1,j)=trial.responses(response(i)+1,j)+1;
end
|