QwAnalysis
QwScaler Class Reference

#include <QwScaler.h>

+ Inheritance diagram for QwScaler:
+ Collaboration diagram for QwScaler:

Public Member Functions

 QwScaler (const TString &name)
 Constructor with name. More...
 
 QwScaler (const QwScaler &source)
 Copy constructor. More...
 
virtual ~QwScaler ()
 Destructor. More...
 
void ProcessOptions (QwOptions &options)
 Process the command line options. More...
 
Int_t LoadChannelMap (TString mapfile)
 
Int_t LoadInputParameters (TString pedestalfile)
 Mandatory parameter file definition. More...
 
void ClearEventData ()
 
Int_t ProcessConfigurationBuffer (const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words)
 
Int_t ProcessEvBuffer (const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words)
 
void ProcessEvent ()
 
void ConstructHistograms (TDirectory *folder, TString &prefix)
 Construct the histograms for this subsystem in a folder with a prefix. More...
 
void FillHistograms ()
 Fill the histograms for this subsystem. More...
 
void ConstructBranchAndVector (TTree *tree, TString &prefix, std::vector< Double_t > &values)
 Construct the branch and tree vector. More...
 
void ConstructBranch (TTree *tree, TString &prefix)
 Construct the branch and tree vector. More...
 
void ConstructBranch (TTree *tree, TString &prefix, QwParameterFile &trim_file)
 Construct the branch and tree vector based on the trim file. More...
 
void FillTreeVector (std::vector< Double_t > &values) const
 Fill the tree vector. More...
 
Bool_t Compare (VQwSubsystem *source)
 
VQwSubsystemoperator= (VQwSubsystem *value)
 
VQwSubsystemoperator+= (VQwSubsystem *value)
 
VQwSubsystemoperator-= (VQwSubsystem *value)
 
void Sum (VQwSubsystem *value1, VQwSubsystem *value2)
 
void Difference (VQwSubsystem *value1, VQwSubsystem *value2)
 
void Ratio (VQwSubsystem *value1, VQwSubsystem *value2)
 
void Scale (Double_t factor)
 
void AccumulateRunningSum (VQwSubsystem *value)
 
void DeaccumulateRunningSum (VQwSubsystem *value)
 remove one entry from the running sums for devices More...
 
void CalculateRunningAverage ()
 
Int_t LoadEventCuts (TString filename)
 Load the event cuts file. More...
 
Bool_t SingleEventCuts ()
 
Bool_t ApplySingleEventCuts ()
 Apply the single event cuts. More...
 
void IncrementErrorCounters ()
 Increment the error counters. More...
 
void PrintErrorCounters () const
 Report the number of events failed due to HW and event cut failures. More...
 
UInt_t GetEventcutErrorFlag ()
 Return the error flag to the top level routines related to stability checks and ErrorFlag updates. More...
 
void UpdateErrorFlag (const VQwSubsystem *ev_error)
 update the error flag in the subsystem level from the top level routines related to stability checks. This will uniquely update the errorflag at each channel based on the error flag in the corresponding channel in the ev_error subsystem More...
 
void PrintValue () const
 
void PrintInfo () const
 
Double_t * GetRawChannelArray ()
 
Double_t GetDataForChannelInModule (Int_t modnum, Int_t channum)
 
Int_t GetChannelIndex (TString channelName, UInt_t module_number)
 
- Public Member Functions inherited from VQwSubsystemParity
 VQwSubsystemParity (const TString &name)
 Constructor with name. More...
 
 VQwSubsystemParity (const VQwSubsystemParity &source)
 Copy constructor. More...
 
virtual ~VQwSubsystemParity ()
 Default destructor. More...
 
virtual void FillDB_MPS (QwParityDB *db, TString type)
 Fill the database with MPS-based variables Note that most subsystems don't need to do this. More...
 
virtual void FillDB (QwParityDB *db, TString type)
 Fill the database. More...
 
virtual void FillErrDB (QwParityDB *db, TString type)
 
virtual UInt_t UpdateErrorFlag ()
 Uses the error flags of contained data elements to update Returns the error flag to the top level routines related to stability checks and ErrorFlag updates. More...
 
virtual void Blind (const QwBlinder *blinder)
 Blind the asymmetry of this subsystem. More...
 
virtual void Blind (const QwBlinder *blinder, const VQwSubsystemParity *subsys)
 Blind the difference of this subsystem. More...
 
virtual void WritePromptSummary (QwPromptSummary *ps, TString type)
 
virtual Bool_t CheckForEndOfBurst () const
 
- Public Member Functions inherited from VQwSubsystem
 VQwSubsystem (const TString &name)
 Constructor with name. More...
 
 VQwSubsystem (const VQwSubsystem &orig)
 Copy constructor by object. More...
 
virtual ~VQwSubsystem ()
 Default destructor. More...
 
TString GetSubsystemName () const
 
Bool_t HasDataLoaded () const
 
void SetParent (QwSubsystemArray *parent)
 Set the parent of this subsystem to the specified array. More...
 
QwSubsystemArrayGetParent (const unsigned int parent=0) const
 Get the parent of this subsystem. More...
 
VQwSubsystemGetSibling (const std::string &name) const
 Get the sibling with specified name. More...
 
Bool_t PublishInternalValue (const TString &name, const TString &desc, const VQwHardwareChannel *value) const
 Publish a variable name to the parent subsystem array. More...
 
virtual Bool_t PublishInternalValues () const
 Publish all variables of the subsystem. More...
 
virtual Bool_t PublishByRequest (TString device_name)
 Try to publish an internal variable matching the submitted name. More...
 
Bool_t RequestExternalValue (const TString &name, VQwHardwareChannel *value) const
 Request a named value which is owned by an external subsystem; the request will be handled by the parent subsystem array. More...
 
