// 2 - falling edge fully independent
// 3 - falling uses calibration from rising edge
// 4 - use common statistic for both rising and falling edge
- hadaq::TrbProcessor::SetDefaults(65, 2);
+ hadaq::TrbProcessor::SetDefaults(33, 2);
hadaq::TdcProcessor::SetTriggerDWindow(-5, 70);
// hadaq::TdcProcessor::SetToTRange(30, 50, 80);
// [min..max] range for HUB ids
- hadaq::TrbProcessor::SetHUBRange(0x0840, 0x0840);
+ hadaq::TrbProcessor::SetHUBRange(0x8000, 0x8FFF);
// Histogramming for ToT: first: nr. of bins, 2nd: TOT range
hadaq::TdcProcessor::SetDefaults(600, 1000);
const char* calname = getenv("CALNAME");
- if ((calname==0) || (*calname==0)) calname = "test_";
+ if ((calname==0) || (*calname==0)) calname = "cal_150MHz_";
const char* calmode = getenv("CALMODE");
int cnt = (calmode && *calmode) ? atoi(calmode) : 100000;
//cnt=100000;
// (1 << 0xD) - special 0XD trigger with internal pulser, used also for TOT calibration
// 0x3FFF - all kinds of trigger types will be used for calibration (excluding 0xE and 0xF)
// 0x80000000 in mask enables usage of temperature correction
- hld->ConfigureCalibration("test", 1e6 , (1 << 0xD));
+ hld->ConfigureCalibration(calname, cnt , (1 << trig));
// only accept trigger type 0x1 when storing file
// new hadaq::HldFilter(0x1);
// 1 - std::vector<hadaq::TdcMessageExt> - includes original TDC message
// 2 - std::vector<hadaq::MessageFloat> - compact form, without channel 0, stamp as float (relative to ch0)
// 3 - std::vector<hadaq::MessageDouble> - compact form, with channel 0, absolute time stamp as double
- base::ProcMgr::instance()->SetStoreKind(2);
+ base::ProcMgr::instance()->SetStoreKind(1);
// when configured as output in DABC, one specifies:
tdc->SetUseLastHit(false);
+ // needed if tdc-ToT values are larger 60ns
+ // arguments: delay, range (min, max)
+ // DiRICH has a 20ns calibration pulse width
+ // but it assumes a 312.5MHz Oscillator on it
+ // The DiRICH5s1 has a 200MHz Calibration Oscillator
+ // This gives a factor of 1.5625, so the calibration pulse has a length of
+ // 31.25ns
+ //tdc->SetToTRange(31.25, 40, 70);
+
+ // in new dirich5s design the correct PLL is included, so no correction necessary!
+
+
//tdc->SetStoreEnabled();
for (unsigned nch=1; nch<tdc->NumChannels(); nch++) {
//if(nch!=48) {
- tdc->SetRefChannel(nch, nch-1, 0xffff, 100000, -50., 50.);
+ //tdc->SetRefChannel(nch, nch-1, 0xffff, 100000, -50., 50.);
//}
}
+ tdc->SetRefChannel(3, 7, 0x1417, 100000, -20.1, 20.);
+ tdc->SetRefChannel(4, 6, 0x1410, 100000, -20.1, 20.);
+ tdc->SetRefChannel(5, 7, 0x1417, 100000, -20.1, 20.);
+ tdc->SetRefChannel(6, 8, 0x1417, 100000, -20.1, 20.);
+ //tdc->SetRefChannel(0, 0, 0x1410, 100000, -500000.1, 500000.);
+
//tdc->SetRefChannel(48, 39, 0xffff, 18000, -50., 50.);
// for (unsigned j=10; j<33; j++) {
// tdc->SetRefChannel(j, 1, 0xffff, 10000, -40., 40.);