-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFitPeaks.m
57 lines (46 loc) · 2.4 KB
/
FitPeaks.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
function out = FitPeaks(WS_OFF,WS_ON,TITLE)
% function out = FitPeaks(WS_OFF,WS_ON) fits water peak for water
% unsuppressed and water suppressed spectra and NAA peak in edit-off MP
% spectrum using FitLorentz. Only the first WS_OFF spectrum is fitted.
% SPDX-License-Identifier: AGPL-3.0-or-later
%
% Copyright (C) 2021, Sophie M Shermer, Swansea University
WS_OFF.spec = GetSpectra(WS_OFF.spec,2^14);
for k=1:length(WS_ON)
WS_ON(k).spec = GetSpectra(WS_ON(k).spec, 2^14);
end
Figs = 2; XLIM1 = [-0.45 0.45]; XLIM2 = [-3 0.5];
F1 = figure('position',[0 2000 500 800]);
subplot('position',[0.15 0.7 0.8 0.25]);
[out.fitH20{1},out.gofH20{1},out.ErrH20{1}] = FitLorentz(WS_OFF.spec.f,abs(WS_OFF.spec.FT),-.2,.2,'r','northwest');
grid on, xlim(XLIM1), set(gca,'XTickLabel','')
ylabel('WS OFF EDIT ON (abs)'), xlabel('')
if exist('TITLE','var'), title(TITLE); end
subplot('position',[0.15 0.4 0.8 0.25]);
[out.fitH20{2},out.gofH20{2},out.ErrH20{2}] = FitLorentz(WS_ON(1).spec.f, abs(WS_ON(1).spec.FT), -1,1,'r','northwest');
grid on, xlim(XLIM1), set(gca,'XTickLabel','')
ylabel('WS ON EDIT ON (abs)'), xlabel('')
subplot('position',[0.15 0.1 0.8 0.25]);
[out.fitH20{3},out.gofH20{3},out.ErrH20{3}] = FitLorentz(WS_ON(2).spec.f, abs(WS_ON(2).spec.FT), -1,1,'r','northwest');
grid on, xlim(XLIM1)
ylabel('WS ON EDIT OFF (abs)')
F2 = figure('position',[500 2000 500 800]);
subplot('position',[0.15 0.7 0.8 0.25]);
[out.fitH20{4},out.gofH20{4},out.ErrH20{4}] = FitLorentz(WS_ON(1).spec.f, real(WS_ON(1).spec.FT), -1,1,'r','northeast');
grid on, xlim(XLIM2),set(gca,'XTickLabel','')
ylabel('WS ON EDIT ON (real)'), xlabel('')
if exist('TITLE','var'), title(TITLE); end
subplot('position',[0.15 0.4 0.8 0.25]);
[out.fitNAA{1},out.gofNAA{1},out.ErrNAA{1}] = FitLorentz(WS_ON(2).spec.f, real(WS_ON(2).spec.FT), -3,-2.5,'r','northeast');
grid on, xlim(XLIM2), set(gca,'XTickLabel','')
ylabel('WS ON EDIT OFF (real)'), xlabel('')
subplot('position',[0.15 0.1 0.8 0.25]);
[out.fitNAA{2},out.gofNAA{2},out.ErrNAA{2}] = FitLorentz(WS_ON(3).spec.f, real(WS_ON(3).spec.FT), -3,-2.5,'r','southwest');
grid on, xlim(XLIM2),
ylabel('WS ON DIFF (real)')
if exist('TITLE','var')
saveas(F1, sprintf('PeakFit1-%s',TITLE),'fig')
saveas(F1, sprintf('PeakFit1-%s',TITLE),'png')
saveas(F2, sprintf('PeakFit2-%s',TITLE),'fig')
saveas(F2, sprintf('PeakFit2-%s',TITLE),'png')
end