-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathDemoForR1Correction.m
57 lines (41 loc) · 2.61 KB
/
DemoForR1Correction.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
% Scripts to remove residual B1 bias from T1 maps calculated with the
% MP2RAGE sequence correction of T1 estimations as sugested on:
% Marques, J.P., Gruetter, R., 2013. New Developments and Applications of the MP2RAGE Sequence - Focusing the Contrast and High Spatial Resolution R1 Mapping. PLoS ONE 8. doi:10.1371/journal.pone.0069294
%
% In this script it is assumed that the B1 maps have been coregistered to the
% space of the MP2RAGE image and that they now have the B1 has in the
% process been interpolated to the same resolution.
addpath(genpath('.'))
%% Sa2RAGE protocol info and loading the Sa2RAGE data for B1 estimation
Sa2RAGE.TR = 2.4;
Sa2RAGE.TRFLASH = 2.75e-3;
Sa2RAGE.TIs = [47e-3 1800e-3];
Sa2RAGE.NZslices = 128*[0.25 0.5]/3 + [6 6]; % Base Resolution * [PartialFourierInPE-0.5 0.5]/iPATpe + [RefLines/2 RefLines/2]*(1-1/iPATpe )
Sa2RAGE.FlipDegrees = [4 10];
Sa2RAGE.averageT1 = 1.5;
Sa2RAGE.B1filename = 'Sa2RAGE_B1map.nii.gz';
B1 = load_untouch_nii(Sa2RAGE.B1filename);
%% MP2RAGE protocol info and loading the MP2RAGE dataset
MP2RAGE.B0 = 7; % In Tesla
MP2RAGE.TR = 6; % MP2RAGE TR in seconds
MP2RAGE.TRFLASH = 6.7e-3; % TR of the GRE readout
MP2RAGE.TIs = [800e-3 2700e-3]; % Inversion times - time between middle of refocusing pulse and excitatoin of the k-space center encoding
MP2RAGE.NZslices = [35 72]; % Slices Per Slab * [PartialFourierInSlice-0.5 0.5]
MP2RAGE.FlipDegrees = [4 5]; % Flip angle of the two readouts in degrees
MP2RAGE.filename = 'MP2RAGE_UNI.nii';
MP2RAGEimg = load_untouch_nii(MP2RAGE.filename);
% Check the properties of this MP2RAGE protocol... this happens to be a very B1 insensitive protocol
plotMP2RAGEproperties(MP2RAGE)
%% Performing the correction
[B1corr, T1corrected, MP2RAGEcorr] = T1B1correctpackage([], B1, Sa2RAGE, MP2RAGEimg, [], MP2RAGE, [], 0.96);
% Saving the data
save_untouch_nii(MP2RAGEcorr, 'data/MP2RAGEcorr.nii')
save_untouch_nii(T1corrected, 'data/T1corrected.nii')
%% If another technique was used to obtain the relative B1 maps
% (1 means correctly calibrated B1)
B1 = load_untouch_nii('Sa2RAGE_B1map.nii.gz');
B1.img = double(B1.img)/1000;
[T1corrected, MP2RAGEcorr] = T1B1correctpackageTFL(B1, MP2RAGEimg, [], MP2RAGE, [], 0.96);
% Saving the data
save_untouch_nii(MP2RAGEcorr, 'MP2RAGEcorr.nii')
save_untouch_nii(T1corrected, 'T1corrected.nii')