9 #include <framework/logging/Logger.h>
10 #include <svd/reconstruction/SVDClusterCharge.h>
11 #include <svd/reconstruction/SVDMaxSumAlgorithm.h>
31 seedCharge = m_PulseShapeCal.getChargeFromADC(rawCluster.
getSensorID(), rawCluster.
isUSide(), seedCellID,
41 for (
int i = 0; i < (int)strips.size(); i++) {
45 double rawCharge = *std::max_element(begin(strip.
samples), end(strip.
samples));
48 double stripCharge = m_PulseShapeCal.getChargeFromADC(rawCluster.
getSensorID(), rawCluster.
isUSide(), strip.
cellID, rawCharge);
51 noise += tmp_noise * tmp_noise;
53 charge += stripCharge;
56 SNR = charge /
sqrt(noise);
70 for (
int i = 0; i < (int)strips.size(); i++) {
75 for (
auto sample : strip.
samples)
79 double stripCharge = m_PulseShapeCal.getChargeFromADC(rawCluster.
getSensorID(), rawCluster.
isUSide(), strip.
cellID, rawCharge);
81 if (stripCharge > seedCharge)
82 seedCharge = stripCharge;
85 noise += tmp_noise * tmp_noise;
87 charge += stripCharge;
90 SNR = charge /
sqrt(noise);
95 void SVDClusterCharge::applyELS3Charge(
const Belle2::SVD::RawCluster& rawCluster,
double& charge,
double& SNR,
double& seedCharge)
103 float m_ELS3tau = 55;
108 seedCharge = m_PulseShapeCal.getChargeFromADC(rawCluster.
getSensorID(), rawCluster.
isUSide(), seedCellID,
119 auto begin = selectedSamples.begin();
121 const double E = std::exp(- m_apvClockPeriod / m_ELS3tau);
122 const double E2 =
E *
E;
123 const double E3 =
E *
E *
E;
124 const double E4 =
E *
E *
E *
E;
125 double a0 = (*begin);
126 double a1 = (*(begin + 1));
127 double a2 = (*(begin + 2));
130 const double w = (a0 - E2 * a2) / (2 * a0 +
E * a1);
131 auto rawtime_num = 2 * E4 + w * E2;
132 auto rawtime_den = 1 - E4 - w * (2 + E2);
133 float rawtime = - m_apvClockPeriod * rawtime_num / rawtime_den;
143 double num = (1. /
E - E3) * a1 + (2 + E2) * a2 - (1 + 2 * E2) * a0;
144 double den = m_apvClockPeriod / m_ELS3tau * std::exp(1 + rawtime / m_ELS3tau) * (1 + 4 * E2 + E4);
151 for (
int i = 0; i < (int)strips.size(); i++) {
156 noise += tmp_noise * tmp_noise;
159 SNR = charge /
sqrt(noise);
Class representing a raw cluster candidate during clustering of the SVD.
int getSeedInternalIndex() const
int getSeedMaxSample() const
Belle2::SVDShaperDigit::APVFloatSamples getClsSamples(bool inElectrons) const
VxdID getSensorID() const
const std::vector< StripInRawCluster > getStripsInRawCluster() const
Class implementing the MaxSum algorithm.
std::vector< float > getSelectedSamples()
double sqrt(double a)
sqrt for double
Abstract base class for different kinds of events.
structure containing the relevant informations of each strip of the raw cluster
Belle2::SVDShaperDigit::APVFloatSamples samples
ADC of the acquired samples.