46 TString varname, varvalue;
47 TString modtype, dettype, name;
48 Int_t modnum = 0, channum = 0;
53 while (mapstr.ReadNextLine())
55 mapstr.TrimComment(
'!');
56 mapstr.TrimWhitespace();
57 if (mapstr.LineIsEmpty())
continue;
59 if (mapstr.HasVariablePair(
"=",varname,varvalue)){
65 }
else if (varname==
"qdc_bank") {
68 }
else if (varname==
"sca_bank") {
71 }
else if (varname==
"slot") {
73 }
else if (varname==
"module") {
78 modtype = mapstr.GetTypedNextToken<TString>();
79 modnum = mapstr.GetTypedNextToken<Int_t>();
80 channum = mapstr.GetTypedNextToken<Int_t>();
81 dettype = mapstr.GetTypedNextToken<TString>();
82 name = mapstr.GetTypedNextToken<TString>();
85 if (modtype==
"SIS3801") {
87 localchannel.SetNeedsExternalClock(kFALSE);
88 fSCAs.push_back(localchannel);
90 Int_t offset = QwSIS3801D24_Channel::GetBufferOffset(modnum,channum);
92 }
else if (modtype==
"V792" || modtype==
"V775") {
104 std::cerr <<
"LoadChannelMap: Unknown line: " << mapstr.GetLine().c_str() << std::endl;
115 Bool_t ldebug=kFALSE;
116 TString varname, varvalue;
126 if (ldebug) std::cout<<
"\nReading raster parameter file: "<<parameterfile<<
"\n";
128 while (mapstr.ReadNextLine())
131 mapstr.TrimComment(
'!');
132 mapstr.TrimWhitespace();
133 if (mapstr.LineIsEmpty())
continue;
135 if (mapstr.HasVariablePair(
"=",varname,varvalue))
138 Double_t value = atof(varvalue.Data());
139 if (varname==
"position_offset_x")
143 else if (varname==
"position_offset_y")
147 else if (varname==
"cal_factor_qdc_x")
151 else if (varname==
"cal_factor_qdc_y")
155 else if (varname==
"channel_offset_x")
159 else if (varname==
"channel_offset_y")
163 else if (varname==
"bpm_3h07a_slope")
167 else if (varname==
"bpm_3h07a_intercept")
171 else if (varname==
"bpm_3h09b_slope")
175 else if (varname==
"bpm_3h09b_intercept")
180 if (ldebug) std::cout<<
"inputs for "<<varname<<
": "<<value<<
"\n";
185 varname = mapstr.GetTypedNextToken<TString>();
187 varname.Remove(TString::kBoth,
' ');
188 varped= mapstr.GetTypedNextToken<Double_t>();
189 varcal= mapstr.GetTypedNextToken<Double_t>();
190 if (ldebug) std::cout<<
"inputs for channel "<<varname
191 <<
": ped="<<varped<<
", cal="<<varcal<<
"\n";
194 if (ldebug) std::cout<<
" line read in the parameter file ="<<lineread<<
" \n";
206 for (
size_t i=0; i<
fPMTs.size(); i++)
208 for (
size_t j=0; j<
fPMTs.at(i).size(); j++)
210 fPMTs.at(i).at(j).SetValue(0);
222 for (
size_t i=0; i<
fSCAs.size(); i++) {
223 fSCAs.at(i).ClearEventData();
244 if (index>=0 && num_words>0)
248 for (
size_t i=0; i<num_words ; i++)
263 catch (std::exception&
e)
265 std::cerr <<
"Standard exception from Raster::FillRawTDCWord: "
266 << e.what() << std::endl;
268 std::cerr <<
" Parameters: index=="<<index
270 <<
"; GetV775ChannelNumber()=="<<chan
274 std::cerr <<
" GetModuleIndex()=="<<modindex
275 <<
"; fModulePtrs.at(modindex).size()=="
277 <<
"; fModulePtrs.at(modindex).at(chan).first {module type}=="
279 <<
"; fModulePtrs.at(modindex).at(chan).second {signal index}=="
288 else if (bank_id==
fBankID[1]) {
291 if (buffer[0]/32!=1)
return 0;
293 if (index>=0 && num_words>0) {
295 UInt_t words_read = 0;
296 for (
size_t i=0; i<
fSCAs.size(); i++) {
311 for (
size_t i=0; i<
fPMTs.size(); i++) {
312 for (
size_t j=0; j<
fPMTs.at(i).size(); j++) {
313 fPMTs.at(i).at(j).ProcessEvent();
325 for (
size_t i=0; i<
fSCAs.size(); i++) {
326 fSCAs.at(i).ProcessEvent();
330 for (
size_t i=0; i<
fPMTs.size(); i++)
332 for (
size_t j=0; j<
fPMTs.at(i).size(); j++)
335 TString element_name =
fPMTs.at(i).at(j).GetElementName();
336 if (element_name==TString(
"raster_posx_adc"))
341 else if (element_name==TString(
"raster_posy_adc"))
347 else if (element_name==TString(
"bpm_3h07a_xp_adc"))
351 else if (element_name==TString(
"bpm_3h07a_xm_adc"))
355 else if (element_name==TString(
"bpm_3h07a_yp_adc"))
359 else if (element_name==TString(
"bpm_3h07a_ym_adc"))
363 else if (element_name==TString(
"bpm_3h09b_xp_adc"))
367 else if (element_name==TString(
"bpm_3h09b_xm_adc"))
371 else if (element_name==TString(
"bpm_3h09b_yp_adc"))
375 else if (element_name==TString(
"bpm_3h09b_ym_adc"))
398 if (prefix ==
"") basename =
"";
399 else basename = prefix;
401 if (folder != NULL) folder->cd();
403 for (
size_t i=0; i<
fPMTs.size(); i++)
405 for (
size_t j=0; j<
fPMTs.at(i).size(); j++)
406 fPMTs.at(i).at(j).ConstructHistograms(folder, basename);
409 for (
size_t i=0; i<
fSCAs.size(); i++) {
410 fSCAs.at(i).ConstructHistograms(folder, prefix);
416 fRateMap =
new TH2D(
"raster_rate_map",
"Raster Rate Map",125,0,0,125,0,0);
418 fRateMap->GetXaxis()->SetTitle(
" X [mm]");
419 fRateMap->GetYaxis()->SetTitle(
" Y [mm]");
421 gStyle -> SetPalette(1);
436 for (
size_t i=0; i<
fPMTs.size(); i++)
438 for (
size_t j=0; j<
fPMTs.at(i).size(); j++)
440 fPMTs.at(i).at(j).FillHistograms();
444 for (
size_t i=0; i<
fSCAs.size(); i++) {
445 fSCAs.at(i).FillHistograms();
454 Double_t fudge_factor = 3.2;
456 Double_t raster_x_mm = 0.0;
457 Double_t raster_y_mm = 0.0;
464 if (
fHistograms.at(j)->GetTitle()==TString(
"raster_position_x"))
468 if (
fHistograms.at(j)->GetTitle()==TString(
"raster_position_y"))
472 if (
fHistograms.at(j)->GetTitle()==TString(
"bpm_3h07a_pos_x"))
476 if (
fHistograms.at(j)->GetTitle()==TString(
"bpm_3h07a_pos_y"))
480 if (
fHistograms.at(j)->GetTitle()==TString(
"bpm_3h09b_pos_x"))
484 if (
fHistograms.at(j)->GetTitle()==TString(
"bpm_3h09b_pos_y"))
490 fRateMap->Fill(raster_x_mm, raster_y_mm);
500 if (prefix==
"") basename =
"beamline";
501 else basename = prefix;
503 values.push_back(0.0);
504 TString list =
"PositionX_ADC/D";
505 values.push_back(0.0);
506 list +=
":PositionY_ADC/D";
507 list +=
":bpm_3h07a_pos_x/D";
508 list +=
":bpm_3h07a_pos_y/D";
509 list +=
":bpm_3h09b_pos_x/D";
510 list +=
":bpm_3h09b_pos_y/D";
512 for (
size_t i=0; i<
fPMTs.size(); i++) {
513 for (
size_t j=0; j<
fPMTs.at(i).size(); j++) {
514 TString element_name =
fPMTs.at(i).at(j).GetElementName();
515 if (element_name==
"") {
518 values.push_back(0.0);
519 list +=
":"+element_name+
"_raw/D";
524 for (
size_t i=0; i<
fSCAs.size(); i++){
525 if (
fSCAs.at(i).GetElementName() !=
"") {
526 values.push_back(0.0);
527 list +=
":" +
fSCAs.at(i).GetElementName() +
"/D";
532 list = list(1,list.Length()-1);
555 for (
size_t i=0; i<
fPMTs.size(); i++)
557 for (
size_t j=0; j<
fPMTs.at(i).size(); j++)
559 if (
fPMTs.at(i).at(j).GetElementName()==
"") {}
562 values[index++] =
fPMTs.at(i).at(j).GetValue();
567 for (
size_t i=0; i<
fSCAs.size(); i++) {
568 if (
fSCAs.at(i).GetElementName()!=
"") {
569 values[index] =
fSCAs.at(i).GetValue();
635 std::pair<EQwModuleType, Int_t> tmppair;
655 std::cerr <<
"QwRaster::RegisterSlotNumber: Slot number "
656 << slot_id <<
" is larger than the number of slots per ROC, "
664 moduletype.ToUpper();
669 if (moduletype==
"V792"){
671 }
else if (moduletype==
"SIS3801") {
693 Int_t chan, UInt_t data)
703 Int_t chanindex =
fModulePtrs.at(modindex).at(chan).second;
712 fPMTs.at(modtype).at(chanindex).SetValue(data);
735 Int_t chanindex = -1;
736 if (modtype < (Int_t)
fPMTs.size())
738 for (
size_t chan = 0; chan <
fPMTs.at(modtype).size(); chan++)
740 if (name ==
fPMTs.at(modtype).at(chan).GetElementName())
752 std::cout <<
"QwRaster: " <<
fSystemName << std::endl;
754 for (
size_t i=0; i<
fPMTs.size(); i++)
756 for (
size_t j=0; j<
fPMTs.at(i).size(); j++)
758 fPMTs.at(i).at(j).PrintInfo();
Int_t GetSubbankIndex() const
Double_t fbpm_3h09b_intercept
std::map< TString, TString > fDetectorMaps
Double_t fChannel_Offset_Y
UInt_t GetTDCChannelNumber()
Bool_t IsSlotRegistered(Int_t bank_index, Int_t slot_num) const
std::map< TString, size_t > fSCAs_map
Double_t fbpm_3h09b_slope
EQwModuleType RegisterModuleType(TString moduletype)
Int_t LoadChannelMap(TString mapfile)
Mandatory map file definition.
void ConstructBranchAndVector(TTree *tree, TString &prefix, std::vector< Double_t > &values)
Construct the branch and tree vector.
static UInt_t GetUInt(const TString &varvalue)
Int_t RegisterSubbank(const UInt_t bank_id)
Int_t LinkChannelToSignal(const UInt_t chan, const TString &name)
size_t fCurrentBankIndex
Name of this subsystem (the region).
std::vector< QwSIS3801D24_Channel > fSCAs
std::vector< TH1_ptr > fHistograms
Histograms associated with this data element.
Double_t fPositionOffsetX
Bool_t HasDataLoaded() const
Int_t LoadInputParameters(TString parameterfile)
Mandatory parameter file definition.
void ProcessOptions(QwOptions &options)
Process the command line options.
Double_t fbpm_3h07a_slope
Double_t fChannel_Offset_X
void FillHistograms()
Fill the histograms for this subsystem.
virtual void ConstructHistograms()
Construct the histograms for this subsystem.
QwRaster()
Private default constructor (not implemented, will throw linker error on use)
virtual ~QwRaster()
Virtual destructor.
Int_t FindSignalIndex(const EQwModuleType modtype, const TString &name) const
Double_t fbpm_3h07a_pos_y
Double_t fCal_Factor_QDC_X
void FillRawWord(Int_t bank_index, Int_t slot_num, Int_t chan, UInt_t data)
static const UInt_t kMaxNumberOfChannelsPerModule
Int_t RegisterSlotNumber(const UInt_t slot_id)
void DecodeTDCWord(UInt_t &word, const UInt_t roc_id=0)
TString fSystemName
Name of this subsystem.
size_t fTreeArrayIndex
Tree indices.
Int_t RegisterROCNumber(const UInt_t roc_id)
Double_t fbpm_3h07a_pos_x
static const UInt_t kMaxNumberOfModulesPerROC
Double_t fbpm_3h09b_pos_y
Double_t fPositionOffsetY
UInt_t GetTDCSlotNumber()
Double_t fbpm_3h09b_pos_x
std::vector< std::vector< Int_t > > fModuleIndex
QwHistogramHelper gQwHists
Globally defined instance of the QwHistogramHelper class.
The pure virtual base class of all subsystems.
Double_t fbpm_3h07a_intercept
class QwScaler_Channel< 0x00ffffff, 0 > QwSIS3801D24_Channel
void ClearAllBankRegistrations()
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.
Int_t GetModuleIndex(size_t bank_index, size_t slot_num) const
void ReportConfiguration()
std::vector< std::vector< std::pair< EQwModuleType, Int_t > > > fModulePtrs
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 FillTreeVector(std::vector< Double_t > &values) const
Fill the tree vector.
Int_t ProcessConfigurationBuffer(const UInt_t roc_id, const UInt_t bank_id, UInt_t *buffer, UInt_t num_words)
Double_t fCal_Factor_QDC_Y
std::vector< Int_t > fSCAs_offset
EQwModuleType fCurrentType
TH1F * Construct1DHist(const TString &inputfile, const TString &name_title)
size_t fTreeArrayNumEntries
void ClearAllBankRegistrations()
Clear all registration of ROC and Bank IDs for this subsystem.
std::vector< std::vector< QwPMT_Channel > > fPMTs
std::vector< EQwModuleType > fModuleTypes
Module index, indexed by bank_index and slot_number.
#define RegisterSubsystemFactory(A)
void SetDataLoaded(Bool_t flag)