CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
EcalFenixStripFgvbEE Class Reference

calculation of Fgvb for the endcap in Fenix Strip calculates fgvb for the endcap in Fenix Strip More...

#include <EcalFenixStripFgvbEE.h>

Public Member Functions

 EcalFenixStripFgvbEE ()
 
void process (std::vector< std::vector< int > > &lin_out, std::vector< int > &output)
 
void setParameters (uint32_t id, const EcalTPGFineGrainStripEE *)
 
virtual ~EcalFenixStripFgvbEE ()
 

Private Attributes

const
EcalTPGFineGrainStripEE::Item
fgparams_
 

Detailed Description

calculation of Fgvb for the endcap in Fenix Strip calculates fgvb for the endcap in Fenix Strip

input: 5X18 bits output: 1 bit

Definition at line 21 of file EcalFenixStripFgvbEE.h.

Constructor & Destructor Documentation

EcalFenixStripFgvbEE::EcalFenixStripFgvbEE ( )

Definition at line 6 of file EcalFenixStripFgvbEE.cc.

7 {
8 }
EcalFenixStripFgvbEE::~EcalFenixStripFgvbEE ( )
virtual

Definition at line 10 of file EcalFenixStripFgvbEE.cc.

10  {
11 }

Member Function Documentation

void EcalFenixStripFgvbEE::process ( std::vector< std::vector< int > > &  lin_out,
std::vector< int > &  output 
)

Definition at line 13 of file EcalFenixStripFgvbEE.cc.

References ecalMGPA::adc(), fgparams_, i, EcalTPGFineGrainStripEE::Item::lut, and EcalTPGFineGrainStripEE::Item::threshold.

Referenced by EcalFenixStrip::process_part2_endcap().

14 {
15  unsigned int maskFgvb[]={1,2,4,8,0x10};
16 
17  // int threshold_fg = (*params_)[6];
18  // int lut_fg = (*params_)[7];
19 
20  int threshold_fg = fgparams_->threshold ;
21  int lut_fg = fgparams_->lut ;
22 
23 
24  std::vector<int> indexLut(output.size());
25 
26  for (unsigned int i=0;i<output.size();i++) {
27  output[i]=0;
28  indexLut[i]=0;
29  for (unsigned int ixtal=0;ixtal<linout.size();ixtal++) {
30  int adc=linout[ixtal][i];
31  int res= (adc>threshold_fg) ? 1 : 0;
32  indexLut[i]=indexLut[i] | (res <<ixtal & maskFgvb[ixtal]);
33  }
34  int mask = 1<<indexLut[i];
35  output[i]= lut_fg & mask;
36  if (output[i]>0) output[i]=1;
37  }
38  return;
39 }
int adc(sample_type sample)
get the ADC sample (12 bits)
int i
Definition: DBlmapReader.cc:9
const EcalTPGFineGrainStripEE::Item * fgparams_
void EcalFenixStripFgvbEE::setParameters ( uint32_t  id,
const EcalTPGFineGrainStripEE ecaltpgFgStripEE 
)

Definition at line 41 of file EcalFenixStripFgvbEE.cc.

References fgparams_, and EBDataFrame::id().

Referenced by EcalFenixStrip::process_part2_endcap().

42 {
43  const EcalTPGFineGrainStripEEMap &fgmap = ecaltpgFgStripEE -> getMap();
44  EcalTPGFineGrainStripEEMapIterator it=fgmap.find(id);
45  if (it!=fgmap.end()) fgparams_=&(*it).second;
46  else edm::LogWarning("EcalTPG")<<" could not find EcalTPGFineGrainStripEEMap entry for "<<id;
47 
48 
49 
50 }
std::map< uint32_t, EcalTPGFineGrainStripEE::Item > EcalTPGFineGrainStripEEMap
const EcalTPGFineGrainStripEE::Item * fgparams_
std::map< uint32_t, EcalTPGFineGrainStripEE::Item >::const_iterator EcalTPGFineGrainStripEEMapIterator

Member Data Documentation

const EcalTPGFineGrainStripEE::Item* EcalFenixStripFgvbEE::fgparams_
private

Definition at line 25 of file EcalFenixStripFgvbEE.h.

Referenced by process(), and setParameters().