-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathspm_DEM_F.m
68 lines (55 loc) · 1.98 KB
/
spm_DEM_F.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
function [F,p] = spm_DEM_F(DEM,ip)
% Free-energy as a function of conditional parameters
% FORMAT [F,p] = spm_DEM_F(DEM,ip)
%
% DEM - hierarchical model
%
% F(i) - free-energy at <q(P(ip))> = p(i)
%
% where p(i) is the ip-th free-parameter. This is a bound on
% the log-likehood (log-evidence) conditioned on the expected parameters.
%__________________________________________________________________________
% Karl Friston
% Copyright (C) 2010-2022 Wellcome Centre for Human Neuroimaging
% Find parameter ranges (using prior covariance)
%--------------------------------------------------------------------------
pE = spm_vec(DEM.M(1).pE);
p = linspace(-6,6,16);
dp = sqrt(DEM.M(1).pC(ip,ip))*p;
p = dp + pE(ip);
% get F
%==========================================================================
DEM.M(1).E.nE = 1;
DEM.M(1).E.nN = 1;
for i = 1:length(p)
% adjust parameter (through prio expectation)
%----------------------------------------------------------------------
P = pE;
P(ip) = p(i);
DEM.M(1).P = spm_unvec(P,DEM.M(1).pE);
% compute free-energy
%----------------------------------------------------------------------
DEM = spm_DEM(DEM);
F(i) = DEM.F(end);
end
% predicted F under the Laplace assumption
%==========================================================================
DEM.M(1).P = DEM.M(1).pE;
DEM = spm_DEM(DEM);
% compute free-energy
%--------------------------------------------------------------------------
dFdp = DEM.qP.dFdp(ip);
dFdpp = DEM.qP.dFdpp(ip,ip);
FP = dFdp*dp + (dFdpp*dp.^2)/2;
FP = FP - max(FP);
% plot
%--------------------------------------------------------------------------
spm_figure('GetWin','Free-energy');
F = F - max(F);
subplot(2,1,1)
plot(p,F,p,FP,':'), hold on
plot(pE(ip)*[1 1],[min(F) 0],':'), hold on
xlabel('Parameter expectation','FontSize',12)
ylabel('Free-energy','FontSize',12)
title('Free-energy profile','FontSize',16)
axis square, box off