Skip to content

Commit 2d33373

Browse files
committed
starting new general table producer for two tracks
1 parent 20d1e4e commit 2d33373

2 files changed

Lines changed: 942 additions & 0 deletions

File tree

Lines changed: 226 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,226 @@
1+
// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
2+
// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
3+
// All rights not expressly granted are reserved.
4+
//
5+
// This software is distributed under the terms of the GNU General Public
6+
// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
7+
//
8+
// In applying this license CERN does not waive the privileges and immunities
9+
// granted to it by virtue of its status as an Intergovernmental Organization
10+
// or submit itself to any jurisdiction.
11+
12+
///
13+
/// \file TwoTracksEventTables.h
14+
/// \author Roman Lavička
15+
/// \since 2025-06-20
16+
/// \brief A table to store information about events preselected to have exactly two tracks.
17+
/// \brief Good for UPC gammagamma (->elel,mumu,tautau) and gammalead (vector mesons)
18+
/// \bried If MC, careful with filling the mother
19+
///
20+
21+
#ifndef ALISW_TWOTRACKSEVENTTABLES_H
22+
#define ALISW_TWOTRACKSEVENTTABLES_H
23+
24+
#include "Framework/AnalysisDataModel.h"
25+
26+
namespace o2::aod
27+
{
28+
namespace two_tracks_tree
29+
{
30+
// event info
31+
DECLARE_SOA_COLUMN(RunNumber, runNumber, int32_t);
32+
DECLARE_SOA_COLUMN(Bc, bc, int);
33+
DECLARE_SOA_COLUMN(TotalTracks, totalTracks, int);
34+
DECLARE_SOA_COLUMN(NumContrib, numContrib, int);
35+
DECLARE_SOA_COLUMN(GlobalNonPVtracks, globalNonPVtracks, int);
36+
DECLARE_SOA_COLUMN(PosX, posX, float);
37+
DECLARE_SOA_COLUMN(PosY, posY, float);
38+
DECLARE_SOA_COLUMN(PosZ, posZ, float);
39+
DECLARE_SOA_COLUMN(RecoMode, recoMode, int);
40+
DECLARE_SOA_COLUMN(OccupancyInTime, occupancyInTime, int);
41+
DECLARE_SOA_COLUMN(HadronicRate, hadronicRate, double);
42+
DECLARE_SOA_COLUMN(Trs, trs, int);
43+
DECLARE_SOA_COLUMN(Trofs, trofs, int);
44+
DECLARE_SOA_COLUMN(Hmpr, hmpr, int);
45+
DECLARE_SOA_COLUMN(Tfb, tfb, int);
46+
DECLARE_SOA_COLUMN(ItsRofb, itsRofb, int);
47+
DECLARE_SOA_COLUMN(Sbp, sbp, int);
48+
DECLARE_SOA_COLUMN(ZvtxFT0vsPv, zvtxFT0vsPv, int);
49+
DECLARE_SOA_COLUMN(VtxITSTPC, vtxITSTPC, int);
50+
// FIT info
51+
DECLARE_SOA_COLUMN(TotalFT0AmplitudeA, totalFT0AmplitudeA, float);
52+
DECLARE_SOA_COLUMN(TotalFT0AmplitudeC, totalFT0AmplitudeC, float);
53+
DECLARE_SOA_COLUMN(TotalFV0AmplitudeA, totalFV0AmplitudeA, float);
54+
DECLARE_SOA_COLUMN(EnergyCommonZNA, energyCommonZNA, float);
55+
DECLARE_SOA_COLUMN(EnergyCommonZNC, energyCommonZNC, float);
56+
DECLARE_SOA_COLUMN(TimeFT0A, timeFT0A, float);
57+
DECLARE_SOA_COLUMN(TimeFT0C, timeFT0C, float);
58+
DECLARE_SOA_COLUMN(TimeFV0A, timeFV0A, float);
59+
DECLARE_SOA_COLUMN(TimeZNA, timeZNA, float);
60+
DECLARE_SOA_COLUMN(TimeZNC, timeZNC, float);
61+
// tracks
62+
DECLARE_SOA_COLUMN(TrkPx, trkPx, float[2]);
63+
DECLARE_SOA_COLUMN(TrkPy, trkPy, float[2]);
64+
DECLARE_SOA_COLUMN(TrkPz, trkPz, float[2]);
65+
DECLARE_SOA_COLUMN(TrkSign, trkSign, int[2]);
66+
DECLARE_SOA_COLUMN(TrkDCAxy, trkDCAxy, float[2]);
67+
DECLARE_SOA_COLUMN(TrkDCAz, trkDCAz, float[2]);
68+
DECLARE_SOA_COLUMN(TrkTimeRes, trkTimeRes, float[2]);
69+
DECLARE_SOA_COLUMN(Trk1ITSclusterSizes, trk1ITSclusterSizes, uint32_t);
70+
DECLARE_SOA_COLUMN(Trk2ITSclusterSizes, trk2ITSclusterSizes, uint32_t);
71+
DECLARE_SOA_COLUMN(TrkTPCsignal, trkTPCsignal, float[2]);
72+
DECLARE_SOA_COLUMN(TrkTPCnSigmaEl, trkTPCnSigmaEl, float[2]);
73+
DECLARE_SOA_COLUMN(TrkTPCnSigmaMu, trkTPCnSigmaMu, float[2]);
74+
DECLARE_SOA_COLUMN(TrkTPCnSigmaPi, trkTPCnSigmaPi, float[2]);
75+
DECLARE_SOA_COLUMN(TrkTPCnSigmaKa, trkTPCnSigmaKa, float[2]);
76+
DECLARE_SOA_COLUMN(TrkTPCnSigmaPr, trkTPCnSigmaPr, float[2]);
77+
DECLARE_SOA_COLUMN(TrkTPCinnerParam, trkTPCinnerParam, float[2]);
78+
DECLARE_SOA_COLUMN(TrkTOFsignal, trkTOFsignal, float[2]);
79+
DECLARE_SOA_COLUMN(TrkTOFnSigmaEl, trkTOFnSigmaEl, float[2]);
80+
DECLARE_SOA_COLUMN(TrkTOFnSigmaMu, trkTOFnSigmaMu, float[2]);
81+
DECLARE_SOA_COLUMN(TrkTOFnSigmaPi, trkTOFnSigmaPi, float[2]);
82+
DECLARE_SOA_COLUMN(TrkTOFnSigmaKa, trkTOFnSigmaKa, float[2]);
83+
DECLARE_SOA_COLUMN(TrkTOFnSigmaPr, trkTOFnSigmaPr, float[2]);
84+
DECLARE_SOA_COLUMN(TrkTOFexpMom, trkTOFexpMom, float[2]);
85+
// truth event
86+
DECLARE_SOA_COLUMN(TrueChannel, trueChannel, int);
87+
DECLARE_SOA_COLUMN(TrueHasRecoColl, trueHasRecoColl, bool);
88+
DECLARE_SOA_COLUMN(TruePosX, truePosX, float);
89+
DECLARE_SOA_COLUMN(TruePosY, truePosY, float);
90+
DECLARE_SOA_COLUMN(TruePosZ, truePosZ, float);
91+
// truth particles
92+
DECLARE_SOA_COLUMN(TrueMotherPx, trueTauPx, float[2]);
93+
DECLARE_SOA_COLUMN(TrueMotherPy, trueTauPy, float[2]);
94+
DECLARE_SOA_COLUMN(TrueMotherPz, trueTauPz, float[2]);
95+
DECLARE_SOA_COLUMN(TrueDaugPx, trueDaugPx, float[2]);
96+
DECLARE_SOA_COLUMN(TrueDaugPy, trueDaugPy, float[2]);
97+
DECLARE_SOA_COLUMN(TrueDaugPz, trueDaugPz, float[2]);
98+
DECLARE_SOA_COLUMN(TrueDaugPdgCode, trueDaugPdgCode, int[2]);
99+
// additional info
100+
DECLARE_SOA_COLUMN(ProblematicEvent, problematicEvent, bool);
101+
102+
} // namespace two_tracks_tree
103+
DECLARE_SOA_TABLE(TwoTracks, "AOD", "TWOTRACK",
104+
two_tracks_tree::RunNumber,
105+
two_tracks_tree::Bc,
106+
two_tracks_tree::TotalTracks,
107+
two_tracks_tree::NumContrib,
108+
two_tracks_tree::GlobalNonPVtracks,
109+
two_tracks_tree::PosX,
110+
two_tracks_tree::PosY,
111+
two_tracks_tree::PosZ,
112+
two_tracks_tree::RecoMode,
113+
two_tracks_tree::OccupancyInTime,
114+
two_tracks_tree::HadronicRate,
115+
two_tracks_tree::Trs,
116+
two_tracks_tree::Trofs,
117+
two_tracks_tree::Hmpr,
118+
two_tracks_tree::Tfb,
119+
two_tracks_tree::ItsRofb,
120+
two_tracks_tree::Sbp,
121+
two_tracks_tree::ZvtxFT0vsPv,
122+
two_tracks_tree::VtxITSTPC,
123+
two_tracks_tree::TotalFT0AmplitudeA,
124+
two_tracks_tree::TotalFT0AmplitudeC,
125+
two_tracks_tree::TotalFV0AmplitudeA,
126+
two_tracks_tree::EnergyCommonZNA,
127+
two_tracks_tree::EnergyCommonZNC,
128+
two_tracks_tree::TimeFT0A,
129+
two_tracks_tree::TimeFT0C,
130+
two_tracks_tree::TimeFV0A,
131+
two_tracks_tree::TimeZNA,
132+
two_tracks_tree::TimeZNC,
133+
two_tracks_tree::TrkPx,
134+
two_tracks_tree::TrkPy,
135+
two_tracks_tree::TrkPz,
136+
two_tracks_tree::TrkSign,
137+
two_tracks_tree::TrkDCAxy,
138+
two_tracks_tree::TrkDCAz,
139+
two_tracks_tree::TrkTimeRes,
140+
two_tracks_tree::Trk1ITSclusterSizes,
141+
two_tracks_tree::Trk2ITSclusterSizes,
142+
two_tracks_tree::TrkTPCsignal,
143+
two_tracks_tree::TrkTPCnSigmaEl,
144+
two_tracks_tree::TrkTPCnSigmaMu,
145+
two_tracks_tree::TrkTPCnSigmaPi,
146+
two_tracks_tree::TrkTPCnSigmaKa,
147+
two_tracks_tree::TrkTPCnSigmaPr,
148+
two_tracks_tree::TrkTPCinnerParam,
149+
two_tracks_tree::TrkTOFsignal,
150+
two_tracks_tree::TrkTOFnSigmaEl,
151+
two_tracks_tree::TrkTOFnSigmaMu,
152+
two_tracks_tree::TrkTOFnSigmaPi,
153+
two_tracks_tree::TrkTOFnSigmaKa,
154+
two_tracks_tree::TrkTOFnSigmaPr,
155+
two_tracks_tree::TrkTOFexpMom);
156+
157+
DECLARE_SOA_TABLE(TrueTwoTracks, "AOD", "TRUETWOTRACK",
158+
two_tracks_tree::RunNumber,
159+
two_tracks_tree::Bc,
160+
two_tracks_tree::TotalTracks,
161+
two_tracks_tree::NumContrib,
162+
two_tracks_tree::GlobalNonPVtracks,
163+
two_tracks_tree::PosX,
164+
two_tracks_tree::PosY,
165+
two_tracks_tree::PosZ,
166+
two_tracks_tree::RecoMode,
167+
two_tracks_tree::OccupancyInTime,
168+
two_tracks_tree::HadronicRate,
169+
two_tracks_tree::Trs,
170+
two_tracks_tree::Trofs,
171+
two_tracks_tree::Hmpr,
172+
two_tracks_tree::Tfb,
173+
two_tracks_tree::ItsRofb,
174+
two_tracks_tree::Sbp,
175+
two_tracks_tree::ZvtxFT0vsPv,
176+
two_tracks_tree::VtxITSTPC,
177+
two_tracks_tree::TotalFT0AmplitudeA,
178+
two_tracks_tree::TotalFT0AmplitudeC,
179+
two_tracks_tree::TotalFV0AmplitudeA,
180+
two_tracks_tree::EnergyCommonZNA,
181+
two_tracks_tree::EnergyCommonZNC,
182+
two_tracks_tree::TimeFT0A,
183+
two_tracks_tree::TimeFT0C,
184+
two_tracks_tree::TimeFV0A,
185+
two_tracks_tree::TimeZNA,
186+
two_tracks_tree::TimeZNC,
187+
two_tracks_tree::TrkPx,
188+
two_tracks_tree::TrkPy,
189+
two_tracks_tree::TrkPz,
190+
two_tracks_tree::TrkSign,
191+
two_tracks_tree::TrkDCAxy,
192+
two_tracks_tree::TrkDCAz,
193+
two_tracks_tree::TrkTimeRes,
194+
two_tracks_tree::Trk1ITSclusterSizes,
195+
two_tracks_tree::Trk2ITSclusterSizes,
196+
two_tracks_tree::TrkTPCsignal,
197+
two_tracks_tree::TrkTPCnSigmaEl,
198+
two_tracks_tree::TrkTPCnSigmaMu,
199+
two_tracks_tree::TrkTPCnSigmaPi,
200+
two_tracks_tree::TrkTPCnSigmaKa,
201+
two_tracks_tree::TrkTPCnSigmaPr,
202+
two_tracks_tree::TrkTPCinnerParam,
203+
two_tracks_tree::TrkTOFsignal,
204+
two_tracks_tree::TrkTOFnSigmaEl,
205+
two_tracks_tree::TrkTOFnSigmaMu,
206+
two_tracks_tree::TrkTOFnSigmaPi,
207+
two_tracks_tree::TrkTOFnSigmaKa,
208+
two_tracks_tree::TrkTOFnSigmaPr,
209+
two_tracks_tree::TrkTOFexpMom,
210+
two_tracks_tree::TrueChannel,
211+
two_tracks_tree::TrueHasRecoColl,
212+
two_tracks_tree::TruePosX,
213+
two_tracks_tree::TruePosY,
214+
two_tracks_tree::TruePosZ,
215+
two_tracks_tree::TrueMotherPx,
216+
two_tracks_tree::TrueMotherPy,
217+
two_tracks_tree::TrueMotherPz,
218+
two_tracks_tree::TrueDaugPx,
219+
two_tracks_tree::TrueDaugPy,
220+
two_tracks_tree::TrueDaugPz,
221+
two_tracks_tree::TrueDaugPdgCode,
222+
two_tracks_tree::ProblematicEvent);
223+
224+
} // namespace o2::aod
225+
226+
#endif // ALISW_TWOTRACKSEVENTTABLES_H

0 commit comments

Comments
 (0)