23 #include "Fed9UUtils.hh"
26 using namespace sistrip;
33 m_gaincalibrationfactor(static_cast<float>(pset.getUntrackedParameter<double>(
"GainNormalizationFactor",690.))),
34 m_defaultpedestalvalue(static_cast<float>(pset.getUntrackedParameter<double>(
"DefaultPedestal",0.))),
35 m_defaultnoisevalue(static_cast<float>(pset.getUntrackedParameter<double>(
"DefaultNoise",0.))),
36 m_defaultthresholdhighvalue(static_cast<float>(pset.getUntrackedParameter<double>(
"DefaultThresholdHigh",0.))),
37 m_defaultthresholdlowvalue(static_cast<float>(pset.getUntrackedParameter<double>(
"DefaultThresholdLow",0.))),
38 m_defaultapvmodevalue(static_cast<uint16_t>(pset.getUntrackedParameter<uint32_t>(
"DefaultAPVMode",37))),
39 m_defaultapvlatencyvalue(static_cast<uint16_t>(pset.getUntrackedParameter<uint32_t>(
"DefaultAPVLatency",142))),
40 m_defaulttickheightvalue(static_cast<float>(pset.getUntrackedParameter<double>(
"DefaultTickHeight",690.))),
41 m_useanalysis(static_cast<bool>(pset.getUntrackedParameter<bool>(
"UseAnalysis",
false))),
42 m_usefed(static_cast<bool>(pset.getUntrackedParameter<bool>(
"UseFED",
false))),
43 m_usefec(static_cast<bool>(pset.getUntrackedParameter<bool>(
"UseFEC",
false))),
44 m_debug(static_cast<bool>(pset.getUntrackedParameter<bool>(
"DebugMode",
false)))
47 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
48 <<
" Constructing object...";
56 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
57 <<
" Constructing object...";
64 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
65 <<
" Destructing object...";
88 SiStripDbParams::SiStripPartitions::const_iterator ipart = partitionsRange.begin();
89 SiStripDbParams::SiStripPartitions::const_iterator ipartEnd = partitionsRange.end();
90 for ( ; ipart != ipartEnd; ++ipart ) {
94 if (label!=
"Cabling" && label !=
"ApvLatency")
99 if(label==
"ApvTiming")
101 if(label==
"ApvLatency")
102 output<<
" FecVersion " << partition.
fecVersion().first <<
"." << partition.
fecVersion().second;
105 if (!strcmp(output.str().c_str(),input.str().c_str()))
115 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]";
145 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
146 <<
" NULL pointer to DeviceFactory returned by SiStripConfigDb!"
147 <<
" Cannot build Pedestals object!";
151 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
152 <<
" NULL pointer to SiStripConfigDb returned by DB \"service\"!"
153 <<
" Cannot build Pedestals object!";
162 if ( descriptions.empty() ) {
164 <<
"SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
165 <<
" No FED descriptions found!";
178 if ( anal_descriptions.empty() ) {
180 <<
"SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
181 <<
" Unable to build SiStripApvGain object!"
182 <<
" No timing-scan analysis descriptions found!";
192 vector<uint32_t> det_ids;
194 if ( det_ids.empty() ) {
196 <<
"SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
197 <<
" Unable to build Pedestals object!"
198 <<
" No DetIds found!";
202 <<
"\n\nSiStripCondObjBuilderFromDb::" << __func__ <<
"]"
203 <<
" Found " << det_ids.size() <<
" active DetIds";
211 vector<const FedChannelConnection *> conns = det_cabling.
getConnections(det_id);
212 if (conns.size()==0){
214 <<
"SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
215 <<
" Unable to build condition object!"
216 <<
" No FED channel connections found for detid "<< det_id;
236 std::cout <<
"Found disabled FedConnection! APVPair: " << apvPair <<
" Strips: " << sistrip::STRIPS_PER_FEDCH << std::endl;
238 for ( ;istrip < (apvPair+1)*sistrip::STRIPS_PER_FEDCH; ++istrip ){
255 std::cout <<
"[SiStripCondObjBuilderFromDb::"<<__func__<<
"]: Set Default Latency for Detid: " << detid <<
" ApvNr: " << apvnr << std::endl;
258 std::cout <<
"[SiStripCondObjBuilderFromDb::"<<__func__<<
"]: Unable to fill Latency for Detid: " << detid <<
" ApvNr: " << apvnr << std::endl;
262 std::cout <<
"[SiStripCondObjBuilderFromDb::"<<__func__<<
"]: Unable to fill Latency for Detid: " << detid <<
" ApvNr: " << apvnr << std::endl;
273 SiStripConfigDb::AnalysisDescriptionsV::const_iterator iii = anal_descriptions.begin();
274 SiStripConfigDb::AnalysisDescriptionsV::const_iterator jjj = anal_descriptions.end();
276 while ( iii != jjj ) {
277 CommissioningAnalysisDescription*
tmp = *iii;
278 uint16_t fed_id = tmp->getFedId();
280 if ( fed_id == ipair.
fedId() && fed_ch == ipair.
fedCh() ) {
break; }
284 TimingAnalysisDescription *anal=0;
285 if ( iii != jjj ) { anal =
dynamic_cast<TimingAnalysisDescription*
>(*iii); }
305 SiStripConfigDb::DeviceDescriptionsV::const_iterator iapv = apvs.begin();
306 SiStripConfigDb::DeviceDescriptionsV::const_iterator japv = apvs.end();
307 if(iapv==japv)
return false;
308 for ( ; iapv != japv; ++iapv ) {
309 apvDescription* apv =
dynamic_cast<apvDescription*
>( *iapv );
310 if ( !apv ) {
continue; }
311 if((apv->getCrateId()) != (ipair.
fecCrate()))
continue;
312 if((apv->getFecSlot()) != (ipair.
fecSlot()))
continue;
313 if((apv->getRingSlot()) != (ipair.
fecRing()))
continue;
314 if((apv->getCcuAddress()) != (ipair.
ccuAddr()))
continue;
315 if((apv->getChannel()) != (ipair.
ccuChan()))
continue;
317 if((apv->getAddress()) == (ipair.
i2cAddr(0))) {
318 if(!latency_.
put( detid, apvnr, static_cast<uint16_t>(apv->getLatency()), static_cast<uint16_t>(apv->getApvMode()))){
319 std::cout <<
"UNABLE APVLatency Put: Detid "<< dec<<detid
320 <<
" APVNr.: " << apvnr
321 <<
" Latency Value: " << dec <<static_cast<uint16_t>(apv->getLatency())
322 <<
" APV Mode: " << dec<< static_cast<uint16_t>(apv->getApvMode())
327 if((apv->getAddress()) == (ipair.
i2cAddr(1))) {
328 if(!latency_.
put( detid, apvnr, static_cast<uint16_t>(apv->getLatency()), static_cast<uint16_t>(apv->getApvMode()))){
329 std::cout <<
"UNABLE APVLatency Put: Detid "<<dec<< detid
330 <<
" APVNr.: " << apvnr
331 <<
" Latency Value: " << dec <<static_cast<uint16_t>(apv->getLatency())
332 <<
" APV Mode: " << dec <<static_cast<uint16_t>(apv->getApvMode())
347 SiStripConfigDb::FedDescriptionsV::const_iterator
description = descriptions.begin();
348 while ( description != descriptions.end() ) {
349 if ( (*description)->getFedId() ==ipair.
fedId() ) {
break; }
352 if ( description == descriptions.end() ) {
return false;}
354 const Fed9U::Fed9UStrips&
strips = (*description)->getFedStrips();
359 for ( uint16_t iapv = 2*ipair.
fedCh(); iapv < 2*ipair.
fedCh()+2; iapv++ ) {
362 Fed9U::Fed9UAddress addr;
363 addr.setFedApv(iapv);
364 vector<Fed9U::Fed9UStripDescription> strip = strips.getApvStrips(addr);
366 vector<Fed9U::Fed9UStripDescription>::const_iterator istrip = strip.begin();
368 for ( ; istrip != strip.end(); istrip++ ) {
373 if(istrip->getDisable()){
374 std::cout <<
"Found disabled strip! Detid: " << detid <<
" APVNr: " << iapv <<
" Strips: " << jstrip << std::endl;
391 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
392 <<
" Unable to insert values into SiStripPedestals object!"
393 <<
" DetId already exists!" << std::endl;
408 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
409 <<
" Unable to insert values into SiStripNoises object!"
410 <<
" DetId already exists!" << std::endl;
422 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
423 <<
" Unable to insert values into SiStripThreshold object!"
424 <<
" DetId already exists!" << std::endl;
437 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
438 <<
" Unable to insert values into SiStripQuality object!"
439 <<
" DetId already exists!" << std::endl;
450 if ( !
gain_->
put( det_id, range ) ) {
452 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
453 <<
" Unable to insert values into SiStripApvGain object!"
454 <<
" DetId already exists!";
465 vector<uint32_t>::const_iterator det_id;
466 vector<uint32_t> det_ids;
469 <<
"\n[SiStripCondObjBuilderFromDb::" << __func__ <<
"] first call to this method";
475 if ( det_ids.empty() ) {
477 <<
"SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
478 <<
" Unable to build Pedestals object!"
479 <<
" No DetIds found!" << std::endl;
482 std::cout <<
"\n\nSiStripCondObjBuilderFromDb::" << __func__ <<
"]"
483 <<
" Found " << det_ids.size() <<
" active DetIds";
486 det_id = det_ids.begin();
487 for ( ; det_id != det_ids.end(); det_id++ ) {
488 std::stringstream ssMessage;
491 if ( !(*det_id) ) {
continue; }
496 const vector<const FedChannelConnection *>& conns=
buildConnections(det_cabling, *det_id);
498 vector<const FedChannelConnection *>::const_iterator ipair = conns.begin();
499 if(conns.size() ==0 )
continue;
506 vector< vector<const FedChannelConnection *>::const_iterator > listConns(nApvPairs,conns.end());
508 for ( ; ipair != conns.end(); ++ipair ){
513 listConns[ipair-conns.begin()]=ipair;
516 <<
"\n impossible to assign connection position in listConns " << std::endl;
524 for (uint16_t apvPair=0;apvPair<listConns.size();++apvPair){
525 ipair=listConns[apvPair];
526 if ( ipair == conns.end() ) {
530 <<
" Unable to find FED connection for detid : " << std::dec << *det_id <<
" APV pair number " << apvPair
531 <<
" Writing default values" << std::endl;
532 (*ipair)->print(ssMessage);
535 std::cout <<
" Put apvPair+100:" << apvPair <<
" into vector!" << std::endl;
536 p_apvpcon=std::make_pair(apvPair,**ipair);
541 p_apvpcon=std::make_pair(apvPair,**ipair);
554 std::cout <<
"Entering [SiStripCondObjBuilderFromDb::"<<__func__ <<
"]"<<std::endl;
561 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
562 <<
" NULL pointer to AnalysisDescriptions returned by SiStripConfigDb!"
563 <<
" Cannot build Analysis object! QUIT";
573 for(
i_trackercon detids=tc.begin();detids!=detids_end;detids++){
574 uint32_t
detid = (*detids).first;
578 for(
i_apvpairconn connections=((*detids).second).begin();connections!=connections_end;connections++){
579 uint32_t apvPair =(*connections).first;
593 <<
" Unable to find Timing Analysis Description"
594 <<
" Writing default values for DetId: " << detid
608 std::cout <<
"Entering [SiStripCondObjBuilderFromDb::"<<__func__ <<
"]"<<std::endl;
619 for(
i_trackercon detids=tc.begin();detids!=detids_end;detids++){
620 uint32_t
detid = (*detids).first;
626 for(
i_apvpairconn connections=((*detids).second).begin();connections!=connections_end;connections++){
627 uint32_t apvPair =(*connections).first;
633 std::cout <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"] No FEDConnection for DetId " << detid <<
" ApvPair " << apvPair-100 <<
" found, skipping Latency Insertion!" << std::endl;
641 <<
" Unable to find FEC Description"
642 <<
" Skipping Insertion for DetId: " << detid << std::endl;
651 std::stringstream
ss;
662 std::cout <<
"Entering [SiStripCondObjBuilderFromDb::"<<__func__ <<
"]"<<std::endl;
676 for(
i_trackercon detids=tc.begin();detids!=detids_end;detids++){
677 uint32_t
detid = (*detids).first;
681 for(
i_apvpairconn connections=((*detids).second).begin();connections!=connections_end;connections++){
682 uint32_t apvPair =(*connections).first;
688 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
689 <<
" Unable to find FED description for FED id: " << ipair.
fedId()
690 <<
" detid : " << detid <<
" APV pair number " << apvPair
691 <<
" Writing default values"<< std::endl;
698 <<
"[SiStripCondObjBuilderFromDb::" << __func__ <<
"]"
699 <<
" Unable to find FED description for FED id: " << ipair.
fedId()
700 <<
" detid : " << detid <<
" APV pair number " << apvPair
701 <<
" Writing default values"<< std::endl;
const uint16_t & fecSlot() const
bool put(const uint32_t &detID, const InputVector &vect)
vector< uint32_t > retrieveActiveDetIds(const SiStripDetCabling &det_cabling)
SiStripPedestals::InputVector inputPedestals
const uint16_t & fecCrate() const
bool put(const uint32_t detId, const uint16_t apv, const uint16_t latency, const uint16_t mode)
void addActiveDetectorsRawIds(std::vector< uint32_t > &) const
SiStripLatency * latency_
SiStripFedCabling * fed_cabling_
SiStripCondObjBuilderFromDb()
Versions maskVersion() const
const uint16_t & fedCh() const
SiStripThreshold * threshold_
const std::pair< unsigned short, double > getNumberOfApvsAndStripLength(uint32_t detId) const
void buildAnalysisRelatedObjects(SiStripConfigDb *const db, const trackercon &tc)
DeviceFactory *const deviceFactory(std::string method_name="") const
static const uint32_t invalid32_
SiStripQuality::InputVector inputQuality
FedDescriptionsRange getFedDescriptions(std::string partition="")
pair_apvpairconn p_apvpcon
std::string partitionName() const
uint16_t apvPairNumber() const
FedDescriptions::range FedDescriptionsRange
SiStripThreshold::InputVector inputThreshold
float m_defaultthresholdhighvalue
const uint16_t & fedId() const
void setDefaultValuesCabling(uint16_t apvPair)
static std::string const input
edm::Service< SiStripConfigDb > db_
bool put(const uint32_t &detID, Range input)
void buildFECRelatedObjects(SiStripConfigDb *const db, const trackercon &tc)
const std::vector< const FedChannelConnection * > & getConnections(uint32_t det_id) const
const_iterator_range partitions() const
bool setValuesApvLatency(SiStripLatency &latency_, SiStripConfigDb *const db, FedChannelConnection &ipair, uint32_t detid, uint16_t apvnr, SiStripConfigDb::DeviceDescriptionsRange apvs)
float m_defaultpedestalvalue
bool retrieveFedDescriptions(SiStripConfigDb *const db)
Versions apvTimingVersion() const
void buildStripRelatedObjects(SiStripConfigDb *const db, const SiStripDetCabling &det_cabling)
bool checkForCompatibility(std::stringstream &input, std::stringstream &output, std::string &label)
float m_defaulttickheightvalue
const uint16_t & fecRing() const
static void buildFecCabling(SiStripConfigDb *const, SiStripFecCabling &, const sistrip::CablingSource &)
Class containning control, module, detector and connection information, at the level of a FED channel...
DeviceDescriptions::range DeviceDescriptionsRange
float m_gaincalibrationfactor
float m_defaultnoisevalue
An interface class to the DeviceFactory.
const uint16_t & ccuChan() const
void buildFEDRelatedObjects(SiStripConfigDb *const db, const trackercon &tc)
void setDefaultValuesApvTiming()
std::pair< ContainerIterator, ContainerIterator > Range
uint16_t retrieveNumberAPVPairs(uint32_t det_id)
std::vector< pair_detcon > trackercon
Container class for database partition parameters.
uint16_t m_defaultapvmodevalue
float m_defaultthresholdlowvalue
AnalysisDescriptionsRange getAnalysisDescriptions(AnalysisType, std::string partition="")
const uint16_t & ccuAddr() const
void storeThreshold(uint32_t det_id)
uint16_t m_defaultapvlatencyvalue
vector< const FedChannelConnection * > buildConnections(const SiStripDetCabling &det_cabling, uint32_t det_id)
SiStripNoises::InputVector inputNoises
void printSummary(std::stringstream &ss) const
Prints the number of ranges as well as the value of singleLatency and singleMode. ...
bool put(const uint32_t &detID, const InputVector &input)
DbClient *const databaseCache(std::string method_name="") const
const SiStripDbParams & dbParams() const
SiStripDbParams dbParams_
bool setValuesCabling(SiStripConfigDb::FedDescriptionsRange &descriptions, FedChannelConnection &ipair, uint32_t detid)
static void getFedCabling(const SiStripFecCabling &in, SiStripFedCabling &out)
static const uint16_t STRIPS_PER_FEDCH
bool put(const uint32_t &detID, InputVector &input)
bool retrieveTimingAnalysisDescriptions(SiStripConfigDb *const db)
AnalysisDescriptions::range AnalysisDescriptionsRange
static const uint16_t invalid_
void setDefaultValuesApvLatency(SiStripLatency &latency_, const FedChannelConnection &ipair, uint32_t detid, uint16_t apvnr)
void setData(const uint16_t &strip, const float &lTh, const float &hTh, Container &vthr)
Contains cabling info at the device level, including DetId, APV pair numbers, hardware addresses...
boost::iterator_range< SiStripPartitions::const_iterator > const_iterator_range
std::vector< std::vector< double > > tmp
SiStripApvGain::InputVector inputApvGain
void printDebug(std::stringstream &ss) const
Prints the full list of all ranges and corresponding values of latency and mode.
void setData(float ped, InputVector &vped)
void storeTiming(uint32_t det_id)
void storePedestals(uint32_t det_id)
static uint16_t fedCh(const uint16_t &fe_unit, const uint16_t &fe_chan)
volatile std::atomic< bool > shutdown_flag false
DeviceDescriptionsRange getDeviceDescriptions(std::string partition="")
static const char mlESSources_[]
void storeNoise(uint32_t det_id)
const uint16_t & i2cAddr(const uint16_t &apv0_or_1) const
std::vector< pair_detcon >::iterator i_trackercon
Versions fecVersion() const
virtual ~SiStripCondObjBuilderFromDb()
SiStripQuality * quality_
Versions cabVersion() const
std::vector< pair_apvpairconn >::iterator i_apvpairconn
SiStripPedestals * pedestals_
Versions fedVersion() const
void setData(float noise_, InputVector &vped)
bool setValuesApvTiming(SiStripConfigDb *const db, FedChannelConnection &ipair)
void storeQuality(uint32_t det_id)