forked from MBB-team/VBA-toolbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathVBA_PPM.m
81 lines (69 loc) · 2.64 KB
/
VBA_PPM.m
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
72
73
function [p] = VBA_PPM(m,v,t,disp,form)
% computes the exceedance probability of a random effect (+ plots)
% FORMAT [p] = VBA_PPM(m,v,t,disp,form)
% IN:
% - m/v: sufficient statistics of the pdf
% -> if form='gaussian', m=E[x] and v=V[x]
% -> if form='beta', m=counts for y=1 and v=counts for y=0, where y
% would be the conjugate binomial variable.
% - t: if t is a scalar, then it is a threshold (to calculate p =
% P(x>t)) ; if it is a vector, then it is an interval (to calculate p =
% P(x<t(1) or x>t(2)).
% - disp: a binary switch that flags whether or not to display the
% exceedance probability onto the posterior pdf.
% - form: 'gaussian' or 'beta'
% OUT:
% - p: the exceedance probability
try, disp; catch, disp=0; end
try, form; catch, form='gaussian'; end
switch form
case 'gaussian'
s = sqrt(v);
dx = s*1e-4;
gridx = -8*s:dx:8*s;
gridx = gridx + m;
f = exp(-0.5*(gridx-m).^2./v);
case 'beta'
gridx = 0:1e-2:1;
logf = (m-1).*log(gridx) + (v-1).*log(1-gridx);
f = exp(logf-max(logf));
% f = (gridx.^(m-1)).*((1-gridx).^(v-1));
end
f = f./sum(f);
if length(t) == 1
[mp,indt] = min(abs(gridx-t));
p = sum(f(indt:end));
else
[mp,indt1] = min(abs(gridx-min(t)));
[mp,indt2] = min(abs(gridx-max(t)));
p = 1-sum(f(indt1:indt2));
end
if disp
hf = figure('color',[1 1 1]);
ha = axes('parent',hf,'nextplot','add');
if length(t) == 1
yp = [f(indt:end),zeros(size(f(indt:end)))];
xp = [gridx(indt:end),fliplr(gridx(indt:end))];
fill(xp,yp,'r','parent',ha,'facecolor',0.5*[1 0 0],'edgealpha',0,'facealpha',0.25);
plot(ha,[gridx(indt),gridx(indt)],[0,f(indt)],'r--')
title(ha,['P(x>',num2str(t,'%4.3e'),') = ',num2str(p,'%4.3e')])
else
yp1 = [f(1:indt1),zeros(size(f(1:indt1)))];
xp1 = [gridx(1:indt1),fliplr(gridx(1:indt1))];
yp2 = [f(indt2:end),zeros(size(f(indt2:end)))];
xp2 = [gridx(indt2:end),fliplr(gridx(indt2:end))];
fill(xp1,yp1,'r','parent',ha,'facecolor',0.5*[1 0 0],'edgealpha',0,'facealpha',0.25);
fill(xp2,yp2,'r','parent',ha,'facecolor',0.5*[1 0 0],'edgealpha',0,'facealpha',0.25);
plot(ha,[gridx(indt1),gridx(indt1)],[0,f(indt1)],'r--')
plot(ha,[gridx(indt2),gridx(indt2)],[0,f(indt2)],'r--')
title(ha,['P(x<',num2str(t(1),'%4.3e'),' or x>',...
num2str(t(2),'%4.3e'),') = ',num2str(p,'%4.3e')])
end
plot(ha,gridx,f,'k')
grid(ha,'on')
axis(ha,'tight')
box(ha,'off')
xlabel(ha,'effect of interest: x')
ylabel(ha,'probability density function: p(x)')
try;getSubplots;end
end