110 lines
3.6 KiB
C
110 lines
3.6 KiB
C
|
#ifndef Parameters_H
|
||
|
#define Parameters_H
|
||
|
|
||
|
//************************************** Correction parameters;
|
||
|
class CorrParas {
|
||
|
|
||
|
public:
|
||
|
CorrParas(){
|
||
|
xnCorr.clear();
|
||
|
xScale.clear();
|
||
|
xfxneCorr.clear();
|
||
|
eCorr.clear();
|
||
|
rdtCorr.clear();
|
||
|
};
|
||
|
|
||
|
std::vector<float> xnCorr; //correction of xn to match xf
|
||
|
std::vector<float> xScale; // correction of x to be (0,1)
|
||
|
std::vector<std::vector<float>> xfxneCorr; //correction of xn and xf to match e
|
||
|
std::vector<std::vector<float>> eCorr; // correction to e, ch -> MeV
|
||
|
std::vector<std::vector<float>> rdtCorr; // correction of rdt, ch -> MeV
|
||
|
|
||
|
//~========================================= xf = xn correction
|
||
|
void LoadXNCorr(bool verbose = false, const char * fileName = "correction_xf_xn.dat"){
|
||
|
printf(" loading xf-xn correction.");
|
||
|
xnCorr.clear();
|
||
|
std::ifstream file;
|
||
|
file.open(fileName);
|
||
|
if( file.is_open() ){
|
||
|
float a;
|
||
|
while( file >> a ) xnCorr.push_back(a);
|
||
|
printf(".......... done.\n");
|
||
|
}else{
|
||
|
printf(".......... fail.\n");
|
||
|
}
|
||
|
file.close();
|
||
|
if( verbose ) for(int i = 0; i < (int) xnCorr.size(); i++) printf("%2d | %10.3f\n", i, xnCorr[i]);
|
||
|
}
|
||
|
|
||
|
|
||
|
//~========================================= X-Scale correction
|
||
|
void LoadXScaleCorr(bool verbose = false, const char * fileName = "correction_scaleX.dat"){
|
||
|
printf(" loading x-Scale correction.");
|
||
|
xScale.clear();
|
||
|
std::ifstream file;
|
||
|
file.open(fileName);
|
||
|
if( file.is_open() ){
|
||
|
float a, b;
|
||
|
while( file >> a ) xScale.push_back(a);
|
||
|
printf("........ done.\n");
|
||
|
}else{
|
||
|
printf("........ fail.\n");
|
||
|
}
|
||
|
file.close();
|
||
|
if( verbose ) for(int i = 0; i < (int) xScale.size(); i++) printf("%2d | %10.3f\n", i, xnCorr[i]);
|
||
|
}
|
||
|
|
||
|
//~========================================= e = xf + xn correction
|
||
|
void LoadXFXN2ECorr(bool verbose = false, const char * fileName = "correction_xfxn_e.dat"){
|
||
|
printf(" loading xf/xn-e correction.");
|
||
|
xfxneCorr.clear();
|
||
|
std::ifstream file;
|
||
|
file.open(fileName);
|
||
|
if( file.is_open() ){
|
||
|
float a, b;
|
||
|
while( file >> a >> b) xfxneCorr.push_back({a, b});
|
||
|
printf("........ done.\n");
|
||
|
}else{
|
||
|
printf("........ fail.\n");
|
||
|
}
|
||
|
file.close();
|
||
|
if( verbose ) for(int i = 0; i < (int) xfxneCorr.size(); i++) printf("%2d | %10.3f, %10.3f\n", i, xfxneCorr[i][0], xfxneCorr[i][1]);
|
||
|
}
|
||
|
|
||
|
//~========================================= e correction
|
||
|
void LoadECorr(bool verbose = false, const char * fileName = "correction_e.dat"){
|
||
|
printf(" loading e correction.");
|
||
|
eCorr.clear();
|
||
|
std::ifstream file;
|
||
|
file.open(fileName);
|
||
|
if( file.is_open() ){
|
||
|
float a, b;
|
||
|
while( file >> a >> b) eCorr.push_back( {a, b} ); // 1/a1, a0 , e' = e * a1 + a0
|
||
|
printf(".............. done.\n");
|
||
|
}else{
|
||
|
printf(".............. fail.\n");
|
||
|
}
|
||
|
file.close();
|
||
|
if( verbose ) for(int i = 0; i < (int) eCorr.size(); i++) printf("%2d | %10.3f, %10.3f\n", i, eCorr[i][0], eCorr[i][1]);
|
||
|
}
|
||
|
|
||
|
//~========================================= rdt correction
|
||
|
void LoadRDTCorr(bool verbose = false, const char * fileName = "correction_rdt.dat"){
|
||
|
printf(" loading rdt correction.");
|
||
|
rdtCorr.clear();
|
||
|
std::ifstream file;
|
||
|
file.open(fileName);
|
||
|
if( file.is_open() ){
|
||
|
float a, b;
|
||
|
while( file >> a >> b) rdtCorr.push_back({a, b});
|
||
|
printf("............ done.\n");
|
||
|
}else{
|
||
|
printf("............ fail.\n");
|
||
|
}
|
||
|
file.close();
|
||
|
if( verbose ) for(int i = 0; i < (int) rdtCorr.size(); i++) printf("%2d | %10.3f, %10.3f\n", i, rdtCorr[i][0], rdtCorr[i][1]);
|
||
|
}
|
||
|
|
||
|
};
|
||
|
|
||
|
#endif
|