AliPhysics  6fe3466 (6fe3466)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
AliMCParticleContainer Class Reference

Container for MC-true particles within the EMCAL framework. More...

#include <AliMCParticleContainer.h>

Inheritance diagram for AliMCParticleContainer:

Public Member Functions

 AliMCParticleContainer ()
 
 AliMCParticleContainer (const char *name)
 
virtual ~AliMCParticleContainer ()
 
virtual Bool_t ApplyMCParticleCuts (const AliAODMCParticle *vp, UInt_t &rejectionReason) const
 
virtual Bool_t AcceptObject (Int_t i, UInt_t &rejectionReason) const
 
virtual Bool_t AcceptObject (const TObject *obj, UInt_t &rejectionReason) const
 
virtual Bool_t AcceptParticle (Int_t i, UInt_t &rejectionReason) const
 
virtual Bool_t AcceptParticle (const AliVParticle *vp, UInt_t &rejectionReason) const
 
virtual Bool_t AcceptMCParticle (const AliAODMCParticle *vp, UInt_t &rejectionReason) const
 
virtual Bool_t AcceptMCParticle (Int_t i, UInt_t &rejectionReason) const
 
virtual AliAODMCParticle * GetMCParticleWithLabel (Int_t lab) const
 
virtual AliAODMCParticle * GetAcceptMCParticleWithLabel (Int_t lab)
 
virtual AliAODMCParticle * GetLeadingMCParticle (const char *opt="")
 
virtual AliAODMCParticle * GetMCParticle (Int_t i=-1) const
 
virtual AliAODMCParticle * GetAcceptMCParticle (Int_t i=-1) const
 
virtual AliAODMCParticle * GetNextAcceptMCParticle ()
 
virtual AliAODMCParticle * GetNextMCParticle ()
 
virtual AliVParticle * GetParticle (Int_t i=-1) const
 
virtual AliVParticle * GetAcceptParticle (Int_t i=-1) const
 
virtual AliVParticle * GetNextAcceptParticle ()
 
virtual AliVParticle * GetNextParticle ()
 
void SetMCFlag (UInt_t m)
 
void SelectPhysicalPrimaries (Bool_t s)
 
const char * GetTitle () const
 
const
AliMCParticleIterableContainer 
all () const
 
const
AliMCParticleIterableContainer 
accepted () const
 
const
AliMCParticleIterableMomentumContainer 
all_momentum () const
 
const
AliMCParticleIterableMomentumContainer 
accepted_momentum () const
 
- Public Member Functions inherited from AliParticleContainer
 AliParticleContainer ()
 
 AliParticleContainer (const char *name)
 
virtual ~AliParticleContainer ()
 
virtual TObjectoperator[] (int index) const
 
virtual Bool_t ApplyParticleCuts (const AliVParticle *vp, UInt_t &rejectionReason) const
 
virtual Bool_t ApplyKinematicCuts (const AliTLorentzVector &mom, UInt_t &rejectionReason) const
 
Double_t GetParticlePtCut () const
 
Double_t GetParticleEtaMin () const
 
Double_t GetParticleEtaMax () const
 
Double_t GetParticlePhiMin () const
 
Double_t GetParticlePhiMax () const
 
void SetParticlePtCut (Double_t cut)
 
void SetParticleEtaLimits (Double_t min, Double_t max)
 
void SetParticlePhiLimits (Double_t min, Double_t max)
 
virtual AliVParticle * GetLeadingParticle (const char *opt="")
 
virtual Bool_t GetMomentumFromParticle (TLorentzVector &mom, const AliVParticle *part, Double_t mass) const
 
virtual Bool_t GetMomentumFromParticle (TLorentzVector &mom, const AliVParticle *part) const
 
virtual Bool_t GetMomentum (TLorentzVector &mom, Int_t i) const
 
virtual Bool_t GetAcceptMomentum (TLorentzVector &mom, Int_t i) const
 
virtual Bool_t GetNextMomentum (TLorentzVector &mom)
 
virtual Bool_t GetNextAcceptMomentum (TLorentzVector &mom)
 
Int_t GetNParticles () const
 
Int_t GetNAcceptedParticles () const
 
void SetMinDistanceTPCSectorEdge (Double_t min)
 
void SetCharge (EChargeCut_t c)
 
void SelectHIJING (Bool_t s)
 
