19 #include "CLHEP/Random/RandFlat.h"
20 #include "CLHEP/Random/RandGauss.h"
39 edm::LogInfo(
"SiStripGainCosmicCalculator::SiStripGainCosmicCalculator");
54 edm::LogInfo(
"SiStripApvGainCalculator")<<
"The calibration for these DetIds will be set to a default value";
56 edm::LogInfo(
"SiStripApvGainCalculator")<<
"exclude detid = "<< *imod;
65 edm::LogInfo(
"SiStripGainCosmicCalculator::~SiStripGainCosmicCalculator");
79 std::cout<<
"SiStripGainCosmicCalculator::algoBeginJob called"<<std::endl;
83 HlistOtherHistos->Add(
new TH1F( Form(
"APVPairCorrections"), Form(
"APVPairCorrections"), 50,-1.,4.));
84 HlistOtherHistos->Add(
new TH1F(Form(
"APVPairCorrectionsTIB1mono"),Form(
"APVPairCorrectionsTIB1mono"),50,-1.,4.));
85 HlistOtherHistos->Add(
new TH1F(Form(
"APVPairCorrectionsTIB1stereo"),Form(
"APVPairCorrectionsTIB1stereo"),50,-1.,4.));
86 HlistOtherHistos->Add(
new TH1F(Form(
"APVPairCorrectionsTIB2"),Form(
"APVPairCorrectionsTIB2"),50,-1.,4.));
87 HlistOtherHistos->Add(
new TH1F(Form(
"APVPairCorrectionsTOB1"),Form(
"APVPairCorrectionsTOB1"),50,-1.,4.));
88 HlistOtherHistos->Add(
new TH1F(Form(
"APVPairCorrectionsTOB2"),Form(
"APVPairCorrectionsTOB2"),50,-1.,4.));
89 HlistOtherHistos->Add(
new TH1F(Form(
"LocalAngle"),Form(
"LocalAngle"),70,-0.1,3.4));
90 HlistOtherHistos->Add(
new TH1F(Form(
"LocalAngleAbsoluteCosine"),Form(
"LocalAngleAbsoluteCosine"),48,-0.1,1.1));
91 HlistOtherHistos->Add(
new TH1F(Form(
"LocalPosition_cm"),Form(
"LocalPosition_cm"),100,-5.,5.));
92 HlistOtherHistos->Add(
new TH1F(Form(
"LocalPosition_normalized"),Form(
"LocalPosition_normalized"),100,-1.1,1.1));
93 TH1F* local_histo =
new TH1F(Form(
"SiStripRecHitType"),Form(
"SiStripRecHitType"),2,0.5,2.5);
HlistOtherHistos->Add(local_histo);
94 local_histo->GetXaxis()->SetBinLabel(1,
"simple"); local_histo->GetXaxis()->SetBinLabel(2,
"matched");
98 std::vector<uint32_t> activeDets; activeDets.clear();
100 siStripDetCabling->addActiveDetectorsRawIds(activeDets);
108 for(TrackerGeometry::DetContainer::const_iterator it = tkGeom->dets().begin(); it != tkGeom->dets().end(); it++){
109 if( dynamic_cast<StripGeomDetUnit*>((*it))!=0){
110 uint32_t
detid=((*it)->geographicalId()).rawId();
112 double module_thickness = (*it)->surface().bounds().thickness();
113 thickness_map.insert(std::make_pair(detid,module_thickness));
115 bool is_active_detector =
false;
117 if( *iactive == detid ){
118 is_active_detector =
true;
123 bool exclude_this_detid =
false;
125 if(*imod == detid) exclude_this_detid =
true;
129 if(is_active_detector && (!exclude_this_detid)){
131 unsigned short NAPVPairs = p.
nstrips()/256;
132 if( NAPVPairs<2 || NAPVPairs>3 ) {
133 edm::LogError(
"SiStripGainCosmicCalculator")<<
"Problem with Number of strips in detector: "<<p.
nstrips()<<
" Exiting program";
136 for(
int iapp = 0; iapp<NAPVPairs; iapp++){
137 TString hid = Form(
"ChargeAPVPair_%i_%i",detid,iapp);
166 for(reco::TrackCollection::const_iterator itr =
tracks->begin(); itr !=
tracks->end(); itr++){
170 std::vector<std::pair<const TrackingRecHit *,float> >hitangle;
172 for(std::vector<std::pair<const TrackingRecHit *,float> >::const_iterator hitangle_iter=hitangle.begin();hitangle_iter!=hitangle.end();hitangle_iter++){
174 float local_angle=hitangle_iter->second;
176 const SiStripRecHit2D* sistripsimplehit=
dynamic_cast<const SiStripRecHit2D*
>(trechit);
177 const SiStripMatchedRecHit2D* sistripmatchedhit=
dynamic_cast<const SiStripMatchedRecHit2D*
>(trechit);
181 if(sistripsimplehit){
183 const SiStripRecHit2D::ClusterRef & cluster=sistripsimplehit->cluster();
184 const std::vector<uint8_t>& ampls = cluster->amplitudes();
186 uint32_t thedetid = cluster->geographicalId();
187 double module_width =
moduleWidth(thedetid, &iSetup);
189 ((TH1F*)
HlistOtherHistos->FindObject(
"LocalPosition_normalized"))->
Fill(local_position.
x()/module_width);
191 int ifirststrip= cluster->firstStrip();
192 int theapvpairid = int(
float(ifirststrip)/256.);
193 TH1F* histopointer = (TH1F*)
HlistAPVPairs->FindObject(Form(
"ChargeAPVPair_%i_%i",thedetid,theapvpairid));
196 for(
unsigned int iampl = 0; iampl<ampls.size(); iampl++){
197 cCharge += ampls[iampl];
199 double cluster_charge_over_path = ((double)cCharge) * fabs(
cos(local_angle)) / ( 10. * module_thickness);
200 histopointer->Fill(cluster_charge_over_path);
213 double adcs = -0.5;
double error = 0.;
double nr_of_entries = inputHisto->GetEntries();
215 return std::make_pair(adcs,error);
226 inputHisto->Fit(
"landau",
"0Q");
227 TF1 * fitfunction = (TF1*) inputHisto->GetListOfFunctions()->First();
228 adcs = fitfunction->GetParameter(
"MPV");
229 error = fitfunction->GetParError(1);
230 double chi2 = fitfunction->GetChisquare();
231 double ndf = fitfunction->GetNDF();
232 double chi2overndf = chi2 / ndf;
234 if(adcs< 2. || (error/adcs)>1.8 ){
235 inputHisto->Fit(
"landau",
"0Q",0,0.,400.);
236 TF1 * fitfunction2 = (TF1*) inputHisto->GetListOfFunctions()->First();
237 std::cout<<
"refitting landau for histogram "<<inputHisto->GetTitle()<<std::endl;
238 std::cout<<
"initial error/adcs ="<<error<<
" / "<<adcs<<std::endl;
239 std::cout<<
"new error/adcs ="<<fitfunction2->GetParError(1)<<
" / "<<fitfunction2->GetParameter(
"MPV")<<std::endl;
240 adcs = fitfunction2->GetParameter(
"MPV");
241 error = fitfunction2->GetParError(1);
242 chi2 = fitfunction2->GetChisquare();
243 ndf = fitfunction2->GetNDF();
244 chi2overndf = chi2 / ndf;
248 adcs = -0.5; error = 0.;
250 return std::make_pair(adcs,error);
257 double module_width=0.;
259 if (dynamic_cast<const StripGeomDetUnit*>(it)==0 && dynamic_cast<const PixelGeomDetUnit*>(it)==0) {
260 std::cout <<
"this detID doesn't seem to belong to the Tracker" << std::endl;
271 double module_thickness=0.;
273 if (dynamic_cast<const StripGeomDetUnit*>(it)==0 && dynamic_cast<const PixelGeomDetUnit*>(it)==0) {
274 std::cout <<
"this detID doesn't seem to belong to the Tracker" << std::endl;
278 return module_thickness;
283 std::cout<<
"SiStripGainCosmicCalculator::getNewObject called"<<std::endl;
287 TH1F *ChargeOfEachAPVPair =
new TH1F(
"ChargeOfEachAPVPair",
"ChargeOfEachAPVPair",1,0,1); ChargeOfEachAPVPair->SetBit(TH1::kCanRebin);
288 TH1F *EntriesApvPairs =
new TH1F(
"EntriesApvPairs",
"EntriesApvPairs",1,0,1); EntriesApvPairs->SetBit(TH1::kCanRebin);
289 TH1F * NrOfEntries =
new TH1F(
"NrOfEntries",
"NrOfEntries",351,-0.5,350.5);
290 TH1F * ModuleThickness =
new TH1F(
"ModuleThickness",
"ModuleThickness",2,0.5,2.5);
HlistOtherHistos->Add(ModuleThickness);
291 ModuleThickness->GetXaxis()->SetBinLabel(1,
"320mu"); ModuleThickness->GetXaxis()->SetBinLabel(2,
"500mu"); ModuleThickness->SetYTitle(
"Nr APVPairs");
292 TH1F * ModuleWidth =
new TH1F(
"ModuleWidth",
"ModuleWidth",5,0.5,5.5);
HlistOtherHistos->Add(ModuleWidth);
293 ModuleWidth->GetXaxis()->SetBinLabel(1,
"6.144cm"); ModuleWidth->GetXaxis()->SetBinLabel(2,
"7.14cm");
294 ModuleWidth->GetXaxis()->SetBinLabel(3,
"9.3696cm"); ModuleWidth->GetXaxis()->SetBinLabel(4,
"10.49cm");
295 ModuleWidth->GetXaxis()->SetBinLabel(5,
"12.03cm");
296 ModuleWidth->SetYTitle(
"Nr APVPairs");
300 double MeanCharge = 0.;
301 double NrOfApvPairs = 0.;
302 TH1F *MyHisto = (TH1F*)hiterator();
304 TString histo_title = MyHisto->GetTitle();
305 if(histo_title.Contains(
"ChargeAPVPair_")){
307 double local_nrofadcs = two_values.first;
308 double local_sigma = two_values.second;
309 ChargeOfEachAPVPair->Fill(histo_title, local_nrofadcs);
310 int ichbin = ChargeOfEachAPVPair->GetXaxis()->FindBin(histo_title.Data());
311 ChargeOfEachAPVPair->SetBinError(ichbin,local_sigma);
312 EntriesApvPairs->Fill(histo_title, MyHisto->GetEntries());
313 NrOfEntries->Fill(MyHisto->GetEntries());
314 if(local_nrofadcs > 0){
315 MeanCharge += local_nrofadcs;
319 MyHisto = (TH1F*)hiterator();
321 ChargeOfEachAPVPair->LabelsDeflate(
"X"); EntriesApvPairs->LabelsDeflate(
"X");
325 MeanCharge = MeanCharge / NrOfApvPairs;
327 TH1F* CorrectionOfEachAPVPair = (TH1F*) ChargeOfEachAPVPair->Clone(
"CorrectionOfEachAPVPair");
328 TH1F *ChargeOfEachAPVPairControlView =
new TH1F(
"ChargeOfEachAPVPairControlView",
"ChargeOfEachAPVPairControlView",1,0,1); ChargeOfEachAPVPairControlView->SetBit(TH1::kCanRebin);
329 TH1F *CorrectionOfEachAPVPairControlView =
new TH1F(
"CorrectionOfEachAPVPairControlView",
"CorrectionOfEachAPVPairControlView",1,0,1); CorrectionOfEachAPVPairControlView->SetBit(TH1::kCanRebin);
330 std::ofstream APVPairTextOutput(
"apvpair_corrections.txt");
331 APVPairTextOutput<<
"# MeanCharge = "<<MeanCharge<<std::endl;
332 APVPairTextOutput<<
"# Nr. of APVPairs = "<<NrOfApvPairs<<std::endl;
333 for(
int ibin=1; ibin <= ChargeOfEachAPVPair->GetNbinsX(); ibin++){
334 TString local_bin_label = ChargeOfEachAPVPair->GetXaxis()->GetBinLabel(ibin);
335 double local_charge_over_path = ChargeOfEachAPVPair->GetBinContent(ibin);
336 if(local_bin_label.Contains(
"ChargeAPVPair_") && local_charge_over_path > 0.0000001){
337 uint32_t extracted_detid; std::istringstream read_label((local_bin_label(14,9)).
Data()); read_label >> extracted_detid;
338 unsigned short extracted_apvpairid; std::istringstream read_apvpair((local_bin_label(24,1)).
Data()); read_apvpair >> extracted_apvpairid;
339 double local_error_of_charge = ChargeOfEachAPVPair->GetBinError(ibin);
340 double local_correction = -0.5;
341 double local_error_correction = 0.;
342 local_correction = MeanCharge / local_charge_over_path;
343 local_error_correction = local_correction * local_error_of_charge / local_charge_over_path;
344 if(local_error_correction>1.8){
345 std::cout<<
"too large error "<<local_error_correction<<
" for histogram "<<local_bin_label<<std::endl;
347 double nr_of_entries = EntriesApvPairs->GetBinContent(ibin);
348 APVPairTextOutput<<local_bin_label<<
" "<<local_correction<<
" "<<local_charge_over_path<<
" "<<nr_of_entries<<std::endl;
349 CorrectionOfEachAPVPair->SetBinContent(ibin, local_correction);
350 CorrectionOfEachAPVPair->SetBinError(ibin, local_error_correction);
353 unsigned int generalized_layer = 0;
363 generalized_layer = 10*thedetId.
subdetId();
369 if(generalized_layer==31){
372 if(generalized_layer==32){
375 if(generalized_layer==33){
378 if(generalized_layer==51){
381 if(generalized_layer==52){
386 const FedChannelConnection& fedchannelconnection = siStripDetCabling->getConnection( extracted_detid, extracted_apvpairid );
387 std::ostringstream local_key;
389 local_key<<
"fecCrate"<<fedchannelconnection.
fecCrate()<<
"_fecSlot"<<fedchannelconnection.
fecSlot()<<
"_fecRing"<<fedchannelconnection.
fecRing()<<
"_ccuAddr"<<fedchannelconnection.
ccuAddr()<<
"_ccuChan"<<fedchannelconnection.
ccuChan()<<
"_apvPair"<<extracted_apvpairid;
390 TString control_key = local_key.str();
391 ChargeOfEachAPVPairControlView->Fill(control_key,local_charge_over_path);
392 int ibin1 = ChargeOfEachAPVPairControlView->GetXaxis()->FindBin(control_key);
393 ChargeOfEachAPVPairControlView->SetBinError(ibin1,local_error_of_charge);
394 CorrectionOfEachAPVPairControlView->Fill(control_key, local_correction);
395 int ibin2 = CorrectionOfEachAPVPairControlView->GetXaxis()->FindBin(control_key);
396 CorrectionOfEachAPVPairControlView->SetBinError(ibin2, local_error_correction);
399 if( fabs(module_thickness - 0.032)<0.001 ) ModuleThickness->Fill(1);
400 if( fabs(module_thickness - 0.05)<0.001 ) ModuleThickness->Fill(2);
403 if(fabs(module_width-6.144)<0.01) ModuleWidth->Fill(1);
404 if(fabs(module_width-7.14)<0.01) ModuleWidth->Fill(2);
405 if(fabs(module_width-9.3696)<0.01) ModuleWidth->Fill(3);
406 if(fabs(module_width-10.49)<0.01) ModuleWidth->Fill(4);
407 if(fabs(module_width-12.03)<0.01) ModuleWidth->Fill(5);
411 ChargeOfEachAPVPairControlView->LabelsDeflate(
"X");
412 CorrectionOfEachAPVPairControlView->LabelsDeflate(
"X");
const uint16_t & fecSlot() const
T getParameter(std::string const &) const
TObjArray * HlistAPVPairs
virtual int nstrips() const =0
T getUntrackedParameter(std::string const &, T const &) const
uint32_t total_nr_of_events
std::vector< uint32_t > SelectedDetIds
double ExpectedChargeDeposition
const uint16_t & fecCrate() const
unsigned int tibLayer(const DetId &id) const
double moduleThickness(const uint32_t detid, const edm::EventSetup *iSetup)
TObjArray * HlistOtherHistos
const edm::EventSetup * eventSetupCopy_
std::vector< Track > TrackCollection
collection of Tracks
const Bounds & bounds() const
~SiStripGainCosmicCalculator()
bool outputHistogramsInRootFile
double moduleWidth(const uint32_t detid, const edm::EventSetup *iSetup)
const Plane & surface() const
The nominal surface of the GeomDet.
std::pair< double, double > getPeakOfLandau(TH1F *inputHisto)
uint32_t rawId() const
get the raw id
virtual float thickness() const =0
unsigned int MinNrEntries
const uint16_t & fecRing() const
void getTOBDetectors(const std::vector< uint32_t > &inputDetRawIds, std::vector< uint32_t > &tobDetRawIds, uint32_t layer=0, uint32_t bkw_frw=0, uint32_t rod=0) const
Class containning control, module, detector and connection information, at the level of a FED channel...
void Fill(HcalDetId &id, double val, std::vector< TH2F > &depth)
void algoBeginJob(const edm::EventSetup &)
Cos< T >::type cos(const T &t)
const uint16_t & ccuChan() const
SiStripGainCosmicCalculator(const edm::ParameterSet &)
std::map< uint32_t, double > thickness_map
int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum) ...
const uint16_t & ccuAddr() const
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
SiStripApvGain * getNewObject()
uint32_t tibGlued(const DetId &id) const
const TrackerTopology * tTopo
std::vector< uint32_t > detModulesToBeExcluded
T const * product() const
void algoAnalyze(const edm::Event &, const edm::EventSetup &)
void getTIBDetectors(const std::vector< uint32_t > &inputDetRawIds, std::vector< uint32_t > &tibDetRawIds, uint32_t layer=0, uint32_t bkw_frw=0, uint32_t int_ext=0, uint32_t string=0) const
uint32_t tibStereo(const DetId &id) const
virtual LocalPoint localPosition() const =0
virtual float width() const =0
unsigned int tobLayer(const DetId &id) const