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
G4INCLICrossSections.hh
Go to the documentation of this file.
Or view
the newest version in sPHENIX GitHub for file G4INCLICrossSections.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
// INCL++ intra-nuclear cascade model
27
// Alain Boudard, CEA-Saclay, France
28
// Joseph Cugnon, University of Liege, Belgium
29
// Jean-Christophe David, CEA-Saclay, France
30
// Pekka Kaitaniemi, CEA-Saclay, France, and Helsinki Institute of Physics, Finland
31
// Sylvie Leray, CEA-Saclay, France
32
// Davide Mancusi, CEA-Saclay, France
33
//
34
#define INCLXX_IN_GEANT4_MODE 1
35
36
#include "
globals.hh
"
37
45
#ifndef G4INCLICROSSSECTIONS_HH
46
#define G4INCLICROSSSECTIONS_HH
47
48
#include "
G4INCLParticle.hh
"
49
50
namespace
G4INCL {
52
class
ICrossSections
{
53
public
:
54
55
ICrossSections
() {}
56
virtual
~ICrossSections
() {}
57
59
virtual
G4double
elastic
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
60
62
virtual
G4double
total
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
63
65
virtual
G4double
NDeltaToNN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
66
68
virtual
G4double
NNToNDelta
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
69
71
virtual
G4double
NNToxPiNN
(
const
G4int
xpi,
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
72
74
virtual
G4double
piNToDelta
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
75
77
virtual
G4double
piNToxPiN
(
const
G4int
xpi,
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
78
80
virtual
G4double
piNToEtaN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
81
83
virtual
G4double
piNToOmegaN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
84
86
virtual
G4double
piNToEtaPrimeN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
87
89
virtual
G4double
etaNToPiN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
90
92
virtual
G4double
etaNToPiPiN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
93
95
virtual
G4double
omegaNToPiN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
96
98
virtual
G4double
omegaNToPiPiN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
99
101
virtual
G4double
etaPrimeNToPiN
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
102
104
virtual
G4double
NNToNNEta
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
105
107
virtual
G4double
NNToNNEtaExclu
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
108
110
virtual
G4double
NNToNNEtaxPi
(
const
G4int
xpi,
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
111
113
virtual
G4double
NNToNDeltaEta
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
114
116
virtual
G4double
NNToNNOmega
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
117
119
virtual
G4double
NNToNNOmegaExclu
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
120
122
virtual
G4double
NNToNNOmegaxPi
(
const
G4int
xpi,
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
123
125
virtual
G4double
NNToNDeltaOmega
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
126
127
129
virtual
G4double
NYelastic
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
130
virtual
G4double
NKbelastic
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
131
virtual
G4double
NKelastic
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
132
134
virtual
G4double
NNToNLK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
135
virtual
G4double
NNToNSK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
136
virtual
G4double
NNToNLKpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
137
virtual
G4double
NNToNSKpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
138
virtual
G4double
NNToNLK2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
139
virtual
G4double
NNToNSK2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
140
virtual
G4double
NNToNNKKb
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
141
virtual
G4double
NNToMissingStrangeness
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
142
144
virtual
G4double
NDeltaToNLK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
145
virtual
G4double
NDeltaToNSK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
146
virtual
G4double
NDeltaToDeltaLK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
147
virtual
G4double
NDeltaToDeltaSK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
148
149
virtual
G4double
NDeltaToNNKKb
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
150
152
virtual
G4double
NpiToLK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
153
virtual
G4double
NpiToSK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
154
virtual
G4double
p_pimToSzKz
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
155
virtual
G4double
p_pimToSmKp
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
156
virtual
G4double
p_pizToSzKp
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
157
virtual
G4double
NpiToLKpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
158
virtual
G4double
NpiToSKpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
159
virtual
G4double
NpiToLK2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
160
virtual
G4double
NpiToSK2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
161
virtual
G4double
NpiToNKKb
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
162
virtual
G4double
NpiToMissingStrangeness
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
163
165
virtual
G4double
NLToNS
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
166
virtual
G4double
NSToNL
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
167
virtual
G4double
NSToNS
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
168
170
virtual
G4double
NKToNK
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
171
virtual
G4double
NKToNKpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
172
virtual
G4double
NKToNK2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
173
175
virtual
G4double
NKbToNKb
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
176
virtual
G4double
NKbToSpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
177
virtual
G4double
NKbToLpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
178
virtual
G4double
NKbToS2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
179
virtual
G4double
NKbToL2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
180
virtual
G4double
NKbToNKbpi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
181
virtual
G4double
NKbToNKb2pi
(
Particle
const
*
const
p1,
Particle
const
*
const
p2) = 0;
182
183
191
virtual
G4double
calculateNNAngularSlope
(
G4double
energyCM,
G4int
iso) = 0;
192
193
};
194
}
195
196
#endif
geant4
tree
geant4-10.6-release
source
processes
hadronic
models
inclxx
incl_physics
include
G4INCLICrossSections.hh
Built by
Jin Huang
. updated:
Wed Jun 29 2022 17:25:44
using
1.8.2 with
ECCE GitHub integration