CMS 3D CMS Logo

DigiConverterFP420.cc
Go to the documentation of this file.
1 // File: DigiConverterFP420.cc
3 // Date: 12.2006
4 // Description: DigiConverterFP420 for FP420
5 // Modifications:
8 
11  verbos = verbosity;
12 
13  const int defaultBits = 10;
14  const int largestBits = 30;
15 
16  // example is in SiStrips:
17  // static SimpleConfigurable<int>
18  // adcBits(defaultBits, "DigiConverterFP420:rawDataAdcBits");
19  adcBits = defaultBits;
20 
21  if (adcBits > largestBits || adcBits < 1)
22  adcBits = largestBits;
23 
24  theMaxADC = ~(~0 << adcBits);
25  // std::cout << "theMaxADC= "<< theMaxADC << std::endl; // = 1023
26  if (verbos > 0) {
27  std::cout << " ***DigiConverterFP420: constructor" << std::endl;
28  std::cout << "with known electronperADC = " << electronperADC << "the adcBits = " << adcBits
29  << " theMaxADC= " << theMaxADC << "for known defaultBits= " << defaultBits
30  << " largestBits= " << largestBits << std::endl;
31  }
32 }
33 
36 
37  for (signal_map_type::const_iterator i = analogSignal.begin(); i != analogSignal.end(); i++) {
38  // convert analog amplitude to digital, means integer number simulating ADC
39  // digitization!
40  // with truncation check
41  int adc = convert((*i).second);
42 
43  if (verbos > 0) {
44  std::cout << " ***DigiConverterFP420: convert: after truncation " << std::endl;
45  std::cout << "adc = " << adc << " (*i).first = " << (*i).first << std::endl;
46  }
47  if (adc > 0)
48  _temp.insert(_temp.end(), DigitalMapType::value_type((*i).first, adc));
49  }
50 
51  return _temp;
52 }
53 
54 int DigiConverterFP420::truncate(float in_adc) {
55  int adc = int(in_adc);
56  if (verbos > 0) {
57  std::cout << " ***DigiConverterFP420: truncate" << std::endl;
58  std::cout << "if adc = " << adc << "bigger theMaxADC = " << theMaxADC << " adc=theMaxADC !!!" << std::endl;
59  }
60  if (adc > theMaxADC)
61  adc = theMaxADC;
62 
63  return adc;
64 }
int truncate(float in_adc)
std::map< int, int, std::less< int > > DigitalMapType
DigiConverterFP420(float in, int)
constexpr int adc(sample_type sample)
get the ADC sample (12 bits)
PileUpFP420::signal_map_type signal_map_type
DigitalMapType convert(const signal_map_type &) override