ATLAS Offline Software
G4SElectronRPlus.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 #include "G4SElectronRPlus.hh"
6 // ######################################################################
7 // ### SElectronRPlus ###
8 // ######################################################################
9 
10 
11 G4SElectronRPlus* G4SElectronRPlus::theInstance = NULL;
12 
13 G4SElectronRPlus* G4SElectronRPlus::Definition(G4double mass, G4double width, G4double charge, G4double PDG, G4bool stable, G4double lifetime, G4bool shortlived)
14 {
15 
16  if (theInstance !=0 && (mass>=0. || width>=0. || lifetime>=0.) )
17  {
18  G4ExceptionDescription description;
19  description << "Trying to redefine the G4SElectronL Plus properties after it has been constructed is not allowed";
20  G4Exception("G4SElectronRPlus", "FailedRedefinition", FatalException, description);
21  abort();
22  }
23 
24  if (theInstance != 0)
25  {
26  return theInstance;
27  }
28 
29 
30  // Arguments for constructor are as follows
31  // name mass width charge
32  // 2*spin parity C-conjugation
33  // 2*Isospin 2*Isospin3 G-parity
34  // type lepton number baryon number PDG encoding
35  // stable lifetime decay table
36  // shortlived subType anti_encoding
37  if (mass >= 0) {
38 
39  G4ParticleDefinition* anInstance =
40  new G4ParticleDefinition("s_e_plus_R", mass, width, charge,
41  0, 0, 0,
42  0, 0, 0,
43  "slepton", 1, 0, PDG,
44  stable, lifetime, NULL,
45  shortlived, "SElectronRPlus");
46 
47  theInstance = reinterpret_cast<G4SElectronRPlus*>(anInstance);
48  return theInstance;
49  }
50  else
51  {
52  G4ExceptionDescription description;
53  description << "Trying to create a particle with default constructor is not allowed";
54  G4Exception("G4SElectronRPlus", "DefaultConstructorCalled", FatalException, description);
55  abort();
56  }
57 }
dqt_zlumi_pandas.mass
mass
Definition: dqt_zlumi_pandas.py:170
PDG20
Definition: Trigger/TrigHypothesis/TrigBphysHypo/src/Constants.h:9
MCTruthPartClassifier::stable
@ stable
Definition: TruthClassifiers.h:148
charge
double charge(const T &p)
Definition: AtlasPID.h:494
Base_Fragment.width
width
Definition: Sherpa_i/share/common/Base_Fragment.py:59
description
std::string description
glabal timer - how long have I taken so far?
Definition: hcg.cxx:88