| 1 | // | // | 
| 2 |  | // Given a calibration and a data file this program create an ntuple with LEVEL2 S4 variables | 
| 3 |  | // | 
| 4 |  | // | 
| 5 | // C/C++ headers | // C/C++ headers | 
| 6 | // | // | 
| 7 | #include <fstream> | #include <fstream> | 
| 32 | #include <stdlib.h> | #include <stdlib.h> | 
| 33 | #include <math.h> | #include <math.h> | 
| 34 | // | // | 
| 35 |  | // RunInfo header | 
| 36 |  | // | 
| 37 |  | #include <RunInfo.h> | 
| 38 |  | #include <GLTables.h> | 
| 39 |  | // | 
| 40 | // YODA headers | // YODA headers | 
| 41 | // | // | 
| 42 | #include <PamelaRun.h> | #include <PamelaRun.h> | 
| 45 | #include <EventHeader.h> | #include <EventHeader.h> | 
| 46 | #include <CalibS4Event.h> | #include <CalibS4Event.h> | 
| 47 | #include <physics/S4/S4Event.h> | #include <physics/S4/S4Event.h> | 
|  | //#include <yodaUtility.h> |  | 
|  | // |  | 
|  | // RunInfo header |  | 
|  | // |  | 
|  | #include <RunInfo.h> |  | 
|  | #include <GLTables.h> |  | 
| 48 | // | // | 
| 49 | // This program headers | // This program headers | 
| 50 | // | // | 
| 51 | #include <S4Level2.h> | #include <S4Level2.h> | 
| 52 | #include <S4Core.h> | #include <S4Core.h> | 
| 53 | #include <S4Verl2.h> | #include <S4Verl2.h> | 
|  |  |  | 
|  | using namespace std; |  | 
|  |  |  | 
|  | // |  | 
| 54 | // | // | 
| 55 |  | using namespace std; | 
| 56 | // | // | 
| 57 | /* | /* | 
| 58 | * Fit function Received from Valeria Malvezzi 06/02/2006 | * Fit function Received from Valeria Malvezzi 06/02/2006 | 
| 101 | // | // | 
| 102 | tr->GetEntry(glS4calib->EV_ROOT); | tr->GetEntry(glS4calib->EV_ROOT); | 
| 103 | // | // | 
| 104 | //----------- variable initialization ------------------------------------------------- | // Variables initialization | 
| 105 | // | // | 
| 106 | Double_t mip[3]={1, 30, 300}; | Double_t mip[3]={1, 30, 300}; | 
| 107 | Double_t adc[3] = {0.,0.,0.}; | Double_t adc[3] = {0.,0.,0.}; | 
| 108 | // | // | 
| 109 | //------------ Fit calibrations and find parameters to calibrate data ------------------ | // Fit calibrations and find parameters to calibrate data | 
| 110 | // | // | 
| 111 | pamela::S4::S4Event  *s4Record = 0; | pamela::S4::S4Event  *s4Record = 0; | 
| 112 | // | // | 
| 135 | adc[2]=adc[2]/128; | adc[2]=adc[2]/128; | 
| 136 | //  if ( IsDebug() ) printf(" adc1 = %g adc2 = %g adc3 = %g\n",adc[0],adc[1],adc[2]); | //  if ( IsDebug() ) printf(" adc1 = %g adc2 = %g adc3 = %g\n",adc[0],adc[1],adc[2]); | 
| 137 | TGraph *fitpar = new TGraph (3, adc, mip); | TGraph *fitpar = new TGraph (3, adc, mip); | 
| 138 | TF1 *func = new TF1("fitf", fitf, -1., 400., 2); // definizione della funzione, 2 = num. parametri | TF1 *func = new TF1("fitf", fitf, -1., 400., 2); // function definition with 2 parameters | 
|  | //  TF1 *func = new TF1("fitf", fitf, -0., 1000., 2); // definizione della funzione, 2 = num. parametri |  | 
| 139 | // | // | 
| 140 | func->SetParameters(0.3,1.);        //inizializzazione dei parametri a 1 | func->SetParameters(0.3,1.); // parameters initialization to 1 | 
| 141 | func->SetParNames("m","q");      //definisce il nome dei parametri | func->SetParNames("m","q"); //parameter's name | 
| 142 | fitpar->Fit(func,"qr");          //fitta fitpar con la funzione func nel range definito nella funzione | fitpar->Fit(func,"qr"); //function fit | 
|  | //fitpar->Fit(func,"r");          //fitta fitpar con la funzione func nel range definito nella funzione |  | 
| 143 | parametri->AddAt(func->GetParameter(0),0); | parametri->AddAt(func->GetParameter(0),0); | 
| 144 | parametri->AddAt(func->GetParameter(1),1); | parametri->AddAt(func->GetParameter(1),1); | 
| 145 | //  if ( parametri[0] < 0. || parametri[0] > 0.5 || parametri[1] < 0.7 || parametri[1] > 1.1 ) valid = 0; | //  if ( parametri[0] < 0. || parametri[0] > 0.5 || parametri[1] < 0.7 || parametri[1] > 1.1 ) valid = 0; | 
| 158 | // | // | 
| 159 | // | // | 
| 160 | int S4Core(UInt_t run, TFile *file, TSQLServer *dbc, Int_t S4argc, char *S4argv[]){ | int S4Core(UInt_t run, TFile *file, TSQLServer *dbc, Int_t S4argc, char *S4argv[]){ | 
|  | Int_t i = 0; |  | 
| 161 | // | // | 
| 162 | TString processFolder = "S4Folder"; | // Set these to true to have a verbose output. | 
| 163 | // | // | 
| 164 | Bool_t debug = false; | Bool_t debug = false; | 
|  | // |  | 
| 165 | Bool_t verbose = false; | Bool_t verbose = false; | 
| 166 | // | // | 
| 167 |  | // | 
| 168 |  | // Output directory is the working directoy. | 
| 169 |  | // | 
| 170 |  | const char* outDir = gSystem->DirName(gSystem->DirName(file->GetPath())); | 
| 171 |  | // | 
| 172 |  | Int_t i = 0; | 
| 173 |  | TString processFolder = "S4Folder_"+run; | 
| 174 | if ( S4argc > 0 ){ | if ( S4argc > 0 ){ | 
| 175 | i = 0; | i = 0; | 
| 176 | while ( i < S4argc ){ | while ( i < S4argc ){ | 
| 190 | i++; | i++; | 
| 191 | }; | }; | 
| 192 | }; | }; | 
|  | // |  | 
|  | const char* outDir = gSystem->DirName(gSystem->DirName(file->GetPath())); |  | 
|  | // |  | 
| 193 | // Variables for level2 | // Variables for level2 | 
| 194 | // | // | 
| 195 | TTree *S4tr = 0; | TTree *S4tr = 0; | 
| 196 | UInt_t nevents = 0; | UInt_t nevents = 0; | 
| 197 | // | // | 
| 198 | // variables needed to reprocess data | // Variables needed to reprocess data | 
| 199 | // | // | 
| 200 | Long64_t maxsize = 10000000000LL; | Long64_t maxsize = 10000000000LL; | 
| 201 | TTree::SetMaxTreeSize(maxsize); | TTree::SetMaxTreeSize(maxsize); |