virtual const VQwHardwareChannelReturnInternalValue (const TString &name) const
 Return a pointer to a varialbe to the parent subsystem array to be delivered to a different subsystem. More...
 
virtual Bool_t ReturnInternalValue (const TString &name, VQwHardwareChannel *value) const
 Return a named value to the parent subsystem array to be delivered to a different subsystem. More...
 
virtual std::vector< TString > GetParamFileNameList ()
 
virtual std::map< TString,
TString > 
GetDetectorMaps ()
 
virtual Int_t LoadDetectorMaps (QwParameterFile &file)
 Parse parameter file to find the map files. More...
 
virtual Int_t LoadGeometryDefinition (TString mapfile)
 Optional geometry definition. More...
 
virtual Int_t LoadCrosstalkDefinition (TString mapfile)
 Optional crosstalk definition. More...
 
void SetEventTypeMask (const UInt_t mask)
 Set event type mask. More...
 
UInt_t GetEventTypeMask () const
 Get event type mask. More...
 
virtual Int_t ProcessEvBuffer (const UInt_t event_type, const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words)
 
virtual void ExchangeProcessedData ()
 Request processed data from other subsystems for internal use in the second event processing stage. Not all derived classes will require data from other subsystems. More...
 
virtual void ProcessEvent_2 ()
 Process the event data again, including data from other subsystems. Not all derived classes will require a second stage of event data processing. More...
 
virtual void AtEndOfEventLoop ()
 Perform actions at the end of the event loop. More...
 
virtual void RandomizeEventData (int helicity=0, double time=0.0)
 
virtual void EncodeEventData (std::vector< UInt_t > &buffer)
 
virtual void PrintDetectorMaps (Bool_t status) const
 
virtual void ConstructHistograms ()
 Construct the histograms for this subsystem. More...
 
virtual void ConstructHistograms (TDirectory *folder)
 Construct the histograms for this subsystem in a folder. More...
 
virtual void ConstructHistograms (TString &prefix)
 Construct the histograms for this subsystem with a prefix. More...
 
virtual void ConstructBranchAndVector (TTree *tree, std::vector< Double_t > &values)
 Construct the branch and tree vector. More...
 
virtual void ConstructTree ()
 Construct the tree for this subsystem. More...
 
virtual void ConstructTree (TDirectory *folder)
 Construct the tree for this subsystem in a folder. More...
 
virtual void ConstructTree (TString &prefix)
 Construct the tree for this subsystem with a prefix. More...
 
virtual void ConstructTree (TDirectory *folder, TString &prefix)
 Construct the tree for this subsystem in a folder with a prefix. More...
 
virtual void FillTree ()
 Fill the tree for this subsystem. More...
 
virtual void DeleteTree ()
 Delete the tree for this subsystem. More...
 
- Public Member Functions inherited from MQwHistograms
void ShareHistograms (const MQwHistograms *source)
 Share histogram pointers between objects. More...
 
- Public Member Functions inherited from MQwCloneable< VQwSubsystem, QwScaler >
virtual ~MQwCloneable ()
 Virtual destructor. More...
 
virtual VQwSubsystemClone () const
 Concrete clone method. More...
 
const VQwFactory< VQwSubsystem > * Factory () const
 Factory getter. More...
 
- Public Member Functions inherited from VQwCloneable< VQwSubsystem >
virtual ~VQwCloneable ()
 Virtual destructor. More...
 
std::string GetClassName () const
 Get demangled name of this class. More...
 

Static Public Member Functions

static void DefineOptions (QwOptions &options)
 
- Static Public Member Functions inherited from VQwSubsystem
static void DefineOptions ()
 Define options function (note: no virtual static functions in C++) More...
 
- Static Public Member Functions inherited from MQwCloneable< VQwSubsystem, QwScaler >
static VQwSubsystemCreate (const std::string &name)
 Object creation. More...
 
static QwScalerCast (QwScaler *type)
 Object dynamic cast. More...
 

Private Types

typedef std::map< Int_t,
std::vector< std::vector
< Int_t > > > 
Subbank_to_Scaler_Map_t
 
typedef std::map< std::pair
< Int_t, Int_t >, Int_t > 
Module_Channel_to_Scaler_Map_t
 
typedef std::map< TString, Int_t > Name_to_Scaler_Map_t
 

Private Member Functions

 QwScaler ()
 Private default constructor (not implemented, will throw linker error on use) More...
 

Private Attributes

Int_t fGoodEventCount
 
Subbank_to_Scaler_Map_t fSubbank_Map
 
Module_Channel_to_Scaler_Map_t fModuleChannel_Map
 
Name_to_Scaler_Map_t fName_Map
 
std::vector< VQwScaler_Channel * > fScaler
 
std::vector< UInt_t > fBufferOffset
 
std::vector< std::pair
< VQwScaler_Channel *, double > > 
fNorm
 

Additional Inherited Members

- Protected Member Functions inherited from VQwSubsystem
void UpdatePublishedValue (const TString &name, VQwHardwareChannel *data_channel)
 
void ClearAllBankRegistrations ()
 Clear all registration of ROC and Bank IDs for this subsystem. More...
 
virtual Int_t RegisterROCNumber (const UInt_t roc_id, const UInt_t bank_id=0)
 Tell the object that it will decode data from this ROC and sub-bank. More...
 
Int_t RegisterSubbank (const UInt_t bank_id)
 Tell the object that it will decode data from this sub-bank in the ROC currently open for registration. More...
 
Int_t GetSubbankIndex () const
 
Int_t GetSubbankIndex (const UInt_t roc_id, const UInt_t bank_id) const
 
