MaCh3  2.5.0
Reference Guide
SplineBase.h
Go to the documentation of this file.
1 #pragma once
2 
3 // C++ includes
4 #include <cstdlib>
5 #include <iomanip>
6 
7 // MaCh3 includes
9 #include "Splines/SplineCommon.h"
10 
12 // ROOT include
13 #include "TFile.h"
14 #include "TH1F.h"
15 #include "TKey.h"
16 #include "TString.h"
17 #include "TIterator.h"
18 #include "TStopwatch.h"
19 #include "TCanvas.h"
20 #include "TStyle.h"
21 #include "TTree.h"
23 
27 class SplineBase {
28  public:
30  SplineBase();
32  virtual ~SplineBase();
33 
35  virtual void Evaluate() = 0;
36 
38  virtual std::string GetName() const {return "SplineBase";};
39 
41  short int GetNParams() const {return nParams;};
42 
44  virtual void PrepareSplineFile(std::string FileName) = 0;
47  virtual void LoadSplineFile(std::string FileName) = 0;
48 
50  virtual void SynchroniseMemTransfer() const = 0;
51 
52  protected:
54  void FindSplineSegment();
56  virtual void CalcSplineWeights() = 0;
57 
60  void PrepareFastSplineInfoDir(std::unique_ptr<TFile>& SplineFile) const;
61 
64  void LoadFastSplineInfoDir(std::unique_ptr<TFile>& SplineFile);
65 
70  void GetTF1Coeff(TF1_red* &spl, int &nPoints, float *&coeffs) const;
71 
74  std::vector<FastSplineInfo> SplineInfoArray;
77  short int *SplineSegments;
79  float *ParamValues;
81  short int nParams;
82 
83  private:
89  void CheckSegmentValidity(const M3::int_t i,
90  const M3::int_t segment,
91  const M3::float_t xvar,
92  const std::vector<M3::float_t>& xPts) const;
93 };
#define _MaCh3_Safe_Include_Start_
KS: Avoiding warning checking for headers.
Definition: Core.h:126
#define _MaCh3_Safe_Include_End_
KS: Restore warning checking after including external headers.
Definition: Core.h:141
Contains definitions for spline coefficients and structure used in both CPU and GPU code.
Contains structures and helper functions for handling spline representations of systematic parameters...
Base class for calculating weight from spline.
Definition: SplineBase.h:27
virtual ~SplineBase()
Destructor.
Definition: SplineBase.cpp:16
void CheckSegmentValidity(const M3::int_t i, const M3::int_t segment, const M3::float_t xvar, const std::vector< M3::float_t > &xPts) const
Validates that the spline segment is correct for the given variation.
Definition: SplineBase.cpp:21
void GetTF1Coeff(TF1_red *&spl, int &nPoints, float *&coeffs) const
CW: Gets the polynomial coefficients for TF1.
Definition: SplineBase.cpp:115
virtual void CalcSplineWeights()=0
CPU based code which eval weight for each spline.
short int nParams
Number of parameters that have splines.
Definition: SplineBase.h:81
virtual std::string GetName() const
Get class name.
Definition: SplineBase.h:38
void FindSplineSegment()
CW:Code used in step by step reweighting, Find Spline Segment for each param.
Definition: SplineBase.cpp:44
virtual void Evaluate()=0
CW: This Eval should be used when using two separate x,{y,a,b,c,d} arrays to store the weights; proba...
short int * SplineSegments
Definition: SplineBase.h:77
std::vector< FastSplineInfo > SplineInfoArray
Definition: SplineBase.h:74
float * ParamValues
Store parameter values they are not in FastSplineInfo as in case of GPU we need to copy paste it to G...
Definition: SplineBase.h:79
SplineBase()
Constructor.
Definition: SplineBase.cpp:7
virtual void PrepareSplineFile(std::string FileName)=0
KS: Prepare spline file that can be used for fast loading.
virtual void LoadSplineFile(std::string FileName)=0
KS: Load preprocessed spline file.
void LoadFastSplineInfoDir(std::unique_ptr< TFile > &SplineFile)
KS: Load preprocessed FastSplineInfo.
Definition: SplineBase.cpp:167
void PrepareFastSplineInfoDir(std::unique_ptr< TFile > &SplineFile) const
KS: Prepare Fast Spline Info within SplineFile.
Definition: SplineBase.cpp:139
virtual void SynchroniseMemTransfer() const =0
KS: After calculations are done on GPU we copy memory to CPU. This operation is asynchronous meaning ...
short int GetNParams() const
Get number of spline parameters.
Definition: SplineBase.h:41
CW: A reduced TF1 class only. Only saves parameters for each TF1 and how many parameters each paramet...
double float_t
Definition: Core.h:37
int int_t
Definition: Core.h:38