File: MZTolerance.hpp

package info (click to toggle)
libpwiz 3.0.18342-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 14,888 kB
  • sloc: cpp: 157,552; sh: 4,182; makefile: 317
file content (73 lines) | stat: -rw-r--r-- 2,299 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
//
// $Id$
//
//
// Original author: Darren Kessner <darren@proteowizard.org>
//
// Copyright 2009 Center for Applied Molecular Medicine
//   University of Southern California, Los Angeles, CA
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and 
// limitations under the License.
//
                                                                                                     
#ifndef _MZTOLERANCE_HPP_
#define _MZTOLERANCE_HPP_


#include "pwiz/utility/misc/Export.hpp"
#include <iosfwd>


namespace pwiz {
namespace chemistry {


///
/// struct for expressing m/z tolerance in either amu or ppm
///
struct PWIZ_API_DECL MZTolerance
{
    enum Units {MZ, PPM};
    double value;
    Units units;

    MZTolerance(double _value = 0, Units _units = MZ)
    :   value(_value), units(_units)
    {}
};


PWIZ_API_DECL std::ostream& operator<<(std::ostream& os, const MZTolerance& mzt);
PWIZ_API_DECL std::istream& operator>>(std::istream& is, MZTolerance& mzt);
PWIZ_API_DECL bool operator==(const MZTolerance& a, const MZTolerance& b);
PWIZ_API_DECL bool operator!=(const MZTolerance& a, const MZTolerance& b);


PWIZ_API_DECL double& operator+=(double& d, const MZTolerance& tolerance);
PWIZ_API_DECL double& operator-=(double& d, const MZTolerance& tolerance);
PWIZ_API_DECL double operator+(double d, const MZTolerance& tolerance);
PWIZ_API_DECL double operator-(double d, const MZTolerance& tolerance);


/// returns true iff a is in (b-tolerance, b+tolerance)
PWIZ_API_DECL bool isWithinTolerance(double a, double b, const MZTolerance& tolerance);
/// returns true iff b - a is greater than the value in tolerance (useful for matching sorted mass lists)
PWIZ_API_DECL bool lessThanTolerance(double a, double b, const MZTolerance& tolerance);


} // namespace chemistry
} // namespace pwiz


#endif // _MZTOLERANCE_HPP_