forked from AliceO2Group/AliceO2
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy patho2TestHistograms.cxx
More file actions
123 lines (112 loc) · 3.88 KB
/
o2TestHistograms.cxx
File metadata and controls
123 lines (112 loc) · 3.88 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
// All rights not expressly granted are reserved.
//
// This software is distributed under the terms of the GNU General Public
// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
//
// In applying this license CERN does not waive the privileges and immunities
// granted to it by virtue of its status as an Intergovernmental Organization
// or submit itself to any jurisdiction.
///
/// \brief FullTracks is a join of Tracks, TracksCov, and TracksExtra.
/// \author
/// \since
#include "Framework/runDataProcessing.h"
#include "Framework/AnalysisTask.h"
#include <TH2F.h>
#include <cmath>
#include <iostream>
using namespace o2;
using namespace o2::framework;
using namespace o2::framework::expressions;
namespace o2::aod
{
namespace skimmedExampleTrack
{
DECLARE_SOA_COLUMN(Pt, pt, float); //!
DECLARE_SOA_COLUMN(Eta, eta, float); //!
} // namespace skimmedExampleTrack
DECLARE_SOA_TABLE(SkimmedExampleTrack, "AOD", "SKIMEXTRK", //!
skimmedExampleTrack::Pt,
skimmedExampleTrack::Eta);
} // namespace o2::aod
struct EtaAndClsHistogramsSimple {
OutputObj<TH2F> etaClsH{TH2F("eta_vs_pt", "#eta vs pT", 102, -2.01, 2.01, 100, 0, 10)};
Produces<o2::aod::SkimmedExampleTrack> skimEx;
void process(aod::Tracks const& tracks, aod::FT0s const&)
{
LOGP(info, "Invoking the simple one");
for (auto& track : tracks) {
etaClsH->Fill(track.eta(), track.pt());
skimEx(track.pt(), track.eta());
}
}
};
struct EtaAndClsHistogramsIUSimple {
OutputObj<TH2F> etaClsH{TH2F("eta_vs_pt", "#eta vs pT", 102, -2.01, 2.01, 100, 0, 10)};
Produces<o2::aod::SkimmedExampleTrack> skimEx;
void process(aod::TracksIU const& tracks, aod::FT0s const&)
{
LOGP(info, "Invoking the simple one");
for (auto& track : tracks) {
etaClsH->Fill(track.eta(), track.pt());
skimEx(track.pt(), track.eta());
}
}
};
struct EtaAndClsHistogramsFull {
OutputObj<TH3F> etaClsH{TH3F("eta_vs_cls_vs_sigmapT", "#eta vs N_{cls} vs sigma_{1/pT}", 102, -2.01, 2.01, 160, -0.5, 159.5, 100, 0, 10)};
void process(soa::Join<aod::FullTracks, aod::TracksCov> const& tracks)
{
LOGP(info, "Invoking the run 3 one");
for (auto& track : tracks) {
etaClsH->Fill(track.eta(), track.tpcNClsFindable(), track.sigma1Pt());
}
}
};
WorkflowSpec defineDataProcessing(ConfigContext const& cfgc)
{
std::string runType = "3";
std::vector<std::string> tables;
if (cfgc.options().hasOption("aod-metadata-Run")) {
runType = cfgc.options().get<std::string>("aod-metadata-Run");
}
if (cfgc.options().hasOption("aod-metadata-tables")) {
tables = cfgc.options().get<std::vector<std::string>>("aod-metadata-tables");
}
LOGP(info, "Runtype is {}", runType);
bool hasTrackCov = false;
bool hasTrackIU = false;
for (auto& table : tables) {
if (table == "O2trackcov") {
hasTrackCov = true;
}
if (table.starts_with("O2track_iu")) {
hasTrackIU = true;
}
LOGP(info, "- {} present.", table);
}
// Notice it's important for the tasks to use the same name, otherwise topology generation will be confused.
if (runType == "2" || !hasTrackCov) {
LOGP(info, "Using only tracks {}", runType);
if (hasTrackIU) {
return WorkflowSpec{
adaptAnalysisTask<EtaAndClsHistogramsIUSimple>(cfgc, TaskName{"simple-histos"}),
};
}
return WorkflowSpec{
adaptAnalysisTask<EtaAndClsHistogramsSimple>(cfgc, TaskName{"simple-histos"}),
};
} else {
LOGP(info, "Using tracks extra {}", runType);
if (hasTrackIU) {
return WorkflowSpec{
adaptAnalysisTask<EtaAndClsHistogramsIUSimple>(cfgc, TaskName{"simple-histos"}),
};
}
return WorkflowSpec{
adaptAnalysisTask<EtaAndClsHistogramsFull>(cfgc, TaskName{"simple-histos"}),
};
}
}