Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4VEmFluctuationModel.hh
Go to the documentation of this file.
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// -------------------------------------------------------------------
28//
29// GEANT4 Class header file
30//
31//
32// File name: G4VEmFluctuationModel
33//
34// Author: Vladimir Ivanchenko
35//
36// Creation date: 03.01.2002
37//
38// Modifications:
39//
40// 28-12-02 add method Dispersion (V.Ivanchenko)
41// 07-02-03 change signature (V.Ivanchenko)
42// 13-02-03 Add name (V.Ivanchenko)
43// 16-10-03 Changed interface to Initialisation (V.Ivanchenko)
44// 08-04-05 Major optimisation of internal interfaces (V.Ivantchenko)
45// 25-07-05 Move constructor and destructor to the body (V.Ivanchenko)
46//
47//
48// Class Description:
49//
50// Abstract class for interface to simualtion of energy loss fluctuations
51
52// -------------------------------------------------------------------
53//
54
55#ifndef G4VEmFluctuationModel_h
56#define G4VEmFluctuationModel_h 1
57
58#include "globals.hh"
60
63class G4Material;
66
68{
69
70public:
71
72 explicit G4VEmFluctuationModel(const G4String& nam);
73
74 virtual ~G4VEmFluctuationModel();
75
76 //------------------------------------------------------------------------
77 // Virtual methods to be implemented for the concrete model
78 //------------------------------------------------------------------------
79
81 const G4DynamicParticle*,
82 const G4double tcut,
83 const G4double tmax,
84 const G4double length,
85 const G4double meanLoss) = 0;
86
88 const G4DynamicParticle*,
89 const G4double tcut,
90 const G4double tmax,
91 const G4double length) = 0;
92
93 //------------------------------------------------------------------------
94 // Methods with standard implementation; may be overwritten if needed
95 //------------------------------------------------------------------------
96
97 virtual void InitialiseMe(const G4ParticleDefinition*);
98
99 virtual void SetParticleAndCharge(const G4ParticleDefinition*, G4double q2);
100
101 //------------------------------------------------------------------------
102 // Generic methods common to all models
103 //------------------------------------------------------------------------
104
105 inline const G4String& GetName() const;
106
107 // hide assignment operator
109 operator=(const G4VEmFluctuationModel &right) = delete;
111
112private:
113
114 const G4String name;
115 G4LossTableManager* fManager;
116};
117
118//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
119//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
120
122{
123 return name;
124}
125
126#endif
127
double G4double
Definition: G4Types.hh:83
virtual G4double Dispersion(const G4Material *, const G4DynamicParticle *, const G4double tcut, const G4double tmax, const G4double length)=0
virtual void SetParticleAndCharge(const G4ParticleDefinition *, G4double q2)
const G4String & GetName() const
G4VEmFluctuationModel(const G4VEmFluctuationModel &)=delete
G4VEmFluctuationModel & operator=(const G4VEmFluctuationModel &right)=delete
virtual G4double SampleFluctuations(const G4MaterialCutsCouple *, const G4DynamicParticle *, const G4double tcut, const G4double tmax, const G4double length, const G4double meanLoss)=0
virtual void InitialiseMe(const G4ParticleDefinition *)