Geant4
10.03
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
G4NucleusLimits.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
// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
27
//
28
// MODULE: G4NucleusLimits.cc
29
//
30
// Version: 0.b.4
31
// Date: 14/04/00
32
// Author: F Lei & P R Truscott
33
// Organisation: DERA UK
34
// Customer: ESA/ESTEC, NOORDWIJK
35
// Contract: 12115/96/JG/NL Work Order No. 3
36
//
37
// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
38
//
39
// CHANGE HISTORY
40
// --------------
41
//
42
// 29 February 2000, P R Truscott, DERA UK
43
// 0.b.3 release.
44
//
45
// 14 April 2000, F Lei, DERA UK
46
// 0.b.4 release. No change in this class
47
//
48
// 02 November 2011, L Desorgher
49
// Remove the maximum limits of A<250 and Z<100
50
// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
52
//
53
#include "
G4NucleusLimits.hh
"
55
//
56
G4NucleusLimits::G4NucleusLimits
()
57
: aMin(1), aMax(250), zMin(0), zMax(100)
58
//
59
// Default constructor sets the limits to cover all nuclei with Z<100.
60
//
61
{;}
63
//
64
G4NucleusLimits::G4NucleusLimits
65
(
G4int
aMin1,
G4int
aMax1,
G4int
zMin1,
G4int
zMax1)
66
{
67
//
68
// check that aMin1 is within [1, 250].
69
//
70
if
(aMin1 < 1) {aMin = 1;}
71
//else if (aMin1 > 250) {aMin = 240;}
72
else
{aMin = aMin1;}
73
74
//
75
// check that aMax1 is within [1, 250].
76
//
77
if
(aMax1 < 1) {aMax = 1;}
78
//else if (aMax1 > 250) {aMax = 250;}
79
else
{aMax = aMax1;}
80
81
//
82
// If aMin > aMax then swap them.
83
//
84
if
(aMin > aMax) {
85
G4int
t = aMin;
86
aMin = aMax;
87
aMax = t;
88
}
89
//
90
// check that zMin1 is within [0, 100].
91
//
92
if
(zMin1 < 0) {zMin = 0;}
93
//else if (zMin1 > 100) {zMin = 100;}
94
else
{zMin = zMin1;}
95
96
//
97
// check that zMax1 is within [0, 100].
98
//
99
if
(zMax1 < 0) {zMax = 0;}
100
//else if (zMax1 > 100) {zMax = 100;}
101
else
{zMax = zMax1;}
102
103
//
104
// If zMin > zMax then swap them.
105
//
106
if
(zMin > zMax) {
107
G4int
t = zMin;
108
zMin = zMax;
109
zMax = t;
110
}
111
}
112
113
114
G4NucleusLimits::~G4NucleusLimits
()
115
{;}
116
117
118
std::ostream &
operator <<
(std::ostream& strm,
const
G4NucleusLimits
& q)
119
{
120
// Definition of the insertion operator << to provide the nucleus limits to
121
// ostream
122
strm <<
"Atomic weight: "
<< q.
GetAMin
() <<
"->"
<< q.
GetAMax
()
123
<<
"Atomic number: "
<< q.
GetZMin
() <<
"->"
<< q.
GetZMax
();
124
return
strm;
125
}
126
G4NucleusLimits::~G4NucleusLimits
~G4NucleusLimits()
Definition:
G4NucleusLimits.cc:114
G4NucleusLimits.hh
G4NucleusLimits::GetZMax
G4int GetZMax() const
Definition:
G4NucleusLimits.hh:100
G4int
int G4int
Definition:
G4Types.hh:78
G4NucleusLimits::GetAMin
G4int GetAMin() const
Definition:
G4NucleusLimits.hh:91
G4NucleusLimits::GetAMax
G4int GetAMax() const
Definition:
G4NucleusLimits.hh:94
operator<<
std::ostream & operator<<(std::ostream &strm, const G4NucleusLimits &q)
Definition:
G4NucleusLimits.cc:118
G4NucleusLimits::G4NucleusLimits
G4NucleusLimits()
Definition:
G4NucleusLimits.cc:56
G4NucleusLimits
Definition:
G4NucleusLimits.hh:58
G4NucleusLimits::GetZMin
G4int GetZMin() const
Definition:
G4NucleusLimits.hh:97
geant4.10.03
source
processes
hadronic
models
radioactive_decay
src
G4NucleusLimits.cc
Generated on Thu Feb 14 2002 02:29:20 for Geant4 by
1.8.8