OpenMS  2.7.0
IDMapper.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: Chris Bielow $
32 // $Authors: Marc Sturm, Hendrik Weisser, Chris Bielow $
33 // --------------------------------------------------------------------------
34 
35 #pragma once
36 
41 
43 
45 
47 
48 #include <algorithm>
49 #include <limits>
50 
51 namespace OpenMS
52 {
66  class OPENMS_DLLAPI IDMapper :
67  public DefaultParamHandler
68  {
69 public:
70  enum Measure {MEASURE_PPM = 0, MEASURE_DA};
71 
74 
76  IDMapper(const IDMapper& cp);
77 
79  IDMapper& operator=(const IDMapper& rhs);
80 
96  void annotate(PeakMap& map, const std::vector<PeptideIdentification>& peptide_ids, const std::vector<ProteinIdentification>& protein_ids, const bool clear_ids = false, const bool map_ms1 = false);
97 
113  void annotate(PeakMap& map, FeatureMap fmap, const bool clear_ids = false, const bool map_ms1 = false);
114 
133  void annotate(FeatureMap& map, const std::vector<PeptideIdentification>& ids, const std::vector<ProteinIdentification>& protein_ids, bool use_centroid_rt = false, bool use_centroid_mz = false, const PeakMap& spectra = PeakMap());
134 
151  void annotate(ConsensusMap& map, const std::vector<PeptideIdentification>& ids,
152  const std::vector<ProteinIdentification>& protein_ids,
153  bool measure_from_subelements = false,
154  bool annotate_ids_with_subelements = false,
155  const PeakMap& spectra = PeakMap());
156 
157 
162  {
163  std::vector<Size> no_precursors;
164  std::vector<Size> identified;
165  std::vector<Size> unidentified;
166  };
167 
184  const std::vector<PeptideIdentification>& ids,
185  double mz_tol = 0.001,
186  double rt_tol = 0.001)
187  {
189  for (Size spectrum_index = 0; spectrum_index < spectra.size(); ++spectrum_index)
190  {
191  const MSSpectrum& spectrum = spectra[spectrum_index];
192  if (!spectrum.getPrecursors().empty())
193  {
194  bool identified(false);
195  const std::vector<Precursor>& precursors = spectrum.getPrecursors();
196 
197  // check if precursor has been identified
198  for (Size i_p = 0; i_p < precursors.size(); ++i_p)
199  {
200  // check by precursor mass and spectrum RT
201  double mz_p = precursors[i_p].getMZ();
202  double rt_s = spectrum.getRT();
203 
204  for (Size i_id = 0; i_id != ids.size(); ++i_id)
205  {
206  const PeptideIdentification& pid = ids[i_id];
207 
208  // do not count empty ids as identification of a spectrum
209  if (pid.getHits().empty()) continue;
210 
211  double mz_id = pid.getMZ();
212  double rt_id = pid.getRT();
213 
214  if ( fabs(mz_id - mz_p) < mz_tol && fabs(rt_s - rt_id) < rt_tol )
215  {
216  identified = true;
217  break;
218  }
219  }
220  }
221  if (!identified)
222  {
223  ret.unidentified.push_back(spectrum_index);
224  }
225  else
226  {
227  ret.identified.push_back(spectrum_index);
228  }
229  }
230  else
231  {
232  ret.no_precursors.push_back(spectrum_index);
233  }
234  }
235  return ret;
236  }
237 
238 
239 protected:
240  void updateMembers_() override;
241 
250 
254  double getAbsoluteMZTolerance_(const double mz) const;
255 
257  bool isMatch_(const double rt_distance, const double mz_theoretical, const double mz_observed) const;
258 
260  void checkHits_(const std::vector<PeptideIdentification>& ids) const;
261 
265  void getIDDetails_(const PeptideIdentification& id, double& rt_pep, DoubleList& mz_values, IntList& charges, bool use_avg_mass = false) const;
266 
269 
272  bool checkMassType_(const std::vector<DataProcessing>& processing) const;
273 
274  };
275 
276 } // namespace OpenMS
277 
A container for consensus elements.
Definition: ConsensusMap.h:88
A base class for all classes handling default parameters.
Definition: DefaultParamHandler.h:93
A container for features.
Definition: FeatureMap.h:105
Annotates an MSExperiment, FeatureMap or ConsensusMap with peptide identifications.
Definition: IDMapper.h:68
void getIDDetails_(const PeptideIdentification &id, double &rt_pep, DoubleList &mz_values, IntList &charges, bool use_avg_mass=false) const
std::vector< Size > unidentified
Definition: IDMapper.h:165
Measure measure_
Measure used for m/z.
Definition: IDMapper.h:247
void increaseBoundingBox_(DBoundingBox< 2 > &box)
increase a bounding box by the given RT and m/z tolerances
double getAbsoluteMZTolerance_(const double mz) const
void checkHits_(const std::vector< PeptideIdentification > &ids) const
helper function that checks if all peptide hits are annotated with RT and MZ meta values
bool isMatch_(const double rt_distance, const double mz_theoretical, const double mz_observed) const
check if distance constraint is fulfilled (using rt_tolerance_, mz_tolerance_ and measure_)
IDMapper & operator=(const IDMapper &rhs)
Assignment.
double mz_tolerance_
Allowed m/z deviation.
Definition: IDMapper.h:245
static SpectraIdentificationState mapPrecursorsToIdentifications(const PeakMap &spectra, const std::vector< PeptideIdentification > &ids, double mz_tol=0.001, double rt_tol=0.001)
Mapping of peptide identifications to spectra This helper function partitions all spectra into those ...
Definition: IDMapper.h:183
void annotate(ConsensusMap &map, const std::vector< PeptideIdentification > &ids, const std::vector< ProteinIdentification > &protein_ids, bool measure_from_subelements=false, bool annotate_ids_with_subelements=false, const PeakMap &spectra=PeakMap())
Mapping method for consensus maps.
IDMapper()
Default constructor.
std::vector< Size > no_precursors
Definition: IDMapper.h:163
bool checkMassType_(const std::vector< DataProcessing > &processing) const
IDMapper(const IDMapper &cp)
Copy C'Tor.
void annotate(PeakMap &map, FeatureMap fmap, const bool clear_ids=false, const bool map_ms1=false)
Mapping method for peak maps.
void updateMembers_() override
This method is used to update extra member variables at the end of the setParameters() method.
void annotate(FeatureMap &map, const std::vector< PeptideIdentification > &ids, const std::vector< ProteinIdentification > &protein_ids, bool use_centroid_rt=false, bool use_centroid_mz=false, const PeakMap &spectra=PeakMap())
Mapping method for feature maps.
bool ignore_charge_
Ignore charge states during matching?
Definition: IDMapper.h:249
std::vector< Size > identified
Definition: IDMapper.h:164
void annotate(PeakMap &map, const std::vector< PeptideIdentification > &peptide_ids, const std::vector< ProteinIdentification > &protein_ids, const bool clear_ids=false, const bool map_ms1=false)
Mapping method for peak maps.
Measure
Definition: IDMapper.h:70
double rt_tolerance_
Allowed RT deviation.
Definition: IDMapper.h:243
Result of a partitioning by identification state with mapPrecursorsToIdentifications().
Definition: IDMapper.h:162
In-Memory representation of a mass spectrometry experiment.
Definition: MSExperiment.h:80
Size size() const
Definition: MSExperiment.h:127
The representation of a 1D spectrum.
Definition: MSSpectrum.h:71
double getRT() const
Represents the peptide hits for a spectrum.
Definition: PeptideIdentification.h:65
double getRT() const
returns the RT of the MS2 spectrum where the identification occurred
const std::vector< PeptideHit > & getHits() const
returns the peptide hits as const
double getMZ() const
returns the MZ of the MS2 spectrum
const std::vector< Precursor > & getPrecursors() const
returns a const reference to the precursors
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:127
std::vector< Int > IntList
Vector of signed integers.
Definition: ListUtils.h:55
std::vector< double > DoubleList
Vector of double precision real types.
Definition: ListUtils.h:62
MSExperiment PeakMap
Two-dimensional map of raw data points or peaks.
Definition: StandardTypes.h:61
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:47