Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4LEPTSElossDistr Class Reference

#include <G4LEPTSElossDistr.hh>

Public Member Functions

 G4LEPTSElossDistr (const G4String &)
 
void ReadFile ()
 
G4double Sample (G4double, G4double)
 
G4bool IsFileFound () const
 

Detailed Description

Definition at line 40 of file G4LEPTSElossDistr.hh.

Constructor & Destructor Documentation

◆ G4LEPTSElossDistr()

G4LEPTSElossDistr::G4LEPTSElossDistr ( const G4String & fname)

Definition at line 37 of file G4LEPTSElossDistr.cc.

38{
39 fileName = fname;
40 ReadFile();
41}

Member Function Documentation

◆ IsFileFound()

G4bool G4LEPTSElossDistr::IsFileFound ( ) const
inline

Definition at line 48 of file G4LEPTSElossDistr.hh.

48{ return bFileFound; }

◆ ReadFile()

void G4LEPTSElossDistr::ReadFile ( )

Definition at line 43 of file G4LEPTSElossDistr.cc.

44{
45 theNDistributions = 0;
46
47 FILE * fp;
48
49 if ((fp=fopen(fileName.c_str(), "r"))==nullptr)
50 {
51 NoBins = 0;
52 bFileFound = false;
53 return;
54 }
55
56 bFileFound = true;
57
58 G4int nEnergies;
59 G4int nAngles;
60 G4int nData;
61 (void) fscanf(fp,"%i \n",&nEnergies);
62 for( G4int ie = 0; ie < nEnergies; ++ie )
63 {
64 G4float energySep;
65 (void) fscanf(fp,"%f \n",&energySep);
66 (void) fscanf(fp,"%i \n",&nAngles);
67 for( G4int ia = 0; ia < nAngles; ++ia )
68 {
69 G4float angleSep;
70 (void) fscanf(fp,"%f \n",&angleSep);
71 auto dist = new G4LEPTSDistribution();
72 ++theNDistributions;
73 std::map<G4double, G4LEPTSDistribution *> angleDist;
74 angleDist[angleSep] = dist;
75 theDistributions[energySep] = std::move(angleDist);
76
77 (void) fscanf(fp,"%i \n",&nData);
78 if( dist->ReadFile( fp, nData ) )
79 {
80 std::ostringstream message;
81 message << "End of file found while reading file: "
82 << fileName;
83 G4Exception("G4LEPTSElossDistr::ReadFile()", "ReadError",
84 FatalException, message);
85 }
86 }
87 }
88
89 fclose(fp);
90}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
float G4float
Definition G4Types.hh:84
int G4int
Definition G4Types.hh:85

Referenced by G4LEPTSElossDistr().

◆ Sample()

G4double G4LEPTSElossDistr::Sample ( G4double eMin,
G4double eMax )

Definition at line 92 of file G4LEPTSElossDistr.cc.

93{
94 // Sample Energy from Cumulative distr. G4interval [eMin, eMax]
95
96 if( eMin > eMax) return 0.0;
97
98 // Get the distribution to do the sampling
99 G4LEPTSDistribution* distr = nullptr;
100 if( theNDistributions == 1 )
101 {
102 distr = (*( (*(theDistributions.cbegin())).second ).cbegin()).second;
103 }
104 else
105 {
106 for( auto itedd = theDistributions.cbegin(); itedd != theDistributions.cend(); ++itedd ){
107 G4double energySep = (*itedd).first;
108 if( eMax < energySep )
109 {
110 const auto& dist1 = (*itedd).second;
111 for( auto ited = dist1.cbegin(); ited != dist1.cend(); ++ited )
112 {
113 G4double angleSep = (*ited).first;
114 if( 1 < angleSep )
115 {
116 distr = (*ited).second;
117 break;
118 }
119 }
120 break;
121 }
122 }
123 }
124
125 return (nullptr != distr) ? distr->Sample(eMin, eMax) : 0.0;
126}
double G4double
Definition G4Types.hh:83
G4double Sample(G4double, G4double)

The documentation for this class was generated from the following files: