8 #include <boost/algorithm/string.hpp>
106 Int_t kMaxWords = 32;
109 QwError <<
"QwScaler_Channel::GetBufferOffset: Invalid scaler index,"
111 <<
". Must be zero or greater."
113 }
else if (scalerindex<0 || wordindex>kMaxWords){
114 QwError <<
"QwScaler_Channel::GetBufferOffset: Invalid word index,"
116 <<
". Must be in range [0," << kMaxWords <<
"]."
119 offset = (header + kMaxWords)*scalerindex + header + wordindex ;
134 std::string varvalue;
136 boost::to_lower(varvalue);
142 template<
unsigned int data_mask,
unsigned int data_shift>
148 buffer.push_back( 0 );
150 buffer.push_back( ((this->fValue_Raw<<data_shift)&data_mask) );
156 template<
unsigned int data_mask,
unsigned int data_shift>
160 UInt_t words_read = 0;
164 words_read = fNumberOfDataWords;
165 }
else if (num_words_left >= fNumberOfDataWords) {
166 fValue_Raw = ((buffer[0] & data_mask) >> data_shift);
167 fValue = fCalibrationFactor * (Double_t(fValue_Raw) - Double_t(fValue_Raw_Old) - fPedestal);
168 words_read = fNumberOfDataWords;
171 if (IsDifferentialScaler())
172 fValue_Raw_Old = fValue_Raw;
191 QwWarning <<
"VQwScaler_Channel::ProcessEvent: "
192 <<
"Missing the reference clock, "
194 <<
", for data element "
206 << std::setprecision(4)
220 if (folder != NULL) folder->cd();
226 TString basename, fullname;
257 values.push_back(0.0);
259 values.push_back(0.0);
260 list +=
":Device_Error_Code/D";
262 values.push_back(0.0);
279 tree->Branch(basename, &
fValue, basename+
"/D");
288 QwError <<
"VQwScaler_Channel::FillTreeVector: fTreeArrayNumEntries=="
291 static bool warned =
false;
293 QwError <<
"VQwScaler_Channel::FillTreeVector: fTreeArrayNumEntries=="
299 QwError <<
"VQwScaler_Channel::FillTreeVector: values.size()=="
301 <<
"; fTreeArrayIndex+fTreeArrayNumEntries=="
307 values[index++] = this->
fValue;
322 TString loc=
"Standard exception from VQwScaler_Channel::AssignValueFrom = "
324 throw std::invalid_argument(loc.Data());
334 TString loc=
"Standard exception from VQwScaler_Channel::AddValueFrom = "
336 throw std::invalid_argument(loc.Data());
346 TString loc=
"Standard exception from VQwScaler_Channel::SubtractValueFrom = "
348 throw std::invalid_argument(loc.Data());
358 TString loc=
"Standard exception from VQwScaler_Channel::MultiplyBy = "
360 throw std::invalid_argument(loc.Data());
371 TString loc=
"Standard exception from VQwScaler_Channel::DivideBy = "
373 throw std::invalid_argument(loc.Data());
379 if(
this == &value)
return *
this;
442 TString loc=
"Standard exception from VQwScaler_Channel::operator+= "
445 throw(std::invalid_argument(loc.Data()));
456 TString loc=
"Standard exception from VQwScaler_Channel::operator-= "
459 throw(std::invalid_argument(loc.Data()));
470 TString loc=
"Standard exception from VQwScaler_Channel::operator*= "
473 throw(std::invalid_argument(loc.Data()));
484 TString loc=
"Standard exception from VQwScaler_Channel::operator/= "
487 throw(std::invalid_argument(loc.Data()));
531 variance = ratio * ratio *
536 }
else if (this->
fValue == 0.0) {
540 QwVerbose <<
"Attempting to divide by zero in "
672 Double_t M12 = value.
fValue;
677 }
else if (n2 == 1) {
680 fValue += (M12 - M11) / n;
685 fValue += n2 * (M12 - M11) / n;
686 fValueM2 += M22 + n1 * n2 * (M12 - M11) * (M12 - M11) / n;
713 <<
" events with a hardware faliure."
719 <<
" events rejected by Event Cuts."
static const double pi
Angles: base unit is radian.
#define QwMessage
Predefined log drain for regular messages.
static const UInt_t kErrorFlag_ZeroHW
const VQwHardwareChannel * fNormChannelPtr
std::string fNormChannelName
void CalculateRunningAverage()
void SetRandomEventParameters(Double_t mean, Double_t sigma)
Set the normal random event parameters.
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
void Scale(Double_t Offset)
virtual void SetExternalClockName(const std::string name)
Bool_t IsNameEmpty() const
Is the name of this element empty?
void RandomizeEventData(int helicity=0, double time=0.0)
Internally generate random event data.
void InitializeChannel(TString name, TString datatosave="raw")
Initialize the fields in this object.
std::vector< Double_t > fMockDriftPhase
Harmonic drift phase.
static Int_t GetBufferOffset(Int_t scalerindex, Int_t wordindex, UInt_t header=1)
std::vector< Double_t > fMockDriftFrequency
Harmonic drift frequency.
void AddChannelOffset(Double_t Offset)
Int_t GetRawValue() const
std::vector< TH1_ptr > fHistograms
Histograms associated with this data element.
#define QwVerbose
Predefined log drain for verbose messages.
static const Bool_t kDEBUG
Double_t fMockGaussianSigma
Sigma of normal distribution.
void SetDataToSave(TString datatosave)
Set the flag indicating if raw or derived values are in this data element.
VQwScaler_Channel & operator=(const VQwScaler_Channel &value)
Double_t fCalibrationFactor
VQwHardwareChannel & operator/=(const VQwHardwareChannel *input)
void SetNumberOfDataWords(const UInt_t &numwords)
Set the number of data words in this data element.
Bool_t ReturnValue(const std::string keyname, T &retvalue)
size_t fTreeArrayNumEntries
void FillTreeVector(std::vector< Double_t > &values) const
void MultiplyBy(const VQwHardwareChannel *valueptr)
void PrintErrorCounters() const
report number of events failed due to HW and event cut failure
Int_t ProcessEvBuffer(UInt_t *buffer, UInt_t num_words_left, UInt_t index=0)
Process the CODA event buffer for this element.
Bool_t MatchDeviceParamsFromList(const std::string &devicename)
void SetNumberOfSubElements(const size_t elements)
Set the number of data words in this data element.
The pure virtual base class of all data elements.
void DivideBy(const VQwHardwareChannel *valueptr)
VQwScaler_Channel & operator-=(const VQwScaler_Channel &value)
void PrintValue() const
Print single line of value and error of this data element.
A logfile class, based on an identical class in the Hermes analyzer.
Double_t GetRandomValue()
void SetSubsystemName(TString sysname)
Set the name of the inheriting subsystem name.
Double_t fMockGaussianMean
Mean of normal distribution.
Bool_t ApplySingleEventCuts()
void SetEventData(Double_t value)
Int_t fNumEvtsWithEventCutsRejected
void Product(VQwScaler_Channel &numer, VQwScaler_Channel &denom)
void EncodeEventData(std::vector< UInt_t > &buffer)
Encode the event data into a CODA buffer.
void AssignScaledValue(const VQwScaler_Channel &value, Double_t scale)
std::vector< Double_t > fMockDriftAmplitude
Harmonic drift amplitude.
void SetElementName(const TString &name)
Set the name of this element.
VQwScaler_Channel & operator*=(const VQwScaler_Channel &value)
Bool_t fIsDifferentialScaler
UInt_t fErrorFlag
This the standard error code generated for the channel that contains the global/local/stability flags...
Double_t fMockAsymmetry
Helicity asymmetry.
QwHistogramHelper gQwHists
Globally defined instance of the QwHistogramHelper class.
void Sum(VQwScaler_Channel &value1, VQwScaler_Channel &value2)
void AccumulateRunningSum(const VQwScaler_Channel &value)
void Ratio(const VQwScaler_Channel &numer, const VQwScaler_Channel &denom)
VQwScaler_Channel & operator+=(const VQwScaler_Channel &value)
UInt_t fErrorConfigFlag
contains the global/local/stability flags
void ConstructBranch(TTree *tree, TString &prefix)
void Difference(VQwScaler_Channel &value1, VQwScaler_Channel &value2)
void ConstructHistograms(TDirectory *folder, TString &prefix)
Construct the histograms for this data element.
void AssignValueFrom(const VQwDataElement *valueptr)
void FillHistograms()
Fill the histograms for this data element.
virtual VQwHardwareChannel & operator=(const VQwHardwareChannel &value)
Arithmetic assignment operator: Should only copy event-based data.
static std::ostream & endl(std::ostream &)
End of the line.
void SetModuleType(TString ModuleType)
set the type of the beam instrument
static const UInt_t kErrorFlag_EventCut_L
Int_t fGoodEventCount
Number of good events accumulated in this element.
TString fElementName
Name of this data element.
virtual const TString & GetElementName() const
Get the name of this element.
void ScaledAdd(Double_t scale, const VQwHardwareChannel *value)
Double_t GetValueError() const
void LoadChannelParameters(QwParameterFile ¶mfile)
void AddValueFrom(const VQwHardwareChannel *valueptr)
void IncrementErrorCounters()
Double_t GetValue() const
void ClearEventData()
Clear the event data in this element.
#define QwWarning
Predefined log drain for warnings.
Double_t GetValueWidth() const
void PrintInfo() const
Print multiple lines of information about this data element.
Int_t fNumEvtsWithHWErrors
TH1F * Construct1DHist(const TString &inputfile, const TString &name_title)
virtual Bool_t NeedsExternalClock()
void SubtractValueFrom(const VQwHardwareChannel *valueptr)
static const UInt_t kErrorFlag_EventCut_U
Bool_t fNeedsExternalClock
#define QwError
Predefined log drain for errors.
Double_t fClockNormalization