OpenMS
Product.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-2023.
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: Marc Sturm $
33 // --------------------------------------------------------------------------
34 
35 #pragma once
36 
38 
39 namespace OpenMS
40 {
48  class OPENMS_DLLAPI Product :
49  public CVTermList
50  {
51 
52 public:
53 
55  Product() = default;
57  Product(const Product &) = default;
59  Product(Product&&) = default;
61  ~Product() override = default;
62 
64  Product & operator=(const Product &) = default;
66  Product& operator=(Product&&) & = default;
67 
69  bool operator==(const Product & rhs) const;
71  bool operator!=(const Product & rhs) const;
72 
74  double getMZ() const;
76  void setMZ(double mz);
77 
81  void setIsolationWindowLowerOffset(double bound);
82 
86  void setIsolationWindowUpperOffset(double bound);
87 
88 protected:
89 
90  double mz_ = 0.0;
91  double window_low_ = 0.0;
92  double window_up_ = 0.0;
93  };
94 } // namespace OpenMS
95 
Representation of controlled vocabulary term list.
Definition: CVTermList.h:54
Product meta information.
Definition: Product.h:50
double getIsolationWindowLowerOffset() const
returns the lower offset from the target m/z
Product(const Product &)=default
Copy constructor.
Product(Product &&)=default
Move constructor.
void setIsolationWindowUpperOffset(double bound)
sets the upper offset from the target m/z
bool operator!=(const Product &rhs) const
Equality operator.
Product & operator=(Product &&) &=default
Move assignment operator.
void setMZ(double mz)
sets the target m/z
double getIsolationWindowUpperOffset() const
returns the upper offset from the target m/z
~Product() override=default
Destructor.
Product()=default
Constructor.
void setIsolationWindowLowerOffset(double bound)
sets the lower offset from the target m/z
bool operator==(const Product &rhs) const
Equality operator.
Product & operator=(const Product &)=default
Assignment operator.
double getMZ() const
returns the target m/z
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:48