68 for(
auto tr :
TV)
delete tr;
74 while(nextVertex !=
nullptr)
77 nextVertex = nextVertex->
GetNext();
93 primaryVertex->
Print();
97 G4cout <<
"G4PrimaryTransformer::PrimaryVertex ("
100 << Z0 / mm <<
"(mm),"
101 << T0 / nanosecond <<
"(nsec))" <<
G4endl;
106 while( primaryParticle !=
nullptr )
109 primaryParticle = primaryParticle->
GetNext();
125 <<
") --- Ignored" <<
G4endl;
129 while(daughter !=
nullptr)
132 daughter = daughter->
GetNext();
142 <<
") --- Transferred with momentum "
154 ed <<
"Primary particle PDG=" << primaryParticle->
GetPDGcode()
155 <<
" deltaMass(MeV)=" << (std::abs(pmas - primaryParticle->
GetMass()))/CLHEP::MeV
156 <<
" is larger than the tolerance(MeV)=" <<
kETolerance/CLHEP::MeV
157 <<
"\n Specified mass(MeV)=" << (primaryParticle->
GetMass())/CLHEP::MeV
158 <<
" while PDG mass(MEV)=" << pmas/CLHEP::MeV
159 <<
"\n To change the tolerance or the exception severity,"
160 <<
" use G4PrimaryTransformer::SetKETolerance() method.";
173 G4Exception(
"G4PrimaryTransformer::GenerateSingleTrack",
175 "Polarization of the optical photon is null.\
176 Random polarization is assumed.");
177 G4cerr <<
"This warning message is issued up to 10 times." <<
G4endl;
188 if (modul2 > 0.) e_perpend = (1./std::sqrt(modul2))*product;
192 + std::sin(angle)*e_perpend;
193 DP->SetPolarization(polar.
x(),polar.
y(),polar.
z());
197 DP->SetPolarization(primaryParticle->
GetPolX(),
203 DP->SetPreAssignedDecayProperTime(primaryParticle->
GetProperTime());
209 if(pmas>=0.) { DP->SetMass(pmas); }
217 DP->SetCharge(primaryParticle->
GetCharge());
224 if (n_e>0) DP->AddElectron(0,n_e);
233 DP->SetPrimaryParticle(primaryParticle);
239 DP->SetPDGcode(primaryParticle->
GetPDGcode());
262 track->SetParentID(0);
266 track->SetWeight(wv*(primaryParticle->
GetWeight()));
270 TV.push_back( track );
278 if(daughter ==
nullptr)
return;
281 if(decayProducts ==
nullptr)
286 while(daughter !=
nullptr)
295 <<
") --- Ignored" <<
G4endl;
306 <<
") --- Attached with momentum " << daughter->
GetMomentum()
312 DP->SetPrimaryParticle(daughter);
318 DP->SetPreAssignedDecayProperTime(daughter->
GetProperTime());
335 DP->SetPolarization(daughter->
GetPolX(),
338 decayProducts->PushProducts(DP);
349 daughter = daughter->
GetNext();
358 G4cerr <<
"unknownParticleDefined cannot be set true because" <<
G4endl
359 <<
"G4UnknownParticle is not defined in the physics list." <<
G4endl
360 <<
"Command ignored." <<
G4endl;
370 G4cerr <<
"chargedUnknownParticleDefined cannot be set true because" <<
G4endl
371 <<
"G4ChargedUnknownParticle is not defined in the physics list." <<
G4endl
372 <<
"Command ignored." <<
G4endl;
382 if(decayProducts !=
nullptr && decayProducts->entries()>0)
return true;
384 <<
"G4PrimaryTransformer: a shortlived primary particle is found"
386 <<
" without any valid decay table nor pre-assigned decay mode."
389 "This primary particle will be ignored.");
397 if(partDef ==
nullptr)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
CLHEP::Hep3Vector G4ThreeVector
std::vector< G4Track * > G4TrackVector
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
Hep3Vector cross(const Hep3Vector &) const
void SetPreAssignedDecayProducts(G4DecayProducts *aDecayProducts)
const G4DecayProducts * GetPreAssignedDecayProducts() const
G4ParticleDefinition * GetDefinition() const
G4PrimaryVertex * GetPrimaryVertex(G4int i=0) const
G4int GetAtomicNumber() const
G4bool IsShortLived() const
G4double GetPDGMass() const
G4int GetPDGEncoding() const
G4DecayTable * GetDecayTable() const
const G4String & GetParticleName() const
static G4ParticleTable * GetParticleTable()
G4double GetWeight() const
G4double GetCharge() const
G4double GetKineticEnergy() const
G4double GetProperTime() const
const G4ThreeVector & GetMomentumDirection() const
void SetTrackID(G4int id)
G4ThreeVector GetPolarization() const
G4PrimaryParticle * GetNext() const
G4ThreeVector GetMomentum() const
G4PrimaryParticle * GetDaughter() const
G4PrimaryVertex * GetNext() const
G4double GetWeight() const
G4PrimaryParticle * GetPrimary(G4int i=0) const