56 theExcitationEnergy(0.0),
57 theGroundStateMass(0.0),
63 numberOfChargedHoles(0),
64 numberOfShellElectrons(0),
65 theParticleDefinition(0),
75 theExcitationEnergy = right.theExcitationEnergy;
76 theGroundStateMass = right.theGroundStateMass;
77 theMomentum = right.theMomentum;
78 theAngularMomentum = right.theAngularMomentum;
79 numberOfParticles = right.numberOfParticles;
80 numberOfCharged = right.numberOfCharged;
81 numberOfHoles = right.numberOfHoles;
82 numberOfChargedHoles = right.numberOfChargedHoles;
83 numberOfShellElectrons = right.numberOfShellElectrons;
84 theParticleDefinition = right.theParticleDefinition;
85 theCreationTime = right.theCreationTime;
86 isStable = right.isStable;
95 theMomentum(aMomentum),
100 numberOfChargedHoles(0),
101 numberOfShellElectrons(0),
102 theParticleDefinition(0),
103 theCreationTime(0.0),
106 theExcitationEnergy = 0.0;
107 theGroundStateMass = 0.0;
109 CalculateGroundStateMass();
110 CalculateExcitationEnergy();
114 if(theExcitationEnergy > 0.0) { isStable =
false; }
123 theMomentum(aMomentum),
125 numberOfParticles(0),
128 numberOfChargedHoles(0),
129 numberOfShellElectrons(0),
130 theParticleDefinition(aParticleDefinition),
131 theCreationTime(0.0),
134 theExcitationEnergy = 0.0;
137 G4String text =
"G4Fragment::G4Fragment constructor for gamma used for "
141 theGroundStateMass = aParticleDefinition->
GetPDGMass();
146 if (
this != &right) {
149 theExcitationEnergy = right.theExcitationEnergy;
150 theGroundStateMass = right.theGroundStateMass;
151 theMomentum = right.theMomentum;
152 theAngularMomentum = right.theAngularMomentum;
153 numberOfParticles = right.numberOfParticles;
154 numberOfCharged = right.numberOfCharged;
155 numberOfHoles = right.numberOfHoles;
156 numberOfChargedHoles = right.numberOfChargedHoles;
157 numberOfShellElectrons = right.numberOfShellElectrons;
158 theParticleDefinition = right.theParticleDefinition;
159 theCreationTime = right.theCreationTime;
160 isStable = right.isStable;
178 out <<
"Fragment: null pointer ";
182 std::ios::fmtflags old_floatfield = out.flags();
183 out.setf(std::ios::floatfield);
185 out <<
"Fragment: A = " << std::setw(3) << theFragment->theA
186 <<
", Z = " << std::setw(3) << theFragment->theZ ;
187 out.setf(std::ios::scientific,std::ios::floatfield);
190 std::streamsize floatPrec = out.precision();
192 out << std::setprecision(3)
196 << theFragment->theMomentum.
x()/CLHEP::MeV <<
","
197 << theFragment->theMomentum.
y()/CLHEP::MeV <<
","
198 << theFragment->theMomentum.
z()/CLHEP::MeV
200 << theFragment->theMomentum.
t()/CLHEP::MeV <<
" MeV"
207 <<
"#Particles= " << theFragment->numberOfParticles
208 <<
", #Charged= " << theFragment->numberOfCharged
209 <<
", #Holes= " << theFragment->numberOfHoles
210 <<
", #ChargedHoles= " << theFragment->numberOfChargedHoles
213 out.setf(old_floatfield,std::ios::floatfield);
214 out.precision(floatPrec);
225 void G4Fragment::ExcitationEnergyWarning()
227 if (theExcitationEnergy < -10 * CLHEP::eV) {
230 G4cout <<
"G4Fragment::CalculateExcitationEnergy(): WARNING "<<
G4endl;
234 #ifdef debug_G4Fragment
237 G4Exception(
"G4Fragment::ExcitationEnergyWarning()",
"had777",
241 theExcitationEnergy = 0.0;
244 void G4Fragment::NumberOfExitationWarning(
const G4String&
value)
246 G4cout <<
"G4Fragment::"<< value <<
" ERROR "
249 G4String text =
"G4Fragment::G4Fragment wrong exciton number ";
std::ostringstream G4ExceptionDescription
G4int GetPDGEncoding() const
G4bool isStable(Cluster const *const c)
True if the cluster is stable.
const G4String & GetParticleName() const
G4ThreadLocal G4Allocator< G4Fragment > * pFragmentAllocator
G4GLOB_DLL std::ostream G4cout
G4bool operator==(const G4Fragment &right) const
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
G4double GetPDGMass() const
G4int GetNumberOfExcitons() const
std::ostream & operator<<(std::ostream &, const BasicVector3D< float > &)
G4bool operator!=(const G4Fragment &right) const
const XML_Char int const XML_Char * value
G4Fragment & operator=(const G4Fragment &right)
G4double GetExcitationEnergy() const