86 : theParticleName(aName),
91 thePDGSpin(iSpin*0.5),
92 thePDGiParity(iParity),
93 thePDGiConjugation(iConjugation),
94 thePDGiGParity(gParity),
95 thePDGiIsospin(iIsospin),
96 thePDGiIsospin3(iIsospin3),
97 thePDGIsospin(iIsospin*0.5),
98 thePDGIsospin3(iIsospin3*0.5),
99 thePDGMagneticMoment(magneticMoment),
100 theLeptonNumber(lepton),
101 theBaryonNumber(baryon),
102 theParticleType(pType),
103 theParticleSubType(subType),
106 fShortLivedFlag(shortlived),
107 thePDGStable(stable),
108 thePDGLifeTime(lifetime),
109 theDecayTable(decaytable)
112 static const G4String nucleus(
"nucleus");
113 static const G4String muAtom(
"MuonicAtom");
115 g4particleDefinitionInstanceID = -1;
116 theProcessManagerShadow =
nullptr;
121 verboseLevel = theParticleTable->GetVerboseLevel();
123 if (anti_encoding != 0) theAntiPDGEncoding = anti_encoding;
128 if (verboseLevel > 0) {
131 G4cout <<
"Particle " << aName <<
" has a strange PDGEncoding " <<
G4endl;
135 "Strange PDGEncoding ");
141 if (!fShortLivedFlag && (theParticleType != nucleus) && (theParticleType != muAtom)
146 G4cout <<
"G4ParticleDefinition (other than ions and shortlived)"
147 <<
" should be created in Pre_Init state - " << aName <<
G4endl;
151 "G4ParticleDefinition should be created in PreInit state");
154 if (theParticleTable->GetIonTable()->IsIon(
this)) {
159 if (theParticleTable->GetIonTable()->IsAntiIon(
this)) {
165 theParticleTable->Insert(
this);
G4ProcessManager * GetProcessManager() const
G4VTrackingManager * GetTrackingManager() const
G4int GetAtomicNumber() const
static const G4PDefManager & GetSubInstanceManager()
G4bool IsGeneralIon() const
G4ParticleDefinition(const G4String &aName, G4double mass, G4double width, G4double charge, G4int iSpin, G4int iParity, G4int iConjugation, G4int iIsospin, G4int iIsospinZ, G4int gParity, const G4String &pType, G4int lepton, G4int baryon, G4int encoding, G4bool stable, G4double lifetime, G4DecayTable *decaytable, G4bool shortlived=false, const G4String &subType="", G4int anti_encoding=0, G4double magneticMoment=0.0)
G4int GetAntiPDGEncoding() const
G4int theAntiQuarkContent[NumberOfQuarkFlavor]
G4int GetVerboseLevel() const
void SetParticleDefinitionID(G4int id=-1)
void SetTrackingManager(G4VTrackingManager *aTrackingManager)
G4int GetAtomicMass() const
virtual ~G4ParticleDefinition()
G4double GetPDGCharge() const
G4bool operator==(const G4ParticleDefinition &right) const
void SetApplyCutsFlag(G4bool)
G4int theQuarkContent[NumberOfQuarkFlavor]
void SetAtomicMass(G4int)
G4double GetIonLifeTime() const
G4int GetBaryonNumber() const
G4bool operator!=(const G4ParticleDefinition &right) const
G4double CalculateAnomaly() const
G4int FillQuarkContents()
const G4String & GetParticleName() const
void SetProcessManager(G4ProcessManager *aProcessManager)
void SetAtomicNumber(G4int)
static G4ParticleTable * GetParticleTable()