32 #ifndef __FASTJET_WRAPPED_STRUCTURE_HH__ 33 #define __FASTJET_WRAPPED_STRUCTURE_HH__ 35 #include "fastjet/PseudoJetStructureBase.hh" 36 #include "fastjet/Error.hh" 38 FASTJET_BEGIN_NAMESPACE
58 : _structure(to_be_shared){
60 throw Error(
"Trying to construct a wrapped structure around an empty (NULL) structure");
68 return "PseudoJet wrapping the structure ("+_structure->description()+
")";
79 return _structure->has_associated_cluster_sequence();
85 return _structure->associated_cluster_sequence();
91 return _structure->has_valid_cluster_sequence();
97 return _structure->validated_cs();
103 return _structure->validated_csab();
123 return _structure->has_partner(reference, partner);
132 return _structure->has_child(reference, child);
142 return _structure->has_parents(reference, parent1, parent2);
150 const PseudoJet &jet)
const FASTJET_OVERRIDE{
151 return _structure->object_in_jet(reference, jet);
159 return _structure->has_constituents();
166 return _structure->constituents(reference);
171 return _structure->has_exclusive_subjets();
185 const double & dcut)
const FASTJET_OVERRIDE{
186 return _structure->exclusive_subjets(reference, dcut);
195 const double & dcut)
const FASTJET_OVERRIDE{
196 return _structure->n_exclusive_subjets(reference, dcut);
205 int nsub)
const FASTJET_OVERRIDE{
206 return _structure->exclusive_subjets_up_to (reference, nsub);
214 return _structure->exclusive_subdmerge(reference, nsub);
223 return _structure->exclusive_subdmerge_max(reference, nsub);
234 return _structure->has_pieces(reference);
240 virtual std::vector<PseudoJet>
pieces(
const PseudoJet &reference)
const FASTJET_OVERRIDE {
241 return _structure->pieces(reference);
252 return _structure->has_area();
259 return _structure->area(reference);
267 return _structure->area_error(reference);
274 return _structure->area_4vector(reference);
281 return _structure->is_pure_ghost(reference);
290 FASTJET_END_NAMESPACE
292 #endif // __FASTJET_PSEUDOJET_STRUCTURE_BASE_HH__ virtual bool has_constituents() const
return true if the structure supports constituents.
WrappedStructure(const SharedPtr< PseudoJetStructureBase > &to_be_shared)
default ctor the argument is the structure we need to wrap
virtual const ClusterSequence * associated_cluster_sequence() const
get a (const) pointer to the parent ClusterSequence (NULL if inexistent)
virtual std::vector< PseudoJet > pieces(const PseudoJet &reference) const
retrieve the pieces building the jet.
virtual bool is_pure_ghost(const PseudoJet &reference) const
true if this jet is made exclusively of ghosts.
virtual double exclusive_subdmerge(const PseudoJet &reference, int nsub) const
return the dij that was present in the merging nsub+1 -> nsub subjets inside this jet...
virtual ~WrappedStructure()
default (virtual) dtor
virtual double area(const PseudoJet &reference) const
return the jet (scalar) area.
virtual int n_exclusive_subjets(const PseudoJet &reference, const double &dcut) const
return the size of exclusive_subjets(...); still n ln n with same coefficient, but marginally more ef...
This wraps a (shared) pointer to an underlying structure.
virtual bool has_pieces(const PseudoJet &reference) const
return true if the structure supports pieces.
Contains any information related to the clustering that should be directly accessible to PseudoJet...
virtual double exclusive_subdmerge_max(const PseudoJet &reference, int nsub) const
return the maximum dij that occurred in the whole event at the stage that the nsub+1 -> nsub merge of...
virtual std::vector< PseudoJet > exclusive_subjets_up_to(const PseudoJet &reference, int nsub) const
return the list of subjets obtained by unclustering the supplied jet down to n subjets (or all consti...
virtual bool object_in_jet(const PseudoJet &reference, const PseudoJet &jet) const
check if the reference PseudoJet is contained the second one passed as argument.
virtual double area_error(const PseudoJet &reference) const
return the error (uncertainty) associated with the determination of the area of this jet...
virtual bool has_child(const PseudoJet &reference, PseudoJet &child) const
check if it has been recombined with another PseudoJet in which case, return its child through the ar...
base class that sets interface for extensions of ClusterSequence that provide information about the a...
virtual PseudoJet area_4vector(const PseudoJet &reference) const
return the jet 4-vector area.
base class corresponding to errors that can be thrown by FastJet
virtual const ClusterSequence * validated_cs() const
if the jet has a valid associated cluster sequence then return a pointer to it; otherwise throw an er...
virtual std::vector< PseudoJet > exclusive_subjets(const PseudoJet &reference, const double &dcut) const
return a vector of all subjets of the current jet (in the sense of the exclusive algorithm) that woul...
an implementation of C++0x shared pointers (or boost's)
virtual bool has_valid_cluster_sequence() const
returns true if this PseudoJet has an associated and still valid ClusterSequence. ...
virtual const ClusterSequenceAreaBase * validated_csab() const
if the jet has valid area information then return a pointer to the associated ClusterSequenceAreaBase...
virtual bool has_exclusive_subjets() const
return true if the structure supports exclusive_subjets.
virtual bool has_partner(const PseudoJet &reference, PseudoJet &partner) const
check if it has been recombined with another PseudoJet in which case, return its partner through the ...
virtual std::vector< PseudoJet > constituents(const PseudoJet &reference) const
retrieve the constituents.
virtual std::string description() const
description
virtual bool has_area() const
check if it has a defined area
SharedPtr< PseudoJetStructureBase > _structure
the wrapped structure
Class to contain pseudojets, including minimal information of use to jet-clustering routines...
virtual bool has_associated_cluster_sequence() const
returns true if there is an associated ClusterSequence
virtual bool has_parents(const PseudoJet &reference, PseudoJet &parent1, PseudoJet &parent2) const
check if it is the product of a recombination, in which case return the 2 parents through the 'parent...