/[PAMELA software]/yoda/techmodel/PhysicsReader.cpp
ViewVC logotype

Diff of /yoda/techmodel/PhysicsReader.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.3 by kusanagi, Sat Jul 17 20:03:38 2004 UTC revision 3.1 by kusanagi, Sun Mar 6 04:29:20 2005 UTC
# Line 1  Line 1 
1  /** @file      /** @file
2   * $Source: /home/cvsmanager/yoda/techmodel/PhysicsReader.cpp,v $   * $Source: /home/cvsmanager/yoda/techmodel/PhysicsReader.cpp,v $
3   * $Id: PhysicsReader.cpp,v 1.2 2004/07/06 13:31:18 kusanagi Exp $   * $Id: PhysicsReader.cpp,v 3.0 2005/03/04 15:54:11 kusanagi Exp $
4   * $Author: kusanagi $   * $Author: kusanagi $
5   *   *
6   * Implementation of the LogReader class.   * Implementation of the LogReader class.
# Line 11  Line 11 
11  #define UINT unsigned int  #define UINT unsigned int
12  #define BYTE  unsigned char  #define BYTE  unsigned char
13  #include <string>  #include <string>
14  #include <log4cpp/Category.hh>  #include <log4cxx/logger.h>
15  extern "C" {  extern "C" {
16  #include <sys/time.h>  #include <sys/time.h>
17  #include "CRC.h"  #include "CRC.h"
# Line 27  using namespace pamela::techmodel; Line 27  using namespace pamela::techmodel;
27  using namespace pamela::tracker;  using namespace pamela::tracker;
28  using namespace pamela::anticounter;  using namespace pamela::anticounter;
29  using namespace pamela::calorimeter;  using namespace pamela::calorimeter;
30    using namespace pamela::neutron;
31    using namespace pamela::S4;
32    using namespace pamela::tof;
33    using namespace pamela::trigger;
34    
35  static log4cpp::Category& cat = log4cpp::Category::getInstance("pamela.techmodel.PhysicsReader");    static log4cxx::LoggerPtr logger = log4cxx::Logger::getLogger(_T("pamela.techmodel.PhysicsReader"));
36    
37  /**  /**
38   * Constructor.   * Constructor.
39   */   */
40  PhysicsReader::PhysicsReader(void):  PhysicsReader::PhysicsReader(void):
41    TechmodelAlgorithm(PacketType::Log, "TechmodelPhysicsReader") {      TechmodelAlgorithm(PacketType::Physics, "TechmodelPhysicsReader") {
42    cat <<  log4cpp::Priority::DEBUG      logger->debug(_T("Constructor"));
43        <<  "Constructor "      trackerReader     = new TrackerReader;
44        <<  "\n " << log4cpp::CategoryStream::ENDLINE;      anticounterReader = new AnticounterReader;
45    trackerReader     = new TrackerReader();      calorimeterReader = new CalorimeterReader;
46    anticounterReader = new AnticounterReader();      neutronReader     = new NeutronDetectorReader;
47    calorimeterReader = new CalorimeterReader();      s4Reader          = new S4Reader;
48        tofReader         = new TofReader;
49        triggerReader     = new TriggerReader;
50  }  }
51    
52  /**  /**
# Line 48  PhysicsReader::PhysicsReader(void): Line 54  PhysicsReader::PhysicsReader(void):
54   */   */
55  std::string PhysicsReader::GetVersionInfo(void) const {  std::string PhysicsReader::GetVersionInfo(void) const {
56    return    return
57      "$Header: /home/cvsmanager/yoda/techmodel/PhysicsReader.cpp,v 1.2 2004/07/06 13:31:18 kusanagi Exp $\n";      "$Header: /home/cvsmanager/yoda/techmodel/PhysicsReader.cpp,v 3.0 2005/03/04 15:54:11 kusanagi Exp $\n";
58  }  }
59    
60  /**  /**
# Line 56  std::string PhysicsReader::GetVersionInf Line 62  std::string PhysicsReader::GetVersionInf
62   * event reader routines for all packet types.   * event reader routines for all packet types.
63   */   */
64  void PhysicsReader::Init(PamelaRun *run) {  void PhysicsReader::Init(PamelaRun *run) {
65    SetInputStream(run);      SetInputStream(run);
66    trackerReader->Init(run);      trackerReader->Init(run);
67    anticounterReader->Init(run);      anticounterReader->Init(run);
68    calorimeterReader->Init(run);      calorimeterReader->Init(run);
69        neutronReader->Init(run);
70        s4Reader->Init(run);
71        tofReader->Init(run);
72        triggerReader->Init(run);
73    //run->WriteSubPacket(this, &physicsEvent, physicsEvent->Class());    //run->WriteSubPacket(this, &physicsEvent, physicsEvent->Class());
74      logger->debug(_T("Initialize"));
75  }  }
76    
77  /**  /**
78   * Unpack the Physics event from an input file.   * Unpack the Physics event from an input file.
79   */   */
80  void PhysicsReader::RunEvent(int EventNumber, long int dataLength) {  void PhysicsReader::RunEvent(int EventNumber, long int dataLenght) throw (Exception){
81      char *subData = new char[dataLength];      char *subData = new char[dataLenght];
82      InputFile->read(subData, sizeof(unsigned char)*dataLength);      InputFile->read(subData, sizeof(unsigned char)*dataLenght);
83    
84          /*-----------------*/      /*-----------------*/
85          //passo packetData a tutti i reader dei vari rivelatori      //passo packetData a tutti i reader dei vari rivelatori
86          trackerReader->RunEvent(EventNumber, subData, dataLength);      trackerReader->RunEvent(EventNumber, subData, dataLenght);
87          anticounterReader->RunEvent(EventNumber, subData, dataLength);      anticounterReader->RunEvent(EventNumber, subData, dataLenght);
88          calorimeterReader->RunEvent(EventNumber, subData, dataLength);      calorimeterReader->RunEvent(EventNumber, subData, dataLenght);
89          /*-----------------*/      neutronReader->RunEvent(EventNumber, subData, dataLenght);
90        s4Reader->RunEvent(EventNumber, subData, dataLenght);
91        tofReader->RunEvent(EventNumber, subData, dataLenght);
92        triggerReader->RunEvent(EventNumber, subData, dataLenght);
93        /*-----------------*/
94        delete [] subData;
95  }  }
96    

Legend:
Removed from v.1.3  
changed lines
  Added in v.3.1

  ViewVC Help
Powered by ViewVC 1.1.23