ARA ROOT v3.10 Software

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 
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 using namespace std;
00035 
00036 int main(int argc, char **argv) {
00037   dataBuffer = new char[200000];
00038   theEvent=0;
00039   if(argc<3) {
00040     std::cout << "Usage: " << basename(argv[0]) << " <file list> <out dir>" << std::endl;
00041     return -1;
00042   }
00043   if(argc==4) 
00044     runNumber=atoi(argv[3]);
00045   makeTree(argv[1],argv[2]);
00046   delete [] dataBuffer;
00047   return 0;
00048 }
00049   
00050 
00051 void makeTree(char *inputName, char *outFile) {
00052   cout << inputName << "\t" << outFile << endl;
00053   strncpy(outName,outFile,FILENAME_MAX);
00054   theEvent = new RawAtriStationEvent();
00055   //    cout << sizeof(AraStationEventHeader_t) << endl;
00056   ifstream SillyFile(inputName);
00057 
00058   int numBytes=0;
00059   char fileName[180];
00060   int error=0;
00061   //    int eventNumber=1;
00062   int counter=0;
00063   while(SillyFile >> fileName) {
00064     if(counter%100==0) 
00065       cout << fileName << endl;
00066     counter++;
00067     
00068     //    const char *subDir = gSystem->DirName(fileName);
00069     //    const char *subSubDir = gSystem->DirName(subDir);
00070     //    const char *eventDir = gSystem->DirName(subSubDir);
00071     //    const char *runDir = gSystem->DirName(eventDir);
00072     //    const char *justRun = gSystem->BaseName(runDir);
00073     //  cout << justRun << endl;
00074     //    sscanf(justRun,"run%d",&runNumber);
00075     
00076     gzFile infile = gzopen (fileName, "rb");    
00077     //    std::cout << "gzeof: " << gzeof(infile) << "\n";
00078     for(int i=0;i<1000;i++) {   
00079       //      cout << i << endl;
00080       numBytes=gzread(infile,&theEventHeader,sizeof(AraStationEventHeader_t));
00081       //      std::cout << numBytes << "\n";
00082       if(numBytes==0) break;
00083       if(numBytes!=sizeof(AraStationEventHeader_t)) {
00084         if(numBytes)
00085           cerr << "Read problem: " <<numBytes << " of " << sizeof(AraStationEventHeader_t) << endl;
00086         error=1;
00087         break;
00088       }
00089       if(theEventHeader.gHdr.numBytes>0) {
00090         //      std::cout << "Num bytes: " << theEventHeader.gHdr.numBytes << "\t" << theEventHeader.numBytes << "\n";
00091         //      std::cout << "Event number: " << theEventHeader.eventNumber << "\t" << theEventHeader.unixTime << "\t" << theEventHeader.unixTimeUs << "\n";
00092         
00093         
00094         Int_t numDataBytes=theEventHeader.gHdr.numBytes-sizeof(AraStationEventHeader_t);
00095         numBytes=gzread(infile,dataBuffer,numDataBytes);
00096         //      std::cout << numBytes << "\n";
00097         if(numBytes==0) break;
00098         if(numBytes!=numDataBytes) {
00099           if(numBytes)
00100             cerr << "Read problem: " <<numBytes << " of " <<  numDataBytes << endl;
00101           error=1;
00102           break;
00103         }
00104         process();
00105         //      exit(0);
00106       }
00107       else {
00108         std::cerr << "How can gHdr.numBytes = " << theEventHeader.gHdr.numBytes << "\n";
00109         error=1;
00110         break;
00111       }
00112 
00113       //      cout << ": " << theEventHeader.unixTime << endl;
00114      }
00115     gzclose(infile);
00116     //  if(error) break;
00117   }
00118   if(eventTree)
00119     eventTree->AutoSave();
00120   //    theFile->Close();
00121 }
00122 
00123 
00124 void process() {
00125   //  cout << "process:\t" << theEventHeader.eventNumber << endl;
00126   static int doneInit=0;
00127   if(!doneInit) {
00128     //    char dirName[FILENAME_MAX];
00129     //    char fileName[FILENAME_MAX];
00130     //    sprintf(dirName,"%s/run%d",outDirName,runNumber);
00131     //    gSystem->mkdir(dirName,kTRUE);
00132     //    sprintf(fileName,"%s/eventFile%d.root",dirName,runNumber);
00133     cout << "Creating File: " << outName << endl;
00134     theFile = new TFile(outName,"RECREATE");
00135     eventTree = new TTree("eventTree","Tree of ARA Event's");
00136     eventTree->Branch("run",&runNumber,"run/I");
00137     eventTree->Branch("event","RawAtriStationEvent",&theEvent);
00138     eventTree->Branch("calevent","UsefulAtriStationEvent",&theUsefulEvent);
00139     
00140     doneInit=1;
00141   }  
00142   //  cout << "Here: "  << theEvent.eventNumber << endl;
00143   if(theEvent) delete theEvent;
00144   if(theUsefulEvent) delete theUsefulEvent;
00145   
00146   theEvent = new RawAtriStationEvent(&theEventHeader,dataBuffer);
00147   theUsefulEvent = new UsefulAtriStationEvent(theEvent, AraCalType::kLatestCalib);
00148   
00149   eventTree->Fill();  
00150   lastRunNumber=runNumber;
00151   //  delete theEvent;
00152 }

Generated on Tue Jul 16 16:58:02 2013 for ARA ROOT v3.10 Software by doxygen 1.4.7