Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions
UltraPrimaryGeneratorAction Class Reference

#include <UltraPrimaryGeneratorAction.hh>

Inheritance diagram for UltraPrimaryGeneratorAction:
G4VUserPrimaryGeneratorAction

Public Member Functions

 UltraPrimaryGeneratorAction ()
 
 ~UltraPrimaryGeneratorAction ()
 
void GeneratePrimaries (G4Event *anEvent)
 
G4GeneralParticleSourceGetParticleGun ()
 
- Public Member Functions inherited from G4VUserPrimaryGeneratorAction
 G4VUserPrimaryGeneratorAction ()
 
virtual ~G4VUserPrimaryGeneratorAction ()
 

Detailed Description

Definition at line 53 of file UltraPrimaryGeneratorAction.hh.

Constructor & Destructor Documentation

UltraPrimaryGeneratorAction::UltraPrimaryGeneratorAction ( )

Definition at line 61 of file UltraPrimaryGeneratorAction.cc.

References python.hepunit::cm, python.hepunit::eV, G4ParticleTable::FindParticle(), G4SingleParticleSource::GetAngDist(), G4GeneralParticleSource::GetCurrentSource(), G4SingleParticleSource::GetEneDist(), G4ParticleTable::GetParticleTable(), G4SingleParticleSource::GetPosDist(), G4SPSPosDistribution::SetCentreCoords(), G4SPSEneDistribution::SetEnergyDisType(), G4SPSEneDistribution::SetMonoEnergy(), G4GeneralParticleSource::SetParticleDefinition(), G4SPSAngDistribution::SetParticleMomentumDirection(), G4GeneralParticleSource::SetParticlePolarization(), G4SPSPosDistribution::SetPosDisShape(), G4SPSPosDistribution::SetPosDisType(), G4SPSPosDistribution::SetPosRot1(), G4SPSPosDistribution::SetPosRot2(), and G4SPSPosDistribution::SetRadius().

62 {
63 
64  particleGun = new G4GeneralParticleSource();
65 
66 
67  // Define here the user default properties for the General Particle Source (GPS)
68  // Can be modified through the GPS Messenger (/gps/... commands)
69 
71  G4String particleName;
72 
73  G4ParticleDefinition* opticalphoton = particleTable->FindParticle(particleName="opticalphoton");
74 
75  //....PARTICLE DEFINITIONS
76  particleGun->SetParticleDefinition(opticalphoton);
77 
78  G4ThreeVector Polarization = G4ThreeVector(1.,1.,0.) ;
79  particleGun->SetParticlePolarization(Polarization);
80 
81  // DEFINE A MONO-ENERGETIC SOURCE
82  G4SPSEneDistribution *eneDist = particleGun->GetCurrentSource()->GetEneDist() ;
83  eneDist->SetEnergyDisType("Mono");
84  eneDist->SetMonoEnergy(3.0*eV);
85 
86  // SET POSITION DISTRIBUTION
87  G4SPSPosDistribution *posDist = particleGun->GetCurrentSource()->GetPosDist() ;
88  posDist->SetPosDisType("Plane");
89  posDist->SetPosDisShape("Circle");
90  posDist->SetRadius(20.0*cm);
91 
92 #ifdef ULTRA_MIRROR_USE
93 #define ULTRA_REFLECTION_USE
94 #endif
95 
96 #ifdef ULTRA_GROUND_USE
97 #define ULTRA_REFLECTION_USE
98 #endif
99 
100  G4SPSAngDistribution *angDist = particleGun->GetCurrentSource()->GetAngDist() ;
101 
102 #ifdef ULTRA_REFLECTION_USE
103  angDist->SetParticleMomentumDirection(G4ThreeVector(0.0,-1.0,0.0)) ;
104  posDist->SetPosRot1(G4ThreeVector(1.,0.,0.));
105  posDist->SetPosRot2(G4ThreeVector(0.,0.,-1.));
106  posDist->SetCentreCoords(G4ThreeVector(0.0*cm,90.0*cm,150.0*cm));
107 
108 #else
109  angDist->SetParticleMomentumDirection(G4ThreeVector(0.0,0.0,-1.0)) ;
110  posDist->SetCentreCoords(G4ThreeVector(0.0*cm,0.0*cm,150.0*cm));
111 
112 #endif
113 
114 }
G4SPSEneDistribution * GetEneDist()
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
CLHEP::Hep3Vector G4ThreeVector
G4SPSPosDistribution * GetPosDist()
void SetParticleDefinition(G4ParticleDefinition *aParticleDefinition)
void SetCentreCoords(G4ThreeVector)
void SetEnergyDisType(G4String)
void SetParticlePolarization(G4ThreeVector aVal)
void SetPosRot1(G4ThreeVector)
G4SingleParticleSource * GetCurrentSource()
G4SPSAngDistribution * GetAngDist()
static G4ParticleTable * GetParticleTable()
void SetPosRot2(G4ThreeVector)
void SetParticleMomentumDirection(G4ParticleMomentum aMomentumDirection)
UltraPrimaryGeneratorAction::~UltraPrimaryGeneratorAction ( )