void SetGeneratorIndex (Short_t i)
 
const char * GetTitle () const
 
const AliParticleIterableContainer all () const
 
const AliParticleIterableContainer accepted () const
 
const
AliParticleIterableMomentumContainer 
all_momentum () const
 
const
AliParticleIterableMomentumContainer 
accepted_momentum () const
 

Protected Attributes

UInt_t fMCFlag
 select MC particles with flags More...
 
- Protected Attributes inherited from AliParticleContainer
Double_t fMinDistanceTPCSectorEdge
 require minimum distance to edge of TPC sector edge More...
 
EChargeCut_t fChargeCut
 select particles according to their charge More...
 
Short_t fGeneratorIndex
 select MC particles with generator index (default = -1 = switch off selection) More...
 

Private Member Functions

 AliMCParticleContainer (const AliMCParticleContainer &obj)
 
AliMCParticleContaineroperator= (const AliMCParticleContainer &other)
 

Additional Inherited Members

- Public Types inherited from AliParticleContainer
enum  EChargeCut_t {
  kNoChargeCut, kCharged, kNeutral, kPositiveCharge,
  kNegativeCharge
}
 

Detailed Description

Container for MC-true particles within the EMCAL framework.

Author
Salvatore Aiola salva.nosp@m.tore.nosp@m..aiol.nosp@m.a@ce.nosp@m.rn.ch, Yale University

Definition at line 24 of file AliMCParticleContainer.h.

Constructor & Destructor Documentation

AliMCParticleContainer::AliMCParticleContainer ( )

Default constructor.

Definition at line 21 of file AliMCParticleContainer.cxx.

AliMCParticleContainer::AliMCParticleContainer ( const char *  name)

Standard constructor.

Parameters
[in]nameName of the container (= name of the array operated on)

Definition at line 33 of file AliMCParticleContainer.cxx.

virtual AliMCParticleContainer::~AliMCParticleContainer ( )
inlinevirtual

Definition at line 29 of file AliMCParticleContainer.h.

AliMCParticleContainer::AliMCParticleContainer ( const AliMCParticleContainer obj)
private

Member Function Documentation

const AliMCParticleIterableContainer AliMCParticleContainer::accepted ( ) const

Create an iterable container interface over accepted objects in the EMCAL container.

Returns
iterable container over accepted objects in the EMCAL container

Definition at line 211 of file AliMCParticleContainer.cxx.

Referenced by AliAnalysisTaskIDFragmentationFunction::FillHistograms(), and AliHFAODMCParticleContainer::IsSpecialPDGFound().

const AliMCParticleIterableMomentumContainer AliMCParticleContainer::accepted_momentum ( ) const

Create an iterable container interface over accepted objects in the EMCAL container.

Returns
iterable container over accepted objects in the EMCAL container

Definition at line 229 of file AliMCParticleContainer.cxx.

Referenced by AliEmcalTrackingQATask::FillHistograms(), and AliAnalysisTaskPWGJEQA::FillTrackHistograms().

Bool_t AliMCParticleContainer::AcceptMCParticle ( const AliAODMCParticle *  vp,
UInt_t rejectionReason 
) const
virtual

Perform full MC particle selection for the particle vp, consisting of kinematical particle selection and MC-specific cuts

Parameters
[in]vpParticle to be checked
[in]rejectionReasonBitmap encoding the reason why the particle was rejected. Note: The variable is not set to NULL inside this function before changing its value.
Returns
True if the particle is accepted, false otherwise

Reimplemented in AliHFAODMCParticleContainer.

Definition at line 143 of file AliMCParticleContainer.cxx.

Referenced by AliHFAODMCParticleContainer::AcceptMCParticle(), AcceptObject(), AcceptParticle(), and GetAcceptMCParticle().

Bool_t AliMCParticleContainer::AcceptMCParticle ( Int_t  i,
UInt_t rejectionReason 
) const
virtual

Perform full MC particle selection for the particle vp, consisting of kinematical particle selection and MC-specific cuts

Parameters
[in]iIndex of the particle to check
[in]rejectionReasonBitmap encoding the reason why the particle was rejected. Note: The variable is not set to NULL inside this function before changing its value.
Returns
True if the particle is accepted, false otherwise

Reimplemented in AliHFAODMCParticleContainer.

