-
Notifications
You must be signed in to change notification settings - Fork 499
Expand file tree
/
Copy pathmuonIteration.cxx
More file actions
57 lines (53 loc) · 2.21 KB
/
muonIteration.cxx
File metadata and controls
57 lines (53 loc) · 2.21 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
// Copyright CERN and copyright holders of ALICE O2. This software is
// distributed under the terms of the GNU General Public License v3 (GPL
// Version 3), copied verbatim in the file "COPYING".
//
// See http://alice-o2.web.cern.ch/license for full licensing information.
//
// 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.
#include "Framework/runDataProcessing.h"
#include "Framework/AnalysisTask.h"
#include "Framework/AnalysisDataModel.h"
using namespace o2;
using namespace o2::framework;
using namespace o2::framework::expressions;
// This task shows how to access the Muons belong to a collision
// The association is made through the BC column (and in Run 3 may not be unique!)
//
// Note that one has to subscribe to aod::Collisions const& to load
// the relevant data even if you access the data itself through m.collision()
// This uses the exclusive matcher, so you only get BCs which have a collision
// If you want also BCs without collision, see the example IterateMuonsSparse below
struct IterateMuons {
void process(aod::MatchedBCCollisionsExclusive::iterator const& m, aod::Collisions const&, aod::Muons const& muons)
{
LOGF(INFO, "Vertex = %f has %d muons", m.collision().posZ(), muons.size());
for (auto& muon : muons) {
LOGF(info, " pT = %.2f", muon.pt());
}
}
};
// This uses the sparase matcher, so you also get BCs without a collision.
// You need to check with m.has_collision()
struct IterateMuonsSparse {
void process(aod::MatchedBCCollisionsSparse::iterator const& m, aod::Collisions const&, aod::Muons const& muons)
{
if (m.has_collision()) {
LOGF(INFO, "Vertex = %f has %d muons", m.collision().posZ(), muons.size());
} else {
LOGF(INFO, "BC without collision has %d muons", muons.size());
}
for (auto& muon : muons) {
LOGF(info, " pT = %.2f", muon.pt());
}
}
};
WorkflowSpec defineDataProcessing(ConfigContext const& cfgc)
{
return WorkflowSpec{
adaptAnalysisTask<IterateMuons>(cfgc, TaskName{"iterate-muons"}),
adaptAnalysisTask<IterateMuonsSparse>(cfgc, TaskName{"iterate-muons-sparse"}),
};
}