53 for (
auto& pos : idMap)
59 for (
auto& pos : energyMap)
65 for (
auto& pos: probabilityMap)
76 return numberOfVacancies;
84 if (vacancyIndex<0 || vacancyIndex>=numberOfVacancies)
87 "vacancyIndex outside boundaries");
91 auto pos = idMap.find(vacancyIndex);
92 if (pos!= idMap.end())
94 n = (
G4int) dataSet[0];
106 if (vacancyIndex<0 || vacancyIndex>=numberOfVacancies)
109 "vacancyIndex outside boundaries, energy deposited locally");
114 n = nInitShells[vacancyIndex]-1;
128 if (vacancyIndex<0 || vacancyIndex>=numberOfVacancies) {
130 "vacancyIndex outside boundaries");
132 auto pos = idMap.find(vacancyIndex);
133 if (pos != idMap.end()) {
139 if (initIndex >= 0 && initIndex < nData) {
140 n = (*dataSet)[initIndex+1];
153 if (vacancyIndex<0 || vacancyIndex>=numberOfVacancies)
156 "vacancyIndex outside boundaries");}
159 auto pos = energyMap.find(vacancyIndex);
164 if (initIndex >= 0 && initIndex < nData)
166 n = dataSet[initIndex];
178 if (vacancyIndex<0 || vacancyIndex>=numberOfVacancies)
181 "vacancyIndex outside boundaries, energy deposited locally");
186 auto pos = probabilityMap.find(vacancyIndex);
191 if (initIndex >= 0 && initIndex < nData)
193 n = dataSet[initIndex];
204 std::ostringstream ost;
206 ost <<
"/fl-tr-pr-"<< Z <<
".dat";
209 ost <<
"/fl-tr-pr-"<<
".dat";
217 G4String excep(
"G4FluoData::LoadData()");
224 G4String dirFile = pathString + fluoDirectory + name;
229 std::ifstream file(dirFile);
230 std::filebuf* lsdp = file.rdbuf();
232 if (! (lsdp->is_open()) )
234 G4String excep =
"G4FluoData::LoadData()";
235 G4String msg =
"data file: " + dirFile +
" not found";
257 idMap[vacIndex] = initIds;
258 energyMap[vacIndex] = transEnergies;
259 probabilityMap[vacIndex] = transProbabilities;
262 nInitShells.push_back(n);
271 if (sLocal == nColumns)
291 if (a != -1) transProbabilities->push_back(a);
295 else if (k%nColumns == 1)
300 if(initIds->size() == 0) {
301 if (a != -1) initIds->push_back((
G4int)a);
307 if (a != -1) initIds->push_back(a);
311 else if (k%nColumns == 0)
317 transEnergies->push_back(e);}
326 delete transEnergies;
327 delete transProbabilities;
334 for (
G4int i = 0; i <numberOfVacancies; ++i)
336 G4cout <<
"---- TransitionData for the vacancy nb "
349 G4cout <<
" - Transition energy = " << e <<
" MeV "<<
G4endl;
353 G4cout <<
"-------------------------------------------------"
const char * G4FindDataDir(const char *)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
G4GLOB_DLL std::ostream G4cout
std::size_t NumberOfTransitions(G4int vacancyIndex) const
G4double StartShellEnergy(G4int initIndex, G4int vacancyIndex) const
G4int VacancyId(G4int vacancyIndex) const
Given the index of the vacancy returns its identity.
std::size_t NumberOfVacancies() const
G4FluoData(const G4String &dir)
G4int StartShellId(G4int initIndex, G4int vacancyIndex) const
G4double StartShellProb(G4int initIndex, G4int vacancyIndex) const