Fork me on GitHub

source: git/modules/TreeWriter.h@ c61b5ce

Last change on this file since c61b5ce was d612dec, checked in by christinaw97 <christina.wang@…>, 3 years ago

Merge branch 'master' of github.com:Christinaw97/delphes into HEAD

  • Property mode set to 100644
File size: 2.7 KB
RevLine 
[b443089]1/*
2 * Delphes: a framework for fast simulation of a generic collider experiment
3 * Copyright (C) 2012-2014 Universite catholique de Louvain (UCL), Belgium
[1fa50c2]4 *
[b443089]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.
[1fa50c2]9 *
[b443089]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.
[1fa50c2]14 *
[b443089]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
[d7d2da3]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);
[d07e957]55 void ProcessVertices(ExRootTreeBranch *branch, TObjArray *array);
[d7d2da3]56 void ProcessTracks(ExRootTreeBranch *branch, TObjArray *array);
57 void ProcessTowers(ExRootTreeBranch *branch, TObjArray *array);
[4d7014e]58 void ProcessParticleFlowCandidates(ExRootTreeBranch *branch, TObjArray *array);
[d7d2da3]59 void ProcessPhotons(ExRootTreeBranch *branch, TObjArray *array);
60 void ProcessElectrons(ExRootTreeBranch *branch, TObjArray *array);
61 void ProcessMuons(ExRootTreeBranch *branch, TObjArray *array);
[a5af1df]62 void ProcessCscCluster(ExRootTreeBranch *branch, TObjArray *array);
[d7d2da3]63 void ProcessTauJets(ExRootTreeBranch *branch, TObjArray *array);
64 void ProcessJets(ExRootTreeBranch *branch, TObjArray *array);
65 void ProcessMissingET(ExRootTreeBranch *branch, TObjArray *array);
66 void ProcessScalarHT(ExRootTreeBranch *branch, TObjArray *array);
[71648c2]67 void ProcessRho(ExRootTreeBranch *branch, TObjArray *array);
[2e229c9]68 void ProcessWeight(ExRootTreeBranch *branch, TObjArray *array);
[8f7db23]69 void ProcessHectorHit(ExRootTreeBranch *branch, TObjArray *array);
[d7d2da3]70
[a5af1df]71
[c5e72d8]72#if !defined(__CINT__) && !defined(__CLING__)
[d7d2da3]73 typedef void (TreeWriter::*TProcessMethod)(ExRootTreeBranch *, TObjArray *); //!
74
[77e9ae1]75 typedef std::map<ExRootTreeBranch *, std::pair<TProcessMethod, TObjArray *> > TBranchMap; //!
[d7d2da3]76
77 TBranchMap fBranchMap; //!
78
[341014c]79 std::map<TClass *, TProcessMethod> fClassMap; //!
[d7d2da3]80#endif
81
[4d7014e]82 ClassDef(TreeWriter, 2)
[d7d2da3]83};
84
85#endif
Note: See TracBrowser for help on using the repository browser.