Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4AblaVirtualData.hh
Go to the documentation of this file.
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// ABLAXX statistical de-excitation model
27// Jose Luis Rodriguez, UDC (translation from ABLA07 and contact person)
28// Pekka Kaitaniemi, HIP (initial translation of ablav3p)
29// Aleksandra Kelic, GSI (ABLA07 code)
30// Davide Mancusi, CEA (contact person INCL)
31// Aatos Heikkinen, HIP (project coordination)
32//
33
34#pragma once
35
36#include "globals.hh"
37
38/**
39 * An interface to data used by ABLA. This interface allows
40 * us to abstract the actual source of data. Currently the data is
41 * read from datafiles by using class G4AblaDataFile. @see
42 * G4AblaDataFile
43 */
44
46protected:
47 /**
48 * Constructor, destructor
49 */
51
52 virtual ~G4AblaVirtualData() = default;
53
54public:
55 /**
56 * Set the value of Alpha.
57 */
59
60 /**
61 * Set the value of Ecnz.
62 */
64
65 /**
66 * Set the value of Vgsld.
67 */
69
70 /**
71 * Set the value of RMS.
72 */
73 G4bool setRms(G4int A, G4int Z, G4double value);
74
75 /**
76 * Set the value of experimental masses.
77 */
79
80 /**
81 * Set the value of experimental masses ID.
82 */
83 G4bool setMexpID(G4int A, G4int Z, G4int value);
84
85 /**
86 * Set the value of beta2 deformation.
87 */
89
90 /**
91 * Set the value of beta4 deformation.
92 */
94
95 /**
96 * Get the value of Alpha.
97 */
99
100 /**
101 * Get the value of Ecnz.
102 */
104
105 /**
106 * Get the value of Vgsld.
107 */
109
110 /*
111 * Get the value of RMS.
112 */
114
115 /**
116 * Get the value of experimental masses.
117 */
119
120 /**
121 * Get the value of experimental masses ID.
122 */
124
125 /**
126 * Get the value of beta2 deformation.
127 */
129
130 /**
131 * Get the value of beta4 deformation.
132 */
134
135 virtual G4bool readData() = 0;
136
137private:
138 static const G4int sRows = 180;
139 static const G4int sCols = 122;
140
141 static const G4int betaRows = sCols + sRows;
142 static const G4int betaCols = 137;
143
144 G4double alpha[sRows][sCols];
145 G4double ecnz[sRows][sCols];
146 G4double vgsld[sRows][sCols];
147 G4double rms[sRows][sCols];
148 G4double mexp[sRows][sCols];
149 G4int mexpid[sRows][sCols];
150 G4double beta2[betaRows][betaCols];
151 G4double beta4[betaRows][betaCols];
152};
double G4double
Definition G4Types.hh:83
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
const G4double A[17]
G4bool setEcnz(G4int A, G4int Z, G4double value)
G4bool setBeta4(G4int A, G4int Z, G4double value)
G4bool setVgsld(G4int A, G4int Z, G4double value)
G4double getRms(G4int A, G4int Z)
G4int getMexpID(G4int A, G4int Z)
G4bool setAlpha(G4int A, G4int Z, G4double value)
G4double getMexp(G4int A, G4int Z)
G4double getEcnz(G4int A, G4int Z)
G4bool setMexp(G4int A, G4int Z, G4double value)
G4bool setBeta2(G4int A, G4int Z, G4double value)
G4double getAlpha(G4int A, G4int Z)
G4double getVgsld(G4int A, G4int Z)
virtual ~G4AblaVirtualData()=default
G4double getBeta2(G4int A, G4int Z)
G4double getBeta4(G4int A, G4int Z)
virtual G4bool readData()=0
G4bool setMexpID(G4int A, G4int Z, G4int value)
G4bool setRms(G4int A, G4int Z, G4double value)