AliPhysics  608b256 (608b256)
AliAnalysisTaskEmcalSoftDropResponse.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 ALIANALYSISTASKEMCALSOFTDROPRESPONSE_H
28 #define ALIANALYSISTASKEMCALSOFTDROPRESPONSE_H
29 
30 #include <vector>
32 
33 class RooUnfoldResponse;
34 class TBinning;
35 class TH2;
36 class TRandom;
37 
38 namespace PWGJE{
39 
40 namespace EMCALJetTasks {
41 
43 public:
48  };
50  kCAAlgo = 0,
51  kKTAlgo = 1,
53  };
54 
56  AliAnalysisTaskEmcalSoftDropResponse(const char *name);
58 
59  void SetBinningMode(EBinningMode_t binmode) { fBinningMode = binmode; }
62  void SetFractionResponseClosure(Double_t fracClosure) { fFractionResponseClosure = fracClosure; }
63  void SetBeta(double beta) { fBeta = beta; }
64  void SetZcut(double zcut) { fZcut = zcut; }
66  void SetSampleFraction(Double_t samplefraction) { fSampleFraction = samplefraction; }
67  void SetUseChargedConstituents(bool doUse) { fUseChargedConstituents = doUse; }
68  void SetUseNeutralConstituents(bool doUse) { fUseNeutralConstituents = doUse; }
69  void SetNameMCParticleContainer(const char *name) { fNameMCParticles = name; }
70 
71  static AliAnalysisTaskEmcalSoftDropResponse *AddTaskEmcalSoftDropResponse(Double_t jetradius, AliJetContainer::EJetType_t jettype, AliJetContainer::ERecoScheme_t recombinationScheme, const char *namepartcont, const char *trigger);
72 
73 protected:
74  virtual void UserCreateOutputObjects();
75  virtual Bool_t CheckMCOutliers();
76  virtual bool Run();
77 
80  TBinning *GetZgBinning() const;
81 
82  std::vector<double> MakeSoftdrop(const AliEmcalJet &jet, double jetradius, const AliParticleContainer *tracks, const AliClusterContainer *clusters) const;
83 
84 private:
85 
91  Double32_t fSampleFraction;
95  TRandom *fSampleSplitter;
96  TRandom *fSampleTrimmer;
99  RooUnfoldResponse *fZgResponse;
100  RooUnfoldResponse *fZgResponseClosure;
108 
111 
113 
114 };
115 
116 }
117 
118 }
119 
120 
121 #endif
double Double_t
Definition: External.C:58
TH2 * fZgPartLevelClosureNoResp
! Zg vs. pt at particle level for closure test (jets not used for response)
TH2 * fZgPartLevelClosureResp
! Zg vs. pt at particle level for closure test (jets used for response)
AliAnalysisTaskEmcalSoftDropResponse & operator=(const AliAnalysisTaskEmcalSoftDropResponse &)
TH2 * fZgDetLevelClosureNoResp
! Zg vs. pt at detector level for closure test (jets not used for response)
TH2 * fZgPartLevelTruncated
! Zg vs. pt at particle level after truncation at
TH2 * fZgDetLevelClosureResp
! Zg vs. pt at detector level for closure test (jets used for response)
Interface for binnings used by the histogram handler.
Definition: TBinning.h:23
Container for particles within the EMCAL framework.
static AliAnalysisTaskEmcalSoftDropResponse * AddTaskEmcalSoftDropResponse(Double_t jetradius, AliJetContainer::EJetType_t jettype, AliJetContainer::ERecoScheme_t recombinationScheme, const char *namepartcont, const char *trigger)
Double_t fFractionResponseClosure
Fraction of events used for the response matrix in the closure test.
virtual Bool_t CheckMCOutliers()
Filter the mc tails in pt-hard distributions.
virtual bool Run()
Run function. This is the core function of the analysis and contains the user code. Therefore users have to implement this function.
RooUnfoldResponse * fZgResponseClosure
! RooUnfold response for the closure test
Definition: External.C:220
Base task in the EMCAL jet framework.
Represent a jet reconstructed using the EMCal jet framework.
Definition: AliEmcalJet.h:51
Double32_t fSampleFraction
Fraction of statistics used for the analysis.
bool Bool_t
Definition: External.C:53
Container structure for EMCAL clusters.
std::vector< double > MakeSoftdrop(const AliEmcalJet &jet, double jetradius, const AliParticleContainer *tracks, const AliClusterContainer *clusters) const