#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include // ADD HEADER FILE HERE using namespace std; //=================================== // global variables //=================================== Bool_t DEBUG; Bool_t SIMU; TString DIR; TString LIST; TString OPTIONS; ULong64_t MAXEV; TString OUTFILE; PamLevel2 *pam_event = NULL; TFile *outfv = NULL; bool fillTree = false; bool fillHistos = false; //========================================== //000000000000000000000000000000000000000000 //========================================== Int_t Loop(TString ddir,TString list, ULong64_t nmax, TString options, TString outfile){ TH1F *hzeta = new TH1F("hzeta","Zeta Distribution",100,0.,50.); if(options.Contains("fillTree"))fillTree=true; if(options.Contains("fillHisto"))fillHistos=true; // ------------------- // create output files // ------------------- TString outfile_t =""; // TString outfile_h =""; // TString outfile_v =""; if( outfile.IsNull() ){ if(!list.IsNull())outfile = list(0,list.Last('.')); else outfile = "output"; }else{ if(outfile.Contains(".root"))outfile = outfile(0,outfile.Last('.')); } // if(fillTree){ outfile_t = outfile; outfile_t.Append("-hzeta.root"); outfv = (TFile*)gROOT->FindObject(outfile_t); if (outfv) outfv->Close(); outfv = new TFile(outfile_t,"RECREATE"); if(outfv->IsZombie()){ cout << "Output file could not be created\n"; return 1; }; cout << "Created output file: "<GetName()<GetEntries(); if(!nmax)nmax = numeric_limits::max(); if(nevents < nmax)nmax=nevents; cout << endl<<" Start loop over events: "<< nmax<Clear(); if( pam_event->GetEntry(i) ){ // get the entry // cn->Print(); // this will simply print on the terminal the determined CaloNuclei values // Float_t zeta = cn->Get_lpz(); // here how you can use the "old" dE/dx on the first plane printf(" Event number %llu zeta %f \n",i,zeta); hzeta->Fill(zeta); } }; pam_event->Clear(); // // save histo to file // gROOT->cd(); outfv->cd(); // hzeta->Write(); outfv->Close(); // printf(" end!\n"); return 0; } ///////////////////////////////////////////////////////////////// void usage(){ cout << "------------------------------------------------------------"< create an output file with histograms \n"; cout << " fillTree --> create an output file with trees storing the selected events \n "; cout << " +(-)ALL --> inlcude(exclude) all trees and branches \n " ; cout << " +(-)TRK1 +(-)TRK2 +(-)CAL1 +(-)CAL2 +(-)TOF +(-)TRG +(-)ND +(-)S4 +(-)ORB --> inlcude(exclude) trees and branches \n" ; cout << "------------------------------------------------------------"<1){ if(!strcmp(argv[1], "-h") || !strcmp(argv[1], "--help") ){ usage(); return(1); }; // ----------------------- // Read input parameters // ----------------------- DEBUG = false; SIMU = false; DIR = gSystem->WorkingDirectory(); LIST = ""; OUTFILE = ""; OPTIONS = "+AUTO fillTree"; MAXEV = 0; for (int i = 1; i < argc; i++){ // -----------------------------------------------------// if (!strcmp(argv[i], "-processDir")){ if (++i >= argc) throw -1; DIR = argv[i]; cout << "processDir "<= argc) throw -1; LIST = argv[i]; cout << "processList "<= argc) throw -1; OUTFILE = argv[i]; cout << "outputFile "<= argc) throw -1; MAXEV = atoi(argv[i]); cout << "NumEvents "<= argc) throw -1; OPTIONS = argv[i]; if( OPTIONS.Contains("[") ){ do{ if (++i >= argc) throw -1; OPTIONS.Append(argv[i]); }while(!OPTIONS.Contains("]")); }else cout << "wrong option format --> ignoring " << endl; } // -----------------------------------------------------// else if (!strcmp(argv[i], "--debug") || !strcmp(argv[i], "-g")){ DEBUG = true; continue; } else if (!strcmp(argv[i], "--simu") || !strcmp(argv[i], "-s")){ SIMU = true; continue; } // -----------------------------------------------------// else{ cout << "Unidentified input parameter. Ignored."<< endl; }; }; }else{ usage(); return(1); }; // ----------------------- // Check input parameters // ----------------------- return(0); }; // int main(int argc, char **argv) { if( HandleInputPar(argc,argv) )return(1); // Loop(DIR,LIST,MAXEV,"-ALL+TRK1+TRK2+CAL1+CAL2+TOF+AC",OUTFILE); cout << "OPTIONS "<