Definition at line 118 of file UltraPrimaryGeneratorAction.cc.

119 {
120  delete particleGun;
121 }

Member Function Documentation

void UltraPrimaryGeneratorAction::GeneratePrimaries ( G4Event anEvent)
virtual

Implements G4VUserPrimaryGeneratorAction.

Definition at line 125 of file UltraPrimaryGeneratorAction.cc.

References python.hepunit::c_light, energy(), python.hepunit::eV, FatalException, G4cerr, G4cout, G4endl, G4Exception(), G4GeneralParticleSource::GeneratePrimaryVertex(), G4GeneralParticleSource::GetCurrentSource(), G4SingleParticleSource::GetEneDist(), G4SPSEneDistribution::GetEnergyDisType(), G4Event::GetEventID(), UltraDetectorConstruction::GetLambdaMax(), UltraDetectorConstruction::GetLambdaMin(), G4GeneralParticleSource::GetParticleDefinition(), G4GeneralParticleSource::GetParticleEnergy(), G4ParticleDefinition::GetParticleName(), G4SingleParticleSource::GetPosDist(), G4SPSPosDistribution::GetPosDisType(), G4RunManager::GetRunManager(), and python.hepunit::h_Planck.

126 {
127 
128  G4int iEvent = anEvent->GetEventID() ;
129  if ( iEvent == 0 ){
130 
131  G4cout << particleGun->GetParticleDefinition()->GetParticleName() << " " ;
132  G4cout << particleGun->GetCurrentSource()->GetEneDist()->GetEnergyDisType() << " " ;
133  G4cout << particleGun->GetCurrentSource()->GetPosDist()->GetPosDisType() << G4endl ;
134 
135 
136 // Check if optical photon wavelength is within limits set for material optical properties tables.
137 
138 
139 
140 
141 }
142  particleGun->GeneratePrimaryVertex(anEvent);
143 
144  if (particleGun->GetParticleDefinition()->GetParticleName() == "opticalphoton"){
145 
146  const UltraDetectorConstruction * detector =
147  dynamic_cast<const UltraDetectorConstruction *>((G4RunManager::GetRunManager())->GetUserDetectorConstruction()) ;
148 
149  G4double lambda_min = detector->GetLambdaMin() ;
150  G4double lambda_max = detector->GetLambdaMax() ;
151 
152  G4double energy = particleGun->GetParticleEnergy() ;
153 
154  if (h_Planck*c_light/energy > lambda_max || h_Planck*c_light/energy < lambda_min){
155  G4cerr << "Error ! Optical photon energy (" << energy/eV << " eV) out of limits set by material optical properties tables. \n"
156  << "Please check that photon wavelength is within the following interval: ["
157  << lambda_min/nm << ","
158  << lambda_max/nm << "] nm"
159  << ", i.e., ["
160  << h_Planck*c_light/lambda_max/eV << ","
161  << h_Planck*c_light/lambda_min/eV << "] eV"
162  << G4endl ;
163 
164  G4Exception("UltraPrimaryGeneratorAction::GeneratePrimaries()","AirSh005",
165  FatalException,"Wavelength outside the valid range") ;
166  }
167  }
168 
169 }
G4ParticleDefinition * GetParticleDefinition()
G4SPSEneDistribution * GetEneDist()
float h_Planck
Definition: hepunit.py:263
G4SPSPosDistribution * GetPosDist()
int G4int
Definition: G4Types.hh:78
const G4String & GetParticleName() const
G4int GetEventID() const
Definition: G4Event.hh:140
double precision function energy(A, Z)
Definition: dpm25nuc6.f:4106
G4GLOB_DLL std::ostream G4cout
G4SingleParticleSource * GetCurrentSource()
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
Definition: G4Exception.cc:41
static G4RunManager * GetRunManager()
Definition: G4RunManager.cc:74
#define G4endl
Definition: G4ios.hh:61
double G4double
Definition: G4Types.hh:76
float c_light
Definition: hepunit.py:257
G4GLOB_DLL std::ostream G4cerr
G4GeneralParticleSource* UltraPrimaryGeneratorAction::GetParticleGun ( )
inline

Definition at line 64 of file UltraPrimaryGeneratorAction.hh.

64 {return particleGun;}

The documentation for this class was generated from the following files: