50 type_of_adjoint_source=
"Spherical";
53 theSingleParticleSource->GetEneDist()->SetEnergyDisType(
"Pow");
54 theSingleParticleSource->GetEneDist()->SetAlpha(-1.);
55 theSingleParticleSource->GetPosDist()->SetPosDisType(
"Point");
56 theSingleParticleSource->GetAngDist()->SetAngDistType(
"planar");
65 delete theSingleParticleSource;
74 if (type_of_adjoint_source ==
"ExternalSurfaceOfAVolume")
82 theG4AdjointPosOnPhysVolGenerator
83 ->GenerateAPositionOnTheExtSurfaceOfThePhysicalVolume(pos, direction,
85 if (costh_to_normal <1.e-4) { costh_to_normal = 1.e-4; }
89 theSingleParticleSource->GetAngDist()
90 ->SetParticleMomentumDirection(-direction);
91 theSingleParticleSource->GetPosDist()->SetCentreCoords(pos);
94 theSingleParticleSource->GetEneDist()->SetEmin(E1);
95 theSingleParticleSource->GetEneDist()->SetEmax(E2);
97 theSingleParticleSource->SetParticleDefinition(adj_part);
98 theSingleParticleSource->GeneratePrimaryVertex(anEvent);
107 if (type_of_adjoint_source ==
"ExternalSurfaceOfAVolume")
115 theG4AdjointPosOnPhysVolGenerator
116 ->GenerateAPositionOnTheExtSurfaceOfThePhysicalVolume(pos, direction,
118 if (costh_to_normal <1.e-4) { costh_to_normal =1.e-4; }
119 theSingleParticleSource->GetAngDist()
120 ->SetParticleMomentumDirection(direction);
121 theSingleParticleSource->GetPosDist()->SetCentreCoords(pos);
124 theSingleParticleSource->GetEneDist()->SetEmin(E1);
125 theSingleParticleSource->GetEneDist()->SetEmax(E2);
127 theSingleParticleSource->SetParticleDefinition(fwd_part);
128 theSingleParticleSource->GeneratePrimaryVertex(anEvent);
136 radius_spherical_source = radius;
137 center_spherical_source = center_pos;
138 type_of_adjoint_source =
"Spherical";
139 theSingleParticleSource->GetPosDist()->SetPosDisType(
"Surface");
140 theSingleParticleSource->GetPosDist()->SetPosDisShape(
"Sphere");
141 theSingleParticleSource->GetPosDist()->SetCentreCoords(center_pos);
142 theSingleParticleSource->GetPosDist()->SetRadius(radius);
143 theSingleParticleSource->GetAngDist()->SetAngDistType(
"cos");
144 theSingleParticleSource->GetAngDist()->SetMaxTheta(pi);
145 theSingleParticleSource->GetAngDist()->SetMinTheta(halfpi);
153 theG4AdjointPosOnPhysVolGenerator->DefinePhysicalVolume1(volume_name);
154 type_of_adjoint_source =
"ExternalSurfaceOfAVolume";
155 theSingleParticleSource->GetPosDist()->SetPosDisType(
"Point");
156 theSingleParticleSource->GetAngDist()->SetAngDistType(
"planar");
166 if (fLinearNavigator ==
nullptr)
174 fLinearNavigator->LocateGlobalPointAndSetup(
position);
177 delete theAccumulatedDepthVector;
182 theAccumulatedDepthVector->InsertValues(acc_length,acc_depth);
184 while (newStep > 0. && thePhysVolume !=
nullptr)
189 theAccumulatedDepthVector->InsertValues(acc_length,acc_depth);
191 thePhysVolume = fLinearNavigator
192 ->LocateGlobalPointAndSetup(
position,
nullptr,
false);
193 newStep = fLinearNavigator->ComputeStep(
position,direction,1.e50,safety);
203 G4double distance = theAccumulatedDepthVector->FindLinearEnergy(rand);
CLHEP::Hep3Vector G4ThreeVector
static G4AdjointPosOnPhysVolGenerator * GetInstance()
void SetSphericalAdjointPrimarySource(G4double radius, G4ThreeVector pos)
void SetAdjointPrimarySourceOnAnExtSurfaceOfAVolume(const G4String &v_name)
void GenerateAdjointPrimaryVertex(G4Event *anEvt, G4ParticleDefinition *adj_part, G4double E1, G4double E2)
G4double SampleDistanceAlongBackRayAndComputeWeightCorrection(G4double &weight_corr)
void GenerateFwdPrimaryVertex(G4Event *anEvt, G4ParticleDefinition *adj_part, G4double E1, G4double E2)
void ComputeAccumulatedDepthVectorAlongBackRay(G4ThreeVector glob_pos, G4ThreeVector direction, G4double ekin, G4ParticleDefinition *aPDef)
G4AdjointPrimaryGenerator()
~G4AdjointPrimaryGenerator()
G4Material * GetMaterial() const
G4double GetDensity() const
static G4TransportationManager * GetTransportationManager()
G4Navigator * GetNavigatorForTracking() const
G4LogicalVolume * GetLogicalVolume() const