File: WeibYNFitFun.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 (32 lines) | stat: -rwxr-xr-x 571 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
32
function [f,g] = WeibFitFun(x,level,nYes,nNo)
% [f,g] = WeibYNFitFun(x,level,nYes,nNo)
%

  alpha = x(1);
  beta  = x(2);

  % nData = nYes + nNo;

  pYes = ComputeWeibYN(level,alpha,beta);

  % 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;