libpappsomspp
Library for mass spectrometry
pappso::PeptideNaturalIsotopeAverage Class Reference

#include <peptidenaturalisotopeaverage.h>

Public Member Functions

 PeptideNaturalIsotopeAverage (const PeptideInterfaceSp &peptide, unsigned int askedIsotopeRank, unsigned int isotopeLevel, unsigned int charge, PrecisionPtr precision)
 
 PeptideNaturalIsotopeAverage (const PeptideNaturalIsotopeList &isotopeList, unsigned int askedIsotopeRank, unsigned int isotopeLevel, unsigned int charge, PrecisionPtr precision)
 
 PeptideNaturalIsotopeAverage (const PeptideNaturalIsotopeAverage &other)
 
 ~PeptideNaturalIsotopeAverage ()
 
PeptideNaturalIsotopeAverageSp makePeptideNaturalIsotopeAverageSp () const
 
pappso_double getMz () const
 
pappso_double getIntensityRatio () const
 
unsigned int getCharge () const
 
unsigned int getIsotopeNumber () const
 
unsigned int getIsotopeRank () const
 
const std::vector< PeptideNaturalIsotopeSp > & getComponents () const
 
const PeptideInterfaceSpgetPeptideInterfaceSp () const
 
PrecisionPtr getPrecision () const
 
virtual bool matchPeak (pappso_double peak_mz) const final
 
bool isEmpty () const
 

Private Member Functions

void recursiveDepletion (std::vector< PeptideNaturalIsotopeSp > &v_isotope_list, unsigned int rank)
 

Private Attributes

const PeptideInterfaceSp mcsp_peptideSp
 
std::vector< PeptideNaturalIsotopeSpm_peptideNaturalIsotopeSpList
 
pappso_double m_averageMz
 
pappso_double m_abundanceRatio
 
unsigned int m_isotopeLevel
 
unsigned int m_isotopeRank = 1
 
unsigned int m_z
 
PrecisionPtr mp_precision = nullptr
 

Detailed Description

Definition at line 63 of file peptidenaturalisotopeaverage.h.

Constructor & Destructor Documentation

◆ PeptideNaturalIsotopeAverage() [1/3]

pappso::PeptideNaturalIsotopeAverage::PeptideNaturalIsotopeAverage ( const PeptideInterfaceSp peptide,
unsigned int  askedIsotopeRank,
unsigned int  isotopeLevel,
unsigned int  charge,
PrecisionPtr  precision 
)

Definition at line 53 of file peptidenaturalisotopeaverage.cpp.

