00001
00002
00003
00004
00006 #ifndef JETCALIBTOOLS_JETCALIBRATIONTOOLBASE_H
00007 #define JETCALIBTOOLS_JETCALIBRATIONTOOLBASE_H 1
00008
00009
00010 #include "AsgTools/ToolHandle.h"
00011 #include "AsgTools/AsgTool.h"
00012 #include "PATInterfaces/CorrectionTool.h"
00013
00014
00015 #include "xAODJet/JetContainer.h"
00016
00017
00018 #include <TSystem.h>
00019 #include <TEnv.h>
00020 #include <TLorentzVector.h>
00021
00022
00023 #include "JetInterface/IJetModifier.h"
00024 #include "JetInterface/ISingleJetModifier.h"
00025
00026
00027 #include "JetCalibTools/IJetCalibrationTool.h"
00028 #include "JetCalibTools/JetCalibUtils.h"
00029
00030 class JetCalibrationToolBase
00031 : virtual public asg::AsgTool,
00032 virtual public CP::CorrectionTool< xAOD::JetContainer >,
00033 virtual public ::IJetCalibrationTool,
00034 virtual public ::IJetModifier,
00035 virtual public ::ISingleJetModifier
00036 {
00037
00038 ASG_TOOL_CLASS( JetCalibrationToolBase, IJetCalibrationTool )
00039
00040
00041
00043 public:
00044 friend class JetCalibrationTool;
00045
00046
00047 JetCalibrationToolBase();
00048
00050 JetCalibrationToolBase(const std::string& name);
00051
00053 virtual ~JetCalibrationToolBase();
00054
00055
00056 virtual StatusCode initialize() { return StatusCode::FAILURE; }
00057
00059 virtual StatusCode applyCalibration(xAOD::Jet& jet) const;
00060
00061 virtual CP::CorrectionCode applyCorrection(xAOD::Jet&) { return CP::CorrectionCode::Ok; }
00062
00063 virtual CP::CorrectionCode calibratedCopy(const xAOD::Jet& inputJet, xAOD::Jet*& outputJet) {
00064 return CP::CorrectionTool< xAOD::JetContainer >::correctedCopy( inputJet, outputJet );
00065 }
00066
00067 virtual CP::CorrectionCode correctedCopy(const xAOD::Jet& inputJet, xAOD::Jet*& outputJet) {
00068 return calibratedCopy( inputJet, outputJet );
00069 }
00070
00071 virtual int modify(xAOD::JetContainer&) const { return 0; }
00072 virtual int modifyJet(xAOD::Jet&) const { return 0; }
00073
00074 virtual void setUnitsGeV(bool useGeV) { if (useGeV) m_GeV=1; else m_GeV=1000; }
00075
00077
00079 protected:
00081 virtual StatusCode calibrateImpl(xAOD::Jet&, JetEventInfo&) const;
00082
00083 virtual TString FindFile(TString filename);
00084
00085 virtual StatusCode setStartP4(xAOD::Jet& jet) const;
00086
00087 protected:
00088 static double m_GeV;
00089 TString m_jetStartScale;
00090
00091 private:
00092 std::string m_jetAlgo;
00093 std::string m_config;
00094 std::string m_calibSeq;
00095 std::string m_calibAreaTag;
00096 bool m_isData;
00097 std::string m_dir;
00098
00099 TString m_basePath;
00100
00101 };
00102
00103
00105
00107
00109
00110
00111 #endif //> !JETCALIBTOOLS_JETCALIBRATIONTOOLBASE_H