libpappsomspp
Library for mass spectrometry
pappso::MsRunReaderScanNumberMultiMap Class Reference

provides a multimap to find quickly spectrum index from scan number More...

#include <msrunreader.h>

Inheritance diagram for pappso::MsRunReaderScanNumberMultiMap:
pappso::SpectrumCollectionHandlerInterface

Public Member Functions

 MsRunReaderScanNumberMultiMap ()
 
virtual ~MsRunReaderScanNumberMultiMap ()
 
virtual void setQualifiedMassSpectrum (const QualifiedMassSpectrum &spectrum) override
 
virtual bool needPeakList () const override
 tells if we need the peak list (if we want the binary data) for each spectrum More...
 
std::size_t getSpectrumIndexFromScanNumber (std::size_t scan_number) const
 
- Public Member Functions inherited from pappso::SpectrumCollectionHandlerInterface
virtual bool needMsLevelPeakList (unsigned int ms_level) const final
 tells if we need the peak list (if we want the binary data) for each spectrum, given an MS level More...
 
virtual void setNeedMsLevelPeakList (unsigned int ms_level, bool want_peak_list) final
 tells if we need the peak list given More...
 
virtual bool shouldStop ()
 
virtual void loadingEnded ()
 
virtual void spectrumListHasSize (std::size_t size)
 
virtual void setReadAhead (bool is_read_ahead) final
 use threads to read a spectrum by batch of batch_size More...
 
virtual bool isReadAhead () const
 tells if we want to read ahead spectrum More...
 

Private Attributes

std::multimap< std::size_t, std::size_t > m_mmap_scan2index
 

Detailed Description

provides a multimap to find quickly spectrum index from scan number

Definition at line 133 of file msrunreader.h.

Constructor & Destructor Documentation

◆ MsRunReaderScanNumberMultiMap()

pappso::MsRunReaderScanNumberMultiMap::MsRunReaderScanNumberMultiMap ( )

Definition at line 152 of file msrunreader.cpp.

153 {
154  // qDebug();
155 }

◆ ~MsRunReaderScanNumberMultiMap()

pappso::MsRunReaderScanNumberMultiMap::~MsRunReaderScanNumberMultiMap ( )
virtual

Definition at line 158 of file msrunreader.cpp.

159 {
160  // qDebug();
161 }

Member Function Documentation

◆ getSpectrumIndexFromScanNumber()

std::size_t pappso::MsRunReaderScanNumberMultiMap::getSpectrumIndexFromScanNumber ( std::size_t  scan_number) const

Definition at line 194 of file msrunreader.cpp.

196 {
197 
198  qDebug() << m_mmap_scan2index.size();
199 
200  auto it = m_mmap_scan2index.find(scan_number);
201 
202  if(it == m_mmap_scan2index.end())
203  {
204  throw ExceptionNotFound(
205  QObject::tr("scan number %1 not found").arg(scan_number));
206  }
207 
208  std::size_t index = it->second;
209 
210  it++;
211  if((it != m_mmap_scan2index.end()) && (it->first == scan_number))
212  {
213  throw PappsoException(
214  QObject::tr("scan number %1 found multiple times").arg(scan_number));
215  }
216  return index;
217 }
std::multimap< std::size_t, std::size_t > m_mmap_scan2index
Definition: msrunreader.h:137

References m_mmap_scan2index.

Referenced by pappso::MsRunReader::scanNumber2SpectrumIndex().

◆ needPeakList()

bool pappso::MsRunReaderScanNumberMultiMap::needPeakList ( ) const
overridevirtual

tells if we need the peak list (if we want the binary data) for each spectrum

Implements pappso::SpectrumCollectionHandlerInterface.

Definition at line 165 of file msrunreader.cpp.

166 {
167  return false;
168 }

◆ setQualifiedMassSpectrum()

void pappso::MsRunReaderScanNumberMultiMap::setQualifiedMassSpectrum ( const QualifiedMassSpectrum spectrum)
overridevirtual

Implements pappso::SpectrumCollectionHandlerInterface.

Definition at line 171 of file msrunreader.cpp.

173 {
174  qDebug() << " " << qspectrum.getMassSpectrumId().getNativeId();
175 
176  QStringList native_id_list =
177  qspectrum.getMassSpectrumId().getNativeId().split("=");
178  if(native_id_list.size() < 2)
179  {
180  return;
181  }
182  else
183  {
184  std::size_t scan_number = native_id_list.back().toULong();
185  m_mmap_scan2index.insert(std::pair<std::size_t, std::size_t>(
186  scan_number, qspectrum.getMassSpectrumId().getSpectrumIndex()));
187 
188  qDebug() << "scan number " << scan_number << "=>"
189  << qspectrum.getMassSpectrumId().getSpectrumIndex();
190  }
191 }

References pappso::QualifiedMassSpectrum::getMassSpectrumId(), pappso::MassSpectrumId::getNativeId(), pappso::MassSpectrumId::getSpectrumIndex(), and m_mmap_scan2index.

Member Data Documentation

◆ m_mmap_scan2index

std::multimap<std::size_t, std::size_t> pappso::MsRunReaderScanNumberMultiMap::m_mmap_scan2index
private

Definition at line 137 of file msrunreader.h.

Referenced by getSpectrumIndexFromScanNumber(), and setQualifiedMassSpectrum().


The documentation for this class was generated from the following files: