G4LivermoreIonisationCrossSection.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$
00027 //
00028 //
00029 // Author: Vladimir Ivanchenko
00030 //
00031 // History:
00032 // --------
00033 // 31 May 2011 V.Ivanchenko  The class is created  
00034 // 04 Jul 2011 L Pandola     Comment unused private member
00035 // 09 Mar 2012 L Pandola     Changed signature of methods
00036 // 
00037 // 
00038 // -------------------------------------------------------------------
00039 //
00040 // Class description:
00041 // Access to Livermore ionisation cross sections for e-
00042 // -------------------------------------------------------------------
00043 
00044 #ifndef G4LIVERMOREIONISATIONCROSSSECTION_HH
00045 #define G4LIVERMOREIONISATIONCROSSSECTION_HH 1
00046 
00047 #include "G4VhShellCrossSection.hh"
00048 #include "globals.hh"
00049 #include "G4AtomicShellEnumerator.hh"
00050 #include <vector>
00051 
00052 class G4AtomicTransitionManager;
00053 class G4VCrossSectionHandler;
00054 
00055 class G4LivermoreIonisationCrossSection : public G4VhShellCrossSection 
00056 {
00057 
00058 public:
00059   
00060   G4LivermoreIonisationCrossSection(const G4String& nam = "LivermorePIXE");
00061   
00062   virtual ~G4LivermoreIonisationCrossSection();
00063 
00064   void Initialise();
00065 
00066   G4double CrossSection(G4int Z, G4AtomicShellEnumerator shell,
00067                         G4double incidentEnergy,
00068                         G4double mass = 0.0,
00069                         const G4Material* mat = 0);
00070 
00071   std::vector<G4double> GetCrossSection(G4int Z,
00072                                         G4double incidentEnergy,
00073                                         G4double mass = 0.0,
00074                                         G4double deltaEnergy = 0.0,
00075                                         const G4Material* mat = 0);
00076 
00077   std::vector<G4double> Probabilities(G4int Z,
00078                                       G4double incidentEnergy,
00079                                       G4double mass = 0.0,
00080                                       G4double deltaEnergy = 0,
00081                                       const G4Material* mat = 0);
00082     
00083     
00084 private:
00085  
00086   G4LivermoreIonisationCrossSection & operator=(const G4LivermoreIonisationCrossSection &right);
00087   G4LivermoreIonisationCrossSection(const G4LivermoreIonisationCrossSection&);
00088 
00089   //Intrinsic energy limits of the model: cannot be extended by the parent process
00090   G4double fLowEnergyLimit;
00091   G4double fHighEnergyLimit;
00092  
00093   //G4bool isInitialised;
00094 
00095   G4int verboseLevel;
00096  
00097   G4VCrossSectionHandler* crossSectionHandler;
00098 
00099   const G4AtomicTransitionManager* transitionManager;
00100 
00101 };
00102 
00103 #endif
00104 

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