OpenMS  2.7.0
BaseLabeler.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-2021.
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: Stephan Aiche, Chris Bielow $
33 // --------------------------------------------------------------------------
34 
35 #pragma once
36 
38 
40 
42 
43 namespace OpenMS
44 {
45 
49  class OPENMS_DLLAPI BaseLabeler :
50  public DefaultParamHandler
51  {
52 public:
53 
56 
58  ~BaseLabeler() override;
59 
61  static void registerChildren();
62 
68  virtual Param getDefaultParameters() const;
69 
77 
85  virtual void preCheck(Param& param) const = 0;
86 
91 
93  virtual void setUpHook(SimTypes::FeatureMapSimVector& /* features */) = 0;
94 
96  virtual void postDigestHook(SimTypes::FeatureMapSimVector& /* features_to_simulate */) = 0;
97 
99  virtual void postRTHook(SimTypes::FeatureMapSimVector& /* features_to_simulate */) = 0;
100 
102  virtual void postDetectabilityHook(SimTypes::FeatureMapSimVector& /* features_to_simulate */) = 0;
103 
105  virtual void postIonizationHook(SimTypes::FeatureMapSimVector& /* features_to_simulate */) = 0;
106 
108  virtual void postRawMSHook(SimTypes::FeatureMapSimVector& /* features_to_simulate */) = 0;
109 
111  virtual void postRawTandemMSHook(SimTypes::FeatureMapSimVector& /* features_to_simulate */, SimTypes::MSSimExperiment& /* simulated map */) = 0;
112 
114 
116 
122  const String& getDescription() const;
123 
130  String getChannelIntensityName(const Size channel_index) const;
131 
132 
133 protected:
142 
152  void mergeProteinAccessions_(Feature& target, const Feature& source) const;
153 
161  void recomputeConsensus_(const SimTypes::FeatureMapSim& simulated_features);
162 
163 
165 
167 
169 
170  };
171 } // namespace OpenMS
172 
Abstract base class for all kinds of labeling techniques.
Definition: BaseLabeler.h:51
~BaseLabeler() override
destructor
virtual void postRawMSHook(SimTypes::FeatureMapSimVector &)=0
Labeling after raw signal generation.
virtual void postRTHook(SimTypes::FeatureMapSimVector &)=0
Labeling after rt simulation.
virtual void setRnd(SimTypes::MutableSimRandomNumberGeneratorPtr rng)
Set the random number generator.
ConsensusMap consensus_
Definition: BaseLabeler.h:164
virtual void preCheck(Param &param) const =0
Checks the (simulation) params passed if they are consistent with the labeling technique.
SimTypes::FeatureMapSim mergeProteinIdentificationsMaps_(const SimTypes::FeatureMapSimVector &maps)
Creates an empty FeatureMap with the merged ProteinIdentifications from all FeatureMaps contained in ...
virtual void postRawTandemMSHook(SimTypes::FeatureMapSimVector &, SimTypes::MSSimExperiment &)=0
Labeling after Tandem MS (e.g. iTRAQ)
BaseLabeler()
constructor
ConsensusMap & getConsensus()
String channel_description_
Definition: BaseLabeler.h:168
SimTypes::MutableSimRandomNumberGeneratorPtr rng_
Definition: BaseLabeler.h:166
void mergeProteinAccessions_(Feature &target, const Feature &source) const
join all protein references of two features
virtual void postDetectabilityHook(SimTypes::FeatureMapSimVector &)=0
Labeling after detectability simulation.
const String & getDescription() const
Get short description of the labeler (e.g., channels used)
virtual void setUpHook(SimTypes::FeatureMapSimVector &)=0
Hook to prepare the simulation process.
void recomputeConsensus_(const SimTypes::FeatureMapSim &simulated_features)
Based on the stored consensus recompute the associations for the passed features, assuming that the f...
virtual void postDigestHook(SimTypes::FeatureMapSimVector &)=0
Labeling between digestion and rt simulation.
virtual Param getDefaultParameters() const
Returns the default parameters. Re-implement.
virtual void postIonizationHook(SimTypes::FeatureMapSimVector &)=0
Labeling after ionization.
String getChannelIntensityName(const Size channel_index) const
to ensure standardized meta value names across labelers for channel intensity
A container for consensus elements.
Definition: ConsensusMap.h:88
A base class for all classes handling default parameters.
Definition: DefaultParamHandler.h:93
A container for features.
Definition: FeatureMap.h:105
An LC-MS feature.
Definition: Feature.h:72
In-Memory representation of a mass spectrometry experiment.
Definition: MSExperiment.h:80
Management and storage of parameters / INI files.
Definition: Param.h:70
A more convenient string class.
Definition: String.h:61
size_t Size
Size type e.g. used as variable which can hold result of size()
Definition: Types.h:127
boost::shared_ptr< SimRandomNumberGenerator > MutableSimRandomNumberGeneratorPtr
Definition: SimTypes.h:174
std::vector< FeatureMapSim > FeatureMapSimVector
Sim FeatureMap Vector.
Definition: SimTypes.h:99
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:47