Home  · Classes  · Annotated Classes  · Modules  · Members  · Namespaces  · Related Pages
InspectOutfile.h
Go to the documentation of this file.
1 // --------------------------------------------------------------------------
2 // OpenMS -- Open-Source Mass Spectrometry
3 // --------------------------------------------------------------------------
4 // Copyright The OpenMS Team -- Eberhard Karls University Tuebingen,
5 // ETH Zurich, and Freie Universitaet Berlin 2002-2017.
6 //
7 // This software is released under a three-clause BSD license:
8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // * Neither the name of any author or any participating institution
14 // may be used to endorse or promote products derived from this software
15 // without specific prior written permission.
16 // For a full list of authors, refer to the file AUTHORS.
17 // --------------------------------------------------------------------------
18 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 // ARE DISCLAIMED. IN NO EVENT SHALL ANY OF THE AUTHORS OR THE CONTRIBUTING
22 // INSTITUTIONS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
23 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
25 // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
26 // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
27 // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
28 // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 //
30 // --------------------------------------------------------------------------
31 // $Maintainer: Timo Sachsenberg $
32 // $Authors: Martin Langwisch $
33 // --------------------------------------------------------------------------
34 
35 #ifndef OPENMS_FORMAT_INSPECTOUTFILE_H
36 #define OPENMS_FORMAT_INSPECTOUTFILE_H
37 
45 
46 
47 namespace OpenMS
48 {
58  class OPENMS_DLLAPI InspectOutfile
59  {
60 public:
63 
65  InspectOutfile(const InspectOutfile & inspect_outfile);
66 
68  virtual ~InspectOutfile();
69 
71  InspectOutfile & operator=(const InspectOutfile & inspect_outfile);
72 
74  bool operator==(const InspectOutfile & inspect_outfile) const;
75 
87  std::vector<Size> load(const String & result_filename, std::vector<PeptideIdentification> & peptide_identifications, ProteinIdentification & protein_identification, const double p_value_threshold, const String & database_filename = "");
88 
96  std::vector<Size> getWantedRecords(const String & result_filename, double p_value_threshold);
97 
105  void compressTrieDB(const String & database_filename, const String & index_filename, std::vector<Size> & wanted_records, const String & snd_database_filename, const String & snd_index_filename, bool append = false);
106 
111  void generateTrieDB(const String & source_database_filename, const String & database_filename, const String & index_filename, bool append = false, const String species = "");
112 
113 
116  void getACAndACType(String line, String & accession, String & accession_type);
117 
122  void getPrecursorRTandMZ(const std::vector<std::pair<String, std::vector<std::pair<Size, Size> > > > & files_and_peptide_identification_with_scan_number, std::vector<PeptideIdentification> & ids);
123 
129  void getLabels(const String & source_database_filename, String & ac_label, String & sequence_start_label, String & sequence_end_label, String & comment_label, String & species_label);
130 
135  std::vector<Size> getSequences(const String & database_filename, const std::map<Size, Size> & wanted_records, std::vector<String> & sequences);
136 
142  void getExperiment(PeakMap & exp, String & type, const String & in_filename)
143  {
144  type.clear();
145  exp.reset();
146  //input file type
147  FileHandler fh;
148  FileTypes::Type in_type = fh.getTypeByContent(in_filename);
149  if (in_type == FileTypes::UNKNOWN)
150  {
151  throw Exception::ParseError(__FILE__, __LINE__, OPENMS_PRETTY_FUNCTION, "Could not determine type of the file. Aborting!", in_filename);
152  }
153  type = FileTypes::typeToName(in_type);
154  fh.loadExperiment(in_filename, exp, in_type, ProgressLogger::NONE, false, false);
155  }
156 
162  bool getSearchEngineAndVersion(const String & cmd_output, ProteinIdentification & protein_identification);
163 
167  void readOutHeader(const String & filename, const String & header_line, Int & spectrum_file_column, Int & scan_column, Int & peptide_column, Int & protein_column, Int & charge_column, Int & MQ_score_column, Int & p_value_column, Int & record_number_column, Int & DB_file_pos_column, Int & spec_file_pos_column, Size & number_of_columns);
168 
169 protected:
174  static const Size db_pos_length_;
175  static const Size trie_db_pos_length_;
176  static const Size protein_name_length_;
177  static const Size record_length_;
178  static const char trie_delimiter_;
179  static const String score_type_;
180  };
181 
182 } //namespace OpenMS
183 
184 #endif // OPENMS_FORMAT_INSPECTOUTFILE_H
Type
Actual file types enum.
Definition: FileTypes.h:59
Representation of a protein identification run.
Definition: ProteinIdentification.h:62
A more convenient string class.
Definition: String.h:57
static const Size db_pos_length_
length of 1)
Definition: InspectOutfile.h:174
void reset()
Resets all internal values.
Definition: MSExperiment.h:709
static const String score_type_
type of score
Definition: InspectOutfile.h:179
bool operator==(_Iterator< _Val, _Ref, _Ptr > const &, _Iterator< _Val, _Ref, _Ptr > const &)
Definition: KDTree.h:806
static const Size protein_name_length_
length of 3)
Definition: InspectOutfile.h:176
static FileTypes::Type getTypeByContent(const String &filename)
Determines the file type of a file by parsing the first few lines.
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:47
static const Size record_length_
length of the whole record
Definition: InspectOutfile.h:177
bool loadExperiment(const String &filename, MSExperiment &exp, FileTypes::Type force_type=FileTypes::UNKNOWN, ProgressLogger::LogType log=ProgressLogger::NONE, const bool rewrite_source_file=true, const bool compute_hash=true)
Loads a file into an MSExperiment.
Unknown file extension.
Definition: FileTypes.h:61
No progress logging.
Definition: ProgressLogger.h:75
In-Memory representation of a mass spectrometry experiment.
Definition: MSExperiment.h:82
static const Size trie_db_pos_length_
length of 2)
Definition: InspectOutfile.h:175
static const char trie_delimiter_
the sequences in the trie database are delimited by this character
Definition: InspectOutfile.h:178
Representation of an Inspect outfile.
Definition: InspectOutfile.h:58
void getExperiment(PeakMap &exp, String &type, const String &in_filename)
Definition: InspectOutfile.h:142
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:128
static String typeToName(Type type)
Returns the name/extension of the type.
int Int
Signed integer type.
Definition: Types.h:103
Facilitates file handling by file type recognition.
Definition: FileHandler.h:63
Parse Error exception.
Definition: Exception.h:623

OpenMS / TOPP release 2.3.0 Documentation generated on Tue Jan 9 2018 18:22:01 using doxygen 1.8.13