void SetDataLoaded (Bool_t flag)
 
Int_t FindIndex (const std::vector< UInt_t > &myvec, const UInt_t value) const
 
Bool_t Compare (VQwSubsystem *source)
 
- Protected Member Functions inherited from MQwHistograms
 MQwHistograms ()
 Default constructor. More...
 
 MQwHistograms (const MQwHistograms &source)
 Copy constructor. More...
 
virtual ~MQwHistograms ()
 Virtual destructor. More...
 
virtual MQwHistogramsoperator= (const MQwHistograms &value)
 
void Fill_Pointer (TH1_ptr hist_ptr, Double_t value)
 
void AddHistogram (TH1 *h)
 Register a histogram. More...
 
- Protected Attributes inherited from VQwSubsystem
std::map< TString,
VQwHardwareChannel * > 
fPublishedInternalValues
 Map of published internal values. More...
 
std::vector< std::vector
< TString > > 
fPublishList
 List of parameters to be published (loaded at the channel map) More...
 
TString fSystemName
 Name of this subsystem. More...
 
UInt_t fEventTypeMask
 Mask of event types. More...
 
Bool_t fIsDataLoaded
 Has this subsystem gotten data to be processed? More...
 
std::vector< TString > fDetectorMapsNames
 
std::map< TString, TString > fDetectorMaps
 
Int_t fCurrentROC_ID
 ROC ID that is currently being processed. More...
 
Int_t fCurrentBank_ID
 Bank ID that is currently being processed. More...
 
std::vector< UInt_t > fROC_IDs
 Vector of ROC IDs associated with this subsystem. More...
 
std::vector< std::vector
< UInt_t > > 
fBank_IDs
 Vector of Bank IDs per ROC ID associated with this subsystem. More...
 
std::vector< QwSubsystemArray * > fArrays
 Vector of pointers to subsystem arrays that contain this subsystem. More...
 
- Protected Attributes inherited from MQwHistograms
std::vector< TH1_ptrfHistograms
 Histograms associated with this data element. More...
 

Detailed Description

Definition at line 16 of file QwScaler.h.

Member Typedef Documentation

typedef std::map< std::pair<Int_t,Int_t>, Int_t > QwScaler::Module_Channel_to_Scaler_Map_t
private

Definition at line 117 of file QwScaler.h.

typedef std::map< TString, Int_t> QwScaler::Name_to_Scaler_Map_t
private

Definition at line 121 of file QwScaler.h.

typedef std::map< Int_t, std::vector< std::vector<Int_t> > > QwScaler::Subbank_to_Scaler_Map_t
private

Definition at line 113 of file QwScaler.h.

Constructor & Destructor Documentation

QwScaler::QwScaler ( )
private

Private default constructor (not implemented, will throw linker error on use)

QwScaler::QwScaler ( const TString &  name)

Constructor with name.

Constructor

Definition at line 29 of file QwScaler.cc.

30 : VQwSubsystem(name),VQwSubsystemParity(name)
31 {
32  // Nothing, really
33 }
VQwSubsystemParity()
Private default constructor (not implemented, will throw linker error on use)
QwScaler::QwScaler ( const QwScaler source)
inline

Copy constructor.

Definition at line 27 of file QwScaler.h.

References fScaler.

28  : VQwSubsystem(source),VQwSubsystemParity(source)
29  {
30  fScaler.resize(source.fScaler.size());
31  for (size_t i = 0; i < fScaler.size(); i++) {
32  VQwScaler_Channel* scaler_tmp = 0;
33  if ((scaler_tmp = dynamic_cast<QwSIS3801D24_Channel*>(source.fScaler.at(i)))) {
34  QwSIS3801D24_Channel* scaler = dynamic_cast<QwSIS3801D24_Channel*>(source.fScaler.at(i));
35  fScaler.at(i) = new QwSIS3801D24_Channel(*scaler);
36  } else if ((scaler_tmp = dynamic_cast<QwSIS3801D32_Channel*>(source.fScaler.at(i)))) {
37  QwSIS3801D32_Channel* scaler = dynamic_cast<QwSIS3801D32_Channel*>(source.fScaler.at(i));
38  fScaler.at(i) = new QwSIS3801D32_Channel(*scaler);
39  }
40  }
41  }
class QwScaler_Channel< 0xffffffff, 0 > QwSIS3801D32_Channel
class QwScaler_Channel< 0x00ffffff, 0 > QwSIS3801D24_Channel
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
VQwSubsystemParity()
Private default constructor (not implemented, will throw linker error on use)
QwScaler::~QwScaler ( )
virtual

Destructor.

Destructor

Delete histograms and clean up scaler channel objects

Definition at line 40 of file QwScaler.cc.

References fScaler.

