File indexing completed on 2025-01-18 09:58:05
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
0032
0033
0034
0035
0036
0037
0038
0039
0040
0041
0042
0043 #ifndef G4DATASET_HH
0044 #define G4DATASET_HH 1
0045
0046 #include <CLHEP/Units/SystemOfUnits.h>
0047
0048 #include "globals.hh"
0049 #include "G4IDataSet.hh"
0050
0051 class G4IInterpolator;
0052
0053 class G4DataSet : public G4IDataSet
0054 {
0055 public:
0056 G4DataSet(G4int argZ,
0057 G4IInterpolator* algo,
0058 G4double xUnit=CLHEP::MeV,
0059 G4double yUnit=CLHEP::barn,
0060 G4bool random=false);
0061
0062 G4DataSet(G4int argZ,
0063 G4DataVector* xData,
0064 G4DataVector* data,
0065 G4IInterpolator* algo,
0066 G4double xUnit=CLHEP::MeV,
0067 G4double yUnit=CLHEP::barn,
0068 G4bool random=false);
0069
0070 virtual ~G4DataSet();
0071
0072 virtual G4double FindValue(G4double x, G4int componentId=0) const;
0073
0074 virtual void PrintData(void) const;
0075
0076 virtual const G4IDataSet* GetComponent(G4int ) const { return 0; }
0077
0078 virtual void AddComponent(G4IDataSet* ) {}
0079
0080 virtual size_t NumberOfComponents(void) const { return 0; }
0081
0082 virtual const G4DataVector& GetEnergies(G4int ) const { return *energies; }
0083 virtual const G4DataVector& GetData(G4int ) const { return *data; }
0084 virtual void SetEnergiesData(G4DataVector* xData, G4DataVector* data, G4int componentId);
0085
0086 virtual G4bool LoadData(const G4String& fileName);
0087 virtual G4bool SaveData(const G4String& fileName) const;
0088
0089 virtual G4double RandomSelect(G4int componentId = 0) const;
0090
0091
0092 private:
0093
0094 size_t FindLowerBound(G4double energy) const;
0095 size_t FindLowerBound(G4double x, G4DataVector* values) const;
0096
0097 G4double IntegrationFunction(G4double x);
0098
0099 virtual void BuildPdf();
0100
0101 G4String FullFileName(const G4String& fileName) const;
0102
0103
0104 G4DataSet();
0105 G4DataSet(const G4DataSet& copy);
0106 G4DataSet& operator=(const G4DataSet& right);
0107
0108 G4int z;
0109
0110 G4DataVector* energies;
0111 G4DataVector* data;
0112
0113 G4IInterpolator* algorithm;
0114
0115 G4double unitEnergies;
0116 G4double unitData;
0117
0118 G4DataVector* pdf;
0119 G4bool randomSet;
0120 };
0121 #endif