utilities/Atri/makeAtriCalibratedEventTree.cxx
00001 #include <cstdio> 00002 #include <fstream> 00003 #include <iostream> 00004 #include <zlib.h> 00005 #include <libgen.h> 00006 #include <cstdlib> 00007 00008 using namespace std; 00009 00010 #include "TTree.h" 00011 #include "TFile.h" 00012 #include "TSystem.h" 00013 00014 #define HACK_FOR_ROOT 00015 00016 #include "araAtriStructures.h" 00017 #include "RawAtriStationEvent.h" 00018 #include "UsefulAtriStationEvent.h" 00019 00020 void process(); 00021 void makeTree(char *inputName, char *outDir); 00022 00023 AraStationEventHeader_t theEventHeader; 00024 char *dataBuffer; 00025 TFile *theFile; 00026 TTree *eventTree; 00027 RawAtriStationEvent *theEvent=0; 00028 UsefulAtriStationEvent *theUsefulEvent=0; 00029 char outName[FILENAME_MAX]; 00030 UInt_t realTime; 00031 Int_t runNumber; 00032 Int_t lastRunNumber; 00033 00034 00035 int main(int argc, char **argv) { 00036 dataBuffer = new char[200000]; 00037 theEvent=0; 00038 if(argc<3) { 00039 std::cout << "Usage: " << basename(argv[0]) << " <file list> <out dir>" << std::endl; 00040 return -1; 00041 } 00042 if(argc==4) 00043 runNumber=atoi(argv[3]); 00044 makeTree(argv[1],argv[2]); 00045 delete [] dataBuffer; 00046 return 0; 00047 } 00048 00049 00050 void makeTree(char *inputName, char *outFile) { 00051 cout << inputName << "\t" << outFile << endl; 00052 strncpy(outName,outFile,FILENAME_MAX); 00053 theEvent = new RawAtriStationEvent(); 00054 // cout << sizeof(AraStationEventHeader_t) << endl; 00055 ifstream SillyFile(inputName); 00056 00057 int numBytes=0; 00058 char fileName[180]; 00059 int error=0; 00060 // int eventNumber=1; 00061 int counter=0; 00062 while(SillyFile >> fileName) { 00063 if(counter%100==0) 00064 cout << fileName << endl; 00065 counter++; 00066 00067 // const char *subDir = gSystem->DirName(fileName); 00068 // const char *subSubDir = gSystem->DirName(subDir); 00069 // const char *eventDir = gSystem->DirName(subSubDir); 00070 // const char *runDir = gSystem->DirName(eventDir); 00071 // const char *justRun = gSystem->BaseName(runDir); 00072 // cout << justRun << endl; 00073 // sscanf(justRun,"run%d",&runNumber); 00074 00075 gzFile infile = gzopen (fileName, "rb"); 00076 // std::cout << "gzeof: " << gzeof(infile) << "\n"; 00077 for(int i=0;i<1000;i++) { 00078 // cout << i << endl; 00079 numBytes=gzread(infile,&theEventHeader,sizeof(AraStationEventHeader_t)); 00080 // std::cout << numBytes << "\n"; 00081 if(numBytes==0) break; 00082 if(numBytes!=sizeof(AraStationEventHeader_t)) { 00083 if(numBytes) 00084 cerr << "Read problem: " <<numBytes << " of " << sizeof(AraStationEventHeader_t) << endl; 00085 error=1; 00086 break; 00087 } 00088 if(theEventHeader.gHdr.numBytes>0) { 00089 // std::cout << "Num bytes: " << theEventHeader.gHdr.numBytes << "\t" << theEventHeader.numBytes << "\n"; 00090 // std::cout << "Event number: " << theEventHeader.eventNumber << "\t" << theEventHeader.unixTime << "\t" << theEventHeader.unixTimeUs << "\n"; 00091 00092 00093 Int_t numDataBytes=theEventHeader.gHdr.numBytes-sizeof(AraStationEventHeader_t); 00094 numBytes=gzread(infile,dataBuffer,numDataBytes); 00095 // std::cout << numBytes << "\n"; 00096 if(numBytes==0) break; 00097 if(numBytes!=numDataBytes) { 00098 if(numBytes) 00099 cerr << "Read problem: " <<numBytes << " of " << numDataBytes << endl; 00100 error=1; 00101 break; 00102 } 00103 process(); 00104 // exit(0); 00105 } 00106 else { 00107 std::cerr << "How can gHdr.numBytes = " << theEventHeader.gHdr.numBytes << "\n"; 00108 error=1; 00109 break; 00110 } 00111 00112 // cout << ": " << theEventHeader.unixTime << endl; 00113 } 00114 gzclose(infile); 00115 // if(error) break; 00116 } 00117 if(eventTree) 00118 eventTree->AutoSave(); 00119 // theFile->Close(); 00120 } 00121 00122 00123 void process() { 00124 // cout << "process:\t" << theEventHeader.eventNumber << endl; 00125 static int doneInit=0; 00126 if(!doneInit) { 00127 // char dirName[FILENAME_MAX]; 00128 // char fileName[FILENAME_MAX]; 00129 // sprintf(dirName,"%s/run%d",outDirName,runNumber); 00130 // gSystem->mkdir(dirName,kTRUE); 00131 // sprintf(fileName,"%s/eventFile%d.root",dirName,runNumber); 00132 cout << "Creating File: " << outName << endl; 00133 theFile = new TFile(outName,"RECREATE"); 00134 eventTree = new TTree("eventTree","Tree of ARA Event's"); 00135 eventTree->Branch("run",&runNumber,"run/I"); 00136 eventTree->Branch("event","RawAtriStationEvent",&theEvent); 00137 eventTree->Branch("calevent","UsefulAtriStationEvent",&theUsefulEvent); 00138 00139 doneInit=1; 00140 } 00141 // cout << "Here: " << theEvent.eventNumber << endl; 00142 if(theEvent) delete theEvent; 00143 if(theUsefulEvent) delete theUsefulEvent; 00144 00145 theEvent = new RawAtriStationEvent(&theEventHeader,dataBuffer); 00146 theUsefulEvent = new UsefulAtriStationEvent(theEvent, AraCalType::kLatestCalib); 00147 00148 eventTree->Fill(); 00149 lastRunNumber=runNumber; 00150 // delete theEvent; 00151 }
Generated on Mon Mar 18 16:00:44 2013 for ARA ROOT v3.4 Software by
