AliPhysics  master (3d17d9d)
AliAnalysisTaskEmcalSoftDropData.h
Go to the documentation of this file.
1 /************************************************************************************
2  * Copyright (C) 2019, Copyright Holders of the ALICE Collaboration *
3  * All rights reserved. *
4  * *
5  * Redistribution and use in source and binary forms, with or without *
6  * modification, are permitted provided that the following conditions are met: *
7  * * Redistributions of source code must retain the above copyright *
8  * notice, this list of conditions and the following disclaimer. *
9  * * Redistributions in binary form must reproduce the above copyright *
10  * notice, this list of conditions and the following disclaimer in the *
11  * documentation and/or other materials provided with the distribution. *
12  * * Neither the name of the <organization> nor the *
13  * names of its contributors may be used to endorse or promote products *
14  * derived from this software without specific prior written permission. *
15  * *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND *
17  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED *
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE *
19  * DISCLAIMED. IN NO EVENT SHALL ALICE COLLABORATION BE LIABLE FOR ANY *
20  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES *
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; *
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND *
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT *
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
25  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
26  ************************************************************************************/
27 #ifndef ALIANALYSISTASKEMCALSOFTDROPDATA_H
28 #define ALIANALYSISTASKEMCALSOFTDROPDATA_H
29 
31 #include <string>
32 #include <vector>
33 
34 class TBinning;
35 class THistManager;
36 
37 namespace PWGJE{
38 
39 namespace EMCALJetTasks {
40 
42 public:
44  kCAAlgo = 0,
45  kKTAlgo = 1,
47  };
48 
52 
53  void SetCustomPtBinning(TBinning *binning) { fPtBinning = binning; }
54  void SetBeta(double beta) { fBeta = beta; }
55  void SetZcut(double zcut) { fZcut = zcut; }
57  void SetUseChargedConstituents(bool doUse) { fUseChargedConstituents = doUse; }
58  void SetUseNeutralConstituents(bool doUse) { fUseNeutralConstituents = doUse; }
59  void SetSelectTrigger(UInt_t triggerbits, const char *triggerstring) { fTriggerBits = triggerbits; fTriggerString = triggerstring; }
61 
63 
64 protected:
65  virtual void UserCreateOutputObjects();
66  virtual void RunChanged(Int_t newrun);
67  virtual Bool_t IsTriggerSelected();
68  virtual Bool_t Run();
69 
71  TBinning *GetZgBinning() const;
72  TBinning *GetRgBinning(double R) const;
73 
75  std::vector<double> MakeSoftdrop(const AliEmcalJet &jet, double jetradius, const AliParticleContainer *tracks, const AliClusterContainer *clusters) const;
76 
77 private:
79  std::string fTriggerString;
88 
90 };
91 
92 }
93 
94 }
95 
96 #endif
double Double_t
Definition: External.C:58
virtual Bool_t IsTriggerSelected()
Selection of a hardware trigger.
Interface for binnings used by the histogram handler.
Definition: TBinning.h:23
static AliAnalysisTaskEmcalSoftDropData * AddTaskEmcalSoftDropData(Double_t jetradius, AliJetContainer::EJetType_t jettype, AliJetContainer::ERecoScheme_t recombinationScheme, EMCAL_STRINGVIEW trigger)
Container for particles within the EMCAL framework.
int Int_t
Definition: External.C:63
virtual Bool_t Run()
Run function. This is the core function of the analysis and contains the user code. Therefore users have to implement this function.
unsigned int UInt_t
Definition: External.C:33
void SetSelectTrigger(UInt_t triggerbits, const char *triggerstring)
virtual void RunChanged(Int_t newrun)
Process tasks relevant when a file with a different run number is processed.
std::vector< double > MakeSoftdrop(const AliEmcalJet &jet, double jetradius, const AliParticleContainer *tracks, const AliClusterContainer *clusters) const
#define EMCAL_STRINGVIEW
Base task in the EMCAL jet framework.
Represent a jet reconstructed using the EMCal jet framework.
Definition: AliEmcalJet.h:51
Container class for histograms.
Definition: THistManager.h:99
bool Bool_t
Definition: External.C:53
Container structure for EMCAL clusters.