File: CumNormYNFitFun.m

package info (click to toggle)
psychtoolbox-3 3.0.14.20170103%2Bgit6-g605ff5c.dfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 103,044 kB
  • ctags: 69,483
  • sloc: ansic: 167,371; cpp: 11,232; objc: 4,708; sh: 1,875; python: 383; php: 344; makefile: 207; java: 113
file content (31 lines) | stat: -rwxr-xr-x 568 bytes parent folder | download | duplicates (4)
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
function [f,g] = CumulativeFitFun(x,level,nYes,nNo)
% [f,g] = CumulativeFitFun(x,level,nYes,nNo)
%
% 9/22/93   jms  Created from FitWeibullYN.

u    = x(1);
theVar  = x(2);

pYes = NormalCumulative(level,u,theVar);

% Handle range problem, can't take log(0);
tol = 1e-4;
z_index = find(pYes == 0);
if (~isempty(z_index))
  pYes(z_index) = tol*ones(length(z_index),1);
end
o_index = find(pYes == 1);
if (~isempty(o_index))
  pYes(o_index) = (1-tol)*ones(length(o_index),1);
end

% Compute error
tmp = nYes.*log(pYes) + nNo.*log(1 - pYes);
f =  -sum(tmp);
g = -1;