18 #define MYSQLPP_SSQLS_NO_STATICS
40 Int_t currentrocread=0;
41 Int_t currentbankread=0;
43 Int_t currentsubbankindex=-1;
46 TString varname, varvalue;
51 mapstr.EnableGreediness();
52 mapstr.SetCommentChars(
"!");
53 while (mapstr.ReadNextLine() && mapstr.SkipSection(
"Monitors"))
56 if (mapstr.PopValue(
"roc",value)) {
57 currentrocread = value;
61 if (mapstr.PopValue(
"bank",value)) {
62 currentbankread = value;
67 if (mapstr.PopValue(
"sample_size",value)) {
71 if (mapstr.HasVariablePair(
"=",varname,varvalue))
75 QwWarning <<
"QwBeamMod::LoadChannelMap: Unrecognized declaration "
81 TString modtype = mapstr.GetTypedNextToken<TString>();
82 mapstr.GetTypedNextToken<Int_t>();
83 mapstr.GetTypedNextToken<Int_t>();
86 TString namech = mapstr.GetTypedNextToken<TString>();
88 TString keyword = mapstr.GetTypedNextToken<TString>();
92 if (currentsubbankindex !=
GetSubbankIndex(currentrocread,currentbankread))
99 QwModChannelID localModChannelID(currentsubbankindex, wordsofar,namech, modtype,
this);
122 localModChannelID.
Print();
123 std::cout<<
"line ok=";
124 if(lineok) std::cout<<
"TRUE"<<std::endl;
125 else std::cout<<
"FALSE"<<std::endl;
130 if(modtype ==
"WORD")
144 fWord.push_back(localword);
147 if (localword.
fWordName ==
"bm_pattern_number") {
151 if(namech==
"ffb_status")
163 std::cout<<
"Done with Load map channel \n";
167 for(
size_t i=0;i<
fWord.size();i++)
172 mapstr.RewindToFileStart();
174 if (varvalue ==
"Monitors") {
176 while (section->ReadNextLine()) {
177 section->TrimComment();
178 section->TrimWhitespace();
179 varvalue = section->GetTypedNextToken<TString>();
180 if (varvalue.Length() > 0) {
188 if(varvalue.Contains(
"qwk_bpm", TString::kExact)){
192 else if(varvalue.Contains(
"target", TString::kExact)){
222 TString name, TString modtype,
QwBeamMod * obj):
223 fSubbankIndex(subbankid),fWordInSubbank(wordssofar),
224 fmoduletype(modtype),fmodulename(name),kUnknownDeviceType(-1)
246 Int_t eventcut_flag = 1;
252 while (mapstr.ReadNextLine()){
254 mapstr.TrimComment(
'!');
255 mapstr.TrimWhitespace();
256 if (mapstr.LineIsEmpty())
continue;
258 TString varname, varvalue;
259 if (mapstr.HasVariablePair(
"=",varname,varvalue)){
260 if (varname ==
"EVENTCUTS"){
266 TString device_type = mapstr.GetTypedNextToken<TString>();
267 device_type.ToLower();
268 TString device_name = mapstr.GetTypedNextToken<TString>();
269 device_name.ToLower();
272 if (device_type ==
"vqwk"){
274 Double_t LLX = mapstr.GetTypedNextToken<Double_t>();
275 Double_t ULX = mapstr.GetTypedNextToken<Double_t>();
276 varvalue = mapstr.GetTypedNextToken<TString>();
278 Double_t stabilitycut = mapstr.GetTypedNextToken<Double_t>();
282 QwMessage <<
" Type " << device_type <<
" Name " << device_name <<
" Index [" << det_index <<
"] "
283 <<
" device flag " << eventcut_flag <<
QwLog::endl;
288 else if (device_type ==
"word" && device_name==
"ffb_status"){
307 Bool_t ldebug=kFALSE;
312 if(ldebug)std::cout<<
"QwBeamMod::LoadInputParameters("<< pedestalfile<<
")\n";
315 while (mapstr.ReadNextLine())
318 if(ldebug)std::cout<<
" line read so far ="<<lineread<<
"\n";
320 mapstr.TrimWhitespace();
321 if (mapstr.LineIsEmpty())
continue;
324 TString varname = mapstr.GetTypedNextToken<TString>();
326 varname.Remove(TString::kBoth,
' ');
327 Double_t varped = mapstr.GetTypedNextToken<Double_t>();
328 Double_t varcal = mapstr.GetTypedNextToken<Double_t>();
329 mapstr.GetTypedNextToken<Double_t>();
343 if(ldebug) std::cout<<
" line read in the pedestal + cal file ="<<lineread<<
" \n";
352 Bool_t lkDEBUG=kFALSE;
356 if (index>=0 && num_words>0){
359 QwMessage <<
"QwBeamMod::ProcessEvBuffer: "
360 <<
"Begin processing ROC" << roc_id
361 <<
" and subbank "<<bank_id
363 if (buffer[0]==0xf0f0f0f0 && num_words%2==1){
366 QwMessage <<
"QwBeamMod::ProcessEvBuffer: "
367 <<
"Skipped padding word 0xf0f0f0f0 at beginning of buffer."
378 std::cout<<
"found modulation data for "<<
fModChannelID[i].fmodulename<<std::endl;
379 std::cout<<
"word left to read in this buffer:"<<num_words-
fModChannelID[i].fWordInSubbank<<std::endl;
389 if(
fWord[i].fWordInSubbank+1<= (Int_t) num_words) {
390 fWord[i].fValue=buffer[
fWord[i].fWordInSubbank];
392 QwWarning <<
"QwBeamMod::ProcessEvBuffer: There is not enough word in the buffer to read data for "
394 QwWarning <<
"QwBeamMod::ProcessEvBuffer: Words in this buffer:" << num_words
395 <<
" trying to read word number =" <<
fWord[i].fWordInSubbank <<
QwLog::endl;
399 QwDebug <<
"QwBeamMod::ProcessEvBuffer: Done with Processing this event" <<
QwLog::endl;
400 for(
size_t i=0;i<
fWord.size();i++) {
401 std::cout <<
" word number = " << i <<
" ";
416 Bool_t test_Mod=kTRUE;
417 Bool_t test_BCM1=kTRUE;
423 test_Mod &= test_BCM1;
424 if(!test_BCM1 &&
bDEBUG) std::cout<<
"******* QwBeamMod::SingleEventCuts()->BCM[ "<<i<<
" , "<<
fModChannel[i].GetElementName()<<
" ] ******\n";
455 std::cout<<
"*********QwBeamMod Error Summary****************"<<std::endl;
476 ErrorFlag |=
fModChannel[i].GetEventcutErrorFlag();
526 for (
size_t i=0;i<
fWord.size();i++)
543 Bool_t ldebug=kFALSE;
546 std::cout<<
"QwBeamMod::GetDetectorIndex\n";
547 std::cout<<
"type_id=="<<type_id<<
" name="<<name<<
"\n";
548 std::cout<<
fModChannelID.size()<<
" already registered detector\n";
577 for(
size_t i=0;i<input->
fWord.size();i++)
647 for(
size_t i=0;i<innumer->
fWord.size();i++)
648 this->
fWord[i].fValue=innumer->
fWord[i].fValue;
667 if(
typeid(*value)!=
typeid(*
this))
692 if (folder != NULL) folder->cd();
695 if (prefix !=
"")
return;
709 for (
size_t chan = 0; chan <
fModChannel.size(); chan++) {
711 basename = TString(
"bmod_") + prefix +
fModChannel[chan].GetElementName();
737 if (fRampChannelIndex < 0 || fRampChannelIndex > Int_t(
fModChannel.size()))
return;
740 if (fPatternWordIndex < 0 || fPatternWordIndex > Int_t(
fWord.size()))
return;
744 if (ramp < 0)
return;
755 if (pattern < 0 || pattern > 4)
return;
767 Double_t ramp_block = ramp_block_41 - ramp_block_32;
772 if( ramp_block < 5.0 && ramp_block > -5.0 ){
773 for (
size_t bpm = 0; bpm <
fMonitors.size(); bpm++){
778 for (
size_t chan = 0; chan <
fModChannel.size(); chan++){
815 for(Int_t i = 0; i < size; i++){
833 TF1 *sine =
new TF1(
"sine",
"[0] + [1]*sin(TMath::DegToRad()*x + [2])", 5, 350);
835 TCanvas *canvas =
new TCanvas(
"canvas",
"canvas", 5);
844 for(
size_t bpm = 0; bpm <
fMonitors.size(); bpm++){
846 for(
size_t pattern = 0; pattern < 5; pattern++){
849 sine->SetParameters(
fHistograms[5*bpm + pattern]->GetMean(), 0.10, 0);
850 sine->SetLineColor(2);
851 sine->SetParLimits(2, 0, TMath::Pi()*2 );
855 amplitude = TMath::Abs(sine->GetParameter(1));
856 phase = sine->GetParameter(2) * TMath::RadToDeg();
859 sine->Derivative2(10),
860 sine->Derivative3(10),
861 sine->GetParameter(0));
866 }
else if (phase < 0){
870 fOffset[bpm][pattern] = sine->GetParameter(0);
872 fPhase[bpm][pattern] = phase;
876 fChisquare[bpm][pattern] = sine->GetChisquare();
877 fNFitPoints[bpm][pattern] = sine->GetNumberFitPoints();
879 QwDebug <<
"QwBeamMod can't fit [" << bpm <<
"][" << pattern
880 <<
"] because there are only "
882 <<
" entries, and we need at least 3."
887 fPhase[bpm][pattern] = 0.0;
905 if(d1 > 0.0 && d2 < 0.0) sign = 1.0;
906 else if(d1 == 0.0 && fmean > 0.0) sign = 1.0;
907 else if(d1 < 0.0 && d2 < 0.0) sign = 1.0;
909 else if(d1 < 0.0 && d3 < 0) sign = 1.0;
911 else if(d1 < 0.0 && d2 > 0.0) sign = -1.0;
912 else if(d1 == 0.0 && fmean < 0.0) sign = -1.0;
913 else if(d1 > 0.0 && d2 > 0.0) sign = -1.0;
915 else if(d1 < 0.0 && d3 > 0) sign = -1.0;
933 for (
size_t i=0; i<
fWord.size(); i++)
936 basename = prefix+
fWord[i].fWordName;
937 values.push_back(0.0);
938 tree->Branch(basename, &(values.back()), basename+
"/D");
948 for (
size_t i = 0; i <
fWord.size(); i++)
949 values[index++] =
fWord[i].fValue;
963 for(
size_t i=0;i<
fWord.size();i++)
971 std::cout<<
"============================="<<std::endl;
972 std::cout<<
" Detector ID="<<i<<std::endl;
985 QwMessage <<
"Index of this detector in the vector of similar detector= "<<
997 Bool_t local_print_flag =
false;
999 if(local_print_flag) {
1000 QwMessage <<
" --------------------------------------------------------------- " <<
QwLog::endl;
1002 QwMessage <<
" --------------------------------------------------------------- " <<
QwLog::endl;
1005 std::vector<QwParitySSQLS::beam_optics> entrylist;
1007 QwParitySSQLS::beam_optics row;
1011 for(
size_t bpm = 0; bpm <
fMonitors.size(); bpm++){
1012 for(
size_t pattern = 0; pattern < 5; pattern++){
1015 row.beam_optics_id = 0;
1016 row.analysis_id = analysis_id;
1018 row.modulation_type_id = pattern;
1020 row.offset =
fOffset[bpm][pattern];
1022 row.phase =
fPhase[bpm][pattern];
1028 entrylist.push_back(row);
1032 if(local_print_flag) {
1040 if( entrylist.size() ) {
1041 mysqlpp::Query query= db->
Query();
1042 query.insert(entrylist.begin(), entrylist.end());
Int_t GetSubbankIndex() const
std::vector< std::pair< Int_t, Int_t > > fWordsPerSubbank
#define QwMessage
Predefined log drain for regular messages.
std::vector< std::vector< Double_t > > fAmplitude
std::map< TString, TString > fDetectorMaps
UInt_t GetMonitorID(const string &name, Bool_t zero_id_is_error=kTRUE)
Int_t GetDetectorIndex(Int_t TypeID, TString name)
void ProcessEvent_2()
Process the event data again, including data from other subsystems. Not all derived classes will requ...
Bool_t ApplySingleEventCuts()
Apply the single event cuts.
void Ratio(VQwSubsystem *numer, VQwSubsystem *denom)
UInt_t fFFB_holdoff_Counter
static const UInt_t kBModErrorFlag
std::vector< TString > fMonitorNames
static const Int_t fNumberPatterns
Bool_t Connect()
Open a connection to the database using the predefined parameters.
void FillErrDB(QwParityDB *db, TString datatype)
void FillHistograms()
Fill the histograms for this subsystem.
void Difference(VQwSubsystem *value1, VQwSubsystem *value2)
static UInt_t GetUInt(const TString &varvalue)
virtual void PrintValue() const
Print values of all channels.
virtual UInt_t UpdateErrorFlag()
Uses the error flags of contained data elements to update Returns the error flag to the top level rou...
Int_t ProcessConfigurationBuffer(const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words)
void TrimComment(const char commentchar)
std::vector< TH1_ptr > fHistograms
Histograms associated with this data element.
Bool_t HasDataLoaded() const
std::vector< std::vector< Double_t > > fPhaseError
VQwSubsystem & operator-=(VQwSubsystem *value)
void ResizeOpticsDataContainers(Int_t)
void FillDB_MPS(QwParityDB *db, TString datatype)
Fill the database with MPS-based variables Note that most subsystems don't need to do this...
static const Bool_t bDEBUG
VQwSubsystem & operator+=(VQwSubsystem *value)
void FillDB(QwParityDB *db, TString datatype)
Fill the database.
virtual void ConstructHistograms()
Construct the histograms for this subsystem.
std::vector< QwModChannelID > fModChannelID
static void PrintErrorCounterHead()
void Sum(VQwSubsystem *value1, VQwSubsystem *value2)
QwParameterFile * ReadNextSection(std::string &secname, const bool keep_header=false)
std::vector< std::vector< Int_t > > fNFitPoints
UInt_t GetEventcutErrorFlag()
Return the error flag to the top level routines related to stability checks and ErrorFlag updates...
void AccumulateRunningSum(VQwSubsystem *)
Update the running sums for devices.
Int_t LoadChannelMap(TString mapfile)
Mandatory map file definition.
std::vector< QwWord > fWord
#define QwDebug
Predefined log drain for debugging output.
Int_t GetDetectorTypeID(TString name)
A logfile class, based on an identical class in the Hermes analyzer.
void Scale(Double_t factor)
std::vector< QwVQWK_Channel > fModChannel
TString fSystemName
Name of this subsystem.
mysqlpp::Query Query(const char *qstr=0)
Int_t LoadInputParameters(TString pedestalfile)
Mandatory parameter file definition.
std::vector< std::vector< Double_t > > fChisquare
std::vector< QwVQWK_Channel > fMonitors
Int_t LoadEventCuts(TString filename)
Load the event cuts file.
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 v...
void IncrementErrorCounters()
Increment the error counters.
QwHistogramHelper gQwHists
Globally defined instance of the QwHistogramHelper class.
The pure virtual base class of all subsystems.
void AtEndOfEventLoop()
Perform actions at the end of the event loop.
A color changing class for the output stream.
void WritePromptSummary(QwPromptSummary *ps, TString type)
void ProcessOptions(QwOptions &options)
Process the command line options.
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 registratio...
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.
static const UInt_t kEventCutMode3
static std::ostream & endl(std::ostream &)
End of the line.
static const UInt_t kGlobalCut
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
Construct the branch and tree vector.
std::vector< std::vector< Double_t > > fOffset
std::vector< std::vector< Double_t > > fPhase
static const UInt_t kBModFFBErrorFlag
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 par...
Double_t GetAmplitudeSign(Double_t, Double_t, Double_t, Double_t)
std::vector< std::vector< Double_t > > fAmplitudeError
void AnalyzeOpticsPlots()
void FillTreeVector(std::vector< Double_t > &values) const
Fill the tree vector.
static void PrintErrorCounterTail()
#define QwWarning
Predefined log drain for warnings.
void InitializeChannel(TString name, TString datatosave)
Initialize the fields in this object.
std::vector< TString > fgModTypeNames
void ExchangeProcessedData()
Request processed data from other subsystems for internal use in the second event processing stage...
VQwSubsystem & operator=(VQwSubsystem *value)
Assignment Note: Must be called at the beginning of all subsystems routine call to operator=(VQwSubsy...
Bool_t Compare(VQwSubsystem *source)
void CalculateRunningAverage()
Calculate the average for all good events.
std::vector< std::vector< Double_t > > fOffsetError
QwModChannelID(Int_t subbankid, Int_t wordssofar, TString name, TString modtype, QwBeamMod *obj)
#define RegisterSubsystemFactory(A)
#define QwError
Predefined log drain for errors.
TProfile * Construct1DProf(const TString &name_title)
UInt_t GetGlobalErrorFlag(TString evtype, Int_t evMode, Double_t stabilitycut)
TString GetSubsystemName() const
void PrintErrorCounters() const
Report the number of events failed due to HW and event cut failures.
void SetDataLoaded(Bool_t flag)