27 Bool_t localdebug = kFALSE;
52 Bool_t localdebug = kFALSE;
91 Bool_t eventokay=kTRUE;
94 for(Short_t i=0;i<2;i++)
97 eventokay &= (deviceerror & 0x0);
99 if (
bDEBUG) std::cout<<
" Inconsistent within BPM terminals wire[ "<<i<<
" ] "<<std::endl;
103 eventokay &= (deviceerror & 0x0);
169 UInt_t error_code = 0;
178 if (
bDEBUG) std::cout<<
" Rel X event cut failed ";
189 if (
bDEBUG) std::cout<<
" Rel X event cut failed ";
200 if (
bDEBUG) std::cout<<
" Abs X event cut failed ";
211 if (
bDEBUG) std::cout<<
"EffectiveCharge event cut failed ";
220 if (ch_name==
"relx"){
222 }
else if (ch_name==
"rely"){
224 }
else if (ch_name==
"absx" || ch_name==
"x" ){
226 }
else if (ch_name==
"absy" || ch_name==
"y"){
228 }
else if (ch_name==
"effectivecharge" || ch_name==
"charge"){
231 TString loc=
"QwLinearDiodeArray::GetSubelementByName for"
233 + ch_name +
", which is an unrecognized subelement name.";
234 throw std::invalid_argument(loc.Data());
299 if(
typeid(*ev_error)==
typeid(*
this)) {
313 TString loc=
"Standard exception from QwBPMCavity::UpdateErrorFlag :"+
316 throw std::invalid_argument(loc.Data());
318 }
catch (std::exception&
e) {
319 std::cerr<< e.what()<<std::endl;
327 Bool_t localdebug = kFALSE;
371 "QwBPMCavity::ProcessEvBuffer(): attempt to fill in raw date for a wire that doesn't exist \n";
373 return word_position_in_buffer;
380 for (Short_t i = 0; i < 2; i++) {
391 for (i = 0; i < 2; i++) {
403 if(subindex<2&&subindex>-1)
406 std::cerr<<
"QwBPMCavity::GetSubElementName for "<<
416 for(Short_t i=0;i<3;i++)
if(subname==
subelement[i])localindex=i;
419 std::cerr <<
"QwBPMCavity::GetSubElementIndex is unable to associate the string -"
420 <<subname<<
"- to any index"<<std::endl;
427 for(Short_t i=0;i<2;i++){
527 for(Short_t i=0;i<2;i++){
585 TString thisprefix=prefix;
624 TString thisprefix=prefix;
648 TString thisprefix=prefix;
680 devicename.ToLower();
685 if (modulelist.
HasValue(devicename)){
686 TString thisprefix=prefix;
758 std::vector <QwDBInterface> row_list;
760 for(
size_t i=0;i<2;i++) {
771 std::vector <QwErrDBInterface> row_list;
773 for(
size_t i=0;i<2;i++) {
830 for (Short_t i=0; i<2; i++)
static const TString subelement[3]
UInt_t UpdateErrorFlag()
Update the error flag based on the error flags of internally contained objects Return paramter is the...
#define QwMessage
Predefined log drain for regular messages.
Int_t ProcessEvBuffer(UInt_t *buffer, UInt_t num_words_left, UInt_t index=0)
Decode the event data from a CODA buffer.
void ProcessEvent()
Process the event data according to pedestal and calibration factor.
VQwBPM & operator=(const VQwBPM &value)
size_t GetNumberOfSamples() const
UInt_t GetEventcutErrorFlag()
return the error flag on this channel/device
void SetRootSaveStatus(TString &prefix)
static const Bool_t bDEBUG
void DeaccumulateRunningSum(const QwVQWK_Channel &value)
void Ratio(const QwVQWK_Channel &numer, const QwVQWK_Channel &denom)
void ConstructBranch(TTree *tree, TString &prefix)
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
void ClearEventData()
Clear the event data in this element.
QwVQWK_Channel fAbsPos[2]
void PrintInfo() const
Print multiple lines of information about this data element.
void SetPedestal(Double_t ped)
void GetAbsolutePosition()
void RandomizeEventData(int helicity=0, double time=0.0)
void SetSubElementCalibrationFactor(Int_t j, Double_t value)
VQwBPM & operator+=(const VQwBPM &value)
Double_t fPositionCenter[3]
void SetEventCutMode(Int_t bcuts)
void Scale(Double_t Offset)
static UInt_t GetSubElementIndex(TString subname)
void SetRandomEventParameters(Double_t meanX, Double_t sigmaX, Double_t meanY, Double_t sigmaY)
void AccumulateRunningSum(const VQwBPM &value)
void ConstructBranch(TTree *tree, TString &prefix)
std::vector< QwDBInterface > GetDBEntry()
static const TString kAxisLabel[2]
static const UInt_t kInvalidSubelementIndex
void EncodeEventData(std::vector< UInt_t > &buffer)
virtual UInt_t GetErrorCode() const
TString GetSubElementName(Int_t subindex)
void CalculateRunningAverage()
void SetEventData(Double_t *block, UInt_t sequencenumber)
void SetHardwareSum(Double_t hwsum, UInt_t sequencenumber=0)
VQwBPM & operator-=(const VQwBPM &value)
void InitializeChannel(TString name)
static const Double_t kQwCavityCalibration
void ConstructHistograms(TDirectory *folder, TString &prefix)
Construct the histograms for this data element.
void PrintInfo() const
Print multiple lines of information about this data element.
Bool_t HasValue(TString &vname)
virtual UInt_t GetEventcutErrorFlag()
return the error flag on this channel/device
void SetCalibrationFactor(Double_t factor)
void PrintValue() const
Print single line of value and error of this data element.
static const Double_t kRotationCorrection
VQwHardwareChannel * GetSubelementByName(TString ch_name)
void AddEntriesToList(std::vector< QwDBInterface > &row_list)
void SetSubElementPedestal(Int_t j, Double_t value)
void ClearEventData()
Clear the event data in this element.
void PrintErrorCounters() const
report number of events failed due to HW and event cut failure
void DeaccumulateRunningSum(VQwBPM &value)
Bool_t ApplySingleEventCuts(Double_t LL, Double_t UL)
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
QwVQWK_Channel fEffectiveCharge
void Scale(Double_t factor)
void FillTreeVector(std::vector< Double_t > &values) const
QwVQWK_Channel fRelPos[2]
void InitializeChannel(TString name)
Int_t ProcessEvBuffer(UInt_t *buffer, UInt_t word_position_in_buffer, UInt_t indexnumber)
Process the CODA event buffer for this element.
void FillHistograms()
Fill the histograms for this data element.
void PrintErrorCounters() const
report number of events failed due to HW and event cut failure
void PrintValue() const
Print single line of value and error of this data element.
void FillHistograms()
Fill the histograms for this data element.
void IncrementErrorCounters()
static std::ostream & endl(std::ostream &)
End of the line.
UInt_t UpdateErrorFlag()
Update the error flag based on the error flags of internally contained objects Return paramter is the...
void FillTreeVector(std::vector< Double_t > &values) const
virtual const TString & GetElementName() const
Get the name of this element.
void ConstructHistograms(TDirectory *folder, TString &prefix)
Construct the histograms for this data element.
void Ratio(QwBPMCavity &numer, QwBPMCavity &denom)
void SetDefaultSampleSize(Int_t sample_size)
size_t GetSequenceNumber() const
std::vector< QwVQWK_Channel > fBPMElementList
std::vector< QwErrDBInterface > GetErrDBEntry()
Bool_t ApplySingleEventCuts()
void SetEventCutMode(Int_t bcuts)
Inherited from VQwDataElement to set the upper and lower limits (fULimit and fLLimit), stability % and the error flag on this channel.
virtual VQwBPM & operator=(const VQwBPM &value)=0
void InitializeChannel(TString name, TString datatosave)
Initialize the fields in this object.
void AddChannelOffset(Double_t Offset)
void AddErrEntriesToList(std::vector< QwErrDBInterface > &row_list)
void IncrementErrorCounters()
void CalculateRunningAverage()
void AccumulateRunningSum(const QwVQWK_Channel &value)