36#include <pwiz/data/msdata/DefaultReaderList.hpp>
74 pwiz::msdata::DefaultReaderList defaultReaderList;
76 std::vector<pwiz::msdata::MSDataPtr> msDataPtrVector;
80 defaultReaderList.read(file_name_std, msDataPtrVector);
82 catch(std::exception &error)
84 qDebug() << QString(
"Failed to read the data from file %1")
85 .arg(QString::fromStdString(file_name_std));
87 throw(
PappsoException(QString(
"Error reading file %1 in PwizMsRunReader, for msrun %2:\n%3")
93 qDebug() <<
"The number of runs is:" << msDataPtrVector.size()
94 <<
"The number of spectra in first run is:"
95 << msDataPtrVector.at(0)->run.spectrumListPtr->size();
104 if(msDataPtrVector.size() != 1)
107 "one run in the file."));
117 for(
const pwiz::msdata::MSDataPtr &msDataPtr : msDataPtrVector)
119 qDebug() <<
"msDataPtr->run.id=" << msDataPtr->run.id.c_str();
120 qDebug() <<
"mcsp_msRunId->getRunId()=" <<
mcsp_msRunId->getRunId();
121 qDebug() <<
"mcsp_msRunId->getXmlId()=" <<
mcsp_msRunId->getXmlId();
122 qDebug() <<
"mcsp_msRunId->getSampleName()=" <<
mcsp_msRunId->getSampleName();
124 if(msDataPtr->run.id ==
mcsp_msRunId->getRunId().toStdString())
128 qDebug() <<
"Found the right MSDataPtr for run id.";
138 "matching the requested run id : %1")
145 pwiz::cv::CVID native_id_format = pwiz::msdata::id::getDefaultNativeIDFormat(*
msp_msData.get());
149 if(native_id_format == pwiz::cv::CVID::MS_Thermo_nativeID_format)
168const pwiz::msdata::MSDataPtr
182 term.
m_name =
"no nativeID format";
184 "No nativeID format indicates that the file tagged with this term does "
186 "contain spectra that can have a nativeID format.";
189 pwiz::cv::CVID cvid = pwiz::msdata::id::getDefaultNativeIDFormat(*(
msp_msData.get()));
193 case pwiz::cv::MS_Thermo_nativeID_format:
195 term.
m_name =
"Thermo nativeID format";
197 "Native format defined by controllerType=xsd:nonNegativeInteger "
198 "controllerNumber=xsd:positiveInteger scan=xsd:positiveInteger.";
206pwiz::msdata::SpectrumPtr
208 std::size_t spectrum_index,
209 bool want_binary_data)
const
211 pwiz::msdata::SpectrumPtr native_pwiz_spectrum_sp;
215 native_pwiz_spectrum_sp = p_spectrum_list->spectrum(spectrum_index, want_binary_data);
217 catch(std::runtime_error &error)
219 qDebug() <<
"getPwizSpectrumPtr error " << error.what() <<
" " <<
typeid(error).name();
222 "MS file std::runtime_error :\n%2")
226 catch(std::exception &error)
228 qDebug() <<
"getPwizSpectrumPtr error " << error.what() <<
typeid(error).name();
230 throw ExceptionNotFound(QObject::tr(
"Pwiz spectrum index %1 not found in MS file :\n%2")
235 if(native_pwiz_spectrum_sp.get() ==
nullptr)
238 QObject::tr(
"Pwiz spectrum index %1 not found in MS file : null pointer")
239 .arg(spectrum_index));
242 return native_pwiz_spectrum_sp;
254 if(!spectrum_p->scanList.scans[0].hasCVParam(pwiz::msdata::MS_scan_start_time))
267 pwiz::data::CVParam retention_time_cv_param =
268 spectrum_p->scanList.scans[0].cvParam(pwiz::msdata::MS_scan_start_time);
272 std::string unit_name = retention_time_cv_param.unitsName();
277 if(unit_name ==
"second")
279 qualified_mass_spectrum.
setRtInSeconds(retention_time_cv_param.valueAs<
double>());
281 else if(unit_name ==
"minute")
283 qualified_mass_spectrum.
setRtInSeconds(retention_time_cv_param.valueAs<
double>() * 60);
288 "scan start time value."));
316 if(spectrum_p->scanList.scans[0].hasCVParam(pwiz::msdata::MS_ion_mobility_drift_time))
326 .cvParam(pwiz::msdata::MS_ion_mobility_drift_time)
347 if(std::isnan(driftTime) || std::isinf(driftTime))
376 pwiz::msdata::Spectrum *spectrum_p,
377 bool want_binary_data,
382 if(spectrum_p ==
nullptr)
383 qFatal(
"Spectrum pointer cannot be nullptr.");
394 int msLevel = (spectrum_p->cvParam(pwiz::msdata::MS_ms_level).valueAs<int>());
398 if(!spectrum_p->scanList.scans[0].hasCVParam(pwiz::msdata::MS_peak_list_scans))
405 spectrum_p->cvParam(pwiz::msdata::MS_peak_list_scans).valueAs<
double>());
410 std::size_t precursor_list_size = spectrum_p->precursors.size();
417 if(precursor_list_size > 0)
423 qDebug() <<
"Going to throw: msLevel cannot be less than two for "
424 "a spectrum that has items in its Precursor list.";
428 "a spectrum that has items in its Precursor list."));
433 for(
auto &precursor : spectrum_p->precursors)
439 std::size_t precursor_spectrum_index = std::numeric_limits<std::size_t>::max();
443 if(precursor.spectrumID.empty())
471 QString::fromStdString(precursor.spectrumID));
482 precursor_spectrum_index =
483 msp_msData->run.spectrumListPtr->find(precursor.spectrumID);
487 if(precursor_spectrum_index ==
msp_msData->run.spectrumListPtr->size())
493 "precursor ion's spectrum."));
508 if(!precursor.selectedIons.size())
510 qDebug() <<
"Going to throw The spectrum has msLevel > 1 but the "
511 "precursor ions's selected ions list is empty..";
515 "precursor ions's selected ions "
519 pwiz::msdata::SelectedIon &ion = *(precursor.selectedIons.begin());
524 QString(ion.cvParam(pwiz::cv::MS_selected_ion_m_z).value.c_str()).toDouble();
533 QString(ion.cvParam(pwiz::cv::MS_peak_intensity).value.c_str()).toDouble();
537 unsigned int selected_ion_charge_state =
538 QString(ion.cvParam(pwiz::cv::MS_charge_state).value.c_str()).toUInt();
544 selected_ion_mz, selected_ion_charge_state, selected_ion_peak_intensity);
586 qDebug() <<
"Going to throw The number of precursors in the file is "
587 "different from the number of precursors in memory.";
590 QObject::tr(
"The number of precursors in the file is different "
591 "from the number of precursors in memory."));
619 std::vector<pwiz::msdata::MZIntensityPair> pairs;
620 spectrum_p->getMZIntensityPairs(pairs);
627 for(std::vector<pwiz::msdata::MZIntensityPair>::const_iterator it = pairs.begin(),
638 spectrum.push_back(
DataPoint(it->mz, it->intensity));
639 tic += it->intensity;
667 qDebug() <<
"Going to throw";
670 QObject::tr(
"Error reading data using the proteowizard library: %1").arg(errorp.
qwhat()));
672 catch(std::exception &error)
674 qDebug() <<
"Going to throw";
677 QObject::tr(
"Error reading data using the proteowizard library: %1").arg(error.what()));
684 return qualified_mass_spectrum;
690 bool want_binary_data,
706 pwiz::msdata::SpectrumListPtr spectrum_list_p =
msp_msData->run.spectrumListPtr;
708 if(spectrum_index == spectrum_list_p.get()->size())
712 QObject::tr(
"The spectrum index cannot be equal to the size of the "
720 pwiz::msdata::SpectrumPtr native_pwiz_spectrum_sp =
725 massSpectrumId.
setNativeId(QString::fromStdString(native_pwiz_spectrum_sp->id));
728 massSpectrumId, native_pwiz_spectrum_sp.get(), want_binary_data, ok);
736 pwiz::msdata::ReaderList reader_list;
738 std::string reader_type = reader_list.identify(file_name.toStdString());
740 if(!reader_type.empty())
792 catch(std::exception &error)
794 qDebug() <<
"Going to throw";
797 QObject::tr(
"Error reading data (spectrum collection) using the "
798 "proteowizard library: %1")
812 catch(std::exception &error)
814 qDebug() <<
"Going to throw";
817 QObject::tr(
"Error reading data (spectrum collection2) using the "
818 "proteowizard library: %1")
825 unsigned int ms_level)
847 pwiz::msdata::SpectrumListPtr spectrum_list_p =
msp_msData->run.spectrumListPtr;
850 std::size_t spectrum_list_size = spectrum_list_p.get()->size();
860 for(std::size_t iter = 0; iter < spectrum_list_size; iter++)
867 qDebug() <<
"The operation was cancelled. Breaking the loop.";
874 pwiz::msdata::SpectrumPtr native_pwiz_spectrum_sp =
899 QString native_id = QString::fromStdString(native_pwiz_spectrum_sp->id);
909 massSpectrumId, native_pwiz_spectrum_sp.get(), want_binary_data, ok);
934 if(qualified_mass_spectrum.
getMsLevel() == ms_level)
978 pwiz::msdata::SpectrumListPtr spectrum_list_p =
msp_msData->run.spectrumListPtr;
981 std::size_t spectrum_list_size = spectrum_list_p.get()->size();
992 for(std::size_t iter = 0; iter < spectrum_list_size; iter++)
1000 qDebug() <<
"The operation was cancelled. Breaking the loop.";
1008 pwiz::msdata::SpectrumPtr native_pwiz_spectrum_sp =
1035 QString native_id = QString::fromStdString(native_pwiz_spectrum_sp->id);
1045 massSpectrumId, native_pwiz_spectrum_sp.get(), want_binary_data, ok);
1086 qDebug() <<
"Loading ended";
1093 return msp_msData->run.spectrumListPtr.get()->size();
1145 std::string env_backup;
1152 std::string env_backup = std::setlocale(LC_ALL,
nullptr);
1153 std::setlocale(LC_ALL,
"C");
1155 std::locale::global(std::locale(
"C"));
1158 catch(std::exception &error)
1161 QObject::tr(
"Error trying to set local to C : %1").arg(error.what()));
1174 std::setlocale(LC_ALL, environment_locale.c_str());
1176 std::locale::global(std::locale(
""));
1179 catch(std::exception &error)
1182 QObject::tr(
"Error trying to set local to original system one %1 : %2")
1183 .arg(environment_locale.c_str())
1184 .arg(error.what()));
1192 std::size_t spectrum_id =
1193 msp_msData->run.spectrumListPtr->find(spectrum_identifier.toStdString());
1194 if(spectrum_id ==
msp_msData->run.spectrumListPtr->size())
1197 QObject::tr(
"Spectrum identifier %1 not found").arg(spectrum_identifier));
1229 for(
auto ¶m_group :
msp_msData.get()->paramGroupPtrs)
1231 for (
const auto &cv_param : param_group.get()->cvParams) {
1232 if(cv_param.cvid == pwiz::cv::CVID::MS_Q_Exactive)
1236 else if(cv_param.cvid == pwiz::cv::CVID::MS_Velos_Plus)
1241 else if(cv_param.cvid == pwiz::cv::CVID::MS_LTQ_Orbitrap_Elite)
1250 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Fusion)
1259 else if(cv_param.cvid == pwiz::cv::CVID::MS_Q_Exactive_HF)
1268 else if(cv_param.cvid == pwiz::cv::CVID::MS_Exactive_Plus)
1273 else if(cv_param.cvid == pwiz::cv::CVID::MS_Q_Exactive_Plus)
1280 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Fusion_Lumos)
1285 else if(cv_param.cvid == pwiz::cv::CVID::MS_Q_Exactive_HF_X)
1292 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Exploris_480)
1299 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Eclipse)
1306 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Exploris_240)
1313 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Exploris_120)
1319 else if(cv_param.cvid == pwiz::cv::CVID::MS_LTQ_Orbitrap_Velos_Pro)
1325 else if(cv_param.cvid == pwiz::cv::CVID::MS_Q_Exactive_UHMR)
1330 else if(cv_param.cvid == pwiz::cv::CVID::MS_TSQ_Altis_Plus)
1337 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Ascend)
1344 else if(cv_param.cvid == pwiz::cv::CVID::MS_Orbitrap_Astral)
const OboPsiModTerm & getOboPsiModTermWithAccession(const QString &accession) const
void setNativeId(const QString &native_id)
void setSpectrumIndex(std::size_t index)
Class to represent a mass spectrum.
void sortMz()
Sort the DataPoint instances of this spectrum.
MassSpectrumSPtr makeMassSpectrumSPtr() const
bool needPeakList() const
bool acceptMsLevel(std::size_t ms_level) const
bool acceptRetentionTimeInSeconds(double retention_time_in_seconds) const
MsRunIdCstSPtr mcsp_msRunId
MsRunReader(const MsRunIdCstSPtr &ms_run_id)
void setAccession(const QString &accession)
virtual const QString & qwhat() const
virtual pappso::XicCoordSPtr newXicCoordSPtrFromSpectrumIndex(std::size_t spectrum_index, pappso::PrecisionPtr precision) const override
get a xic coordinate object from a given spectrum index
pwiz::msdata::MSDataPtr msp_msData
virtual void readSpectrumCollectionByMsLevel(SpectrumCollectionHandlerInterface &handler, unsigned int ms_level) override
function to visit an MsRunReader and get each Spectrum in a spectrum collection handler by Ms Levels
static std::string setGlobalLocaleToEnglish()
virtual void readSpectrumCollectionWithMsrunReadConfig(const MsRunReadConfig &config, SpectrumCollectionHandlerInterface &handler)
bool processDriftTime(pwiz::msdata::Spectrum *spectrum_p, QualifiedMassSpectrum &qualified_mass_spectrum) const
virtual MassSpectrumCstSPtr massSpectrumCstSPtr(std::size_t spectrum_index) override
const pwiz::msdata::MSDataPtr getMsDataPtr() const
QualifiedMassSpectrum qualifiedMassSpectrumFromPwizMSData(std::size_t spectrum_index, bool want_binary_data, bool &ok) const
PwizMsRunReader(MsRunIdCstSPtr &msrun_id_csp)
static void setGlobalLocaleToCurrentOs(const std::string &environment_locale)
QualifiedMassSpectrum qualifiedMassSpectrumFromPwizSpectrumPtr(const MassSpectrumId &massSpectrumId, pwiz::msdata::Spectrum *spectrum_p, bool want_binary_data, bool &ok) const
virtual void readSpectrumCollection2(const MsRunReadConfig &config, SpectrumCollectionHandlerInterface &handler) override
function to visit an MsRunReader and get each Spectrum in a spectrum collection handler
virtual std::size_t spectrumStringIdentifier2SpectrumIndex(const QString &spectrum_identifier) override
if possible, get the spectrum index given a string identifier throw a not found exception if spectrum...
virtual QualifiedMassSpectrum qualifiedMassSpectrum(std::size_t spectrum_index, bool want_binary_data=true) const override
get a QualifiedMassSpectrum class given its scan number
virtual bool hasScanNumbers() const override
tells if spectra can be accessed using scan numbers by default, it returns false. Only overrided func...
bool processRetentionTime(pwiz::msdata::Spectrum *spectrum_p, QualifiedMassSpectrum &qualified_mass_spectrum) const
virtual bool acquireDevice() override
acquire data back end device
virtual const OboPsiModTerm getOboPsiModTermInstrumentModelName() const override
get OboPsiModTerm corresponding to the instrument model name child of : [Term] id: MS:1000031 name: i...
virtual ~PwizMsRunReader()
virtual void initialize() override
virtual void readSpectrumCollection(SpectrumCollectionHandlerInterface &handler) override
function to visit an MsRunReader and get each Spectrum in a spectrum collection handler
virtual bool accept(const QString &file_name) const override
tells if the reader is able to handle this file must be implemented by private MS run reader,...
virtual std::size_t spectrumListSize() const override
get the totat number of spectrum conained in the MSrun data file
pwiz::msdata::SpectrumPtr getPwizSpectrumPtr(pwiz::msdata::SpectrumList *p_spectrum_list, std::size_t spectrum_index, bool want_binary_data) const
virtual bool releaseDevice() override
release data back end device if a the data back end is released, the developper has to use acquireDev...
virtual pappso::XicCoordSPtr newXicCoordSPtrFromQualifiedMassSpectrum(const pappso::QualifiedMassSpectrum &mass_spectrum, pappso::PrecisionPtr precision) const override
get a xic coordinate object from a given spectrum
const OboPsiModTerm getOboPsiModTermNativeIDFormat() const
get OboPsiModTerm corresponding to the nativeID format format of mz data
virtual MassSpectrumSPtr massSpectrumSPtr(std::size_t spectrum_index) override
get a MassSpectrumSPtr class given its spectrum index
Class representing a fully specified mass spectrum.
uint getMsLevel() const
Get the mass spectrum level.
MassSpectrumCstSPtr getMassSpectrumCstSPtr() const
Get the MassSpectrumCstSPtr.
void setPrecursorNativeId(const QString &native_id)
Set the scan native id of the precursor ion.
const std::vector< PrecursorIonData > & getPrecursorIonData() const
void setDtInMilliSeconds(pappso_double rt)
Set the drift time in milliseconds.
const QString & getPrecursorNativeId() const
void appendPrecursorIonData(const PrecursorIonData &precursor_ion_data)
void setMsLevel(uint ms_level)
Set the mass spectrum level.
void setPrecursorSpectrumIndex(std::size_t precursor_scan_num)
Set the scan number of the precursor ion.
pappso_double getPrecursorMz(bool *ok=nullptr) const
get precursor mz
MassSpectrumSPtr getMassSpectrumSPtr() const
Get the MassSpectrumSPtr.
void setParameterValue(QualifiedMassSpectrumParameter parameter, const QVariant &value)
void setMassSpectrumSPtr(MassSpectrumSPtr massSpectrum)
Set the MassSpectrumSPtr.
void setRtInSeconds(pappso_double rt)
Set the retention time in seconds.
pappso_double getRtInSeconds() const
Get the retention time in seconds.
void setEmptyMassSpectrum(bool is_empty_mass_spectrum)
interface to collect spectrums from the MsRunReader class
virtual bool shouldStop()
virtual bool needPeakList() const =0
tells if we need the peak list (if we want the binary data) for each spectrum
virtual void loadingEnded()
virtual void spectrumListHasSize(std::size_t size)
virtual void setQualifiedMassSpectrum(const QualifiedMassSpectrum &spectrum)=0
static std::string toUtf8StandardString(const QString &text)
tries to keep as much as possible monoisotopes, removing any possible C13 peaks and changes multichar...
std::shared_ptr< const MsRunId > MsRunIdCstSPtr
double pappso_double
A type definition for doubles.
std::shared_ptr< const MassSpectrum > MassSpectrumCstSPtr
const PrecisionBase * PrecisionPtr
std::shared_ptr< MassSpectrum > MassSpectrumSPtr
std::shared_ptr< XicCoord > XicCoordSPtr