00001 #include "HIPixelMedianVtxProducer.h"
00002
00003 #include "FWCore/Framework/interface/MakerMacros.h"
00004 #include "FWCore/Framework/interface/ESHandle.h"
00005 #include "FWCore/Framework/interface/Frameworkfwd.h"
00006 #include "FWCore/Framework/interface/Event.h"
00007
00008 #include "DataFormats/VertexReco/interface/Vertex.h"
00009 #include "DataFormats/VertexReco/interface/VertexFwd.h"
00010
00011 #include <fstream>
00012 #include <iostream>
00013 #include <vector>
00014 #include <algorithm>
00015
00016 #include "TROOT.h"
00017 #include "TH1F.h"
00018 #include "TF1.h"
00019
00020
00021 HIPixelMedianVtxProducer::HIPixelMedianVtxProducer(const edm::ParameterSet& ps) :
00022 theTrackCollection(ps.getParameter<edm::InputTag>("TrackCollection")),
00023 thePtMin(ps.getParameter<double>("PtMin")),
00024 thePeakFindThresh(ps.getParameter<unsigned int>("PeakFindThreshold")),
00025 thePeakFindMaxZ(ps.getParameter<double>("PeakFindMaxZ")),
00026 thePeakFindBinning(ps.getParameter<int>("PeakFindBinsPerCm")),
00027 theFitThreshold(ps.getParameter<int>("FitThreshold")),
00028 theFitMaxZ(ps.getParameter<double>("FitMaxZ")),
00029 theFitBinning(ps.getParameter<int>("FitBinsPerCm"))
00030 {
00031 produces<reco::VertexCollection>();
00032 }
00033
00034
00035 void HIPixelMedianVtxProducer::produce
00036 (edm::Event& ev, const edm::EventSetup& es)
00037 {
00038
00039 edm::Handle<reco::TrackCollection> trackCollection;
00040 ev.getByLabel(theTrackCollection, trackCollection);
00041 const reco::TrackCollection tracks_ = *(trackCollection.product());
00042
00043
00044 std::vector<const reco::Track *> tracks;
00045 for (unsigned int i=0; i<tracks_.size(); i++) {
00046 if (tracks_[i].pt() < thePtMin && std::fabs(tracks_[i].vz()) < 100000.) continue;
00047 reco::TrackRef recTrack(trackCollection, i);
00048 tracks.push_back( &(*recTrack));
00049 }
00050
00051 LogTrace("MinBiasTracking")
00052 << " [VertexProducer] selected tracks: "
00053 << tracks.size() << " (out of " << tracks_.size()
00054 << ") above pt = " << thePtMin;
00055
00056
00057 std::auto_ptr<reco::VertexCollection> vertices(new reco::VertexCollection);
00058
00059
00060 if(tracks.size() == 0) {
00061 ev.put(vertices);
00062 return;
00063 }
00064
00065
00066 std::sort(tracks.begin(), tracks.end(), ComparePairs());
00067
00068
00069 float med;
00070 if(tracks.size() % 2 == 0)
00071 med = (tracks[tracks.size()/2-1]->vz() + tracks[tracks.size()/2]->vz())/2;
00072 else
00073 med = tracks[tracks.size()/2 ]->vz();
00074
00075 LogTrace("MinBiasTracking")
00076 << " [vertex position] median = " << med << " cm";
00077
00078
00079 if(tracks.size() > thePeakFindThresh) {
00080
00081
00082 TH1F hmax("hmax","hmax",thePeakFindBinning*2.0*thePeakFindMaxZ,-1.0*thePeakFindMaxZ,thePeakFindMaxZ);
00083
00084 for(std::vector<const reco::Track *>::const_iterator
00085 track = tracks.begin(); track!= tracks.end(); track++)
00086 if(fabs((*track)->vz()) < thePeakFindMaxZ)
00087 hmax.Fill((*track)->vz());
00088
00089 int maxBin = hmax.GetMaximumBin();
00090
00091 LogTrace("MinBiasTracking")
00092 << " [vertex position] most prob = "
00093 << hmax.GetBinCenter(maxBin) << " cm";
00094
00095
00096 float num=0.0, denom=0.0;
00097 for(int i=-1; i<=1; i++) {
00098 num += hmax.GetBinContent(maxBin+i)*hmax.GetBinCenter(maxBin+i);
00099 denom += hmax.GetBinContent(maxBin+i);
00100 }
00101 float nBinAvg = num/denom;
00102
00103
00104 med = nBinAvg;
00105
00106 LogTrace("MinBiasTracking")
00107 << " [vertex position] 3-bin weighted average = "
00108 << nBinAvg << " cm";
00109
00110 }
00111
00112
00113 TH1F histo("histo","histo", theFitBinning*2.0*theFitMaxZ,-1.0*theFitMaxZ,theFitMaxZ);
00114 histo.Sumw2();
00115
00116 for(std::vector<const reco::Track *>::const_iterator
00117 track = tracks.begin(); track!= tracks.end(); track++)
00118 if(fabs((*track)->vz() - med) < theFitMaxZ)
00119 histo.Fill((*track)->vz() - med);
00120
00121 LogTrace("MinBiasTracking")
00122 << " [vertex position] most prob for fit = "
00123 << med + histo.GetBinCenter(histo.GetMaximumBin()) << " cm";
00124
00125
00126 if(histo.GetEntries() <= theFitThreshold) {
00127
00128 LogTrace("MinBiasTracking")
00129 << " [vertex position] Fewer than" << theFitThreshold
00130 << " entries in fit histogram. Returning median.";
00131
00132 reco::Vertex::Error err;
00133 err(2,2) = 0.1 * 0.1;
00134 reco::Vertex ver(reco::Vertex::Point(0,0,med),
00135 err, 0, 1, 1);
00136 vertices->push_back(ver);
00137 ev.put(vertices);
00138 return;
00139 }
00140
00141
00142 TF1 f1("f1","[0]*exp(-0.5 * ((x-[1])/[2])^2) + [3]");
00143 f1.SetParameters(10.,0.,0.02,0.002*tracks.size());
00144 f1.SetParLimits(1,-0.1,0.1);
00145 f1.SetParLimits(2,0.001,0.05);
00146 f1.SetParLimits(3,0.0,0.005*tracks.size());
00147
00148 histo.Fit("f1","QN");
00149
00150 LogTrace("MinBiasTracking")
00151 << " [vertex position] fitted = "
00152 << med + f1.GetParameter(1) << " +- " << f1.GetParError(1) << " cm";
00153
00154 reco::Vertex::Error err;
00155 err(2,2) = f1.GetParError(1) * f1.GetParError(1);
00156 reco::Vertex ver(reco::Vertex::Point(0,0,med + f1.GetParameter(1)),
00157 err, 0, 1, 1);
00158 vertices->push_back(ver);
00159
00160 ev.put(vertices);
00161 return;
00162
00163 }
00164