Definition at line 164 of file AliMCParticleContainer.cxx.

virtual Bool_t AliMCParticleContainer::AcceptObject ( Int_t  i,
UInt_t rejectionReason 
) const
inlinevirtual

Reimplemented from AliParticleContainer.

Definition at line 32 of file AliMCParticleContainer.h.

virtual Bool_t AliMCParticleContainer::AcceptObject ( const TObject obj,
UInt_t rejectionReason 
) const
inlinevirtual

Reimplemented from AliParticleContainer.

Definition at line 33 of file AliMCParticleContainer.h.

virtual Bool_t AliMCParticleContainer::AcceptParticle ( Int_t  i,
UInt_t rejectionReason 
) const
inlinevirtual

Perform full particle selection consisting of kinematical and particle property selection on the \( i^{th} \) particle in the array. In case the particle is rejected, the reason for the rejection is encoded in the bitmap rejectionReason.

Parameters
[in]iIndex of the particle to select.
[out]rejectionReasonBitmap with the reason why the particle was accepted. Note: The value is not set to 0 in the function in order to combine the information with other selection steps.
Returns
True if the particle was accepted, false otherwise

Reimplemented from AliParticleContainer.

Definition at line 34 of file AliMCParticleContainer.h.

virtual Bool_t AliMCParticleContainer::AcceptParticle ( const AliVParticle *  vp,
UInt_t rejectionReason 
) const
inlinevirtual

Perform full particle selection consisting of kinematical and particle property selection on the particle provided. In case the particle is rejected, the reason for the rejection is encoded in the bitmap rejectionReason.

Parameters
vpParticle for which to perform the selection
rejectionReasonBitmap with the reason why the particle was accepted. Note: The value is not set to 0 in the function in order to combine the information with other selection steps.
Returns
True if the particle is accepted, false otherwise.

Reimplemented from AliParticleContainer.

Definition at line 35 of file AliMCParticleContainer.h.

const AliMCParticleIterableContainer AliMCParticleContainer::all ( ) const

Create an iterable container interface over all objects in the EMCAL container.

Returns
iterable container over all objects in the EMCAL container

Definition at line 202 of file AliMCParticleContainer.cxx.

Referenced by AliAnalysisTaskEmcal::CheckMCOutliers().

const AliMCParticleIterableMomentumContainer AliMCParticleContainer::all_momentum ( ) const

Create an iterable container interface over all objects in the EMCAL container.

Returns
iterable container over all objects in the EMCAL container

Definition at line 220 of file AliMCParticleContainer.cxx.

Referenced by AliAnalysisTaskDmesonJets::FillPartonLevelHistograms().

Bool_t AliMCParticleContainer::ApplyMCParticleCuts ( const AliAODMCParticle *  vp,
UInt_t rejectionReason 
) const
virtual

Apply MC particle cuts, e.g. primary particle selection.

Parameters
[in]vpParticle to be checked
[in]rejectionReasonBitmap encoding the reason why the particle was rejected. Note: The variable is not set to NULL inside this function before changing its value.
Returns
True if the particle is accepted, false otherwise

Definition at line 184 of file AliMCParticleContainer.cxx.

Referenced by AcceptMCParticle().

AliAODMCParticle * AliMCParticleContainer::GetAcceptMCParticle ( Int_t  i = -1) const
virtual

Get track at index in the container

Parameters
[in]iIndex of the particle in the container
Returns
pointer to particle if particle is accepted, NULL otherwise

Definition at line 81 of file AliMCParticleContainer.cxx.

Referenced by GetAcceptMCParticleWithLabel(), GetAcceptParticle(), and GetNextAcceptMCParticle().

AliAODMCParticle * AliMCParticleContainer::GetAcceptMCParticleWithLabel ( Int_t  lab)
virtual

Get MC particle using the MC label

Parameters
[in]labLabel of the particle
Returns
pointer to particle if particle is found and accepted, NULL otherwise

Definition at line 57 of file AliMCParticleContainer.cxx.

Referenced by AliEmcalTrackingQATask::FillHistograms(), and AliAnalysisTaskPWGJEQA::FillTrackHistograms().

virtual AliVParticle* AliMCParticleContainer::GetAcceptParticle ( Int_t  i = -1) const
inlinevirtual

Get \( i^{th} \) particle in the container if it is accepted. In case it is not accepted a nullpointer is returned.

