Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/processes/electromagnetic/lowenergy/src/G4MicroElecCrossSectionDataSet_new.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/lowenergy/src/G4MicroElecCrossSectionDataSet_new.cc (Version 11.3.0) and /processes/electromagnetic/lowenergy/src/G4MicroElecCrossSectionDataSet_new.cc (Version 10.5)


  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 //  MR - 04/04/2012                               
 27 //  Based on G4DNACrossSectionDataSet             
 28 //                                                
 29                                                   
 30 #include "G4MicroElecCrossSectionDataSet_new.h    
 31 #include "G4VDataSetAlgorithm.hh"                 
 32 #include "G4EMDataSet.hh"                         
 33 #include <vector>                                 
 34 #include <fstream>                                
 35 #include <sstream>                                
 36                                                   
 37 //....oooOO0OOooo........oooOO0OOooo........oo    
 38                                                   
 39                                                   
 40 G4MicroElecCrossSectionDataSet_new::G4MicroEle    
 41                G4double argUnitEnergies,          
 42                G4double argUnitData)              
 43   :                                               
 44    algorithm(argAlgorithm), unitEnergies(argUn    
 45 {;}                                               
 46                                                   
 47 //....oooOO0OOooo........oooOO0OOooo........oo    
 48                                                   
 49 G4MicroElecCrossSectionDataSet_new::~G4MicroEl    
 50 {                                                 
 51   CleanUpComponents();                            
 52                                                   
 53   if (algorithm)                                  
 54     delete algorithm;                             
 55 }                                                 
 56                                                   
 57 //....oooOO0OOooo........oooOO0OOooo........oo    
 58                                                   
 59 G4bool G4MicroElecCrossSectionDataSet_new::Loa    
 60 {                                                 
 61   CleanUpComponents();                            
 62   G4cout << "loaddata : " << argFileName << G4    
 63   G4String fullFileName(FullFileName(argFileNa    
 64   std::ifstream in(fullFileName, std::ifstream    
 65                                                   
 66   if (!in.is_open())                              
 67     {                                             
 68       G4String message("Data file \"");           
 69       message+=fullFileName;                      
 70       message+="\" not found";                    
 71       G4Exception("G4MicroElecCrossSectionData    
 72       FatalException,message);                    
 73       return false;                               
 74     }                                             
 75                                                   
 76   std::vector<G4DataVector *> columns;            
 77   std::vector<G4DataVector *> log_columns;        
 78                                                   
 79   std::stringstream *stream(new std::stringstr    
 80   char c;                                         
 81   G4bool comment(false);                          
 82   G4bool space(true);                             
 83   G4bool first(true);                             
 84                                                   
 85   try                                             
 86     {                                             
 87       while (!in.eof())                           
 88   {                                               
 89     in.get(c);                                    
 90                                                   
 91     switch (c)                                    
 92       {                                           
 93       case '\r':                                  
 94       case '\n':                                  
 95         if (!first)                               
 96     {                                             
 97       unsigned long i(0);                         
 98       G4double value;                             
 99                                                   
100       while (!stream->eof())                      
101         {                                         
102           (*stream) >> value;                     
103                                                   
104           while (i>=columns.size())               
105                         {                         
106         columns.push_back(new G4DataVector);      
107         log_columns.push_back(new G4DataVector    
108                         }                         
109                                                   
110           columns[i]->push_back(value);           
111                                                   
112           // N. A. Karakatsanis                   
113           // A condition is applied to check i    
114           // If yes, then a near-zero value is    
115           // If a value is zero, this simplifi    
116           // If a value is negative, then it i    
117           // logarithmic values should not be     
118           //                                      
119           // Therefore, G4LogLogInterpolation     
120           // Instead, G4LinInterpolation is sa    
121           // SemiLogInterpolation is safe only    
122           // G4LinLogInterpolation is safe onl    
123                                                   
124                       if (value <=0.) value =     
125                       log_columns[i]->push_bac    
126                                                   
127           i++;                                    
128         }                                         
129                                                   
130       delete stream;                              
131       stream=new std::stringstream;               
132     }                                             
133                                                   
134         first=true;                               
135         comment=false;                            
136         space=true;                               
137         break;                                    
138                                                   
139       case '#':                                   
140         comment=true;                             
141         break;                                    
142                                                   
143       case '\t':                                  
144         c=' ';                                    
145               break;                              
146       //case ' ':                                 
147             //  if (space)                        
148       //  break;                                  
149       default:                                    
150               if ((c==' ') && space)              
151                  break;                           
152                                                   
153         if (comment)                              
154     break;                                        
155                                                   
156         if (c==' ')                               
157     space=true;                                   
158         else                                      
159     {                                             
160       if (space && (!first))                      
161         (*stream) << ' ';                         
162                                                   
163       first=false;                                
164       (*stream) << c;                             
165       space=false;                                
166     }                                             
167       }                                           
168   }                                               
169     }                                             
170   catch(const std::ios::failure &e)               
171     {                                             
172       // some implementations of STL could thr    
173       // when read wants read characters after    
174     }                                             
175   delete stream;                                  
176                                                   
177   std::size_t maxI(columns.size());               
178                                                   
179   if (maxI<2)                                     
180     {                                             
181       G4String message("Data file \"");           
182       message+=fullFileName;                      
183       message+="\" should have at least two co    
184       G4Exception("G4MicroElecCrossSectionData    
185       FatalException,message);                    
186       return false;                               
187     }                                             
188                                                   
189   std::size_t i(1);                               
190   while (i<maxI)                                  
191     {                                             
192       std::size_t maxJ(columns[i]->size());       
193                                                   
194       if (maxJ!=columns[0]->size())               
195   {                                               
196     G4String message("Data file \"");             
197     message+=fullFileName;                        
198     message+="\" has lines with a different nu    
199     G4Exception("G4MicroElecCrossSectionDataSe    
200                       FatalException,message);    
201     return false;                                 
202   }                                               
203                                                   
204       std::size_t j(0);                           
205                                                   
206       G4DataVector *argEnergies=new G4DataVect    
207       G4DataVector *argData=new G4DataVector;     
208       G4DataVector *argLogEnergies=new G4DataV    
209       G4DataVector *argLogData=new G4DataVecto    
210                                                   
211       while(j<maxJ)                               
212   {                                               
213     argEnergies->push_back(columns[0]->operato    
214     argData->push_back(columns[i]->operator[]     
215     argLogEnergies->push_back(log_columns[0]->    
216     argLogData->push_back(log_columns[i]->oper    
217     j++;                                          
218   }                                               
219                                                   
220       AddComponent(new G4EMDataSet(G4int(i-1),    
221                                                   
222       ++i;                                        
223     }                                             
224                                                   
225   i=maxI;                                         
226   while (i>0)                                     
227     {                                             
228       i--;                                        
229       delete columns[i];                          
230       delete log_columns[i];                      
231     }                                             
232                                                   
233   return true;                                    
234 }                                                 
235                                                   
236 //....oooOO0OOooo........oooOO0OOooo........oo    
237                                                   
238 G4bool G4MicroElecCrossSectionDataSet_new::Loa    
239 {                                                 
240   CleanUpComponents();                            
241                                                   
242   G4String fullFileName(FullFileName(argFileNa    
243   std::ifstream in(fullFileName, std::ifstream    
244                                                   
245   if (!in.is_open())                              
246     {                                             
247       G4String message("Data file \"");           
248       message+=fullFileName;                      
249       message+="\" not found";                    
250       G4Exception("G4MicroElecCrossSectionData    
251                       FatalException,message);    
252       return false;                               
253     }                                             
254                                                   
255   std::vector<G4DataVector *> columns;            
256                                                   
257   std::stringstream *stream(new std::stringstr    
258   char c;                                         
259   G4bool comment(false);                          
260   G4bool space(true);                             
261   G4bool first(true);                             
262                                                   
263   try                                             
264     {                                             
265       while (!in.eof())                           
266   {                                               
267     in.get(c);                                    
268                                                   
269     switch (c)                                    
270       {                                           
271       case '\r':                                  
272       case '\n':                                  
273         if (!first)                               
274     {                                             
275       unsigned long i(0);                         
276       G4double value;                             
277                                                   
278       while (!stream->eof())                      
279         {                                         
280           (*stream) >> value;                     
281                                                   
282           while (i>=columns.size())               
283                         {                         
284        columns.push_back(new G4DataVector);       
285                         }                         
286                                                   
287           columns[i]->push_back(value);           
288                                                   
289           i++;                                    
290         }                                         
291                                                   
292       delete stream;                              
293       stream=new std::stringstream;               
294     }                                             
295                                                   
296         first=true;                               
297         comment=false;                            
298         space=true;                               
299         break;                                    
300                                                   
301       case '#':                                   
302         comment=true;                             
303         break;                                    
304                                                   
305       default:                                    
306               if( c=='\t')                        
307                  c=' ';                           
308               if( c==' ' && space)                
309                  break;                           
310                                                   
311         if (comment)                              
312     break;                                        
313                                                   
314         if (c==' ')                               
315     space=true;                                   
316         else                                      
317     {                                             
318       if (space && (!first))                      
319         (*stream) << ' ';                         
320                                                   
321       first=false;                                
322       (*stream) << c;                             
323       space=false;                                
324     }                                             
325       }                                           
326   }                                               
327     }                                             
328   catch(const std::ios::failure &e)               
329     {                                             
330       // some implementations of STL could thr    
331       // when read wants read characters after    
332     }                                             
333                                                   
334   delete stream;                                  
335                                                   
336   std::size_t maxI(columns.size());               
337                                                   
338   if (maxI<2)                                     
339     {                                             
340       G4String message("Data file \"");           
341       message+=fullFileName;                      
342       message+="\" should have at least two co    
343       G4Exception("G4MicroElecCrossSectionData    
344                       FatalException,message);    
345       return false;                               
346     }                                             
347                                                   
348   std::size_t i(1);                               
349   while (i<maxI)                                  
350     {                                             
351       std::size_t maxJ(columns[i]->size());       
352                                                   
353                                                   
354       if (maxJ!=columns[0]->size())               
355   {                                               
356     G4String message("Data file \"");             
357     message+=fullFileName;                        
358     message+="\" has lines with a different nu    
359           G4Exception("G4MicroElecCrossSection    
360                       FatalException,message);    
361     return false;                                 
362   }                                               
363                                                   
364       std::size_t j(0);                           
365                                                   
366       G4DataVector *argEnergies=new G4DataVect    
367       G4DataVector *argData=new G4DataVector;     
368                                                   
369       while(j<maxJ)                               
370   {                                               
371     argEnergies->push_back(columns[0]->operato    
372     argData->push_back(columns[i]->operator[]     
373     ++j;                                          
374   }                                               
375                                                   
376       AddComponent(new G4EMDataSet(G4int(i-1),    
377                                                   
378       ++i;                                        
379     }                                             
380                                                   
381   i=maxI;                                         
382   while (i>0)                                     
383     {                                             
384       --i;                                        
385       delete columns[i];                          
386     }                                             
387                                                   
388   return true;                                    
389 }                                                 
390                                                   
391 //....oooOO0OOooo........oooOO0OOooo........oo    
392                                                   
393 G4bool G4MicroElecCrossSectionDataSet_new::Sav    
394 {                                                 
395   const std::size_t n(NumberOfComponents());      
396                                                   
397   if (n==0)                                       
398     {                                             
399       G4Exception("G4MicroElecCrossSectionData    
400                       FatalException,"Expected    
401                                                   
402       return false;                               
403     }                                             
404                                                   
405   G4String fullFileName(FullFileName(argFileNa    
406   std::ofstream out(fullFileName);                
407                                                   
408   if (!out.is_open())                             
409     {                                             
410       G4String message("Cannot open \"");         
411       message+=fullFileName;                      
412       message+="\"";                              
413       G4Exception("G4MicroElecCrossSectionData    
414                       FatalException,message);    
415       return false;                               
416     }                                             
417                                                   
418   G4DataVector::const_iterator iEnergies(GetCo    
419   G4DataVector::const_iterator iEnergiesEnd(Ge    
420   G4DataVector::const_iterator * iData(new G4D    
421                                                   
422   std::size_t k(n);                               
423                                                   
424   while (k>0)                                     
425     {                                             
426       --k;                                        
427       iData[k]=GetComponent((G4int)k)->GetData    
428     }                                             
429                                                   
430   while (iEnergies!=iEnergiesEnd)                 
431     {                                             
432       out.precision(10);                          
433       out.width(15);                              
434       out.setf(std::ofstream::left);              
435       out << ((*iEnergies)/GetUnitEnergies());    
436                                                   
437       k=0;                                        
438                                                   
439       while (k<n)                                 
440   {                                               
441     out << ' ';                                   
442     out.precision(10);                            
443     out.width(15);                                
444     out.setf(std::ofstream::left);                
445     out << ((*(iData[k]))/GetUnitData());         
446                                                   
447     iData[k]++;                                   
448     ++k;                                          
449   }                                               
450                                                   
451       out << std::endl;                           
452                                                   
453       ++iEnergies;                                
454     }                                             
455                                                   
456   delete[] iData;                                 
457                                                   
458   return true;                                    
459 }                                                 
460                                                   
461 //....oooOO0OOooo........oooOO0OOooo........oo    
462                                                   
463 G4String G4MicroElecCrossSectionDataSet_new::F    
464 {                                                 
465   const char* path = G4FindDataDir("G4LEDATA")    
466   if (!path)                                      
467     {                                             
468       G4Exception("G4MicroElecCrossSectionData    
469       return "";                                  
470     }                                             
471                                                   
472   //Reading DCS file                              
473                                                   
474   std::ostringstream fullFileName;                
475   fullFileName << path << "/microelec/" << arg    
476   return G4String(fullFileName.str().c_str());    
477 }                                                 
478                                                   
479 //....oooOO0OOooo........oooOO0OOooo........oo    
480                                                   
481 G4double G4MicroElecCrossSectionDataSet_new::F    
482 {                                                 
483   // Returns the sum over the shells correspon    
484   G4double value = 0.;                            
485                                                   
486   std::vector<G4VEMDataSet *>::const_iterator     
487   std::vector<G4VEMDataSet *>::const_iterator     
488                                                   
489   while (i!=end)                                  
490     {                                             
491       value+=(*i)->FindValue(argEnergy);          
492       i++;                                        
493     }                                             
494                                                   
495   return value;                                   
496 }                                                 
497                                                   
498 //....oooOO0OOooo........oooOO0OOooo........oo    
499                                                   
500 G4double G4MicroElecCrossSectionDataSet_new::F    
501 {                                                 
502   return components.at(shell)->FindValue(argEn    
503 }                                                 
504                                                   
505 //....oooOO0OOooo........oooOO0OOooo........oo    
506                                                   
507 void G4MicroElecCrossSectionDataSet_new::Print    
508 {                                                 
509   const std::size_t n(NumberOfComponents());      
510                                                   
511   G4cout << "The data set has " << n << " comp    
512   G4cout << G4endl;                               
513                                                   
514   G4int i(0);                                     
515                                                   
516   while (i<(G4int)n)                              
517     {                                             
518       G4cout << "--- Component " << i << " ---    
519       GetComponent(i)->PrintData();               
520       ++i;                                        
521     }                                             
522 }                                                 
523                                                   
524 //....oooOO0OOooo........oooOO0OOooo........oo    
525                                                   
526 void G4MicroElecCrossSectionDataSet_new::SetEn    
527            G4DataVector* argData,                 
528            G4int argComponentId)                  
529 {                                                 
530   G4VEMDataSet * component(components[argCompo    
531                                                   
532   if (component)                                  
533     {                                             
534       component->SetEnergiesData(argEnergies,     
535       return;                                     
536     }                                             
537                                                   
538   std::ostringstream message;                     
539   message << "Component " << argComponentId <<    
540                                                   
541   G4Exception("G4MicroElecCrossSectionDataSet_    
542                  FatalException,message.str().    
543                                                   
544 }                                                 
545                                                   
546 //....oooOO0OOooo........oooOO0OOooo........oo    
547                                                   
548 void G4MicroElecCrossSectionDataSet_new::SetLo    
549            G4DataVector* argData,                 
550                                          G4Dat    
551                                          G4Dat    
552            G4int argComponentId)                  
553 {                                                 
554   G4VEMDataSet * component(components[argCompo    
555                                                   
556   if (component)                                  
557     {                                             
558       component->SetLogEnergiesData(argEnergie    
559       return;                                     
560     }                                             
561                                                   
562   std::ostringstream message;                     
563   message << "Component " << argComponentId <<    
564                                                   
565   G4Exception("G4MicroElecCrossSectionDataSet_    
566                  FatalException,message.str().    
567                                                   
568 }                                                 
569                                                   
570 //....oooOO0OOooo........oooOO0OOooo........oo    
571                                                   
572 void G4MicroElecCrossSectionDataSet_new::Clean    
573 {                                                 
574   while (!components.empty())                     
575     {                                             
576       if (components.back()) delete components    
577       components.pop_back();                      
578     }                                             
579 }                                                 
580                                                   
581 //....oooOO0OOooo........oooOO0OOooo........oo    
582                                                   
583