// // ******************************************************************** // * License and Disclaimer * // * * // * The Geant4 software is copyright of the Copyright Holders of * // * the Geant4 Collaboration. It is provided under the terms and * // * conditions of the Geant4 Software License, included in the file * // * LICENSE and available at http://cern.ch/geant4/license . These * // * include a list of copyright holders. * // * * // * Neither the authors of this software system, nor their employing * // * institutes,nor the agencies providing financial support for this * // * work make any representation or warranty, express or implied, * // * regarding this software system or assume any liability for its * // * use. Please see the license in the file LICENSE and URL above * // * for the full disclaimer and the limitation of liability. * // * * // * This code implementation is the result of the scientific and * // * technical work of the GEANT4 collaboration. * // * By using, copying, modifying or distributing the software (or * // * any work based on the software) you agree to acknowledge its * // * use in resulting scientific publications, and indicate your * // * acceptance of all terms of the Geant4 Software license. * // ******************************************************************** // // // $Id: G4ParticleDefinition.cc,v 1.34 2009/09/21 04:08:24 kurasige Exp $ // GEANT4 tag $Name: geant4-09-03-cand-01 $ // // // -------------------------------------------------------------- // GEANT 4 class implementation file // // History: first implementation, based on object model of // 2nd December 1995, G.Cosmo // ---------------- G4ParticleDefinition ----------------- // first implementation by Makoto Asai, 29 January 1996 // revised by G.Cosmo, 29 February 1996 // revised by H.Kurashige, 19 April 1996 // Code uses operators (+=, *=, ++, -> etc.) correctly, P. Urban, 26/6/96 // revised by H.Kurashige, 4 July 1996 // revised by H.Kurashige, 16 Feb 1997 // revised by H.Kurashige, 10 Nov 1997 // remove new/delete G4ProcessManager by H.Kurashige 06 June 1998 // added Resonance flag and ApplyCuts flag H.Kurashige 27 June 1998 // modify FillQuarkContents() for quarks/diquarks H.Kurashige 30 June 1998 // modify encoding rule H.Kurashige 23 Oct. 98 // modify FillQuarkContents() for deltas 25 Nov.,98 H.Kurashige // // modify FillQuarkContents() to use G4PDGCodeChecker 17 Aug. 99 H.Kurashige // -------------------------------------------------------------- #include "G4ParticleDefinition.hh" #include "G4ParticleTable.hh" #include "G4IonTable.hh" #include "G4DecayTable.hh" #include "G4PDGCodeChecker.hh" #include "G4StateManager.hh" G4ParticleDefinition::G4ParticleDefinition( const G4String& aName, G4double mass, G4double width, G4double charge, G4int iSpin, G4int iParity, G4int iConjugation, G4int iIsospin, G4int iIsospin3, G4int gParity, const G4String& pType, G4int lepton, G4int baryon, G4int encoding, G4bool stable, G4double lifetime, G4DecayTable *decaytable, G4bool shortlived, const G4String& subType, G4int anti_encoding, G4double magneticMoment) : theParticleName(aName), thePDGMass(mass), thePDGWidth(width), thePDGCharge(charge), thePDGiSpin(iSpin), thePDGSpin(iSpin*0.5), thePDGiParity(iParity), thePDGiConjugation(iConjugation), thePDGiGParity(gParity), thePDGiIsospin(iIsospin), thePDGiIsospin3(iIsospin3), thePDGIsospin(iIsospin*0.5), thePDGIsospin3(iIsospin3*0.5), thePDGMagneticMoment(magneticMoment), theLeptonNumber(lepton), theBaryonNumber(baryon), theParticleType(pType), theParticleSubType(subType), thePDGEncoding(encoding), theAntiPDGEncoding(-1*encoding), fShortLivedFlag(shortlived), thePDGStable(stable), thePDGLifeTime(lifetime), theDecayTable(decaytable), theProcessManager(0), theAtomicNumber(0), theAtomicMass(0), verboseLevel(1), fApplyCutsFlag(false) { static G4String nucleus("nucleus"); theParticleTable = G4ParticleTable::GetParticleTable(); //set verboseLevel equal to ParticleTable verboseLevel = theParticleTable->GetVerboseLevel(); if (anti_encoding !=0) theAntiPDGEncoding = anti_encoding; // check quark contents if (this->FillQuarkContents() != thePDGEncoding) { #ifdef G4VERBOSE if (verboseLevel>0) { // Using G4cerr expecting that it is available in construction of static objects G4cerr << "Particle " << aName << " has a strange PDGEncoding " <GetCurrentState(); if ( (theParticleType!=nucleus) && (currentState!=G4State_PreInit)){ #ifdef G4VERBOSE if (GetVerboseLevel()>0) { G4cout << "G4ParticleDefintion (other than ions) should be created in Pre_Init state "; G4cout << aName << G4endl; } #endif G4Exception( "G4ParticleDefintion::G4ParticleDefintion", "Illegal operation", JustWarning, "G4ParticleDefinition should be created in PreInit state"); } if (theParticleTable->GetIonTable()->IsIon(this)) { SetAtomicNumber( G4int(GetPDGCharge()/eplus) ); SetAtomicMass( GetBaryonNumber() ); } // check name and register this particle into ParticleTable theParticleTable->Insert(this); } G4ParticleDefinition::G4ParticleDefinition(const G4ParticleDefinition &) { G4Exception("G4ParticleDefinition::G4ParticleDefinition()", "illegal constructor call", FatalException, "You call Copy Constructor of G4ParticleDefinition "); } G4ParticleDefinition::G4ParticleDefinition() { G4Exception("G4ParticleDefinition::G4ParticleDefinition()", "illegal constructor call", FatalException, "You call Default Constructor of G4ParticleDefinition "); } G4ParticleDefinition::~G4ParticleDefinition() { if (theDecayTable!= 0) delete theDecayTable; } const G4ParticleDefinition & G4ParticleDefinition::operator=(const G4ParticleDefinition &right) { if (this != &right) { } return *this; } G4int G4ParticleDefinition::operator==(const G4ParticleDefinition &right) const { return (this->theParticleName == right.theParticleName); } G4int G4ParticleDefinition::operator!=(const G4ParticleDefinition &right) const { return (this->theParticleName != right.theParticleName); } G4int G4ParticleDefinition::FillQuarkContents() // calculate quark and anti-quark contents // return value is PDG encoding for this particle. // It means error if the return value is differnt from // this->thePDGEncoding. { G4int flavor; for (flavor= 0; flavor0) { G4cout << "G4ParticleDefinition::FillQuarkContents : "; G4cout << " illegal charge (" << thePDGCharge/eplus; G4cout << " PDG code=" << thePDGEncoding <0) { G4cout << "G4ParticleDefinition::FillQuarkContents : "; G4cout << " illegal SPIN (" << thePDGiSpin << "/2"; G4cout << " PDG code=" << thePDGEncoding <GetAntiPDGEncoding() << "]"<< G4endl; G4cout << " Mass [GeV/c2] : " << thePDGMass/GeV ; G4cout << " Width : " << thePDGWidth/GeV << G4endl; G4cout << " Lifetime [nsec] : " << thePDGLifeTime/ns << G4endl; G4cout << " Charge [e]: " << thePDGCharge/eplus << G4endl; G4cout << " Spin : " << thePDGiSpin << "/2" << G4endl; G4cout << " Parity : " << thePDGiParity << G4endl; G4cout << " Charge conjugation : " << thePDGiConjugation << G4endl; G4cout << " Isospin : (I,Iz): (" << thePDGiIsospin <<"/2"; G4cout << " , " << thePDGiIsospin3 << "/2 ) " << G4endl; G4cout << " GParity : " << thePDGiGParity << G4endl; if (thePDGMagneticMoment != 0.0) { G4cout << " MagneticMoment [MeV/T] : " << thePDGMagneticMoment/MeV*tesla << G4endl; } G4cout << " Quark contents (d,u,s,c,b,t) : " << theQuarkContent[0]; G4cout << ", " << theQuarkContent[1]; G4cout << ", " << theQuarkContent[2]; G4cout << ", " << theQuarkContent[3]; G4cout << ", " << theQuarkContent[4]; G4cout << ", " << theQuarkContent[5] << G4endl; G4cout << " AntiQuark contents : " << theAntiQuarkContent[0]; G4cout << ", " << theAntiQuarkContent[1]; G4cout << ", " << theAntiQuarkContent[2]; G4cout << ", " << theAntiQuarkContent[3]; G4cout << ", " << theAntiQuarkContent[4]; G4cout << ", " << theAntiQuarkContent[5] << G4endl; G4cout << " Lepton number : " << theLeptonNumber; G4cout << " Baryon number : " << theBaryonNumber << G4endl; G4cout << " Particle type : " << theParticleType ; G4cout << " [" << theParticleSubType << "]" << G4endl; if ( fShortLivedFlag ){ G4cout << " ShortLived : ON" << G4endl; } if ( thePDGStable ){ G4cout << " Stable : stable" << G4endl; } else { if( theDecayTable != 0 ){ theDecayTable->DumpInfo(); } else { G4cout << "Decay Table is not defined !!" <