00001 #include <stdlib.h>
00002 #include <string.h>
00003 #include <TFile.h>
00004
00005 #include <Stiostream.h>
00006 #include <StMessMgr.h>
00007 #include <StEventTypes.h>
00008 #include <StEvent.h>
00009
00010 #include "StEEmcSimulatorMaker/StEEmcFastMaker.h"
00011 #include "StEEmcSimulatorMaker/StEEmcSlowMaker.h"
00012 #include "StEEmcMixerMaker.h"
00013 #include "StEEmcUtil/database/EEmcDbItem.h"
00014 #include "StEEmcUtil/database/StEEmcDb.h"
00015 #include "StEEmcUtil/database/cstructs/eemcConstDB.hh"
00016 #include "StEEmcUtil/EEmcGeom/EEmcGeomDefs.h"
00017
00018 #include "StDAQMaker/StDAQReader.h"
00019 #include "StEmcRawMaker/StEemcRaw.h"
00020
00021 #include "StEmcRawMaker/StEEmcPrint.h"
00022
00023
00024 ClassImp(StEEmcMixerMaker)
00025
00026
00027
00028 StEEmcMixerMaker::StEEmcMixerMaker(const char *name):StMaker(name){
00029 panicOff=false;
00030 mEEDb = 0;
00031 }
00032
00033
00034
00035 StEEmcMixerMaker::~StEEmcMixerMaker() {
00036
00037 }
00038
00039
00040
00041 Int_t StEEmcMixerMaker::Finish() {
00042 return StMaker::Finish();
00043 }
00044
00045
00046
00047 Int_t
00048 StEEmcMixerMaker::Init(){
00049 mEEDb=(StEEmcDb*)GetDataSet("StEEmcDb");
00050 if( mEEDb==0){
00051 panicOff=true;
00052 LOG_FATAL<< "::Init()\n\n Fatal Error - Eemc_DbMaker is not in the chain,\n panicOff="<<panicOff<<endm;
00053 return kStErr;
00054 }
00055 assert(!strcmp(mEEDb->ClassName(),"StEEmcDb"));
00056 return StMaker::Init();
00057 }
00058
00059
00060
00061 Int_t
00062 StEEmcMixerMaker::Make(){
00063
00064
00065
00066
00067 LOG_INFO <<"::Make() start...."<<endm;
00068 StEvent* mEvent = (StEvent*)GetInputDS("StEvent");
00069 if(mEvent==0) panicOff=true;
00070 StEmcCollection* ecolA =(StEmcCollection*)mEvent->emcCollection();
00071 if(ecolA==0) {
00072 LOG_WARN<<"::Make(), raw2pixels() no emc collection, skip"<<endm;
00073 return kStErr;
00074 }
00075
00076 if(panicOff) {
00077 LOG_FATAL<< "::Make()\n\n Fatal Error was encounter earlier, Endcap embedding disabled panicOff="<<panicOff<<endm;
00078 return kStErr;
00079 }
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094 StEEmcPrint eemcPrint;
00095 eemcPrint.setMode(15);
00096
00097 LOG_DEBUG<<"::Make() -------------- print data: Ecoll-A ---- real backg eve ---------"<<endm;
00098 if(Debug()) eemcPrint.print(ecolA);
00099
00100
00101
00102
00103
00104 StEmcCollection *ecolB = 0;
00105 StEEmcFastMaker *sim = (StEEmcFastMaker*)GetMakerInheritsFrom("StEEmcFastMaker");
00106
00107 if(!sim) {
00108 LOG_WARN<<"::Make() No fast EEmcSimulator found, nothing to embed"<<endm; return kStWarn; }
00109 ecolB = sim->GetLocalEmcCollection();
00110
00111 if(!ecolB) {
00112 LOG_WARN<<"::Make() No second EmcCollection to embed"<<endm; return kStWarn; }
00113
00114
00115 LOG_DEBUG <<"::Make() -------------- print data: Ecoll-B ----- M-C physics probe eve -----------"<<endm;
00116 if(Debug()) eemcPrint.print(ecolB);
00117
00118
00119 LOG_DEBUG<<GetName() <<"::Make() -------------- print data: Ecoll-A+B ----- before mrging -----"<<endm;
00120 if(Debug()) eemcPrint.printChange(ecolA,ecolB,Form("before merging"));
00121
00122 if(!mergeADCs(ecolA,ecolB)) return kStErr;
00123
00124 mMixerEmcCollection = ecolA;
00125
00126 LOG_DEBUG <<"::Make() -------------- print Ecoll-A after mixing ----------------"<<endm;
00127 if(Debug()) eemcPrint.print(ecolA);
00128
00129 LOG_DEBUG <<"::Make() -------------- print data: Ecoll-A+B ----- after mrging -----"<<endm;
00130 if(Debug()) eemcPrint.printChange(ecolA,ecolB,Form("after merging"));
00131 return kStOK;
00132 }
00133
00134
00135
00136
00137 bool
00138 StEEmcMixerMaker::mergeADCs(StEmcCollection*emccolA,StEmcCollection*emccolB){
00143 LOG_DEBUG <<"::Make() merging ADCs ..."<<endm;
00144
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154 for(int det = kEndcapEmcTowerId; det<= kEndcapSmdVStripId; det++){
00155
00156 StDetectorId id = StDetectorId(det);
00157 StEmcDetector* detectorA=emccolA->detector(id);
00158 StEmcDetector* detectorB=emccolB->detector(id);
00159 if(!detectorA)
00160 LOG_WARN<<"detectorA not loaded"<<endm;
00161 if(!detectorB)
00162 LOG_WARN<<"detectorB not loaded"<<endm;
00163
00164 if(!detectorA || !detectorB) continue;
00165 for(int secID=1; secID<=kEEmcNumSectors; secID++){
00166
00167 StEmcModule* sectorA = detectorA->module(secID);
00168 StEmcModule* sectorB = detectorB->module(secID);
00169 StSPtrVecEmcRawHit& rawHitA=sectorA->hits();
00170 StSPtrVecEmcRawHit& rawHitB=sectorB->hits();
00171
00172
00173 vector<StEmcRawHit*> myHitB;
00174 for(UInt_t k2=0;k2<rawHitB.size();k2++)
00175 myHitB.push_back(rawHitB[k2]);
00176 vector<StEmcRawHit*>::iterator hitB;
00177
00178
00179
00180
00181
00182
00183 for(UInt_t k1=0;k1<rawHitA.size();k1++) {
00184
00185
00186 uint Bmod=rawHitA[k1]->module();
00187
00188 if((int)Bmod==!secID) {
00189 LOG_FATAL << "::Make()\n\n Fatal Error "<<Bmod<<"= Bmod==!secID ="<<secID<<" StEvent internal consistency failed - corrupted event file, abort"<<endm;
00190 panicOff=true;
00191 return false;
00192
00193 }
00194
00195
00196 uint Beta=rawHitA[k1]->eta();
00197 int Bsub=rawHitA[k1]->sub();
00198
00199
00200 rawHitA[k1]->setEnergy(-654.3210);
00201
00202 for( hitB=myHitB.begin() ; hitB< myHitB.end(); hitB++) {
00203 if( (*hitB)->module()!=Bmod) continue;
00204 if( (*hitB)->eta() !=Beta) continue;
00205 if( (*hitB)->sub() !=Bsub) continue;
00206
00207 int adc=(*hitB)->adc();
00208
00209 myHitB.erase(hitB);
00210
00211
00212
00213
00214
00215
00216
00217 hitB=(vector<StEmcRawHit*>::iterator)NULL;
00218
00219 const EEmcDbItem *x=mEEDb->StBarrelIndex2Item(det,Bmod,Beta,Bsub);
00220 if(!x) break;
00221
00222
00223
00224
00225 int adcAdd=adc;
00226 if(adcAdd<=0) break;
00227 int adcSum=rawHitA[k1]->adc() +adcAdd;
00228
00229 rawHitA[k1]->setAdc(adcSum);
00230 break;
00231 }
00232
00233 }
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243 if(myHitB.size())
00244 LOG_WARN<<Form("%s::Make() merging: %d hits in collB for sect=%d are dropped\n since those channels are not avaliable in collA, \n a create is probably masked out\n",GetName(), myHitB.size(),secID)<<endm;
00245
00246
00247 }
00248 }
00249
00250 return true;
00251 }
00252
00253
00254
00256
00257
00258
00259
00260
00261
00262
00263
00264
00265
00266
00267
00268
00269
00270
00271
00272
00273
00274
00275
00276
00277
00278
00279
00280
00281
00282
00283
00284
00285
00286
00287
00288
00289
00290
00291
00292
00293
00294
00295
00296
00297