AliPhysics  d0bc297 (d0bc297)
AliEmcalClusterJetConstituent.cxx
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  ************************************************************************************/
28 
32 
33 namespace PWG {
34 namespace JETFW {
35 
36 AliEmcalClusterJetConstituent::AliEmcalClusterJetConstituent() :
38  fkCaloCluster(nullptr),
39  fDefaultEnergyDefinition(AliVCluster::kUserDefEnergy1),
40  fPVec()
41 {
42 }
43 
44 
45 AliEmcalClusterJetConstituent::AliEmcalClusterJetConstituent(const AliVCluster *const clust, AliVCluster::VCluUserDefEnergy_t energydef, Double_t *pvec):
47  fkCaloCluster(clust),
48  fDefaultEnergyDefinition(energydef),
49  fPVec(pvec)
50 {
51 }
52 
55  fkCaloCluster(clust),
56  fDefaultEnergyDefinition(AliVCluster::kUserDefEnergy1),
57  fPVec()
58 {
59 }
60 
65  fPVec(other.fPVec)
66 {
67 }
68 
70  AliEmcalJetConstituent::operator=(other);
71 
72  if(this != &other){
75  fPVec = other.fPVec;
76  }
77  return *this;
78 }
79 
81  if(!fkCaloCluster || !rhs.fkCaloCluster) return false;
82  return fkCaloCluster->GetUniqueID() == rhs.fkCaloCluster->GetUniqueID();
83 }
84 
85 
87 
88 }
89 
91  return fPVec.X();
92 }
93 
95  return fPVec.Y();
96 }
97 
99  return fPVec.Z();
100 }
101 
103  return fPVec.Pt();
104 }
105 
107  return fkCaloCluster ? fkCaloCluster->GetUserDefEnergy(fDefaultEnergyDefinition): 0;
108 }
109 
111  return fPVec.Eta();
112 }
113 
115  return fPVec.Phi();
116 }
117 
118 }
119 }
double Double_t
Definition: External.C:58
AliEmcalClusterJetConstituent & operator=(const AliEmcalClusterJetConstituent &other)
Assignment operator Constituent object is non-owning, therefore shallow copy is sufficient.
virtual double E() const
Access to constituent energy.
virtual double Py() const
Access to y-component of the momentum vector.
Namespace for objects belonging to the ALICE jet framework.
virtual double Px() const
Access to x-component of the momentum vector.
const AliVCluster * fkCaloCluster
Underlying calorimeter cluster.
virtual double Phi() const
Access to azimuthal angle.
Interface class for constituent objects (clusters / particles) in an ALICE jet.
AliVCluster::VCluUserDefEnergy_t fDefaultEnergyDefinition
Default energy definition used in jetfinder.
virtual double Eta() const
Access to pseudorapidity.
Namespace for PWG framework classes.
Implementation of a jet constituent for constituent clusters.
bool operator==(const AliEmcalClusterJetConstituent &rhs) const
Check for equality Check done on the cluster itself.
virtual double Pt() const
Access to transverse momentum.
virtual double Pz() const
Access to z-component of the momentum vector.