42 : fParticleName(particlename),
49 : fParticleName(particlename),
62 delete fImportanceConfigurator; fImportanceConfigurator =
nullptr;
63 delete fWeightWindowConfigurator; fWeightWindowConfigurator =
nullptr;
64 delete fWeightCutOffConfigurator; fWeightCutOffConfigurator =
nullptr;
66 fConfigurators.clear();
67 fIsConfigured =
false;
75 G4cout <<
"WARNING - G4GeometrySampler::IsConfigured()"
76 <<
" Some initialization exists, use ClearSampling()"
77 <<
" before a new initialization !" <<
G4endl;
107 G4cout <<
"G4GeometrySampler:: preparing importance sampling WorldName is " << fWorldName <<
G4endl;
111 fImportanceConfigurator =
114 fImportanceConfigurator->SetWorldName(fWorldName);
116 if (!fImportanceConfigurator)
118 G4Exception(
"G4GeometrySampler::PrepareImportanceSampling()",
120 "Failed allocation of G4ImportanceConfigurator !");
130 G4cout <<
"G4GeometrySampler:: preparing weight roulette" <<
G4endl;
139 fWeightCutOffConfigurator =
147 if (!fWeightCutOffConfigurator)
149 G4Exception(
"G4GeometrySampler::PrepareWeightRoulett()",
151 "Failed allocation of G4WeightCutOffConfigurator !");
161 G4cout <<
"G4GeometrySampler:: preparing weight window" <<
G4endl;
165 fWeightWindowConfigurator =
169 placeOfAction, paraflag);
176 fIsConfigured =
true;
178 if (fImportanceConfigurator)
180 fConfigurators.push_back(fImportanceConfigurator);
182 if (fWeightWindowConfigurator)
184 fConfigurators.push_back(fWeightWindowConfigurator);
188#ifdef G4MULTITHREADED
189 G4cout <<
" make sure AddProcess() is invoked for biasing!!! " <<
G4endl;
201 for (
auto it = fConfigurators.cbegin();
202 it != fConfigurators.cend(); ++it)
208 if (fWeightCutOffConfigurator !=
nullptr)
210 fWeightCutOffConfigurator->Configure(
nullptr);
228 fParticleName = particlename;
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
G4GLOB_DLL std::ostream G4cout
void SetParticle(const G4String &particlename)
void SetParallel(G4bool paraflag)
virtual void PrepareWeightRoulett(G4double wsurvive, G4double wlimit, G4double isource)
void SetWorld(const G4VPhysicalVolume *world)
virtual G4bool IsConfigured() const
virtual void ClearSampling()
virtual void PrepareWeightWindow(G4VWeightWindowStore *wwstore, G4VWeightWindowAlgorithm *wwAlg, G4PlaceOfAction placeOfAction)
virtual void PrepareImportanceSampling(G4VIStore *istore, const G4VImportanceAlgorithm *ialg)
virtual ~G4GeometrySampler()
virtual void AddProcess()
G4GeometrySampler(G4VPhysicalVolume *worldvolume, const G4String &particlename)
G4VPhysicalVolume * GetWorldVolume() const
static G4TransportationManager * GetTransportationManager()
G4Navigator * GetNavigatorForTracking() const
virtual const G4VPhysicalVolume & GetWorldVolume() const =0
virtual void Configure(G4VSamplerConfigurator *preConf)=0
virtual const G4VPhysicalVolume & GetWorldVolume() const =0