pappsomspp
Library for mass spectrometry
peptidevariablemodificationbuilder.h
Go to the documentation of this file.
1 /*******************************************************************************
2  * Copyright (c) 2015 Olivier Langella <Olivier.Langella@moulon.inra.fr>.
3  *
4  * This file is part of the PAPPSOms++ library.
5  *
6  * PAPPSOms++ is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * PAPPSOms++ is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with PAPPSOms++. If not, see <http://www.gnu.org/licenses/>.
18  *
19  * Contributors:
20  * Olivier Langella <Olivier.Langella@moulon.inra.fr> - initial API and
21  *implementation
22  ******************************************************************************/
23 
24 #pragma once
25 
26 
27 #include "peptidemodificatorbase.h"
28 
29 namespace pappso
30 {
31 
32 
33 /** \brief Modify a peptide shared pointer with a variable modification on one
34  * AA
35  * */
36 class PMSPP_LIB_DECL PeptideVariableModificationBuilder
37  : public PeptideModificatorBase
38 {
39  private:
40  QString m_aaModificationList;
41 
42  protected:
43  static bool next_combination(const std::vector<unsigned int>::iterator first,
44  std::vector<unsigned int>::iterator k,
45  const std::vector<unsigned int>::iterator last);
46 
47  PeptideModificatorInterface *m_sink = nullptr;
48  AaModificationP mp_mod;
49  // minimum number of positions to modify
50  unsigned int m_minNumberMod = 0;
51  // maximum number of positions to modify
52  unsigned int m_maxNumberMod = 30000;
53  // modification counter per site
54  unsigned int m_modificationCount = 0;
55 
56  // protein Nter modification
57  bool m_isProtNterMod = true;
58  // protein Cter modification
59  bool m_isProtCterMod = true;
60 
61  bool m_isProtElseMod = true;
62 
63  public:
66  void setPeptideSp(std::int8_t sequence_database_id,
67  const ProteinSp &protein_sp,
68  bool is_decoy,
69  const PeptideSp &peptide_sp_original,
70  unsigned int start,
71  bool is_nter,
72  unsigned int missed_cleavage_number,
73  bool semi_enzyme) override;
74 
75  void addAa(char aa);
76 
77  void
78  setMaxNumberMod(unsigned int max_num)
79  {
80  m_maxNumberMod = max_num;
81  };
82  void
83  setMinNumberMod(unsigned int min_num)
84  {
85  m_minNumberMod = min_num;
86  };
87  void
88  setModificationCounter(unsigned int counter)
89  {
90  m_modificationCount = counter;
91  };
92 
93  void
94  setSink(PeptideModificatorInterface *sink) override
95  {
96  m_sink = sink;
97  };
98 
99 
100  /** \brief this modification concerns the Nter peptide
101  * */
102  void
103  setProtNter(bool arg1)
104  {
105  m_isProtNterMod = arg1;
106  };
107  /** \brief this modification concerns the Cter peptide
108  * */
109  void
110  setProtCter(bool arg1)
111  {
112  m_isProtCterMod = arg1;
113  };
114  /** \brief this modification concerns all peptides between Nter and Cter
115  * */
116  void
117  setProtElse(bool arg1)
118  {
119  m_isProtElseMod = arg1;
120  };
121 };
122 
123 
124 } // namespace pappso
PMSPP_LIB_DECL
#define PMSPP_LIB_DECL
Definition: exportinmportconfig.h:12
pappso
Definition: aa.cpp:38
peptidemodificatorbase.h
base class for all peptide modification builders
pappso::PeptideModificatorInterface
Definition: enzymeproductinterface.h:83
pappso::ProteinSp
std::shared_ptr< const Protein > ProteinSp
shared pointer on a Protein object
Definition: protein.h:62
pappso::QualifiedMassSpectrumParameter::last
pappso::AaModificationP
const typedef AaModification * AaModificationP
Definition: aamodification.h:71
pappso::PeptideVariableModificationBuilder
Modify a peptide shared pointer with a variable modification on one AA.
Definition: peptidevariablemodificationbuilder.h:55
pappso::PeptideSp
std::shared_ptr< const Peptide > PeptideSp
Definition: aamodification.h:66