-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathAlignUsingPeak.m
104 lines (92 loc) · 4.12 KB
/
AlignUsingPeak.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
function [AllFramesFTrealign, MRS_struct] = AlignUsingPeak(AllFramesFTrealign, MRS_struct)
%Using the freq information from MRS_struct, determine appropriate range to
%fit NAA signal over
switch MRS_struct.p.alignment
case 'NAA'
PEAK_ppm = 2.02;
%Determine limits
z = abs(MRS_struct.spec.freq - 2.26);
lb = find(min(z) == z);
z = abs(MRS_struct.spec.freq - 1.76);
ub = find(min(z) == z);
Initx = [50 0.1 PEAK_ppm 0 0 0];
case 'Cr'
PEAK_ppm = 3.02;
%Determine limits
z = abs(MRS_struct.spec.freq - 3.12);
lb = find(min(z) == z);
z = abs(MRS_struct.spec.freq - 2.72);
ub = find(min(z) == z);
Initx = [30 0.05 PEAK_ppm 0 0 0];
case 'Cho'
PEAK_ppm = 3.2;
%Determine limits
z = abs(MRS_struct.spec.freq - 3.32);
lb = find(min(z) == z);
z = abs(MRS_struct.spec.freq - 3.1);
ub = find(min(z) == z);
Initx = [30 0.05 PEAK_ppm 0 0 0];
end
%Set initial parameters by fitting the sum
freqrange = MRS_struct.spec.freq(lb:ub);
SumSpec = sum(AllFramesFTrealign(lb:ub,:),2);
SumSpecParams = FitPeaksByFrames(freqrange, SumSpec, Initx);
%Update freq and phase of AllFramesFTrealign to reflect Sum fit
AllFramesFTrealign = AllFramesFTrealign * exp(1i*SumSpecParams(4));
%Shift NAA freq to 2.02
freq_step_size = abs(MRS_struct.spec.freq(1) - MRS_struct.spec.freq(2));
Shift_points = round((real(SumSpecParams(3)) - PEAK_ppm)/freq_step_size);
for ii = 1:size(AllFramesFTrealign,2)
AllFramesFTrealign(:,ii) = circshift(AllFramesFTrealign(:,ii), [Shift_points 0]);
end
%Set initial fitting parameters by fitting the sum
Init = SumSpecParams ./ [size(AllFramesFTrealign,2) 1 1 1 size(AllFramesFTrealign,2) size(AllFramesFTrealign,2)];
Init(3) = PEAK_ppm;
Init(4) = 0;
Data2bFit = AllFramesFTrealign(lb:ub,:);
FrameParams = FitPeaksByFrames(freqrange, Data2bFit, Init);
%Update freq and phase of AllFramesFTrealign to reflect Frame-by-Frame fit
FrameShift_points = round((real(FrameParams(:,3)) - PEAK_ppm) / freq_step_size);
for jj = 1:size(FrameShift_points,1)
AllFramesFTrealign(:,jj) = circshift(AllFramesFTrealign(:,jj),[FrameShift_points(jj) 0]);
end
AllFramesFTrealign = AllFramesFTrealign.*repmat(exp(1i*FrameParams(:,4)).', [length(MRS_struct.spec.freq) 1]);
AllFramesFTrealign = AllFramesFTrealign-repmat(FrameParams(:,5).', [length(MRS_struct.spec.freq) 1]);
%Fit just the Cr in the aligned mean spectrum to get CrFWHMHz
CrFitLimLow = 2.6;
CrFitLimHigh = 3.11;
%Still need ranges for Creatine align plot
z = abs(MRS_struct.spec.freq - CrFitLimHigh);
clb = find(min(z) == z);
z = abs(MRS_struct.spec.freq - CrFitLimLow);
cub = find(min(z) == z);
freqrange = MRS_struct.spec.freq(clb:cub);
CrMeanSpec = mean(AllFramesFTrealign(clb:cub,:),2);
CrMeanSpecFit = FitCr(freqrange, CrMeanSpec, Init, MRS_struct.p.LarmorFreq);
MRS_struct.out.CrFWHMHz(MRS_struct.ii) = CrMeanSpecFit(2);
% Reject any point where the fit params - area, fwhm, phase
% or freq are > 3stdev away from the mean
% set reject criteria for all fit parameters
MeanFrameParams = mean(FrameParams, 1);
UpperLim = repmat(MeanFrameParams + 3*std(FrameParams,1), [size(AllFramesFTrealign,2) 1]);
LowerLim = repmat(MeanFrameParams - 3*std(FrameParams,1), [size(AllFramesFTrealign,2) 1]);
%but don't reject on linear, const baseline fit vals
UpperLim(:,5:6) = Inf;
LowerLim(:,5:6) = -Inf;
rejectframe = gt(FrameParams, UpperLim);
rejectframe = rejectframe + lt(FrameParams, LowerLim);
MRS_struct.out.reject{MRS_struct.ii} = max(rejectframe,[],2)';
%Balance up rejects
stepsize = find(MRS_struct.fids.ON_OFF ~= MRS_struct.fids.ON_OFF(1), 1) - 1;
for kk = 1:length(MRS_struct.out.reject{MRS_struct.ii})
%first find whether reject is ON or OFF
if MRS_struct.out.reject{MRS_struct.ii}(kk) == 1
if MRS_struct.fids.ON_OFF(kk) == MRS_struct.fids.ON_OFF(1)
MRS_struct.out.reject{MRS_struct.ii}(kk + stepsize) = 1;
else
MRS_struct.out.reject{MRS_struct.ii}(kk - stepsize) = 1;
end
end
end
fprintf('\n');
end