CMS 3D CMS Logo

DTPerformanceHandler.cc
Go to the documentation of this file.
1 /*
2  * See header file for a description of this class.
3  *
4  * $Date: 2008/02/15 18:14:45 $
5  * $Revision: 1.3 $
6  * \author Paolo Ronchese INFN Padova
7  *
8  */
9 
10 //-----------------------
11 // This Class' Header --
12 //-----------------------
14 
15 //-------------------------------
16 // Collaborating Class Headers --
17 //-------------------------------
19 
20 //---------------
21 // C++ Headers --
22 //---------------
23 #include <iostream>
24 #include <fstream>
25 
26 //-------------------
27 // Initializations --
28 //-------------------
29 
30 
31 //----------------
32 // Constructors --
33 //----------------
35  dataTag( ps.getParameter<std::string> ( "tag" ) ),
36  fileName( ps.getParameter<std::string> ( "file" ) ),
37  runNumber( ps.getParameter<unsigned int> ( "run" ) ) {
38 }
39 
40 //--------------
41 // Destructor --
42 //--------------
44 }
45 
46 //--------------
47 // Operations --
48 //--------------
50 
51  //to access the information on the tag inside the offline database:
52  cond::TagInfo const & ti = tagInfo();
53  unsigned int last = ti.lastInterval.first;
54 
55  //to access the information on last successful log entry for this tag:
56 // cond::LogDBEntry const & lde = logDBEntry();
57 
58  //to access the lastest payload (Ref is a smart pointer)
59 // Ref payload = lastPayload();
60 
61 /*
62  int irun = event.id().run();
63  int ievt = event.id().event();
64  std::cout << "================ "
65  << irun << " " << ievt << std::endl;
66 
67 // edm::Service<cond::service::PoolDBOutputService> dbservice;
68 
69  std::map<std::string, popcon::PayloadIOV> mp = getOfflineInfo();
70  std::map<std::string, popcon::PayloadIOV>::iterator iter = mp.begin();
71  std::map<std::string, popcon::PayloadIOV>::iterator iend = mp.end();
72  std::cout << "list of all tags: " << std::endl;
73  while ( iter != iend ) {
74  std::cout << "Tag: " << iter->first
75  << " , last object valid since " << iter->second.last_since
76  << " to " << iter->second.last_till
77  << std::endl;
78  iter++;
79  }
80 
81  std::cout << "look for tag " << dataTag << std::endl;
82  std::map<std::string, popcon::PayloadIOV>::iterator itag =
83  mp.find( dataTag );
84 */
85 
86  DTPerformance* dtPerf = new DTPerformance( dataTag );
87 
88  int status = 0;
89  std::ifstream ifile( fileName.c_str() );
90  int whe;
91  int sta;
92  int sec;
93  int qua;
94  float meanT0;
95  float meanTtrig;
96  float meanMtime;
97  float meanNoise;
98  float meanAfterPulse;
99  float meanResolution;
100  float meanEfficiency;
101  while ( ifile >> whe
102  >> sta
103  >> sec
104  >> qua
105  >> meanT0
106  >> meanTtrig
107  >> meanMtime
108  >> meanNoise
109  >> meanAfterPulse
110  >> meanResolution
111  >> meanEfficiency ) {
112  status = dtPerf->set( whe, sta, sec, qua,
113  meanT0, meanTtrig, meanMtime, meanNoise,
114  meanAfterPulse, meanResolution, meanEfficiency,
116  std::cout << whe << " "
117  << sta << " "
118  << sec << " "
119  << qua << std::endl << " === "
120  << meanT0 << " "
121  << meanTtrig << " "
122  << meanMtime << " "
123  << meanNoise << " "
124  << meanAfterPulse << " "
125  << meanResolution << " "
126  << meanEfficiency << std::endl << " -> ";
127  std::cout << "insert status: " << status << std::endl;
128  }
129 
130 /*
131  unsigned int runf = irun;
132  unsigned int runl = 0xffffffff;
133  popcon::IOVPair iop = { runf, runl };
134  std::cout << "APPEND NEW OBJECT: "
135  << runf << " " << runl << " " << dtPerf << std::endl;
136  m_to_transfer->push_back( std::make_pair( dtPerf, iop ) );
137 */
138 
139  //for each payload provide IOV information (say in this case we use since)
140  cond::Time_t snc = runNumber;
141  if ( runNumber > last )
142  m_to_transfer.push_back( std::make_pair( dtPerf, snc ) );
143  else
144  std::cout << "More recent data already present - skipped" << std::endl;
145 
146  return;
147 
148 }
149 
150 
152  return dataTag;
153 }
154 
155 
DTPerformanceHandler(const edm::ParameterSet &ps)
cond::ValidityInterval lastInterval
Definition: Types.h:75
unsigned long long Time_t
Definition: Time.h:16
int set(int wheelId, int stationId, int sectorId, int slId, float meanT0, float meanTtrig, float meanMtime, float meanNoise, float meanAfterPulse, float meanResolution, float meanEfficiency, DTTimeUnits::type unit)
std::string id() const