Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2025-01-18 09:59:29

0001 //
0002 // ********************************************************************
0003 // * License and Disclaimer                                           *
0004 // *                                                                  *
0005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
0006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
0007 // * conditions of the Geant4 Software License,  included in the file *
0008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
0009 // * include a list of copyright holders.                             *
0010 // *                                                                  *
0011 // * Neither the authors of this software system, nor their employing *
0012 // * institutes,nor the agencies providing financial support for this *
0013 // * work  make  any representation or  warranty, express or implied, *
0014 // * regarding  this  software system or assume any liability for its *
0015 // * use.  Please see the license in the file  LICENSE  and URL above *
0016 // * for the full disclaimer and the limitation of liability.         *
0017 // *                                                                  *
0018 // * This  code  implementation is the result of  the  scientific and *
0019 // * technical work of the GEANT4 collaboration.                      *
0020 // * By using,  copying,  modifying or  distributing the software (or *
0021 // * any work based  on the software)  you  agree  to acknowledge its *
0022 // * use  in  resulting  scientific  publications,  and indicate your *
0023 // * acceptance of all terms of the Geant4 Software license.          *
0024 // ********************************************************************
0025 //
0026 
0027 #ifndef G4XNNTotalLowE_h
0028 #define G4XNNTotalLowE_h
0029 
0030 #include <map>
0031 #include <CLHEP/Units/SystemOfUnits.h>
0032 
0033 #include "globals.hh"
0034 #include "G4VCrossSectionSource.hh"
0035 #include "G4CrossSectionVector.hh"
0036 #include "G4LowEXsection.hh"
0037 
0038 class G4KineticTrack;
0039 
0040 class G4XNNTotalLowE : public G4VCrossSectionSource
0041 {
0042 
0043 public:
0044 
0045   G4XNNTotalLowE();
0046 
0047   virtual ~G4XNNTotalLowE();
0048 
0049   virtual G4double CrossSection(const G4KineticTrack& trk1, const G4KineticTrack& trk2) const;
0050   virtual const G4CrossSectionVector* GetComponents() const { return 0; }
0051   virtual G4bool IsValid(G4double e) const;
0052   
0053   virtual G4String Name() const;
0054   virtual G4double HighLimit() const { return 3.*CLHEP::GeV; }
0055 
0056 
0057 protected:
0058 
0059 
0060 private:  
0061 
0062   G4XNNTotalLowE(const G4XNNTotalLowE &right);
0063   const G4XNNTotalLowE& operator=(const G4XNNTotalLowE &right);
0064   
0065   static const G4double ppTot[29];
0066   static const G4double ss[29];
0067   static const G4double npTot[29];
0068   static const G4int tableSize;
0069 
0070   std::map <const G4ParticleDefinition *, G4LowEXsection *,
0071   std::less<const G4ParticleDefinition *> > theCrossSections;
0072   typedef std::map <const G4ParticleDefinition *, G4LowEXsection*, std::less<const G4ParticleDefinition *> > LowEMap;
0073 
0074 };
0075 
0076 #endif
0077 
0078 
0079 
0080 
0081 
0082 
0083 
0084 
0085 
0086 
0087 
0088 
0089 
0090 
0091 
0092 
0093 
0094 
0095 
0096 
0097 
0098 
0099 
0100 
0101 
0102 
0103 
0104 
0105 
0106 
0107 
0108 
0109 
0110 
0111 
0112 
0113 
0114 
0115 
0116 
0117 
0118 
0119