thepeg
is hosted by
Hepforge
,
IPPP Durham
ThePEG
2.3.0
Helicity
Vertex
Scalar
VVSSVertex.h
1
// -*- C++ -*-
2
//
3
// VVSSVertex.h is a part of ThePEG - Toolkit for HEP Event Generation
4
// Copyright (C) 2003-2019 Peter Richardson, Leif Lonnblad
5
//
6
// ThePEG is licenced under version 3 of the GPL, see COPYING for details.
7
// Please respect the MCnet academic guidelines, see GUIDELINES for details.
8
//
9
#ifndef ThePEG_VVSSVertex_H
10
#define ThePEG_VVSSVertex_H
11
//
12
// This is the declaration of the VVSSVertex class.
13
//
14
#include "ThePEG/Helicity/Vertex/AbstractVVSSVertex.h"
15
#include "ThePEG/Helicity/WaveFunction/ScalarWaveFunction.h"
16
#include "ThePEG/Helicity/WaveFunction/VectorWaveFunction.h"
17
#include "VVSSVertex.fh"
18
19
namespace
ThePEG
{
20
namespace
Helicity {
21
35
class
VVSSVertex
:
public
AbstractVVSSVertex
{
36
37
public
:
38
42
static
void
Init
();
43
44
public
:
45
59
Complex
evaluate
(
Energy2
q2,
const
VectorWaveFunction
& vec1,
60
const
VectorWaveFunction
& vec2,
const
ScalarWaveFunction
& sca3,
61
const
ScalarWaveFunction
& sca4);
62
76
VectorWaveFunction
evaluate
(
Energy2
q2,
int
iopt,
tcPDPtr
out,
77
const
VectorWaveFunction
& vec2,
78
const
ScalarWaveFunction
& sca3,
79
const
ScalarWaveFunction
& sca4,
80
complex<Energy> mass=-GeV, complex<Energy> width=-GeV);
81
95
ScalarWaveFunction
evaluate
(
Energy2
q2,
int
iopt,
tcPDPtr
out,
96
const
VectorWaveFunction
& vec1,
97
const
VectorWaveFunction
& vec2,
98
const
ScalarWaveFunction
& sca3,
99
complex<Energy> mass=-GeV, complex<Energy> width=-GeV);
101
109
virtual
void
setCoupling
(
Energy2
,
tcPDPtr
,
tcPDPtr
,
tcPDPtr
) {
110
assert(
false
);
111
}
112
123
virtual
void
setCoupling
(
Energy2
q2,
tcPDPtr
part1,
tcPDPtr
part2,
tcPDPtr
part3,
124
tcPDPtr
part4)=0;
126
127
private
:
128
132
VVSSVertex
&
operator=
(
const
VVSSVertex
&) =
delete
;
133
134
};
135
136
}
137
138
}
139
#endif
/* ThePEG_VVSSVertex_H */
ThePEG::Helicity::AbstractVVSSVertex
The AbstractVVSSVertex class is the base class for vector-vector-scalar-scalar interactions in ThePEG...
Definition:
AbstractVVSSVertex.h:20
ThePEG::Helicity::ScalarWaveFunction
Definition:
ScalarWaveFunction.h:36
ThePEG::Helicity::VVSSVertex
The VVSSVertex class is the implementation of the coupling of two vectors and two scalars.
Definition:
VVSSVertex.h:35
ThePEG::Helicity::VVSSVertex::evaluate
Complex evaluate(Energy2 q2, const VectorWaveFunction &vec1, const VectorWaveFunction &vec2, const ScalarWaveFunction &sca3, const ScalarWaveFunction &sca4)
Members to calculate the helicity amplitude expressions for vertices and off-shell particles.
ThePEG::Helicity::VVSSVertex::Init
static void Init()
Standard Init function used to initialize the interfaces.
ThePEG::Helicity::VVSSVertex::evaluate
VectorWaveFunction evaluate(Energy2 q2, int iopt, tcPDPtr out, const VectorWaveFunction &vec2, const ScalarWaveFunction &sca3, const ScalarWaveFunction &sca4, complex< Energy > mass=-GeV, complex< Energy > width=-GeV)
Evaluate the off-shell vector coming from the vertex.
ThePEG::Helicity::VVSSVertex::setCoupling
virtual void setCoupling(Energy2 q2, tcPDPtr part1, tcPDPtr part2, tcPDPtr part3, tcPDPtr part4)=0
Calculate the couplings for a four point interaction.
ThePEG::Helicity::VVSSVertex::operator=
VVSSVertex & operator=(const VVSSVertex &)=delete
Private and non-existent assignment operator.
ThePEG::Helicity::VVSSVertex::evaluate
ScalarWaveFunction evaluate(Energy2 q2, int iopt, tcPDPtr out, const VectorWaveFunction &vec1, const VectorWaveFunction &vec2, const ScalarWaveFunction &sca3, complex< Energy > mass=-GeV, complex< Energy > width=-GeV)
Evaluate the off-shell scalar coming from the vertex.
ThePEG::Helicity::VVSSVertex::setCoupling
virtual void setCoupling(Energy2, tcPDPtr, tcPDPtr, tcPDPtr)
Set coupling methods.
Definition:
VVSSVertex.h:109
ThePEG::Helicity::VectorWaveFunction
Definition:
VectorWaveFunction.h:50
ThePEG::Pointer::TransientConstRCPtr
TransientConstRCPtr is a simple wrapper around a bare const pointer which can be assigned to and from...
Definition:
RCPtr.h:696
ThePEG::Qty< 0, 2, 0 >
ThePEG
This is the main namespace within which all identifiers in ThePEG are declared.
Definition:
FactoryBase.h:28
ThePEG::Complex
std::complex< double > Complex
ThePEG code should use Complex for all complex scalars.
Definition:
Complex.h:23
Generated on Thu Jun 20 2024 14:47:00 for ThePEG by
1.9.6