Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/toolx/hdf5/h2file

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 /externals/g4tools/include/toolx/hdf5/h2file (Version 11.3.0) and /externals/g4tools/include/toolx/hdf5/h2file (Version 10.0.p2)


  1 // Copyright (C) 2010, Guy Barrand. All rights    
  2 // See the file tools.license for terms.          
  3                                                   
  4 #ifndef toolx_hdf5_h2file                         
  5 #define toolx_hdf5_h2file                         
  6                                                   
  7 #include "tools"                                  
  8 #include "T_tools"                                
  9                                                   
 10 #include <tools/histo/histo_data>                 
 11 #include <tools/sout>                             
 12 #include <ostream>                                
 13                                                   
 14 namespace toolx {                                 
 15 namespace hdf5 {                                  
 16                                                   
 17 }}                                                
 18                                                   
 19 #include <map>                                    
 20                                                   
 21 namespace toolx {                                 
 22 namespace hdf5 {                                  
 23                                                   
 24 inline bool write_std_map_ss(hid_t a_loc,const    
 25                              unsigned int /*a_    
 26   if(!write_scalar<tools::uint64>(a_loc,a_name    
 27   unsigned int count = 0; //uint for num2s.       
 28   std::string scount;                             
 29   tools_mforcit(std::string,std::string,a_map,    
 30     tools::num2s(count,scount);                   
 31     if(!write_string(a_loc,a_name+"_elem_"+sco    
 32     if(!write_string(a_loc,a_name+"_elem_"+sco    
 33     count++;                                      
 34   }                                               
 35   return true;                                    
 36 }                                                 
 37                                                   
 38 inline bool read_std_map_ss(hid_t a_loc,const     
 39                              unsigned int /*a_    
 40   a_map.clear();                                  
 41   tools::uint64 sz;                               
 42   if(!read_scalar<tools::uint64>(a_loc,a_name+    
 43   std::string scount,key,value;                   
 44   for(tools::uint64 count=0;count<sz;count++)     
 45     tools::num2s(count,scount);                   
 46     if(!read_string(a_loc,a_name+"_elem_"+scou    
 47     if(!read_string(a_loc,a_name+"_elem_"+scou    
 48     a_map[key] = value;                           
 49   }                                               
 50   return true;                                    
 51 }                                                 
 52                                                   
 53 typedef tools::histo::histo_data<double,unsign    
 54                                                   
 55 inline bool write_hdata(hid_t a_loc,const hist    
 56                                                   
 57   if(!write_string(a_loc,"title",a_hdata.m_tit    
 58   if(!write_scalar<unsigned int>(a_loc,"dimens    
 59   if(!write_scalar<unsigned int>(a_loc,"bin_nu    
 60                                                   
 61   if(!write_std_vec<unsigned int>(a_loc,"bin_e    
 62   if(!write_std_vec<double>(a_loc,"bin_Sw",a_h    
 63   if(!write_std_vec<double>(a_loc,"bin_Sw2",a_    
 64   if(!write_std_vec_vec<double>(a_loc,"bin_Sxw    
 65   if(!write_std_vec_vec<double>(a_loc,"bin_Sx2    
 66                                                   
 67   // axes :                                       
 68  {std::string name,saxis;                         
 69   for(unsigned int iaxis=0;iaxis<a_hdata.m_dim    
 70     tools::num2s(iaxis,saxis);                    
 71     name = "axis_"+saxis+"_";                     
 72     const histo_data_t::axis_t& _axis = a_hdat    
 73     if(!write_scalar<unsigned int>(a_loc,name+    
 74     if(!write_scalar<unsigned int>(a_loc,name+    
 75     if(!write_scalar<double>(a_loc,name+"minim    
 76     if(!write_scalar<double>(a_loc,name+"maxim    
 77     if(!write_scalar<bool>(a_loc,name+"fixed",    
 78     if(!write_scalar<double>(a_loc,name+"bin_w    
 79     if(!write_std_vec<double>(a_loc,name+"edge    
 80   }}                                              
 81                                                   
 82   // etc :                                        
 83   if(!write_std_vec<double>(a_loc,"in_range_pl    
 84                                                   
 85   // m_annotations :                              
 86   if(!write_std_map_ss(a_loc,"annotations",a_h    
 87                                                   
 88   return true;                                    
 89 }                                                 
 90                                                   
 91 template <class HISTO>                            
 92 inline bool write_histo(std::ostream& a_out,hi    
 93                                                   
 94   hid_t histo = toolx_H5Gcreate(a_loc,a_name.c    
 95   if(histo<0) {                                   
 96     a_out << "toolx::hdf5::write_histo : can't    
 97     ::H5Gclose(histo);                            
 98     return false;                                 
 99   }                                               
100                                                   
101   if(!write_atb(histo,"type","object")) {         
102     a_out << "toolx::hdf5::write_histo : write    
103     ::H5Gclose(histo);                            
104     return false;                                 
105   }                                               
106   if(!write_atb(histo,"class",a_histo.s_cls())    
107     a_out << "toolx::hdf5::write_histo : write    
108     ::H5Gclose(histo);                            
109     return false;                                 
110   }                                               
111   int v = 1;                                      
112   if(!write_scalar_atb<int>(histo,"version",v)    
113     a_out << "toolx::hdf5::write_histo : write    
114     ::H5Gclose(histo);                            
115     return false;                                 
116   }                                               
117                                                   
118   if(!write_hdata(histo,a_histo.dac())) {::H5G    
119                                                   
120   ::H5Gclose(histo);                              
121                                                   
122   a_histo.not_a_profile(); //trick to be sure     
123                                                   
124   return true;                                    
125 }                                                 
126                                                   
127 template <class PROFILE>                          
128 inline bool write_profile(std::ostream& a_out,    
129                                                   
130   hid_t histo = toolx_H5Gcreate(a_loc,a_name.c    
131   if(histo<0) {                                   
132     a_out << "toolx::hdf5::write_profile : can    
133     ::H5Gclose(histo);                            
134     return false;                                 
135   }                                               
136                                                   
137   if(!write_atb(histo,"type","object")) {         
138     a_out << "toolx::hdf5::write_profile : wri    
139     ::H5Gclose(histo);                            
140     return false;                                 
141   }                                               
142   if(!write_atb(histo,"class",a_histo.s_cls())    
143     a_out << "toolx::hdf5::write_profile : wri    
144     ::H5Gclose(histo);                            
145     return false;                                 
146   }                                               
147   int v = 1;                                      
148   if(!write_scalar_atb<int>(histo,"version",v)    
149     a_out << "toolx::hdf5::write_profile : wri    
150     ::H5Gclose(histo);                            
151     return false;                                 
152   }                                               
153                                                   
154   typename PROFILE::pd_t pdata = a_histo.get_h    
155                                                   
156   if(!write_hdata(histo,pdata)) {::H5Gclose(hi    
157                                                   
158   if(!write_bool(histo,"is_profile",pdata.m_is    
159   if(!write_std_vec<double>(histo,"bin_Svw",pd    
160   if(!write_std_vec<double>(histo,"bin_Sv2w",p    
161   if(!write_bool(histo,"cut_v",pdata.m_cut_v))    
162   if(!write_scalar<double>(histo,"min_v",pdata    
163   if(!write_scalar<double>(histo,"max_v",pdata    
164                                                   
165   ::H5Gclose(histo);                              
166                                                   
167   return true;                                    
168 }                                                 
169                                                   
170 inline bool read_hdata(hid_t a_loc,histo_data_    
171   if(!read_string(a_loc,"title",a_hdata.m_titl    
172   if(!read_scalar<unsigned int>(a_loc,"dimensi    
173   if(!read_scalar<unsigned int>(a_loc,"bin_num    
174                                                   
175   if(!read_std_vec<unsigned int>(a_loc,"bin_en    
176   if(!read_std_vec<double>(a_loc,"bin_Sw",a_hd    
177   if(!read_std_vec<double>(a_loc,"bin_Sw2",a_h    
178                                                   
179   if(!read_std_vec_vec<double>(a_loc,"bin_Sxw"    
180   if(!read_std_vec_vec<double>(a_loc,"bin_Sx2w    
181                                                   
182   // axes :                                       
183  {a_hdata.m_axes.resize(a_hdata.m_dimension);     
184   std::string name,saxis;                         
185   for(unsigned int iaxis=0;iaxis<a_hdata.m_dim    
186     tools::num2s(iaxis,saxis);                    
187     name = "axis_"+saxis+"_";                     
188     histo_data_t::axis_t& _axis = a_hdata.m_ax    
189     if(!read_scalar<unsigned int>(a_loc,name+"    
190     if(!read_scalar<unsigned int>(a_loc,name+"    
191     if(!read_scalar<double>(a_loc,name+"minimu    
192     if(!read_scalar<double>(a_loc,name+"maximu    
193     if(!read_scalar<bool>(a_loc,name+"fixed",_    
194     if(!read_scalar<double>(a_loc,name+"bin_wi    
195     if(!read_std_vec<double>(a_loc,name+"edges    
196   }}                                              
197                                                   
198   // etc :                                        
199   if(!read_std_vec<double>(a_loc,"in_range_pla    
200                                                   
201   // m_annotations :                              
202   if(!read_std_map_ss(a_loc,"annotations",a_hd    
203                                                   
204   return true;                                    
205 }                                                 
206                                                   
207 template <class HISTO>                            
208 inline bool read_histo(std::ostream& a_out,hid    
209   a_histo = 0;                                    
210                                                   
211   //if(::H5Gget_objinfo(a_loc,a_name.c_str(),0    
212                                                   
213   hid_t histo = toolx_H5Gopen(a_loc,a_name.c_s    
214   if(histo<0) {                                   
215     a_out << "toolx::hdf5::read_histo : can't     
216     return false;                                 
217   }                                               
218                                                   
219   std::string sclass;                             
220   if(!read_atb(histo,"class",sclass)) {           
221     a_out << "toolx::hdf5::read_histo : can't     
222     ::H5Gclose(histo);                            
223     return false;                                 
224   }                                               
225                                                   
226   if(sclass!=HISTO::s_class()) {                  
227     if(a_verb_class) {                            
228       a_out << "toolx::hdf5::read_histo :"        
229             << " read class " << tools::sout(s    
230     }                                             
231     ::H5Gclose(histo);                            
232     return false;                                 
233   }                                               
234                                                   
235   int v;                                          
236   if(!read_atb(histo,"version",v)) {              
237     a_out << "toolx::hdf5::read_histo : read_a    
238     ::H5Gclose(histo);                            
239     return false;                                 
240   }                                               
241                                                   
242   histo_data_t hdata;                             
243                                                   
244   if(!read_hdata(histo,hdata)) {::H5Gclose(his    
245                                                   
246   ::H5Gclose(histo);                              
247                                                   
248   hdata.update_fast_getters();                    
249                                                   
250   a_histo = new HISTO;                            
251   a_histo->copy_from_data(hdata);                 
252   a_histo->not_a_profile(); //trick to be sure    
253   return true;                                    
254 }                                                 
255                                                   
256 template <class PROFILE>                          
257 inline bool read_profile(std::ostream& a_out,h    
258   a_histo = 0;                                    
259                                                   
260   hid_t histo = toolx_H5Gopen(a_loc,a_name.c_s    
261   if(histo<0) {                                   
262     a_out << "toolx::hdf5::read_profile : can'    
263     return false;                                 
264   }                                               
265                                                   
266   std::string sclass;                             
267   if(!read_atb(histo,"class",sclass)) {           
268     a_out << "toolx::hdf5::read_profile : can'    
269     ::H5Gclose(histo);                            
270     return false;                                 
271   }                                               
272                                                   
273   if(sclass!=PROFILE::s_class()) {                
274     if(a_verb_class) {                            
275       a_out << "toolx::hdf5::read_profile :"      
276             << " read class " << tools::sout(s    
277     }                                             
278     ::H5Gclose(histo);                            
279     return false;                                 
280   }                                               
281                                                   
282   int v;                                          
283   if(!read_atb(histo,"version",v)) {              
284     a_out << "toolx::hdf5::read_profile : read    
285     ::H5Gclose(histo);                            
286     return false;                                 
287   }                                               
288                                                   
289   typename PROFILE::pd_t pdata;                   
290                                                   
291   if(!read_hdata(histo,pdata)) {::H5Gclose(his    
292                                                   
293   if(!read_bool(histo,"is_profile",pdata.m_is_    
294   if(!read_std_vec<double>(histo,"bin_Svw",pda    
295   if(!read_std_vec<double>(histo,"bin_Sv2w",pd    
296   if(!read_bool(histo,"cut_v",pdata.m_cut_v))     
297   if(!read_scalar<double>(histo,"min_v",pdata.    
298   if(!read_scalar<double>(histo,"max_v",pdata.    
299                                                   
300   ::H5Gclose(histo);                              
301                                                   
302   pdata.update_fast_getters();                    
303                                                   
304   a_histo = new PROFILE;                          
305   a_histo->copy_from_data(pdata);                 
306   return true;                                    
307 }                                                 
308                                                   
309 inline bool read_class_version(std::ostream& a    
310                                std::string& a_    
311   hid_t id = toolx_H5Gopen(a_loc,a_name.c_str(    
312   if(id<0) {                                      
313     if(a_verbose) a_out << "toolx::hdf5::read_    
314     a_class.clear();                              
315     a_version = 0;                                
316     return false;                                 
317   }                                               
318                                                   
319   if(!read_atb(id,"class",a_class)) {             
320     if(a_verbose) a_out << "toolx::hdf5::read_    
321     ::H5Gclose(id);                               
322     a_class.clear();                              
323     a_version = 0;                                
324     return false;                                 
325   }                                               
326                                                   
327   if(!read_atb(id,"version",a_version)) {         
328     if(a_verbose) a_out << "toolx::hdf5::read_    
329     ::H5Gclose(id);                               
330     a_class.clear();                              
331     a_version = 0;                                
332     return false;                                 
333   }                                               
334                                                   
335   ::H5Gclose(id);                                 
336   return true;                                    
337 }                                                 
338                                                   
339 }}                                                
340                                                   
341                                                   
342 #endif