35 #ifndef OPENMS_ANALYSIS_ID_IDMAPPER_H 36 #define OPENMS_ANALYSIS_ID_IDMAPPER_H 71 enum Measure {MEASURE_PPM = 0, MEASURE_DA};
97 void annotate(
PeakMap& map,
const std::vector<PeptideIdentification>& peptide_ids,
const std::vector<ProteinIdentification>& protein_ids,
const bool clear_ids =
false,
const bool mapMS1 =
false)
99 checkHits_(peptide_ids);
103 std::vector<PeptideIdentification> empty_ids;
106 it->setPeptideIdentifications(empty_ids);
108 std::vector<ProteinIdentification> empty_prot_ids;
112 if (peptide_ids.empty())
return;
118 std::multimap<double, Size> experiment_precursors;
119 for (
Size i = 0; i < map.
size(); i++)
121 experiment_precursors.insert(std::make_pair(map[i].getRT(), i));
125 std::multimap<double, Size> identifications_precursors;
126 for (
Size i = 0; i < peptide_ids.size(); ++i)
128 if (!peptide_ids[i].empty())
130 identifications_precursors.insert(std::make_pair(peptide_ids[i].getRT(), i));
136 std::set<Size> peptides_mapped;
139 std::multimap<double, Size>::const_iterator experiment_iterator = experiment_precursors.begin();
140 std::multimap<double, Size>::const_iterator identifications_iterator = identifications_precursors.begin();
145 while (experiment_iterator != experiment_precursors.end())
148 if (identifications_iterator == identifications_precursors.end())
150 --identifications_iterator;
154 while (identifications_iterator != identifications_precursors.begin() &&
155 (experiment_iterator->first - identifications_iterator->first) < rt_tolerance_)
157 --identifications_iterator;
160 if (identifications_iterator != identifications_precursors.end() && ((experiment_iterator->first - identifications_iterator->first) > rt_tolerance_))
162 ++identifications_iterator;
165 if (identifications_iterator == identifications_precursors.end())
171 while (identifications_iterator != identifications_precursors.end() &&
172 (identifications_iterator->first - experiment_iterator->first) < rt_tolerance_)
176 ((!map[experiment_iterator->second].getPrecursors().
empty()) &&
177 isMatch_(0, peptide_ids[identifications_iterator->second].getMZ(), map[experiment_iterator->second].getPrecursors()[0].getMZ())))
179 map[experiment_iterator->second].getPeptideIdentifications().push_back(peptide_ids[identifications_iterator->second]);
180 peptides_mapped.insert(identifications_iterator->second);
182 ++identifications_iterator;
185 ++experiment_iterator;
189 LOG_INFO <<
"Peptides assigned to a precursor: " << peptides_mapped.size() <<
"\n" 190 <<
" Unassigned peptides: " << peptide_ids.size() - peptides_mapped.size() <<
"\n" 191 <<
" Unmapped (empty) peptides: " << peptide_ids.size() - identifications_precursors.size() << std::endl;
214 std::vector<PeptideIdentification> peptide_ids;
216 for (FeatureMap::const_iterator it = fmap.begin(); it != fmap.end(); ++it)
218 const std::vector<PeptideIdentification>& pi = it->getPeptideIdentifications();
219 for (std::vector<PeptideIdentification>::const_iterator itp = pi.begin(); itp != pi.end(); ++itp)
221 peptide_ids.push_back(*itp);
223 if (!itp->hasMZ()) peptide_ids.back().setMZ(it->getMZ());
224 if (!itp->hasRT()) peptide_ids.back().setRT(it->getRT());
228 annotate(map, peptide_ids, protein_ids, clear_ids, mapMS1);
250 void annotate(
FeatureMap& map,
const std::vector<PeptideIdentification>& ids,
const std::vector<ProteinIdentification>& protein_ids,
bool use_centroid_rt =
false,
bool use_centroid_mz =
false,
const PeakMap& spectra =
PeakMap());
268 void annotate(
ConsensusMap& map,
const std::vector<PeptideIdentification>& ids,
269 const std::vector<ProteinIdentification>& protein_ids,
270 bool measure_from_subelements =
false,
271 bool annotate_ids_with_subelements =
false,
301 const std::vector<PeptideIdentification>& ids,
302 double mz_tol = 0.001,
303 double rt_tol = 0.001)
306 for (
Size spectrum_index = 0; spectrum_index < spectra.
size(); ++spectrum_index)
308 const MSSpectrum& spectrum = spectra[spectrum_index];
311 bool identified(
false);
312 const std::vector<Precursor>& precursors = spectrum.
getPrecursors();
315 for (
Size i_p = 0; i_p < precursors.size(); ++i_p)
318 double mz_p = precursors[i_p].getMZ();
319 double rt_s = spectrum.
getRT();
321 for (
Size i_id = 0; i_id != ids.size(); ++i_id)
326 if (pid.
getHits().empty())
continue;
328 double mz_id = pid.
getMZ();
329 double rt_id = pid.
getRT();
331 if ( fabs(mz_id - mz_p) < mz_tol && fabs(rt_s - rt_id) < rt_tol )
357 void updateMembers_();
371 double getAbsoluteMZTolerance_(
const double mz)
const;
374 bool isMatch_(
const double rt_distance,
const double mz_theoretical,
const double mz_observed)
const;
377 void checkHits_(
const std::vector<PeptideIdentification>& ids)
const;
389 bool checkMassType_(
const std::vector<DataProcessing>& processing)
const;
395 #endif // OPENMS_ANALYSIS_ID_IDMAPPER_H double rt_tolerance_
Allowed RT deviation.
Definition: IDMapper.h:360
void setProteinIdentifications(const std::vector< ProteinIdentification > &protein_identifications)
sets the protein ProteinIdentification vector
double mz_tolerance_
Allowed m/z deviation.
Definition: IDMapper.h:362
#define LOG_INFO
Macro if a information, e.g. a status should be reported.
Definition: LogStream.h:455
std::vector< double > DoubleList
Vector of double precision real types.
Definition: ListUtils.h:66
void annotate(PeakMap &map, FeatureMap fmap, const bool clear_ids=false, const bool mapMS1=false)
Mapping method for peak maps.
Definition: IDMapper.h:211
std::vector< Size > no_precursors
Definition: IDMapper.h:280
Result of a partitioning by identification state with mapPrecursorsToIdentifications().
Definition: IDMapper.h:278
A container for features.
Definition: FeatureMap.h:94
const std::vector< PeptideHit > & getHits() const
returns the peptide hits as const
Annotates an MSExperiment, FeatureMap or ConsensusMap with peptide identifications.
Definition: IDMapper.h:67
std::vector< Size > unidentified
Definition: IDMapper.h:282
Measure
Definition: IDMapper.h:71
Iterator begin()
Definition: MSExperiment.h:162
A container for consensus elements.
Definition: ConsensusMap.h:72
std::vector< Int > IntList
Vector of signed integers.
Definition: ListUtils.h:59
Size size() const
Definition: MSExperiment.h:132
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:47
double getMZ() const
returns the MZ of the MS2 spectrum
Iterator end()
Definition: MSExperiment.h:172
Base::iterator iterator
Definition: MSExperiment.h:129
The representation of a 1D spectrum.
Definition: MSSpectrum.h:67
void annotate(PeakMap &map, const std::vector< PeptideIdentification > &peptide_ids, const std::vector< ProteinIdentification > &protein_ids, const bool clear_ids=false, const bool mapMS1=false)
Mapping method for peak maps.
Definition: IDMapper.h:97
double getRT() const
returns the RT of the MS2 spectrum where the identification occurred
MSExperiment PeakMap
Two-dimensional map of raw data points or peaks.
Definition: StandardTypes.h:59
bool ignore_charge_
Ignore charge states during matching?
Definition: IDMapper.h:366
bool empty() const
Definition: MSExperiment.h:142
std::vector< Size > identified
Definition: IDMapper.h:281
In-Memory representation of a mass spectrometry experiment.
Definition: MSExperiment.h:82
const std::vector< Precursor > & getPrecursors() const
returns a const reference to the precursors
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:128
static SpectraIdentificationState mapPrecursorsToIdentifications(const PeakMap &spectra, const std::vector< PeptideIdentification > &ids, double mz_tol=0.001, double rt_tol=0.001)
Mapping of peptide identifications to spectra This helper function partitions all spectra into those ...
Definition: IDMapper.h:300
Measure measure_
Measure used for m/z.
Definition: IDMapper.h:364
A base class for all classes handling default parameters.
Definition: DefaultParamHandler.h:92
const std::vector< ProteinIdentification > & getProteinIdentifications() const
returns a const reference to the protein ProteinIdentification vector
const std::vector< ProteinIdentification > & getProteinIdentifications() const
non-mutable access to the protein identifications
Represents the peptide hits for a spectrum.
Definition: PeptideIdentification.h:63