Geant4 Cross Reference |
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 //--------------------------------------------------------------- 30 // GEANT 4 class header file 31 // 32 // GVFlashShowerParameterisation 33 // 34 // Class description: 35 // 36 // Base class for GFlash shower parameterisation. 37 38 // Author: Joanna Weng - 11.2005 39 //--------------------------------------------------------------- 40 #ifndef GVFlashShowerParameterisation_h 41 #define GVFlashShowerParameterisation_h 1 42 43 #include "globals.hh" 44 #include "GVFlashHomoShowerTuning.hh" 45 46 class MyGamma; 47 class G4Material; 48 49 class GVFlashShowerParameterisation 50 { 51 public: // with description 52 GVFlashShowerParameterisation(); 53 virtual ~GVFlashShowerParameterisation(); 54 55 virtual void ComputeRadialParameters(G4double y, G4double Tau) = 0; 56 virtual void GenerateLongitudinalProfile(G4double Energy) = 0; 57 virtual G4double IntegrateEneLongitudinal(G4double LongitudinalStep) = 0; 58 virtual G4double IntegrateNspLongitudinal(G4double LongitudinalStep) = 0; 59 virtual G4double ComputeTau(G4double LongitudinalPosition) = 0; 60 virtual G4double GenerateRadius(G4int ispot, G4double Energy, 61 G4double LongitudinalPosition) = 0; 62 virtual void ComputeLongitudinalParameters(G4double y) = 0; 63 virtual void GenerateEnergyProfile(G4double y) = 0; 64 virtual void GenerateNSpotProfile(G4double y) = 0; 65 virtual G4double GenerateExponential(G4double Energy) = 0; 66 67 virtual G4double GetAveR99() = 0; 68 virtual G4double GetAveR90() = 0; 69 70 virtual G4double GetAveTmx() = 0; 71 virtual G4double GetAveT99() = 0; 72 virtual G4double GetAveT90() = 0; 73 74 virtual G4double GetNspot() = 0; 75 virtual G4double GetX0() = 0; 76 virtual G4double GetEc() = 0; 77 virtual G4double GetRm() = 0; 78 79 G4double GeneratePhi(); 80 G4double GetEffZ(const G4Material* material); 81 G4double GetEffA(const G4Material* material); 82 G4double gam(G4double x, G4double a) const; // @@@@ gamma function 83 void PrintMaterial(const G4Material* mat); 84 85 protected: 86 GVFlashHomoShowerTuning* thePar; 87 // Parameterisation parameters 88 G4double density, A, Z, X0, Ec, Rm; 89 // Medium related quantities 90 G4double NSpot; 91 92 private: 93 MyGamma* fGamma; 94 }; 95 96 #endif 97