OpenMS
Loading...
Searching...
No Matches
PercolatorInfile.h
Go to the documentation of this file.
1// Copyright (c) 2002-present, OpenMS Inc. -- EKU Tuebingen, ETH Zurich, and FU Berlin
2// SPDX-License-Identifier: BSD-3-Clause
3//
4// --------------------------------------------------------------------------
5// $Maintainer: Timo Sachsenberg $
6// $Authors: Timo Sachsenberg $
7// --------------------------------------------------------------------------
8
9#pragma once
10
14
15#include <set>
16#include <utility>
17#include <vector>
18
19namespace OpenMS
20{
21
26 class OPENMS_DLLAPI PercolatorInfile
27 {
28 public:
29 static void store(const std::string& pin_file,
30 const PeptideIdentificationList& peptide_ids,
31 const StringList& feature_set,
32 const std::string& enz,
33 int min_charge,
34 int max_charge);
35
36
64 static PeptideIdentificationList load(const std::string& pin_file,
65 bool higher_score_better,
66 const std::string& score_name,
67 const StringList& extra_scores,
68 StringList& filenames,
69 std::string decoy_prefix = "",
70 double threshold = 0.01,
71 bool SageAnnotation = false);
72
73 // uses spectrum_reference, if empty uses spectrum_id, if also empty fall back to using index
74 static std::string getScanIdentifier(const PeptideIdentification& pid, size_t index);
75
87 static StringList getStandardFeatureSet(int min_charge, int max_charge);
88
114 static std::set<std::pair<size_t, size_t>> stampPinFeaturesOnHits(
115 PeptideIdentificationList& peptide_ids,
116 const std::string& enz,
117 int min_charge,
118 int max_charge);
119
120 protected:
121
122 //id <tab> label <tab> scannr <tab> calcmass <tab> expmass <tab> feature1 <tab> ... <tab> featureN <tab> peptide <tab> proteinId1 <tab> .. <tab> proteinIdM
124 const PeptideIdentificationList& peptide_ids,
125 const StringList& feature_set,
126 const std::string& enz,
127 int min_charge,
128 int max_charge);
129
130 static bool isEnz_(const char& n, const char& c, const std::string& enz);
131
132 static Size countEnzymatic_(const std::string& peptide, const std::string& enz);
133
134 };
135} // namespace OpenMS
Container for peptide identifications from multiple spectra.
Definition PeptideIdentificationList.h:66
Represents the set of candidates (SpectrumMatches) identified for a single precursor spectrum.
Definition PeptideIdentification.h:66
Class for storing Percolator tab-delimited input files.
Definition PercolatorInfile.h:27
static Size countEnzymatic_(const std::string &peptide, const std::string &enz)
static void store(const std::string &pin_file, const PeptideIdentificationList &peptide_ids, const StringList &feature_set, const std::string &enz, int min_charge, int max_charge)
static std::string getScanIdentifier(const PeptideIdentification &pid, size_t index)
static TextFile preparePin_(const PeptideIdentificationList &peptide_ids, const StringList &feature_set, const std::string &enz, int min_charge, int max_charge)
static bool isEnz_(const char &n, const char &c, const std::string &enz)
static std::set< std::pair< size_t, size_t > > stampPinFeaturesOnHits(PeptideIdentificationList &peptide_ids, const std::string &enz, int min_charge, int max_charge)
Compute and stamp PIN-equivalent meta values on every PeptideHit.
static StringList getStandardFeatureSet(int min_charge, int max_charge)
Returns the standard Percolator feature columns every .pin file should declare.
static PeptideIdentificationList load(const std::string &pin_file, bool higher_score_better, const std::string &score_name, const StringList &extra_scores, StringList &filenames, std::string decoy_prefix="", double threshold=0.01, bool SageAnnotation=false)
Loads peptide identifications from a Percolator input file.
Definition TextFile.h:21
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition Types.h:97
std::vector< std::string > StringList
Vector of String.
Definition ListUtils.h:44
Main OpenMS namespace.
Definition openswathalgo/include/OpenMS/OPENSWATHALGO/DATAACCESS/ISpectrumAccess.h:19