54 : tLength(n), fName(nam)
56 data.resize(n,
nullptr);
57 fMaxXS =
new std::vector<G4double>;
58 fXSpeaks =
new std::vector<G4TwoPeaksXS*>;
66 if (!fUseBaseParticleTable) {
67 for (std::size_t i=0; i<tLength; ++i) {
73 if (!fElemSelectors.empty()) {
74 for (
auto const & ptr : fElemSelectors) {
76 for (
auto const & p : *ptr) {
delete p; }
87 for (std::size_t i=0; i<tLength; ++i) {
88 if (ptr == data[i]) {
return i; }
101 if (ptr != data[idx]) { data[idx] = ptr; }
104 G4cout <<
"### G4EmDataHandler::UpdateTable fail for idx=" << idx
105 <<
" length=" << tLength <<
G4endl;
123 if (idx >= tLength) {
124 data.push_back(
nullptr);
140 if (ptr != data[idx]) {
157 if (i < tLength &&
nullptr != data[i]) {
159 ptr->clearAndDestroy();
161 for (std::size_t j=0; j<tLength; ++j) {
162 if (ptr == data[j]) { data[j] =
nullptr; }
175 if(
nullptr != data[idx]) {
176 yes = data[idx]->StorePhysicsTable(fname, ascii);
179 G4cout <<
"### Physics table is stored for "
181 <<
" <" << fname <<
"> " <<
G4endl;
183 G4cout <<
"### Fail to store Physics Table for "
185 <<
" <" << fname <<
"> " <<
G4endl;
203 G4cout <<
"### Physics table " << idx <<
" for "
205 <<
" is retrieved from <" << fname <<
">"
208 }
else if (1 < param->
Verbose()) {
209 G4cout <<
"### Fail to retrieve physics table " << idx <<
" for "
211 << fname <<
">" <<
G4endl;
220 masterProcess.push_back(ptr);
227 return (idx < masterProcess.size()) ? masterProcess[idx] :
nullptr;
236 if (fElemSelectors[i] != p) {
237 delete fElemSelectors[i];
239 fElemSelectors[i] = p;
241 fElemSelectors.push_back(p);
G4GLOB_DLL std::ostream G4cout
void SetMasterProcess(const G4VEmProcess *)
void SaveTable(G4PhysicsTable *, std::size_t idx)
std::size_t SetTable(G4PhysicsTable *)
void SetElementSelectors(std::vector< G4EmElementSelector * > *, std::size_t)
G4PhysicsTable * Table(std::size_t idx) const
const G4VEmProcess * GetMasterProcess(size_t idx) const
G4EmDataHandler(std::size_t nTable, const G4String &nam="")
G4bool RetrievePhysicsTable(std::size_t idx, const G4ParticleDefinition *part, const G4String &fname, G4bool ascii, G4bool spline)
G4bool StorePhysicsTable(std::size_t idx, const G4ParticleDefinition *part, const G4String &fname, G4bool ascii)
void UpdateTable(G4PhysicsTable *, std::size_t idx)
void CleanTable(std::size_t idx)
G4PhysicsTable * MakeTable(std::size_t idx)
void Register(G4EmDataHandler *)
static G4EmDataRegistry * Instance()
static G4EmParameters * Instance()
const G4String & GetParticleName() const
static G4PhysicsTable * PreparePhysicsTable(G4PhysicsTable *physTable)
static G4bool RetrievePhysicsTable(G4PhysicsTable *physTable, const G4String &fileName, G4bool ascii, G4bool spline)