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
EvtPsi2JpsiPiPi.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 EVTPSI2JPSIPIPI_HH
22#define EVTPSI2JPSIPIPI_HH
23
25
26#include <array>
27#include <string>
28
29class EvtDecayBase;
30class EvtParticle;
31
32// Description: Header file for the model "PSI2JPSIPIPI" which generates
33// psi2S -> J/psi pi+ pi- decays based on hep-ph/1507.07985
34
36 public:
38
39 std::string getName() const override;
40 EvtDecayBase* clone() const override;
41 void initProbMax() override;
42 void init() override;
43 void decay( EvtParticle* p ) override;
44
45 private:
46 bool m_tree;
47 double m_phi; // LO vs NLO mixing angle (radians)
49 // NLO corrections
50 static const int m_nQ = 6; // number of terms in mPiPi interpolation
51 std::array<double, m_nQ> m_c0, m_c1, m_c2, m_s1, m_s2;
52
53 void setNLOArrays();
54};
55
56#endif
EvtDecayBase()=default
std::array< double, m_nQ > m_c2
std::array< double, m_nQ > m_s2
void initProbMax() override
std::array< double, m_nQ > m_c1
static const int m_nQ
EvtDecayBase * clone() const override
std::array< double, m_nQ > m_s1
std::string getName() const override
void init() override
void decay(EvtParticle *p) override
std::array< double, m_nQ > m_c0