DeDxDiscriminatorLearner

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
#ifndef TrackRecoDeDx_DeDxDiscriminatorLearner_H
#define TrackRecoDeDx_DeDxDiscriminatorLearner_H

#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"

#include "CommonTools/ConditionDBWriter/interface/ConditionDBWriter.h"
#include "CondFormats/PhysicsToolsObjects/interface/Histogram3D.h"

#include "TrackingTools/PatternTools/interface/Trajectory.h"
#include "TrackingTools/PatternTools/interface/TrajTrackAssociation.h"
#include "TrackingTools/TrajectoryState/interface/TrajectoryStateOnSurface.h"

#include "RecoTracker/DeDx/interface/DeDxTools.h"

#include "TFile.h"
#include "TH3F.h"

#include <memory>

class DeDxDiscriminatorLearner : public ConditionDBWriter<PhysicsTools::Calibration::HistogramD3D> {
public:
  explicit DeDxDiscriminatorLearner(const edm::ParameterSet&);
  ~DeDxDiscriminatorLearner() override;

private:
  void algoBeginJob(const edm::EventSetup&) override;
  void algoAnalyze(const edm::Event&, const edm::EventSetup&) override;
  void algoEndJob() override;

  void processHit(const TrackingRecHit* recHit,
                  float trackMomentum,
                  float& cosine,
                  const TrajectoryStateOnSurface& trajState);
  void algoAnalyzeTheTree(const edm::EventSetup& iSetup);

  std::unique_ptr<PhysicsTools::Calibration::HistogramD3D> getNewObject() override;

  // ----------member data ---------------------------
  edm::EDGetTokenT<TrajTrackAssociationCollection> m_trajTrackAssociationTag;
  edm::EDGetTokenT<reco::TrackCollection> m_tracksTag;

  edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> m_tkGeomToken;

  float MinTrackMomentum;
  float MaxTrackMomentum;
  float MinTrackEta;
  float MaxTrackEta;
  unsigned int MaxNrStrips;
  unsigned int MinTrackHits;
  float MaxTrackChiOverNdf;

  float P_Min;
  float P_Max;
  int P_NBins;
  float Path_Min;
  float Path_Max;
  int Path_NBins;
  float Charge_Min;
  float Charge_Max;
  int Charge_NBins;

  std::vector<std::string> VInputFiles;
  std::string algoMode;
  std::string HistoFile;

  TH3F* Charge_Vs_Path;

  std::string m_calibrationPath;
  bool useCalibration;
  bool shapetest;

  std::vector<std::vector<float> > calibGains;
  unsigned int m_off;
};

#endif