Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4Isotope.cc
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// 26.06.96: Code uses operators (+=, *=, ++, -> etc.) correctly, P. Urban
27// 29.01.97: Forbidden to create Isotope with Z<1 or N<Z, M.Maire
28// 03.05.01: flux.precision(prec) at begin/end of operator<<
29// 17.07.01: migration to STL. M. Verderi.
30// 13.09.01: suppression of the data member fIndexInTable
31// 14.09.01: fCountUse: nb of elements which use this isotope
32// 26.02.02: fIndexInTable renewed
33// 17.10.06: if fA is not defined in the constructor, it is computed from
34// NistManager v.Ivanchenko
35// 25.10.11: new scheme for G4Exception (mma)
36
37#include "G4Isotope.hh"
38
39#include "G4NistManager.hh"
41#include "G4SystemOfUnits.hh"
42
43#include <iomanip>
44
45//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
46
47// Create an isotope
48//
50 : fName(Name), fZ(Z), fN(N), fA(A), fm(il)
51{
52 if (Z < 1) {
54 ed << "Wrong Isotope " << Name << " Z= " << Z << G4endl;
55 G4Exception("G4Isotope::G4Isotope()", "mat001", FatalException, ed);
56 }
57 if (N < Z) {
59 ed << "Wrong Isotope " << Name << " Z= " << Z << " > N= " << N << G4endl;
60 G4Exception("G4Isotope::G4Isotope()", "mat002", FatalException, ed);
61 }
62 if (A <= 0.0) {
63 fA =
64 (G4NistManager::Instance()->GetAtomicMass(Z, N)) * CLHEP::g / (CLHEP::mole * CLHEP::amu_c2);
65 }
66 GetIsotopeTableRef().push_back(this);
67 fIndexInTable = GetIsotopeTableRef().size() - 1;
68}
69
70//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
71
72G4Isotope::~G4Isotope() { GetIsotopeTableRef()[fIndexInTable] = nullptr; }
73
74//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
75
76G4bool G4Isotope::operator==(const G4Isotope& right) const { return (this == (G4Isotope*)&right); }
77
78//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
79
80G4bool G4Isotope::operator!=(const G4Isotope& right) const { return (this != (G4Isotope*)&right); }
81
82//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
83
84std::ostream& operator<<(std::ostream& flux, const G4Isotope* isotope)
85{
86 std::ios::fmtflags mode = flux.flags();
87 flux.setf(std::ios::fixed, std::ios::floatfield);
88 G4long prec = flux.precision(3);
89
90 // clang-format off
91 flux
92 << " Isotope: " << std::setw(5) << isotope->fName
93 << " Z = " << std::setw(2) << isotope->fZ
94 << " N = " << std::setw(3) << isotope->fN
95 << " A = " << std::setw(6) << std::setprecision(2)
96 << (isotope->fA)/(g/mole) << " g/mole";
97 // clang-format on
98
99 flux.precision(prec);
100 flux.setf(mode, std::ios::floatfield);
101 return flux;
102}
103
104//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
105
106std::ostream& operator<<(std::ostream& flux, const G4Isotope& isotope)
107{
108 flux << &isotope;
109 return flux;
110}
111
112//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
113
114std::ostream& operator<<(std::ostream& flux, const G4IsotopeTable& IsotopeTable)
115{
116 // Dump info for all known isotopes
117 flux << "\n***** Table : Nb of isotopes = " << IsotopeTable.size() << " *****\n" << G4endl;
118
119 for (auto const & i : IsotopeTable) {
120 flux << i << G4endl;
121 }
122
123 return flux;
124}
125
126//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
127
128const G4IsotopeTable* G4Isotope::GetIsotopeTable() { return &GetIsotopeTableRef(); }
129
130//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
131
132G4IsotopeTable& G4Isotope::GetIsotopeTableRef()
133{
134 struct Holder {
136 ~Holder() {
137 for(auto item : instance)
138 delete item;
139 }
140 };
141 static Holder _holder;
142 return _holder.instance;
143}
144
145
146//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
147
148std::size_t G4Isotope::GetNumberOfIsotopes() { return GetIsotopeTableRef().size(); }
149
150//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
151
152G4Isotope* G4Isotope::GetIsotope(const G4String& isotopeName, G4bool warning)
153{
154 // search the isotope by its name
155 for (auto const & J : GetIsotopeTableRef()) {
156 if (J->GetName() == isotopeName) {
157 return J;
158 }
159 }
160
161 // the isotope does not exist in the table
162 if (warning) {
163 G4cout << "\n---> warning from G4Isotope::GetIsotope(). The isotope: " << isotopeName
164 << " does not exist in the table. Return NULL pointer." << G4endl;
165 }
166 return nullptr;
167}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
std::ostream & operator<<(std::ostream &flux, const G4Isotope *isotope)
Definition G4Isotope.cc:84
std::vector< G4Isotope * > G4IsotopeTable
Definition G4Isotope.hh:59
G4TemplateRNGHelper< G4long > * G4TemplateRNGHelper< G4long >::instance
double G4double
Definition G4Types.hh:83
long G4long
Definition G4Types.hh:87
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
const G4double A[17]
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
static const G4IsotopeTable * GetIsotopeTable()
Definition G4Isotope.cc:128
G4bool operator!=(const G4Isotope &) const
Definition G4Isotope.cc:80
static G4Isotope * GetIsotope(const G4String &name, G4bool warning=false)
Definition G4Isotope.cc:152
G4Isotope(const G4String &name, G4int z, G4int n, G4double a=0., G4int mlevel=0)
Definition G4Isotope.cc:49
G4bool operator==(const G4Isotope &) const
Definition G4Isotope.cc:76
static std::size_t GetNumberOfIsotopes()
Definition G4Isotope.cc:148
G4double GetAtomicMass(G4int Z, G4int N) const
static G4NistManager * Instance()
#define N
Definition crc32.c:57