G4ITReactionChange.hh

Go to the documentation of this file.
00001 //
00002 // ********************************************************************
00003 // * License and Disclaimer                                           *
00004 // *                                                                  *
00005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
00006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
00007 // * conditions of the Geant4 Software License,  included in the file *
00008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
00009 // * include a list of copyright holders.                             *
00010 // *                                                                  *
00011 // * Neither the authors of this software system, nor their employing *
00012 // * institutes,nor the agencies providing financial support for this *
00013 // * work  make  any representation or  warranty, express or implied, *
00014 // * regarding  this  software system or assume any liability for its *
00015 // * use.  Please see the license in the file  LICENSE  and URL above *
00016 // * for the full disclaimer and the limitation of liability.         *
00017 // *                                                                  *
00018 // * This  code  implementation is the result of  the  scientific and *
00019 // * technical work of the GEANT4 collaboration.                      *
00020 // * By using,  copying,  modifying or  distributing the software (or *
00021 // * any work based  on the software)  you  agree  to acknowledge its *
00022 // * use  in  resulting  scientific  publications,  and indicate your *
00023 // * acceptance of all terms of the Geant4 Software license.          *
00024 // ********************************************************************
00025 //
00026 // $Id: G4ITReactionChange.hh 64057 2012-10-30 15:04:49Z gcosmo $
00027 //
00028 // Author: Mathieu Karamitros (kara (AT) cenbg . in2p3 . fr) 
00029 //
00030 // WARNING : This class is released as a prototype.
00031 // It might strongly evolve or even disapear in the next releases.
00032 //
00033 // History:
00034 // -----------
00035 // 10 Oct 2011 M.Karamitros created
00036 //
00037 // -------------------------------------------------------------------
00038 
00039 #ifndef G4ITReactionChange_H
00040 #define G4ITReactionChange_H
00041 
00042 #include "globals.hh"
00043 #include "G4ParticleChange.hh"
00044 #include "G4TrackFastVector.hh"
00045 
00050 class G4ITReactionChange
00051 {
00052 public:
00054     G4ITReactionChange();
00056     virtual ~G4ITReactionChange();
00057 
00058     //_____________________________________________________
00059     // To be used by reaction processes
00060     void Initialize(const G4Track&,
00061                     const G4Track&,
00062                     G4VParticleChange* particleChangeA = 0,
00063                     G4VParticleChange* particleChangeB = 0
00064                     ) ;
00065     void AddSecondary(G4Track* aSecondary);
00066     inline void KillParents(G4bool);
00067 
00068     // If both parents are not killed therefore
00069     // we can used the particle change
00070     // you will have to give the pointers
00071     // of your particleChange while intializing
00072     // but it might tell you that energy is not
00073     // conserved for instance
00074     G4VParticleChange* GetParticleChange(const G4Track*);
00075 
00076     //_____________________________________________________
00077     // Not to be used in reaction processes
00078     void UpdateStepInfo(G4Step*, G4Step*);
00079     G4Track* GetSecondary(G4int) const;
00080     G4TrackFastVector* GetfSecondary() ;
00081 
00082     G4int GetNumberOfSecondaries() const;
00083     G4bool WereParentsKilled() const;
00084 
00085     const G4Track* GetTrackA();
00086     const G4Track* GetTrackB();
00087 
00088 protected:
00092     G4ITReactionChange(const G4ITReactionChange& other);
00097     G4ITReactionChange& operator=(const G4ITReactionChange& other);
00098     // equal/unequal operator
00099     G4bool operator==(const G4ITReactionChange &right) const;
00100     G4bool operator!=(const G4ITReactionChange &right) const;
00101     // "equal" means that the objects have the same pointer.
00102 protected:
00103     std::map<const G4Track*, G4VParticleChange*> fParticleChange;
00104     G4TrackFastVector* fSecondaries ;
00105     G4int fNumberOfSecondaries;
00106     G4bool fKillParents ;
00107     G4bool fParticleChangeIsSet;
00108 };
00109 
00110 inline G4Track* G4ITReactionChange::GetSecondary(G4int anIndex) const
00111 {
00112     return (*fSecondaries)[anIndex];
00113 }
00114 
00115 inline G4int G4ITReactionChange::GetNumberOfSecondaries() const
00116 {
00117     return fNumberOfSecondaries;
00118 }
00119 
00120 inline void G4ITReactionChange::KillParents(G4bool kill)
00121 {
00122     fKillParents = kill;
00123 }
00124 
00125 inline G4bool G4ITReactionChange::WereParentsKilled() const
00126 {
00127     return fKillParents ;
00128 }
00129 
00130 inline G4TrackFastVector* G4ITReactionChange::GetfSecondary()
00131 {
00132     return fSecondaries;
00133 }
00134 
00135 #endif // G4ITReactionChange_H

Generated on Mon May 27 17:48:41 2013 for Geant4 by  doxygen 1.4.7