00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051 #ifndef StuRefCentrality2_hh
00052 #define StuRefCentrality2_hh
00053
00054 #include "StEventTypes.h"
00055 inline unsigned int
00056 uncorrectedMultiplicity(StEvent& evt)
00057 {
00058 StPrimaryVertex* primVtx = evt.primaryVertex();
00059
00060 if (!primVtx) return 0;
00061
00062 const StSPtrVecPrimaryTrack& tracks = primVtx->daughters();
00063 size_t countedTracks = 0;
00064 for (StSPtrVecPrimaryTrackConstIterator iter = tracks.begin(); iter != tracks.end(); iter++) {
00065 StTrack* track = (*iter);
00066 if (track->flag()<=0 ) continue;
00067 if (fabs(track->geometry()->momentum().pseudoRapidity())<0.75) ++countedTracks;
00068 }
00069 return countedTracks;
00070 }
00071 inline unsigned int
00072 binOfCentrality(StEvent& evt)
00073 {
00074 StPrimaryVertex* primVtx = evt.primaryVertex();
00075
00076 if (!primVtx) return 0;
00077
00078 size_t countedTracks = uncorrectedMultiplicity(evt);
00079
00080 unsigned int cent[] = {0,14,30,60,107,176,271,400,569,675};
00081
00082
00083 if (countedTracks < cent[1]) { return 1; }
00084 else if (countedTracks < cent[2]) { return 2; }
00085 else if (countedTracks < cent[3]) { return 3; }
00086 else if (countedTracks < cent[4]) { return 4; }
00087 else if (countedTracks < cent[5]) { return 5; }
00088 else if (countedTracks < cent[6]) { return 6; }
00089 else if (countedTracks < cent[7]) { return 7; }
00090 else if (countedTracks < cent[8]) { return 8; }
00091 else if (countedTracks < cent[9]) { return 9; }
00092 else { return 10; }
00093 }
00094 inline float
00095 percentOfCentrality(StEvent& evt)
00096 {
00097 StPrimaryVertex* primVtx = evt.primaryVertex();
00098
00099 if (!primVtx) return -1.;
00100
00101 size_t countedTracks = uncorrectedMultiplicity(evt);
00102
00103 unsigned int cent[] = {0,14,30,60,107,176,271,400,569,675};
00104 float percent[] ={1.00,0.80,0.70,0.60,0.50,0.40,0.30,0.20,0.10,0.05,0.00};
00105
00106 if (countedTracks < cent[1]) { return percent[0]; }
00107 else if (countedTracks < cent[2]) { return percent[1]; }
00108 else if (countedTracks < cent[3]) { return percent[2]; }
00109 else if (countedTracks < cent[4]) { return percent[3]; }
00110 else if (countedTracks < cent[5]) { return percent[4]; }
00111 else if (countedTracks < cent[6]) { return percent[5]; }
00112 else if (countedTracks < cent[7]) { return percent[6]; }
00113 else if (countedTracks < cent[8]) { return percent[7]; }
00114 else if (countedTracks < cent[9]) { return percent[8]; }
00115 else { return percent[9]; }
00116 }
00117
00118 #endif
00119
00120
00121