-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathanalyze_behavior.m
50 lines (40 loc) · 1.6 KB
/
analyze_behavior.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
function analyze_behavior()
maindir = pwd;
addpath(fullfile(maindir,'rw'));
betas = linspace(0.001,15,100);
alphas = linspace(0.0001,0.9999,100);
pos = {'interested','excited','attentive','strong' ...
'enthusiastic','proud','alert','active','inspired','determined'};
neg = {'distressed','upset','guilty','scared','hostile','jittery', ...
'irritable','ashamed','nervous','afraid'};
loglike_surface = zeros(length(alphas),length(betas));
for a = 1:length(alphas)
for b = 1:length(betas)
blocks = 1:4;
subjects = 501:508;
loglike_i = 0;
for subject = subjects
for r = 1:length(blocks)
datadir = fullfile(maindir,'data',num2str(subject));
load(fullfile(datadir,sprintf('%s_Computer_feedback_%d.mat',num2str(subject),r)))
choicedata = [data.Npoints; data.deckchoice]';
choicedata(~choicedata(:,2),:) = [];
choicedata(choicedata(:,2)>2,:) = [];
% estimate learning
out = choicedata(:,1);
dec = choicedata(:,2);
alpha = alphas(a);
beta = betas(b);
[loglike_e, ~, ~, ~] = runRW_fe(dec, out, alpha, beta, loglike_i);
loglike_surface(a,b) = loglike_e;
end
end
end
disp(a)
end
figure,imagesc(loglike_surface);
[alpha_idx,beta_idx,~] = find(loglike_surface == max(max(loglike_surface)));
a_mle = alphas(alpha_idx(1));
b_mle = betas(beta_idx(1));
fprintf('FE: alpha = %3.3f, beta = %3.3f', a_mle, b_mle);
keyboard