FastJet 3.4.3
|
Helps solve closest pair problems with factorised interparticle and beam distances (ie satisfying the FastJet lemma) that are on a cylindrical geometry and allow tiling. More...
#include <fastjet/NNFJN2Tiled.hh>
Public Member Functions | |
NNFJN2Tiled (const std::vector< PseudoJet > &jets, double requested_tile_size) | |
constructor with an initial set of jets (which will be assigned indices 0...jets.size()-1 ) | |
NNFJN2Tiled (const std::vector< PseudoJet > &jets, double requested_tile_size, I *info) | |
void | start (const std::vector< PseudoJet > &jets) |
initialisation from a given list of particles | |
double | dij_min (int &iA, int &iB) |
return the dij_min and indices iA, iB, for the corresponding jets. | |
void | remove_jet (int iA) |
remove the jet pointed to by index iA | |
void | merge_jets (int iA, int iB, const PseudoJet &jet, int jet_index) |
merge the jets pointed to by indices A and B and replace them with jet, assigning it an index jet_index. | |
~NNFJN2Tiled () | |
a destructor | |
Public Member Functions inherited from fastjet::NNBase< I > | |
NNBase () | |
Default constructor. | |
NNBase (I *info) | |
Constuctor with additional Info. | |
Public Member Functions inherited from fastjet::NNInfo< I > | |
NNInfo (I *info) | |
template<class BJ > | |
void | init_jet (BJ *briefjet, const fastjet::PseudoJet &jet, int index) |
Helps solve closest pair problems with factorised interparticle and beam distances (ie satisfying the FastJet lemma) that are on a cylindrical geometry and allow tiling.
(see NNBase.hh for an introductory description)
This variant provides an implementation based on the N2Tiled clustering strategy in FastJet. As for the NNFJN2Plain case, the interparticle and beam distances should be of the form
Additionally, the NNFJN2Tiled class takes a tile_size parameter that controls the size of the tiles. It must be such that, for any two points in non-neighbouring (and non-identical) tiles, the geometrical distance between the 2 points is larger than the geometrical beam distance of each of the 2 points.
It is templated with a BJ (brief jet) class and can be used with or without an extra "Information" template, i.e. NNFJN2Tiled<BJ> or NNFJN2Tiled<BJ,I>
For the NNFJN2Tiled<BJ> version of the class to function, BJ must provide three member functions
For the NNFJN2Tiled<BJ,I> version to function, the BJ::init(...) member must accept an extra argument
NOTE: THE DISTANCE MUST BE SYMMETRIC I.E. SATISFY
Finally, the BJ class needs to provide access to the variables used for the rectangular tiling:
Note that you are strongly advised to add the following lines to your BJ class to allow it to be used also with NNH:
Definition at line 113 of file NNFJN2Tiled.hh.
|
inline |
constructor with an initial set of jets (which will be assigned indices 0...jets.size()-1
)
Definition at line 118 of file NNFJN2Tiled.hh.
|
inline |
Definition at line 120 of file NNFJN2Tiled.hh.
|
inline |
a destructor
Definition at line 137 of file NNFJN2Tiled.hh.
|
virtual |
initialisation from a given list of particles
Implements fastjet::NNBase< I >.
Definition at line 272 of file NNFJN2Tiled.hh.
|
virtual |
return the dij_min and indices iA, iB, for the corresponding jets.
If iB < 0 then iA recombines with the beam
Implements fastjet::NNBase< I >.
Definition at line 334 of file NNFJN2Tiled.hh.
|
virtual |
remove the jet pointed to by index iA
Implements fastjet::NNBase< I >.
Definition at line 359 of file NNFJN2Tiled.hh.
|
virtual |
merge the jets pointed to by indices A and B and replace them with jet, assigning it an index jet_index.
Implements fastjet::NNBase< I >.
Definition at line 410 of file NNFJN2Tiled.hh.