Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/processes/electromagnetic/utils/src/G4EmTableUtil.cc

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /processes/electromagnetic/utils/src/G4EmTableUtil.cc (Version 11.3.0) and /processes/electromagnetic/utils/src/G4EmTableUtil.cc (Version 9.5.p1)


  1 //                                                  1 
  2 // *******************************************    
  3 // * License and Disclaimer                       
  4 // *                                              
  5 // * The  Geant4 software  is  copyright of th    
  6 // * the Geant4 Collaboration.  It is provided    
  7 // * conditions of the Geant4 Software License    
  8 // * LICENSE and available at  http://cern.ch/    
  9 // * include a list of copyright holders.         
 10 // *                                              
 11 // * Neither the authors of this software syst    
 12 // * institutes,nor the agencies providing fin    
 13 // * work  make  any representation or  warran    
 14 // * regarding  this  software system or assum    
 15 // * use.  Please see the license in the file     
 16 // * for the full disclaimer and the limitatio    
 17 // *                                              
 18 // * This  code  implementation is the result     
 19 // * technical work of the GEANT4 collaboratio    
 20 // * By using,  copying,  modifying or  distri    
 21 // * any work based  on the software)  you  ag    
 22 // * use  in  resulting  scientific  publicati    
 23 // * acceptance of all terms of the Geant4 Sof    
 24 // *******************************************    
 25 //                                                
 26 //                                                
 27 // Geant4 class G4EmTableUtil                     
 28 //                                                
 29 // Author V.Ivanchenko 14.03.2022                 
 30 //                                                
 31                                                   
 32 #include "G4EmTableUtil.hh"                       
 33 #include "G4RegionStore.hh"                       
 34 #include "G4ProductionCutsTable.hh"               
 35 #include "G4EmParameters.hh"                      
 36 #include "G4EmUtility.hh"                         
 37 #include "G4LossTableManager.hh"                  
 38 #include "G4EmTableType.hh"                       
 39 #include "G4PhysicsModelCatalog.hh"               
 40 #include "G4LowEnergyEmProcessSubType.hh"         
 41 #include "G4PhysicsTableHelper.hh"                
 42 #include "G4PhysicsLogVector.hh"                  
 43 #include "G4ProcessManager.hh"                    
 44 #include "G4UIcommand.hh"                         
 45 #include "G4GenericIon.hh"                        
 46 #include <iostream>                               
 47                                                   
 48 //....oooOO0OOooo........oooOO0OOooo........oo    
 49                                                   
 50 const G4DataVector*                               
 51 G4EmTableUtil::PrepareEmProcess(G4VEmProcess*     
 52                                 const G4Partic    
 53                                 const G4Partic    
 54               G4EmModelManager* modelManager,     
 55                                 const G4double    
 56               G4int& secID, G4int& tripletID,     
 57                                 G4int& mainSec    
 58                                 const G4bool&     
 59 {                                                 
 60   G4EmParameters* param = G4EmParameters::Inst    
 61                                                   
 62   // initialisation of models                     
 63   G4double plimit = param->MscThetaLimit();       
 64   G4int nModels = modelManager->NumberOfModels    
 65   for(G4int i=0; i<nModels; ++i) {                
 66     G4VEmModel* mod = modelManager->GetModel(i    
 67     if(nullptr == mod) { continue; }              
 68     mod->SetPolarAngleLimit(plimit);              
 69     if(mod->HighEnergyLimit() > maxKinEnergy)     
 70       mod->SetHighEnergyLimit(maxKinEnergy);      
 71     }                                             
 72     proc->SetEmModel(mod);                        
 73   }                                               
 74                                                   
 75   // defined ID of secondary particles and ver    
 76   G4int stype = proc->GetProcessSubType();        
 77   if(stype == fAnnihilation) {                    
 78     secID = _Annihilation;                        
 79     tripletID = _TripletGamma;                    
 80   } else if(stype == fGammaConversion) {          
 81     secID = _PairProduction;                      
 82     mainSec = 2;                                  
 83   } else if(stype == fPhotoElectricEffect) {      
 84     secID = _PhotoElectron;                       
 85   } else if(stype == fComptonScattering) {        
 86     secID = _ComptonElectron;                     
 87   } else if(stype >= fLowEnergyElastic) {         
 88     secID = fDNAUnknownModel;                     
 89   }                                               
 90   if(master) {                                    
 91     proc->SetVerboseLevel(param->Verbose());      
 92   } else {                                        
 93     proc->SetVerboseLevel(param->WorkerVerbose    
 94   }                                               
 95                                                   
 96   // model initialisation                         
 97   const G4DataVector* cuts = modelManager->Ini    
 98                                                   
 99   if(1 < verb) {                                  
100     G4cout << "### G4EmTableUtil::PreparePhysi    
101            << proc->GetProcessName()              
102            << " and particle " << part->GetPar    
103            << G4endl;                             
104   }                                               
105   return cuts;                                    
106 }                                                 
107                                                   
108 //....oooOO0OOooo........oooOO0OOooo........oo    
109                                                   
110 void G4EmTableUtil::BuildEmProcess(G4VEmProces    
111                                    const G4VEm    
112                  const G4ParticleDefinition* f    
113                  const G4ParticleDefinition* p    
114                  const G4int nModels, const G4    
115                                    const G4boo    
116                                    const G4boo    
117 {                                                 
118   G4String num = part->GetParticleName();         
119   if(1 < verb) {                                  
120     G4cout << "### G4EmTableUtil::BuildPhysics    
121            << proc->GetProcessName() << " and     
122            << " buildLambdaTable=" << toBuild     
123            << G4endl;                             
124   }                                               
125                                                   
126   if(firstPart == part) {                         
127                                                   
128     // worker initialisation                      
129     if(!master) {                                 
130       proc->SetLambdaTable(masterProc->LambdaT    
131       proc->SetLambdaTablePrim(masterProc->Lam    
132       proc->SetCrossSectionType(masterProc->Cr    
133       proc->SetEnergyOfCrossSectionMax(masterP    
134                                                   
135       // local initialisation of models           
136       baseMat = masterProc->UseBaseMaterial();    
137       G4bool printing = true;                     
138       for(G4int i=0; i<nModels; ++i) {            
139         G4VEmModel* mod = proc->GetModelByInde    
140         G4VEmModel* mod0= masterProc->GetModel    
141         mod->SetUseBaseMaterials(baseMat);        
142         mod->InitialiseLocal(part, mod0);         
143       }                                           
144       // master thread                            
145     } else {                                      
146       if(toBuild) { proc->BuildLambdaTable();     
147       auto fXSType = proc->CrossSectionType();    
148       auto v = proc->EnergyOfCrossSectionMax()    
149       delete v;                                   
150       v = nullptr;                                
151       if(fXSType == fEmOnePeak) {                 
152         auto table = proc->LambdaTable();         
153         if(nullptr == table) {                    
154     v = G4EmUtility::FindCrossSectionMax(proc,    
155   } else {                                        
156     v = G4EmUtility::FindCrossSectionMax(table    
157   }                                               
158         if(nullptr == v) { proc->SetCrossSecti    
159       }                                           
160       proc->SetEnergyOfCrossSectionMax(v);        
161     }                                             
162   }                                               
163   // protection against double printout           
164   if(isLocked) { return; }                        
165                                                   
166   // explicitly defined printout by particle n    
167   if(1 < verb || (0 < verb && (num == "gamma"     
168              num == "e+"    || num == "mu+" ||    
169              num == "mu-"   || num == "proton"    
170              num == "pi+"   || num == "pi-" ||    
171              num == "kaon+" || num == "kaon-"     
172              num == "alpha" || num == "anti_pr    
173              num == "GenericIon" ||               
174              num == "alpha+" || num == "helium    
175              num == "hydrogen"))) {               
176     proc->StreamInfo(G4cout, *part);              
177   }                                               
178                                                   
179   if(1 < verb) {                                  
180     G4cout << "### G4EmTableUtil::BuildPhysics    
181            << proc->GetProcessName() << " and     
182            << " baseMat=" << baseMat << G4endl    
183   }                                               
184 }                                                 
185                                                   
186 //....oooOO0OOooo........oooOO0OOooo........oo    
187                                                   
188 void G4EmTableUtil::BuildLambdaTable(G4VEmProc    
189                                      const G4P    
190                                      G4EmModel    
191                    G4LossTableBuilder* bld,       
192                                      G4Physics    
193                                      G4Physics    
194                                      const G4d    
195                                      const G4d    
196                                      const G4d    
197                                      const G4d    
198              const G4int verboseLevel,            
199                                      const G4b    
200                                      const G4b    
201 {                                                 
202   if(1 < verboseLevel) {                          
203     G4cout << "G4EmTableUtil::BuildLambdaTable    
204            << proc->GetProcessName() << " and     
205            << part->GetParticleName() << G4end    
206   }                                               
207                                                   
208   // Access to materials                          
209   const G4ProductionCutsTable* theCoupleTable=    
210         G4ProductionCutsTable::GetProductionCu    
211   std::size_t numOfCouples = theCoupleTable->G    
212                                                   
213   G4PhysicsLogVector* aVector = nullptr;          
214   G4PhysicsLogVector* aVectorPrim = nullptr;      
215   G4PhysicsLogVector* bVectorPrim = nullptr;      
216                                                   
217   G4double emax1 = std::min(maxKinEnergy, minK    
218                                                   
219   for(std::size_t i=0; i<numOfCouples; ++i) {     
220                                                   
221     if (bld->GetFlag(i)) {                        
222       // create physics vector and fill it        
223       const G4MaterialCutsCouple* couple =        
224         theCoupleTable->GetMaterialCutsCouple(    
225                                                   
226       // build main table                         
227       if(nullptr != theLambdaTable) {             
228         delete (*theLambdaTable)[i];              
229                                                   
230         // if start from zero then change the     
231         G4double emin = minKinEnergy;             
232         G4bool startNull = false;                 
233         if(startFromNull) {                       
234           G4double e = proc->MinPrimaryEnergy(    
235           if(e >= emin) {                         
236             emin = e;                             
237             startNull = true;                     
238           }                                       
239         }                                         
240         G4double emax = emax1;                    
241         if(emax <= emin) { emax = 2*emin; }       
242         G4int bin = G4lrint(scale*G4Log(emax/e    
243         bin = std::max(bin, 5);                   
244         aVector = new G4PhysicsLogVector(emin,    
245         modelManager->FillLambdaVector(aVector    
246         if(splineFlag) { aVector->FillSecondDe    
247         G4PhysicsTableHelper::SetPhysicsVector    
248       }                                           
249       // build high energy table                  
250       if(nullptr != theLambdaTablePrim && minK    
251         delete (*theLambdaTablePrim)[i];          
252                                                   
253         // start not from zero and always use     
254         if(nullptr == bVectorPrim) {              
255           G4int bin = G4lrint(scale*G4Log(maxK    
256           bin = std::max(bin, 5);                 
257           aVectorPrim =                           
258             new G4PhysicsLogVector(minKinEnerg    
259           bVectorPrim = aVectorPrim;              
260         } else {                                  
261           aVectorPrim = new G4PhysicsLogVector    
262         }                                         
263         modelManager->FillLambdaVector(aVector    
264                                        fIsCros    
265         aVectorPrim->FillSecondDerivatives();     
266         G4PhysicsTableHelper::SetPhysicsVector    
267                                                   
268       }                                           
269     }                                             
270   }                                               
271                                                   
272   if(1 < verboseLevel) {                          
273     G4cout << "Lambda table is built for " <<     
274   }                                               
275 }                                                 
276                                                   
277 //....oooOO0OOooo........oooOO0OOooo........oo    
278                                                   
279 void  G4EmTableUtil::BuildLambdaTable(G4VEnerg    
280                                      const G4P    
281                                      G4EmModel    
282                    G4LossTableBuilder* bld,       
283                                      G4Physics    
284                                      const G4D    
285                                      const G4d    
286                                      const G4d    
287                                      const G4d    
288              const G4int verboseLevel,            
289                                      const G4b    
290 {                                                 
291   if(1 < verboseLevel) {                          
292     G4cout << "G4EmTableUtil::BuildLambdaTable    
293            << proc->GetProcessName() << " and     
294            << part->GetParticleName() << G4end    
295   }                                               
296                                                   
297   const G4ProductionCutsTable* theCoupleTable=    
298         G4ProductionCutsTable::GetProductionCu    
299   std::size_t numOfCouples = theCoupleTable->G    
300                                                   
301   G4PhysicsLogVector* aVector = nullptr;          
302   for(std::size_t i=0; i<numOfCouples; ++i) {     
303     if (bld->GetFlag(i)) {                        
304       // create physics vector and fill it        
305       const G4MaterialCutsCouple* couple =        
306         theCoupleTable->GetMaterialCutsCouple(    
307                                                   
308       delete (*theLambdaTable)[i];                
309       G4bool startNull = true;                    
310       G4double emin =                             
311         proc->MinPrimaryEnergy(part, couple->G    
312       if(minKinEnergy > emin) {                   
313         emin = minKinEnergy;                      
314         startNull = false;                        
315       }                                           
316                                                   
317       G4double emax = maxKinEnergy;               
318       if(emax <= emin) { emax = 2*emin; }         
319       G4int bin = G4lrint(scale*G4Log(emax/emi    
320       bin = std::max(bin, 5);                     
321       aVector = new G4PhysicsLogVector(emin, e    
322       modelManager->FillLambdaVector(aVector,     
323       if(splineFlag) { aVector->FillSecondDeri    
324       G4PhysicsTableHelper::SetPhysicsVector(t    
325     }                                             
326   }                                               
327                                                   
328   if(1 < verboseLevel) {                          
329     G4cout << "Lambda table is built for " <<     
330   }                                               
331 }                                                 
332                                                   
333 //....oooOO0OOooo........oooOO0OOooo........oo    
334                                                   
335 const G4ParticleDefinition*                       
336 G4EmTableUtil::CheckIon(G4VEnergyLossProcess*     
337                         const G4ParticleDefini    
338                         const G4ParticleDefini    
339                         const G4int verb, G4bo    
340 {                                                 
341   if(1 < verb) {                                  
342     G4cout << "G4EmTableUtil::CheckIon for "      
343            << proc->GetProcessName() << " for     
344            << " should be called from G4VEnerg    
345            << G4endl;                             
346   }                                               
347   const G4ParticleDefinition* particle = partL    
348                                                   
349   // Are particle defined?                        
350   if(nullptr == particle) { particle = part; }    
351   if(part->GetParticleType() == "nucleus") {      
352     G4String pname = part->GetParticleName();     
353     if(pname != "deuteron" && pname != "triton    
354        pname != "He3" && pname != "alpha+" &&     
355                                                   
356       const G4ParticleDefinition* theGIon = G4    
357       isIon = true;                               
358                                                   
359       // this is a loop to compare pointers of    
360       // to confirm that for given particle th    
361       if(particle != theGIon) {                   
362         G4ProcessManager* pm = theGIon->GetPro    
363         G4ProcessVector* v = pm->GetAlongStepP    
364         G4int n = (G4int)v->size();               
365         for(G4int j=0; j<n; ++j) {                
366           if((*v)[j] == proc) {                   
367             particle = theGIon;                   
368             break;                                
369           }                                       
370         }                                         
371       }                                           
372     }                                             
373   }                                               
374   return particle;                                
375 }                                                 
376                                                   
377 //....oooOO0OOooo........oooOO0OOooo........oo    
378                                                   
379 void G4EmTableUtil::UpdateModels(G4VEnergyLoss    
380                G4EmModelManager* modelManager,    
381                                  const G4doubl    
382                                  const G4int n    
383                                  G4int& secID,    
384                                  G4int& mainSe    
385                                  const G4bool,    
386 {                                                 
387   // defined ID of secondary particles            
388   G4int stype = proc->GetProcessSubType();        
389   if(stype == fBremsstrahlung) {                  
390     secID = _Bremsstrahlung;                      
391     biasID = _SplitBremsstrahlung;                
392   } else if(stype == fPairProdByCharged) {        
393     secID = _PairProduction;                      
394     mainSec = 2;                                  
395   }                                               
396                                                   
397   // initialisation of models                     
398   for(G4int i=0; i<nModels; ++i) {                
399     G4VEmModel* mod = modelManager->GetModel(i    
400     mod->SetAngularGeneratorFlag(useAGen);        
401     if(mod->HighEnergyLimit() > maxKinEnergy)     
402       mod->SetHighEnergyLimit(maxKinEnergy);      
403     }                                             
404     mod->SetUseBaseMaterials(baseMat);            
405   }                                               
406 }                                                 
407                                                   
408 //....oooOO0OOooo........oooOO0OOooo........oo    
409                                                   
410 void                                              
411 G4EmTableUtil::BuildLocalElossProcess(G4VEnerg    
412               const G4VEnergyLossProcess* mast    
413               const G4ParticleDefinition* part    
414               const G4int nModels)                
415 {                                                 
416   // copy table pointers from master thread       
417   proc->SetDEDXTable(masterProc->DEDXTable(),f    
418   proc->SetDEDXTable(masterProc->DEDXunRestric    
419   proc->SetDEDXTable(masterProc->IonisationTab    
420   proc->SetRangeTableForLoss(masterProc->Range    
421   proc->SetCSDARangeTable(masterProc->CSDARang    
422   proc->SetInverseRangeTable(masterProc->Inver    
423   proc->SetLambdaTable(masterProc->LambdaTable    
424   proc->SetCrossSectionType(masterProc->CrossS    
425   proc->SetEnergyOfCrossSectionMax(masterProc-    
426   proc->SetTwoPeaksXS(masterProc->TwoPeaksXS()    
427   proc->SetIonisation(masterProc->IsIonisation    
428   G4bool baseMat = masterProc->UseBaseMaterial    
429                                                   
430   // local initialisation of models               
431   G4bool printing = true;                         
432   for(G4int i=0; i<nModels; ++i) {                
433     G4VEmModel* mod = proc->GetModelByIndex(i,    
434     G4VEmModel* mod0= masterProc->GetModelByIn    
435     mod->SetUseBaseMaterials(baseMat);            
436     mod->InitialiseLocal(part, mod0);             
437   }                                               
438 }                                                 
439                                                   
440 //....oooOO0OOooo........oooOO0OOooo........oo    
441                                                   
442 void G4EmTableUtil::BuildDEDXTable(G4VEnergyLo    
443            const G4ParticleDefinition* part,      
444            G4EmModelManager* modelManager,        
445            G4LossTableBuilder* bld,               
446            G4PhysicsTable* table,                 
447            const G4double emin,                   
448            const G4double emax,                   
449            const G4int nbins,                     
450            const G4int verbose,                   
451            const G4EmTableType tType,             
452            const G4bool spline)                   
453 {                                                 
454   // Access to materials                          
455   const G4ProductionCutsTable* theCoupleTable=    
456         G4ProductionCutsTable::GetProductionCu    
457   std::size_t numOfCouples = theCoupleTable->G    
458                                                   
459   if(1 < verbose) {                               
460     G4cout << numOfCouples << " couples" << "     
461            << " maxKinEnergy(MeV)= " << emax <    
462   }                                               
463   G4PhysicsLogVector* aVector = nullptr;          
464   G4PhysicsLogVector* bVector = nullptr;          
465                                                   
466   for(std::size_t i=0; i<numOfCouples; ++i) {     
467                                                   
468     if(1 < verbose) {                             
469       G4cout << "G4EmTableUtil::BuildDEDXVecto    
470              << "  flagTable=" << table->GetFl    
471              << " flagBuilder=" << bld->GetFla    
472     }                                             
473     if(bld->GetFlag(i)) {                         
474                                                   
475       // create physics vector and fill it        
476       const G4MaterialCutsCouple* couple =        
477         theCoupleTable->GetMaterialCutsCouple(    
478       delete (*table)[i];                         
479       if(nullptr != bVector) {                    
480         aVector = new G4PhysicsLogVector(*bVec    
481       } else {                                    
482         bVector = new G4PhysicsLogVector(emin,    
483         aVector = bVector;                        
484       }                                           
485                                                   
486       modelManager->FillDEDXVector(aVector, co    
487       if(spline) { aVector->FillSecondDerivati    
488                                                   
489       // Insert vector for this material into     
490       G4PhysicsTableHelper::SetPhysicsVector(t    
491     }                                             
492   }                                               
493                                                   
494   if(1 < verbose) {                               
495     G4cout << "G4EmTableUtil::BuildDEDXTable()    
496            << part->GetParticleName()             
497            << " and process " << proc->GetProc    
498            << G4endl;                             
499     if(2 < verbose) G4cout << (*table) << G4en    
500   }                                               
501 }                                                 
502                                                   
503 //....oooOO0OOooo........oooOO0OOooo........oo    
504                                                   
505 void G4EmTableUtil::PrepareMscProcess(G4VMulti    
506               const G4ParticleDefinition& part    
507               G4EmModelManager* modelManager,     
508               G4MscStepLimitType& stepLimit,      
509                                       G4double    
510               G4bool& latDisplacement, G4bool&    
511               G4bool& isIon, G4bool& baseMat)     
512 {                                                 
513   auto param = G4EmParameters::Instance();        
514   G4int verb = (master) ? param->Verbose() : p    
515   proc->SetVerboseLevel(verb);                    
516                                                   
517   if(part.GetPDGMass() > CLHEP::GeV ||            
518      part.GetParticleName() == "GenericIon") {    
519                                                   
520   if(1 < verb) {                                  
521     G4cout << "### G4EmTableUtil::PrepearPhysi    
522            << proc->GetProcessName()              
523            << " and particle " << part.GetPart    
524            << " isIon: " << isIon << " isMaste    
525      << G4endl;                                   
526   }                                               
527                                                   
528   // initialise process                           
529   proc->InitialiseProcess(&part);                 
530                                                   
531   // heavy particles                              
532   if(part.GetPDGMass() > CLHEP::MeV) {            
533     stepLimit = param->MscMuHadStepLimitType()    
534     facrange = param->MscMuHadRangeFactor();      
535     latDisplacement = param->MuHadLateralDispl    
536   } else {                                        
537     stepLimit = param->MscStepLimitType();        
538     facrange = param->MscRangeFactor();           
539     latDisplacement = param->LateralDisplaceme    
540   }                                               
541                                                   
542   // initialisation of models                     
543   auto numberOfModels = modelManager->NumberOf    
544   for(G4int i=0; i<numberOfModels; ++i) {         
545     G4VMscModel* msc = proc->GetModelByIndex(i    
546     msc->SetIonisation(nullptr, &part);           
547     msc->SetPolarAngleLimit(param->MscThetaLim    
548     G4double emax = std::min(msc->HighEnergyLi    
549     msc->SetHighEnergyLimit(emax);                
550     msc->SetUseBaseMaterials(baseMat);            
551   }                                               
552   modelManager->Initialise(&part, nullptr, ver    
553 }                                                 
554                                                   
555 //....oooOO0OOooo........oooOO0OOooo........oo    
556                                                   
557 void G4EmTableUtil::BuildMscProcess(G4VMultipl    
558                                     const G4VM    
559                         const G4ParticleDefini    
560                         const G4ParticleDefini    
561             G4int nModels, G4bool master)         
562 {                                                 
563   auto param = G4EmParameters::Instance();        
564   G4int verb = param->Verbose();                  
565                                                   
566   if (firstPart == &part) {                       
567     G4LossTableBuilder* bld = G4LossTableManag    
568     G4bool baseMat = bld->GetBaseMaterialFlag(    
569     if (master) {                                 
570       for (G4int i=0; i<nModels; ++i) {           
571   G4VMscModel* msc = proc->GetModelByIndex(i);    
572   msc->SetUseBaseMaterials(baseMat);              
573   // table is always built for low mass partic    
574         if (part.GetParticleName() != "Generic    
575       (part.GetPDGMass() < CLHEP::GeV || msc->    
576     G4double emin =                               
577       std::max(msc->LowEnergyLimit(), msc->Low    
578     G4double emax =                               
579       std::min(msc->HighEnergyLimit(), msc->Hi    
580     emin = std::max(emin, param->MinKinEnergy(    
581     emax = std::min(emax, param->MaxKinEnergy(    
582     if (emin < emax) {                            
583       auto table = bld->BuildTableForModel(msc    
584              msc, &part, emin, emax, true);       
585       msc->SetCrossSectionTable(table, true);     
586     }                                             
587   }                                               
588       }                                           
589     } else {                                      
590       for (G4int i=0; i<nModels; ++i) {           
591   G4VMscModel* msc = proc->GetModelByIndex(i);    
592   G4VMscModel* msc0 = masterProc->GetModelByIn    
593   msc->SetUseBaseMaterials(baseMat);              
594   msc->SetCrossSectionTable(msc0->GetCrossSect    
595   msc->InitialiseLocal(&part, msc0);              
596       }                                           
597     }                                             
598   }                                               
599   if(!param->IsPrintLocked()) {                   
600     const G4String& num = part.GetParticleName    
601                                                   
602     // explicitly defined printout by particle    
603     if(1 < verb || (0 < verb && (num == "e-" |    
604          num == "e+"    || num == "mu+" ||        
605          num == "mu-"   || num == "proton"||      
606          num == "pi+"   || num == "pi-" ||        
607          num == "kaon+" || num == "kaon-" ||      
608          num == "alpha" || num == "anti_proton    
609          num == "GenericIon" || num == "alpha+    
610          num == "alpha" ))) {                     
611       proc->StreamInfo(G4cout, part);             
612     }                                             
613   }                                               
614   if(1 < verb) {                                  
615     G4cout << "### G4EmTableUtil::BuildPhysics    
616      << proc->GetProcessName()                    
617      << " and particle " << part.GetParticleNa    
618   }                                               
619 }                                                 
620                                                   
621 //....oooOO0OOooo........oooOO0OOooo........oo    
622                                                   
623 G4bool G4EmTableUtil::StoreMscTable(G4VMultipl    
624                                     const G4Pa    
625                                     const G4St    
626                                     const G4in    
627                         const G4bool ascii)       
628 {                                                 
629   G4bool ok = true;                               
630   for(G4int i=0; i<nModels; ++i) {                
631     G4VMscModel* msc = proc->GetModelByIndex(i    
632     G4PhysicsTable* table = msc->GetCrossSecti    
633     if (nullptr != table) {                       
634       G4String ss = G4UIcommand::ConvertToStri    
635       G4String name =                             
636         proc->GetPhysicsTableFileName(part, di    
637       G4bool yes = table->StorePhysicsTable(na    
638                                                   
639       if ( yes ) {                                
640         if ( verb > 0 ) {                         
641           G4cout << "Physics table are stored     
642                  << part->GetParticleName()       
643                  << " and process " << proc->G    
644                  << " with a name <" << name <    
645         }                                         
646       } else {                                    
647         G4cout << "Fail to store Physics Table    
648                << part->GetParticleName()         
649                << " and process " << proc->Get    
650                << " in the directory <" << dir    
651                << "> " << G4endl;                 
652   ok = false;                                     
653       }                                           
654     }                                             
655   }                                               
656   return ok;                                      
657 }                                                 
658                                                   
659 //....oooOO0OOooo........oooOO0OOooo........oo    
660                                                   
661 G4bool G4EmTableUtil::StoreTable(G4VProcess* p    
662                                  const G4Parti    
663                                  G4PhysicsTabl    
664                                  const G4Strin    
665                                  const G4Strin    
666                                  const G4int v    
667 {                                                 
668   G4bool res = true;                              
669   if (nullptr != aTable) {                        
670     const G4String& name =                        
671       ptr->GetPhysicsTableFileName(part, dir,     
672     if ( aTable->StorePhysicsTable(name, ascii    
673       if (1 < verb) G4cout << "Stored: " << na    
674     } else {                                      
675       res = false;                                
676       G4cout << "G4EmTableUtil::StoreTable fai    
677     }                                             
678   }                                               
679   return res;                                     
680 }                                                 
681                                                   
682 //....oooOO0OOooo........oooOO0OOooo........oo    
683                                                   
684 G4bool G4EmTableUtil::RetrieveTable(G4VProcess    
685                                     const G4Pa    
686                                     G4PhysicsT    
687                                     const G4St    
688                                     const G4in    
689                                     const G4bo    
690 {                                                 
691   G4bool res = true;                              
692   if (nullptr == aTable) { return res; }          
693   if (1 < verb) {                                 
694     G4cout << tname << " table for " << part->    
695            << " will be retrieved " << G4endl;    
696   }                                               
697   const G4String& name =                          
698     ptr->GetPhysicsTableFileName(part, dir, tn    
699   if(G4PhysicsTableHelper::RetrievePhysicsTabl    
700     if(spline) {                                  
701       for(auto & v : *aTable) {                   
702   if(nullptr != v) { v->FillSecondDerivatives(    
703       }                                           
704     }                                             
705     if (0 < verb) {                               
706       G4cout << tname << " table for " << part    
707        << " is retrieved from <" << name << ">    
708        << G4endl;                                 
709     }                                             
710   } else {                                        
711     res = false;                                  
712     G4cout << "G4EmTableUtil::RetrieveTable fa    
713            << " from " << name << " for " << p    
714   }                                               
715   return res;                                     
716 }                                                 
717                                                   
718 //....oooOO0OOooo........oooOO0OOooo........oo    
719                                                   
720