AliPhysics  9b6b435 (9b6b435)
AliAnalysisTaskEmcalJetEnergySpectrum.h
Go to the documentation of this file.
1 /************************************************************************************
2  * Copyright (C) 2017, 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 __ALINANLYSISTASKJETENERGYSPECTRUM_H__
28 #define __ALINANLYSISTASKJETENERGYSPECTRUM_H__
29 
31 #include <vector>
32 #include <TArrayD.h>
33 
34 class THistManager;
35 class AliEventCuts;
36 
37 namespace EmcalTriggerJets {
38 
40 public:
54  };
56  AliAnalysisTaskEmcalJetEnergySpectrum(const char *name);
58 
59  void SetIsMC(bool isMC) { fIsMC = isMC; }
60  void SetNameJetContainer(const char *name) { fNameJetContainer = name; }
62  void SetTriggerSelection(UInt_t triggerbits, const char *triggerstring) {
63  fTriggerSelectionBits = triggerbits;
64  fTriggerSelectionString = triggerstring;
65  }
66  void SetUseDownscaleWeight(bool doUse) { fUseDownscaleWeight = doUse; }
67  void SetUseAliEventCuts(bool doUse) { fUseAliEventCuts = doUse; }
69  void SetRequireSubsetMB(bool doRequire, ULong_t minbiastrigger = AliVEvent::kAny) { fRequireSubsetMB = doRequire; fMinBiasTrigger = minbiastrigger; }
70  void SetUserPtBinning(int nbins, double *binning) { fUserPtBinning.Set(nbins+1, binning); }
71  void SetRequestCentrality(bool doRequest) { fRequestCentrality = doRequest; }
72  void SetRequestTriggerClusters(bool doRequest) { fRequestTriggerClusters = doRequest; }
73  void SetCentralityEstimator(const char *centest) { fCentralityEstimator = centest; }
74 
75  static AliAnalysisTaskEmcalJetEnergySpectrum *AddTaskJetEnergySpectrum(Bool_t isMC, AliJetContainer::EJetType_t jettype, double radius, const char *trigger, const char *suffix = "");
76 
77 protected:
78  virtual void UserCreateOutputObjects();
79  virtual bool Run();
80  virtual bool IsEventSelected();
81  virtual bool IsTriggerSelected();
82  virtual Bool_t CheckMCOutliers();
83  virtual void RunChanged(Int_t newrun);
84  std::vector<TriggerCluster_t> GetTriggerClusterIndices(const TString &triggerstring) const;
85  bool IsSelectEmcalTriggers(const std::string &triggerstring) const;
86  std::string MatchTrigger(const std::string &striggerstring);
87 
88 private:
91 
93  AliEventCuts *fEventCuts;
108 
110 };
111 
112 }
113 #endif
void SetRequireSubsetMB(bool doRequire, ULong_t minbiastrigger=AliVEvent::kAny)
AliEventCuts * fEventCuts
Event cuts as implemented in AliEventCuts.
Bool_t fRequireSubsetMB
Require for triggers to be a subset of Min. Bias (for efficiency studies)
static AliAnalysisTaskEmcalJetEnergySpectrum * AddTaskJetEnergySpectrum(Bool_t isMC, AliJetContainer::EJetType_t jettype, double radius, const char *trigger, const char *suffix="")
std::vector< TriggerCluster_t > GetTriggerClusterIndices(const TString &triggerstring) const
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.
int Int_t
Definition: External.C:63
unsigned int UInt_t
Definition: External.C:33
ULong_t fMinBiasTrigger
Min bias trigger for trigger subset (for efficiency studies)
void SetTriggerSelection(UInt_t triggerbits, const char *triggerstring)
unsigned long ULong_t
Definition: External.C:38
Bool_t fRequestTriggerClusters
Request distinction of trigger clusters.
virtual void RunChanged(Int_t newrun)
Process tasks relevant when a file with a different run number is processed.
Bool_t fUseTriggerSelectionForData
Use trigger selection on data (require trigger patch in addition to trigger selection string) ...
Bool_t isMC
Base task in the EMCAL jet framework.
Container class for histograms.
Definition: THistManager.h:99
AliAnalysisTaskEmcalJetEnergySpectrum & operator=(const AliAnalysisTaskEmcalJetEnergySpectrum &)
const Int_t nbins
bool Bool_t
Definition: External.C:53