29 Bool_t localdebug = kFALSE;
34 for(i=kXAxis;i<kNumAxes;i++)
37 fEffectiveCharge.InitializeChannel(name+
"_EffectiveCharge",
"derived");
40 fWire[i].InitializeChannel(name+subelement[i],
"raw");
42 std::cout<<
" Wire ["<<i<<
"]="<<fWire[i].GetElementName()<<
"\n";
45 for(i=kXAxis;i<kNumAxes;i++) fRelPos[i].
InitializeChannel(name+
"Rel"+kAxisLabel[i],
"derived");
64 Bool_t localdebug = kFALSE;
68 for(i=kXAxis;i<kNumAxes;i++)
69 fAbsPos[i].
InitializeChannel(subsystem,
"QwBPMStripline", name+kAxisLabel[i],
"derived");
71 fEffectiveCharge.InitializeChannel(subsystem,
"QwBPMStripline", name+
"_EffectiveCharge",
"derived");
74 fWire[i].InitializeChannel(subsystem,
"QwBPMStripline", name+subelement[i],
"raw");
76 std::cout<<
" Wire ["<<i<<
"]="<<fWire[i].GetElementName()<<
"\n";
79 for(i=kXAxis;i<kNumAxes;i++) fRelPos[i].
InitializeChannel(subsystem,
"QwBPMStripline", name+
"Rel"+kAxisLabel[i],
"derived");
93 for(i=kXAxis;i<kNumAxes;i++){
94 fAbsPos[i].ClearEventData();
95 fRelPos[i].ClearEventData();
97 fEffectiveCharge.ClearEventData();
106 Bool_t eventokay=kTRUE;
108 UInt_t deviceerror=0;
109 for(Short_t i=0;i<4;i++)
111 deviceerror|= fWire[i].ApplyHWChecks();
112 eventokay &= (deviceerror & 0x0);
128 for(i=kXAxis;i<kNumAxes;i++) {
129 fRelPos[i].IncrementErrorCounters();
130 fAbsPos[i].IncrementErrorCounters();
132 fEffectiveCharge.IncrementErrorCounters();
141 for(i=kXAxis;i<kNumAxes;i++) {
142 fRelPos[i].PrintErrorCounters();
143 fAbsPos[i].PrintErrorCounters();
145 fEffectiveCharge.PrintErrorCounters();
153 for(i=kXAxis;i<kNumAxes;i++) {
154 error|=fRelPos[i].GetEventcutErrorFlag();
155 error|=fAbsPos[i].GetEventcutErrorFlag();
157 error|=fEffectiveCharge.GetEventcutErrorFlag();
168 error1 |= fWire[i].GetErrorCode();
169 error2 |= fWire[i].GetEventcutErrorFlag();
171 for(i=kXAxis;i<kNumAxes;i++) {
172 fRelPos[i].UpdateErrorFlag(error1);
173 fAbsPos[i].UpdateErrorFlag(error1);
174 error2|=fRelPos[i].GetEventcutErrorFlag();
175 error2|=fAbsPos[i].GetEventcutErrorFlag();
177 fEffectiveCharge.UpdateErrorFlag(error1);
178 error2|=fEffectiveCharge.GetEventcutErrorFlag();
187 if(
typeid(*ev_error)==
typeid(*
this)) {
194 for(i=kXAxis;i<kNumAxes;i++) {
195 fRelPos[i].UpdateErrorFlag(value_bpm->
fRelPos[i]);
196 fAbsPos[i].UpdateErrorFlag(value_bpm->
fAbsPos[i]);
201 TString loc=
"Standard exception from QwBPMStripline::UpdateErrorFlag :"+
204 throw std::invalid_argument(loc.Data());
206 }
catch (std::exception&
e) {
207 std::cerr<< e.what()<<std::endl;
218 UInt_t element_error_code[2];
226 if (bDEBUG) std::cout<<
" Abs X event cut failed ";
231 element_error_code[kXAxis] = GetSubelementByName(
"xm")->GetErrorCode() | GetSubelementByName(
"xp")->GetErrorCode();
233 element_error_code[kYAxis] = GetSubelementByName(
"ym")->GetErrorCode() | GetSubelementByName(
"yp")->GetErrorCode();
235 fRelPos[kXAxis].UpdateErrorFlag(element_error_code[kXAxis]);
236 fRelPos[kYAxis].UpdateErrorFlag(element_error_code[kYAxis]);
237 fAbsPos[kXAxis].UpdateErrorFlag(element_error_code[kXAxis]);
238 fAbsPos[kYAxis].UpdateErrorFlag(element_error_code[kYAxis]);
240 fEffectiveCharge.UpdateErrorFlag(element_error_code[kXAxis]|element_error_code[kYAxis]);
245 for(i=kXAxis;i<kNumAxes;i++){
251 if (bDEBUG) std::cout<<
" Rel X event cut failed ";
255 for(i=kXAxis;i<kNumAxes;i++){
261 if (bDEBUG) std::cout<<
" Abs X event cut failed ";
266 if (fEffectiveCharge.ApplySingleEventCuts()){
271 if (bDEBUG) std::cout<<
"EffectiveCharge event cut failed ";
283 }
else if (ch_name==
"xm"){
285 }
else if (ch_name==
"yp"){
287 }
else if (ch_name==
"ym"){
289 }
else if (ch_name==
"relx"){
290 tmpptr = &fRelPos[0];
291 }
else if (ch_name==
"rely"){
292 tmpptr = &fRelPos[1];
293 }
else if (ch_name==
"absx" || ch_name==
"x" ){
294 tmpptr = &fAbsPos[0];
295 }
else if (ch_name==
"absy" || ch_name==
"y"){
296 tmpptr = &fAbsPos[1];
297 }
else if (ch_name==
"effectivecharge" || ch_name==
"charge"){
298 tmpptr = &fEffectiveCharge;
300 TString loc=
"QwBPMStripline::GetSubelementByName for"
302 + ch_name +
", which is an unrecognized subelement name.";
303 throw std::invalid_argument(loc.Data());
367 Bool_t localdebug = kFALSE;
368 static T numer(
"numerator",
"derived"), denom(
"denominator",
"derived");
369 static T tmp1(
"tmp1",
"derived"), tmp2(
"tmp2",
"derived");
370 static T rawpos[2] = {
T(
"rawpos_0",
"derived"),
T(
"rawpos_1",
"derived")};
380 fEffectiveCharge.ClearEventData();
384 fWire[i].ProcessEvent();
385 fEffectiveCharge+=fWire[i];
408 for(i=kXAxis;i<kNumAxes;i++)
410 fWire[i*2+1].Scale(fRelativeGains[i]);
411 numer.Difference(fWire[i*2],fWire[i*2+1]);
412 denom.Sum(fWire[i*2],fWire[i*2+1]);
413 rawpos[i].Ratio(numer,denom);
414 rawpos[i].Scale(fQwStriplineCalibration);
420 std::cout<<
" hw Wire["<<i*2<<
"]="<<fWire[i*2].GetValue()<<
" ";
421 std::cout<<
" hw relative gain * Wire["<<i*2+1<<
"]="<<fWire[i*2+1].GetValue()<<
"\n";
422 std::cout<<
" Relative gain["<<i<<
"]="<<fRelativeGains[i]<<
"\n";
423 std::cout<<
" hw numerator= "<<numer.GetValue()<<
" ";
424 std::cout<<
" hw denominator= "<<denom.GetValue()<<
"\n";
425 std::cout<<
" Rotation = "<<fRotationAngle<<std::endl;
429 for(i=kXAxis;i<kNumAxes;i++){
430 tmp1.AssignScaledValue(rawpos[i], fCosRotation);
431 tmp2.AssignScaledValue(rawpos[1-i], fSinRotation);
433 fRelPos[i].Difference(tmp1,tmp2);
435 fRelPos[i].Sum(tmp1,tmp2);
440 for(i=kXAxis;i<kNumAxes;i++){
441 fAbsPos[i] = fRelPos[i];
442 fAbsPos[i].AddChannelOffset(fPositionCenter[i]);
443 fAbsPos[i].Scale(1.0/fGains[i]);
447 std::cout<<
" hw fRelPos["<<kAxisLabel[i]<<
"]="<<fRelPos[i].GetValue()<<
"\n";
448 std::cout<<
" hw fOffset["<<kAxisLabel[i]<<
"]="<<fPositionCenter[i]<<
"\n";
449 std::cout<<
" hw fAbsPos["<<kAxisLabel[i]<<
"]="<<fAbsPos[i].GetValue()<<
"\n \n";
463 fWire[index].ProcessEvBuffer(buffer,word_position_in_buffer);
468 "QwBPMStripline::ProcessEvBuffer(): attemp to fill in raw date for a wire that doesn't exist \n";
470 return word_position_in_buffer;
478 for (Short_t i = 0; i < 2; i++) {
479 fAbsPos[i].PrintValue();
480 fRelPos[i].PrintValue();
503 for (i = 0; i < 4; i++) fWire[i].
PrintInfo();
504 for (i = 0; i < 2; i++) {
505 fRelPos[i].PrintInfo();
506 fAbsPos[i].PrintInfo();
508 fEffectiveCharge.PrintInfo();
516 if(subindex<4&&subindex>-1)
517 thisname=fWire[subindex].GetElementName();
519 std::cerr<<
"QwBPMStripline::GetSubElementName for "<<
530 for(Short_t i=0;i<4;i++)
if(subname==subelement[i])localindex=i;
533 std::cerr <<
"QwBPMStripline::GetSubElementIndex is unable to associate the string -"
534 <<subname<<
"- to any index"<<std::endl;
541 for(Short_t i=kXAxis;i<kNumAxes;i++){
542 fAbsPos[i]= fRelPos[i];
543 fAbsPos[i].AddChannelOffset(fPositionCenter[i]);
568 for(i=0;i<4;i++) this->fWire[i]=value.
fWire[i];
569 for(i=kXAxis;i<kNumAxes;i++) {
570 this->fRelPos[i]=value.
fRelPos[i];
571 this->fAbsPos[i]=value.
fAbsPos[i];
592 for(i=0;i<4;i++) this->fWire[i]+=value.
fWire[i];
593 for(i=kXAxis;i<kNumAxes;i++) {
594 this->fRelPos[i]+=value.
fRelPos[i];
595 this->fAbsPos[i]+=value.
fAbsPos[i];
615 for(i=0;i<4;i++) this->fWire[i]-=value.
fWire[i];
616 for(i=kXAxis;i<kNumAxes;i++) {
617 this->fRelPos[i]-=value.
fRelPos[i];
618 this->fAbsPos[i]-=value.
fAbsPos[i];
648 fEffectiveCharge.Scale(factor);
650 for(i=0;i<4;i++) fWire[i].
Scale(factor);
651 for(Short_t i=kXAxis;i<kNumAxes;i++){
652 fRelPos[i].Scale(factor);
653 fAbsPos[i].Scale(factor);
663 for (i = 0; i < 4; i++){
664 fWire[i].CalculateRunningAverage();
667 for (i = 0; i < 2; i++){
668 fRelPos[i].CalculateRunningAverage();
669 fAbsPos[i].CalculateRunningAverage();
671 fEffectiveCharge.CalculateRunningAverage();
686 for (i = 0; i < 4; i++){
687 fWire[i].AccumulateRunningSum(value.
fWire[i]);
689 for (i = 0; i < 2; i++){
690 fRelPos[i].AccumulateRunningSum(value.
fRelPos[i]);
691 fAbsPos[i].AccumulateRunningSum(value.
fAbsPos[i]);
704 for (i = 0; i < 4; i++){
705 fWire[i].DeaccumulateRunningSum(value.
fWire[i]);
707 for (i = 0; i < 2; i++){
708 fRelPos[i].DeaccumulateRunningSum(value.
fRelPos[i]);
709 fAbsPos[i].DeaccumulateRunningSum(value.
fAbsPos[i]);
722 fEffectiveCharge.ConstructHistograms(folder, prefix);
723 TString thisprefix=prefix;
732 for(i=kXAxis;i<kNumAxes;i++) {
733 fRelPos[i].ConstructHistograms(folder, thisprefix);
734 fAbsPos[i].ConstructHistograms(folder, thisprefix);
747 fEffectiveCharge.FillHistograms();
752 for(i=kXAxis;i<kNumAxes;i++){
753 fRelPos[i].FillHistograms();
754 fAbsPos[i].FillHistograms();
768 TString thisprefix=prefix;
774 fEffectiveCharge.ConstructBranchAndVector(tree,prefix,values);
779 for(i=kXAxis;i<kNumAxes;i++) {
780 fRelPos[i].ConstructBranchAndVector(tree,thisprefix,values);
781 fAbsPos[i].ConstructBranchAndVector(tree,thisprefix,values);
795 TString thisprefix=prefix;
801 fEffectiveCharge.ConstructBranch(tree,prefix);
806 for(i=kXAxis;i<kNumAxes;i++) {
807 fRelPos[i].ConstructBranch(tree,thisprefix);
808 fAbsPos[i].ConstructBranch(tree,thisprefix);
830 devicename.ToLower();
835 if (modulelist.
HasValue(devicename)){
836 TString thisprefix=prefix;
842 fEffectiveCharge.ConstructBranch(tree,prefix);
847 for(i=kXAxis;i<kNumAxes;i++) {
848 fRelPos[i].ConstructBranch(tree,thisprefix);
849 fAbsPos[i].ConstructBranch(tree,thisprefix);
871 fEffectiveCharge.FillTreeVector(values);
876 for(i=kXAxis;i<kNumAxes;i++){
877 fRelPos[i].FillTreeVector(values);
878 fAbsPos[i].FillTreeVector(values);
890 for (i=kXAxis;i<kNumAxes;i++) {
891 fRelPos[i].SetEventCutMode(bcuts);
892 fAbsPos[i].SetEventCutMode(bcuts);
894 fEffectiveCharge.SetEventCutMode(bcuts);
901 for(
size_t i=kXAxis;i<kNumAxes;i++) {
902 T relpos(fRelPos[i]);
904 fBPMElementList.push_back(relpos);
905 T abspos(fAbsPos[i]);
907 fBPMElementList.push_back(abspos);
909 T bpm_sub_element(fEffectiveCharge);
910 bpm_sub_element = fEffectiveCharge;
911 fBPMElementList.push_back(bpm_sub_element);
918 std::vector <QwDBInterface> row_list;
921 for(
size_t i=0;i<2;i++) {
922 fRelPos[i].AddEntriesToList(row_list);
923 fAbsPos[i].AddEntriesToList(row_list);
925 fEffectiveCharge.AddEntriesToList(row_list);
933 std::vector <QwErrDBInterface> row_list;
936 for(
size_t i=0;i<2;i++) {
937 fRelPos[i].AddErrEntriesToList(row_list);
938 fAbsPos[i].AddErrEntriesToList(row_list);
940 fEffectiveCharge.AddErrEntriesToList(row_list);
954 Double_t sumX = 1.1e8;
955 Double_t sumY = 0.9e8;
959 Double_t rotated_meanX = (meanX*fCosRotation - meanY*fSinRotation);
960 Double_t rotated_meanY = (meanX*fSinRotation + meanY*fCosRotation);
961 meanX = rotated_meanX;
962 meanY = rotated_meanY;
966 Double_t meanXP = (1.0 + meanX / fQwStriplineCalibration) * sumX / 2.0;
967 Double_t meanXM = (1.0 - meanX / fQwStriplineCalibration) * sumX / 2.0;
968 Double_t meanYP = (1.0 + meanY / fQwStriplineCalibration) * sumY / 2.0;
969 Double_t meanYM = (1.0 - meanY / fQwStriplineCalibration) * sumY / 2.0;
973 Double_t sigmaXP = fabs(sumX * sigmaX / meanX);
974 Double_t sigmaXM = sigmaXP;
975 Double_t sigmaYP = fabs(sumY * sigmaY / meanY);
976 Double_t sigmaYM = sigmaYP;
979 fWire[0].SetRandomEventParameters(meanXP, sigmaXP);
980 fWire[1].SetRandomEventParameters(meanXM, sigmaXM);
981 fWire[2].SetRandomEventParameters(meanYP, sigmaYP);
982 fWire[3].SetRandomEventParameters(meanYM, sigmaYM);
989 for (Short_t i=0; i<4; i++) fWire[i].RandomizeEventData(helicity, time);
998 for (Short_t i=0; i<2; i++)
1007 template<
typename T>
1010 for (Short_t i=0; i<4; i++) fWire[i].EncodeEventData(buffer);
1014 template<
typename T>
1017 for(Short_t i=0;i<4;i++) fWire[i].SetDefaultSampleSize((
size_t)sample_size);
1022 template<
typename T>
1025 fWire[j].SetPedestal(value);
1029 template<
typename T>
1032 fWire[j].SetCalibrationFactor(value);
#define QwMessage
Predefined log drain for regular messages.
Bool_t ApplySingleEventCuts()
void AccumulateRunningSum(const QwBPMStripline &value)
VQwBPM & operator=(const VQwBPM &value)
void CalculateRunningAverage()
void SetSubElementCalibrationFactor(Int_t j, Double_t value)
void AccumulateRunningSum(const QwEnergyCalculator &value)
void FillHistograms()
Fill the histograms for this data element.
void ConstructBranch(TTree *tree, TString &prefix)
void SetRootSaveStatus(TString &prefix)
void ConstructHistograms(TDirectory *folder, TString &prefix)
Construct the histograms for this data element.
void IncrementErrorCounters()
void InitializeChannel(TString name, TString datatosave)
void Ratio(QwEnergyCalculator &numer, QwEnergyCalculator &denom)
std::vector< QwDBInterface > GetDBEntry()
void SetSubElementPedestal(Int_t j, Double_t value)
void Ratio(VQwBPM &numer, VQwBPM &denom)
Bool_t ApplySingleEventCuts()
UInt_t UpdateErrorFlag()
Update the error flag based on the error flags of internally contained objects Return paramter is the...
void FillHistograms()
Fill the histograms for this data element.
void DeaccumulateRunningSum(VQwBPM &value)
static const UInt_t kInvalidSubelementIndex
void IncrementErrorCounters()
void PrintErrorCounters() const
report number of events failed due to HW and event cut failure
void PrintInfo() const
Print multiple lines of information about this data element.
void DeaccumulateRunningSum(QwEnergyCalculator &value)
void ClearEventData()
Clear the event data in this element.
void GetAbsolutePosition()
Bool_t HasValue(TString &vname)
void PrintErrorCounters() const
report number of events failed due to HW and event cut failure
void ConstructHistograms(TDirectory *folder, TString &prefix)
Construct the histograms for this data element.
void PrintInfo(TStopwatch &timer)
void RandomizeEventData(int helicity=0, double time=0.0)
void Scale(Double_t factor)
void SetRandomEventParameters(Double_t meanX, Double_t sigmaX, Double_t meanY, Double_t sigmaY)
static const double T
Magnetic field: base unit is T.
void InitializeChannel(TString name)
void PrintValue() const
Print single line of value and error of this data element.
void Scale(Double_t factor)
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
UInt_t GetEventcutErrorFlag()
return the error flag on this channel/device
void SetEventCutMode(Int_t bcuts)
Int_t ProcessEvBuffer(UInt_t *buffer, UInt_t word_position_in_buffer, UInt_t indexnumber)
Process the CODA event buffer for this element.
void FillTreeVector(std::vector< Double_t > &values) const
std::vector< QwErrDBInterface > GetErrDBEntry()
VQwBPM & operator-=(const VQwBPM &value)
static std::ostream & endl(std::ostream &)
End of the line.
void SetModuleType(TString ModuleType)
set the type of the beam instrument
void ConstructBranch(TTree *tree, TString &prefix)
TString fElementName
Name of this data element.
static UInt_t GetSubElementIndex(TString subname)
virtual const TString & GetElementName() const
Get the name of this element.
void SetEventCutMode(Int_t bcuts)
void EncodeEventData(std::vector< UInt_t > &buffer)
void FillTreeVector(std::vector< Double_t > &values) const
void ClearEventData()
Clear the event data in this element.
virtual VQwBPM & operator=(const VQwBPM &value)=0
UInt_t GetEventcutErrorFlag()
return the error flag on this channel/device
void InitializeChannel(TString name)
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
TString GetSubElementName(Int_t subindex)
void SetDefaultSampleSize(Int_t sample_size)
VQwBPM & operator+=(const VQwBPM &value)
void WritePromptSummary(QwPromptSummary *ps, TString type)
void SetEventData(Double_t *block, UInt_t sequencenumber)
VQwHardwareChannel * GetSubelementByName(TString ch_name)