source: trunk/source/processes/electromagnetic/utils/include/G4VEmProcess.hh @ 1183

Last change on this file since 1183 was 1055, checked in by garnier, 15 years ago

maj sur la beta de geant 4.9.3

File size: 20.1 KB
RevLine 
[819]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//
[1055]26// $Id: G4VEmProcess.hh,v 1.51 2009/04/07 18:39:47 vnivanch Exp $
27// GEANT4 tag $Name: geant4-09-03-beta-cand-01 $
[819]28//
29// -------------------------------------------------------------------
30//
31// GEANT4 Class header file
32//
33//
34// File name:     G4VEmProcess
35//
36// Author:        Vladimir Ivanchenko
37//
38// Creation date: 01.10.2003
39//
40// Modifications:
41// 30-06-04 make destructor virtual (V.Ivanchenko)
42// 09-08-04 optimise integral option (V.Ivanchenko)
43// 11-08-04 add protected methods to access cuts (V.Ivanchenko)
44// 09-09-04 Bug fix for the integral mode with 2 peaks (V.Ivanchneko)
45// 16-09-04 Add flag for LambdaTable and method RecalculateLambda (VI)
46// 08-11-04 Migration to new interface of Store/Retrieve tables (V.Ivantchenko)
47// 08-04-05 Major optimisation of internal interfaces (V.Ivantchenko)
48// 18-04-05 Use G4ParticleChangeForGamma (V.Ivantchenko)
49// 09-05-05 Fix problem in logic when path boundary between materials (VI)
50// 11-01-06 add A to parameters of ComputeCrossSectionPerAtom (VI)
51// 01-02-06 put default value A=0. to keep compatibility with v5.2 (mma)
52// 13-05-06 Add method to access model by index (V.Ivanchenko)
53// 12-09-06 add SetModel() (mma)
54// 25-09-07 More accurate handling zero xsect in
55//          PostStepGetPhysicalInteractionLength (V.Ivanchenko)
56// 27-10-07 Virtual functions moved to source (V.Ivanchenko)
[961]57// 15-07-08 Reorder class members for further multi-thread development (VI)
[819]58//
59// Class Description:
60//
61// It is the unified Discrete process
62
63// -------------------------------------------------------------------
64//
65
66#ifndef G4VEmProcess_h
67#define G4VEmProcess_h 1
68
69#include "G4VDiscreteProcess.hh"
70#include "globals.hh"
71#include "G4Material.hh"
72#include "G4MaterialCutsCouple.hh"
73#include "G4Track.hh"
74#include "G4EmModelManager.hh"
75#include "G4UnitsTable.hh"
76#include "G4ParticleDefinition.hh"
77#include "G4ParticleChangeForGamma.hh"
78
79class G4Step;
80class G4VEmModel;
81class G4DataVector;
82class G4VParticleChange;
83class G4PhysicsTable;
84class G4PhysicsVector;
85
86//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
87
88class G4VEmProcess : public G4VDiscreteProcess
89{
90public:
91
92  G4VEmProcess(const G4String& name,
[961]93               G4ProcessType type = fElectromagnetic);
[819]94
95  virtual ~G4VEmProcess();
96
97  //------------------------------------------------------------------------
98  // Virtual methods to be implemented in concrete processes
99  //------------------------------------------------------------------------
100
101  virtual G4bool IsApplicable(const G4ParticleDefinition& p) = 0;
102
103  virtual void PrintInfo() = 0;
104
105protected:
106
107  virtual void InitialiseProcess(const G4ParticleDefinition*) = 0;
108
109  //------------------------------------------------------------------------
[1055]110  // Implementation of virtual methods common to all Discrete processes
[819]111  //------------------------------------------------------------------------
112
[961]113public:
[819]114
[961]115  // Initialise for build of tables
116  void PreparePhysicsTable(const G4ParticleDefinition&);
[819]117
[961]118  // Build physics table during initialisation
119  void BuildPhysicsTable(const G4ParticleDefinition&);
[819]120
[1055]121  void PrintInfoDefinition();
122
123  // implementation of virtual method, specific for G4VEmProcess
124  G4double PostStepGetPhysicalInteractionLength(
125                             const G4Track& track,
126                             G4double   previousStepSize,
127                             G4ForceCondition* condition
128                            );
129
130  // implementation of virtual method, specific for G4VEmProcess
131  G4VParticleChange* PostStepDoIt(const G4Track&, const G4Step&);
132
[961]133  // Store PhysicsTable in a file.
134  // Return false in case of failure at I/O
[819]135  G4bool StorePhysicsTable(const G4ParticleDefinition*,
136                           const G4String& directory,
137                           G4bool ascii = false);
138
[961]139  // Retrieve Physics from a file.
140  // (return true if the Physics Table can be build by using file)
141  // (return false if the process has no functionality or in case of failure)
142  // File name should is constructed as processName+particleName and the
143  // should be placed under the directory specifed by the argument.
[819]144  G4bool RetrievePhysicsTable(const G4ParticleDefinition*,
145                              const G4String& directory,
146                              G4bool ascii);
147
[1055]148  // deexcitation activated per G4Region
149  void ActivateDeexcitation(G4bool, const G4Region* r = 0);
150
[819]151  //------------------------------------------------------------------------
152  // Specific methods for Discrete EM post step simulation
153  //------------------------------------------------------------------------
154
[961]155  // It returns the cross section per volume for energy/ material
156  G4double CrossSectionPerVolume(G4double kineticEnergy,
157                                 const G4MaterialCutsCouple* couple);
[819]158
[961]159  // It returns the cross section of the process per atom
[819]160  inline G4double ComputeCrossSectionPerAtom(G4double kineticEnergy, 
161                                             G4double Z, G4double A=0., 
162                                             G4double cut=0.0);
163
164  inline G4double MeanFreePath(const G4Track& track);
165
[961]166  // It returns cross section per volume
[819]167  inline G4double GetLambda(G4double& kinEnergy, 
168                            const G4MaterialCutsCouple* couple);
169
170  //------------------------------------------------------------------------
171  // Specific methods to build and access Physics Tables
172  //------------------------------------------------------------------------
173
[961]174  // Binning for lambda table
[819]175  inline void SetLambdaBinning(G4int nbins);
176  inline G4int LambdaBinning() const;
177
[961]178  // Min kinetic energy for tables
[819]179  inline void SetMinKinEnergy(G4double e);
180  inline G4double MinKinEnergy() const;
181
[961]182  // Max kinetic energy for tables
[819]183  inline void SetMaxKinEnergy(G4double e);
184  inline G4double MaxKinEnergy() const;
185
[961]186  inline void SetPolarAngleLimit(G4double a);
187  inline G4double PolarAngleLimit() const;
188
[819]189  inline const G4PhysicsTable* LambdaTable() const;
190
191  //------------------------------------------------------------------------
192  // Define and access particle type
193  //------------------------------------------------------------------------
194
195  inline const G4ParticleDefinition* Particle() const;
196  inline const G4ParticleDefinition* SecondaryParticle() const;
197
198  //------------------------------------------------------------------------
[1055]199  // Specific methods to set, access, modify models and basic parameters
[819]200  //------------------------------------------------------------------------
201
[1055]202protected:
203  // Select model in run time
204  inline void SelectModel(G4double& kinEnergy);
205
206public:
207  // Select model by energy and region index
208  inline G4VEmModel* SelectModelForMaterial(G4double kinEnergy, 
209                                            size_t& idxRegion) const;
[1005]210   
[1055]211  // Add model for region, smaller value of order defines which
212  // model will be selected for a given energy interval 
213  void AddEmModel(G4int, G4VEmModel*, const G4Region* region = 0);
214
[819]215  // Assign a model to a process
[1055]216  void SetModel(G4VEmModel*, G4int index = 1);
[819]217 
218  // return the assigned model
[1055]219  G4VEmModel* Model(G4int index = 1);
[819]220   
[961]221  // Define new energy range for the model identified by the name
[1055]222  void UpdateEmModel(const G4String&, G4double, G4double);
[819]223
224  // Access to models
[1055]225  G4VEmModel* GetModelByIndex(G4int idx = 0, G4bool ver = false);
[819]226
227  inline void SetLambdaFactor(G4double val);
228
229  inline void SetIntegral(G4bool val);
230  inline G4bool IsIntegral() const;
231
232  inline void SetApplyCuts(G4bool val);
[1055]233
234  //------------------------------------------------------------------------
235  // Other generic methods
236  //------------------------------------------------------------------------
[819]237 
238protected:
239
240  G4double GetMeanFreePath(const G4Track& track,
241                           G4double previousStepSize,
242                           G4ForceCondition* condition);
243
244  G4PhysicsVector* LambdaPhysicsVector(const G4MaterialCutsCouple*);
245
[1055]246  inline G4double RecalculateLambda(G4double kinEnergy,
247                                    const G4MaterialCutsCouple* couple);
248
[961]249  inline G4ParticleChangeForGamma* GetParticleChange();
250
[819]251  inline void SetParticle(const G4ParticleDefinition* p);
252 
253  inline void SetSecondaryParticle(const G4ParticleDefinition* p);
254
255  inline size_t CurrentMaterialCutsCoupleIndex() const;
256
257  inline G4double GetGammaEnergyCut();
258
259  inline G4double GetElectronEnergyCut();
260
261  inline void SetBuildTableFlag(G4bool val);
262
263  inline void SetStartFromNullFlag(G4bool val);
264
265private:
266
267  void Clear();
268
269  void BuildLambdaTable();
270
271  void FindLambdaMax();
272
273  inline void InitialiseStep(const G4Track&);
274
275  inline void DefineMaterial(const G4MaterialCutsCouple* couple);
276
277  inline void ComputeIntegralLambda(G4double kinEnergy);
278
279  inline G4double GetLambdaFromTable(G4double kinEnergy);
280
281  inline G4double GetCurrentLambda(G4double kinEnergy);
282
283  inline G4double ComputeCurrentLambda(G4double kinEnergy);
284
[1055]285  // copy constructor and hide assignment operator
[819]286  G4VEmProcess(G4VEmProcess &);
287  G4VEmProcess & operator=(const G4VEmProcess &right);
288
[961]289  // ======== Parameters of the class fixed at construction =========
[819]290
[961]291  G4EmModelManager*            modelManager;
292  const G4ParticleDefinition*  theGamma;
293  const G4ParticleDefinition*  theElectron;
294  const G4ParticleDefinition*  thePositron;
295  const G4ParticleDefinition*  secondaryParticle;
[819]296
[961]297  G4bool                       buildLambdaTable;
[819]298
[961]299  // ======== Parameters of the class fixed at initialisation =======
[819]300
[1055]301  std::vector<G4VEmModel*>     emModels;
302
[819]303  // tables and vectors
304  G4PhysicsTable*              theLambdaTable;
305  G4double*                    theEnergyOfCrossSectionMax;
306  G4double*                    theCrossSectionMax;
307
308  const std::vector<G4double>* theCuts;
309  const std::vector<G4double>* theCutsGamma;
310  const std::vector<G4double>* theCutsElectron;
311  const std::vector<G4double>* theCutsPositron;
312
313  G4int                        nLambdaBins;
314
315  G4double                     minKinEnergy;
316  G4double                     maxKinEnergy;
317  G4double                     lambdaFactor;
[961]318  G4double                     polarAngleLimit;
[819]319
[961]320  G4bool                       integral;
321  G4bool                       applyCuts;
322  G4bool                       startFromNull;
[1055]323  G4bool                       useDeexcitation;
[961]324
[1055]325  G4int                        nDERegions;
326  std::vector<const G4Region*> deRegions;
327  G4bool*                      idxDERegions;
[961]328
329  // ======== Cashed values - may be state dependent ================
330
331protected:
332
333  G4ParticleChangeForGamma     fParticleChange;
334
335private:
336
337  std::vector<G4DynamicParticle*> secParticles;
338
[1055]339  G4VEmModel*                  currentModel; 
[961]340
341  const G4ParticleDefinition*  particle;
342
[819]343  // cash
344  const G4Material*            currentMaterial;
345  const G4MaterialCutsCouple*  currentCouple;
346  size_t                       currentMaterialIndex;
347
348  G4double                     mfpKinEnergy;
349  G4double                     preStepKinEnergy;
350  G4double                     preStepLambda;
351
352};
353
354//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
355//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
356
[1055]357inline G4double G4VEmProcess::ComputeCrossSectionPerAtom(
358                 G4double kineticEnergy, G4double Z, G4double A, G4double cut)
[819]359{
[1055]360  SelectModel(kineticEnergy);
361  G4double x = 0.0;
362  if(currentModel) {
363   x = currentModel->ComputeCrossSectionPerAtom(particle,kineticEnergy,
364                                                 Z,A,cut);
[819]365  }
[1055]366  return x;
[819]367}
368
369//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
370
[1055]371inline G4double G4VEmProcess::MeanFreePath(const G4Track& track)
[819]372{
373  DefineMaterial(track.GetMaterialCutsCouple());
[1055]374  preStepLambda = GetCurrentLambda(track.GetKineticEnergy());
375  G4double x = DBL_MAX;
376  if(DBL_MIN < preStepLambda) x = 1.0/preStepLambda;
377  return x;
[819]378}
379
380//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
381
382inline G4double G4VEmProcess::GetLambda(G4double& kineticEnergy,
[961]383                                        const G4MaterialCutsCouple* couple)
[819]384{
385  DefineMaterial(couple);
386  return GetCurrentLambda(kineticEnergy);
387}
388
389//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
390
[1055]391inline void G4VEmProcess::SetLambdaBinning(G4int nbins)
[819]392{
[1055]393  nLambdaBins = nbins;
[819]394}
395
396//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
397
[1055]398inline G4int G4VEmProcess::LambdaBinning() const
[819]399{
[1055]400  return nLambdaBins;
[819]401}
402
403//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
404
[1055]405inline void G4VEmProcess::SetMinKinEnergy(G4double e)
[819]406{
[1055]407  minKinEnergy = e;
[819]408}
409
410//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
411
[1055]412inline G4double G4VEmProcess::MinKinEnergy() const
[819]413{
[1055]414  return minKinEnergy;
[819]415}
416
417//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
418
[1055]419inline void G4VEmProcess::SetMaxKinEnergy(G4double e)
[819]420{
[1055]421  maxKinEnergy = e;
422}
[819]423
[1055]424//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
425
426inline G4double G4VEmProcess::MaxKinEnergy() const
427{
428  return maxKinEnergy;
[819]429}
430
431//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
432
[1055]433inline void G4VEmProcess::SetPolarAngleLimit(G4double val)
[819]434{
[1055]435  if(val < 0.0)     polarAngleLimit = 0.0;
436  else if(val > pi) polarAngleLimit = pi;
437  else              polarAngleLimit = val;
[819]438}
439
440//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
441
[1055]442inline G4double G4VEmProcess::PolarAngleLimit() const
[819]443{
[1055]444  return polarAngleLimit;
[819]445}
446
447//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
448
[1055]449inline const G4PhysicsTable* G4VEmProcess::LambdaTable() const
[819]450{
[1055]451  return theLambdaTable;
[819]452}
453
454//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
455
456inline const G4ParticleDefinition* G4VEmProcess::Particle() const
457{
458  return particle;
459}
460
461//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
462
463inline const G4ParticleDefinition* G4VEmProcess::SecondaryParticle() const
464{
465  return secondaryParticle;
466}
467
468//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
469
[1055]470inline void G4VEmProcess::SelectModel(G4double& kinEnergy)
[819]471{
[1055]472  currentModel = modelManager->SelectModel(kinEnergy, currentMaterialIndex);
473  currentModel->SetCurrentCouple(currentCouple);
[819]474}
475
476//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
477
[1055]478inline G4VEmModel* G4VEmProcess::SelectModelForMaterial(
479                                   G4double kinEnergy, size_t& idxRegion) const
[819]480{
[1055]481  return modelManager->SelectModel(kinEnergy, idxRegion);
[819]482}
483
484//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
485
[1007]486inline void G4VEmProcess::SetLambdaFactor(G4double val)
[819]487{
[1007]488  if(val > 0.0 && val <= 1.0) lambdaFactor = val;
[819]489}
490
491//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
492
[1055]493inline void G4VEmProcess::SetIntegral(G4bool val)
[819]494{
[1055]495  if(particle && particle != theGamma) integral = val;
496  if(integral) buildLambdaTable = true;
[819]497}
498
499//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
500
[1055]501inline G4bool G4VEmProcess::IsIntegral() const
[819]502{
[1055]503  return integral;
[819]504}
505
506//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
507
[1055]508inline void G4VEmProcess::SetApplyCuts(G4bool val)
[819]509{
[1055]510  applyCuts = val;
[819]511}
512
513//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
514
[1055]515inline G4double G4VEmProcess::RecalculateLambda(G4double e, 
516                                                const G4MaterialCutsCouple* couple)
[819]517{
[1055]518  DefineMaterial(couple);
519  return ComputeCurrentLambda(e);
[819]520}
521
522//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
523
[1055]524inline G4ParticleChangeForGamma* G4VEmProcess::GetParticleChange()
[819]525{
[1055]526  return &fParticleChange;
[819]527}
528
529//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
530
[1055]531inline void G4VEmProcess::SetParticle(const G4ParticleDefinition* p)
[819]532{
[1055]533  particle = p;
[819]534}
535
536//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
537
[1055]538inline void G4VEmProcess::SetSecondaryParticle(const G4ParticleDefinition* p)
[819]539{
[1055]540  secondaryParticle = p;
[819]541}
542
543//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
544
[1055]545inline size_t G4VEmProcess::CurrentMaterialCutsCoupleIndex() const 
[819]546{
[1055]547  return currentMaterialIndex;
[819]548}
549
550//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
551
[1055]552inline G4double G4VEmProcess::GetGammaEnergyCut()
[819]553{
[1055]554  return (*theCutsGamma)[currentMaterialIndex];
[819]555}
556
557//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
558
[1055]559inline G4double G4VEmProcess::GetElectronEnergyCut()
[819]560{
[1055]561  return (*theCutsElectron)[currentMaterialIndex];
[819]562}
563
564//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
565
[1055]566inline void G4VEmProcess::SetBuildTableFlag(G4bool val)
[819]567{
[1055]568  buildLambdaTable = val;
569  if(!val) integral = false;
[819]570}
571
572//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
573
[1055]574inline void G4VEmProcess::SetStartFromNullFlag(G4bool val)
[819]575{
[1055]576  startFromNull = val;
[819]577}
578
579//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
580
[1055]581inline void G4VEmProcess::InitialiseStep(const G4Track& track)
[819]582{
[1055]583  preStepKinEnergy = track.GetKineticEnergy();
584  DefineMaterial(track.GetMaterialCutsCouple());
585  if (theNumberOfInteractionLengthLeft < 0.0) mfpKinEnergy = DBL_MAX;
[819]586}
587
588//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
589
[1055]590inline void G4VEmProcess::DefineMaterial(const G4MaterialCutsCouple* couple)
[819]591{
[1055]592  if(couple != currentCouple) {
593    currentCouple   = couple;
594    currentMaterial = couple->GetMaterial();
595    currentMaterialIndex = couple->GetIndex();
596    mfpKinEnergy = DBL_MAX;
597  }
[819]598}
599
600//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
601
[1055]602inline void G4VEmProcess::ComputeIntegralLambda(G4double e)
[961]603{
[1055]604  mfpKinEnergy  = theEnergyOfCrossSectionMax[currentMaterialIndex];
605  if (e <= mfpKinEnergy) {
606    preStepLambda = GetLambdaFromTable(e);
[819]607
[1055]608  } else {
609    G4double e1 = e*lambdaFactor;
610    if(e1 > mfpKinEnergy) {
611      preStepLambda  = GetLambdaFromTable(e);
612      G4double preStepLambda1 = GetLambdaFromTable(e1);
613      if(preStepLambda1 > preStepLambda) {
614        mfpKinEnergy = e1;
615        preStepLambda = preStepLambda1;
616      }
617    } else {
618      preStepLambda = theCrossSectionMax[currentMaterialIndex];
619    }
620  }
[819]621}
622
623//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
624
[1055]625inline G4double G4VEmProcess::GetLambdaFromTable(G4double e)
[819]626{
[1055]627  G4bool b;
628  return (((*theLambdaTable)[currentMaterialIndex])->GetValue(e, b));
[819]629}
630
631//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
632
[1055]633inline G4double G4VEmProcess::GetCurrentLambda(G4double e)
[819]634{
[1055]635  G4double x = 0.0;
636  if(theLambdaTable) x = GetLambdaFromTable(e);
637  else               x = ComputeCurrentLambda(e);
638  return x;
[819]639}
640
641//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
642
[1055]643inline G4double G4VEmProcess::ComputeCurrentLambda(G4double e)
[819]644{
[1055]645  SelectModel(e);
646  G4double x = 0.0;
647  if(currentModel) {
648    x = currentModel->CrossSectionPerVolume(currentMaterial,particle,
649                                            e,(*theCuts)[currentMaterialIndex]);
650  }
651  return x;
[819]652}
653
654//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
655
656#endif
Note: See TracBrowser for help on using the repository browser.