evtgen is hosted by Hepforge, IPPP Durham
EvtGen  2.0.0
Monte Carlo generator of particle decays, in particular the weak decays of heavy flavour particles such as B mesons.
EvtDalitzCoord.hh
Go to the documentation of this file.
1 
2 /***********************************************************************
3 * Copyright 1998-2020 CERN for the benefit of the EvtGen authors *
4 * *
5 * This file is part of EvtGen. *
6 * *
7 * EvtGen is free software: you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation, either version 3 of the License, or *
10 * (at your option) any later version. *
11 * *
12 * EvtGen is distributed in the hope that it will be useful, *
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
15 * GNU General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU General Public License *
18 * along with EvtGen. If not, see <https://www.gnu.org/licenses/>. *
19 ***********************************************************************/
20 
21 #ifndef EVT_DALITZ_COORD_HH
22 #define EVT_DALITZ_COORD_HH
23 
24 #include "EvtGenBase/EvtCyclic3.hh"
25 
26 #include <iostream>
27 
28 // Two dimensional coordinate of a point in a Dalitz plot
29 
30 class EvtDalitzCoord final {
31  public:
32  // ctor, dtor
33 
36  double q2 );
38 
39  inline EvtCyclic3::Pair pair1() const { return _i1; }
40  inline EvtCyclic3::Pair pair2() const { return _i2; }
41  inline double q1() const { return _q1; }
42  inline double q2() const { return _q2; }
43 
44  // It's nice to have an equality operator for
45  // a coordinate. However, beware effects of numerical precision
46 
47  bool operator==( const EvtDalitzCoord& ) const;
48 
49  void print( std::ostream& ) const;
50 
51  private:
52  // Two coordinates define the point
53 
56 
57  double _q1;
58  double _q2;
59 };
60 
61 std::ostream& operator<<( std::ostream&, const EvtDalitzCoord& );
62 
63 #endif
bool operator==(const EvtDalitzCoord &) const
EvtCyclic3::Pair _i2
void print(std::ostream &) const
double q1() const
double q2() const
EvtCyclic3::Pair pair1() const
EvtCyclic3::Pair _i1
EvtCyclic3::Pair pair2() const
std::ostream & operator<<(std::ostream &, const EvtDalitzCoord &)
Index other(Index i, Index j)
Definition: EvtCyclic3.cpp:156