QwAnalysis
|
#include <QwScaler.h>
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) |
VQwSubsystem & | operator= (VQwSubsystem *value) |
VQwSubsystem & | operator+= (VQwSubsystem *value) |
VQwSubsystem & | operator-= (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) |
![]() | |
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 |
![]() | |
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... | |
QwSubsystemArray * | GetParent (const unsigned int parent=0) const |
Get the parent of this subsystem. More... | |
VQwSubsystem * | GetSibling (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 VQwHardwareChannel * | ReturnInternalValue (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... | |
![]() | |
void | ShareHistograms (const MQwHistograms *source) |
Share histogram pointers between objects. More... | |
![]() | |
virtual | ~MQwCloneable () |
Virtual destructor. More... | |
virtual VQwSubsystem * | Clone () const |
Concrete clone method. More... | |
const VQwFactory< VQwSubsystem > * | Factory () const |
Factory getter. More... | |
![]() | |
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 void | DefineOptions () |
Define options function (note: no virtual static functions in C++) More... | |
![]() | |
static VQwSubsystem * | Create (const std::string &name) |
Object creation. More... | |
static QwScaler * | Cast (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 | |
![]() | |
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) |
![]() | |
MQwHistograms () | |
Default constructor. More... | |
MQwHistograms (const MQwHistograms &source) | |
Copy constructor. More... | |
virtual | ~MQwHistograms () |
Virtual destructor. More... | |
virtual MQwHistograms & | operator= (const MQwHistograms &value) |
void | Fill_Pointer (TH1_ptr hist_ptr, Double_t value) |
void | AddHistogram (TH1 *h) |
Register a histogram. More... | |
![]() | |
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... | |
![]() | |
std::vector< TH1_ptr > | fHistograms |
Histograms associated with this data element. More... | |
Definition at line 16 of file QwScaler.h.
|
private |
Definition at line 117 of file QwScaler.h.
|
private |
Definition at line 121 of file QwScaler.h.
|
private |
Definition at line 113 of file QwScaler.h.
|
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.
|
inline |
Copy constructor.
Definition at line 27 of file QwScaler.h.
References fScaler.
|
virtual |
Destructor.
Destructor
Delete histograms and clean up scaler channel objects
Definition at line 40 of file QwScaler.cc.
References fScaler.
|
virtual |
Accumulate the running sum
Implements VQwSubsystemParity.
Definition at line 473 of file QwScaler.cc.
References Compare(), and fGoodEventCount.
|
virtual |
Apply the single event cuts.
Implements VQwSubsystemParity.
Definition at line 498 of file QwScaler.cc.
|
virtual |
Normalize the running sum
Implements VQwSubsystemParity.
Definition at line 484 of file QwScaler.cc.
References fGoodEventCount, and Scale().
|
virtual |
Clear the event data in this subsystem
Implements VQwSubsystem.
Definition at line 260 of file QwScaler.cc.
References fGoodEventCount, and fScaler.
Bool_t QwScaler::Compare | ( | VQwSubsystem * | value | ) |
Compare two scaler objects
value | Object to compare with |
Definition at line 527 of file QwScaler.cc.
References fScaler.
Referenced by AccumulateRunningSum(), Difference(), operator+=(), operator-=(), operator=(), Ratio(), and Sum().
|
inlinevirtual |
Construct the branch and tree vector.
Implements VQwSubsystem.
Definition at line 64 of file QwScaler.h.
|
inlinevirtual |
Construct the branch and tree vector based on the trim file.
Implements VQwSubsystem.
Definition at line 65 of file QwScaler.h.
|
virtual |
Construct the branch and tree vector.
Implements VQwSubsystem.
Definition at line 354 of file QwScaler.cc.
References fScaler.
|
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.
|
inlinevirtual |
remove one entry from the running sums for devices
Implements VQwSubsystemParity.
Definition at line 80 of file QwScaler.h.
|
static |
Definition at line 15 of file QwScaler.cc.
|
virtual |
Difference
value1 | First value |
value2 | Second value |
Implements VQwSubsystemParity.
Definition at line 435 of file QwScaler.cc.
References Compare().
|
virtual |
Fill the histograms for this subsystem.
Implements VQwSubsystem.
Definition at line 347 of file QwScaler.cc.
References fScaler.
|
virtual |
Fill the tree vector.
Implements VQwSubsystem.
Definition at line 361 of file QwScaler.cc.
References fScaler.
Int_t QwScaler::GetChannelIndex | ( | TString | channelName, |
UInt_t | module_number | ||
) |
Definition at line 516 of file QwScaler.cc.
|
inline |
Definition at line 100 of file QwScaler.h.
References fModuleChannel_Map, and fScaler.
|
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.
Double_t* QwScaler::GetRawChannelArray | ( | ) |
|
virtual |
Increment the error counters.
Implements VQwSubsystemParity.
Definition at line 503 of file QwScaler.cc.
|
virtual |
Load the channel map
mapfile | Map file |
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().
|
virtual |
Load the event cuts file.
Implements VQwSubsystemParity.
Definition at line 493 of file QwScaler.cc.
|
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.
|
virtual |
Addition-assignment operator
value | Right-hand side |
Implements VQwSubsystemParity.
Definition at line 390 of file QwScaler.cc.
References Compare(), and fScaler.
|
virtual |
Subtraction-assignment operator
value | Right-hand side |
Implements VQwSubsystemParity.
Definition at line 406 of file QwScaler.cc.
References Compare(), and fScaler.
|
virtual |
Assignment operator
value | Right-hand side |
Implements VQwSubsystemParity.
Definition at line 373 of file QwScaler.cc.
References Compare(), fScaler, and VQwSubsystem::operator=().
|
virtual |
Report the number of events failed due to HW and event cut failures.
Implements VQwSubsystemParity.
Definition at line 507 of file QwScaler.cc.
|
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.
|
virtual |
Print the value for the subcomponents
Reimplemented from VQwSubsystemParity.
Definition at line 564 of file QwScaler.cc.
References fScaler.
|
virtual |
Process the configuration buffer for this subsystem
roc_id | ROC ID |
bank_id | Subbank ID |
buffer | Buffer to read from |
num_words | Number of words left in buffer |
Implements VQwSubsystem.
Definition at line 278 of file QwScaler.cc.
|
virtual |
Process the event buffer for this subsystem
roc_id | ROC ID |
bank_id | Subbank ID |
buffer | Buffer to read from |
num_words | Number of words left in buffer |
Implements VQwSubsystem.
Definition at line 291 of file QwScaler.cc.
References fBufferOffset, fScaler, fSubbank_Map, and VQwSubsystem::GetSubbankIndex().
|
virtual |
Implements VQwSubsystem.
Definition at line 324 of file QwScaler.cc.
References fNorm, and fScaler.
|
virtual |
Process the command line options.
Reimplemented from VQwSubsystem.
Definition at line 20 of file QwScaler.cc.
|
virtual |
Determine the ratio of two photon detectors
numer | Numerator |
denom | Denominator |
Implements VQwSubsystemParity.
Definition at line 448 of file QwScaler.cc.
References Compare(), and fScaler.
|
virtual |
Scale the photon detector
factor | Scale factor |
Implements VQwSubsystemParity.
Definition at line 463 of file QwScaler.cc.
References fScaler.
Referenced by CalculateRunningAverage().
Bool_t QwScaler::SingleEventCuts | ( | ) |
|
virtual |
Summation
value1 | First value |
value2 | Second value |
Implements VQwSubsystemParity.
Definition at line 422 of file QwScaler.cc.
References Compare().
|
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.
|
private |
Definition at line 126 of file QwScaler.h.
Referenced by LoadChannelMap(), and ProcessEvBuffer().
|
private |
Definition at line 110 of file QwScaler.h.
Referenced by AccumulateRunningSum(), CalculateRunningAverage(), and ClearEventData().
|
private |
Definition at line 118 of file QwScaler.h.
Referenced by GetDataForChannelInModule(), and LoadChannelMap().
|
private |
Definition at line 122 of file QwScaler.h.
Referenced by LoadChannelMap(), and LoadInputParameters().
|
private |
Definition at line 127 of file QwScaler.h.
Referenced by LoadChannelMap(), and ProcessEvent().
|
private |
Definition at line 125 of file QwScaler.h.
Referenced by ClearEventData(), Compare(), ConstructBranchAndVector(), ConstructHistograms(), FillHistograms(), FillTreeVector(), GetDataForChannelInModule(), LoadChannelMap(), LoadInputParameters(), operator+=(), operator-=(), operator=(), PrintInfo(), PrintValue(), ProcessEvBuffer(), ProcessEvent(), QwScaler(), Ratio(), Scale(), and ~QwScaler().
|
private |
Definition at line 114 of file QwScaler.h.
Referenced by LoadChannelMap(), and ProcessEvBuffer().