ECCE @ EIC Software
Reference for
ECCE @ EIC
simulation and reconstruction software on GitHub
Home page
Related Pages
Modules
Namespaces
Classes
Files
External Links
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
G4ExcitedLambdaConstructor.hh
Go to the documentation of this file.
Or view
the newest version in sPHENIX GitHub for file G4ExcitedLambdaConstructor.hh
1
//
2
// ********************************************************************
3
// * License and Disclaimer *
4
// * *
5
// * The Geant4 software is copyright of the Copyright Holders of *
6
// * the Geant4 Collaboration. It is provided under the terms and *
7
// * conditions of the Geant4 Software License, included in the file *
8
// * LICENSE and available at http://cern.ch/geant4/license . These *
9
// * include a list of copyright holders. *
10
// * *
11
// * Neither the authors of this software system, nor their employing *
12
// * institutes,nor the agencies providing financial support for this *
13
// * work make any representation or warranty, express or implied, *
14
// * regarding this software system or assume any liability for its *
15
// * use. Please see the license in the file LICENSE and URL above *
16
// * for the full disclaimer and the limitation of liability. *
17
// * *
18
// * This code implementation is the result of the scientific and *
19
// * technical work of the GEANT4 collaboration. *
20
// * By using, copying, modifying or distributing the software (or *
21
// * any work based on the software) you agree to acknowledge its *
22
// * use in resulting scientific publications, and indicate your *
23
// * acceptance of all terms of the Geant4 Software license. *
24
// ********************************************************************
25
//
26
//
27
//
28
//
29
// --------------------------------------------------------------
30
// GEANT 4 class implementation file
31
//
32
// History: first implementation, based on object model of
33
// 10 oct 1998 H.Kurashige
34
// ---------------------------------------------------------------
35
#ifndef G4ExcitedLambdaConstructor_h
36
#define G4ExcitedLambdaConstructor_h 1
37
38
#include "
globals.hh
"
39
#include "
G4ios.hh
"
40
#include "
G4ExcitedBaryonConstructor.hh
"
41
42
class
G4ExcitedLambdaConstructor
:
public
G4ExcitedBaryonConstructor
43
{
44
//This class is a utility class for construction
45
//short lived particles
46
47
public
:
48
G4ExcitedLambdaConstructor
();
49
virtual
~G4ExcitedLambdaConstructor
();
50
51
protected
:
52
virtual
G4bool
Exist
(
G4int
){
return
true
;}
53
54
virtual
G4int
GetQuarkContents
(
G4int
,
G4int
);
55
virtual
G4String
GetName
(
G4int
iIso3,
G4int
iState);
56
virtual
G4String
GetMultipletName
(
G4int
iState);
57
virtual
G4double
GetMass
(
G4int
state,
G4int
iso);
58
virtual
G4double
GetWidth
(
G4int
state,
G4int
iso);
59
virtual
G4int
GetiSpin
(
G4int
iState);
60
virtual
G4int
GetiParity
(
G4int
iState);
61
virtual
G4int
GetEncodingOffset
(
G4int
iState);
62
63
virtual
G4DecayTable
*
CreateDecayTable
(
const
G4String
&
name
,
64
G4int
iIso3,
G4int
iState,
65
G4bool
fAnti =
false
);
66
private
:
67
G4DecayTable
*
AddNKMode
(
G4DecayTable
* table,
const
G4String
&
name
,
68
G4double
br,
G4int
iIso3,
G4bool
fAnti);
69
G4DecayTable
*
AddNKStarMode
(
G4DecayTable
* table,
const
G4String
&
name
,
70
G4double
br,
G4int
iIso3,
G4bool
fAnti);
71
G4DecayTable
*
AddSigmaPiMode
(
G4DecayTable
* table,
const
G4String
&
name
,
72
G4double
br,
G4int
iIso3,
G4bool
fAnti);
73
G4DecayTable
*
AddSigmaStarPiMode
(
G4DecayTable
* table,
const
G4String
&
name
,
74
G4double
br,
G4int
iIso3,
G4bool
fAnti);
75
G4DecayTable
*
AddLambdaGammaMode
(
G4DecayTable
* table,
const
G4String
&
name
,
76
G4double
br,
G4int
iIso3,
G4bool
fAnti);
77
G4DecayTable
*
AddLambdaEtaMode
(
G4DecayTable
* table,
const
G4String
&
name
,
78
G4double
br,
G4int
iIso3,
G4bool
fAnti);
79
G4DecayTable
*
AddLambdaOmegaMode
(
G4DecayTable
* table,
const
G4String
&
name
,
80
G4double
br,
G4int
iIso3,
G4bool
fAnti);
81
82
public
:
83
enum
{
NStates
= 12 };
84
private
:
85
enum
{
LambdaIsoSpin
= 0 };
86
87
private
:
88
static
const
char
*
name
[
NStates
];
89
static
const
G4double
mass
[
NStates
];
90
static
const
G4double
width
[
NStates
];
91
static
const
G4int
iSpin
[
NStates
];
92
static
const
G4int
iParity
[
NStates
];
93
static
const
G4int
encodingOffset
[
NStates
];
94
95
public
:
96
enum
{
NumberOfDecayModes
= 7 };
97
private
:
98
enum
{
NK
=0,
NKStar
=1,
SigmaPi
=2,
SigmaStarPi
=3,
LambdaGamma
=4,
99
LambdaEta
=5,
LambdaOmega
=6 };
100
private
:
101
static
const
G4double
bRatio
[
NStates
][
NumberOfDecayModes
];
102
};
103
104
inline
105
G4double
G4ExcitedLambdaConstructor::GetMass
(
G4int
iState,
G4int
)
106
{
107
return
mass
[iState];
108
}
109
110
inline
111
G4double
G4ExcitedLambdaConstructor::GetWidth
(
G4int
iState,
G4int
)
112
{
113
return
width
[iState];
114
}
115
116
inline
117
G4int
G4ExcitedLambdaConstructor::GetiSpin
(
G4int
iState)
118
{
119
return
iSpin
[iState];
120
}
121
122
inline
123
G4int
G4ExcitedLambdaConstructor::GetiParity
(
G4int
iState)
124
{
125
return
iParity
[iState];
126
}
127
128
inline
129
G4int
G4ExcitedLambdaConstructor::GetEncodingOffset
(
G4int
iState)
130
{
131
return
encodingOffset
[iState];
132
}
133
134
inline
135
G4int
G4ExcitedLambdaConstructor::GetQuarkContents
(
G4int
iQ,
G4int
)
136
{
137
G4int
quark=0;
138
if
( iQ == 0 ){
139
// s-quark
140
quark = 3;
141
}
else
if
( iQ == 1 ){
142
// d-quark
143
quark = 1;
144
}
else
if
( iQ == 2 ){
145
// u-quark
146
quark = 2;
147
}
148
return
quark;
149
}
150
151
inline
152
G4String
G4ExcitedLambdaConstructor::GetMultipletName
(
G4int
iState)
153
{
154
return
name
[iState];
155
}
156
157
inline
158
G4String
G4ExcitedLambdaConstructor::GetName
(
G4int
,
G4int
iState)
159
{
160
G4String
particle
=
name
[iState];
161
return
particle
;
162
}
163
#endif
164
165
166
167
168
169
170
171
172
173
geant4
tree
geant4-10.6-release
source
particles
shortlived
include
G4ExcitedLambdaConstructor.hh
Built by
Jin Huang
. updated:
Wed Jun 29 2022 17:25:24
using
1.8.2 with
ECCE GitHub integration