OpenMS  2.6.0
AASequence.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-2020.
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: Andreas Bertsch $
33 // --------------------------------------------------------------------------
34 
35 #pragma once
36 
40 #include <OpenMS/CONCEPT/Types.h>
43 
44 #include <vector>
45 #include <iosfwd>
46 
47 namespace OpenMS
48 {
49 
111  class OPENMS_DLLAPI AASequence
112  {
113 public:
114 
115  class Iterator;
116 
121  class OPENMS_DLLAPI ConstIterator
122  {
123 public:
124 
125  // TODO Iterator constructor for ConstIterator
126 
127  typedef const Residue& const_reference;
128  typedef Residue& reference;
129  typedef const Residue* const_pointer;
130  typedef std::vector<const Residue*>::difference_type difference_type;
132  typedef const Residue* pointer;
133  typedef std::random_access_iterator_tag iterator_category;
134 
138  ConstIterator()
140  {
141  }
142 
144  ConstIterator(const std::vector<const Residue*>* vec_ptr, difference_type position)
145  {
146  vector_ = vec_ptr;
147  position_ = position;
148  }
149 
152  vector_(rhs.vector_),
153  position_(rhs.position_)
154  {
155  }
156 
159  vector_(rhs.vector_),
160  position_(rhs.position_)
161  {
162  }
163 
165  virtual ~ConstIterator()
166  {
167  }
168 
170 
173  {
174  if (this != &rhs)
175  {
176  position_ = rhs.position_;
177  vector_ = rhs.vector_;
178  }
179  return *this;
180  }
181 
185  const_reference operator*() const
187  {
188  return *(*vector_)[position_];
189  }
190 
192  const_pointer operator->() const
193  {
194  return (*vector_)[position_];
195  }
196 
199  {
200  return ConstIterator(vector_, position_ + diff);
201  }
202 
204  {
205  return position_ - rhs.position_;
206  }
207 
210  {
211  return ConstIterator(vector_, position_ - diff);
212  }
213 
215  bool operator==(const ConstIterator& rhs) const
216  {
217  return vector_ == rhs.vector_ && position_ == rhs.position_;
218  }
219 
221  bool operator!=(const ConstIterator& rhs) const
222  {
223  return vector_ != rhs.vector_ || position_ != rhs.position_;
224  }
225 
228  {
229  ++position_;
230  return *this;
231  }
232 
235  {
236  --position_;
237  return *this;
238  }
239 
241 
242 protected:
243 
244  // pointer to the AASequence vector
245  const std::vector<const Residue*>* vector_;
246 
247  // position in the AASequence vector
249  };
250 
251 
256  class OPENMS_DLLAPI Iterator
257  {
258 public:
259 
261 
262  typedef const Residue& const_reference;
263  typedef Residue& reference;
264  typedef const Residue* const_pointer;
265  typedef const Residue* pointer;
266  typedef std::vector<const Residue*>::difference_type difference_type;
267 
271  Iterator()
273  {
274  }
275 
277  Iterator(std::vector<const Residue*>* vec_ptr, difference_type position)
278  {
279  vector_ = vec_ptr;
280  position_ = position;
281  }
282 
284  Iterator(const Iterator& rhs) :
285  vector_(rhs.vector_),
286  position_(rhs.position_)
287  {
288  }
289 
291  virtual ~Iterator()
292  {
293  }
294 
296 
299  {
300  if (this != &rhs)
301  {
302  position_ = rhs.position_;
303  vector_ = rhs.vector_;
304  }
305  return *this;
306  }
307 
311  const_reference operator*() const
313  {
314  return *(*vector_)[position_];
315  }
316 
318  const_pointer operator->() const
319  {
320  return (*vector_)[position_];
321  }
322 
324  pointer operator->()
325  {
326  return (*vector_)[position_];
327  }
328 
331  {
332  return Iterator(vector_, position_ + diff);
333  }
334 
336  {
337  return position_ - rhs.position_;
338  }
339 
342  {
343  return Iterator(vector_, position_ - diff);
344  }
345 
347  bool operator==(const Iterator& rhs) const
348  {
349  return vector_ == rhs.vector_ && position_ == rhs.position_;
350  }
351 
353  bool operator!=(const Iterator& rhs) const
354  {
355  return vector_ != rhs.vector_ || position_ != rhs.position_;
356  }
357 
360  {
361  ++position_;
362  return *this;
363  }
364 
367  {
368  --position_;
369  return *this;
370  }
371 
373 
374 protected:
375 
376  // pointer to the AASequence vector
377  std::vector<const Residue*>* vector_;
378 
379  // position in the AASequence vector
381  };
382 
386 
388  AASequence();
389 
391  AASequence(const AASequence&) = default;
392 
394  AASequence(AASequence&&) noexcept = default;
395 
397  virtual ~AASequence();
399 
401  AASequence& operator=(const AASequence&) = default;
402 
404  AASequence& operator=(AASequence&&) = default; // TODO: add noexcept (gcc 4.8 bug)
405 
407  bool empty() const;
408 
412 
424  String toString() const;
425 
427  String toUnmodifiedString() const;
428 
437  String toUniModString() const;
438 
457  String toBracketString(bool integer_mass = true,
458  bool mass_delta = false,
459  const std::vector<String> & fixed_modifications = std::vector<String>()) const;
460 
463  void setModification(Size index, const String& modification);
464 
465  // sets the (potentially modified) residue
466  void setModification(Size index, const Residue* modification) { peptide_[index] = modification; }
467 
470  void setNTerminalModification(const String& modification);
471 
473  void setNTerminalModification(const ResidueModification* modification);
474 
476  const String& getNTerminalModificationName() const;
477 
479  const ResidueModification* getNTerminalModification() const;
480 
483  void setCTerminalModification(const String& modification);
484 
486  void setCTerminalModification(const ResidueModification* modification);
487 
489  const String& getCTerminalModificationName() const;
490 
492  const ResidueModification* getCTerminalModification() const;
493 
495  const Residue& getResidue(Size index) const;
496 
498  EmpiricalFormula getFormula(Residue::ResidueType type = Residue::Full, Int charge = 0) const;
499 
501  double getAverageWeight(Residue::ResidueType type = Residue::Full, Int charge = 0) const;
502 
507  double getMonoWeight(Residue::ResidueType type = Residue::Full, Int charge = 0) const;
508 
510  const Residue& operator[](Size index) const;
511 
513  AASequence operator+(const AASequence& peptide) const;
514 
516  AASequence& operator+=(const AASequence&);
517 
519  AASequence operator+(const Residue* residue) const;
520 
522  AASequence& operator+=(const Residue*);
523 
525  Size size() const;
526 
528  AASequence getPrefix(Size index) const;
529 
531  AASequence getSuffix(Size index) const;
532 
534  AASequence getSubsequence(Size index, UInt number) const;
535 
537  void getAAFrequencies(Map<String, Size>& frequency_table) const;
538 
540 
544  bool has(const Residue& residue) const;
546 
549  bool hasSubsequence(const AASequence& peptide) const;
550 
553  bool hasPrefix(const AASequence& peptide) const;
554 
557  bool hasSuffix(const AASequence& peptide) const;
558 
560  bool hasNTerminalModification() const;
561 
563  bool hasCTerminalModification() const;
564 
566  bool isModified() const;
567 
569  bool operator==(const AASequence& rhs) const;
570 
572  bool operator<(const AASequence& rhs) const;
573 
575  bool operator!=(const AASequence& rhs) const;
577 
581  inline Iterator begin() { return Iterator(&peptide_, 0); }
582 
583  inline ConstIterator begin() const { return ConstIterator(&peptide_, 0); }
584 
585  inline Iterator end() { return Iterator(&peptide_, (Int) peptide_.size()); }
586 
587  inline ConstIterator end() const { return ConstIterator(&peptide_, (Int) peptide_.size()); }
589 
593  friend OPENMS_DLLAPI std::ostream& operator<<(std::ostream& os, const AASequence& peptide);
595 
597  friend OPENMS_DLLAPI std::istream& operator>>(std::istream& is, const AASequence& peptide);
599 
608  static AASequence fromString(const String& s,
609  bool permissive = true);
610 
619  static AASequence fromString(const char* s,
620  bool permissive = true);
621 
622  protected:
623 
624  std::vector<const Residue*> peptide_;
625 
627 
629 
644  static String::ConstIterator parseModRoundBrackets_(const String::ConstIterator str_it,
645  const String& str,
646  AASequence& aas,
647  const ResidueModification::TermSpecificity& specificity);
648 
662  static String::ConstIterator parseModSquareBrackets_(const String::ConstIterator str_it,
663  const String& str,
664  AASequence& aas,
665  const ResidueModification::TermSpecificity& specificity);
666 
667  static void parseString_(const String& peptide, AASequence& aas,
668  bool permissive = true);
669  };
670 
671  OPENMS_DLLAPI std::ostream& operator<<(std::ostream& os, const AASequence& peptide);
672 
673  OPENMS_DLLAPI std::istream& operator>>(std::istream& os, const AASequence& peptide);
674 
675 } // namespace OpenMS
676 
677 
OpenMS::AASequence::Iterator::operator=
Iterator & operator=(const Iterator &rhs)
assignment operator
Definition: AASequence.h:298
OpenMS::AASequence::ConstIterator
ConstIterator for AASequence.
Definition: AASequence.h:121
OpenMS::AASequence::peptide_
std::vector< const Residue * > peptide_
Definition: AASequence.h:624
OpenMS::AASequence::ConstIterator::difference_type
std::vector< const Residue * >::difference_type difference_type
Definition: AASequence.h:130
OpenMS::ResidueModification
Representation of a modification.
Definition: ResidueModification.h:76
Types.h
OpenMS::operator*
DPosition< D, TCoordinateType > operator*(DPosition< D, TCoordinateType > position, typename DPosition< D, TCoordinateType >::CoordinateType scalar)
Scalar multiplication (a bit inefficient)
Definition: DPosition.h:427
OpenMS::AASequence::end
Iterator end()
Definition: AASequence.h:585
OpenMS::AASequence::c_term_mod_
const ResidueModification * c_term_mod_
Definition: AASequence.h:628
OpenMS::String
A more convenient string class.
Definition: String.h:59
KDTree::operator!=
bool operator!=(_Iterator< _Val, _Ref, _Ptr > const &, _Iterator< _Val, _Ref, _Ptr > const &)
Definition: KDTree.h:824
OpenMS::AASequence::Iterator::position_
difference_type position_
Definition: AASequence.h:380
OpenMS::Size
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:127
OpenMS::AASequence::Iterator::vector_
std::vector< const Residue * > * vector_
Definition: AASequence.h:377
OpenMS::Residue::Full
with N-terminus and C-terminus
Definition: Residue.h:153
OpenMS::AASequence::ConstIterator::operator=
ConstIterator & operator=(const ConstIterator &rhs)
assignment operator
Definition: AASequence.h:172
OpenMS::AASequence::ConstIterator::const_reference
const typedef Residue & const_reference
Definition: AASequence.h:127
Map.h
OpenMS::operator<
bool operator<(const QTCluster &q1, const QTCluster &q2)
OpenMS::AASequence::ConstIterator::operator+
const ConstIterator operator+(difference_type diff) const
forward jump operator
Definition: AASequence.h:198
OpenMS::AASequence::ConstIterator::operator->
const_pointer operator->() const
dereference operator
Definition: AASequence.h:192
OpenMS::AASequence::Iterator
Iterator class for AASequence.
Definition: AASequence.h:256
OpenMS::AASequence::ConstIterator::pointer
const typedef Residue * pointer
Definition: AASequence.h:132
OpenMS::AASequence::Iterator::operator-
difference_type operator-(Iterator rhs) const
Definition: AASequence.h:335
OpenMS
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:46
OpenMS::AASequence::Iterator::operator->
const_pointer operator->() const
dereference operator
Definition: AASequence.h:318
OpenMS::AASequence::ConstIterator::operator--
ConstIterator & operator--()
decrement operator
Definition: AASequence.h:234
OpenMS::Residue
Representation of a residue.
Definition: Residue.h:62
OpenMS::ResidueModification::TermSpecificity
TermSpecificity
Position where the modification is allowed to occur.
Definition: ResidueModification.h:95
OpenMS::AASequence::ConstIterator::operator==
bool operator==(const ConstIterator &rhs) const
equality comparator
Definition: AASequence.h:215
OpenMS::AASequence::ConstIterator::operator++
ConstIterator & operator++()
increment operator
Definition: AASequence.h:227
int
OpenMS::AASequence::Iterator::operator->
pointer operator->()
mutable dereference operator
Definition: AASequence.h:324
OpenMS::AASequence::ConstIterator::const_pointer
const typedef Residue * const_pointer
Definition: AASequence.h:129
OpenMS::AASequence::ConstIterator::ConstIterator
ConstIterator(const AASequence::Iterator &rhs)
copy constructor from Iterator
Definition: AASequence.h:158
OpenMS::AASequence::Iterator::Iterator
Iterator(const Iterator &rhs)
copy constructor
Definition: AASequence.h:284
OpenMS::AASequence::ConstIterator::ConstIterator
ConstIterator(const std::vector< const Residue * > *vec_ptr, difference_type position)
detailed constructor with pointer to the vector and offset position
Definition: AASequence.h:144
OpenMS::AASequence::Iterator::operator!=
bool operator!=(const Iterator &rhs) const
inequality operator
Definition: AASequence.h:353
OpenMS::AASequence::Iterator::reference
Residue & reference
Definition: AASequence.h:263
OpenMS::AASequence::Iterator::operator++
Iterator & operator++()
increment operator
Definition: AASequence.h:359
OpenMS::AASequence::ConstIterator::operator-
const ConstIterator operator-(difference_type diff) const
backward jump operator
Definition: AASequence.h:209
OpenMS::AASequence::begin
ConstIterator begin() const
Definition: AASequence.h:583
OpenMS::AASequence::Iterator::const_reference
const typedef Residue & const_reference
Definition: AASequence.h:262
OpenMS::Residue::ResidueType
ResidueType
Definition: Residue.h:151
OpenMS::AASequence::ConstIterator::operator-
difference_type operator-(ConstIterator rhs) const
Definition: AASequence.h:203
OpenMS::operator<<
std::ostream & operator<<(std::ostream &os, const AccurateMassSearchResult &amsr)
OpenMS::TargetedExperimentHelper::setModification
void setModification(int location, int max_size, String modification, OpenMS::AASequence &aas)
helper function that sets a modification on a AASequence object
OpenMS::UInt
unsigned int UInt
Unsigned integer type.
Definition: Types.h:94
OpenMS::AASequence::ConstIterator::vector_
const std::vector< const Residue * > * vector_
Definition: AASequence.h:245
OpenMS::AASequence::ConstIterator::iterator_category
std::random_access_iterator_tag iterator_category
Definition: AASequence.h:133
OpenMS::AASequence::ConstIterator::ConstIterator
ConstIterator(const ConstIterator &rhs)
copy constructor
Definition: AASequence.h:151
OpenMS::AASequence::Iterator::difference_type
std::vector< const Residue * >::difference_type difference_type
Definition: AASequence.h:266
Residue.h
OpenMS::StringConversions::toString
String toString(const T &i)
fallback template for general purpose using Boost::Karma; more specializations below
Definition: StringUtils.h:127
OpenMS::AASequence::ConstIterator::~ConstIterator
virtual ~ConstIterator()
destructor
Definition: AASequence.h:165
EmpiricalFormula.h
OpenMS::Internal::operator==
bool operator==(const IDBoostGraph::ProteinGroup &lhs, const IDBoostGraph::ProteinGroup &rhs)
OpenMS::AASequence::Iterator::operator==
bool operator==(const Iterator &rhs) const
equality comparator
Definition: AASequence.h:347
OpenMS::EmpiricalFormula
Representation of an empirical formula.
Definition: EmpiricalFormula.h:82
OpenMS::AASequence::ConstIterator::reference
Residue & reference
Definition: AASequence.h:128
OpenMS::AASequence::Iterator::const_pointer
const typedef Residue * const_pointer
Definition: AASequence.h:264
OpenMS::AASequence::end
ConstIterator end() const
Definition: AASequence.h:587
String.h
OpenMS::AASequence::ConstIterator::operator!=
bool operator!=(const ConstIterator &rhs) const
inequality operator
Definition: AASequence.h:221
OpenMS::AASequence::Iterator::Iterator
Iterator(std::vector< const Residue * > *vec_ptr, difference_type position)
detailed constructor with pointer to the vector and offset position
Definition: AASequence.h:277
OpenMS::AASequence::Iterator::operator--
Iterator & operator--()
decrement operator
Definition: AASequence.h:366
OpenMS::AASequence::begin
Iterator begin()
Definition: AASequence.h:581
OpenMS::AASequence::Iterator::operator+
const Iterator operator+(difference_type diff) const
forward jump operator
Definition: AASequence.h:330
OpenMS::AASequence
Representation of a peptide/protein sequence.
Definition: AASequence.h:111
ResidueModification.h
OpenMS::Map
Map class based on the STL map (containing several convenience functions)
Definition: Map.h:50
OpenMS::operator>>
std::istream & operator>>(std::istream &os, const AASequence &peptide)
OpenMS::AASequence::ConstIterator::value_type
Residue value_type
Definition: AASequence.h:131
seqan::position
Size< TNeedle >::Type position(const PatternAuxData< TNeedle > &dh)
Definition: AhoCorasickAmbiguous.h:561
OpenMS::String::ConstIterator
const_iterator ConstIterator
Const Iterator.
Definition: String.h:73
OpenMS::AASequence::Iterator::pointer
const typedef Residue * pointer
Definition: AASequence.h:265
OpenMS::AASequence::Iterator::operator-
const Iterator operator-(difference_type diff) const
backward jump operator
Definition: AASequence.h:341
OpenMS::AASequence::ConstIterator::position_
difference_type position_
Definition: AASequence.h:248
OpenMS::AASequence::Iterator::~Iterator
virtual ~Iterator()
destructor
Definition: AASequence.h:291
OpenMS::AASequence::n_term_mod_
const ResidueModification * n_term_mod_
Definition: AASequence.h:626