From 31ede82a02d880670d66e4a006e17f64a4bfdc37 Mon Sep 17 00:00:00 2001 From: Helge <47348963+HJZollner@users.noreply.github.com> Date: Thu, 7 Mar 2024 10:32:58 -0500 Subject: [PATCH] Add flag to preserve polarity - Added flag to preserve polarity for TI Series scans --- process/OspreyProcess.m | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/process/OspreyProcess.m b/process/OspreyProcess.m index 1c86d6d0..ed33a58c 100644 --- a/process/OspreyProcess.m +++ b/process/OspreyProcess.m @@ -391,15 +391,19 @@ % actually have negative polarity, but end up positive in the data, so % that the spectrum needs to be flipped. if ~isfield(MRSCont.opts.SubSpecAlignment, 'polResidCr') - raw_Cr = op_freqrange(raw,2.8,3.2); - % Determine the polarity of the respective peak: if the absolute of the - % maximum minus the absolute of the minimum is positive, the polarity - % of the respective peak is positive; if the absolute of the maximum - % minus the absolute of the minimum is negative, the polarity is negative. - polResidCr = abs(max(real(raw_Cr.specs))) - abs(min(real(raw_Cr.specs))); - polResidCr = squeeze(polResidCr); - polResidCr(polResidCr<0) = -1; - polResidCr(polResidCr>0) = 1; + if isfield(MRSCont.opts.SubSpecAlignment, 'PreservePolarity') && ~MRSCont.opts.SubSpecAlignment.PreservePolarity + raw_Cr = op_freqrange(raw,2.8,3.2); + % Determine the polarity of the respective peak: if the absolute of the + % maximum minus the absolute of the minimum is positive, the polarity + % of the respective peak is positive; if the absolute of the maximum + % minus the absolute of the minimum is negative, the polarity is negative. + polResidCr = abs(max(real(raw_Cr.specs))) - abs(min(real(raw_Cr.specs))); + polResidCr = squeeze(polResidCr); + polResidCr(polResidCr<0) = -1; + polResidCr(polResidCr>0) = 1; + else + polResidCr = 1; + end else polResidCr = MRSCont.opts.SubSpecAlignment.polResidCr; end @@ -602,9 +606,9 @@ raw_no_subspec_aling = raw; % Correct the frequency axis so that Cr appears at 3.027 ppm - [refShift_SubSpecAlign, ~] = osp_XReferencing(raw,[3.03 3.22],[1 1],[1.85 4.2]);% determine frequency shift + [refShift_SubSpecAlign, ~] = osp_XReferencing(raw,[3.03 3.22],[1 1],[1.85 3.9]);% determine frequency shift if abs(refShift_SubSpecAlign) > 10 % This a huge shift. Most likley wrong and we will try it again with tNAA only - [refShift_SubSpecAlign, ~] = osp_XReferencing(raw,2.01,1,[1.85 4.2]);% determine frequency shift + [refShift_SubSpecAlign, ~] = osp_XReferencing(raw,2.01,1,[1.85 3.9]);% determine frequency shift end % Apply initial referencing shift