]> git.uio.no Git - u/mrichter/AliRoot.git/blob - PWG2/FEMTOSCOPY/AliFemto/AliFemtoPicoEventCollectionVectorHideAway.h
More coding rule conformance
[u/mrichter/AliRoot.git] / PWG2 / FEMTOSCOPY / AliFemto / AliFemtoPicoEventCollectionVectorHideAway.h
1 ///////////////////////////////////////////////////////////////////////////
2 //                                                                       //
3 // AliFemtoPicoEventCollectionVectorHideAway: a helper class for         //
4 // managing many mixing buffers with up to three variables used for      //
5 // binning.                                                              //
6 //                                                                       //
7 ///////////////////////////////////////////////////////////////////////////
8
9 #ifndef ALIFEMTOPICOEVENTCOLLECTIONVECTORHIDEAWAY_H
10 #define ALIFEMTOPICOEVENTCOLLECTIONVECTORHIDEAWAY_H
11 #include "AliFemtoPicoEvent.h"
12 #include "AliFemtoPicoEventCollection.h"
13 #include "AliFemtoPicoEventCollectionVector.h"
14 #include <vector>
15 #include <list>
16 #include <float.h>
17 #include <limits.h>
18
19 #if !defined(ST_NO_NAMESPACES)
20 using std::vector;
21 using std::list;
22 #endif
23
24 class AliFemtoPicoEventCollectionVectorHideAway {
25 public:
26   AliFemtoPicoEventCollectionVectorHideAway(int bx=1, double lx=-FLT_MAX, double ux=FLT_MAX,
27                                             int by=1, double ly=-FLT_MAX, double uy=FLT_MAX,
28                                             int bz=1, double lz=-FLT_MAX, double uz=FLT_MAX);
29   AliFemtoPicoEventCollectionVectorHideAway(const AliFemtoPicoEventCollectionVectorHideAway& aColl);
30   ~AliFemtoPicoEventCollectionVectorHideAway();
31   AliFemtoPicoEventCollectionVectorHideAway& operator=(const AliFemtoPicoEventCollectionVectorHideAway& aColl);
32
33   AliFemtoPicoEventCollection* PicoEventCollection(int bx, int by, int bz);
34   AliFemtoPicoEventCollection* PicoEventCollection(double x, double y=0, double z=0);
35 private:
36   int fBinsTot;                                        // Total number of bins 
37   int fBinsx,fBinsy,fBinsz;                            // Number of bins on x, y, z axis
38   double fMinx,fMiny,fMinz;                            // Minima on x, y, z axis
39   double fMaxx,fMaxy,fMaxz;                            // Maxima on x, y, z axis
40   double fStepx,fStepy,fStepz;                         // Steps on x, y, z axis
41   AliFemtoPicoEventCollection* fCollection;            // Pico event collection
42   AliFemtoPicoEventCollectionVector fCollectionVector; // Collection vector
43 };
44
45 #endif