OpenMS  2.4.0
MSSpectrum.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-2018.
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: Timo Sachsenberg$
32 // $Authors: Marc Sturm $
33 // --------------------------------------------------------------------------
34 
35 #pragma once
36 
37 #include <OpenMS/KERNEL/Peak1D.h>
44 
45 namespace OpenMS
46 {
47  class Peak1D;
66  class OPENMS_DLLAPI MSSpectrum :
67  private std::vector<Peak1D>,
68  public RangeManager<1>,
69  public SpectrumSettings
70  {
71 public:
72 
74  struct OPENMS_DLLAPI RTLess : public std::binary_function<MSSpectrum, MSSpectrum, bool>
75  {
76  bool operator()(const MSSpectrum& a, const MSSpectrum& b) const;
77  };
78 
80 
81  typedef OpenMS::Peak1D PeakType;
86  typedef std::vector<PeakType> ContainerType;
89  typedef std::vector<FloatDataArray> FloatDataArrays;
92  typedef std::vector<StringDataArray> StringDataArrays;
95  typedef std::vector<IntegerDataArray> IntegerDataArrays;
97 
99 
100  typedef typename ContainerType::iterator Iterator;
103  typedef typename ContainerType::const_iterator ConstIterator;
105  typedef typename ContainerType::reverse_iterator ReverseIterator;
107  typedef typename ContainerType::const_reverse_iterator ConstReverseIterator;
109 
111 
112  using ContainerType::operator[];
113  using ContainerType::begin;
114  using ContainerType::rbegin;
115  using ContainerType::end;
116  using ContainerType::rend;
117  using ContainerType::resize;
118  using ContainerType::size;
119  using ContainerType::push_back;
120  using ContainerType::emplace_back;
121  using ContainerType::pop_back;
122  using ContainerType::empty;
123  using ContainerType::front;
124  using ContainerType::back;
125  using ContainerType::reserve;
126  using ContainerType::insert;
127  using ContainerType::erase;
128  using ContainerType::swap;
129 
130  using typename ContainerType::iterator;
131  using typename ContainerType::const_iterator;
132  using typename ContainerType::size_type;
133  using typename ContainerType::value_type;
134  using typename ContainerType::reference;
135  using typename ContainerType::const_reference;
136  using typename ContainerType::pointer;
137  using typename ContainerType::difference_type;
139 
140 
142  MSSpectrum();
143 
145  MSSpectrum(const MSSpectrum& source);
146 
148  MSSpectrum(MSSpectrum&&) = default;
149 
151  ~MSSpectrum() override
152  {}
153 
155  MSSpectrum& operator=(const MSSpectrum& source);
156 
158  MSSpectrum& operator=(MSSpectrum&&) & = default;
159 
161  MSSpectrum& operator=(const SpectrumSettings & source);
162 
164  bool operator==(const MSSpectrum& rhs) const;
165 
167  bool operator!=(const MSSpectrum& rhs) const
168  {
169  return !(operator==(rhs));
170  }
171 
172  // Docu in base class (RangeManager)
173  void updateRanges() override;
174 
178  double getRT() const;
179 
181  void setRT(double rt);
182 
191  double getDriftTime() const;
192 
196  void setDriftTime(double dt);
197 
203  UInt getMSLevel() const;
204 
206  void setMSLevel(UInt ms_level);
207 
209  const String& getName() const;
210 
212  void setName(const String& name);
213 
215 
229  const FloatDataArrays& getFloatDataArrays() const;
231 
234  {
235  return float_data_arrays_;
236  }
237 
239  void setFloatDataArrays(const FloatDataArrays& fda);
240 
242  const StringDataArrays& getStringDataArrays() const;
243 
245  StringDataArrays& getStringDataArrays();
246 
248  void setStringDataArrays(const StringDataArrays& sda);
249 
251  const IntegerDataArrays& getIntegerDataArrays() const;
252 
254  IntegerDataArrays& getIntegerDataArrays();
255 
257  void setIntegerDataArrays(const IntegerDataArrays& ida);
259 
261 
262 
267  void sortByIntensity(bool reverse = false);
268 
274  void sortByPosition();
275 
277  bool isSorted() const;
278 
280 
283 
293  Size findNearest(CoordinateType mz) const;
294 
306  Int findNearest(CoordinateType mz, CoordinateType tolerance) const;
307 
321  Int findNearest(CoordinateType mz, CoordinateType tolerance_left, CoordinateType tolerance_right) const;
322 
328  Iterator MZBegin(CoordinateType mz);
329 
335  Iterator MZBegin(Iterator begin, CoordinateType mz, Iterator end);
336 
342  Iterator MZEnd(CoordinateType mz);
343 
349  Iterator MZEnd(Iterator begin, CoordinateType mz, Iterator end);
350 
356  ConstIterator MZBegin(CoordinateType mz) const;
357 
363  ConstIterator MZBegin(ConstIterator begin, CoordinateType mz, ConstIterator end) const;
364 
370  ConstIterator MZEnd(CoordinateType mz) const;
371 
377  ConstIterator MZEnd(ConstIterator begin, CoordinateType mz, ConstIterator end) const;
378 
386  Iterator PosBegin(CoordinateType mz);
387 
395  Iterator PosBegin(Iterator begin, CoordinateType mz, Iterator end);
396 
404  ConstIterator PosBegin(CoordinateType mz) const;
405 
413  ConstIterator PosBegin(ConstIterator begin, CoordinateType mz, ConstIterator end) const;
414 
422  Iterator PosEnd(CoordinateType mz);
423 
431  Iterator PosEnd(Iterator begin, CoordinateType mz, Iterator end);
432 
440  ConstIterator PosEnd(CoordinateType mz) const;
441 
449  ConstIterator PosEnd(ConstIterator begin, CoordinateType mz, ConstIterator end) const;
450 
452 
453 
459  void clear(bool clear_meta_data);
460 
461  /*
462  @brief Select a (subset of) spectrum and its data_arrays, only retaining the indices given in @p indices
463 
464  @param indices Vector of indices to keep
465  @return Reference to this MSSpectrum
466 
467  */
468  MSSpectrum& select(const std::vector<Size>& indices);
469 
470 
481  SpectrumSettings::SpectrumType getType(const bool query_data) const;
482  using SpectrumSettings::getType; // expose base class function
483 
484 protected:
485 
488 
490  double drift_time_;
491 
494 
497 
500 
503 
506  };
507 
508  inline std::ostream& operator<<(std::ostream& os, const MSSpectrum& spec)
509  {
510  os << "-- MSSPECTRUM BEGIN --" << std::endl;
511 
512  // spectrum settings
513  os << static_cast<const SpectrumSettings&>(spec);
514 
515  // peaklist
516  for (MSSpectrum::ConstIterator it = spec.begin(); it != spec.end(); ++it)
517  {
518  os << *it << std::endl;
519  }
520 
521  os << "-- MSSPECTRUM END --" << std::endl;
522  return os;
523  }
524 
525 } // namespace OpenMS
PeakType::CoordinateType CoordinateType
Coordinate (m/z) type.
Definition: MSSpectrum.h:84
A more convenient string class.
Definition: String.h:58
IntegerDataArrays integer_data_arrays_
Integer data arrays.
Definition: MSSpectrum.h:505
~MSSpectrum() override
Destructor.
Definition: MSSpectrum.h:151
SpectrumType
Spectrum peak type.
Definition: SpectrumSettings.h:70
StringDataArrays string_data_arrays_
String data arrays.
Definition: MSSpectrum.h:502
Comparator for the retention time.
Definition: MSSpectrum.h:74
ContainerType::reverse_iterator ReverseIterator
Mutable reverse iterator.
Definition: MSSpectrum.h:105
unsigned int UInt
Unsigned integer type.
Definition: Types.h:94
Peak2D PeakType
Definition: MassTrace.h:47
ContainerType::const_iterator ConstIterator
Non-mutable iterator.
Definition: MSSpectrum.h:103
OpenMS::DataArrays::FloatDataArray FloatDataArray
Float data array vector type.
Definition: MSSpectrum.h:88
bool operator==(_Iterator< _Val, _Ref, _Ptr > const &, _Iterator< _Val, _Ref, _Ptr > const &)
Definition: KDTree.h:806
Representation of 1D spectrum settings.
Definition: SpectrumSettings.h:63
String name_
Name.
Definition: MSSpectrum.h:496
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:46
ContainerType::iterator Iterator
Mutable iterator.
Definition: MSSpectrum.h:101
std::vector< FloatDataArray > FloatDataArrays
Definition: MSSpectrum.h:89
Float data array class.
Definition: DataArrays.h:45
Integer data array class.
Definition: DataArrays.h:52
FloatDataArrays float_data_arrays_
Float data arrays.
Definition: MSSpectrum.h:499
The representation of a 1D spectrum.
Definition: MSSpectrum.h:66
SpectrumType getType() const
returns the spectrum type (centroided (PEAKS) or profile data (RAW))
bool operator!=(const MSSpectrum &rhs) const
Equality operator.
Definition: MSSpectrum.h:167
A 1-dimensional raw data point or peak.
Definition: Peak1D.h:54
std::ostream & operator<<(std::ostream &os, const AccurateMassSearchResult &amsr)
std::vector< StringDataArray > StringDataArrays
Definition: MSSpectrum.h:92
FloatDataArrays & getFloatDataArrays()
Returns a mutable reference to the float meta data arrays.
Definition: MSSpectrum.h:233
std::vector< PeakType > ContainerType
Spectrum base type.
Definition: MSSpectrum.h:86
OpenMS::DataArrays::StringDataArray StringDataArray
String data array vector type.
Definition: MSSpectrum.h:91
std::vector< IntegerDataArray > IntegerDataArrays
Definition: MSSpectrum.h:95
double retention_time_
Retention time.
Definition: MSSpectrum.h:487
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:127
UInt ms_level_
MS level.
Definition: MSSpectrum.h:493
OpenMS::DataArrays::IntegerDataArray IntegerDataArray
Integer data array vector type.
Definition: MSSpectrum.h:94
double drift_time_
Drift time.
Definition: MSSpectrum.h:490
String data array class.
Definition: DataArrays.h:59
Handles the management of a position and intensity range.
Definition: RangeManager.h:47
int Int
Signed integer type.
Definition: Types.h:102
ContainerType::const_reverse_iterator ConstReverseIterator
Non-mutable reverse iterator.
Definition: MSSpectrum.h:107