/usr/share/psychtoolbox-3/Quest/QuestQuantile.m is in psychtoolbox-3-common 3.0.14.20170103+git6-g605ff5c.dfsg1-1build1.
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 | function t=QuestQuantile(q,quantileOrder)
% intensity=QuestQuantile(q,[quantileOrder])
%
% Gets a quantile of the pdf in the struct q. You may specify the desired
% quantileOrder, e.g. 0.5 for median, or, making two calls, 0.05 and 0.95
% for a 90% confidence interval. If the "quantileOrder" argument is not
% supplied, then it's taken from the "q" struct. QuestCreate uses
% QuestRecompute to compute the optimal quantileOrder and saves that in the
% "q" struct; this quantileOrder yields a quantile that is the most
% informative intensity for the next trial.
%
% This is based on work presented at a conference, but otherwise
% unpublished: Pelli, D. G. (1987). The ideal psychometric procedure.
% Investigative Ophthalmology & Visual Science, 28(Suppl), 366.
%
% See Quest.
% Denis Pelli, 6/9/96
% 6/17/96 dgp, worked around "nonmonotonic" (i.e. not strictly monotonic)
% interp1 error.
% 3/1/97 dgp updated to use Matlab 5 structs.
% 4/12/99 dgp removed support for Matlab 4.
% 4/22/15 dgp improved handling of the special case of a quantile not in
% the tabulated range, which can arise in testing of model
% observers, because they can produce a huge number of correct
% trials. In that case, QuestQuantile was returning NaN, which
% may confuse a threshold estimation procedure. Now
% QuestQuantile returns the closest intensity in the tabulated
% range.
%
% Copyright (c) 1996-2015 Denis Pelli
if nargin>2
error('Usage: intensity=QuestQuantile(q,[quantileOrder])')
end
if length(q)>1
if nargin>1
error('Cannot accept quantileOrder for q vector. Set each q.quantileOrder instead.')
end
t=zeros(size(q));
for i=1:length(q(:))
t(i)=QuestQuantile(q(i));
end
return
end
if nargin<2
quantileOrder=q.quantileOrder;
end
if quantileOrder > 1 || quantileOrder < 0
error('quantileOrder %f is outside range 0 to 1.',quantileOrder);
end
p=cumsum(q.pdf);
if ~isfinite(p(end))
error('pdf is not finite')
end
if p(end)==0
error('pdf is all zero')
end
if quantileOrder < p(1)
t=q.tGuess+q.x(1);
return
end
if quantileOrder > p(end)
t=q.tGuess+q.x(end);
return
end
index=find(diff([-1 p])>0);
if length(index)<2
error('pdf has only %g nonzero point(s)',length(index));
end
t=q.tGuess+interp1(p(index),q.x(index),quantileOrder*p(end)); % 40 ms
|