EvtGen 2.2.0
Monte Carlo generator of particle decays, in particular the weak decays of heavy flavour particles such as B mesons.
Loading...
Searching...
No Matches
EvtResonance.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 EVTRESONANCE_HH
22#define EVTRESONANCE_HH
23
25
26class EvtComplex;
27
28class EvtResonance final {
29 public:
31
32 //constructor with all information about the resonance
34 const EvtVector4R& p4_d2, double ampl = 0.0, double theta = 0.0,
35 double gamma = 0.0, double bwm = 0.0, int spin = 0 );
36
37 //accessors
38 //return 4-momenta of the particles involved
39 inline const EvtVector4R& p4_p() { return m_p4_p; }
40 inline const EvtVector4R& p4_d1() { return m_p4_d1; }
41 inline const EvtVector4R& p4_d2() { return m_p4_d2; }
42
43 //return amplitude
44 inline double amplitude() { return m_ampl; }
45
46 //return theta
47 inline double theta() { return m_theta; }
48
49 //return gamma
50 inline double gamma() { return m_gamma; }
51
52 //return bwm
53 inline double bwm() { return m_bwm; }
54
55 //return spin
56 inline int spin() { return m_spin; }
57
58 //calculate amplitude for this resonance
60
61 //calculate relativistic Breit-Wigner amplitude for P-decays of scalars
62 EvtComplex relBrWig( int i );
63
64 private:
67 int m_spin;
68};
69
70#endif
const EvtVector4R & p4_d2()
const EvtVector4R & p4_d1()
EvtResonance & operator=(const EvtResonance &)
EvtVector4R m_p4_d2
EvtVector4R m_p4_p
double amplitude()
EvtComplex relBrWig(int i)
double gamma()
EvtVector4R m_p4_d1
EvtComplex resAmpl()
EvtResonance(const EvtVector4R &p4_p, const EvtVector4R &p4_d1, const EvtVector4R &p4_d2, double ampl=0.0, double theta=0.0, double gamma=0.0, double bwm=0.0, int spin=0)
const EvtVector4R & p4_p()
double theta()