OpenMS
OpenSwathHelper.h
Go to the documentation of this file.
1 // Copyright (c) 2002-2023, The OpenMS Team -- EKU Tuebingen, ETH Zurich, and FU Berlin
2 // SPDX-License-Identifier: BSD-3-Clause
3 //
4 // --------------------------------------------------------------------------
5 // $Maintainer: Hannes Roest $
6 // $Authors: Hannes Roest $
7 // --------------------------------------------------------------------------
8 
9 #pragma once
10 
17 
18 namespace OpenMS
19 {
23  class OPENMS_DLLAPI OpenSwathHelper
24  {
25 
26 public:
27 
40  static String computePrecursorId(const String& transition_group_id, int isotope)
41  {
42  return transition_group_id + "_Precursor_i" + String(isotope);
43  }
44 
56  static String computeTransitionGroupId(const String& precursor_id)
57  {
58  std::vector<String> substrings;
59  precursor_id.split("_", substrings);
60 
61  if (substrings.size() == 3) return substrings[0];
62  else if (substrings.size() > 3)
63  {
64  String r;
65  for (Size k = 0; k < substrings.size() - 2; k++) r += substrings[k] + "_";
66  return r.prefix(r.size() - 1);
67  }
68  return "";
69  }
70 
82  static void selectSwathTransitions(const OpenMS::TargetedExperiment& targeted_exp,
83  OpenMS::TargetedExperiment& selected_transitions,
84  double min_upper_edge_dist,
85  double lower, double upper);
86 
99  OpenSwath::LightTargetedExperiment& selected_transitions,
100  double min_upper_edge_dist,
101  double lower, double upper);
110  static void selectSwathTransitionsPasef(const OpenSwath::LightTargetedExperiment& transition_exp, std::vector<int>& tr_win_map,
111  double min_upper_edge_dist, const std::vector< OpenSwath::SwathMap > & swath_maps);
112 
130  static void checkSwathMap(const OpenMS::PeakMap& swath_map,
131  double& lower, double& upper, double& center);
132 
144  template <class TargetedExperimentT>
146  const TargetedExperimentT& targeted_exp,
147  TargetedExperimentT& selected_transitions,
148  double min_upper_edge_dist)
149  {
150  if (exp.empty() || exp[0].getPrecursors().empty())
151  {
152  std::cerr << "WARNING: File " << exp.getLoadedFilePath()
153  << " does not have any experiments or any precursors. Is it a SWATH map? "
154  << "I will move to the next map."
155  << std::endl;
156  return false;
157  }
158  double upper, lower, center;
159  OpenSwathHelper::checkSwathMap(exp, lower, upper, center);
160  OpenSwathHelper::selectSwathTransitions(targeted_exp, selected_transitions, min_upper_edge_dist, lower, upper);
161  if (selected_transitions.getTransitions().size() == 0)
162  {
163  std::cerr << "WARNING: For File " << exp.getLoadedFilePath()
164  << " no transition were within the precursor window of " << lower << " to " << upper
165  << std::endl;
166  return false;
167  }
168  return true;
169 
170  }
171 
181  static std::pair<double,double> estimateRTRange(const OpenSwath::LightTargetedExperiment & exp);
182 
197  static std::map<std::string, double> simpleFindBestFeature(const OpenMS::MRMFeatureFinderScoring::TransitionGroupMapType & transition_group_map,
198  bool useQualCutoff = false,
199  double qualCutoff = 0.0);
200  };
201 
202 } // namespace OpenMS
203 
const String & getLoadedFilePath() const
get the file_name_ which is the absolute path to the file loaded from
std::map< String, MRMTransitionGroupType > TransitionGroupMapType
Definition: MRMFeatureFinderScoring.h:79
In-Memory representation of a mass spectrometry run.
Definition: MSExperiment.h:46
bool empty() const
Are there any spectra (does not consider chromatograms)
Definition: MSExperiment.h:133
A helper class that is used by several OpenSWATH tools.
Definition: OpenSwathHelper.h:24
static bool checkSwathMapAndSelectTransitions(const OpenMS::PeakMap &exp, const TargetedExperimentT &targeted_exp, TargetedExperimentT &selected_transitions, double min_upper_edge_dist)
Check the map and select transition in one function.
Definition: OpenSwathHelper.h:145
static String computePrecursorId(const String &transition_group_id, int isotope)
Compute unique precursor identifier.
Definition: OpenSwathHelper.h:40
static String computeTransitionGroupId(const String &precursor_id)
Compute transition group id.
Definition: OpenSwathHelper.h:56
static void selectSwathTransitions(const OpenMS::TargetedExperiment &targeted_exp, OpenMS::TargetedExperiment &selected_transitions, double min_upper_edge_dist, double lower, double upper)
Select transitions between lower and upper and write them into the new TargetedExperiment.
static std::map< std::string, double > simpleFindBestFeature(const OpenMS::MRMFeatureFinderScoring::TransitionGroupMapType &transition_group_map, bool useQualCutoff=false, double qualCutoff=0.0)
Returns the feature with the highest score for each transition group.
static void selectSwathTransitions(const OpenSwath::LightTargetedExperiment &targeted_exp, OpenSwath::LightTargetedExperiment &selected_transitions, double min_upper_edge_dist, double lower, double upper)
Select transitions between lower and upper and write them into the new TargetedExperiment.
static std::pair< double, double > estimateRTRange(const OpenSwath::LightTargetedExperiment &exp)
Computes the min and max retention time value.
static void checkSwathMap(const OpenMS::PeakMap &swath_map, double &lower, double &upper, double &center)
Get the lower / upper offset for this SWATH map and do some sanity checks.
static void selectSwathTransitionsPasef(const OpenSwath::LightTargetedExperiment &transition_exp, std::vector< int > &tr_win_map, double min_upper_edge_dist, const std::vector< OpenSwath::SwathMap > &swath_maps)
Match transitions with their "best" window across m/z and ion mobility, save results in a vector.
A more convenient string class.
Definition: String.h:34
String prefix(SizeType length) const
returns the prefix of length length
bool split(const char splitter, std::vector< String > &substrings, bool quote_protect=false) const
Splits a string into substrings using splitter as delimiter.
A description of a targeted experiment containing precursor and production ions.
Definition: TargetedExperiment.h:39
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:101
const double k
Definition: Constants.h:132
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:22
Definition: TransitionExperiment.h:185