62G4AdjointSimManager::G4AdjointSimManager()
64 theAdjointPrimaryGeneratorAction =
new G4AdjointPrimaryGeneratorAction();
65 theAdjointSteppingAction =
new G4AdjointSteppingAction();
66 theAdjointTrackingAction =
new G4AdjointTrackingAction(theAdjointSteppingAction);
67 theAdjointStackingAction =
new G4AdjointStackingAction(theAdjointTrackingAction);
68 theAdjointTrackingAction->SetListOfPrimaryFwdParticles(
69 theAdjointPrimaryGeneratorAction->GetListOfPrimaryFwdParticles());
71 theMessenger =
new G4AdjointSimMessenger(
this);
76G4AdjointSimManager::~G4AdjointSimManager()
78 delete theAdjointRunAction;
79 delete theAdjointPrimaryGeneratorAction;
80 delete theAdjointSteppingAction;
81 delete theAdjointEventAction;
82 delete theAdjointTrackingAction;
83 delete theAdjointStackingAction;
91 if (instance ==
nullptr) instance =
new G4AdjointSimManager;
100 if (welcome_message) {
101 G4cout <<
"****************************************************************" << std::endl;
102 G4cout <<
"*** Geant4 Reverse/Adjoint Monte Carlo mode ***" << std::endl;
103 G4cout <<
"*** Author: L.Desorgher ***" << std::endl;
104 G4cout <<
"*** Company: SpaceIT GmbH, Bern, Switzerland ***" << std::endl;
105 G4cout <<
"*** Sponsored by: ESA/ESTEC contract contract 21435/08/NL/AT ***" << std::endl;
106 G4cout <<
"****************************************************************" << std::endl;
107 welcome_message =
false;
116 nb_evt_of_last_run = nb_evt;
119 G4int(nb_evt * theAdjointPrimaryGeneratorAction->GetNbOfAdjointPrimaryTypes()));
125void G4AdjointSimManager::SetRestOfAdjointActions()
129 if (!user_action_already_defined) DefineUserActions();
134 theRunManager->G4RunManager::SetUserAction(theAdjointEventAction);
135 theRunManager->G4RunManager::SetUserAction(theAdjointSteppingAction);
136 theRunManager->G4RunManager::SetUserAction(theAdjointTrackingAction);
150 adjoint_sim_mode =
true;
151 ID_of_last_particle_that_reach_the_ext_source = 0;
162 adjoint_sim_mode =
false;
167void G4AdjointSimManager::SetAdjointActions()
172 if (!user_action_already_defined) DefineUserActions();
177 theRunManager->G4RunManager::SetUserAction(
this);
180 theRunManager->G4RunManager::SetUserAction(theAdjointPrimaryGeneratorAction);
181 theRunManager->G4RunManager::SetUserAction(theAdjointStackingAction);
182 if (use_user_StackingAction)
186 theRunManager->G4RunManager::SetUserAction(theAdjointEventAction);
187 theRunManager->G4RunManager::SetUserAction(theAdjointSteppingAction);
188 theRunManager->G4RunManager::SetUserAction(theAdjointTrackingAction);
189 if (use_user_TrackingAction)
198void G4AdjointSimManager::SetAdjointPrimaryRunAndStackingActions()
202 if (!user_action_already_defined) DefineUserActions();
207 theRunManager->G4RunManager::SetUserAction(theAdjointRunAction);
209 theRunManager->G4RunManager::SetUserAction(theAdjointPrimaryGeneratorAction);
210 theRunManager->G4RunManager::SetUserAction(theAdjointStackingAction);
211 if (use_user_StackingAction)
212 theAdjointStackingAction->SetUserFwdStackingAction(fUserStackingAction);
214 theAdjointStackingAction->SetUserFwdStackingAction(
nullptr);
220void G4AdjointSimManager::ResetUserActions()
226 theRunManager->G4RunManager::SetUserAction(fUserRunAction);
228 theRunManager->G4RunManager::SetUserAction(fUserEventAction);
229 theRunManager->G4RunManager::SetUserAction(fUserSteppingAction);
230 theRunManager->G4RunManager::SetUserAction(fUserTrackingAction);
231 theRunManager->G4RunManager::SetUserAction(fUserPrimaryGeneratorAction);
232 theRunManager->G4RunManager::SetUserAction(fUserStackingAction);
238void G4AdjointSimManager::ResetRestOfUserActions()
246 theRunManager->G4RunManager::SetUserAction(fUserEventAction);
247 theRunManager->G4RunManager::SetUserAction(fUserSteppingAction);
248 theRunManager->G4RunManager::SetUserAction(fUserTrackingAction);
253void G4AdjointSimManager::ResetUserPrimaryRunAndStackingActions()
258 theRunManager->G4RunManager::SetUserAction(fUserRunAction);
260 theRunManager->G4RunManager::SetUserAction(fUserPrimaryGeneratorAction);
261 theRunManager->G4RunManager::SetUserAction(fUserStackingAction);
267void G4AdjointSimManager::DefineUserActions()
274 fUserEventAction =
const_cast<G4UserEventAction*
>(theRunManager->
GetUserEventAction());
276 theAdjointSteppingAction->SetUserForwardSteppingAction(fUserSteppingAction);
277 fUserPrimaryGeneratorAction =
280 user_action_already_defined =
true;
288 return theAdjointTrackingAction->GetIsAdjointTrackingMode();
295 adjoint_tracking_mode = aBool;
297 if (adjoint_tracking_mode) {
298 SetRestOfAdjointActions();
299 theAdjointStackingAction->SetAdjointMode(
true);
300 theAdjointStackingAction->SetKillTracks(
false);
303 ResetRestOfUserActions();
304 theAdjointStackingAction->SetAdjointMode(
false);
306 theAdjointStackingAction->SetKillTracks(
false);
310 theAdjointStackingAction->SetKillTracks(
true);
325 return theAdjointPrimaryGeneratorAction->GetListOfPrimaryFwdParticles();
332 return theAdjointPrimaryGeneratorAction->GetListOfPrimaryFwdParticles()->size();
339 return theAdjointTrackingAction->GetPositionAtEndOfLastAdjointTrack(i);
346 return theAdjointTrackingAction->GetDirectionAtEndOfLastAdjointTrack(i);
353 return theAdjointTrackingAction->GetEkinAtEndOfLastAdjointTrack(i);
360 return theAdjointTrackingAction->GetEkinNucAtEndOfLastAdjointTrack(i);
367 return theAdjointTrackingAction->GetWeightAtEndOfLastAdjointTrack(i);
374 return theAdjointTrackingAction->GetCosthAtEndOfLastAdjointTrack(i);
381 return theAdjointTrackingAction->GetFwdParticleNameAtEndOfLastAdjointTrack();
388 return theAdjointTrackingAction->GetFwdParticlePDGEncodingAtEndOfLastAdjointTrack(i);
395 return theAdjointTrackingAction->GetLastFwdParticleIndex(i);
402 return theAdjointTrackingAction->GetNbOfAdointTracksReachingTheExternalSurface();
409 theAdjointTrackingAction->ClearEndOfAdjointTrackInfoVectors();
416 last_pos = theAdjointSteppingAction->GetLastPosition();
417 last_direction = theAdjointSteppingAction->GetLastMomentum();
418 last_direction /= last_direction.mag();
419 last_cos_th = last_direction.z();
424 last_fwd_part_name.erase(0, 4);
426 last_fwd_part_PDGEncoding =
429 std::vector<G4ParticleDefinition*>* aList =
430 theAdjointPrimaryGeneratorAction->GetListOfPrimaryFwdParticles();
431 last_fwd_part_index = -1;
433 while (i < (
G4int)aList->size() && last_fwd_part_index < 0) {
434 if ((*aList)[i]->GetParticleName() == last_fwd_part_name) last_fwd_part_index = i;
438 last_ekin = theAdjointSteppingAction->GetLastEkin();
439 last_ekin_nuc = last_ekin;
442 last_ekin_nuc /= nb_nuc;
445 last_weight = theAdjointSteppingAction->GetLastWeight();
447 last_pos_vec.push_back(last_pos);
448 last_direction_vec.push_back(last_direction);
449 last_ekin_vec.push_back(last_ekin);
450 last_ekin_nuc_vec.push_back(last_ekin_nuc);
451 last_cos_th_vec.push_back(last_cos_th);
452 last_weight_vec.push_back(last_weight);
453 last_fwd_part_PDGEncoding_vec.push_back(last_fwd_part_PDGEncoding);
454 last_fwd_part_index_vec.push_back(last_fwd_part_index);
455 ID_of_last_particle_that_reach_the_ext_source++;
456 ID_of_last_particle_that_reach_the_ext_source_vec.push_back(
457 ID_of_last_particle_that_reach_the_ext_source);
494 theAdjointSteppingAction->SetExtSourceEMax(Emax);
504 theAdjointPrimaryGeneratorAction->SetSphericalAdjointPrimarySource(radius, pos);
505 area_of_the_adjoint_source = area;
518 "AdjointSource", radius, volume_name, center, area);
519 theAdjointPrimaryGeneratorAction->SetSphericalAdjointPrimarySource(radius, center);
520 area_of_the_adjoint_source = area;
530 "AdjointSource", volume_name, area);
531 area_of_the_adjoint_source = area;
533 theAdjointPrimaryGeneratorAction->SetAdjointPrimarySourceOnAnExtSurfaceOfAVolume(volume_name);
542 theAdjointPrimaryGeneratorAction->SetEmin(Emin);
549 theAdjointPrimaryGeneratorAction->SetEmax(Emax);
556 theAdjointPrimaryGeneratorAction->ConsiderParticleAsPrimary(particle_name);
563 theAdjointPrimaryGeneratorAction->NeglectParticleAsPrimary(particle_name);
571 theAdjointPrimaryGeneratorAction->SetPrimaryIon(adjointIon, fwdIon);
578 return theAdjointPrimaryGeneratorAction->GetPrimaryIonName();
585 theAdjointPrimaryWeight = aWeight;
586 theAdjointSteppingAction->SetPrimWeight(aWeight);
593 theAdjointEventAction = anAction;
600 theAdjointSteppingAction->SetUserAdjointSteppingAction(anAction);
607 theAdjointStackingAction->SetUserAdjointStackingAction(anAction);
614 theAdjointRunAction = anAction;
621 theAdjointPrimaryGeneratorAction->SetNbPrimaryFwdGammasPerEvent(nb);
628 theAdjointPrimaryGeneratorAction->SetNbAdjointPrimaryGammasPerEvent(nb);
635 theAdjointPrimaryGeneratorAction->SetNbAdjointPrimaryElectronsPerEvent(nb);
641{
if (!adjoint_sim_mode){
642 if(fUserRunAction !=
nullptr) fUserRunAction->BeginOfRunAction(aRun);
645 if (theAdjointRunAction !=
nullptr) theAdjointRunAction->BeginOfRunAction(aRun);
655 if (!adjoint_sim_mode) {
656 if (fUserRunAction !=
nullptr) fUserRunAction->EndOfRunAction(aRun);
658 else if (theAdjointRunAction !=
nullptr)
669 return theAdjointPrimaryGeneratorAction->GetLastGeneratedFwdPrimaryParticle();
676 theAdjointSteppingAction->ResetDidOneAdjPartReachExtSourceDuringEvent();
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cout
G4bool AddaSphericalSurface(const G4String &SurfaceName, G4double radius, G4ThreeVector pos, G4double &area)
G4bool AddanExtSurfaceOfAvolume(const G4String &SurfaceName, const G4String &volume_name, G4double &area)
static G4AdjointCrossSurfChecker * GetInstance()
G4bool AddaSphericalSurfaceWithCenterAtTheCenterOfAVolume(const G4String &SurfaceName, G4double radius, const G4String &volume_name, G4ThreeVector ¢er, G4double &area)
void SetAdjointStackingAction(G4UserStackingAction *anAction)
void ClearEndOfAdjointTrackInfoVectors()
G4bool DefineAdjointSourceOnTheExtSurfaceOfAVolume(const G4String &volume_name)
const G4String & GetPrimaryIonName()
G4bool DefineExtSourceOnTheExtSurfaceOfAVolume(const G4String &volume_name)
G4double GetEkinAtEndOfLastAdjointTrack(std::size_t i=0)
G4int GetFwdParticlePDGEncodingAtEndOfLastAdjointTrack(std::size_t i=0)
G4bool GetDidAdjParticleReachTheExtSource()
std::vector< G4ParticleDefinition * > * GetListOfPrimaryFwdParticles()
void RunAdjointSimulation(G4int nb_evt)
G4double GetCosthAtEndOfLastAdjointTrack(std::size_t i=0)
void BeginOfRunAction(const G4Run *aRun) override
G4bool GetAdjointTrackingMode()
const G4String & GetFwdParticleNameAtEndOfLastAdjointTrack()
G4bool DefineSphericalExtSourceWithCentreAtTheCentreOfAVolume(G4double radius, const G4String &volume_name)
void SetNbAdjointPrimaryGammasPerEvent(G4int)
void SetAdjointTrackingMode(G4bool aBool)
void ConsiderParticleAsPrimary(const G4String &particle_name)
void SwitchToAdjointSimulationMode()
std::size_t GetNbOfPrimaryFwdParticles()
void SetAdjointRunAction(G4UserRunAction *anAction)
void SetExtSourceEmax(G4double Emax)
void RegisterAtEndOfAdjointTrack()
void SetAdjointSourceEmax(G4double Emax)
void RegisterAdjointPrimaryWeight(G4double aWeight)
void SetAdjointSourceEmin(G4double Emin)
G4double GetWeightAtEndOfLastAdjointTrack(std::size_t i=0)
void ResetDidOneAdjPartReachExtSourceDuringEvent()
void SetAdjointEventAction(G4UserEventAction *anAction)
void NeglectParticleAsPrimary(const G4String &particle_name)
G4bool DefineSphericalAdjointSourceWithCentreAtTheCentreOfAVolume(G4double radius, const G4String &volume_name)
void SetNbAdjointPrimaryElectronsPerEvent(G4int)
static G4AdjointSimManager * GetInstance()
G4int GetFwdParticleIndexAtEndOfLastAdjointTrack(std::size_t i=0)
G4double GetEkinNucAtEndOfLastAdjointTrack(std::size_t i=0)
void SetNbOfPrimaryFwdGammasPerEvent(G4int)
G4ThreeVector GetDirectionAtEndOfLastAdjointTrack(std::size_t i=0)
void BackToFwdSimulationMode()
G4ParticleDefinition * GetLastGeneratedFwdPrimaryParticle()
void SetAdjointSteppingAction(G4UserSteppingAction *anAction)
G4bool DefineSphericalExtSource(G4double radius, G4ThreeVector pos)
G4ThreeVector GetPositionAtEndOfLastAdjointTrack(std::size_t i=0)
std::size_t GetNbOfAdointTracksReachingTheExternalSurface()
G4bool DefineSphericalAdjointSource(G4double radius, G4ThreeVector pos)
void SetPrimaryIon(G4ParticleDefinition *adjointIon, G4ParticleDefinition *fwdIon)
void EndOfRunAction(const G4Run *aRun) override
void SetUserFwdStackingAction(G4UserStackingAction *anAction)
void SetUserForwardTrackingAction(G4UserTrackingAction *anAction)
const G4String & GetParticleType() const
G4int GetPDGEncoding() const
G4int GetBaryonNumber() const
const G4String & GetParticleName() const
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
static G4ParticleTable * GetParticleTable()
const G4UserTrackingAction * GetUserTrackingAction() const
const G4VUserPrimaryGeneratorAction * GetUserPrimaryGeneratorAction() const
const G4UserEventAction * GetUserEventAction() const
static G4RunManager * GetRunManager()
virtual void BeamOn(G4int n_event, const char *macroFile=nullptr, G4int n_select=-1)
const G4UserStackingAction * GetUserStackingAction() const
const G4UserSteppingAction * GetUserSteppingAction() const
const G4UserRunAction * GetUserRunAction() const
virtual void EndOfRunAction(const G4Run *)