00001 #include "Calibration/EcalCalibAlgos/interface/PhiSymmetryCalibration.h"
00002
00003
00004 #include <memory>
00005
00006
00007 #include "FWCore/MessageLogger/interface/MessageLogger.h"
00008 #include "FWCore/Framework/interface/ESHandle.h"
00009 #include "FWCore/ParameterSet/interface/ParameterSet.h"
00010
00011 #include "DataFormats/EcalRecHit/interface/EcalRecHitCollections.h"
00012 #include "DataFormats/EcalDetId/interface/EBDetId.h"
00013 #include "DataFormats/EcalDetId/interface/EEDetId.h"
00014 #include "CondFormats/DataRecord/interface/EcalIntercalibConstantsRcd.h"
00015 #include "CondFormats/EcalObjects/interface/EcalIntercalibErrors.h"
00016 #include "CondTools/Ecal/interface/EcalIntercalibConstantsXMLTranslator.h"
00017 #include "FWCore/Framework/interface/LuminosityBlock.h"
00018
00019
00020 #include "Geometry/Records/interface/CaloGeometryRecord.h"
00021 #include "Geometry/CaloGeometry/interface/CaloSubdetectorGeometry.h"
00022 #include "Geometry/CaloGeometry/interface/CaloCellGeometry.h"
00023 #include "Geometry/CaloGeometry/interface/CaloGeometry.h"
00024
00025
00026 #include "CondFormats/EcalObjects/interface/EcalChannelStatus.h"
00027 #include "CondFormats/DataRecord/interface/EcalChannelStatusRcd.h"
00028 #include "CondFormats/EcalObjects/interface/EcalChannelStatusCode.h"
00029
00030 #include "FWCore/Framework/interface/Run.h"
00031
00032
00033
00034
00035
00036
00037 #include "boost/filesystem/operations.hpp"
00038
00039 using namespace std;
00040 #include <fstream>
00041 #include <iostream>
00042 #include "TH2F.h"
00043 #include "TFile.h"
00044 #include "TTree.h"
00045 #include "TH1F.h"
00046 #include "TF1.h"
00047 #include "TGraph.h"
00048 #include "TCanvas.h"
00049
00050 const float PhiSymmetryCalibration::kMiscalRangeEB = .05;
00051 const float PhiSymmetryCalibration::kMiscalRangeEE = .10;
00052
00053
00054
00055
00056
00057
00058
00059 PhiSymmetryCalibration::PhiSymmetryCalibration(const edm::ParameterSet& iConfig) :
00060
00061 ecalHitsProducer_(iConfig.getParameter<std::string>("ecalRecHitsProducer")),
00062 barrelHits_( iConfig.getParameter< std::string > ("barrelHitCollection")),
00063 endcapHits_( iConfig.getParameter< std::string > ("endcapHitCollection")),
00064 eCut_barl_( iConfig.getParameter< double > ("eCut_barrel") ),
00065 ap_( iConfig.getParameter<double> ("ap") ),
00066 b_( iConfig.getParameter<double> ("b") ),
00067 eventSet_( iConfig.getParameter< int > ("eventSet") ),
00068 statusThreshold_(iConfig.getUntrackedParameter<int>("statusThreshold",3)),
00069 reiteration_(iConfig.getUntrackedParameter< bool > ("reiteration",false)),
00070 oldcalibfile_(iConfig.getUntrackedParameter<std::string>("oldcalibfile",
00071 "EcalintercalibConstants.xml"))
00072 {
00073
00074
00075 isfirstpass_=true;
00076
00077 et_spectrum_b_histos.resize(kBarlRings);
00078 e_spectrum_b_histos.resize(kBarlRings);
00079 et_spectrum_e_histos.resize(kEndcEtaRings);
00080 e_spectrum_e_histos.resize(kEndcEtaRings);
00081
00082 spectra=true;
00083
00084 nevents_=0;
00085 eventsinrun_=0;
00086 eventsinlb_=0;
00087 }
00088
00089
00090
00091
00092
00093 PhiSymmetryCalibration::~PhiSymmetryCalibration()
00094 {
00095
00096
00097 for(Int_t i=0;i<kBarlRings;i++){
00098 delete et_spectrum_b_histos[i];
00099 delete e_spectrum_b_histos[i];
00100
00101 }
00102 for(Int_t i=0;i<kEndcEtaRings;i++){
00103 delete et_spectrum_e_histos[i];
00104 delete e_spectrum_e_histos[i];
00105 }
00106
00107
00108 }
00109
00110
00111
00112
00113
00114 void PhiSymmetryCalibration::beginJob( )
00115 {
00116
00117
00118
00119 for (int sign=0; sign<kSides; sign++) {
00120 for (int ieta=0; ieta<kBarlRings; ieta++) {
00121 for (int iphi=0; iphi<kBarlWedges; iphi++) {
00122 etsum_barl_[ieta][iphi][sign]=0.;
00123 nhits_barl_[ieta][iphi][sign]=0;
00124
00125 }
00126 }
00127 for (int ix=0; ix<kEndcWedgesX; ix++) {
00128 for (int iy=0; iy<kEndcWedgesY; iy++) {
00129 etsum_endc_[ix][iy][sign]=0.;
00130 nhits_endc_[ix][iy][sign]=0;
00131 }
00132 }
00133 }
00134
00135
00136
00137 for (int imiscal=0; imiscal<kNMiscalBinsEB; imiscal++) {
00138 miscalEB_[imiscal]= (1-kMiscalRangeEB) + float(imiscal)* (2*kMiscalRangeEB/(kNMiscalBinsEB-1));
00139 for (int ieta=0; ieta<kBarlRings; ieta++) etsum_barl_miscal_[imiscal][ieta]=0.;
00140 }
00141
00142 for (int imiscal=0; imiscal<kNMiscalBinsEE; imiscal++) {
00143 miscalEE_[imiscal]= (1-kMiscalRangeEE) + float(imiscal)* (2*kMiscalRangeEE/(kNMiscalBinsEE-1));
00144 for (int ring=0; ring<kEndcEtaRings; ring++) etsum_endc_miscal_[imiscal][ring]=0.;
00145 }
00146
00147
00148
00149
00150 if (eventSet_!=1) spectra = false;
00151
00152 if(spectra)
00153 {
00154 ostringstream t;
00155 for(Int_t i=0;i<kBarlRings;i++)
00156 {
00157 t << "et_spectrum_b_" << i+1;
00158 et_spectrum_b_histos[i]=new TH1F(t.str().c_str(),";E_{T} [MeV]",50,0.,500.);
00159 t.str("");
00160
00161 t << "e_spectrum_b_" << i+1;
00162 e_spectrum_b_histos[i]=new TH1F(t.str().c_str(),";E [MeV]",50,0.,500.);
00163 t.str("");
00164
00165 }
00166 for(Int_t i=0;i<kEndcEtaRings;i++)
00167 {
00168 t << "et_spectrum_e_" << i+1;
00169 et_spectrum_e_histos[i]=new TH1F(t.str().c_str(),";E_{T} [MeV]",75,0.,1500.);
00170 t.str("");
00171
00172 t << "e_spectrum_e_" << i+1;
00173 e_spectrum_e_histos[i]=new TH1F(t.str().c_str(),";E [MeV]",75,0.,1500.);
00174 t.str("");
00175
00176 }
00177 }
00178
00179 }
00180
00181
00182
00183
00184
00185 void PhiSymmetryCalibration::endJob()
00186 {
00187
00188 edm::LogInfo("Calibration") << "[PhiSymmetryCalibration] At end of job";
00189
00190
00191 if(spectra)
00192 {
00193 TFile f("Espectra_plus.root","recreate");
00194
00195 for(int i=0;i<kBarlRings;i++){
00196 et_spectrum_b_histos[i]->Write();
00197 e_spectrum_b_histos[i]->Write();
00198 }
00199
00200 for(int i=0;i<kEndcEtaRings;i++){
00201 et_spectrum_e_histos[i]->Write();
00202 e_spectrum_e_histos[i]->Write();
00203 }
00204
00205 f.Close();
00206 }
00207
00208
00209
00210
00211 if (eventSet_==1) {
00212
00213
00214 getKfactors();
00215
00216 std::ofstream k_barl_out("k_barl.dat", ios::out);
00217 for (int ieta=0; ieta<kBarlRings; ieta++)
00218 k_barl_out << ieta << " " << k_barl_[ieta] << endl;
00219 k_barl_out.close();
00220
00221 std::ofstream k_endc_out("k_endc.dat", ios::out);
00222 for (int ring=0; ring<kEndcEtaRings; ring++)
00223 k_endc_out << ring << " " << k_endc_[ring] << endl;
00224 k_endc_out.close();
00225 }
00226
00227
00228 if (eventSet_!=0) {
00229
00230
00231 stringstream etsum_file_barl;
00232 etsum_file_barl << "etsum_barl_"<<eventSet_<<".dat";
00233
00234 std::ofstream etsum_barl_out(etsum_file_barl.str().c_str(),ios::out);
00235
00236 for (int ieta=0; ieta<kBarlRings; ieta++) {
00237 for (int iphi=0; iphi<kBarlWedges; iphi++) {
00238 for (int sign=0; sign<kSides; sign++) {
00239 etsum_barl_out << eventSet_ << " " << ieta << " " << iphi << " " << sign
00240 << " " << etsum_barl_[ieta][iphi][sign] << " "
00241 << nhits_barl_[ieta][iphi][sign] << endl;
00242 }
00243 }
00244 }
00245 etsum_barl_out.close();
00246
00247 stringstream etsum_file_endc;
00248 etsum_file_endc << "etsum_endc_"<<eventSet_<<".dat";
00249
00250 std::ofstream etsum_endc_out(etsum_file_endc.str().c_str(),ios::out);
00251 for (int ix=0; ix<kEndcWedgesX; ix++) {
00252 for (int iy=0; iy<kEndcWedgesY; iy++) {
00253 int ring = e_.endcapRing_[ix][iy];
00254 if (ring!=-1) {
00255 for (int sign=0; sign<kSides; sign++) {
00256 etsum_endc_out << eventSet_ << " " << ix << " " << iy << " " << sign
00257 << " " << etsum_endc_[ix][iy][sign] << " "
00258 << nhits_endc_[ix][iy][sign]<<" "
00259 << e_.endcapRing_[ix][iy]<<endl;
00260 }
00261 }
00262 }
00263 }
00264 etsum_endc_out.close();
00265 }
00266 cout<<"Events processed " << nevents_<< endl;
00267 }
00268
00269
00270
00271
00272
00273 void PhiSymmetryCalibration::analyze( const edm::Event& event, const edm::EventSetup& setup )
00274 {
00275 using namespace edm;
00276 using namespace std;
00277
00278 if (isfirstpass_) {
00279 setUp(setup);
00280 isfirstpass_=false;
00281 }
00282
00283
00284 Handle<EBRecHitCollection> barrelRecHitsHandle;
00285 Handle<EERecHitCollection> endcapRecHitsHandle;
00286
00287 event.getByLabel(ecalHitsProducer_,barrelHits_,barrelRecHitsHandle);
00288 if (!barrelRecHitsHandle.isValid()) {
00289 LogError("") << "[PhiSymmetryCalibration] Error! Can't get product!" << std::endl;
00290 }
00291
00292 event.getByLabel(ecalHitsProducer_,endcapHits_,endcapRecHitsHandle);
00293 if (!endcapRecHitsHandle.isValid()) {
00294 LogError("") << "[PhiSymmetryCalibration] Error! Can't get product!" << std::endl;
00295 }
00296
00297
00298
00299 edm::ESHandle<CaloGeometry> geoHandle;
00300 setup.get<CaloGeometryRecord>().get(geoHandle);
00301 const CaloSubdetectorGeometry *barrelGeometry =
00302 geoHandle->getSubdetectorGeometry(DetId::Ecal, EcalBarrel);
00303 const CaloSubdetectorGeometry *endcapGeometry =
00304 geoHandle->getSubdetectorGeometry(DetId::Ecal, EcalEndcap);
00305
00306 bool pass=false;
00307
00308 EBRecHitCollection::const_iterator itb;
00309 for (itb=barrelRecHitsHandle->begin(); itb!=barrelRecHitsHandle->end(); itb++) {
00310 EBDetId hit = EBDetId(itb->id());
00311 float eta = barrelGeometry->getGeometry(hit)->getPosition().eta();
00312 float et = itb->energy()/cosh(eta);
00313 float e = itb->energy();
00314
00315
00316
00317
00318
00319 if (reiteration_) {
00320 et= et * oldCalibs_[hit];
00321 e = e * oldCalibs_[hit];
00322 }
00323
00324 float et_thr = eCut_barl_/cosh(eta) + 1.;
00325
00326 int sign = hit.ieta()>0 ? 1 : 0;
00327
00328 if (e > eCut_barl_ && et < et_thr && e_.goodCell_barl[abs(hit.ieta())-1][hit.iphi()-1][sign]) {
00329 etsum_barl_[abs(hit.ieta())-1][hit.iphi()-1][sign] += et;
00330 nhits_barl_[abs(hit.ieta())-1][hit.iphi()-1][sign] ++;
00331 pass =true;
00332 }
00333
00334 if (eventSet_==1) {
00335
00336
00337 for (int imiscal=0; imiscal<kNMiscalBinsEB; imiscal++) {
00338 if (miscalEB_[imiscal]*e > eCut_barl_&& miscalEB_[imiscal]*et < et_thr && e_.goodCell_barl[abs(hit.ieta())-1][hit.iphi()-1][sign]) {
00339 etsum_barl_miscal_[imiscal][abs(hit.ieta())-1] += miscalEB_[imiscal]*et;
00340 }
00341 }
00342
00343
00344 if(spectra && hit.ieta()>0)
00345
00346 {
00347 et_spectrum_b_histos[abs(hit.ieta())-1]->Fill(et*1000.);
00348 e_spectrum_b_histos[abs(hit.ieta())-1]->Fill(e*1000.);
00349 }
00350
00351 }
00352 }
00353
00354
00355
00356 EERecHitCollection::const_iterator ite;
00357 for (ite=endcapRecHitsHandle->begin(); ite!=endcapRecHitsHandle->end(); ite++) {
00358 EEDetId hit = EEDetId(ite->id());
00359 float eta = abs(endcapGeometry->getGeometry(hit)->getPosition().eta());
00360
00361
00362 float et = ite->energy()/cosh(eta);
00363 float e = ite->energy();
00364
00365
00366 if (reiteration_) {
00367 et= et * oldCalibs_[hit];
00368 e = e * oldCalibs_[hit];
00369 }
00370
00371 int sign = hit.zside()>0 ? 1 : 0;
00372
00373
00374
00375
00376
00377 double eCut_endc=0;
00378 for (int ring=0; ring<kEndcEtaRings; ring++) {
00379
00380 if(eta>e_.etaBoundary_[ring] && eta<e_.etaBoundary_[ring+1])
00381 {
00382 float eta_ring= abs(e_.cellPos_[ring][50].eta()) ;
00383 eCut_endc = ap_ + eta_ring*b_;
00384
00385 }
00386 }
00387
00388
00389 float et_thr = eCut_endc/cosh(eta) + 1.;
00390
00391 if (e > eCut_endc && et < et_thr && e_.goodCell_endc[hit.ix()-1][hit.iy()-1][sign]){
00392 etsum_endc_[hit.ix()-1][hit.iy()-1][sign] += et;
00393 nhits_endc_[hit.ix()-1][hit.iy()-1][sign] ++;
00394 pass=true;
00395 }
00396
00397
00398
00399 if (eventSet_==1) {
00400
00401
00402 for (int imiscal=0; imiscal<kNMiscalBinsEE; imiscal++) {
00403 if (miscalEE_[imiscal]*e> eCut_endc && et*miscalEE_[imiscal] < et_thr && e_.goodCell_endc[hit.ix()-1][hit.iy()-1][sign]){
00404 int ring = e_.endcapRing_[hit.ix()-1][hit.iy()-1];
00405 etsum_endc_miscal_[imiscal][ring] += miscalEE_[imiscal]*et;
00406 }
00407 }
00408
00409
00410 if(spectra && hit.zside()>0)
00411
00412 {
00413 int ring = e_.endcapRing_[hit.ix()-1][hit.iy()-1];
00414
00415 et_spectrum_e_histos[ring]->Fill(et*1000.);
00416 e_spectrum_e_histos[ring]->Fill(e*1000.);
00417
00418 if(ring==16)
00419 {
00420
00421 for (int ip=0; ip<e_.nRing_[ring]; ip++) {
00422
00423 }
00424
00425 }
00426 }
00427
00428 }
00429 }
00430
00431 if (pass) {
00432 nevents_++;
00433 eventsinrun_++;
00434 eventsinlb_++;
00435 }
00436 }
00437
00438 void PhiSymmetryCalibration::endRun(edm::Run& run, const edm::EventSetup&){
00439
00440
00441 std::cout << "PHIREPRT : run "<< run.run()
00442 << " start " << (run.beginTime().value()>>32)
00443 << " end " << (run.endTime().value()>>32)
00444 << " dur " << (run.endTime().value()>>32)- (run.beginTime().value()>>32)
00445
00446 << " npass " << eventsinrun_ << std::endl;
00447 eventsinrun_=0;
00448
00449 return ;
00450
00451 }
00452
00453
00454
00455 void PhiSymmetryCalibration::getKfactors()
00456 {
00457
00458 float epsilon_T_eb[kNMiscalBinsEB];
00459 float epsilon_M_eb[kNMiscalBinsEB];
00460
00461 float epsilon_T_ee[kNMiscalBinsEE];
00462 float epsilon_M_ee[kNMiscalBinsEE];
00463
00464 std::vector<TGraph*> k_barl_graph(kBarlRings);
00465 std::vector<TCanvas*> k_barl_plot(kBarlRings);
00466
00467 for (int ieta=0; ieta<kBarlRings; ieta++) {
00468 for (int imiscal=0; imiscal<kNMiscalBinsEB; imiscal++) {
00469 int middlebin = int (kNMiscalBinsEB/2);
00470 epsilon_T_eb[imiscal] = etsum_barl_miscal_[imiscal][ieta]/etsum_barl_miscal_[middlebin][ieta] - 1.;
00471 epsilon_M_eb[imiscal] = miscalEB_[imiscal] - 1.;
00472 }
00473 k_barl_graph[ieta] = new TGraph (kNMiscalBinsEB,epsilon_M_eb,epsilon_T_eb);
00474 k_barl_graph[ieta]->Fit("pol1");
00475
00476
00477 ostringstream t;
00478 t<< "k_barl_" << ieta+1;
00479 k_barl_plot[ieta] = new TCanvas(t.str().c_str(),"");
00480 k_barl_plot[ieta]->SetFillColor(10);
00481 k_barl_plot[ieta]->SetGrid();
00482 k_barl_graph[ieta]->SetMarkerSize(1.);
00483 k_barl_graph[ieta]->SetMarkerColor(4);
00484 k_barl_graph[ieta]->SetMarkerStyle(20);
00485 k_barl_graph[ieta]->GetXaxis()->SetLimits(-1.*kMiscalRangeEB,kMiscalRangeEB);
00486 k_barl_graph[ieta]->GetXaxis()->SetTitleSize(.05);
00487 k_barl_graph[ieta]->GetYaxis()->SetTitleSize(.05);
00488 k_barl_graph[ieta]->GetXaxis()->SetTitle("#epsilon_{M}");
00489 k_barl_graph[ieta]->GetYaxis()->SetTitle("#epsilon_{T}");
00490 k_barl_graph[ieta]->Draw("AP");
00491
00492 k_barl_[ieta] = k_barl_graph[ieta]->GetFunction("pol1")->GetParameter(1);
00493 std::cout << "k_barl_[" << ieta << "]=" << k_barl_[ieta] << std::endl;
00494 }
00495
00496
00497 std::vector<TGraph*> k_endc_graph(kEndcEtaRings);
00498 std::vector<TCanvas*> k_endc_plot(kEndcEtaRings);
00499
00500 for (int ring=0; ring<kEndcEtaRings; ring++) {
00501 for (int imiscal=0; imiscal<kNMiscalBinsEE; imiscal++) {
00502 int middlebin = int (kNMiscalBinsEE/2);
00503 epsilon_T_ee[imiscal] = etsum_endc_miscal_[imiscal][ring]/etsum_endc_miscal_[middlebin][ring] - 1.;
00504 epsilon_M_ee[imiscal] = miscalEE_[imiscal] - 1.;
00505 }
00506 k_endc_graph[ring] = new TGraph (kNMiscalBinsEE,epsilon_M_ee,epsilon_T_ee);
00507 k_endc_graph[ring]->Fit("pol1");
00508
00509 ostringstream t;
00510 t<< "k_endc_"<< ring+1;
00511 k_endc_plot[ring] = new TCanvas(t.str().c_str(),"");
00512 k_endc_plot[ring]->SetFillColor(10);
00513 k_endc_plot[ring]->SetGrid();
00514 k_endc_graph[ring]->SetMarkerSize(1.);
00515 k_endc_graph[ring]->SetMarkerColor(4);
00516 k_endc_graph[ring]->SetMarkerStyle(20);
00517 k_endc_graph[ring]->GetXaxis()->SetLimits(-1*kMiscalRangeEE,kMiscalRangeEE);
00518 k_endc_graph[ring]->GetXaxis()->SetTitleSize(.05);
00519 k_endc_graph[ring]->GetYaxis()->SetTitleSize(.05);
00520 k_endc_graph[ring]->GetXaxis()->SetTitle("#epsilon_{M}");
00521 k_endc_graph[ring]->GetYaxis()->SetTitle("#epsilon_{T}");
00522 k_endc_graph[ring]->Draw("AP");
00523
00524 k_endc_[ring] = k_endc_graph[ring]->GetFunction("pol1")->GetParameter(1);
00525 std::cout << "k_endc_[" << ring << "]=" << k_endc_[ring] << std::endl;
00526 }
00527
00528 TFile f("PhiSymmetryCalibration_kFactors.root","recreate");
00529 for (int ieta=0; ieta<kBarlRings; ieta++) {
00530 k_barl_plot[ieta]->Write();
00531 delete k_barl_plot[ieta];
00532 delete k_barl_graph[ieta];
00533 }
00534 for (int ring=0; ring<kEndcEtaRings; ring++) {
00535 k_endc_plot[ring]->Write();
00536 delete k_endc_plot[ring];
00537 delete k_endc_graph[ring];
00538 }
00539 f.Close();
00540
00541 }
00542
00543
00544
00545
00546
00547
00548
00549
00550
00551 void PhiSymmetryCalibration::setUp(const edm::EventSetup& setup){
00552
00553 edm::ESHandle<EcalChannelStatus> chStatus;
00554 setup.get<EcalChannelStatusRcd>().get(chStatus);
00555
00556 edm::ESHandle<CaloGeometry> geoHandle;
00557 setup.get<CaloGeometryRecord>().get(geoHandle);
00558
00559 e_.setup(&(*geoHandle), &(*chStatus), statusThreshold_);
00560
00561
00562 if (reiteration_){
00563
00564 EcalCondHeader h;
00565
00566
00567
00568
00569
00570 edm::FileInPath fip("Calibration/EcalCalibAlgos/data/"+oldcalibfile_);
00571
00572
00573
00574 int ret=
00575 EcalIntercalibConstantsXMLTranslator::readXML(fip.fullPath(),h,oldCalibs_);
00576 if (ret) edm::LogError("PhiSym")<<"Error reading XML files"<<endl;;
00577
00578 } else {
00579
00580 edm::ESHandle<EcalIntercalibConstants> pIcal;
00581 setup.get<EcalIntercalibConstantsRcd>().get(pIcal);
00582 oldCalibs_=*pIcal;
00583
00584 }
00585
00586 }
00587
00588
00589 void PhiSymmetryCalibration::endLuminosityBlock(edm::LuminosityBlock const& lb, edm::EventSetup const&){
00590
00591
00592 if ((lb.endTime().value()>>32)- (lb.beginTime().value()>>32) <60 )
00593 return;
00594
00595 std::cout << "PHILB : run "<< lb.run()
00596 << " id " << lb.id()
00597 << " start " << (lb.beginTime().value()>>32)
00598 << " end " << (lb.endTime().value()>>32)
00599 << " dur " << (lb.endTime().value()>>32)- (lb.beginTime().value()>>32)
00600
00601 << " npass " << eventsinlb_ << std::endl;
00602
00603 eventsinlb_=0;
00604
00605 }