/[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.2 by kusanagi, Tue Jul 6 13:31:18 2004 UTC revision 2.2 by kusanagi, Thu Dec 9 08:48:41 2004 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.1.1.1 2004/07/06 12:20:23 kusanagi Exp $   * $Id: PhysicsReader.cpp,v 2.1 2004/12/03 22:08:01 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 25  extern "C" { Line 25  extern "C" {
25  using namespace pamela;  using namespace pamela;
26  using namespace pamela::techmodel;  using namespace pamela::techmodel;
27  using namespace pamela::tracker;  using namespace pamela::tracker;
28    using namespace pamela::anticounter;
29    using namespace pamela::calorimeter;
30    using namespace pamela::neutron;
31    using namespace pamela::S4;
32    
33  static log4cpp::Category& cat = log4cpp::Category::getInstance("pamela.techmodel.PhysicsReader");    static log4cxx::LoggerPtr logger = log4cxx::Logger::getLogger(_T("pamela.techmodel.PhysicsReader"));
34    
35  /**  /**
36   * Constructor.   * Constructor.
37   */   */
38  PhysicsReader::PhysicsReader(void):  PhysicsReader::PhysicsReader(void):
39    TechmodelAlgorithm(PacketType::Log, "TechmodelPhysicsReader") {    TechmodelAlgorithm(PacketType::Physics, "TechmodelPhysicsReader") {
40    cat <<  log4cpp::Priority::DEBUG    logger->debug(_T("Constructor"));
41        <<  "Constructor "    trackerReader     = new TrackerReader;
42        <<  "\n " << log4cpp::CategoryStream::ENDLINE;    anticounterReader = new AnticounterReader;
43    trackerReader = new TrackerReader();    calorimeterReader = new CalorimeterReader;
44      neutronReader     = new NeutronDetectorReader;
45      s4Reader          = new S4Reader;
46  }  }
47    
48  /**  /**
# Line 44  PhysicsReader::PhysicsReader(void): Line 50  PhysicsReader::PhysicsReader(void):
50   */   */
51  std::string PhysicsReader::GetVersionInfo(void) const {  std::string PhysicsReader::GetVersionInfo(void) const {
52    return    return
53      "$Header: /home/cvsmanager/yoda/techmodel/PhysicsReader.cpp,v 1.1.1.1 2004/07/06 12:20:23 kusanagi Exp $\n";      "$Header: /home/cvsmanager/yoda/techmodel/PhysicsReader.cpp,v 2.1 2004/12/03 22:08:01 kusanagi Exp $\n";
54  }  }
55    
56  /**  /**
# Line 54  std::string PhysicsReader::GetVersionInf Line 60  std::string PhysicsReader::GetVersionInf
60  void PhysicsReader::Init(PamelaRun *run) {  void PhysicsReader::Init(PamelaRun *run) {
61    SetInputStream(run);    SetInputStream(run);
62    trackerReader->Init(run);    trackerReader->Init(run);
63      anticounterReader->Init(run);
64      calorimeterReader->Init(run);
65      neutronReader->Init(run);
66    //run->WriteSubPacket(this, &physicsEvent, physicsEvent->Class());    //run->WriteSubPacket(this, &physicsEvent, physicsEvent->Class());
67      logger->debug(_T("Initialize"));
68  }  }
69    
70  /**  /**
71   * Unpack the Physics event from an input file.   * Unpack the Physics event from an input file.
72   */   */
73  void PhysicsReader::RunEvent(int EventNumber, long int length) {  void PhysicsReader::RunEvent(int EventNumber, long int dataLenght) throw (Exception){
74        char *subData = new char[dataLenght];
75        InputFile->read(subData, sizeof(unsigned char)*dataLenght);
76    
77      /*UINT16      CRCread;     //CRC read from the end of the subpacket          /*-----------------*/
     UINT16      CRCsum;      //CRC of the data  
     char        packetData[length-2];  
     char        CRCevent[2];  
     long int    dataLength;  
   
     InputFile->read(packetData, sizeof(packetData));  
     InputFile->read(CRCevent, sizeof(CRCevent));  
   
     CRCsum = CM_Compute_CRC16(0, (BYTE*)packetData, length -(long int)2 );  
     CRCread = ((UINT16)(CRCevent[0]<<8)) + ((UINT16)CRCevent[1]);  
     InputFile->seekg(-(length), std::ios::cur);  
   
     if (CRCread == CRCsum){  
           
78          //passo packetData a tutti i reader dei vari rivelatori          //passo packetData a tutti i reader dei vari rivelatori
79      } else {          trackerReader->RunEvent(EventNumber, subData, dataLenght);
80          cat <<  log4cpp::Priority::ERROR          anticounterReader->RunEvent(EventNumber, subData, dataLenght);
81              <<  "The test of calculated CRC with one wrote on file FAILED!!"          calorimeterReader->RunEvent(EventNumber, subData, dataLenght);
82              <<  "\n " << log4cpp::CategoryStream::ENDLINE;          neutronReader->RunEvent(EventNumber, subData, dataLenght);
83      }*/          s4Reader->RunEvent(EventNumber, subData, dataLenght);
84            /*-----------------*/
85      char        packetData[length-2];      delete[] subData;
     int         ERROR;  
   
     InputFile->read(packetData, sizeof(packetData));  
     //Skip the last two crc bytes already checked in UnpackPscu  
     //This part have to be refactored!!!! too bad......  
     //InputFile->seekg((long int)2, std::ios::cur);  
       
     /*-----------------*/  
     //passo packetData a tutti i reader dei vari rivelatori  
     //trackerReader->RunEvent(EventNumber, packetData, length-2);  
     /*-----------------*/  
     //free(packetData);      
       
86  }  }
87    

Legend:
Removed from v.1.2  
changed lines
  Added in v.2.2

  ViewVC Help
Powered by ViewVC 1.1.23