23#include "TGraphAsymmErrors.h"
25#include <fairlogger/Logger.h>
34 mTurnOnHistos = std::make_unique<TurnOnHistos>();
38 mUseCCDB =
other.mUseCCDB;
39 mRunStartTime =
other.mUseCCDB;
42 mTurnOnHistos = std::make_unique<TurnOnHistos>();
47 for (
short ddl = 0; ddl < 14; ddl++) {
48 const std::array<float, TurnOnHistos::Npt>& all = mTurnOnHistos->getTotSpectrum(ddl);
49 const std::array<float, TurnOnHistos::Npt>& tr = mTurnOnHistos->getTrSpectrum(ddl);
50 float sumAll = 0, sumTr = 0.;
55 LOG(info) <<
"DDL " << ddl <<
" total entries " << sumAll <<
" trigger clusters " << sumTr;
59 const gsl::span<const Cluster>&
clusters,
const gsl::span<const TriggerRecord>& cluTR)
62 auto ctr = cellTR.begin();
63 auto clutr = cluTR.begin();
64 while (ctr != cellTR.end() && clutr != cluTR.end()) {
69 if (ctr->getBCData() == clutr->getBCData()) {
72 LOG(error) <<
"Different TrigRecords for cells:" << ctr->getBCData() <<
" and clusters:" << clutr->getBCData();
82 mTurnOnHistos.reset();
84void PHOSTurnonSlot::scanClusters(
const gsl::span<const Cell>&
cells,
const TriggerRecord& celltr,
91 for (
int i = firstCellInEvent;
i < lastCellInEvent;
i++) {
105 for (
int i = firstCluInEvent;
i < lastCluInEvent;
i++) {
124 mTurnOnHistos->fillFiredMap(mFiredTiles);
125 mNoisyTiles ^= mFiredTiles;
126 mTurnOnHistos->fillNoisyMap(mFiredTiles);
134 if (!mTurnOnHistos) {
140 for (
int mod = 0; mod < 8; mod++) {
141 mTurnOnHistos->merge(
c->getCollectedHistos());
149 auto& slot = front ? cont.emplace_front(tstart, tend) : cont.emplace_back(tstart, tend);
150 slot.setContainer(std::make_unique<PHOSTurnonSlot>(mUseCCDB));
155 const gsl::span<const Cluster>&
clusters,
const gsl::span<const TriggerRecord>& cluTR)
159 slotTF.getContainer()->setRunStartTime(
tf);
174 TF1* th =
new TF1(
"aTh",
"[0]/(TMath::Exp(([1]-x)/[2])+1.)+(1.-[0])/(TMath::Exp(([3]-x)/[2])+1.)", 0., 40.);
177 TH1F hF(
"fired",
"fired", 200, 0., 20.);
178 TH1F hA(
"all",
"all", 200, 0., 20.);
179 const std::array<float, TurnOnHistos::Npt>& vf = mTurnOnHistos->getTrSpectrum(ddl);
180 const std::array<float, TurnOnHistos::Npt>& va = mTurnOnHistos->getTotSpectrum(ddl);
181 for (
int i = 0;
i < 200;
i++) {
182 hF.SetBinContent(
i + 1, vf[
i]);
183 hA.SetBinContent(
i + 1, va[
i]);
188 TGraphAsymmErrors* gr =
new TGraphAsymmErrors(&hF, &hA);
189 th->SetParameters(0.9, 3.5, 0.3, 7.5, 0.6);
190 gr->Fit(th,
"Q",
"", 2., 20.);
191 gr->SetName(Form(
"DDL_%d", ddl));
192 gr->SetTitle(Form(
"DDL %d", ddl));
194 double* par = th->GetParameters();
195 for (
int i = 0;
i < 10;
i++) {
199 std::string_view versionName{
"default"};
200 mTriggerMap->addTurnOnCurvesParams(versionName,
params);
Utils and constants for calibration and related workflows.
Device to calculate PHOS turn-on curve and bad map.
o2::calibration::TFType TFType
Slot & getSlotForTF(TFType tf)
const Container * getContainer() const
TFType getTFStart() const
Contains PHOS cluster parameters.
void getLocalPosition(float &posX, float &posZ) const
static int getTotalNCells()
void finalizeSlot(Slot &slot) final
bool process(uint64_t tf, const gsl::span< const Cell > &cells, const gsl::span< const TriggerRecord > &trs, const gsl::span< const Cluster > &clusters, const gsl::span< const TriggerRecord > &cluTR)
Slot & emplaceNewSlot(bool front, TFType tstart, TFType tend) final
void fill(const gsl::span< const Cell > &cells, const gsl::span< const TriggerRecord > &trs, const gsl::span< const Cluster > &clusters, const gsl::span< const TriggerRecord > &cluTR)
PHOSTurnonSlot(bool useCCDB)
Header for data corresponding to the same hardware trigger adapted from DataFormatsEMCAL/TriggerRecor...
int getFirstEntry() const
int getNumberOfObjects() const
static constexpr short Npt
Number of bins in pt distribution.
static constexpr short NDDL
Number of DDLs.
GLenum const GLfloat * params
GLdouble GLdouble GLdouble z
std::unique_ptr< GPUReconstructionTimeframe > tf
VectorOfTObjectPtrs other
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"
std::vector< Cluster > clusters
std::vector< Cell > cells