00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013 #include "StHbtMaker/CorrFctn/QvecQualCorrFctn.h"
00014 #include <cstdio>
00015
00016 #ifdef __ROOT__
00017 ClassImp(QvecQualCorrFctn)
00018 #endif
00019
00020 QvecQualCorrFctn:: QvecQualCorrFctn(char* title, const int& nbinsQ, const float& QLo, const float& QHi,
00021 const int& nbinsQual, const float& QualLo, const float& QualHi){
00022
00023 char Tit[100];
00024 sprintf(Tit,"Num2D");
00025 strcat(Tit,title);
00026 mNumerator2D = new StHbt2DHisto(Tit,title,nbinsQ,QLo,QHi,nbinsQual,QualLo,QualHi);
00027
00028
00029 sprintf(Tit,"Den2D");
00030 strcat(Tit,title);
00031 mDenominator2D = new StHbt2DHisto(Tit,title,nbinsQ,QLo,QHi,nbinsQual,QualLo,QualHi);
00032
00033
00034 sprintf(Tit,"Rat2D");
00035 strcat(Tit,title);
00036 mRatio2D = new StHbt2DHisto(Tit,title,nbinsQ,QLo,QHi,nbinsQual,QualLo,QualHi);
00037
00038
00039 mNumerator2D->Sumw2();
00040 mDenominator2D->Sumw2();
00041 mRatio2D->Sumw2();
00042
00043 }
00044
00045
00046 QvecQualCorrFctn::~QvecQualCorrFctn(){
00047 delete mNumerator2D;
00048 delete mDenominator2D;
00049 delete mRatio2D;
00050 }
00051
00052 void QvecQualCorrFctn::Finish(){
00053
00054
00055
00056
00057 mRatio2D->Divide(mNumerator2D,mDenominator2D,1.0,1.0);
00058 }
00059
00060
00061 StHbtString QvecQualCorrFctn::Report(){
00062 string stemp = "Qvector-QualityFactor Correlation Function Report:\n";
00063 char ctemp[100];
00064 sprintf(ctemp,"Number of entries in numerator:\t%E\n",
00065 mNumerator2D->GetEntries());
00066 stemp += ctemp;
00067 sprintf(ctemp,"Number of entries in denominator:\t%E\n",
00068 mDenominator2D->GetEntries());
00069 stemp += ctemp;
00070 StHbtString returnThis = stemp;
00071 return returnThis;
00072 }
00073
00074 void QvecQualCorrFctn::AddRealPair(const StHbtPair* pair){
00075
00076 double Qual = pair->quality();
00077 double Q = fabs(pair->fourMomentumDiff().vect().mag());
00078
00079 mNumerator2D->Fill(Q,Qual,1.0);
00080 }
00081
00082 void QvecQualCorrFctn::AddMixedPair(const StHbtPair* pair){
00083
00084 double Qual = pair->quality();
00085 double Q = fabs(pair->fourMomentumDiff().vect().mag());
00086
00087 mDenominator2D->Fill(Q,Qual,1.0);
00088
00089 }
00090
00091
00092