QwAnalysis
|
#include <QwScanner.h>
Public Member Functions | |
QwScanner (const TString &name) | |
Constructor with name. More... | |
QwScanner (const QwScanner &source) | |
Copy constructor. More... | |
virtual | ~QwScanner () |
Virtual destructor. More... | |
VQwSubsystem & | operator= (VQwSubsystem *value) |
Assignment Note: Must be called at the beginning of all subsystems routine call to operator=(VQwSubsystem *value) by VQwSubsystem::operator=(value) More... | |
VQwSubsystem & | operator+= (VQwSubsystem *value) |
VQwSubsystem & | operator-= (VQwSubsystem *value) |
void | ProcessOptions (QwOptions &options) |
Process the command line options. More... | |
void | Sum (VQwSubsystem *value1, VQwSubsystem *value2) |
void | Difference (VQwSubsystem *value1, VQwSubsystem *value2) |
void | Ratio (VQwSubsystem *numer, VQwSubsystem *denom) |
void | Scale (Double_t factor) |
void | AccumulateRunningSum (VQwSubsystem *value) |
Update the running sums for devices. More... | |
void | DeaccumulateRunningSum (VQwSubsystem *value) |
remove one entry from the running sums for devices More... | |
void | CalculateRunningAverage () |
Calculate the average for all good events. More... | |
Int_t | LoadEventCuts (TString filename) |
Load the event cuts file. More... | |
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... | |
Bool_t | CheckRunningAverages (Bool_t) |
Int_t | LoadChannelMap (TString mapfile) |
Mandatory map file definition. More... | |
Int_t | LoadGeometryDefinition (TString filename) |
Optional geometry definition. More... | |
Int_t | LoadInputParameters (TString parameterfile) |
Mandatory parameter file definition. More... | |
Int_t | ProcessConfigurationBuffer (const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words) |
void | InitializeChannel (TString name, TString datatosave) |
void | ClearEventData () |
void | SetPedestal (Double_t ped) |
void | SetCalibrationFactor (Double_t calib) |
Int_t | ProcessEvBuffer (const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words) |
TODO: The non-event-type-aware ProcessEvBuffer routine should be replaced with the event-type-aware version. More... | |
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 | FillTreeVector (std::vector< Double_t > &values) const |
Fill the tree vector. More... | |
void | FillDB (QwParityDB *db, TString type) |
Fill the database. More... | |
void | GetHitList (QwHitContainer &grandHitContainer) |
Get the hit list. More... | |
void | ReportConfiguration (Bool_t verbose) |
Bool_t | Compare (VQwSubsystem *value) |
Bool_t | ApplyHWChecks () |
void | PrintValue () const |
Print values of all channels. More... | |
void | PrintInfo () const |
Print some information about the subsystem. More... | |
void | FillRawTDCWord (Int_t bank_index, Int_t slot_num, Int_t chan, UInt_t data) |
void | FillHardwareErrorSummary () |
Hardware error summary. More... | |
![]() | |
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 | 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... | |
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... | |
![]() | |
VQwSubsystemTracking (TString name) | |
Constructor with name. More... | |
virtual | ~VQwSubsystemTracking () |
Default destructor. More... | |
Int_t | LoadGeometryDefinition (TString mapfile) |
Load geometry definition for tracking subsystems. More... | |
Int_t | LoadCrosstalkDefinition (TString mapfile) |
Load crosstalk definition for tracking subsystems. More... | |
const QwGeometry & | GetDetectorInfo () const |
Get the detector geometry information. More... | |
virtual void | ConstructBranch (TTree *tree, TString &prefix) |
Construct the branch and tree vector. More... | |
virtual void | ConstructBranch (TTree *tree, TString &prefix, QwParameterFile &trim_file) |
Construct the branch and tree vector based on the trim file. 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... | |
Protected Member Functions | |
void | SubtractReferenceTimes () |
void | UpdateHits () |
Bool_t | IsF1ReferenceChannel (Int_t slot, Int_t chan) |
void | FillRawWord (Int_t bank_index, Int_t slot_num, Int_t chan, UInt_t data) |
void | ClearAllBankRegistrations () |
Int_t | RegisterROCNumber (const UInt_t roc_id) |
Int_t | RegisterSubbank (const UInt_t bank_id) |
Int_t | RegisterSlotNumber (const UInt_t slot_id) |
EQwModuleType | RegisterModuleType (TString moduletype) |
Int_t | GetModuleIndex (size_t bank_index, size_t slot_num) const |
Bool_t | IsSlotRegistered (Int_t bank_index, Int_t slot_num) const |
Int_t | LinkChannelToSignal (const UInt_t chan, const TString &name) |
Int_t | FindSignalIndex (const EQwModuleType modtype, const TString &name) const |
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 | 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... | |
Protected Attributes | |
EQwModuleType | fCurrentType |
Bool_t | fDEBUG |
TString | fRegion |
Int_t | fCurrentBankIndex |
Name of this subsystem (the region). More... | |
Int_t | fCurrentSlot |
Int_t | fCurrentModuleIndex |
UInt_t | kMaxNumberOfChannelsPerModule |
Int_t | fNumberOfModules |
MQwV775TDC | fQDCTDC |
MQwF1TDC | fF1TDCDecoder |
QwF1TDContainer * | fF1TDContainer |
std::vector< QwHit > | fTDCHits |
std::vector< std::vector < QwDetectorID > > | fDetectorIDs |
std::vector< std::pair< Int_t, Int_t > > | fReferenceChannels |
std::vector< std::vector < Double_t > > | fReferenceData |
Int_t | fRefTime_SlotNum |
Int_t | fRefTime_ChanNum |
Double_t | fRefTime |
std::vector< std::vector < QwPMT_Channel > > | fPMTs |
std::vector< QwSIS3801D24_Channel > | fSCAs |
std::map< TString, size_t > | fSCAs_map |
std::vector< Int_t > | fSCAs_offset |
std::vector< QwVQWK_Channel > | fADCs |
std::map< TString, size_t > | fADCs_map |
std::vector< Int_t > | fADCs_offset |
std::vector< std::vector< Int_t > > | fModuleIndex |
std::vector< EQwModuleType > | fModuleTypes |
Module index, indexed by bank_index and slot_number. More... | |
std::vector< std::vector < std::pair< EQwModuleType, Int_t > > > | fModulePtrs |
TProfile2D * | fRateMapCM |
TProfile2D * | fRateMapEM |
std::vector< TString > | fParameterFileNames |
TH1F * | fParameterFileNamesHist |
![]() | |
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... | |
![]() | |
QwGeometry | fDetectorInfo |
Geometry information of this subsystem. More... | |
size_t | fTreeArrayIndex |
Tree indices. More... | |
size_t | fTreeArrayNumEntries |
Double_t | fF1TDCResolutionNS |
Static Protected Attributes | |
static const UInt_t | kMaxNumberOfModulesPerROC = 21 |
static const Int_t | kF1ReferenceChannelNumber = 99 |
Private Member Functions | |
QwScanner () | |
Private default constructor (not implemented, will throw linker error on use) More... | |
Private Attributes | |
UInt_t | fScaEventCounter |
Double_t | fHelicityFrequency |
variables for calibrating and calculating scanner positions More... | |
Double_t | fHomePositionX |
Double_t | fHomePositionY |
Double_t | fVoltage_Offset_X |
Double_t | fVoltage_Offset_Y |
Double_t | fChannel_Offset_X |
Double_t | fChannel_Offset_Y |
Double_t | fCal_Factor_VQWK_X |
Double_t | fCal_Factor_VQWK_Y |
Double_t | fCal_Factor_QDC_X |
Double_t | fCal_Factor_QDC_Y |
Double_t | fPowSupply_VQWK |
Double_t | fPositionX_VQWK |
Double_t | fPositionY_VQWK |
Double_t | fFrontSCA |
Double_t | fBackSCA |
Double_t | fCoincidenceSCA |
Double_t | fFrontADC |
Double_t | fFrontTDC |
Double_t | fBackADC |
Double_t | fBackTDC |
Double_t | fPositionX_ADC |
Double_t | fPositionY_ADC |
Double_t | fMeanPositionX_ADC |
Double_t | fMeanPositionY_ADC |
UInt_t | fBankID [4] |
Static Private Attributes | |
static const Bool_t | bStoreRawData = kTRUE |
Additional Inherited Members | |
![]() | |
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 QwScanner * | Cast (QwScanner *type) |
Object dynamic cast. More... | |
Definition at line 40 of file QwScanner.h.
|
private |
Private default constructor (not implemented, will throw linker error on use)
QwScanner::QwScanner | ( | const TString & | name | ) |
Constructor with name.
Definition at line 28 of file QwScanner.cc.
References ClearAllBankRegistrations(), fCurrentBankIndex, fCurrentModuleIndex, fCurrentSlot, fDEBUG, VQwSubsystem::fEventTypeMask, fF1TDCDecoder, fF1TDContainer, fNumberOfModules, fRegion, fScaEventCounter, QwF1TDContainer::GetF1TDCDecoder(), MQwF1TDC::GetTDCMaxChannels(), and kMaxNumberOfChannelsPerModule.
QwScanner::QwScanner | ( | const QwScanner & | source | ) |
Copy constructor.
Definition at line 49 of file QwScanner.cc.
References fCal_Factor_QDC_X, fCal_Factor_QDC_Y, fCal_Factor_VQWK_X, fCal_Factor_VQWK_Y, fChannel_Offset_X, fChannel_Offset_Y, fHelicityFrequency, fHomePositionX, fHomePositionY, fRateMapCM, fRateMapEM, fVoltage_Offset_X, and fVoltage_Offset_Y.
|
virtual |
Virtual destructor.
Definition at line 71 of file QwScanner.cc.
References fADCs, fF1TDContainer, fPMTs, and fSCAs.
|
inlinevirtual |
Update the running sums for devices.
Implements VQwSubsystemParity.
Definition at line 79 of file QwScanner.h.
|
inline |
|
inlinevirtual |
Apply the single event cuts.
Implements VQwSubsystemParity.
Definition at line 96 of file QwScanner.h.
|
inlinevirtual |
Calculate the average for all good events.
Implements VQwSubsystemParity.
Definition at line 87 of file QwScanner.h.
|
inline |
Definition at line 106 of file QwScanner.h.
|
protected |
Definition at line 1607 of file QwScanner.cc.
References VQwSubsystem::ClearAllBankRegistrations(), fDetectorIDs, fModuleIndex, fModulePtrs, fModuleTypes, fNumberOfModules, and fTDCHits.
Referenced by QwScanner().
|
virtual |
Implements VQwSubsystem.
Definition at line 429 of file QwScanner.cc.
References fADCs, fPMTs, fReferenceData, fSCAs, fTDCHits, and VQwSubsystem::SetDataLoaded().
Bool_t QwScanner::Compare | ( | VQwSubsystem * | value | ) |
Definition at line 1489 of file QwScanner.cc.
References QwLog::endl(), fADCs, fPMTs, fSCAs, and QwError.
Referenced by operator+=(), operator-=(), and operator=().
|
virtual |
Construct the branch and tree vector.
Reimplemented from VQwSubsystemTracking.
Definition at line 1325 of file QwScanner.cc.
References bStoreRawData, fADCs, fPMTs, fSCAs, VQwSubsystemTracking::fTreeArrayIndex, VQwSubsystemTracking::fTreeArrayNumEntries, gQwHists, and QwHistogramHelper::MatchDeviceParamsFromList().
|
virtual |
Construct the histograms for this subsystem in a folder with a prefix.
Implements VQwSubsystem.
Definition at line 1177 of file QwScanner.cc.
References bStoreRawData, QwHistogramHelper::Construct1DHist(), fADCs, MQwHistograms::fHistograms, fPMTs, fRateMapCM, fRateMapEM, fSCAs, and gQwHists.
|
inlinevirtual |
remove one entry from the running sums for devices
Implements VQwSubsystemParity.
Definition at line 84 of file QwScanner.h.
|
inlinevirtual |
|
inlinevirtual |
Fill the database.
Reimplemented from VQwSubsystemParity.
Definition at line 139 of file QwScanner.h.
|
virtual |
Hardware error summary.
Reimplemented from VQwSubsystemTracking.
Definition at line 2162 of file QwScanner.cc.
References fF1TDContainer, QwF1TDContainer::PrintErrorSummary(), and QwF1TDContainer::WriteErrorSummary().
|
virtual |
Fill the histograms for this subsystem.
Implements VQwSubsystem.
Definition at line 1240 of file QwScanner.cc.
References bStoreRawData, fADCs, fCoincidenceSCA, MQwHistograms::fHistograms, fMeanPositionX_ADC, fMeanPositionY_ADC, fPMTs, fPositionX_ADC, fPositionX_VQWK, fPositionY_ADC, fPositionY_VQWK, fRateMapCM, fRateMapEM, fScaEventCounter, fSCAs, and VQwSubsystem::HasDataLoaded().
void QwScanner::FillRawTDCWord | ( | Int_t | bank_index, |
Int_t | slot_num, | ||
Int_t | chan, | ||
UInt_t | data | ||
) |
Definition at line 1791 of file QwScanner.cc.
References fDetectorIDs, fReferenceData, fTDCHits, GetModuleIndex(), kDirectionNull, kF1ReferenceChannelNumber, kRegionIDScanner, and QwHit::WireMatches().
Referenced by ProcessEvBuffer().
|
protected |
Definition at line 1761 of file QwScanner.cc.
References fModulePtrs, fPMTs, GetModuleIndex(), and kUnknownModuleType.
Referenced by ProcessEvBuffer().
|
virtual |
Fill the tree vector.
Reimplemented from VQwSubsystemTracking.
Definition at line 1394 of file QwScanner.cc.
References bStoreRawData, fADCs, fBackADC, fBackSCA, fBackTDC, fCoincidenceSCA, fFrontADC, fFrontSCA, fFrontTDC, fPMTs, fPositionX_ADC, fPositionX_VQWK, fPositionY_ADC, fPositionY_VQWK, fPowSupply_VQWK, fSCAs, VQwSubsystemTracking::fTreeArrayIndex, and VQwSubsystem::HasDataLoaded().
|
protected |
Definition at line 2077 of file QwScanner.cc.
References fPMTs.
Referenced by LoadChannelMap().
|
inlineprotectedvirtual |
Return the error flag to the top level routines related to stability checks and ErrorFlag updates.
Implements VQwSubsystemParity.
Definition at line 253 of file QwScanner.h.
|
inlinevirtual |
Get the hit list.
Implements VQwSubsystemTracking.
Definition at line 144 of file QwScanner.h.
References QwHitContainer::Append(), and fTDCHits.
|
protected |
Definition at line 2062 of file QwScanner.cc.
References fModuleIndex.
Referenced by FillRawTDCWord(), FillRawWord(), IsSlotRegistered(), ProcessConfigurationBuffer(), ProcessEvBuffer(), and ReportConfiguration().
|
inlinevirtual |
Increment the error counters.
Implements VQwSubsystemParity.
Definition at line 100 of file QwScanner.h.
void QwScanner::InitializeChannel | ( | TString | name, |
TString | datatosave | ||
) |
Definition at line 2108 of file QwScanner.cc.
References fADCs, SetCalibrationFactor(), and SetPedestal().
|
inlineprotected |
Definition at line 212 of file QwScanner.h.
References fRefTime_ChanNum, and fRefTime_SlotNum.
Referenced by ProcessEvBuffer().
|
inlineprotected |
Definition at line 241 of file QwScanner.h.
References GetModuleIndex().
Referenced by ProcessEvBuffer().
|
protected |
Definition at line 1743 of file QwScanner.cc.
References fCurrentModuleIndex, fCurrentType, fModulePtrs, and fPMTs.
Referenced by LoadChannelMap().
|
virtual |
Mandatory map file definition.
Implements VQwSubsystem.
Definition at line 85 of file QwScanner.cc.
References fADCs, fADCs_map, fADCs_offset, fBankID, fCurrentBankIndex, fCurrentModuleIndex, fCurrentType, fDetectorIDs, VQwSubsystem::fDetectorMaps, FindSignalIndex(), fModuleIndex, fModulePtrs, fReferenceChannels, fRefTime_ChanNum, fRefTime_SlotNum, fSCAs, fSCAs_map, fSCAs_offset, QwVQWK_Channel::GetBufferOffset(), QwParameterFile::GetUInt(), kDirectionNull, kF1ReferenceChannelNumber, kRegionIDScanner, kUnknownModuleType, LinkChannelToSignal(), RegisterModuleType(), RegisterROCNumber(), RegisterSlotNumber(), RegisterSubbank(), and ReportConfiguration().
|
inlinevirtual |
|
inlinevirtual |
Optional geometry definition.
Reimplemented from VQwSubsystem.
Definition at line 113 of file QwScanner.h.
|
virtual |
Mandatory parameter file definition.
Implements VQwSubsystem.
Definition at line 340 of file QwScanner.cc.
References fCal_Factor_QDC_X, fCal_Factor_QDC_Y, fCal_Factor_VQWK_X, fCal_Factor_VQWK_Y, fChannel_Offset_X, fChannel_Offset_Y, VQwSubsystem::fDetectorMaps, fHelicityFrequency, fHomePositionX, fHomePositionY, fVoltage_Offset_X, and fVoltage_Offset_Y.
|
virtual |
Implements VQwSubsystemParity.
Definition at line 1557 of file QwScanner.cc.
References Compare(), QwLog::endl(), fADCs, fBackSCA, fCoincidenceSCA, fFrontSCA, fSCAs, and QwError.
|
virtual |
Implements VQwSubsystemParity.
Definition at line 1582 of file QwScanner.cc.
References Compare(), QwLog::endl(), fADCs, fBackSCA, fCoincidenceSCA, fFrontSCA, fSCAs, and QwError.
|
virtual |
Assignment Note: Must be called at the beginning of all subsystems routine call to operator=(VQwSubsystem *value) by VQwSubsystem::operator=(value)
Implements VQwSubsystemParity.
Definition at line 1514 of file QwScanner.cc.
References Compare(), QwLog::endl(), fADCs, fBackADC, fBackSCA, fBackTDC, fBankID, fCoincidenceSCA, fFrontADC, fFrontSCA, fFrontTDC, fMeanPositionX_ADC, fMeanPositionY_ADC, fPMTs, fPositionX_ADC, fPositionX_VQWK, fPositionY_ADC, fPositionY_VQWK, fPowSupply_VQWK, fScaEventCounter, fSCAs, VQwSubsystem::operator=(), and QwError.
|
inlinevirtual |
Report the number of events failed due to HW and event cut failures.
Implements VQwSubsystemParity.
Definition at line 103 of file QwScanner.h.
|
virtual |
Print some information about the subsystem.
Reimplemented from VQwSubsystem.
Definition at line 2118 of file QwScanner.cc.
References fADCs, fPMTs, and VQwSubsystem::fSystemName.
|
inlinevirtual |
Print values of all channels.
Reimplemented from VQwSubsystemParity.
Definition at line 162 of file QwScanner.h.
|
virtual |
Implements VQwSubsystem.
Definition at line 464 of file QwScanner.cc.
References QwF1TDContainer::AddQwF1TDC(), QwF1TDContainer::DoneF1TDCsConfiguration(), fBankID, fF1TDContainer, VQwSubsystemTracking::fF1TDCResolutionNS, GetModuleIndex(), VQwSubsystem::GetSubbankIndex(), VQwSubsystem::GetSubsystemName(), kMaxNumberOfModulesPerROC, QwF1TDContainer::Print(), QwF1TDC::SetF1BankIndex(), QwF1TDC::SetF1SystemName(), QwF1TDC::SetF1TDCBuffer(), and QwF1TDC::SetF1TDCIndex().
|
virtual |
TODO: The non-event-type-aware ProcessEvBuffer routine should be replaced with the event-type-aware version.
Implements VQwSubsystem.
Definition at line 593 of file QwScanner.cc.
References QwF1TDContainer::CheckDataIntegrity(), MQwV775TDC::DecodeTDCWord(), MQwF1TDC::DecodeTDCWord(), Qw::e, fADCs, fADCs_offset, fBankID, fDEBUG, fF1TDCDecoder, fF1TDContainer, FillRawTDCWord(), FillRawWord(), fModulePtrs, fQDCTDC, fRefTime, fRefTime_ChanNum, fRefTime_SlotNum, fScaEventCounter, fSCAs, fSCAs_offset, GetModuleIndex(), VQwSubsystem::GetSubbankIndex(), MQwV775TDC::GetTDCChannelNumber(), MQwF1TDC::GetTDCChannelNumber(), MQwV775TDC::GetTDCData(), MQwF1TDC::GetTDCData(), MQwV775TDC::GetTDCSlotNumber(), MQwF1TDC::GetTDCSlotNumber(), IsF1ReferenceChannel(), IsSlotRegistered(), MQwV775TDC::IsValidDataword(), MQwF1TDC::IsValidDataword(), and VQwSubsystem::SetDataLoaded().
|
virtual |
bank_index, slot_num, rawtime_arb_unit, reftime, corrected_time_arb_unit);
Implements VQwSubsystem.
Definition at line 929 of file QwScanner.cc.
References fADCs, fADCs_map, fBackADC, fBackSCA, fBackTDC, fCal_Factor_QDC_X, fCal_Factor_QDC_Y, fCal_Factor_VQWK_X, fCal_Factor_VQWK_Y, fChannel_Offset_X, fChannel_Offset_Y, fCoincidenceSCA, fF1TDContainer, fFrontADC, fFrontSCA, fFrontTDC, fHelicityFrequency, fHomePositionX, fHomePositionY, fMeanPositionX_ADC, fMeanPositionY_ADC, fPMTs, fPositionX_ADC, fPositionX_VQWK, fPositionY_ADC, fPositionY_VQWK, fPowSupply_VQWK, fRefTime, fScaEventCounter, fSCAs, fSCAs_map, fVoltage_Offset_X, fVoltage_Offset_Y, VQwSubsystem::HasDataLoaded(), QwF1TDContainer::ReferenceSignalCorrection(), QwF1TDContainer::ReturnTimeCalibration(), SubtractReferenceTimes(), and UpdateHits().
|
virtual |
Process the command line options.
Reimplemented from VQwSubsystem.
Definition at line 80 of file QwScanner.cc.
|
inlinevirtual |
|
protected |
Definition at line 1697 of file QwScanner.cc.
References fCurrentModuleIndex, fCurrentType, fModuleTypes, fPMTs, kF1TDC, kV775_TDC, and kV792_ADC.
Referenced by LoadChannelMap().
|
protected |
Definition at line 1621 of file QwScanner.cc.
References fModuleIndex, kMaxNumberOfModulesPerROC, and VQwSubsystem::RegisterROCNumber().
Referenced by LoadChannelMap().
|
protected |
Definition at line 1663 of file QwScanner.cc.
References fCurrentBankIndex, fCurrentModuleIndex, fCurrentSlot, fDetectorIDs, fModuleIndex, fModulePtrs, fModuleTypes, fNumberOfModules, kMaxNumberOfChannelsPerModule, kMaxNumberOfModulesPerROC, and kUnknownModuleType.
Referenced by LoadChannelMap().
|
protected |
Definition at line 1630 of file QwScanner.cc.
References fCurrentBankIndex, VQwSubsystem::fCurrentROC_ID, fModuleIndex, fReferenceChannels, fReferenceData, VQwSubsystem::GetSubbankIndex(), kMaxNumberOfModulesPerROC, and VQwSubsystem::RegisterSubbank().
Referenced by LoadChannelMap().
void QwScanner::ReportConfiguration | ( | Bool_t | verbose | ) |
Definition at line 1446 of file QwScanner.cc.
References fADCs, VQwSubsystem::fBank_IDs, fBankID, VQwSubsystem::fROC_IDs, fSCAs, GetModuleIndex(), VQwSubsystem::GetSubbankIndex(), and kMaxNumberOfModulesPerROC.
Referenced by LoadChannelMap().
|
inlinevirtual |
void QwScanner::SetCalibrationFactor | ( | Double_t | calib | ) |
Definition at line 2101 of file QwScanner.cc.
References fADCs.
Referenced by InitializeChannel().
void QwScanner::SetPedestal | ( | Double_t | ped | ) |
Definition at line 2095 of file QwScanner.cc.
References fADCs.
Referenced by InitializeChannel().
|
protected |
Definition at line 1896 of file QwScanner.cc.
References fF1TDContainer, fReferenceData, fTDCHits, VQwSubsystem::GetSubsystemName(), QwMessage, and QwF1TDContainer::ReferenceSignalCorrection().
Referenced by ProcessEvent().
|
inlinevirtual |
|
inlineprotectedvirtual |
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 262 of file QwScanner.h.
|
protected |
Definition at line 2015 of file QwScanner.cc.
References VQwSubsystemTracking::fF1TDCResolutionNS, and fTDCHits.
Referenced by ProcessEvent().
|
staticprivate |
Definition at line 278 of file QwScanner.h.
Referenced by ConstructBranchAndVector(), ConstructHistograms(), FillHistograms(), and FillTreeVector().
|
protected |
Definition at line 224 of file QwScanner.h.
Referenced by ApplyHWChecks(), ClearEventData(), Compare(), ConstructBranchAndVector(), ConstructHistograms(), FillHistograms(), FillTreeVector(), InitializeChannel(), LoadChannelMap(), operator+=(), operator-=(), operator=(), PrintInfo(), ProcessEvBuffer(), ProcessEvent(), ReportConfiguration(), SetCalibrationFactor(), SetPedestal(), and ~QwScanner().
|
protected |
Definition at line 225 of file QwScanner.h.
Referenced by LoadChannelMap(), and ProcessEvent().
|
protected |
Definition at line 226 of file QwScanner.h.
Referenced by LoadChannelMap(), and ProcessEvBuffer().
|
private |
Definition at line 305 of file QwScanner.h.
Referenced by FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 301 of file QwScanner.h.
Referenced by FillTreeVector(), operator+=(), operator-=(), operator=(), and ProcessEvent().
|
private |
Definition at line 306 of file QwScanner.h.
Referenced by FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 314 of file QwScanner.h.
Referenced by LoadChannelMap(), operator=(), ProcessConfigurationBuffer(), ProcessEvBuffer(), and ReportConfiguration().
|
private |
Definition at line 294 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 295 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 292 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 293 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 289 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 290 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 302 of file QwScanner.h.
Referenced by FillHistograms(), FillTreeVector(), operator+=(), operator-=(), operator=(), and ProcessEvent().
|
protected |
Name of this subsystem (the region).
Definition at line 175 of file QwScanner.h.
Referenced by LoadChannelMap(), QwScanner(), RegisterSlotNumber(), and RegisterSubbank().
|
protected |
Definition at line 177 of file QwScanner.h.
Referenced by LinkChannelToSignal(), LoadChannelMap(), QwScanner(), RegisterModuleType(), and RegisterSlotNumber().
|
protected |
Definition at line 176 of file QwScanner.h.
Referenced by QwScanner(), and RegisterSlotNumber().
|
protected |
Definition at line 171 of file QwScanner.h.
Referenced by LinkChannelToSignal(), LoadChannelMap(), and RegisterModuleType().
|
protected |
Definition at line 172 of file QwScanner.h.
Referenced by ProcessEvBuffer(), and QwScanner().
|
protected |
Definition at line 197 of file QwScanner.h.
Referenced by ClearAllBankRegistrations(), FillRawTDCWord(), LoadChannelMap(), and RegisterSlotNumber().
|
protected |
Definition at line 186 of file QwScanner.h.
Referenced by ProcessEvBuffer(), and QwScanner().
|
protected |
Definition at line 187 of file QwScanner.h.
Referenced by FillHardwareErrorSummary(), ProcessConfigurationBuffer(), ProcessEvBuffer(), ProcessEvent(), QwScanner(), SubtractReferenceTimes(), and ~QwScanner().
|
private |
Definition at line 303 of file QwScanner.h.
Referenced by FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 300 of file QwScanner.h.
Referenced by FillTreeVector(), operator+=(), operator-=(), operator=(), and ProcessEvent().
|
private |
Definition at line 304 of file QwScanner.h.
Referenced by FillTreeVector(), operator=(), and ProcessEvent().
|
private |
variables for calibrating and calculating scanner positions
Definition at line 283 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 285 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 286 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 311 of file QwScanner.h.
Referenced by FillHistograms(), operator=(), and ProcessEvent().
|
private |
Definition at line 312 of file QwScanner.h.
Referenced by FillHistograms(), operator=(), and ProcessEvent().
|
protected |
Definition at line 249 of file QwScanner.h.
Referenced by ClearAllBankRegistrations(), GetModuleIndex(), LoadChannelMap(), RegisterROCNumber(), RegisterSlotNumber(), and RegisterSubbank().
|
protected |
Definition at line 251 of file QwScanner.h.
Referenced by ClearAllBankRegistrations(), FillRawWord(), LinkChannelToSignal(), LoadChannelMap(), ProcessEvBuffer(), and RegisterSlotNumber().
|
protected |
Module index, indexed by bank_index and slot_number.
Definition at line 250 of file QwScanner.h.
Referenced by ClearAllBankRegistrations(), RegisterModuleType(), and RegisterSlotNumber().
|
protected |
Definition at line 183 of file QwScanner.h.
Referenced by ClearAllBankRegistrations(), QwScanner(), and RegisterSlotNumber().
|
protected |
Definition at line 270 of file QwScanner.h.
|
protected |
Definition at line 271 of file QwScanner.h.
|
protected |
Definition at line 214 of file QwScanner.h.
Referenced by ClearEventData(), Compare(), ConstructBranchAndVector(), ConstructHistograms(), FillHistograms(), FillRawWord(), FillTreeVector(), FindSignalIndex(), LinkChannelToSignal(), operator=(), PrintInfo(), ProcessEvent(), RegisterModuleType(), and ~QwScanner().
|
private |
Definition at line 308 of file QwScanner.h.
Referenced by FillHistograms(), FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 298 of file QwScanner.h.
Referenced by FillHistograms(), FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 309 of file QwScanner.h.
Referenced by FillHistograms(), FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 299 of file QwScanner.h.
Referenced by FillHistograms(), FillTreeVector(), operator=(), and ProcessEvent().
|
private |
Definition at line 297 of file QwScanner.h.
Referenced by FillTreeVector(), operator=(), and ProcessEvent().
|
protected |
Definition at line 185 of file QwScanner.h.
Referenced by ProcessEvBuffer().
|
protected |
Definition at line 263 of file QwScanner.h.
Referenced by ConstructHistograms(), FillHistograms(), and QwScanner().
|
protected |
Definition at line 268 of file QwScanner.h.
Referenced by ConstructHistograms(), FillHistograms(), and QwScanner().
|
protected |
Definition at line 199 of file QwScanner.h.
Referenced by LoadChannelMap(), and RegisterSubbank().
|
protected |
Definition at line 202 of file QwScanner.h.
Referenced by ClearEventData(), FillRawTDCWord(), RegisterSubbank(), and SubtractReferenceTimes().
|
protected |
Definition at line 210 of file QwScanner.h.
Referenced by ProcessEvBuffer(), and ProcessEvent().
|
protected |
Definition at line 209 of file QwScanner.h.
Referenced by IsF1ReferenceChannel(), LoadChannelMap(), and ProcessEvBuffer().
|
protected |
Definition at line 208 of file QwScanner.h.
Referenced by IsF1ReferenceChannel(), LoadChannelMap(), and ProcessEvBuffer().
|
protected |
Definition at line 174 of file QwScanner.h.
Referenced by QwScanner().
|
private |
Definition at line 280 of file QwScanner.h.
Referenced by FillHistograms(), operator=(), ProcessEvBuffer(), ProcessEvent(), and QwScanner().
|
protected |
Definition at line 220 of file QwScanner.h.
Referenced by ClearEventData(), Compare(), ConstructBranchAndVector(), ConstructHistograms(), FillHistograms(), FillTreeVector(), LoadChannelMap(), operator+=(), operator-=(), operator=(), ProcessEvBuffer(), ProcessEvent(), ReportConfiguration(), and ~QwScanner().
|
protected |
Definition at line 221 of file QwScanner.h.
Referenced by LoadChannelMap(), and ProcessEvent().
|
protected |
Definition at line 222 of file QwScanner.h.
Referenced by LoadChannelMap(), and ProcessEvBuffer().
|
protected |
Definition at line 195 of file QwScanner.h.
Referenced by ClearAllBankRegistrations(), ClearEventData(), FillRawTDCWord(), GetHitList(), SubtractReferenceTimes(), and UpdateHits().
|
private |
Definition at line 287 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
private |
Definition at line 288 of file QwScanner.h.
Referenced by LoadInputParameters(), ProcessEvent(), and QwScanner().
|
staticprotected |
Definition at line 180 of file QwScanner.h.
Referenced by FillRawTDCWord(), and LoadChannelMap().
|
protected |
Definition at line 182 of file QwScanner.h.
Referenced by QwScanner(), and RegisterSlotNumber().
|
staticprotected |
Definition at line 179 of file QwScanner.h.
Referenced by ProcessConfigurationBuffer(), RegisterROCNumber(), RegisterSlotNumber(), RegisterSubbank(), and ReportConfiguration().