From 5e33144e6d4b13e8ac584c56ead640bf7743dc07 Mon Sep 17 00:00:00 2001 From: JPorron Date: Thu, 7 Nov 2024 10:34:42 +0100 Subject: [PATCH] Changes in TRestRawSignal --- src/TRestRawSignal.cxx | 45 +++++++++++++++++++++--------------------- 1 file changed, 22 insertions(+), 23 deletions(-) diff --git a/src/TRestRawSignal.cxx b/src/TRestRawSignal.cxx index b5057dd..fbb154f 100644 --- a/src/TRestRawSignal.cxx +++ b/src/TRestRawSignal.cxx @@ -913,8 +913,6 @@ TGraph* TRestRawSignal::GetGraph(Int_t color) { vector> TRestRawSignal::GetPeaks(double threshold, UShort_t distance) const { vector> peaks; - std::cout << "Small change to test pipelines" << std::endl; - const UShort_t smoothingWindow = 10; // Region to compare for peak/no peak classification. 10 means 5 bins to each side const size_t numPoints = GetNumberOfPoints(); @@ -979,30 +977,31 @@ vector> TRestRawSignal::GetPeaks(double threshold, UShort } // If it's a peak and it´s above the threshold and further than distance to the previous peak, add - // to peaks + // to peaks the biggest amplitude bin within the next "distance" bins and as amplitude the TripleMaxAverage. + // This is because for flat regions the detected peak is more to the left than the actual one. if (isPeak && smoothedValue > threshold) { if (peaks.empty() || i - peaks.back().first >= distance) { - double fitMinRange = i - 20; - double fitMaxRange = i + 20; - - // Create a Gaussian fit function - TF1 fitFunction("gaussianFit", "gaus", fitMinRange, fitMaxRange); - // Fit the data with the Gaussian function - fitFunction.SetRange(fitMinRange, fitMaxRange); // Initial parameters - - // Create histogram with the values to fit - TH1D histogram("hist", "hist", 40, fitMinRange, fitMaxRange); - for (int k = i - 20; k <= i + 20; ++k) { - histogram.SetBinContent(k - (i - 20) + 1, GetRawData(k)); // Set bin content + + // Initialize variables to find the max amplitude within the next "distance" bins + int maxBin = i; + double maxAmplitude = smoothedValues[i]; + + // Look ahead within the specified distance to find the bin with the maximum amplitude + for (int j = i + 1; j <= i + distance && j < smoothedValues.size(); ++j) { + if (smoothedValues[j] > maxAmplitude) { + maxAmplitude = smoothedValues[j]; + maxBin = j; + } } - histogram.Fit(&fitFunction, "RQ"); - - // Get peak position and amplitude from the fit - double peakPosition = fitFunction.GetParameter(1); - UShort_t formattedPeakPosition = static_cast(peakPosition); - double peakAmplitude = GetRawData(formattedPeakPosition); - - peaks.push_back(std::make_pair(formattedPeakPosition, peakAmplitude)); + + // Calculate the peak amplitude as the average of maxBin and its two neighbors + double amplitude1 = GetRawData(maxBin - 1); + double amplitude2 = GetRawData(maxBin); + double amplitude3 = GetRawData(maxBin + 1); + double peakAmplitude = (amplitude1 + amplitude2 + amplitude3) / 3.0; + + // Store the peak position and amplitude + peaks.push_back(std::make_pair(maxBin, peakAmplitude)); } } }