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 // G4QMDMeanField 27 // 28 // Author: Tatsumi Koi (SLAC), 29 March 2007 29 // -------------------------------------------------------------------- 30 #ifndef G4QMDMeanField_hh 31 #define G4QMDMeanField_hh 32 33 #include "G4QMDSystem.hh" 34 #include "G4QMDNucleus.hh" 35 36 class G4QMDMeanField 37 { 38 public: 39 40 G4QMDMeanField(); 41 ~G4QMDMeanField() = default; 42 43 void SetSystem ( G4QMDSystem* aSystem ); 44 void SetNucleus ( G4QMDNucleus* aSystem ); 45 inline G4QMDSystem* GetSystem () { return system; } 46 47 void Cal2BodyQuantities(); 48 void Cal2BodyQuantities( G4int ); 49 50 void CalGraduate(); 51 52 G4bool IsPauliBlocked( G4int ); 53 54 G4double GetTotalPotential(); 55 G4double GetPotential( G4int ); 56 57 void DoPropagation( G4double ); 58 59 std::vector< G4QMDNucleus* > DoClusterJudgment(); 60 61 inline G4double GetRR2( G4int i , G4int j ) { return rr2[i][j]; } 62 63 inline G4double GetRHA( G4int i , G4int j ) { return rha[i][j]; } 64 inline G4double GetRHE( G4int i , G4int j ) { return rhe[i][j]; } 65 inline G4ThreeVector GetFFr( G4int i ) { return ffr[i]; } 66 inline G4ThreeVector GetFFp( G4int i ) { return ffp[i]; } 67 68 std::vector< G4double > GetLocalDensity(); 69 std::vector< G4double > GetDepthOfPotential(); 70 71 void Update(); 72 73 private: 74 75 G4double calPauliBlockingFactor( G4int ); 76 77 private: 78 79 G4QMDSystem* system; 80 81 G4double rclds { 4.0 }; // distance for cluster judgement 82 83 G4double hbc , rho0; 84 G4double epsx { -20.0 }; // gauss term 85 G4double epscl { 0.0001 }; // coulomb term 86 87 G4double cpc; 88 89 //G4int icoul, irelcr; 90 G4int irelcr { 1 }; 91 G4double gamm, c0, c3, cs, cl, wl; 92 //G4double c0w, c3w, clw, c0sw; 93 G4double c0w, clw, c0sw; 94 95 G4double c0g,c3g,csg,pag; 96 97 G4double cpw,cph; 98 99 // 2 Body Quantities 100 std::vector < std::vector < G4double > > rr2; 101 std::vector < std::vector < G4double > > pp2; 102 std::vector < std::vector < G4double > > rbij; 103 104 // Gauss 105 std::vector < std::vector < G4double > > rha; 106 107 // Coulomb 108 std::vector < std::vector < G4double > > rhe; 109 std::vector < std::vector < G4double > > rhc; 110 111 std::vector < G4ThreeVector > ffr; 112 std::vector < G4ThreeVector > ffp; 113 std::vector < G4double > rh3d; 114 }; 115 116 #endif 117