source: trunk/source/processes/hadronic/models/management/include/G4HadronicInteraction.hh@ 1005

Last change on this file since 1005 was 962, checked in by garnier, 17 years ago

update processes

File size: 6.6 KB
Line 
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//
27// $Id: G4HadronicInteraction.hh,v 1.9 2009/01/24 11:56:27 vnivanch Exp $
28// GEANT4 tag $Name: geant4-09-02-ref-02 $
29//
30// Hadronic Interaction abstract base class
31// This class is the base class for the model classes.
32// It sorts out the energy-range for the models and provides
33// class utilities.
34// original by H.P. Wellisch
35// Modified by J.L.Chuma, TRIUMF, 21-Mar-1997
36// Last modified: 3-Apr-1997
37// Added units to energy initialization: J.L. Chuma 04-Apr-97
38// Modified by J.L.Chuma, 05-May-97 to Initialize theBlockedCounter
39// Modified by J.L.Chuma, 08-Jul-97 to implement the Nucleus changes
40// Adding a registry for memory management of hadronic models, HPW 22-Mar-99
41// 23-Jan-2009 V.Ivanchenko move constructor and destructor to the body
42// and reorder methods in the header
43
44// Class Description
45// This is the base class for all hadronic interaction models in geant4.
46// If you want to implement a new way of producing a final state, please,
47// inherit from here.
48// Class Description - End
49
50#ifndef G4HadronicInteraction_h
51#define G4HadronicInteraction_h 1
52
53#include "G4HadFinalState.hh"
54#include "G4ReactionDynamics.hh"
55#include "G4Material.hh"
56#include "G4Nucleus.hh"
57#include "G4Track.hh"
58#include "G4HadProjectile.hh"
59
60class G4HadronicInteraction
61{
62public: // With description
63
64
65 G4HadronicInteraction(const G4String& modelName = "HadronicModel");
66
67 virtual ~G4HadronicInteraction();
68
69 virtual G4HadFinalState *ApplyYourself(const G4HadProjectile &aTrack,
70 G4Nucleus & targetNucleus ) = 0;
71 // This is the interface to implement for final state production code.
72
73 virtual G4bool IsApplicable(const G4HadProjectile &/*aTrack*/,
74 G4Nucleus & /*targetNucleus*/)
75 { return true;}
76
77 inline G4double GetMinEnergy() const
78 { return theMinEnergy; }
79
80 virtual G4double GetMinEnergy( const G4Material *aMaterial,
81 const G4Element *anElement ) const;
82
83 inline void SetMinEnergy( const G4double anEnergy )
84 { theMinEnergy = anEnergy; }
85
86 virtual void SetMinEnergy( G4double anEnergy, G4Element *anElement );
87
88 virtual void SetMinEnergy( G4double anEnergy, G4Material *aMaterial );
89
90 inline G4double GetMaxEnergy() const
91 { return theMaxEnergy; }
92
93 virtual G4double GetMaxEnergy( const G4Material *aMaterial,
94 const G4Element *anElement ) const;
95
96 inline void SetMaxEnergy( const G4double anEnergy )
97 { theMaxEnergy = anEnergy; }
98
99 virtual void SetMaxEnergy( G4double anEnergy, G4Element *anElement );
100
101 virtual void SetMaxEnergy( G4double anEnergy, G4Material *aMaterial );
102
103 inline const G4HadronicInteraction *GetMyPointer() const
104 { return this; }
105
106 inline G4int GetVerboseLevel() const
107 { return verboseLevel; }
108
109 inline void SetVerboseLevel( G4int value )
110 { verboseLevel = value; }
111
112 inline const G4String& GetModelName() const
113 { return theModelName; }
114
115public: // Without description
116
117 virtual void DeActivateFor( G4Material *aMaterial );
118
119 virtual void ActivateFor( G4Material *aMaterial )
120 {
121 Block();
122 SetMaxEnergy(GetMaxEnergy(), aMaterial);
123 SetMinEnergy(GetMinEnergy(), aMaterial);
124 }
125
126 virtual void DeActivateFor( G4Element *anElement );
127 virtual void ActivateFor( G4Element *anElement )
128 {
129 Block();
130 SetMaxEnergy(GetMaxEnergy(), anElement);
131 SetMinEnergy(GetMinEnergy(), anElement);
132 }
133
134 virtual G4bool IsBlocked( const G4Material *aMaterial ) const;
135
136 virtual G4bool IsBlocked( const G4Element *anElement) const;
137
138 inline G4bool operator==(const G4HadronicInteraction &right ) const
139 { return ( this == (G4HadronicInteraction *) &right ); }
140
141 inline G4bool operator!=(const G4HadronicInteraction &right ) const
142 { return ( this != (G4HadronicInteraction *) &right ); }
143
144private:
145
146 G4HadronicInteraction(const G4HadronicInteraction &right );
147
148 const G4HadronicInteraction& operator=(const G4HadronicInteraction &right);
149
150protected:
151
152 inline G4bool IsBlocked() const { return isBlocked;}
153 inline void Block() { isBlocked = true; }
154
155 G4HadFinalState theParticleChange;
156 // the G4HadFinalState object which is modified and returned
157 // by address by the ApplyYourself method,
158 // (instead of aParticleChange as found in G4VProcess)
159
160 G4int verboseLevel;
161 // control flag for output messages
162 // 0: silent
163 // 1: warning messages
164 // 2: more
165 // (instead of verboseLevel as found in G4VProcess)
166
167 G4ReactionDynamics theReactionDynamics;
168
169 // these two have global validity
170 // units are assumed to be MeV
171
172 G4double theMinEnergy;
173 G4double theMaxEnergy;
174
175 G4bool isBlocked;
176
177 G4String theModelName;
178
179private:
180
181 std::vector<std::pair<G4double, G4Material *> > theMinEnergyList;
182 std::vector<std::pair<G4double, G4Material *> > theMaxEnergyList;
183 std::vector<std::pair<G4double, G4Element *> > theMinEnergyListElements;
184 std::vector<std::pair<G4double, G4Element *> > theMaxEnergyListElements;
185 std::vector<G4Material *> theBlockedList;
186 std::vector<G4Element *> theBlockedListElements;
187};
188
189#endif
Note: See TracBrowser for help on using the repository browser.