58 : Zmin(zmin - 1), Zmax(zmax), fSubName(subname)
62 fData = reg->GetElementDataByName(name);
63 if (
nullptr == fData) {
66 reg->RegisterMe(fData);
74 G4int Z = std::min(ZZ, Zmax);
75 auto v = fData->GetElementData(Z);
78 v = fData->GetElementData(Z);
81 std::ostringstream ost;
82 ost << fParameters->GetDirLEDATA() << fSubName << Z <<
".dat";
83 std::ifstream fin(ost.str().c_str());
86 ed <<
"G4EmElementXS: data file <" << ost.str().c_str() <<
"> for Z=" << Z
87 <<
" is not opened!" <<
G4endl;
89 "G4LEDATA version should be checked");
91 v->Retrieve(fin,
true);
92 v->ScaleVector(CLHEP::MeV, CLHEP::barn);
94 fData->InitialiseForElement(Z, v);
106 return (
nullptr != v) ? v->Value(ekin) : 0.0;
G4TemplateAutoLock< G4Mutex > G4AutoLock
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
#define G4MUTEX_INITIALIZER
static G4ElementDataRegistry * Instance()
G4EmElementXS(G4int zmin, G4int zmax, const G4String &name, const G4String &subname)
G4double GetXS(G4int Z, G4double ekin) const
G4PhysicsVector * Retrieve(G4int Z) const
static G4EmParameters * Instance()