41 {
42  // Delete scalers
43  for (size_t i = 0; i < fScaler.size(); i++) {
44  delete fScaler.at(i);
45  }
46  fScaler.clear();
47 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

Member Function Documentation

void QwScaler::AccumulateRunningSum ( VQwSubsystem value)
virtual

Accumulate the running sum

Implements VQwSubsystemParity.

Definition at line 473 of file QwScaler.cc.

References Compare(), and fGoodEventCount.

474 {
475  if (Compare(value)) {
476  fGoodEventCount++;
477  *this += value;
478  }
479 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527
Int_t fGoodEventCount
Definition: QwScaler.h:110

+ Here is the call graph for this function:

Bool_t QwScaler::ApplySingleEventCuts ( )
virtual

Apply the single event cuts.

Implements VQwSubsystemParity.

Definition at line 498 of file QwScaler.cc.

499 {
500  return true;
501 }
void QwScaler::CalculateRunningAverage ( )
virtual

Normalize the running sum

Implements VQwSubsystemParity.

Definition at line 484 of file QwScaler.cc.

References fGoodEventCount, and Scale().

485 {
486  if (fGoodEventCount <= 0) {
487  Scale(0);
488  } else {
489  Scale(1.0/fGoodEventCount);
490  }
491 }
Int_t fGoodEventCount
Definition: QwScaler.h:110
void Scale(Double_t factor)
Definition: QwScaler.cc:463

+ Here is the call graph for this function:

void QwScaler::ClearEventData ( )
virtual

Clear the event data in this subsystem

Implements VQwSubsystem.

Definition at line 260 of file QwScaler.cc.

References fGoodEventCount, and fScaler.

261 {
262  // Clear all scaler channels
263  for (size_t i = 0; i < fScaler.size(); i++) {
264  fScaler.at(i)->ClearEventData();
265  }
266  // Reset good event count
267  fGoodEventCount = 0;
268 }
Int_t fGoodEventCount
Definition: QwScaler.h:110
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
Bool_t QwScaler::Compare ( VQwSubsystem value)

Compare two scaler objects

Parameters
valueObject to compare with
Returns
kTRUE if the object is equal

Definition at line 527 of file QwScaler.cc.

References fScaler.

Referenced by AccumulateRunningSum(), Difference(), operator+=(), operator-=(), operator=(), Ratio(), and Sum().

528 {
529  // Immediately fail on null objects
530  if (value == 0) return kFALSE;
531 
532  // Continue testing on actual object
533  Bool_t result = kTRUE;
534  if (typeid(*value) != typeid(*this)) {
535  result = kFALSE;
536 
537  } else {
538  QwScaler* input = dynamic_cast<QwScaler*> (value);
539  if (input->fScaler.size() != fScaler.size()) {
540  result = kFALSE;
541  }
542  }
543  return result;
544 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the caller graph for this function:

void QwScaler::ConstructBranch ( TTree *  tree,
TString &  prefix 
)
inlinevirtual

Construct the branch and tree vector.

Implements VQwSubsystem.

Definition at line 64 of file QwScaler.h.

64 { };
void QwScaler::ConstructBranch ( TTree *  tree,
TString &  prefix,
QwParameterFile trim_file 
)
inlinevirtual

Construct the branch and tree vector based on the trim file.

Implements VQwSubsystem.

Definition at line 65 of file QwScaler.h.

65 { };
void QwScaler::ConstructBranchAndVector ( TTree *  tree,
TString &  prefix,
std::vector< Double_t > &  values 
)
virtual

Construct the branch and tree vector.

Implements VQwSubsystem.

Definition at line 354 of file QwScaler.cc.

References fScaler.

355 {
356  for (size_t i = 0; i < fScaler.size(); i++) {
357  fScaler.at(i)->ConstructBranchAndVector(tree, prefix, values);
358  }
359 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
void QwScaler::ConstructHistograms ( TDirectory *  folder,
TString &  prefix 
)
virtual

Construct the histograms for this subsystem in a folder with a prefix.

Implements VQwSubsystem.

Definition at line 340 of file QwScaler.cc.

References fScaler.

341 {
342  for(size_t i = 0; i < fScaler.size(); i++) {
343  fScaler.at(i)->ConstructHistograms(folder, prefix);
344  }
345 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
void QwScaler::DeaccumulateRunningSum ( VQwSubsystem value)
inlinevirtual

remove one entry from the running sums for devices

Implements VQwSubsystemParity.

Definition at line 80 of file QwScaler.h.

80  {
81  };
void QwScaler::DefineOptions ( QwOptions options)
static

Definition at line 15 of file QwScaler.cc.

16 {
17  // Define command line options
18 }
void QwScaler::Difference ( VQwSubsystem value1,
VQwSubsystem value2 
)
virtual

Difference

Parameters
value1First value
value2Second value

Implements VQwSubsystemParity.

Definition at line 435 of file QwScaler.cc.

References Compare().

436 {
437  if (Compare(value1) && Compare(value2)) {
438  *this = value1;
439  *this -= value2;
440  }
441 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527

+ Here is the call graph for this function:

void QwScaler::FillHistograms ( )
virtual

Fill the histograms for this subsystem.

Implements VQwSubsystem.

Definition at line 347 of file QwScaler.cc.

References fScaler.

348 {
349  for(size_t i = 0; i < fScaler.size(); i++) {
350  fScaler.at(i)->FillHistograms();
351  }
352 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
void QwScaler::FillTreeVector ( std::vector< Double_t > &  values) const
virtual

Fill the tree vector.

Implements VQwSubsystem.

Definition at line 361 of file QwScaler.cc.

References fScaler.

362 {
363  for(size_t i = 0; i < fScaler.size(); i++) {
364  fScaler.at(i)->FillTreeVector(values);
365  }
366 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
Int_t QwScaler::GetChannelIndex ( TString  channelName,
UInt_t  module_number 
)

Definition at line 516 of file QwScaler.cc.

517 {
518  return 0;
519 }
Double_t QwScaler::GetDataForChannelInModule ( Int_t  modnum,
Int_t  channum 
)
inline

Definition at line 100 of file QwScaler.h.

References fModuleChannel_Map, and fScaler.

100  {
101  Int_t index = fModuleChannel_Map[std::pair<Int_t,Int_t>(modnum,channum)];
102  return fScaler.at(index)->GetValue();
103  }
Module_Channel_to_Scaler_Map_t fModuleChannel_Map
Definition: QwScaler.h:118
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
UInt_t QwScaler::GetEventcutErrorFlag ( )
virtual

Return the error flag to the top level routines related to stability checks and ErrorFlag updates.

Implements VQwSubsystemParity.

Definition at line 511 of file QwScaler.cc.

512 {
513  return 0;
514 }
Double_t* QwScaler::GetRawChannelArray ( )
void QwScaler::IncrementErrorCounters ( )
virtual

Increment the error counters.

Implements VQwSubsystemParity.

Definition at line 503 of file QwScaler.cc.

504 {
505 }
Int_t QwScaler::LoadChannelMap ( TString  mapfile)
virtual

Load the channel map

Parameters
mapfileMap file
Returns
Zero if successful

Implements VQwSubsystem.

Definition at line 55 of file QwScaler.cc.

References QwLog::endl(), fBufferOffset, VQwSubsystem::fDetectorMaps, fModuleChannel_Map, fName_Map, fNorm, fScaler, fSubbank_Map, VQwSubsystem::GetSubbankIndex(), QwParameterFile::GetUInt(), QwError, QwMessage, QwVerbose, VQwSubsystem::RegisterROCNumber(), VQwSubsystem::RegisterSubbank(), and VQwScaler_Channel::SetDifferentialScaler().

56 {
57  Int_t current_roc_id = -1; // current ROC id
58  Int_t current_bank_id = -1; // current bank id
59 
60  // Normalization channel (register default token "1")
61  const TString default_norm_channel = "1";
62  fName_Map[default_norm_channel] = -1;
63  Name_to_Scaler_Map_t::iterator current_norm_channel = fName_Map.find(default_norm_channel);
64  double current_norm_factor = 1;
65  // Map with normalizations
66  std::vector<Name_to_Scaler_Map_t::iterator> norm_channel;
67  std::vector<double> norm_factor;
68 
69  // Include header for this scaler bank
70  UInt_t header = 1;
71 
72  // By default the scalers are not differential
73  Bool_t differential = false;
74 
75  // Open the file
76  QwParameterFile mapstr(mapfile.Data());
77  fDetectorMaps.insert(mapstr.GetParamFileNameContents());
78  while (mapstr.ReadNextLine()) {
79  mapstr.TrimComment(); // Remove everything after a comment character.
80  mapstr.TrimWhitespace(); // Get rid of leading and trailing whitespace
81  if (mapstr.LineIsEmpty()) continue;
82 
83  TString varname, varvalue;
84  if (mapstr.HasVariablePair("=", varname, varvalue)) {
85  // This is a declaration line. Decode it.
86  varname.ToLower();
87  UInt_t value = QwParameterFile::GetUInt(varvalue);
88  if (varname == "roc") {
89  current_roc_id = value;
90  RegisterROCNumber(current_roc_id,0);
91  } else if (varname == "bank") {
92  current_bank_id = value;
93  RegisterSubbank(current_bank_id);
94  } else if (varname == "norm") {
95  // Normalization line of format: norm = [ 1 | channel / factor ]
96  string dummy = mapstr.GetNextToken("=");
97  string channame = mapstr.GetNextToken("/");
98  string channorm = mapstr.GetNextToken("/");
99  if (fName_Map.count(channame) == 0) {
100  // assign a temporarily pointer
101  fName_Map[channame] = -1;
102  }
103  current_norm_channel = fName_Map.find(channame);
104  try {
105  current_norm_factor = lexical_cast<double>(channorm);
106  } catch (boost::bad_lexical_cast&) {
107  current_norm_factor = 1;
108  }
109  QwMessage << "Normalization channel: " << channame << QwLog::endl;
110  QwMessage << "Normalization factor: " << current_norm_factor << QwLog::endl;
111  } else if (varname == "header") {
112  // Header for this block of channels
113  header = value;
114  QwMessage << "Number of scaler header words: " << header << QwLog::endl;
115  if (header > 32)
116  QwError << "Is that really what you want?" << QwLog::endl;
117  } else if (varname == "differential") {
118  // Differential scaler
119  try {
120  differential = lexical_cast<bool>(varvalue);
121  } catch (boost::bad_lexical_cast&) {
122  differential = false;
123  }
124  if (differential)
125  QwMessage << "Subsequent scalers will be differential." << QwLog::endl;
126  else
127  QwMessage << "Subsequent scalers will not be differential." << QwLog::endl;
128  }
129 
130  } else {
131 
132  // Break this line into tokens to process it.
133  TString modtype = mapstr.GetTypedNextToken<TString>();
134  UInt_t modnum = mapstr.GetTypedNextToken<UInt_t>();
135  UInt_t channum = mapstr.GetTypedNextToken<UInt_t>();
136  TString dettype = mapstr.GetTypedNextToken<TString>();
137  TString keyword = mapstr.GetTypedNextToken<TString>();
138  modtype.ToUpper();
139  dettype.ToUpper();
140 
141  UInt_t offset = 0;
142  if (modtype == "SIS3801" || modtype == "SIS3801D24" || modtype == "SIS3801D32") {
143  offset = QwSIS3801D24_Channel::GetBufferOffset(modnum, channum, header);
144  } else if (modtype == "STR7200") {
145  offset = QwSIS3801D32_Channel::GetBufferOffset(modnum, channum, header);
146  } else {
147  QwError << "Unrecognized module type " << modtype << QwLog::endl;
148  continue;
149  }
150 
151  // Register data channel type
152  Int_t subbank = GetSubbankIndex(current_roc_id,current_bank_id);
153  if (modnum >= fSubbank_Map[subbank].size())
154  fSubbank_Map[subbank].resize(modnum+1);
155  if (channum >= fSubbank_Map[subbank].at(modnum).size())
156  fSubbank_Map[subbank].at(modnum).resize(channum+1,-1);
157  // Add scaler channel
158  if (fSubbank_Map[subbank].at(modnum).at(channum) < 0) {
159  QwVerbose << "Registering " << modtype << " " << keyword
160  << std::hex
161  << " in ROC 0x" << current_roc_id << ", bank 0x" << current_bank_id
162  << std::dec
163  << " at mod " << modnum << ", chan " << channum
164  << QwLog::endl;
165  size_t index = fScaler.size();
166  VQwScaler_Channel* scaler = 0;
167  if (modtype == "SIS3801" || modtype == "SIS3801D24")
168  scaler = new QwSIS3801D24_Channel(keyword);
169  else if (modtype == "SIS3801D32")
170  scaler = new QwSIS3801D32_Channel(keyword);
171  else if (modtype == "STR7200")
172  scaler = new QwSTR7200_Channel(keyword);
173  else {
174  QwError << "Unrecognized module type " << modtype << QwLog::endl;
175  continue;
176  }
177 
178  // Differential scaler
179  scaler->SetDifferentialScaler(differential);
180 
181  // Register keyword to scaler channel
182  fName_Map[keyword] = index;
183  fSubbank_Map[subbank].at(modnum).at(channum) = index;
184  fModuleChannel_Map[std::pair<Int_t,Int_t>(modnum,channum)] = index;
185  // Store scaler
186  fScaler.push_back(scaler);
187  fNorm.push_back(std::pair<VQwScaler_Channel*,double>((VQwScaler_Channel*)0,1));
188  fBufferOffset.push_back(offset);
189  // Store current normalization
190  norm_channel.push_back(current_norm_channel);
191  norm_factor.push_back(current_norm_factor);
192  }
193  }
194  }
195 
196  // Check for normalization names without actual channels
197  for (Name_to_Scaler_Map_t::iterator iter = fName_Map.begin(); iter != fName_Map.end(); iter++) {
198  if (iter->second == -1 && iter->first != default_norm_channel) {
199  QwError << "Normalization channel " << iter->first << " not found!" << QwLog::endl;
200  }
201  }
202 
203  // Fill normalization structure
204  fNorm.resize(fScaler.size());
205  for (size_t i = 0; i < fScaler.size(); i++) {
206  Int_t norm_index = norm_channel.at(i)->second;
207  if (norm_index < 0) {
208  // No normalization
209  fNorm.at(i).first = 0;
210  fNorm.at(i).second = 1;
211  } else {
212  // Normalization
213  fNorm.at(i).first = fScaler.at(norm_index);
214  fNorm.at(i).second = norm_factor.at(i);
215  // Prevent corruption of normalization channel itself
216  fNorm.at(norm_index).first = 0;
217  fNorm.at(norm_index).second = 1;
218  }
219  }
220 
221  mapstr.Close(); // Close the file (ifstream)
222  return 0;
223 }
Int_t GetSubbankIndex() const
Definition: VQwSubsystem.h:303
#define QwMessage
Predefined log drain for regular messages.
Definition: QwLog.h:50
std::map< TString, TString > fDetectorMaps
Definition: VQwSubsystem.h:322
static UInt_t GetUInt(const TString &varvalue)
std::vector< std::pair< VQwScaler_Channel *, double > > fNorm
Definition: QwScaler.h:127
#define QwVerbose
Predefined log drain for verbose messages.
Definition: QwLog.h:55
class QwScaler_Channel< 0xffffffff, 0 > QwSTR7200_Channel
Module_Channel_to_Scaler_Map_t fModuleChannel_Map
Definition: QwScaler.h:118
Name_to_Scaler_Map_t fName_Map
Definition: QwScaler.h:122
virtual void SetDifferentialScaler(Bool_t diff)
Subbank_to_Scaler_Map_t fSubbank_Map
Definition: QwScaler.h:114
class QwScaler_Channel< 0xffffffff, 0 > QwSIS3801D32_Channel
std::vector< UInt_t > fBufferOffset
Definition: QwScaler.h:126
class QwScaler_Channel< 0x00ffffff, 0 > QwSIS3801D24_Channel
Int_t RegisterSubbank(const UInt_t bank_id)
Tell the object that it will decode data from this sub-bank in the ROC currently open for registratio...
virtual Int_t RegisterROCNumber(const UInt_t roc_id, const UInt_t bank_id=0)
Tell the object that it will decode data from this ROC and sub-bank.
static std::ostream & endl(std::ostream &)
End of the line.
Definition: QwLog.cc:299
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
#define QwError
Predefined log drain for errors.
Definition: QwLog.h:40

+ Here is the call graph for this function:

Int_t QwScaler::LoadEventCuts ( TString  filename)
virtual

Load the event cuts file.

Implements VQwSubsystemParity.

Definition at line 493 of file QwScaler.cc.

494 {
495  return 0;
496 }
Int_t QwScaler::LoadInputParameters ( TString  mapfile)
virtual

Mandatory parameter file definition.

Implements VQwSubsystem.

Definition at line 225 of file QwScaler.cc.

References QwLog::endl(), VQwSubsystem::fDetectorMaps, fName_Map, fScaler, QwMessage, and QwVerbose.

226 {
227  // Open the file
228  QwParameterFile mapstr(mapfile.Data());
229  fDetectorMaps.insert(mapstr.GetParamFileNameContents());
230  while (mapstr.ReadNextLine()) {
231  mapstr.TrimComment(); // Remove everything after a comment character
232  mapstr.TrimWhitespace(); // Get rid of leading and trailing spaces
233  if (mapstr.LineIsEmpty()) continue;
234 
235  TString varname = mapstr.GetTypedNextToken<TString>(); // name of the channel
236  varname.ToLower();
237  varname.Remove(TString::kBoth,' ');
238  Double_t varped = mapstr.GetTypedNextToken<Double_t>(); // value of the pedestal
239  Double_t varcal = mapstr.GetTypedNextToken<Double_t>(); // value of the calibration factor
240  QwVerbose << varname << ": " << QwLog::endl;
241 
242  if (fName_Map.count(varname) != 0) {
243  Int_t index = fName_Map[varname];
244  QwMessage << "Parameters scaler channel " << varname << ": "
245  << "ped = " << varped << ", "
246  << "cal = " << varcal << QwLog::endl;
247  fScaler[index]->SetPedestal(varped);
248  fScaler[index]->SetCalibrationFactor(varcal);
249  }
250 
251  } // end of loop reading all lines of the pedestal file
252 
253  mapstr.Close(); // Close the file (ifstream)
254  return 0;
255 }
#define QwMessage
Predefined log drain for regular messages.
Definition: QwLog.h:50
std::map< TString, TString > fDetectorMaps
Definition: VQwSubsystem.h:322
#define QwVerbose
Predefined log drain for verbose messages.
Definition: QwLog.h:55
Name_to_Scaler_Map_t fName_Map
Definition: QwScaler.h:122
static std::ostream & endl(std::ostream &)
End of the line.
Definition: QwLog.cc:299
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

VQwSubsystem & QwScaler::operator+= ( VQwSubsystem value)
virtual

Addition-assignment operator

Parameters
valueRight-hand side
Returns
Left-hand side

Implements VQwSubsystemParity.

Definition at line 390 of file QwScaler.cc.

References Compare(), and fScaler.

391 {
392  if (Compare(value)) {
393  QwScaler* input = dynamic_cast<QwScaler*>(value);
394  for (size_t i = 0; i < fScaler.size(); i++) {
395  *(fScaler.at(i)) += *(input->fScaler.at(i));
396  }
397  }
398  return *this;
399 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

VQwSubsystem & QwScaler::operator-= ( VQwSubsystem value)
virtual

Subtraction-assignment operator

Parameters
valueRight-hand side
Returns
Left-hand side

Implements VQwSubsystemParity.

Definition at line 406 of file QwScaler.cc.

References Compare(), and fScaler.

407 {
408  if (Compare(value)) {
409  QwScaler* input = dynamic_cast<QwScaler *> (value);
410  for (size_t i = 0; i < fScaler.size(); i++) {
411  *(fScaler.at(i)) -= *(input->fScaler.at(i));
412  }
413  }
414  return *this;
415 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

VQwSubsystem & QwScaler::operator= ( VQwSubsystem value)
virtual

Assignment operator

Parameters
valueRight-hand side
Returns
Left-hand side

Implements VQwSubsystemParity.

Definition at line 373 of file QwScaler.cc.

References Compare(), fScaler, and VQwSubsystem::operator=().

374 {
375  if (Compare(value)) {
377  QwScaler* input = dynamic_cast<QwScaler*>(value);
378  for (size_t i = 0; i < fScaler.size(); i++) {
379  *(fScaler.at(i)) = *(input->fScaler.at(i));
380  }
381  }
382  return *this;
383 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527
virtual VQwSubsystem & operator=(VQwSubsystem *value)
Assignment Note: Must be called at the beginning of all subsystems routine call to operator=(VQwSubsy...
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

void QwScaler::PrintErrorCounters ( ) const
virtual

Report the number of events failed due to HW and event cut failures.

Implements VQwSubsystemParity.

Definition at line 507 of file QwScaler.cc.

508 {
509 }
void QwScaler::PrintInfo ( ) const
virtual

Print some debugging output for the subcomponents

Reimplemented from VQwSubsystem.

Definition at line 549 of file QwScaler.cc.

References QwLog::endl(), fScaler, VQwSubsystem::PrintInfo(), and QwOut.

550 {
552 
553  QwOut << " there are " << fScaler.size() << " scaler channels" << QwLog::endl;
554 
555  for (size_t i = 0; i < fScaler.size(); i++) {
556  QwOut << " scaler " << i << ": ";
557  fScaler.at(i)->PrintInfo();
558  }
559 }
#define QwOut
Predefined log drain for explicit output.
Definition: QwLog.h:35
virtual void PrintInfo() const
Print some information about the subsystem.
static std::ostream & endl(std::ostream &)
End of the line.
Definition: QwLog.cc:299
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

void QwScaler::PrintValue ( ) const
virtual

Print the value for the subcomponents

Reimplemented from VQwSubsystemParity.

Definition at line 564 of file QwScaler.cc.

References fScaler.

565 {
566  for(size_t i = 0; i < fScaler.size(); i++) {
567  fScaler.at(i)->PrintValue();
568  }
569 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
Int_t QwScaler::ProcessConfigurationBuffer ( const UInt_t  roc_id,
const UInt_t  bank_id,
UInt_t *  buffer,
UInt_t  num_words 
)
virtual

Process the configuration buffer for this subsystem

Parameters
roc_idROC ID
bank_idSubbank ID
bufferBuffer to read from
num_wordsNumber of words left in buffer
Returns
Number of words read

Implements VQwSubsystem.

Definition at line 278 of file QwScaler.cc.

279 {
280  return 0;
281 }
Int_t QwScaler::ProcessEvBuffer ( const UInt_t  roc_id,
const UInt_t  bank_id,
UInt_t *  buffer,
UInt_t  num_words 
)
virtual

Process the event buffer for this subsystem

Parameters
roc_idROC ID
bank_idSubbank ID
bufferBuffer to read from
num_wordsNumber of words left in buffer
Returns
Number of words read

Implements VQwSubsystem.

Definition at line 291 of file QwScaler.cc.

References fBufferOffset, fScaler, fSubbank_Map, and VQwSubsystem::GetSubbankIndex().

292 {
293  // TODO fix :-)
294 
295  UInt_t words_read = 0;
296 
297  // Get the subbank index (or -1 when no match)
298  Int_t subbank = GetSubbankIndex(roc_id, bank_id);
299 
300  if (subbank >= 0 && num_words > 0) {
301 
302  // Read header word
303  //UInt_t num_events = buffer[words_read];
304  words_read++;
305  // TODO Multiscaler functionality
306 
307  // Read scalers
308  for (size_t modnum = 0; modnum < fSubbank_Map[subbank].size(); modnum++) {
309  for (size_t channum = 0; channum < fSubbank_Map[subbank].at(modnum).size(); channum++) {
310  Int_t index = fSubbank_Map[subbank].at(modnum).at(channum);
311  if (index >= 0) {
312  UInt_t offset = fBufferOffset.at(index);
313  words_read += fScaler[index]->ProcessEvBuffer(&(buffer[offset]), num_words - offset);
314  }
315  }
316  }
317  words_read = num_words;
318 
319  }
320 
321  return words_read;
322 }
Int_t GetSubbankIndex() const
Definition: VQwSubsystem.h:303
Subbank_to_Scaler_Map_t fSubbank_Map
Definition: QwScaler.h:114
std::vector< UInt_t > fBufferOffset
Definition: QwScaler.h:126
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

void QwScaler::ProcessEvent ( )
virtual

Implements VQwSubsystem.

Definition at line 324 of file QwScaler.cc.

References fNorm, and fScaler.

325 {
326  // Process the event
327  for (size_t i = 0; i < fScaler.size(); i++) {
328  fScaler.at(i)->ProcessEvent();
329  }
330 
331  // Normalization
332  for (size_t i = 0; i < fScaler.size(); i++) {
333  if (fNorm.at(i).first) {
334  fScaler.at(i)->Scale(fNorm.at(i).second);
335  fScaler.at(i)->DivideBy(*(fNorm.at(i).first));
336  }
337  }
338 }
std::vector< std::pair< VQwScaler_Channel *, double > > fNorm
Definition: QwScaler.h:127
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125
void QwScaler::ProcessOptions ( QwOptions options)
virtual

Process the command line options.

Reimplemented from VQwSubsystem.

Definition at line 20 of file QwScaler.cc.

21 {
22  // Handle command line options
23 }
void QwScaler::Ratio ( VQwSubsystem numer,
VQwSubsystem denom 
)
virtual

Determine the ratio of two photon detectors

Parameters
numerNumerator
denomDenominator

Implements VQwSubsystemParity.

Definition at line 448 of file QwScaler.cc.

References Compare(), and fScaler.

449 {
450  if (Compare(numer) && Compare(denom)) {
451  QwScaler* innumer = dynamic_cast<QwScaler*>(numer);
452  QwScaler* indenom = dynamic_cast<QwScaler*>(denom);
453  for (size_t i = 0; i < fScaler.size(); i++) {
454  fScaler.at(i)->Ratio(*(innumer->fScaler.at(i)), *(indenom->fScaler.at(i)));
455  }
456  }
457 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the call graph for this function:

void QwScaler::Scale ( Double_t  factor)
virtual

Scale the photon detector

Parameters
factorScale factor

Implements VQwSubsystemParity.

Definition at line 463 of file QwScaler.cc.

References fScaler.

Referenced by CalculateRunningAverage().

464 {
465  for (size_t i = 0; i < fScaler.size(); i++) {
466  fScaler.at(i)->Scale(factor);
467  }
468 }
std::vector< VQwScaler_Channel * > fScaler
Definition: QwScaler.h:125

+ Here is the caller graph for this function:

Bool_t QwScaler::SingleEventCuts ( )
void QwScaler::Sum ( VQwSubsystem value1,
VQwSubsystem value2 
)
virtual

Summation

Parameters
value1First value
value2Second value

Implements VQwSubsystemParity.

Definition at line 422 of file QwScaler.cc.

References Compare().

423 {
424  if (Compare(value1) && Compare(value2)) {
425  *this = value1;
426  *this += value2;
427  }
428 }
Bool_t Compare(VQwSubsystem *source)
Definition: QwScaler.cc:527

+ Here is the call graph for this function:

void QwScaler::UpdateErrorFlag ( const VQwSubsystem ev_error)
inlinevirtual

update the error flag in the subsystem level from the top level routines related to stability checks. This will uniquely update the errorflag at each channel based on the error flag in the corresponding channel in the ev_error subsystem

Implements VQwSubsystemParity.

Definition at line 92 of file QwScaler.h.

92  {
93  };

Field Documentation

std::vector< UInt_t > QwScaler::fBufferOffset
private

Definition at line 126 of file QwScaler.h.

Referenced by LoadChannelMap(), and ProcessEvBuffer().

Int_t QwScaler::fGoodEventCount
private

Definition at line 110 of file QwScaler.h.

Referenced by AccumulateRunningSum(), CalculateRunningAverage(), and ClearEventData().

Module_Channel_to_Scaler_Map_t QwScaler::fModuleChannel_Map
private

Definition at line 118 of file QwScaler.h.

Referenced by GetDataForChannelInModule(), and LoadChannelMap().

Name_to_Scaler_Map_t QwScaler::fName_Map
private

Definition at line 122 of file QwScaler.h.

Referenced by LoadChannelMap(), and LoadInputParameters().

std::vector< std::pair< VQwScaler_Channel*, double > > QwScaler::fNorm
private

Definition at line 127 of file QwScaler.h.

Referenced by LoadChannelMap(), and ProcessEvent().

Subbank_to_Scaler_Map_t QwScaler::fSubbank_Map
private

Definition at line 114 of file QwScaler.h.

Referenced by LoadChannelMap(), and ProcessEvBuffer().


The documentation for this class was generated from the following files: