![]() |
![]() |
00001 // 00002 // Original Author: Fedor Ratnikov Oct 21, 2005 00003 // $Id: HcalHardcodeCalibrations.h,v 1.15 2010/02/22 20:51:12 kukartse Exp $ 00004 // 00005 // ESSource to generate default HCAL calibration objects 00006 // 00007 #include <map> 00008 #include <string> 00009 00010 #include "FWCore/Framework/interface/ESProducer.h" 00011 #include "FWCore/Framework/interface/EventSetupRecordIntervalFinder.h" 00012 #include "FWCore/ParameterSet/interface/ParameterSet.h" 00013 00014 #include "CondFormats/HcalObjects/interface/AllObjects.h" 00015 class ParameterSet; 00016 00017 class HcalPedestalsRcd; 00018 class HcalPedestalWidthsRcd; 00019 class HcalGainsRcd; 00020 class HcalGainWidthsRcd; 00021 class HcalQIEDataRcd; 00022 class HcalChannelQualityRcd; 00023 class HcalElectronicsMapRcd; 00024 class HcalRespCorrsRcd; 00025 class HcalZSThresholdsRcd; 00026 class HcalL1TriggerObjectsRcd; 00027 class HcalTimeCorrsRcd; 00028 class HcalLUTCorrsRcd; 00029 class HcalPFCorrsRcd; 00030 class HcalValidationCorrsRcd; 00031 class HcalLutMetadataRcd; 00032 class HcalDcsRcd; 00033 class HcalDcsMapRcd; 00034 00035 class HcalHardcodeCalibrations : public edm::ESProducer, 00036 public edm::EventSetupRecordIntervalFinder 00037 { 00038 public: 00039 HcalHardcodeCalibrations (const edm::ParameterSet& ); 00040 ~HcalHardcodeCalibrations (); 00041 00042 void produce () {}; 00043 00044 protected: 00045 virtual void setIntervalFor(const edm::eventsetup::EventSetupRecordKey&, 00046 const edm::IOVSyncValue& , 00047 edm::ValidityInterval&) ; 00048 00049 std::auto_ptr<HcalPedestals> producePedestals (const HcalPedestalsRcd& rcd); 00050 std::auto_ptr<HcalPedestalWidths> producePedestalWidths (const HcalPedestalWidthsRcd& rcd); 00051 std::auto_ptr<HcalGains> produceGains (const HcalGainsRcd& rcd); 00052 std::auto_ptr<HcalGainWidths> produceGainWidths (const HcalGainWidthsRcd& rcd); 00053 std::auto_ptr<HcalQIEData> produceQIEData (const HcalQIEDataRcd& rcd); 00054 std::auto_ptr<HcalChannelQuality> produceChannelQuality (const HcalChannelQualityRcd& rcd); 00055 std::auto_ptr<HcalElectronicsMap> produceElectronicsMap (const HcalElectronicsMapRcd& rcd); 00056 00057 std::auto_ptr<HcalRespCorrs> produceRespCorrs (const HcalRespCorrsRcd& rcd); 00058 std::auto_ptr<HcalZSThresholds> produceZSThresholds (const HcalZSThresholdsRcd& rcd); 00059 std::auto_ptr<HcalL1TriggerObjects> produceL1TriggerObjects (const HcalL1TriggerObjectsRcd& rcd); 00060 std::auto_ptr<HcalTimeCorrs> produceTimeCorrs (const HcalTimeCorrsRcd& rcd); 00061 std::auto_ptr<HcalLUTCorrs> produceLUTCorrs (const HcalLUTCorrsRcd& rcd); 00062 std::auto_ptr<HcalPFCorrs> producePFCorrs (const HcalPFCorrsRcd& rcd); 00063 00064 std::auto_ptr<HcalValidationCorrs> produceValidationCorrs (const HcalValidationCorrsRcd& rcd); 00065 std::auto_ptr<HcalLutMetadata> produceLutMetadata (const HcalLutMetadataRcd& rcd); 00066 std::auto_ptr<HcalDcsValues> produceDcsValues (const HcalDcsRcd& rcd); 00067 std::auto_ptr<HcalDcsMap> produceDcsMap (const HcalDcsMapRcd& rcd); 00068 00069 bool h2mode_; 00070 }; 00071