-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgetJ3.m
32 lines (28 loc) · 1.25 KB
/
getJ3.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
function J = getJ3(d,tp,t,f)
% [time x trial x run x taper x freq x vox x window]
%[N ,E ,R ,K,F,V,W]
[Nd,Ed,Rd,~,~,V,Wd] = size(d);
[~ ,~ ,~ ,K,~,~,~ ] = size(tp);
[~ ,~ ,~ ,~,F,~,~ ] = size(f);
[Nt,Et,Rt,~,~,~,Wt] = size(t);
if Nd~=Nt ; dbstack; end; N = Nd;
if Et~=1 && Ed~=Et; dbstack; end; E = Ed;
if Rt~=1 && Rd~=Rt; dbstack; end; R = Rd;
if Wt~=1 && Wd~=Wt; dbstack; end; W = Wd;
J = zeros(1,E,R,K,F,V,W);
for e = 1:E
tp2 = reshape( tp .* exp(-f.*t(:,e)*2*pi*1i) ,[N 1*R*K*F*1*Wt]);
d2 = reshape( d(:,e,:,:,:,:,:,:) - mean(d(:,e,:,:,:,:,:,:),1) ,[N 1*R*1*1*V*W ]); % removing the mean here
% tp2 = reshape( tp .* exp(-f.*t*2*pi*1i) ,[N Et*R*K*F*1*Wt]);
% d2 = reshape( d - mean(d,1) ,[N E*R*1*1*V*W]); % removing the mean here
d2 = permute(d2,[2 1]);
j = d2*tp2; % [V 1*R*K*F*1*W]
% [E*R*1*1*V*W Et*R*K*F*1*Wt]
j = reshape(j,[1*R*1*1*V*W 1 R K F 1 Wt]);
j = permute(j,[2 3 4 5 6 7 1]);
j = reshape(j,[1 R K F 1 Wt 1 R 1 1 V W]);
J(:,e,:,:,:,:,:) = permute(j,[13 7 2 3 4 11 6 1 5 8 9 10 12]); %[N ,E ,R ,K,F,V,W]
if any(size(J,9:15)~=1); dbstack; error('X'); end
end
% J = reshape(J,[V E R K F 1 W]); % [V E R K F 1 W]
% J = permute(J,[6 2 3 4 5 1 7]); % [N E R K F V W]