Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/tools/histo/b3

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/tools/histo/b3 (Version 11.3.0) and /externals/g4tools/include/tools/histo/b3 (Version 11.1.3)


  1 // Copyright (C) 2010, Guy Barrand. All rights      1 // Copyright (C) 2010, Guy Barrand. All rights reserved.
  2 // See the file tools.license for terms.            2 // See the file tools.license for terms.
  3                                                     3 
  4 #ifndef tools_histo_b3                              4 #ifndef tools_histo_b3
  5 #define tools_histo_b3                              5 #define tools_histo_b3
  6                                                     6 
  7 #include "base_histo"                               7 #include "base_histo"
  8                                                     8 
  9 #include <ostream>                                  9 #include <ostream>
 10                                                    10 
 11 namespace tools {                                  11 namespace tools {
 12 namespace histo {                                  12 namespace histo {
 13                                                    13 
 14 template <class TC,class TO,class TN,class TW,     14 template <class TC,class TO,class TN,class TW,class TH>
 15 class b3 : public base_histo<TC,TO,TN,TW,TH> {     15 class b3 : public base_histo<TC,TO,TN,TW,TH> {
 16   typedef base_histo<TC,TO,TN,TW,TH> parent;       16   typedef base_histo<TC,TO,TN,TW,TH> parent;
 17 public:                                            17 public:
 18   typedef base_histo<TC,TO,TN,TW,TH> base_hist     18   typedef base_histo<TC,TO,TN,TW,TH> base_histo_t;
 19   typedef typename parent::axis_t axis_t;          19   typedef typename parent::axis_t axis_t;
 20   typedef typename parent::bn_t bn_t;              20   typedef typename parent::bn_t bn_t;
 21 protected:                                         21 protected:
 22   enum {AxisX=0,AxisY=1,AxisZ=2};                  22   enum {AxisX=0,AxisY=1,AxisZ=2};
 23 public:                                            23 public:
 24   virtual TH bin_error(int,int,int) const = 0;     24   virtual TH bin_error(int,int,int) const = 0; //for print
 25 public:                                            25 public:
 26   // Partition :                                   26   // Partition :
 27   int coord_to_index_x(TC aCoord) const {          27   int coord_to_index_x(TC aCoord) const {
 28     return axis_x().coord_to_index(aCoord);        28     return axis_x().coord_to_index(aCoord);
 29   }                                                29   }
 30   int coord_to_index_y(TC aCoord) const {          30   int coord_to_index_y(TC aCoord) const {
 31     return axis_y().coord_to_index(aCoord);        31     return axis_y().coord_to_index(aCoord);
 32   }                                                32   }
 33   int coord_to_index_z(TC aCoord) const {          33   int coord_to_index_z(TC aCoord) const {
 34     return axis_z().coord_to_index(aCoord);        34     return axis_z().coord_to_index(aCoord);
 35   }                                                35   }
 36                                                    36 
 37   TC mean_x() const {                              37   TC mean_x() const {
 38     if(parent::m_in_range_Sw==0) return 0;         38     if(parent::m_in_range_Sw==0) return 0;
 39     return parent::m_in_range_Sxw[0]/parent::m     39     return parent::m_in_range_Sxw[0]/parent::m_in_range_Sw;
 40   }                                                40   }
 41                                                    41 
 42   TC mean_y() const {                              42   TC mean_y() const {
 43     if(parent::m_in_range_Sw==0) return 0;         43     if(parent::m_in_range_Sw==0) return 0;
 44     return parent::m_in_range_Sxw[1]/parent::m     44     return parent::m_in_range_Sxw[1]/parent::m_in_range_Sw;
 45   }                                                45   }
 46                                                    46 
 47   TC mean_z() const {                              47   TC mean_z() const {
 48     if(parent::m_in_range_Sw==0) return 0;         48     if(parent::m_in_range_Sw==0) return 0;
 49     return parent::m_in_range_Sxw[2]/parent::m     49     return parent::m_in_range_Sxw[2]/parent::m_in_range_Sw;
 50   }                                                50   }
 51                                                    51 
 52   TC rms_x() const {                               52   TC rms_x() const {
 53     if(parent::m_in_range_Sw==0) return 0;         53     if(parent::m_in_range_Sw==0) return 0;
 54     TC mean = parent::m_in_range_Sxw[0]/parent     54     TC mean = parent::m_in_range_Sxw[0]/parent::m_in_range_Sw;
 55     return ::sqrt(::fabs((parent::m_in_range_S     55     return ::sqrt(::fabs((parent::m_in_range_Sx2w[0] / parent::m_in_range_Sw) - mean * mean));
 56   }                                                56   }
 57                                                    57 
 58   TC rms_y() const {                               58   TC rms_y() const {
 59     if(parent::m_in_range_Sw==0) return 0;         59     if(parent::m_in_range_Sw==0) return 0;
 60     TC mean = parent::m_in_range_Sxw[1]/parent     60     TC mean = parent::m_in_range_Sxw[1]/parent::m_in_range_Sw;
 61     return ::sqrt(::fabs((parent::m_in_range_S     61     return ::sqrt(::fabs((parent::m_in_range_Sx2w[1] / parent::m_in_range_Sw) - mean * mean));
 62   }                                                62   }
 63                                                    63 
 64   TC rms_z() const {                               64   TC rms_z() const {
 65     if(parent::m_in_range_Sw==0) return 0;         65     if(parent::m_in_range_Sw==0) return 0;
 66     TC mean = parent::m_in_range_Sxw[2]/parent     66     TC mean = parent::m_in_range_Sxw[2]/parent::m_in_range_Sw;
 67     return ::sqrt(::fabs((parent::m_in_range_S     67     return ::sqrt(::fabs((parent::m_in_range_Sx2w[2] / parent::m_in_range_Sw) - mean * mean));
 68   }                                                68   }
 69                                                    69 
 70   // bins :                                        70   // bins :
 71   TN bin_entries(int aI,int aJ,int aK) const {     71   TN bin_entries(int aI,int aJ,int aK) const {
 72     TO offset;                                     72     TO offset;
 73     if(!_find_offset(aI,aJ,aK,offset)) return      73     if(!_find_offset(aI,aJ,aK,offset)) return 0;
 74     return parent::m_bin_entries[offset];          74     return parent::m_bin_entries[offset];
 75   }                                                75   }
 76                                                    76 
 77   TH bin_height(int aI,int aJ,int aK) const {      77   TH bin_height(int aI,int aJ,int aK) const {
 78     TO offset;                                     78     TO offset;
 79     if(!_find_offset(aI,aJ,aK,offset)) return      79     if(!_find_offset(aI,aJ,aK,offset)) return 0;
 80     return this->get_bin_height(offset);           80     return this->get_bin_height(offset);
 81   }                                                81   }
 82                                                    82 
 83   TC bin_center_x(int aI) const {return parent     83   TC bin_center_x(int aI) const {return parent::m_axes[0].bin_center(aI);}
 84   TC bin_center_y(int aJ) const {return parent     84   TC bin_center_y(int aJ) const {return parent::m_axes[1].bin_center(aJ);}
 85   TC bin_center_z(int aK) const {return parent     85   TC bin_center_z(int aK) const {return parent::m_axes[2].bin_center(aK);}
 86                                                    86 
 87   TC bin_mean_x(int aI,int aJ,int aK) const {      87   TC bin_mean_x(int aI,int aJ,int aK) const {
 88     TO offset;                                     88     TO offset;
 89     if(!_find_offset(aI,aJ,aK,offset)) return      89     if(!_find_offset(aI,aJ,aK,offset)) return 0;
 90     TW sw = parent::m_bin_Sw[offset];              90     TW sw = parent::m_bin_Sw[offset];
 91     if(sw==0) return 0;                            91     if(sw==0) return 0;
 92     return parent::m_bin_Sxw[offset][AxisX]/sw     92     return parent::m_bin_Sxw[offset][AxisX]/sw;
 93   }                                                93   }
 94                                                    94 
 95   TC bin_mean_y(int aI,int aJ,int aK) const {      95   TC bin_mean_y(int aI,int aJ,int aK) const {
 96     TO offset;                                     96     TO offset;
 97     if(!_find_offset(aI,aJ,aK,offset)) return      97     if(!_find_offset(aI,aJ,aK,offset)) return 0;
 98     TW sw = parent::m_bin_Sw[offset];              98     TW sw = parent::m_bin_Sw[offset];
 99     if(sw==0) return 0;                            99     if(sw==0) return 0;
100     return parent::m_bin_Sxw[offset][AxisY]/sw    100     return parent::m_bin_Sxw[offset][AxisY]/sw;
101   }                                               101   }
102                                                   102 
103   TC bin_mean_z(int aI,int aJ,int aK) const {     103   TC bin_mean_z(int aI,int aJ,int aK) const {
104     TO offset;                                    104     TO offset;
105     if(!_find_offset(aI,aJ,aK,offset)) return     105     if(!_find_offset(aI,aJ,aK,offset)) return 0;
106     TW sw = parent::m_bin_Sw[offset];             106     TW sw = parent::m_bin_Sw[offset];
107     if(sw==0) return 0;                           107     if(sw==0) return 0;
108     return parent::m_bin_Sxw[offset][AxisZ]/sw    108     return parent::m_bin_Sxw[offset][AxisZ]/sw;
109   }                                               109   }
110                                                   110 
111   TC bin_rms_x(int aI,int aJ,int aK) const {      111   TC bin_rms_x(int aI,int aJ,int aK) const {
112     TO offset;                                    112     TO offset;
113     if(!_find_offset(aI,aJ,aK,offset)) return     113     if(!_find_offset(aI,aJ,aK,offset)) return 0;
114     TW sw = parent::m_bin_Sw[offset];             114     TW sw = parent::m_bin_Sw[offset];
115     if(sw==0) return 0;                           115     if(sw==0) return 0;
116     TC sxw = parent::m_bin_Sxw[offset][AxisX];    116     TC sxw = parent::m_bin_Sxw[offset][AxisX];
117     TC sx2w = parent::m_bin_Sx2w[offset][AxisX    117     TC sx2w = parent::m_bin_Sx2w[offset][AxisX];
118     TC mean = sxw/sw;                             118     TC mean = sxw/sw;
119     return ::sqrt(::fabs((sx2w / sw) - mean *     119     return ::sqrt(::fabs((sx2w / sw) - mean * mean));
120   }                                               120   }
121                                                   121 
122   TC bin_rms_y(int aI,int aJ,int aK) const {      122   TC bin_rms_y(int aI,int aJ,int aK) const {
123     TO offset;                                    123     TO offset;
124     if(!_find_offset(aI,aJ,aK,offset)) return     124     if(!_find_offset(aI,aJ,aK,offset)) return 0;
125     TW sw = parent::m_bin_Sw[offset];             125     TW sw = parent::m_bin_Sw[offset];
126     if(sw==0) return 0;                           126     if(sw==0) return 0;
127     TC sxw = parent::m_bin_Sxw[offset][AxisY];    127     TC sxw = parent::m_bin_Sxw[offset][AxisY];
128     TC sx2w = parent::m_bin_Sx2w[offset][AxisY    128     TC sx2w = parent::m_bin_Sx2w[offset][AxisY];
129     TC mean = sxw/sw;                             129     TC mean = sxw/sw;
130     return ::sqrt(::fabs((sx2w / sw) - mean *     130     return ::sqrt(::fabs((sx2w / sw) - mean * mean));
131   }                                               131   }
132                                                   132 
133   TC bin_rms_z(int aI,int aJ,int aK) const {      133   TC bin_rms_z(int aI,int aJ,int aK) const {
134     TO offset;                                    134     TO offset;
135     if(!_find_offset(aI,aJ,aK,offset)) return     135     if(!_find_offset(aI,aJ,aK,offset)) return 0;
136     TW sw = parent::m_bin_Sw[offset];             136     TW sw = parent::m_bin_Sw[offset];
137     if(sw==0) return 0;                           137     if(sw==0) return 0;
138     TC sxw = parent::m_bin_Sxw[offset][AxisZ];    138     TC sxw = parent::m_bin_Sxw[offset][AxisZ];
139     TC sx2w = parent::m_bin_Sx2w[offset][AxisZ    139     TC sx2w = parent::m_bin_Sx2w[offset][AxisZ];
140     TC mean = sxw/sw;                             140     TC mean = sxw/sw;
141     return ::sqrt(::fabs((sx2w / sw) - mean *     141     return ::sqrt(::fabs((sx2w / sw) - mean * mean));
142   }                                               142   }
143                                                   143 
144   // Axes :                                       144   // Axes :
145   const axis_t& axis_x() const {return parent:    145   const axis_t& axis_x() const {return parent::m_axes[0];}
146   const axis_t& axis_y() const {return parent:    146   const axis_t& axis_y() const {return parent::m_axes[1];}
147   const axis_t& axis_z() const {return parent:    147   const axis_t& axis_z() const {return parent::m_axes[2];}
148   axis_t& axis_x() {return parent::m_axes[0];}    148   axis_t& axis_x() {return parent::m_axes[0];} //touchy
149   axis_t& axis_y() {return parent::m_axes[1];}    149   axis_t& axis_y() {return parent::m_axes[1];} //touchy
150   axis_t& axis_z() {return parent::m_axes[2];}    150   axis_t& axis_z() {return parent::m_axes[2];} //touchy
151                                                   151 
152   // Projection :                                 152   // Projection :
153   TN bin_entries_x(int aI) const {                153   TN bin_entries_x(int aI) const {
154     if(!parent::m_dimension) return 0;            154     if(!parent::m_dimension) return 0;
155     bn_t ibin;                                    155     bn_t ibin;
156     if(!parent::m_axes[0].in_range_to_absolute    156     if(!parent::m_axes[0].in_range_to_absolute_index(aI,ibin)) return 0;
157     bn_t jbin,kbin,offset;                        157     bn_t jbin,kbin,offset;
158     bn_t ybins = parent::m_axes[1].bins()+2;      158     bn_t ybins = parent::m_axes[1].bins()+2;
159     bn_t zbins = parent::m_axes[2].bins()+2;      159     bn_t zbins = parent::m_axes[2].bins()+2;
160     TO yoffset = parent::m_axes[1].m_offset;      160     TO yoffset = parent::m_axes[1].m_offset;
161     TO zoffset = parent::m_axes[2].m_offset;      161     TO zoffset = parent::m_axes[2].m_offset;
162     TO joffset = ibin;                            162     TO joffset = ibin;
163     TN _entries = 0;                              163     TN _entries = 0;
164     for(jbin=0;jbin<ybins;jbin++) {               164     for(jbin=0;jbin<ybins;jbin++) {
165       //joffset = ibin + jbin * parent::m_axes    165       //joffset = ibin + jbin * parent::m_axes[1].m_offset;
166       offset = joffset;                           166       offset = joffset;
167       for(kbin=0;kbin<zbins;kbin++) {             167       for(kbin=0;kbin<zbins;kbin++) {
168         //offset = joffset + kbin * parent::m_    168         //offset = joffset + kbin * parent::m_axes[2].m_offset;
169         _entries += parent::m_bin_entries[offs    169         _entries += parent::m_bin_entries[offset];
170         offset += zoffset;                        170         offset += zoffset;
171       }                                           171       }
172       joffset += yoffset;                         172       joffset += yoffset;
173     }                                             173     }
174     return _entries;                              174     return _entries;
175   }                                               175   }
176                                                   176 
177   TN bin_entries_y(int aJ) const {                177   TN bin_entries_y(int aJ) const {
178     if(!parent::m_dimension) return 0;            178     if(!parent::m_dimension) return 0;
179     bn_t jbin;                                    179     bn_t jbin;
180     if(!parent::m_axes[1].in_range_to_absolute    180     if(!parent::m_axes[1].in_range_to_absolute_index(aJ,jbin)) return 0;
181     bn_t ibin,kbin;                               181     bn_t ibin,kbin;
182     TO offset;                                    182     TO offset;
183     bn_t xbins = parent::m_axes[0].bins()+2;      183     bn_t xbins = parent::m_axes[0].bins()+2;
184     bn_t zbins = parent::m_axes[2].bins()+2;      184     bn_t zbins = parent::m_axes[2].bins()+2;
185     TO yoffset = parent::m_axes[1].m_offset;      185     TO yoffset = parent::m_axes[1].m_offset;
186     TO zoffset = parent::m_axes[2].m_offset;      186     TO zoffset = parent::m_axes[2].m_offset;
187     TO joffset = jbin * yoffset;                  187     TO joffset = jbin * yoffset;
188     TN _entries = 0;                              188     TN _entries = 0;
189     for(ibin=0;ibin<xbins;ibin++) {               189     for(ibin=0;ibin<xbins;ibin++) {
190       //joffset = ibin + jbin * parent::m_axes    190       //joffset = ibin + jbin * parent::m_axes[1].m_offset;
191       offset = joffset;                           191       offset = joffset;
192       for(kbin=0;kbin<zbins;kbin++) {             192       for(kbin=0;kbin<zbins;kbin++) {
193         //offset = joffset + kbin * parent::m_    193         //offset = joffset + kbin * parent::m_axes[2].m_offset;
194         _entries += parent::m_bin_entries[offs    194         _entries += parent::m_bin_entries[offset];
195         offset += zoffset;                        195         offset += zoffset;
196       }                                           196       }
197       joffset++;                                  197       joffset++;
198     }                                             198     }
199     return _entries;                              199     return _entries;
200   }                                               200   }
201                                                   201 
202   TN bin_entries_z(int aK) const {                202   TN bin_entries_z(int aK) const {
203     if(!parent::m_dimension) return 0;            203     if(!parent::m_dimension) return 0;
204     bn_t kbin;                                    204     bn_t kbin;
205     if(!parent::m_axes[2].in_range_to_absolute    205     if(!parent::m_axes[2].in_range_to_absolute_index(aK,kbin)) return 0;
206     bn_t ibin,jbin;                               206     bn_t ibin,jbin;
207     TO offset;                                    207     TO offset;
208     bn_t xbins = parent::m_axes[0].bins()+2;      208     bn_t xbins = parent::m_axes[0].bins()+2;
209     bn_t ybins = parent::m_axes[1].bins()+2;      209     bn_t ybins = parent::m_axes[1].bins()+2;
210     TO yoffset = parent::m_axes[1].m_offset;      210     TO yoffset = parent::m_axes[1].m_offset;
211     TO zoffset = parent::m_axes[2].m_offset;      211     TO zoffset = parent::m_axes[2].m_offset;
212     TO koffset = kbin * zoffset;                  212     TO koffset = kbin * zoffset;
213     TN _entries = 0;                              213     TN _entries = 0;
214     for(ibin=0;ibin<xbins;ibin++) {               214     for(ibin=0;ibin<xbins;ibin++) {
215       //koffset = ibin + kbin * parent::m_axes    215       //koffset = ibin + kbin * parent::m_axes[2].m_offset;
216       offset = koffset;                           216       offset = koffset;
217       for(jbin=0;jbin<ybins;jbin++) {             217       for(jbin=0;jbin<ybins;jbin++) {
218         //offset = koffset + jbin * parent::m_    218         //offset = koffset + jbin * parent::m_axes[1].m_offset;
219         _entries += parent::m_bin_entries[offs    219         _entries += parent::m_bin_entries[offset];
220         offset += yoffset;                        220         offset += yoffset;
221       }                                           221       }
222       koffset++;                                  222       koffset++;
223     }                                             223     }
224     return _entries;                              224     return _entries;
225   }                                               225   }
226                                                   226 
227   TW bin_height_x(int aI) const {                 227   TW bin_height_x(int aI) const {
228     //to slow : return get_ith_axis_bin_height    228     //to slow : return get_ith_axis_bin_height(0,aI);
229     if(!parent::m_dimension) return 0;            229     if(!parent::m_dimension) return 0;
230     bn_t ibin;                                    230     bn_t ibin;
231     if(!parent::m_axes[0].in_range_to_absolute    231     if(!parent::m_axes[0].in_range_to_absolute_index(aI,ibin)) return 0;
232     bn_t ybins = parent::m_axes[1].bins()+2;      232     bn_t ybins = parent::m_axes[1].bins()+2;
233     bn_t zbins = parent::m_axes[2].bins()+2;      233     bn_t zbins = parent::m_axes[2].bins()+2;
234     TO yoffset = parent::m_axes[1].m_offset;      234     TO yoffset = parent::m_axes[1].m_offset;
235     TO zoffset = parent::m_axes[2].m_offset;      235     TO zoffset = parent::m_axes[2].m_offset;
236     TO joffset = ibin;                            236     TO joffset = ibin;
237     TW sw = 0;                                    237     TW sw = 0;
238     for(bn_t jbin=0;jbin<ybins;jbin++) {          238     for(bn_t jbin=0;jbin<ybins;jbin++) {
239       //joffset = ibin + jbin * parent::m_axes    239       //joffset = ibin + jbin * parent::m_axes[1].m_offset;
240       TO offset = joffset;                        240       TO offset = joffset;
241       for(bn_t kbin=0;kbin<zbins;kbin++) {        241       for(bn_t kbin=0;kbin<zbins;kbin++) {
242         //offset = joffset + kbin * parent::m_    242         //offset = joffset + kbin * parent::m_axes[2].m_offset;
243         sw += this->get_bin_height(offset);       243         sw += this->get_bin_height(offset);
244         offset += zoffset;                        244         offset += zoffset;
245       }                                           245       }
246       joffset += yoffset;                         246       joffset += yoffset;
247     }                                             247     }
248     return sw;                                    248     return sw;
249   }                                               249   }
250                                                   250 
251   TW bin_height_y(int aJ) const {                 251   TW bin_height_y(int aJ) const {
252     if(!parent::m_dimension) return 0;            252     if(!parent::m_dimension) return 0;
253     bn_t jbin;                                    253     bn_t jbin;
254     if(!parent::m_axes[1].in_range_to_absolute    254     if(!parent::m_axes[1].in_range_to_absolute_index(aJ,jbin)) return 0;
255     bn_t xbins = parent::m_axes[0].bins()+2;      255     bn_t xbins = parent::m_axes[0].bins()+2;
256     bn_t zbins = parent::m_axes[2].bins()+2;      256     bn_t zbins = parent::m_axes[2].bins()+2;
257     TO yoffset = parent::m_axes[1].m_offset;      257     TO yoffset = parent::m_axes[1].m_offset;
258     TO zoffset = parent::m_axes[2].m_offset;      258     TO zoffset = parent::m_axes[2].m_offset;
259     TO joffset = jbin * yoffset;                  259     TO joffset = jbin * yoffset;
260     TW sw = 0;                                    260     TW sw = 0;
261     for(bn_t ibin=0;ibin<xbins;ibin++) {          261     for(bn_t ibin=0;ibin<xbins;ibin++) {
262       //joffset = ibin + jbin * parent::m_axes    262       //joffset = ibin + jbin * parent::m_axes[1].m_offset;
263       TO offset = joffset;                        263       TO offset = joffset;
264       for(bn_t kbin=0;kbin<zbins;kbin++) {        264       for(bn_t kbin=0;kbin<zbins;kbin++) {
265         //offset = joffset + kbin * parent::m_    265         //offset = joffset + kbin * parent::m_axes[2].m_offset;
266         sw += this->get_bin_height(offset);       266         sw += this->get_bin_height(offset);
267         offset += zoffset;                        267         offset += zoffset;
268       }                                           268       }
269       joffset++;                                  269       joffset++;
270     }                                             270     }
271     return sw;                                    271     return sw;
272   }                                               272   }
273                                                   273 
274   TW bin_height_z(int aK) const {                 274   TW bin_height_z(int aK) const {
275     if(!parent::m_dimension) return 0;            275     if(!parent::m_dimension) return 0;
276     bn_t kbin;                                    276     bn_t kbin;
277     if(!parent::m_axes[2].in_range_to_absolute    277     if(!parent::m_axes[2].in_range_to_absolute_index(aK,kbin)) return 0;
278     bn_t xbins = parent::m_axes[0].bins()+2;      278     bn_t xbins = parent::m_axes[0].bins()+2;
279     bn_t ybins = parent::m_axes[1].bins()+2;      279     bn_t ybins = parent::m_axes[1].bins()+2;
280     TO yoffset = parent::m_axes[1].m_offset;      280     TO yoffset = parent::m_axes[1].m_offset;
281     TO zoffset = parent::m_axes[2].m_offset;      281     TO zoffset = parent::m_axes[2].m_offset;
282     TO koffset = kbin * zoffset;                  282     TO koffset = kbin * zoffset;
283     TW sw = 0;                                    283     TW sw = 0;
284     for(bn_t ibin=0;ibin<xbins;ibin++) {          284     for(bn_t ibin=0;ibin<xbins;ibin++) {
285       //koffset = ibin + kbin * parent::m_axes    285       //koffset = ibin + kbin * parent::m_axes[2].m_offset;
286       TO offset = koffset;                        286       TO offset = koffset;
287       for(bn_t jbin=0;jbin<ybins;jbin++) {        287       for(bn_t jbin=0;jbin<ybins;jbin++) {
288         //offset = koffset + jbin * parent::m_    288         //offset = koffset + jbin * parent::m_axes[1].m_offset;
289         sw += this->get_bin_height(offset);       289         sw += this->get_bin_height(offset);
290         offset += yoffset;                        290         offset += yoffset;
291       }                                           291       }
292       koffset++;                                  292       koffset++;
293     }                                             293     }
294     return sw;                                    294     return sw;
295   }                                               295   }
296                                                   296 
297   TC Sxyw() const {return parent::m_in_range_p    297   TC Sxyw() const {return parent::m_in_range_plane_Sxyw[0];}
298   TC Syzw() const {return parent::m_in_range_p    298   TC Syzw() const {return parent::m_in_range_plane_Sxyw[1];}
299   TC Szxw() const {return parent::m_in_range_p    299   TC Szxw() const {return parent::m_in_range_plane_Sxyw[2];}
300 public:                                           300 public:
301   //NOTE : print is a Python keyword.             301   //NOTE : print is a Python keyword.
302   void hprint(std::ostream& a_out) {              302   void hprint(std::ostream& a_out) {
303     // A la HPRINT.                               303     // A la HPRINT.
304     a_out << parent::dimension() << parent::ti    304     a_out << parent::dimension() << parent::title() << std::endl;
305     a_out                                         305     a_out
306       << " * ENTRIES = " << parent::all_entrie    306       << " * ENTRIES = " << parent::all_entries() << std::endl;
307                                                   307 
308   }                                               308   }
309 public:                                           309 public:
310   b3(const std::string& a_title,                  310   b3(const std::string& a_title,
311      bn_t aXnumber,TC aXmin,TC aXmax,             311      bn_t aXnumber,TC aXmin,TC aXmax,
312      bn_t aYnumber,TC aYmin,TC aYmax,             312      bn_t aYnumber,TC aYmin,TC aYmax,
313      bn_t aZnumber,TC aZmin,TC aZmax)             313      bn_t aZnumber,TC aZmin,TC aZmax)
314   {                                               314   {
315     parent::m_title = a_title;                    315     parent::m_title = a_title;
316     std::vector<bn_t> nbins;                      316     std::vector<bn_t> nbins;
317     nbins.push_back(aXnumber);                    317     nbins.push_back(aXnumber);
318     nbins.push_back(aYnumber);                    318     nbins.push_back(aYnumber);
319     nbins.push_back(aZnumber);                    319     nbins.push_back(aZnumber);
320     std::vector<TC> mins;                         320     std::vector<TC> mins;
321     mins.push_back(aXmin);                        321     mins.push_back(aXmin);
322     mins.push_back(aYmin);                        322     mins.push_back(aYmin);
323     mins.push_back(aZmin);                        323     mins.push_back(aZmin);
324     std::vector<TC> maxs;                         324     std::vector<TC> maxs;
325     maxs.push_back(aXmax);                        325     maxs.push_back(aXmax);
326     maxs.push_back(aYmax);                        326     maxs.push_back(aYmax);
327     maxs.push_back(aZmax);                        327     maxs.push_back(aZmax);
328     parent::configure(3,nbins,mins,maxs);         328     parent::configure(3,nbins,mins,maxs);
329   }                                               329   }
330                                                   330 
331   b3(const std::string& a_title,                  331   b3(const std::string& a_title,
332      const std::vector<TC>& a_edges_x,            332      const std::vector<TC>& a_edges_x,
333      const std::vector<TC>& a_edges_y,            333      const std::vector<TC>& a_edges_y,
334      const std::vector<TC>& a_edges_z)            334      const std::vector<TC>& a_edges_z)
335   {                                               335   {
336     parent::m_title = a_title;                    336     parent::m_title = a_title;
337     std::vector< std::vector<TC> > edges(3);      337     std::vector< std::vector<TC> > edges(3);
338     edges[0] = a_edges_x;                         338     edges[0] = a_edges_x;
339     edges[1] = a_edges_y;                         339     edges[1] = a_edges_y;
340     edges[2] = a_edges_z;                         340     edges[2] = a_edges_z;
341     parent::configure(3,edges);                   341     parent::configure(3,edges);
342   }                                               342   }
343                                                   343 
344   virtual ~b3(){}                                 344   virtual ~b3(){}
345 protected:                                        345 protected:
346   b3(const b3& a_from):parent(a_from) {}          346   b3(const b3& a_from):parent(a_from) {}
347   b3& operator=(const b3& a_from){parent::oper    347   b3& operator=(const b3& a_from){parent::operator=(a_from);return *this;}
348 public:                                           348 public:
349   bool configure(bn_t aXnumber,TC aXmin,TC aXm    349   bool configure(bn_t aXnumber,TC aXmin,TC aXmax,
350                  bn_t aYnumber,TC aYmin,TC aYm    350                  bn_t aYnumber,TC aYmin,TC aYmax,
351                  bn_t aZnumber,TC aZmin,TC aZm    351                  bn_t aZnumber,TC aZmin,TC aZmax){
352     std::vector<bn_t> nbins;                      352     std::vector<bn_t> nbins;
353     nbins.push_back(aXnumber);                    353     nbins.push_back(aXnumber);
354     nbins.push_back(aYnumber);                    354     nbins.push_back(aYnumber);
355     nbins.push_back(aZnumber);                    355     nbins.push_back(aZnumber);
356     std::vector<TC> mins;                         356     std::vector<TC> mins;
357     mins.push_back(aXmin);                        357     mins.push_back(aXmin);
358     mins.push_back(aYmin);                        358     mins.push_back(aYmin);
359     mins.push_back(aZmin);                        359     mins.push_back(aZmin);
360     std::vector<TC> maxs;                         360     std::vector<TC> maxs;
361     maxs.push_back(aXmax);                        361     maxs.push_back(aXmax);
362     maxs.push_back(aYmax);                        362     maxs.push_back(aYmax);
363     maxs.push_back(aZmax);                        363     maxs.push_back(aZmax);
364     return parent::configure(3,nbins,mins,maxs    364     return parent::configure(3,nbins,mins,maxs);
365   }                                               365   }
366                                                   366 
367   bool configure(const std::vector<TC>& a_edge    367   bool configure(const std::vector<TC>& a_edges_x,
368                  const std::vector<TC>& a_edge    368                  const std::vector<TC>& a_edges_y,
369                  const std::vector<TC>& a_edge    369                  const std::vector<TC>& a_edges_z){
370     std::vector< std::vector<TC> > edges(3);      370     std::vector< std::vector<TC> > edges(3);
371     edges[0] = a_edges_x;                         371     edges[0] = a_edges_x;
372     edges[1] = a_edges_y;                         372     edges[1] = a_edges_y;
373     edges[2] = a_edges_z;                         373     edges[2] = a_edges_z;
374     return parent::configure(3,edges);            374     return parent::configure(3,edges);
375   }                                               375   }
376                                                   376 
377 protected:                                        377 protected:
378   bool _find_offset(int aI,int aJ,int aK,TO& a    378   bool _find_offset(int aI,int aJ,int aK,TO& a_offset) const {
379     if(parent::m_dimension!=3) {a_offset=0;ret    379     if(parent::m_dimension!=3) {a_offset=0;return false;}
380     bn_t ibin,jbin,kbin;                          380     bn_t ibin,jbin,kbin;
381     if(!parent::m_axes[0].in_range_to_absolute    381     if(!parent::m_axes[0].in_range_to_absolute_index(aI,ibin)) {a_offset=0;return false;}
382     if(!parent::m_axes[1].in_range_to_absolute    382     if(!parent::m_axes[1].in_range_to_absolute_index(aJ,jbin)) {a_offset=0;return false;}
383     if(!parent::m_axes[2].in_range_to_absolute    383     if(!parent::m_axes[2].in_range_to_absolute_index(aK,kbin)) {a_offset=0;return false;}
384     a_offset = ibin + jbin * parent::m_axes[1]    384     a_offset = ibin + jbin * parent::m_axes[1].m_offset + kbin * parent::m_axes[2].m_offset;
385     return true;                                  385     return true;
386   }                                               386   }
387 };                                                387 };
388                                                   388 
389 }}                                                389 }}
390                                                   390 
391 #endif                                            391 #endif
392                                                   392 
393                                                   393 
394                                                   394 
395                                                   395