Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4SandiaTable.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// class description
27//
28// This class is an interface to G4StaticSandiaData.
29// it provides - Sandia coeff for an element, given its Z
30// - sandia coeff for a material, given a pointer to it
31//
32// History:
33//
34// 10.06.97 created. V. Grichine
35// 18.11.98 simplified public interface; new methods for materials. mma
36// 30.01.01 major bug in the computation of AoverAvo and in the units (/g!)
37// in GetSandiaCofPerAtom(). mma
38// 03.04.01 fnulcof[4] added; returned if energy < emin
39// 05.03.04 V.Grichine, new methods for old sorting algorithm for PAI model
40// 21.21.13 V.Ivanchenko, changed signature of methods, reduced number of
41// static variables, methods
42//
43
44#ifndef G4SANDIATABLE_HH
45#define G4SANDIATABLE_HH
46
47#include "G4OrderedTable.hh"
48#include "G4ios.hh"
49#include "globals.hh"
50
52#include <assert.h>
53
54#include <vector>
55
56class G4Material;
57
59{
60 public: // with description
63 G4SandiaTable(G4int matIndex);
65
67 G4SandiaTable& operator=(const G4SandiaTable& right) = delete;
68
69 // main computation per atom:
70 void GetSandiaCofPerAtom(G4int Z, G4double energy, std::vector<G4double>& coeff) const;
71
72 void GetSandiaCofWater(G4double energy, std::vector<G4double>& coeff) const;
73
76
77 static G4double GetZtoA(G4int Z);
78
79 // per volume of a material:
83 const G4double* GetSandiaCofForMaterial(G4double energy) const;
84
87
88 inline void SetVerbose(G4int ver) { fVerbose = ver; };
89
90 /////////////////////////////////////////////////////////////////////
91 //
92 // Methods for implementation of PAI model
93 //
94 /////////////////////////////////////////////////////////////////////
95
96 void Initialize(const G4Material*);
97
99
100 G4int SandiaMixing(G4int Z[], const G4double* fractionW, G4int el, G4int mi);
101
103
104 G4int GetMaxInterval() const;
105
106 inline G4bool GetLowerI1() { return fLowerI1; };
107 inline void SetLowerI1(G4bool flag) { fLowerI1 = flag; };
108
109 // operators
110 G4bool operator==(const G4SandiaTable&) const = delete;
111 G4bool operator!=(const G4SandiaTable&) const = delete;
112
113 private:
114 void ComputeMatSandiaMatrix();
115 void ComputeMatSandiaMatrixPAI();
116
117 // methods per atom
118 G4double GetSandiaPerAtom(G4int Z, G4int, G4int) const;
119
120#ifdef G4VERBOSE
121 static G4int PrintErrorZ(G4int Z, const G4String&);
122 static void PrintErrorV(const G4String&);
123#endif
124
125 void ComputeMatTable();
126
127 void SandiaSwap(G4double** da, G4int i, G4int j);
128
129 void SandiaSort(G4double** da, G4int sz);
130
131 G4double** GetPointerToCof();
132
133 // computed once
134 static G4int fCumulInterval[101];
135 static const G4double funitc[5];
136
137 // used at initialisation
138 std::vector<G4double> fSandiaCofPerAtom;
139
140 // members of the class
141 const G4Material* fMaterial;
142 G4int fMatNbOfIntervals;
143 G4OrderedTable* fMatSandiaMatrix;
144 G4OrderedTable* fMatSandiaMatrixPAI;
145
146 static const G4double fSandiaTable[981][5];
147 static const G4int fNumberOfElements;
148 static const G4int fIntervalLimit;
149 static const G4int fNumberOfIntervals;
150 static const G4int fH2OlowerInt;
151
152 // data members for PAI model
153 G4double** fPhotoAbsorptionCof; // SandiaTable for mixture
154
155 G4int fMaxInterval;
156 G4int fVerbose;
157 G4bool fLowerI1;
158};
159
160#endif
double G4double
Definition G4Types.hh:83
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
void SetVerbose(G4int ver)
void Initialize(const G4Material *)
G4int GetMaxInterval() const
G4SandiaTable & operator=(const G4SandiaTable &right)=delete
G4bool operator==(const G4SandiaTable &) const =delete
G4double GetWaterEnergyLimit() const
G4int GetMatNbOfIntervals() const
static G4double GetZtoA(G4int Z)
G4double GetWaterCofForMaterial(G4int, G4int) const
G4SandiaTable(G4SandiaTable &)=delete
G4double GetSandiaCofForMaterial(G4int, G4int) const
const G4double * GetSandiaCofForMaterialPAI(G4double energy) const
void GetSandiaCofWater(G4double energy, std::vector< G4double > &coeff) const
void SetLowerI1(G4bool flag)
G4bool operator!=(const G4SandiaTable &) const =delete
G4double GetSandiaMatTablePAI(G4int, G4int) const
G4int SandiaMixing(G4int Z[], const G4double *fractionW, G4int el, G4int mi)
void GetSandiaCofPerAtom(G4int Z, G4double energy, std::vector< G4double > &coeff) const
G4int SandiaIntervals(G4int Z[], G4int el)
G4double GetSandiaMatTable(G4int, G4int) const
G4bool GetLowerI1()
G4double GetPhotoAbsorpCof(G4int i, G4int j) const