57 { // get the askedIsotopeRank :
58  std::vector<PeptideNaturalIsotopeSp> v_isotope_list(
59  isotopeList.getByIsotopeNumber(isotope_number, m_z));
60 
61  // qDebug() << __FILE__ << " " << __FUNCTION__ << " " << __LINE__
62  // << "v_isotope_list.size()=" << v_isotope_list.size() << " "
63  // << isotope_number << " " << askedIsotopeRank;
64  m_abundanceRatio = 0;
65  m_averageMz = 0;

◆ PeptideNaturalIsotopeAverage() [2/3]

pappso::PeptideNaturalIsotopeAverage::PeptideNaturalIsotopeAverage ( const PeptideNaturalIsotopeList isotopeList,
unsigned int  askedIsotopeRank,
unsigned int  isotopeLevel,
unsigned int  charge,
PrecisionPtr  precision 
)

Definition at line 67 of file peptidenaturalisotopeaverage.cpp.

67  {
68  // there is no isotope at this rank
69  return;
70  // throw PappsoException(QObject::tr("askedIsotopeRank greater than
71  // v_isotope_list.size() %1 vs
72  // %2").arg(askedIsotopeRank).arg(v_isotope_list.size()));
73  }
74  else if(askedIsotopeRank < 1)
75  {
76  throw PappsoException(
77  QObject::tr("askedIsotopeRank must be 1 or more and not %1")
78  .arg(askedIsotopeRank));
79  }
80 
81  unsigned int rank = 0;
82 
83  recursiveDepletion(v_isotope_list, rank);
84 
85  // qDebug() << __FILE__ << " " << __FUNCTION__ << " " << __LINE__;
86 }
87 
88 
89 void
91  std::vector<PeptideNaturalIsotopeSp> &v_isotope_list, unsigned int rank)
92 {
93  rank++;
94 
95  m_abundanceRatio = 0;
96  m_averageMz = 0;
98  std::vector<PeptideNaturalIsotopeSp> peptide_list;
99  // select neighbors in the precision range :
100  MzRange mz_range(v_isotope_list[0].get()->getMz(m_z), mp_precision);
101 
102  for(auto &isotope_sp : v_isotope_list)
103  {
104  if(mz_range.contains(isotope_sp.get()->getMz(m_z)))
105  {
106  peptide_list.push_back(isotope_sp);
107  m_abundanceRatio += isotope_sp.get()->getIntensityRatio(m_z);

◆ PeptideNaturalIsotopeAverage() [3/3]

pappso::PeptideNaturalIsotopeAverage::PeptideNaturalIsotopeAverage ( const PeptideNaturalIsotopeAverage other)

Definition at line 180 of file peptidenaturalisotopeaverage.cpp.

185 {
186  return m_abundanceRatio;
187 }
188 
189 unsigned int
191 {
192  return m_z;

◆ ~PeptideNaturalIsotopeAverage()

pappso::PeptideNaturalIsotopeAverage::~PeptideNaturalIsotopeAverage ( )

Definition at line 194 of file peptidenaturalisotopeaverage.cpp.

197 {

References m_isotopeLevel.

Member Function Documentation

◆ getCharge()

unsigned int pappso::PeptideNaturalIsotopeAverage::getCharge ( ) const

Definition at line 211 of file peptidenaturalisotopeaverage.cpp.

215 {

◆ getComponents()

const std::vector< PeptideNaturalIsotopeSp > & pappso::PeptideNaturalIsotopeAverage::getComponents ( ) const

Definition at line 229 of file peptidenaturalisotopeaverage.cpp.

◆ getIntensityRatio()

pappso_double pappso::PeptideNaturalIsotopeAverage::getIntensityRatio ( ) const

◆ getIsotopeNumber()

unsigned int pappso::PeptideNaturalIsotopeAverage::getIsotopeNumber ( ) const

Definition at line 217 of file peptidenaturalisotopeaverage.cpp.

221 {

◆ getIsotopeRank()

unsigned int pappso::PeptideNaturalIsotopeAverage::getIsotopeRank ( ) const

◆ getMz()

pappso_double pappso::PeptideNaturalIsotopeAverage::getMz ( ) const

Definition at line 199 of file peptidenaturalisotopeaverage.cpp.

203 {

◆ getPeptideInterfaceSp()

const PeptideInterfaceSp & pappso::PeptideNaturalIsotopeAverage::getPeptideInterfaceSp ( ) const

Definition at line 235 of file peptidenaturalisotopeaverage.cpp.

236 {
237  return (m_peptideNaturalIsotopeSpList.size() == 0);
238 }

References m_peptideNaturalIsotopeSpList.

◆ getPrecision()

PrecisionPtr pappso::PeptideNaturalIsotopeAverage::getPrecision ( ) const

Definition at line 241 of file peptidenaturalisotopeaverage.cpp.

◆ isEmpty()

bool pappso::PeptideNaturalIsotopeAverage::isEmpty ( ) const

Definition at line 256 of file peptidenaturalisotopeaverage.cpp.

◆ makePeptideNaturalIsotopeAverageSp()

PeptideNaturalIsotopeAverageSp pappso::PeptideNaturalIsotopeAverage::makePeptideNaturalIsotopeAverageSp ( ) const

◆ matchPeak()

bool pappso::PeptideNaturalIsotopeAverage::matchPeak ( pappso_double  peak_mz) const
finalvirtual

◆ recursiveDepletion()

void pappso::PeptideNaturalIsotopeAverage::recursiveDepletion ( std::vector< PeptideNaturalIsotopeSp > &  v_isotope_list,
unsigned int  rank 
)
private

Definition at line 111 of file peptidenaturalisotopeaverage.cpp.

114  {
116 
117  // depletion
118  auto it_remove = std::remove_if(
119  v_isotope_list.begin(),
120  v_isotope_list.end(),
121  [peptide_list](const PeptideNaturalIsotopeSp &isotope_sp) {
122  auto it =
123  std::find(peptide_list.begin(), peptide_list.end(), isotope_sp);
124  return (it != peptide_list.end());
125  });
126  v_isotope_list.erase(it_remove, v_isotope_list.end());
127 
128  if(rank == m_isotopeRank)
129  {
130  m_peptideNaturalIsotopeSpList = peptide_list;
131  return;
132  }
133  else
134  {
135  unsigned int charge = m_z;
136  std::sort(v_isotope_list.begin(),
137  v_isotope_list.end(),
138  [charge](const PeptideNaturalIsotopeSp &m,
139  const PeptideNaturalIsotopeSp &n) {
140  return (m.get()->getIntensityRatio(charge) >
141  n.get()->getIntensityRatio(charge));
142  });
143  recursiveDepletion(v_isotope_list, rank);
144  }
145  }
146  else
147  {
148  m_abundanceRatio = 0;
149  m_averageMz = 0;
150  }
151 }
152 
155 {
156  return std::make_shared<PeptideNaturalIsotopeAverage>(*this);
157 }
158 
160  const PeptideNaturalIsotopeAverage &other)
162 {
163 
164  m_peptideNaturalIsotopeSpList = other.m_peptideNaturalIsotopeSpList;
165 
166  m_averageMz = other.m_averageMz;
167  m_abundanceRatio = other.m_abundanceRatio;
168  m_isotopeLevel = other.m_isotopeLevel;
169  m_isotopeRank = other.m_isotopeRank;
170  m_z = other.m_z;
171 }
172 

Member Data Documentation

◆ m_abundanceRatio

pappso_double pappso::PeptideNaturalIsotopeAverage::m_abundanceRatio
private

Definition at line 102 of file peptidenaturalisotopeaverage.h.

◆ m_averageMz

pappso_double pappso::PeptideNaturalIsotopeAverage::m_averageMz
private

Definition at line 101 of file peptidenaturalisotopeaverage.h.

◆ m_isotopeLevel

unsigned int pappso::PeptideNaturalIsotopeAverage::m_isotopeLevel
private

Definition at line 103 of file peptidenaturalisotopeaverage.h.

Referenced by ~PeptideNaturalIsotopeAverage().

◆ m_isotopeRank

unsigned int pappso::PeptideNaturalIsotopeAverage::m_isotopeRank = 1
private

Definition at line 104 of file peptidenaturalisotopeaverage.h.

◆ m_peptideNaturalIsotopeSpList

std::vector<PeptideNaturalIsotopeSp> pappso::PeptideNaturalIsotopeAverage::m_peptideNaturalIsotopeSpList
private

Definition at line 99 of file peptidenaturalisotopeaverage.h.

Referenced by getPeptideInterfaceSp().

◆ m_z

unsigned int pappso::PeptideNaturalIsotopeAverage::m_z
private

Definition at line 105 of file peptidenaturalisotopeaverage.h.

◆ mcsp_peptideSp

const PeptideInterfaceSp pappso::PeptideNaturalIsotopeAverage::mcsp_peptideSp
private

Definition at line 98 of file peptidenaturalisotopeaverage.h.

◆ mp_precision

PrecisionPtr pappso::PeptideNaturalIsotopeAverage::mp_precision = nullptr
private

Definition at line 106 of file peptidenaturalisotopeaverage.h.


The documentation for this class was generated from the following files:
pappso::PeptideNaturalIsotopeAverage::getMz
pappso_double getMz() const
Definition: peptidenaturalisotopeaverage.cpp:199
pappso::PeptideNaturalIsotopeAverage::getCharge
unsigned int getCharge() const
Definition: peptidenaturalisotopeaverage.cpp:211
pappso::PeptideNaturalIsotopeAverage::mp_precision
PrecisionPtr mp_precision
Definition: peptidenaturalisotopeaverage.h:106
pappso::PeptideNaturalIsotopeAverage::m_peptideNaturalIsotopeSpList
std::vector< PeptideNaturalIsotopeSp > m_peptideNaturalIsotopeSpList
Definition: peptidenaturalisotopeaverage.h:99
pappso::PeptideNaturalIsotopeAverage::recursiveDepletion
void recursiveDepletion(std::vector< PeptideNaturalIsotopeSp > &v_isotope_list, unsigned int rank)
Definition: peptidenaturalisotopeaverage.cpp:111
pappso::PeptideNaturalIsotopeAverage::m_isotopeRank
unsigned int m_isotopeRank
Definition: peptidenaturalisotopeaverage.h:104
pappso::PeptideNaturalIsotopeAverage::m_averageMz
pappso_double m_averageMz
Definition: peptidenaturalisotopeaverage.h:101
pappso::PeptideNaturalIsotopeAverage::PeptideNaturalIsotopeAverage
PeptideNaturalIsotopeAverage(const PeptideInterfaceSp &peptide, unsigned int askedIsotopeRank, unsigned int isotopeLevel, unsigned int charge, PrecisionPtr precision)
Definition: peptidenaturalisotopeaverage.cpp:53
pappso::PeptideNaturalIsotopeSp
std::shared_ptr< const PeptideNaturalIsotope > PeptideNaturalIsotopeSp
Definition: peptidenaturalisotope.h:62
pappso::PeptideNaturalIsotopeAverage::makePeptideNaturalIsotopeAverageSp
PeptideNaturalIsotopeAverageSp makePeptideNaturalIsotopeAverageSp() const
Definition: peptidenaturalisotopeaverage.cpp:175
pappso::PeptideNaturalIsotopeAverage::m_z
unsigned int m_z
Definition: peptidenaturalisotopeaverage.h:105
pappso::PeptideNaturalIsotopeAverage::mcsp_peptideSp
const PeptideInterfaceSp mcsp_peptideSp
Definition: peptidenaturalisotopeaverage.h:98
pappso::PeptideNaturalIsotopeAverage::m_abundanceRatio
pappso_double m_abundanceRatio
Definition: peptidenaturalisotopeaverage.h:102
pappso::PeptideNaturalIsotopeAverageSp
std::shared_ptr< const PeptideNaturalIsotopeAverage > PeptideNaturalIsotopeAverageSp
Definition: peptidenaturalisotopeaverage.h:58