9 #include <top/calibration/TOPCommonT0LLAlgorithm.h> 
   10 #include <top/dbobjects/TOPCalCommonT0.h> 
   11 #include <top/utilities/Chi2MinimumFinder1D.h> 
   32     TOPCommonT0LLAlgorithm::TOPCommonT0LLAlgorithm():
 
   36                      "with neg. log likelihood minimization (method LL)");
 
   44       auto h1 = getObjectPtr<TH1F>(
"tracks_per_set");
 
   46         B2ERROR(
"TOPCommonT0LLAlgorithm: histogram 'tracks_per_set' not found");
 
   49       unsigned numSets = h1->GetNbinsX();
 
   51       vector<Chi2MinimumFinder1D> finders;
 
   52       for (
unsigned set = 0; set < numSets; set++) {
 
   53         string name = 
"chi2_set" + to_string(set);
 
   54         auto h = getObjectPtr<TH1D>(name);
 
   58       if (finders.size() != numSets) {
 
   59         B2ERROR(
"TOPCommonT0LLAlgorithm: got number of chi2 scans not as expected" 
   60                 << 
LogVar(
"expected", numSets)
 
   61                 << 
LogVar(
"found", finders.size()));
 
   67       auto h4 = getObjectPtr<TH1F>(
"offset");
 
   69         B2ERROR(
"TOPCommonT0LLAlgorithm: histogram 'offset' not found");
 
   72       double bunchTimeSep = h4->GetXaxis()->GetXmax() - h4->GetXaxis()->GetXmin();
 
   77       string expNo = to_string(expRun[0].first);
 
   78       while (expNo.length() < 4) expNo.insert(0, 
"0");
 
   79       string runNo = to_string(expRun[0].second);
 
   80       while (runNo.length() < 5) runNo.insert(0, 
"0");
 
   81       string outputFileName = 
"commonT0-e" + expNo + 
"-r" + runNo + 
".root";
 
   82       auto* file = TFile::Open(outputFileName.c_str(), 
"recreate");
 
   84       auto* tree = 
new TTree(
"tree", 
"common T0 calibration results");
 
   85       tree->Branch<
int>(
"expNum", &
m_expNo);
 
   86       tree->Branch<
int>(
"runNum", &
m_runNo);
 
   89       tree->Branch<
float>(
"offset", &
m_offset);
 
  102       auto h_pulls = 
new TH1F(
"pulls", 
"Pulls of statistically independent results",
 
  104       h_pulls->SetXTitle(
"pulls");
 
  105       std::vector<double> pos, err;
 
  106       for (
auto& finder : finders) {
 
  107         const auto& minimum = finder.getMinimum();
 
  108         if (not minimum.valid) 
continue;
 
  109         pos.push_back(minimum.position);
 
  110         err.push_back(minimum.error);
 
  112       for (
unsigned i = 0; i < pos.size(); i++) {
 
  113         for (
unsigned j = i + 1; j < pos.size(); j++) {
 
  114           double pull = (pos[i] - pos[j]) / 
sqrt(err[i] * err[i] + err[j] * err[j]);
 
  118       double scaleError = 1;
 
  119       if (h_pulls->GetEntries() > 1) scaleError = h_pulls->GetRMS();
 
  123       auto finder = finders[0];
 
  124       for (
unsigned i = 1; i < numSets; i++) {
 
  125         finder.add(finders[i]);
 
  128       auto h_commonT0 = 
new TH1F(
"commonT0", 
"Common T0", 1, 0, 1);
 
  129       h_commonT0->SetYTitle(
"common T0 [ns]");
 
  131       const auto& minimum = finder.getMinimum();
 
  137         h_commonT0->SetBinContent(1, 
m_offset);
 
  153       auto h = finder.getHistogram(
"chi2", 
"chi2 scan; t0 [ns]; -2 logL");
 
  156       auto h2 = getObjectPtr<TH1F>(
"numHits");
 
  158       auto h3 = getObjectPtr<TH2F>(
"timeHits");
 
Base class for calibration algorithms.
void saveCalibration(TClonesArray *data, const std::string &name)
Store DBArray payload with given name with default IOV.
void setDescription(const std::string &description)
Set algorithm description (in constructor)
EResult
The result of calibration.
@ c_OK
Finished successfuly =0 in Python.
@ c_NotEnoughData
Needs more data =2 in Python.
const std::vector< Calibration::ExpRun > & getRunList() const
Get the list of runs for which calibration is called.
Common T0 calibration constant.
Minimum finder using tabulated chi^2 values in one dimension.
float m_offsetError
error on fitted offset
float m_offset
wrap-around of fitted offset (= common T0)
int m_runLast
last run number
int m_expNo
experiment number
virtual EResult calibrate() final
algorithm implementation
int m_runNo
first run number
float m_errorScaling
factor used for scaling the error
int m_numTracks
number of tracks used
int m_numEvents
number of events used
int m_fitStatus
fit status (0 = OK)
double m_minError
minimal commonT0 uncertainty [ns] to declare c_OK
float m_fittedOffset
fitted offset
Class to store variables with their name which were sent to the logging service.
double sqrt(double a)
sqrt for double
Abstract base class for different kinds of events.