23#ifndef REST_TRestDataSetGainMap 
   24#define REST_TRestDataSetGainMap 
   31#include <TRestStringOutput.h> 
   37#include "TRestDataSet.h" 
   38#include "TRestMetadata.h" 
   74    Int_t GetNumberOfPlanes()
 const { 
return GetPlaneIDs().size(); }
 
   75    Int_t GetNumberOfModules()
 const {
 
   81    std::string GetCalibrationFileName()
 const { 
return fCalibFileName; }
 
   83    std::string GetObservable()
 const { 
return fObservable; }
 
   88    Module* 
GetModule(
const size_t index = 0);
 
   89    Module* 
GetModule(
const int planeID, 
const int moduleID);
 
   90    double GetSlopeParameter(
const int planeID, 
const int moduleID, 
const double x, 
const double y);
 
   95    void SetCalibrationFileName(
const std::string& fileName) { 
fCalibFileName = fileName; }
 
   96    void SetOutputFileName(
const std::string& fileName) { 
fOutputFileName = fileName; }
 
   98    void SetObservable(
const std::string& observable) { 
fObservable = observable; }
 
   99    void SetSpatialObservableX(
const std::string& spatialObservableX) {
 
  102    void SetSpatialObservableY(
const std::string& spatialObservableY) {
 
  107    void Import(
const std::string& fileName);
 
  108    void Export(
const std::string& fileName = 
"");
 
  115    void CalibrateDataSet(
const std::string& dataSetFileName, std::string outputFileName = 
"",
 
  116                          std::vector<std::string> excludeColumns = {});
 
  129        std::pair<double, double> FitPeaks(TH1F* hSeg, TGraph* gr);
 
  130        std::pair<double, double> UpdateCalibrationFits(TH1F* hSeg, TGraph* gr);
 
  139        Int_t fModuleId = -1;  
 
  176        std::vector<std::vector<double>> 
fSlope = {};  
 
  207        void AddPeak(
const double& energyPeak, 
const TVector2& rangePeak = TVector2(0, 0)) {
 
  215        std::pair<int, int> 
GetIndexMatrix(
const double x, 
const double y) 
const;
 
  216        double GetSlope(
const double x, 
const double y) 
const;
 
  217        double GetIntercept(
const double x, 
const double y) 
const;
 
  218        double GetSlopeFullSpc()
 const { 
return fFullSlope; };
 
  221        Int_t GetPlaneId()
 const { 
return fPlaneId; }
 
  222        Int_t GetModuleId()
 const { 
return fModuleId; }
 
  223        std::string GetObservable()
 const { 
return p->
fObservable; }
 
  226        inline std::string GetModuleDefinitionCut()
 const { 
return fDefinitionCut; }
 
  230        std::set<double> GetSplitX()
 const { 
return fSplitX; }
 
  231        std::set<double> GetSplitY()
 const { 
return fSplitY; }
 
  235        void DrawSpectrum(
const bool drawFits = 
true, 
const int color = -1, TCanvas* c = 
nullptr);
 
  236        void DrawSpectrum(
const TVector2& position, 
bool drawFits = 
true, 
int color = -1,
 
  237                          TCanvas* c = 
nullptr);
 
  238        void DrawSpectrum(
const int index_x, 
const int index_y, 
bool drawFits = 
true, 
int color = -1,
 
  239                          TCanvas* c = 
nullptr);
 
  240        void DrawFullSpectrum(
const bool drawFits = 
true, 
const int color = -1, TCanvas* c = 
nullptr);
 
  242        void DrawLinearFit(TCanvas* c = 
nullptr);
 
  243        void DrawLinearFit(
const TVector2& position, TCanvas* c = 
nullptr);
 
  244        void DrawLinearFit(
const int index_x, 
const int index_y, TCanvas* c = 
nullptr);
 
  246        void DrawGainMap(
const int peakNumber = 0, 
const bool fullModuleAsRef = 
true);
 
  248        void Refit(
const TVector2& position, 
const double energy, 
const TVector2& range);
 
  249        void Refit(
const size_t x, 
const size_t y, 
const size_t peakNumber, 
const TVector2& range);
 
  250        void RefitFullSpc(
const double energy, 
const TVector2& range);
 
  251        void RefitFullSpc(
const size_t peakNumber, 
const TVector2& range);
 
  252        void UpdateCalibrationFits(
const size_t x, 
const size_t y);
 
  255        void SetPlaneId(
const Int_t& planeId) { 
fPlaneId = planeId; }
 
  256        void SetModuleId(
const Int_t& moduleId) { fModuleId = moduleId; }
 
  257        void SetModuleDefinitionCut(
const std::string& moduleDefinitionCut) {
 
  260        void SetCalibrationRange(
const TVector2& calibrationRange) { 
fCalibRange = calibrationRange; }
 
  261        void SetNBins(
const Int_t& nBins) { 
fNBins = nBins; }
 
  264        void SetSplitX(
const std::set<double>& splitX);
 
  265        void SetSplitY(
const std::set<double>& splitY);
 
  267        void SetSplits(
const std::set<double>& splitXandY) {
 
  272        void SetNumberOfSegmentsX(
const Int_t& numberOfSegmentsX) { 
fNumberOfSegmentsX = numberOfSegmentsX; }
 
  273        void SetNumberOfSegmentsY(
const Int_t& numberOfSegmentsY) { 
fNumberOfSegmentsY = numberOfSegmentsY; }
 
  275        void SetDataSetFileName(
const std::string& dataSetFileName) { 
fDataSetFileName = dataSetFileName; }
 
  276        void SetReadoutRange(
const TVector2& readoutRange) { 
fReadoutRange = readoutRange; }
 
  277        void SetZeroPoint(
const bool& ZeroPoint) { 
fZeroPoint = ZeroPoint; }
 
  278        void SetAutoRangePeaks(
const bool& autoRangePeaks) { 
fAutoRangePeaks = autoRangePeaks; }
 
  287        Module(
const TRestDataSetGainMap& parent, 
const Int_t planeId, 
const Int_t moduleId) : 
p(&parent) {
 
  289            SetModuleId(moduleId);
 
 
 
A class to help on cuts definitions. To be used with TRestAnalysisTree.
double fFullIntercept
Intercept of the calibration linear fit of whole module.
std::vector< std::vector< double > > fIntercept
Array containing the intercept of the linear fit for each segment.
Int_t fNumberOfSegmentsY
Number of segments in the y direction.
void SetSplitY()
Function to set the class members for segmentation of the detector plane along the Y axis.
std::vector< std::vector< TGraph * > > fSegLinearFit
Array containing the calibration linear fit for each segment.
void SetSplits()
Function to set the class members for segmentation of the detector plane along the X and Y axis.
void SetSplitX()
Function to set the class members for segmentation of the detector plane along the X axis.
std::vector< std::vector< TH1F * > > fSegSpectra
Array containing the observable spectrum for each segment.
void DrawSpectrum(const bool drawFits=true, const int color=-1, TCanvas *c=nullptr)
Function to draw the spectrum for each segment of the module on the same canvas. The canvas is divide...
void LoadConfigFromTiXmlElement(const TiXmlElement *module)
Function to read the parameters from the RML element (TiXmlElement) and set those class members.
void GenerateGainMap()
Function that calculates the calibration parameters for each segment defined at fSplitX and fSplitY a...
double fFullSlope
Slope of the calibration linear fit of whole module.
double GetSlope(const double x, const double y) const
Function to get the calibration parameter slope for a given x and y position on the detector plane.
std::set< double > fSplitX
Split points in the x direction.
void Print() const
Prints on screen the information about the members of Module.
void Refit(const TVector2 &position, const double energy, const TVector2 &range)
Function to fit again manually a peak for a given segment of the module.
std::string fDataSetFileName
std::set< double > fSplitY
Split points in the y direction.
void RefitFullSpc(const double energy, const TVector2 &range)
Function to fit again manually a peak for the whole module spectrum. The calibration curve is updated...
std::vector< TVector2 > fRangePeaks
Range of the peaks to be used for the calibration. If empty it will be automatically calculated.
const TRestDataSetGainMap * p
Pointer to the parent class.
void UpdateCalibrationFitsFullSpc()
Function to update the calibration curve for the whole module. The calibration curve is cleared and t...
std::vector< std::vector< double > > fSlope
Array containing the slope of the linear fit for each segment.
Int_t fNumberOfSegmentsX
Number of segments in the x direction.
void DrawGainMap(const int peakNumber=0, const bool fullModuleAsRef=true)
Function to draw the relative gain map for a given energy peak of the module.
Int_t fNBins
Number of bins for the spectrum histograms.
TVector2 fCalibRange
Calibration range. If fCalibRange.X()>=fCalibRange.Y() the range will be automatically calculated.
std::string fDefinitionCut
Cut that defines which events are from this module. Default is "1" (all events).
TGraph * fFullLinearFit
Calibration linear fit for the whole module.
TH1F * fFullSpectrum
Spectrum of the observable for the whole module.
bool fAutoRangePeaks
Automatic range for the peaks fitting. See GenerateGainMap() for more information of the logic.
double GetIntercept(const double x, const double y) const
Function to get the calibration parameter intercept for a given x and y position on the detector plan...
TVector2 fReadoutRange
Readout dimensions.
std::pair< int, int > GetIndexMatrix(const double x, const double y) const
Function to get the index of the matrix of calibration parameters for a given x and y position on the...
std::vector< double > fEnergyPeaks
Energy of the peaks to be used for the calibration.
Metadata class to calculate,store and apply the gain corrected calibration of a group of detectors.
double GetInterceptParameter(const int planeID, const int moduleID, const double x, const double y)
Function to get the intercept parameter of the module with planeID and moduleID at physical position ...
double GetSlopeParameter(const int planeID, const int moduleID, const double x, const double y)
Function to get the slope parameter of the module with planeID and moduleID at physical position (x,...
std::string fObservable
Observable that will be used to calculate the gain map.
double GetInterceptParameterFullSpc(const int planeID, const int moduleID)
Function to get the intercept parameter of the whole module with planeID and moduleID.
void CalibrateDataSet(const std::string &dataSetFileName, std::string outputFileName="", std::vector< std::string > excludeColumns={})
Function to calibrate a dataset with this gain map.
~TRestDataSetGainMap()
Default destructor.
void GenerateGainMap()
Function to calculate the calibration parameters of all modules.
TRestDataSetGainMap()
Default constructor.
void Initialize() override
Making default settings.
std::vector< Module > fModulesCal
List of modules.
void SetModule(const Module &moduleCal)
Function to set a module calibration. If the module calibration already exists (same planeId and modu...
void InitFromConfigFile() override
Initialization of TRestDataSetGainMap members through a RML file.
double GetSlopeParameterFullSpc(const int planeID, const int moduleID)
Function to get the slope parameter of the whole module with planeID and moduleID.
void Export(const std::string &fileName="")
Function to export the calibration to the file fileName.
void PrintMetadata() override
Prints on screen the information about the metadata members.
std::map< int, std::set< int > > GetModuleIDs() const
Function to get the map of the module IDs for each plane ID.
std::string fSpatialObservableY
Observable that will be used to segmentize the gain map in the y direction.
std::string fCalibFileName
Name of the file that contains the calibration data.
TRestCut * fCut
Cut to be applied to the calibration data.
std::string fOutputFileName
Name of the file where the gain map was (or will be) exported.
std::set< int > GetPlaneIDs() const
Function to get a list (set) of the plane IDs.
std::string fSpatialObservableX
Observable that will be used to segmentize the gain map in the x direction.
Module * GetModule(const size_t index=0)
Function to retrieve the module calibration by index. Default is 0.
void Import(const std::string &fileName)
Function to import the calibration parameters from the root file fileName.