OpenMS  2.7.0
OpenSwathHelper.h
Go to the documentation of this file.
1 // --------------------------------------------------------------------------
2 // OpenMS -- Open-Source Mass Spectrometry
3 // --------------------------------------------------------------------------
4 // Copyright The OpenMS Team -- Eberhard Karls University Tuebingen,
5 // ETH Zurich, and Freie Universitaet Berlin 2002-2021.
6 //
7 // This software is released under a three-clause BSD license:
8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // * Neither the name of any author or any participating institution
14 // may be used to endorse or promote products derived from this software
15 // without specific prior written permission.
16 // For a full list of authors, refer to the file AUTHORS.
17 // --------------------------------------------------------------------------
18 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 // ARE DISCLAIMED. IN NO EVENT SHALL ANY OF THE AUTHORS OR THE CONTRIBUTING
22 // INSTITUTIONS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
23 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
25 // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
26 // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
27 // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
28 // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 //
30 // --------------------------------------------------------------------------
31 // $Maintainer: Hannes Roest $
32 // $Authors: Hannes Roest $
33 // --------------------------------------------------------------------------
34 
35 #pragma once
36 
42 
43 namespace OpenMS
44 {
48  class OPENMS_DLLAPI OpenSwathHelper
49  {
50 
51 public:
52 
65  static String computePrecursorId(const String& transition_group_id, int isotope)
66  {
67  return transition_group_id + "_Precursor_i" + String(isotope);
68  }
69 
81  static String computeTransitionGroupId(const String& precursor_id)
82  {
83  std::vector<String> substrings;
84  precursor_id.split("_", substrings);
85 
86  if (substrings.size() == 3) return substrings[0];
87  else if (substrings.size() > 3)
88  {
89  String r;
90  for (Size k = 0; k < substrings.size() - 2; k++) r += substrings[k] + "_";
91  return r.prefix(r.size() - 1);
92  }
93  return "";
94  }
95 
107  static void selectSwathTransitions(const OpenMS::TargetedExperiment& targeted_exp,
108  OpenMS::TargetedExperiment& selected_transitions,
109  double min_upper_edge_dist,
110  double lower, double upper);
111 
124  OpenSwath::LightTargetedExperiment& selected_transitions,
125  double min_upper_edge_dist,
126  double lower, double upper);
127 
145  static void checkSwathMap(const OpenMS::PeakMap& swath_map,
146  double& lower, double& upper, double& center);
147 
159  template <class TargetedExperimentT>
161  const TargetedExperimentT& targeted_exp,
162  TargetedExperimentT& selected_transitions,
163  double min_upper_edge_dist)
164  {
165  if (exp.size() == 0 || exp[0].getPrecursors().size() == 0)
166  {
167  std::cerr << "WARNING: File " << exp.getLoadedFilePath()
168  << " does not have any experiments or any precursors. Is it a SWATH map? "
169  << "I will move to the next map."
170  << std::endl;
171  return false;
172  }
173  double upper, lower, center;
174  OpenSwathHelper::checkSwathMap(exp, lower, upper, center);
175  OpenSwathHelper::selectSwathTransitions(targeted_exp, selected_transitions, min_upper_edge_dist, lower, upper);
176  if (selected_transitions.getTransitions().size() == 0)
177  {
178  std::cerr << "WARNING: For File " << exp.getLoadedFilePath()
179  << " no transition were within the precursor window of " << lower << " to " << upper
180  << std::endl;
181  return false;
182  }
183  return true;
184 
185  }
186 
196  static std::pair<double,double> estimateRTRange(const OpenSwath::LightTargetedExperiment & exp);
197 
212  static std::map<std::string, double> simpleFindBestFeature(const OpenMS::MRMFeatureFinderScoring::TransitionGroupMapType & transition_group_map,
213  bool useQualCutoff = false,
214  double qualCutoff = 0.0);
215  };
216 
217 } // namespace OpenMS
218 
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:109
In-Memory representation of a mass spectrometry experiment.
Definition: MSExperiment.h:80
Size size() const
Definition: MSExperiment.h:127
A helper class that is used by several OpenSWATH tools.
Definition: OpenSwathHelper.h:49
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:160
static String computePrecursorId(const String &transition_group_id, int isotope)
Compute unique precursor identifier.
Definition: OpenSwathHelper.h:65
static String computeTransitionGroupId(const String &precursor_id)
Compute transition group id.
Definition: OpenSwathHelper.h:81
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.
A more convenient string class.
Definition: String.h:61
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:65
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:127
const double k
Definition: Constants.h:153
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:47
Definition: TransitionExperiment.h:207