File indexing completed on 2025-10-26 08:45:02
0001 
0002 
0003 
0004 
0005 
0006 
0007 
0008 
0009 
0010 
0011 
0012 
0013 
0014 
0015 
0016 
0017 
0018 
0019 
0020 
0021 
0022 
0023 
0024 
0025 
0026 
0027 
0028 
0029 
0030 
0031 #ifndef G4StatMFMacroTemperature_h
0032 #define G4StatMFMacroTemperature_h 1
0033 
0034 #include "G4StatMFParameters.hh"
0035 #include "G4VStatMFMacroCluster.hh"
0036 #include "G4StatMFMacroChemicalPotential.hh"
0037 #include "G4Solver.hh"
0038 
0039 
0040 
0041 class G4StatMFMacroTemperature {
0042 
0043 public:
0044 
0045     G4StatMFMacroTemperature(const G4double anA, const G4double aZ, 
0046                  const G4double ExEnergy, const G4double FreeE0, 
0047                  const G4double kappa, 
0048                  std::vector<G4VStatMFMacroCluster*> * ClusterVector);
0049     
0050     ~G4StatMFMacroTemperature();
0051    
0052     G4double operator()(const G4double T)
0053     { return (_ExEnergy - this->FragsExcitEnergy(T))/_ExEnergy; }   
0054 
0055 private:
0056 
0057     
0058     G4StatMFMacroTemperature();
0059 
0060     
0061     G4StatMFMacroTemperature(const G4StatMFMacroTemperature &) {};
0062 
0063 
0064     
0065     G4StatMFMacroTemperature & operator=(const G4StatMFMacroTemperature & right);
0066     G4bool operator==(const G4StatMFMacroTemperature & right) const;
0067     G4bool operator!=(const G4StatMFMacroTemperature & right) const;
0068 
0069 public:
0070 
0071     inline G4double GetMeanMultiplicity(void) const {return _MeanMultiplicity;}
0072     
0073     inline G4double GetChemicalPotentialMu(void) const {return _ChemPotentialMu;}
0074 
0075     inline G4double GetChemicalPotentialNu(void) const {return _ChemPotentialNu;}
0076 
0077     inline G4double GetTemperature(void) const {return _MeanTemperature;}
0078 
0079     inline G4double GetEntropy(void) const {return _MeanEntropy;}
0080 
0081     G4double CalcTemperature(void);
0082 
0083 private:
0084     
0085     G4double FragsExcitEnergy(const G4double T);
0086 
0087     void CalcChemicalPotentialNu(const G4double T);
0088 
0089 private:
0090 
0091     G4double theA;
0092 
0093     G4double theZ;
0094 
0095     G4double _ExEnergy;
0096     
0097     G4double _FreeInternalE0;
0098 
0099     G4double _Kappa;
0100 
0101     G4double _MeanMultiplicity;
0102 
0103     G4double _MeanTemperature;
0104     
0105     G4double _ChemPotentialMu;
0106     
0107     G4double _ChemPotentialNu;
0108     
0109     G4double _MeanEntropy;
0110     
0111     std::vector<G4VStatMFMacroCluster*> * _theClusters; 
0112 
0113 
0114 };
0115 #endif