Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/event/include/G4UserEventAction.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  1 //
  2 // ********************************************************************
  3 // * License and Disclaimer                                           *
  4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.                             *
 10 // *                                                                  *
 11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                                                  *
 18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // ********************************************************************
 25 //
 26 // G4UserEventAction
 27 //
 28 // Class description:
 29 //
 30 // This is the base class of one of the user's optional action classes.
 31 // The two methods BeginOfEventAction() and EndOfEventAction() are invoked
 32 // at the beginning and the end of one event processing. These methods are
 33 // invoked by G4EventManager.
 34 // Be aware that BeginOfEventAction() is invoked when a G4Event object is
 35 // sent to G4EventManager. Thus the primary vertexes/particles have already
 36 // been made by the primary generator. In case the user wants to do something
 37 // before generating primaries (i.e., store random number status), do it in
 38 // the G4VUserPrimaryGeneratorAction concrete class
 39 
 40 // Author: Makoto Asai (SLAC)
 41 // Adding MergeSubEvent - Sep/11/2023 Makoto Asai (JLab)
 42 // --------------------------------------------------------------------
 43 #ifndef G4UserEventAction_hh
 44 #define G4UserEventAction_hh 1
 45 
 46 class G4EventManager;
 47 class G4Event;
 48 
 49 class G4UserEventAction 
 50 {
 51   public:
 52 
 53     G4UserEventAction();
 54     virtual ~G4UserEventAction() = default;
 55     virtual void SetEventManager(G4EventManager* value);
 56 
 57     virtual void BeginOfEventAction(const G4Event* anEvent);
 58     virtual void EndOfEventAction(const G4Event* anEvent);
 59       // Two virtual method the user can override.
 60 
 61     virtual void MergeSubEvent(G4Event* masterEvent, const G4Event* subEvent);
 62       // A virtual method to merge the results of a sub-event into the master
 63       // event. The ownership of "subEvent" and its contents blong to the
 64       // worker thread. 
 65       // Merging trajectories and scores are taken care by G4Event and
 66       // G4ScoringManager so the user does not need to take care of them.
 67       // But merging hits collections and UserEventInformation must be taken 
 68       // care by this method.
 69       // This method is invoked only for the case of sub-event parallelism.
 70 
 71   protected:
 72 
 73       G4EventManager* fpEventManager = nullptr; // not owned
 74 };
 75 
 76 #endif
 77