Parameters
[in]iIndex of the particle
Returns
Particle at the index if it is accepted, NULL otherwise

Reimplemented from AliParticleContainer.

Definition at line 46 of file AliMCParticleContainer.h.

virtual AliAODMCParticle* AliMCParticleContainer::GetLeadingMCParticle ( const char *  opt = "")
inlinevirtual

Definition at line 40 of file AliMCParticleContainer.h.

AliAODMCParticle * AliMCParticleContainer::GetMCParticle ( Int_t  i = -1) const
virtual

Get track at index in the container

Parameters
[in]iIndex of the particle in the container
Returns
pointer to particle if particle is found, NULL otherwise

Definition at line 68 of file AliMCParticleContainer.cxx.

Referenced by AcceptMCParticle(), AliHFAODMCParticleContainer::AcceptMCParticle(), AliAnalysisTaskDmesonJets::FillPartonLevelHistograms(), GetAcceptMCParticle(), GetMCParticleWithLabel(), GetNextMCParticle(), GetParticle(), and AliAnalysisTaskDmesonJets::AnalysisEngine::RunParticleLevelAnalysis().

AliAODMCParticle * AliMCParticleContainer::GetMCParticleWithLabel ( Int_t  lab) const
virtual
AliAODMCParticle * AliMCParticleContainer::GetNextAcceptMCParticle ( )
virtual

Get next accepted particle in the container selected using the track cuts provided.

Deprecated:
Old style iterator - for compatibility reasons, use AliParticleContainer::accept_iterator instead
Returns
Next accepted particle (NULL if the end of the array is reached)

Definition at line 101 of file AliMCParticleContainer.cxx.

Referenced by GetNextAcceptParticle().

virtual AliVParticle* AliMCParticleContainer::GetNextAcceptParticle ( )
inlinevirtual

Iterator over accepted particles in the container. Get the next accepted particle in the array. If the end is reached, NULL is returned.

Deprecated:
Only for backward compatibility - use accept_iterator instead
Returns
Next accepted particle in the array (NULL if the end is reached)

Reimplemented from AliParticleContainer.

Definition at line 47 of file AliMCParticleContainer.h.

AliAODMCParticle * AliMCParticleContainer::GetNextMCParticle ( )
virtual

Get next particle in the container

Deprecated:
Old style iterator - for compatibility reasons, use AliParticleContainer::all_iterator instead
Returns
Next track in the container (NULL if end of the container is reached)

Definition at line 119 of file AliMCParticleContainer.cxx.

Referenced by GetNextParticle().

virtual AliVParticle* AliMCParticleContainer::GetNextParticle ( )
inlinevirtual

Iterator over all particles in the container. Get the next particle in the array. If the end is reached, NULL is returned.

Deprecated:
Only for backward compatibility - use all_iterator instead.
Returns
Next particle in the array (NULL if the end is reached)

Reimplemented from AliParticleContainer.

Definition at line 48 of file AliMCParticleContainer.h.

virtual AliVParticle* AliMCParticleContainer::GetParticle ( Int_t  i = -1) const
inlinevirtual

Get \( i^{th} \) particle in the container.

Parameters
[in]iIndex of the particle to access
Returns
Parrticle at the given index (NULL if the index is out of range)

Reimplemented from AliParticleContainer.

Definition at line 45 of file AliMCParticleContainer.h.

const char * AliMCParticleContainer::GetTitle ( ) const

Build title of the container consisting of the container name and a string encoding the minimum \( p_{t} \) cut applied in the kinematic particle selection.

Returns
Title of the container

Definition at line 239 of file AliMCParticleContainer.cxx.

AliMCParticleContainer& AliMCParticleContainer::operator= ( const AliMCParticleContainer other)
private
void AliMCParticleContainer::SelectPhysicalPrimaries ( Bool_t  s)
inline
void AliMCParticleContainer::SetMCFlag ( UInt_t  m)
inline

Definition at line 50 of file AliMCParticleContainer.h.

Member Data Documentation

UInt_t AliMCParticleContainer::fMCFlag
protected

select MC particles with flags

Definition at line 64 of file AliMCParticleContainer.h.

Referenced by ApplyMCParticleCuts(), SelectPhysicalPrimaries(), and SetMCFlag().


The documentation for this class was generated from the following files: