-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathEPGsim_TSE_VFA.m
35 lines (30 loc) · 1.07 KB
/
EPGsim_TSE_VFA.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
function [om_store,echoes,seq] = EPGsim_TSE_VFA(alphas,esp,rlx)
% [om_store, echoes, seq] = EPGsim_TSE_VFA(alphas,esp,rlx)
% Simulates variable flip angle (VFA) EPG with TSE scheme
% Note:
% (1) First pulse is always (90,90) to keep T(alpha) real
% (2) TSE RF spacing:esp/2, esp, esp, esp, .... (in milliseconds)
% (3) 2nd to last pulses are specified by alphass
% (4) rlx = [T1 T2] (set both to zero for no relaxation)
T1 = rlx(1); T2 = rlx(2);
N = length(alphas);
dt = esp/2;
% Let's do it!
seq.name = 'VFA TSE';
seq.rf = [[90,90]', [zeros(size(alphas));alphas]];
seq.grad = ones(1,2*N+1);
seq.time = [0 dt dt];
seq.events = {'rf','grad','relax'};
for n = 1:N
seq.time = [seq.time,seq.time(end),...
seq.time(end)+dt,seq.time(end)+dt,...
seq.time(end)+2*dt,seq.time(end)+2*dt];
seq.events{end+1} = 'rf';
seq.events{end+1} = 'grad';
seq.events{end+1} = 'relax';
seq.events{end+1} = 'grad';
seq.events{end+1} = 'relax';
end
seq.T1 = T1; seq.T2 = T2;
[om_store,echoes] = EPG_custom(seq);
end