Belle II Software  release-08-01-10
DQMHistAnalysisSVDOnMiraBelle.h
1 /**************************************************************************
2  * basf2 (Belle II Analysis Software Framework) *
3  * Author: The Belle II Collaboration *
4  * *
5  * See git log for contributors and copyright holders. *
6  * This file is licensed under LGPL-3.0, see LICENSE.md. *
7  **************************************************************************/
8 
9 #pragma once
10 
11 #include <dqm/core/DQMHistAnalysis.h>
12 
13 #include <vector>
14 
15 #include <TROOT.h>
16 #include <TCanvas.h>
17 #include <TH1F.h>
18 #include <TH2F.h>
19 
20 namespace Belle2 {
28 
29  public:
30 
36  void initialize() override final;
38  void beginRun() override final;
40  void event() override final;
42  void endRun() override final;
44  void terminate() override final;
45 
46  private:
47 
49  TCanvas* m_c_avgEfficiency = nullptr;
50  TCanvas* m_c_avgOffOccupancy = nullptr;
51  TCanvas* m_c_MPVChargeClusterOnTrack = nullptr;
52  TCanvas* m_c_MPVSNRClusterOnTrack = nullptr;
53  TCanvas* m_c_MPVTimeClusterOnTrack = nullptr;
55  nullptr;
56  TCanvas* m_c_MeanSVDEventT0 = nullptr;
60 
69  std::vector<float> highOccupancySensor(int iLayer, TH1F* hU, TH1F* hV, int iBin, int nEvents) const;
70 
81  std::vector<float> avgOccupancyUV(int iLayer, TH1F* hU, TH1F* hV, int min, int max, int offset, int step, int nEvents) const;
82 
90  std::vector<float> avgEfficiencyUV(TH2F* hMCU, TH2F* hMCV, TH2F* hFTU, TH2F* hFTV, int minX, int maxX, int minY, int maxY) const;
91 
97  float xForMaxY(TH1F* h) const;
98 
104  float histFWHM(TH1F* h) const;
105 
106  };
108 } // end namespace Belle2
109 
110 
111 
112 
113 
The base class for the histogram analysis module.
Class derived from HistoModule, for SVD monitoring variables at MiraBelle.
void initialize() override final
Module function initialize.
float histFWHM(TH1F *h) const
Calculate full width at half maximum of histogram.
TCanvas * m_c_MPVTimeClusterOnTrack
time for clusters on track
std::vector< float > avgEfficiencyUV(TH2F *hMCU, TH2F *hMCV, TH2F *hFTU, TH2F *hFTV, int minX, int maxX, int minY, int maxY) const
Calculate avg efficiency for specified sensors.
std::vector< float > avgOccupancyUV(int iLayer, TH1F *hU, TH1F *hV, int min, int max, int offset, int step, int nEvents) const
Calculate avg offline occupancy for specified sensors.
TCanvas * m_c_MPVChargeClusterOnTrack
charge for clusters on track
MonitoringObject * m_monObj
Monitoring Object to be produced by this module, which contain defined canvases and monitoring variab...
TCanvas * m_c_avgEfficiency
List of canvases to be added to MonitoringObject.
void terminate() override final
Module function terminate.
void event() override final
Module function event.
TCanvas * m_c_MPVSNRClusterOnTrack
SNR for clusters on track.
void endRun() override final
Module function endRun.
float xForMaxY(TH1F *h) const
Calculate abscissa of max Y bin.
TCanvas * m_c_avgOffOccupancy
number of ZS5 fired strips
void beginRun() override final
Module function beginRun.
TCanvas * m_c_avgMaxBinClusterOnTrack
average number of the APV sample which corresponds to the maximum amplitude for clusters on track
std::vector< float > highOccupancySensor(int iLayer, TH1F *hU, TH1F *hV, int iBin, int nEvents) const
Calculate avg offline occupancy for one specific sensor, especially with high occupancy.
MonitoringObject is a basic object to hold data for the run-dependency monitoring Run summary TCanvas...
Abstract base class for different kinds of events.