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

Diff of /yoda/techmodel/CalibCalPedReader.cpp

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

revision 2.3 by kusanagi, Thu Dec 9 13:17:24 2004 UTC revision 4.1 by kusanagi, Sat May 28 08:02:48 2005 UTC
# Line 1  Line 1 
 #define BYTE  unsigned char  
 #include <string>  
1  #include <log4cxx/logger.h>  #include <log4cxx/logger.h>
2  #include <fstream>  #include <fstream>
3  #include "stdio.h"  
4  extern "C" {  extern "C" {
5  #include "CRC.h"    
6      //Struct per il passaggio di dati da e verso la chiamata fortran      //Struct per il passaggio di dati da e verso la chiamata fortran
7      extern struct {      extern struct {
8          int   iev;          int   iev;
# Line 16  extern "C" { Line 14  extern "C" {
14          float calrms[4][11][96];          float calrms[4][11][96];
15          float calbase[4][11][6];          float calbase[4][11][6];
16          float calvar[4][11][6];          float calvar[4][11][6];
17          float calpuls[4][11][96];          //float calpuls[4][11][96];
18      } calib_;      } calib_;
19      //external declaration of the Fortran function      //external declaration of the Fortran function
20      void calpedestal_(char*, long int*, int*);      void calpedestal_(char*, long int*, int*);
# Line 44  CalibCalPedReader::CalibCalPedReader(voi Line 42  CalibCalPedReader::CalibCalPedReader(voi
42   */   */
43  std::string CalibCalPedReader::GetVersionInfo(void) const {  std::string CalibCalPedReader::GetVersionInfo(void) const {
44    return    return
45      "$Header: /home/cvsmanager/yoda/techmodel/CalibCalPedReader.cpp,v 2.2 2004/12/03 22:08:00 kusanagi Exp $\n";      "$Header: /home/cvsmanager/yoda/techmodel/CalibCalPedReader.cpp,v 4.0 2005/03/06 04:33:02 kusanagi Exp $\n";
46  }  }
47    
48  /**  /**
# Line 67  void CalibCalPedReader::RunEvent(int Eve Line 65  void CalibCalPedReader::RunEvent(int Eve
65      InputFile->read(packetData, sizeof(packetData));      InputFile->read(packetData, sizeof(packetData));
66    
67      calpedestal_((char*)packetData, &dataLength, &ERROR);      calpedestal_((char*)packetData, &dataLength, &ERROR);
68    
69        calibCalPed->unpackError = ERROR;
70      if (ERROR != 0) {      if (ERROR != 0) {
71          char *errmsg;          char *errmsg;
72          switch (ERROR){          switch (ERROR){
# Line 74  void CalibCalPedReader::RunEvent(int Eve Line 74  void CalibCalPedReader::RunEvent(int Eve
74          }          }
75          oss.str("");          oss.str("");
76          oss << "Fortran77 function calpedestal error code = " << ERROR          oss << "Fortran77 function calpedestal error code = " << ERROR
77              <<  "\n" <<errmsg;              <<  " " << errmsg;
78          logger->warn(oss.str().c_str());          logger->warn(oss.str().c_str());
79      } else {      } else {
80        //Store the unpacked data        //Store the unpacked data
# Line 88  void CalibCalPedReader::RunEvent(int Eve Line 88  void CalibCalPedReader::RunEvent(int Eve
88          float tempCalrms[96][11][4];          float tempCalrms[96][11][4];
89          float tempCalbase[6][11][4];          float tempCalbase[6][11][4];
90          float tempCalvar[6][11][4];          float tempCalvar[6][11][4];
91          float tempCalpuls[96][11][4];          //float tempCalpuls[96][11][4];
92    
93          memcpy(tempCalped,  calib_.calped,  sizeof(tempCalped));          memcpy(tempCalped,  calib_.calped,  sizeof(tempCalped));
94          memcpy(tempCalgood, calib_.calgood, sizeof(tempCalgood));          memcpy(tempCalgood, calib_.calgood, sizeof(tempCalgood));
# Line 96  void CalibCalPedReader::RunEvent(int Eve Line 96  void CalibCalPedReader::RunEvent(int Eve
96          memcpy(tempCalrms,  calib_.calrms,  sizeof(tempCalrms));          memcpy(tempCalrms,  calib_.calrms,  sizeof(tempCalrms));
97          memcpy(tempCalbase, calib_.calbase, sizeof(tempCalbase));          memcpy(tempCalbase, calib_.calbase, sizeof(tempCalbase));
98          memcpy(tempCalvar,  calib_.calvar,  sizeof(tempCalvar));          memcpy(tempCalvar,  calib_.calvar,  sizeof(tempCalvar));
99          memcpy(tempCalpuls, calib_.calpuls, sizeof(tempCalpuls));          //memcpy(tempCalpuls, calib_.calpuls, sizeof(tempCalpuls));
100    
101          for (int i = 0; i < 4; i++){          for (int i = 0; i < 4; i++){
102              for (int j = 0; j <11; j++){              for (int j = 0; j <11; j++){
# Line 104  void CalibCalPedReader::RunEvent(int Eve Line 104  void CalibCalPedReader::RunEvent(int Eve
104                      calibCalPed->calped[i][j][z]    = tempCalped[z][j][i];                      calibCalPed->calped[i][j][z]    = tempCalped[z][j][i];
105                      calibCalPed->calgood[i][j][z]   = tempCalgood[z][j][i];                      calibCalPed->calgood[i][j][z]   = tempCalgood[z][j][i];
106                      calibCalPed->calrms[i][j][z]    = tempCalrms[z][j][i];                      calibCalPed->calrms[i][j][z]    = tempCalrms[z][j][i];
107                      calibCalPed->calpuls[i][j][z]   = tempCalpuls[z][j][i];                      //calibCalPed->calpuls[i][j][z]   = tempCalpuls[z][j][i];
108                  }                  }
109              }              }
110          }          }

Legend:
Removed from v.2.3  
changed lines
  Added in v.4.1

  ViewVC Help
Powered by ViewVC 1.1.23