Changeset 4195 for trunk/MagicSoft


Ignore:
Timestamp:
05/26/04 17:20:43 (21 years ago)
Author:
stamerra
Message:
*** empty log message ***
Location:
trunk/MagicSoft/Mars/mtemp/mpisa/classes
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/mtemp/mpisa/classes/MReportTrigger.cc

    r4185 r4195  
    9797Bool_t MReportTrigger::InterpreteCell(TString &str)
    9898{
    99   Int_t len, n, i=0;
     99  Int_t len=0, n, i=0;
    100100  Int_t gsNCells=32;
    101101
    102   const char *pos = str.Data();
    103   const char *end = str.Data() + gsNCells;
    104 
    105   while (pos < end)
    106     {
    107       n = sscanf(pos, " %f %n", &fCell->fCellRate[i++], &len);
     102  for (i=0;i<gsNCells;i++)
     103    {
     104      n = sscanf(str.Data(), " %f %n", &fCell->fCellRate[i], &len);
    108105      if (n!=1)
    109106        {
     
    111108          return kCONTINUE;
    112109        }
     110      str.Remove(0, len); // Remove cell rates from report string
     111    }
     112
     113  str=str.Strip(TString::kLeading); 
     114
     115      *fLog << warn << "Cell ok!" <<endl;
     116  return kTRUE;
     117}
     118
     119// --------------------------------------------------------------------------
     120//
     121// Interprete the Prescaling factors part of the report
     122//
     123Bool_t MReportTrigger::InterpretePrescFact(TString &str)
     124{
     125  Int_t len=0, n, i=0;
     126  Int_t gsNPrescFacts=8;
     127 
     128      *fLog << warn << "Presca"<<endl;
     129  for (i=0;i<gsNPrescFacts;i++)
     130    {
     131    const Int_t ws = str.First(' ');
     132    *fLog << str << endl;
     133
     134    if (ws<=0)
     135       {
     136        *fLog << warn << "WARNING - Cannot determine name of L1 trigger table." << endl;
     137        return kCONTINUE;
     138       }
     139   
     140    TString L1tablename = str(0, ws);
     141    *fLog << "Presc " <<L1tablename <<endl;
     142    str.Remove(0, ws);
     143     
     144      n = sscanf(str.Data(), " %li %n", &fPrescFactor->fPrescFact[i], &len);
     145      if (n!=2)
     146        {
     147          *fLog << warn << "WARNING - prescaler factor " << i << " missing." << endl;
     148          return kCONTINUE;
     149        }
     150      str.Remove(0, len); // Remove Prescal. factors from report string
     151      *fLog << warn << fPrescFactor->fPrescFact[i]<<endl;
     152    }
     153  str=str.Strip(TString::kLeading); 
     154 
     155  *fLog << warn << "PrescFact ok!" <<endl;
     156  return kTRUE;
     157}
     158
     159// --------------------------------------------------------------------------
     160//
     161// Interprete the Scaler with Live-Deadtime part of the report
     162//  Read 4x5 integers separated with a blank
     163//
     164Bool_t MReportTrigger::InterpreteLiveTime(TString &str)
     165{
     166  Int_t len, n, i=0;
     167  Int_t gsNScalers=5;
     168  Int_t D_LSB, D_MSB,L_LSB, L_MSB;
     169
     170  const char *pos = str.Data();
     171  const char *end = str.Data() + gsNScalers;
     172
     173  while (pos < end)
     174    {
     175      i++;
     176      n = sscanf(pos, " %d %d %d %d %n", &L_LSB, &L_MSB,&D_LSB, &D_MSB, &len);
     177      if (n!=4)
     178        {
     179          *fLog << warn << "WARNING - Live-Deadtime Scaler Value #" << i << " missing." << endl;
     180          return kCONTINUE;
     181        }
    113182      pos += len;
    114     }
    115 
     183
     184      //convert to seconds and fill container
     185      // (FIXME! only the MSB (seconds is now considered)
     186      fLiveTime->fLiveTime[i] = L_MSB;
     187      fLiveTime->fDeadTime[i] = D_MSB;     
     188    }
     189
     190  str.Remove(0, end-str.Data()); // Remove Live-Deadtimes from report string
     191  str=str.Strip(TString::kLeading); 
     192
     193  *fLog << warn << "LiveTime ok!" <<endl;
    116194  return kTRUE;
    117195}
     
    120198//
    121199// Interprete the Bit rates part of the report
     200// 20 integers. First and last two are not used
    122201//
    123202Bool_t MReportTrigger::InterpreteBit(TString &str)
    124203{
    125 
     204  Int_t len, n, i=0;
     205  Int_t gsNBits=20;
     206 
     207  const char *pos = str.Data();
     208  const char *end = str.Data() + gsNBits;
     209
     210  while (pos < end)
     211    {
     212      n = sscanf(pos, " %f %n", &fBit->fBit[i++], &len);
     213      if (n!=1)
     214        {
     215          *fLog << warn << "WARNING - Bit rate #" << i << " missing." << endl;
     216          return kCONTINUE;
     217        }
     218      pos += len;
     219    }
     220
     221  str.Remove(0, end-str.Data()); // Remove output bit rates from report string
     222  str=str.Strip(TString::kLeading); 
     223
     224  *fLog << warn << "Bit ok!" <<endl;
     225  return kTRUE;
     226}
     227
     228// --------------------------------------------------------------------------
     229//
     230// Interprete the L1 and L2 table names
     231// 1String + 1Int +1 String
     232//
     233Bool_t MReportTrigger::InterpreteL1L2Table(TString &str)
     234{
     235    const Int_t wsL1 = str.First(' ');
     236 
     237    if (wsL1<=0)
     238       {
     239        *fLog << warn << "WARNING - Cannot determine name of L1 trigger table." << endl;
     240        return kCONTINUE;
     241       }
     242   
     243    TString L1tablename = str(0, wsL1);
     244    *fLog << "L1: " <<L1tablename <<endl;
     245    str.Remove(0, wsL1);
     246
     247    // remove an integer between names
     248    Int_t len;
     249    Int_t mi;
     250    Int_t n=sscanf(str.Data(), "%d %n", &mi, &len);
     251    if (n!=1)
     252      {
     253        *fLog << warn << "WARNING - Not enough arguments." << endl;
     254        return kCONTINUE;
     255    }
     256    str.Remove(0, len);
     257
     258    // L2 tablename
     259    const Int_t wsL2 = str.First(' ');
     260 
     261    if (wsL2<=0)
     262      {
     263        *fLog << warn << "WARNING - Cannot determine name of L2 trigger table." << endl;
     264        return kCONTINUE;
     265      }   
     266    TString L2tablename = str(0, wsL2);
     267    *fLog << "L2: " <<L2tablename <<endl;
     268    str.Remove(0,wsL2);
     269    str.Strip(TString::kBoth);
     270   
     271    return kTRUE;
     272}
     273
     274// --------------------------------------------------------------------------
     275//
     276// Interprete a part of the report without meaning by this time
     277// 18 integers
     278//
     279Bool_t MReportTrigger::InterpreteDummy(TString &str)
     280{
     281  Int_t len, n, i=0;
     282  Int_t gsNDummies=18;
     283  Int_t dummy; 
     284
     285  const char *pos = str.Data();
     286  const char *end = str.Data() + gsNDummies;
     287
     288  while (pos < end)
     289    {
     290      n = sscanf(pos, " %d %n", &dummy, &len);
     291      if (n!=1)
     292        {
     293          *fLog << warn << "WARNING - Dummy #" << i << " missing." << endl;
     294          return kCONTINUE;
     295        }
     296      pos += len;
     297    }
     298
     299  str.Remove(0, end-str.Data()); // Remove dummies from report string
     300  str=str.Strip(TString::kLeading); 
     301
     302  *fLog << warn << "Dummy ok!" <<endl;
    126303  return kTRUE;
    127304}
     
    134311{
    135312
    136   return kTRUE;
    137 }
    138 
    139 // --------------------------------------------------------------------------
    140 //
    141 // Interprete the Prescaling factors part of the report
    142 //
    143 Bool_t MReportTrigger::InterpretePrescFact(TString &str)
    144 {
    145 
    146   return kTRUE;
    147 }
     313
     314  *fLog << warn << "IPR ok!" <<endl;
     315  return kTRUE;
     316}
     317
    148318
    149319// --------------------------------------------------------------------------
     
    172342      return kCONTINUE;
    173343
    174 
    175     /*
    176     const char *pos = str.Data();
    177 
    178     const Char_t pro[4] = {pos[0],pos[1],pos[2],pos[3]};
    179     *fLog << warn << pro[0] <<" " <<pro[1] <<" " <<pro[2] <<" " <<pro[3]<<endl;
    180    
    181     Int_t len, n;
    182     Float_t dummy;
    183     */
    184 
    185344    // Read L1 and L2 table name (2 fields)
     345    if (!InterpreteL1L2Table(str))
     346      return kCONTINUE;   
    186347
    187348    // Read prescaling factors  (2x8 fields)
     
    190351   
    191352    // Read livetime and deadtime (5x4 fields)
     353    if (!InterpreteLiveTime(str))
     354      return kCONTINUE;
    192355
    193356    // Read L2 outout bit rates
     
    196359
    197360    // Read global rates (before and after prescaling)
     361    Int_t len, n;
     362    n = sscanf(str.Data(), " %f %f %n", &fL2BeforePrescaler, &fL2AfterPrescaler, &len);
     363    if (n!=2)
     364    {
     365         *fLog << warn << "WARNING - Couldn't read Trigger rates." << endl;
     366        return kFALSE;
     367    }
     368    str.Remove(0,len);
     369    str.Strip(TString::kBoth);
    198370
    199371    // Read 18 dummy fields
     372    if (!InterpreteDummy(str))
     373      return kCONTINUE;
    200374
    201375    // Read IPR
    202     if (!InterpreteBit(str))
     376    if (!InterpreteIPR(str))
    203377      return kCONTINUE;
    204378
     
    226400    // Read Individual pixel rates
    227401    pos = str.Data();
    228     end = str.Data() + 344;
    229 
     402     end = str.Data() + 344;
     403 
    230404    Int_t i=0;
    231405    while (pos < end)
     
    243417                           */
    244418
    245     Int_t len=1;
    246419    str.Remove(0,len);
    247420    str.Strip(TString::kBoth);
  • trunk/MagicSoft/Mars/mtemp/mpisa/classes/MReportTrigger.h

    r4185 r4195  
    3737  Bool_t InterpreteBit(TString &str);
    3838  Bool_t InterpretePrescFact(TString &str);
     39  Bool_t InterpreteLiveTime(TString &str);
     40  Bool_t InterpreteDummy(TString &str);
     41  Bool_t InterpreteL1L2Table(TString &str);
    3942
    4043  Int_t InterpreteBody(TString &str);
  • trunk/MagicSoft/Mars/mtemp/mpisa/classes/mtrigger/MTriggerBit.h

    r4185 r4195  
    99#endif
    1010
    11 #ifndef ROOT_TArrayL
    12 #include <TArrayL.h>
     11#ifndef ROOT_TArrayF
     12#include <TArrayF.h>
    1313#endif
    1414
     
    2020    Byte_t  fStatus;        // Monitor of the L2T status
    2121   
    22     static const Int_t gsNBits=16;        // number of output bits
     22    static const Int_t gsNBits=20;        // number of output bits
    2323
    24     TArrayL fBit; // Array with the prescaling factors
     24    TArrayF fBit; // Array with the output bit rates
    2525
    2626public:
Note: See TracChangeset for help on using the changeset viewer.