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.
EvtSVPCP.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 EVTSVPCP_HH
22 #define EVTSVPCP_HH
23 
25 
26 class EvtParticle;
27 
28 // Description: Routine to decay scalar -> vectors+photon
29 // including CP violation effects
30 //
31 //Class to handle decays of the form SCALAR ->VECTOR PHOTON
32 //where the helicity amplitudes must be specified. The
33 //first and third arguements are the magnetudes of the H+
34 //and H- helicity amplitudes respectively. The second and
35 //fourth arguements are the phases.
36 //Calls EvtSVPHel.
37 
38 class EvtSVPCP : public EvtDecayAmp {
39  public:
40  std::string getName() override;
41  EvtDecayBase* clone() override;
42 
43  void init() override;
44  void initProbMax() override;
45  void decay( EvtParticle* p ) override;
46  static void SVPHel( EvtParticle* parent, EvtAmp& amp, EvtId n_v1,
47  EvtId n_v2, const EvtComplex& hp, const EvtComplex& hm );
48 
49  std::string getParamName( int i ) override;
50  std::string getParamDefault( int i ) override;
51 };
52 
53 #endif
std::string getParamName(int i) override
Definition: EvtSVPCP.cpp:169
EvtDecayBase * clone() override
Definition: EvtSVPCP.cpp:45
std::string getName() override
Definition: EvtSVPCP.cpp:40
void decay(EvtParticle *p) override
Definition: EvtSVPCP.cpp:67
void initProbMax() override
Definition: EvtSVPCP.cpp:50
Definition: EvtId.hh:27
Definition: EvtAmp.hh:30
std::string getParamDefault(int i) override
Definition: EvtSVPCP.cpp:191
static void SVPHel(EvtParticle *parent, EvtAmp &amp, EvtId n_v1, EvtId n_v2, const EvtComplex &hp, const EvtComplex &hm)
void init() override
Definition: EvtSVPCP.cpp:55