Fork me on GitHub

source: git/modules/TreeWriter.h @ 341014c

ImprovedOutputFileTimingllp
Last change on this file since 341014c was 341014c, checked in by Pavel Demin <pavel-demin@…>, 18 months ago

apply .clang-format to all .h, .cc and .cpp files

  • Property mode set to 100644
File size: 2.6 KB
Line 
1/*
2 *  Delphes: a framework for fast simulation of a generic collider experiment
3 *  Copyright (C) 2012-2014  Universite catholique de Louvain (UCL), Belgium
4 *
5 *  This program is free software: you can redistribute it and/or modify
6 *  it under the terms of the GNU General Public License as published by
7 *  the Free Software Foundation, either version 3 of the License, or
8 *  (at your option) any later version.
9 *
10 *  This program is distributed in the hope that it will be useful,
11 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 *  GNU General Public License for more details.
14 *
15 *  You should have received a copy of the GNU General Public License
16 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
17 */
18
19#ifndef TreeWriter_h
20#define TreeWriter_h
21
22/** \class TreeWriter
23 *
24 *  Fills ROOT tree branches.
25 *
26 *  \author P. Demin - UCL, Louvain-la-Neuve
27 *
28 */
29
30#include "classes/DelphesModule.h"
31
32#include <map>
33
34class TClass;
35class TObjArray;
36class TRefArray;
37
38class Candidate;
39class ExRootTreeBranch;
40
41class TreeWriter: public DelphesModule
42{
43public:
44  TreeWriter();
45  ~TreeWriter();
46
47  void Init();
48  void Process();
49  void Finish();
50
51private:
52  void FillParticles(Candidate *candidate, TRefArray *array);
53
54  void ProcessParticles(ExRootTreeBranch *branch, TObjArray *array);
55  void ProcessVertices(ExRootTreeBranch *branch, TObjArray *array);
56  void ProcessTracks(ExRootTreeBranch *branch, TObjArray *array);
57  void ProcessTowers(ExRootTreeBranch *branch, TObjArray *array);
58  void ProcessPhotons(ExRootTreeBranch *branch, TObjArray *array);
59  void ProcessElectrons(ExRootTreeBranch *branch, TObjArray *array);
60  void ProcessMuons(ExRootTreeBranch *branch, TObjArray *array);
61  void ProcessTauJets(ExRootTreeBranch *branch, TObjArray *array);
62  void ProcessJets(ExRootTreeBranch *branch, TObjArray *array);
63  void ProcessMissingET(ExRootTreeBranch *branch, TObjArray *array);
64  void ProcessScalarHT(ExRootTreeBranch *branch, TObjArray *array);
65  void ProcessRho(ExRootTreeBranch *branch, TObjArray *array);
66  void ProcessWeight(ExRootTreeBranch *branch, TObjArray *array);
67  void ProcessHectorHit(ExRootTreeBranch *branch, TObjArray *array);
68
69#if !defined(__CINT__) && !defined(__CLING__)
70  typedef void (TreeWriter::*TProcessMethod)(ExRootTreeBranch *, TObjArray *); //!
71
72  typedef std::map<ExRootTreeBranch *, std::pair<TProcessMethod, TObjArray *>> TBranchMap; //!
73
74  TBranchMap fBranchMap; //!
75
76  std::map<TClass *, TProcessMethod> fClassMap; //!
77#endif
78
79  ClassDef(TreeWriter, 1)
80};
81
82#endif
Note: See TracBrowser for help on using the repository browser.