siscone is hosted by Hepforge, IPPP Durham

The SISCone Jet Algorithm

Version 3.0.6



SISCone 3.0.6
siscone_spherical::CSphsplit_merge Class Reference

Class used to split and merge jets. More...

#include <split_merge.h>

Inheritance diagram for siscone_spherical::CSphsplit_merge:
Collaboration diagram for siscone_spherical::CSphsplit_merge:

Classes

class  Cuser_scale_base
 base class for user-defined ordering of stable cones More...
 

Public Member Functions

 CSphsplit_merge ()
 default ctor More...
 
 ~CSphsplit_merge ()
 default dtor More...
 
int init (std::vector< CSphmomentum > &_particles, std::vector< CSphmomentum > *protocones, double R2, double Emin=0.0)
 initialisation function More...
 
int init_particles (std::vector< CSphmomentum > &_particles)
 initialisation function for particle list More...
 
int init_pleft ()
 build initial list of left particles More...
 
int set_E_weighted_splitting (bool _use_E_weighted_splitting)
 use an energy-dependent boundary for splitting When called with true, the criterium for splitting two protojets will be to compare D1^2/kt1^2 vs. More...
 
int partial_clear ()
 partial clearance More...
 
int full_clear ()
 full clearance More...
 
void set_user_scale (const Cuser_scale_base *user_scale_in)
 associate a user-defined scale to order the stable cones More...
 
const Cuser_scale_baseuser_scale () const
 return the user-defined scale (NULL if none) More...
 
int merge_collinear_and_remove_soft ()
 build the list 'p_uncol_hard' from p_remain by clustering collinear particles note that thins in only used for stable-cone detection so the parent_index field is unnecessary More...
 
int add_protocones (std::vector< CSphmomentum > *protocones, double R2, double Emin=0.0)
 add a list of protocones More...
 
int add_hardest_protocone_to_jets (std::vector< CSphmomentum > *protocones, double R2, double Emin=0.0)
 remove the hardest protocone and declare it a a jet More...
 
int perform (double overlap_tshold, double Emin=0.0)
 really do the splitting and merging At the end, the vector jets is filled with the jets found. More...
 
int save_contents (FILE *flux)
 save final jets More...
 
int show ()
 show jets/candidates status More...
 

Public Attributes

int n
 number of particles More...
 
std::vector< CSphmomentumparticles
 list of particles More...
 
std::vector< double > particles_norm2
 norm^2 of the particle (3-vect part) More...
 
int n_left
 numer of particles that does not belong to any jet More...
 
std::vector< CSphmomentump_remain
 list of particles remaining to deal with More...
 
std::vector< CSphmomentump_uncol_hard
 list of particles remaining with collinear clustering More...
 
int n_pass
 index of the run More...
 
double most_ambiguous_split
 minimal difference in squared distance between a particle and two overlapping protojets when doing a split (useful when testing approx. More...
 
std::vector< CSphjetjets
 list of jets More...
 
int * indices
 maximal size array for indices works More...
 
int idx_size
 number of elements in indices1 More...
 
bool merge_identical_protocones
 The following flag indicates that identical protocones are to be merged automatically each time around the split-merge loop and before anything else happens. More...
 
CSphsplit_merge_ptcomparison ptcomparison
 member used for detailed comparisons of pt's More...
 
double SM_var2_hardest_cut_off
 stop split–merge or progressive-removal when the squared SM_var of the hardest protojet is below this cut-off. More...
 
double stable_cone_soft_E2_cutoff
 Energy cutoff for the particles to put in p_uncol_hard this is meant to allow removing soft particles in the stable-cone search. More...
 

Detailed Description

Class used to split and merge jets.

Definition at line 175 of file split_merge.h.

Constructor & Destructor Documentation

◆ CSphsplit_merge()

◆ ~CSphsplit_merge()

siscone_spherical::CSphsplit_merge::~CSphsplit_merge ( )

default dtor

Definition at line 260 of file split_merge.cpp.

References full_clear().

Member Function Documentation

◆ add_hardest_protocone_to_jets()

int siscone_spherical::CSphsplit_merge::add_hardest_protocone_to_jets ( std::vector< CSphmomentum > *  protocones,
double  R2,
double  Emin = 0.0 
)

◆ add_protocones()

◆ full_clear()

int siscone_spherical::CSphsplit_merge::full_clear ( )

full clearance

Definition at line 386 of file split_merge.cpp.

References indices, partial_clear(), and particles.

Referenced by init_particles(), and ~CSphsplit_merge().

◆ init()

int siscone_spherical::CSphsplit_merge::init ( std::vector< CSphmomentum > &  _particles,
std::vector< CSphmomentum > *  protocones,
double  R2,
double  Emin = 0.0 
)

initialisation function

Parameters
_particleslist of particles
protoconeslist of protocones (initial jet candidates)
R2cone radius (squared)
Eminminimal energy allowed for jets
Returns
0 on success, 1 on error

Definition at line 271 of file split_merge.cpp.

References add_protocones().

◆ init_particles()

int siscone_spherical::CSphsplit_merge::init_particles ( std::vector< CSphmomentum > &  _particles)

◆ init_pleft()

int siscone_spherical::CSphsplit_merge::init_pleft ( )

build initial list of left particles

Definition at line 310 of file split_merge.cpp.

References merge_collinear_and_remove_soft(), n, n_left, n_pass, p_remain, and particles.

Referenced by init_particles(), and siscone_spherical::CSphsiscone::recompute_jets().

◆ merge_collinear_and_remove_soft()

int siscone_spherical::CSphsplit_merge::merge_collinear_and_remove_soft ( )

build the list 'p_uncol_hard' from p_remain by clustering collinear particles note that thins in only used for stable-cone detection so the parent_index field is unnecessary

Note that soft particles are not removed here This is just a remnant from the trunk version

Definition at line 403 of file split_merge.cpp.

References EPSILON_COLLINEAR, n_left, p_remain, p_uncol_hard, stable_cone_soft_E2_cutoff, and twopi.

Referenced by add_hardest_protocone_to_jets(), add_protocones(), and init_pleft().

◆ partial_clear()

◆ perform()

int siscone_spherical::CSphsplit_merge::perform ( double  overlap_tshold,
double  Emin = 0.0 
)

really do the splitting and merging At the end, the vector jets is filled with the jets found.

the 'contents' field of each jets contains the indices of the particles included in that jet.

Parameters
overlap_tsholdthreshold for splitting/merging transition
Eminminimal energy allowed for jets
Returns
the number of jets is returned

Definition at line 715 of file split_merge.cpp.

References jets, particles, show(), and SM_var2_hardest_cut_off.

Referenced by siscone_spherical::CSphsiscone::compute_jets(), and siscone_spherical::CSphsiscone::recompute_jets().

◆ save_contents()

int siscone_spherical::CSphsplit_merge::save_contents ( FILE *  flux)

◆ set_E_weighted_splitting()

int siscone_spherical::CSphsplit_merge::set_E_weighted_splitting ( bool  _use_E_weighted_splitting)
inline

use an energy-dependent boundary for splitting When called with true, the criterium for splitting two protojets will be to compare D1^2/kt1^2 vs.

D2^2/kt2^2, the (anti-)kt-weighted distance instead of the plain distance D1^2 vs. D2^2. This can be set in order to produce more circular hard jets, with the same underlying philosophy as for the anti-kt algorithm. We thus expect a behaviour closer to the IterativeCone one. By default, we use the standard D1^2 vs. D2^2 comparison and this function is not called.

Definition at line 221 of file split_merge.h.

◆ set_user_scale()

void siscone_spherical::CSphsplit_merge::set_user_scale ( const Cuser_scale_base user_scale_in)
inline

associate a user-defined scale to order the stable cones

Note that this is only used in "progressive-removal mode", e.g. in add_hardest_protocone_to_jets().

Definition at line 275 of file split_merge.h.

◆ show()

◆ user_scale()

const Cuser_scale_base * siscone_spherical::CSphsplit_merge::user_scale ( ) const
inline

return the user-defined scale (NULL if none)

Definition at line 280 of file split_merge.h.

Member Data Documentation

◆ idx_size

int siscone_spherical::CSphsplit_merge::idx_size

number of elements in indices1

Definition at line 361 of file split_merge.h.

◆ indices

int* siscone_spherical::CSphsplit_merge::indices

maximal size array for indices works

Definition at line 360 of file split_merge.h.

Referenced by CSphsplit_merge(), full_clear(), and init_particles().

◆ jets

std::vector<CSphjet> siscone_spherical::CSphsplit_merge::jets

◆ merge_identical_protocones

bool siscone_spherical::CSphsplit_merge::merge_identical_protocones

The following flag indicates that identical protocones are to be merged automatically each time around the split-merge loop and before anything else happens.

This flag is only effective if ALLOW_MERGE_IDENTICAL_PROTOCONES is set in 'defines.h' Note that this lead to infrared-unsafety so it is disabled by default

Definition at line 371 of file split_merge.h.

Referenced by CSphsplit_merge(), and partial_clear().

◆ most_ambiguous_split

double siscone_spherical::CSphsplit_merge::most_ambiguous_split

minimal difference in squared distance between a particle and two overlapping protojets when doing a split (useful when testing approx.

collinear safety)

Definition at line 354 of file split_merge.h.

Referenced by partial_clear().

◆ n

int siscone_spherical::CSphsplit_merge::n

number of particles

Definition at line 343 of file split_merge.h.

Referenced by init_particles(), and init_pleft().

◆ n_left

int siscone_spherical::CSphsplit_merge::n_left

◆ n_pass

int siscone_spherical::CSphsplit_merge::n_pass

index of the run

Definition at line 349 of file split_merge.h.

Referenced by add_hardest_protocone_to_jets(), add_protocones(), and init_pleft().

◆ p_remain

std::vector<CSphmomentum> siscone_spherical::CSphsplit_merge::p_remain

list of particles remaining to deal with

Definition at line 347 of file split_merge.h.

Referenced by add_hardest_protocone_to_jets(), add_protocones(), init_pleft(), merge_collinear_and_remove_soft(), and partial_clear().

◆ p_uncol_hard

std::vector<CSphmomentum> siscone_spherical::CSphsplit_merge::p_uncol_hard

list of particles remaining with collinear clustering

Definition at line 348 of file split_merge.h.

Referenced by siscone_spherical::CSphsiscone::compute_jets(), siscone_spherical::CSphsiscone::compute_jets_progressive_removal(), and merge_collinear_and_remove_soft().

◆ particles

std::vector<CSphmomentum> siscone_spherical::CSphsplit_merge::particles

◆ particles_norm2

std::vector<double> siscone_spherical::CSphsplit_merge::particles_norm2

norm^2 of the particle (3-vect part)

Definition at line 345 of file split_merge.h.

Referenced by CSphsplit_merge(), and init_particles().

◆ ptcomparison

◆ SM_var2_hardest_cut_off

double siscone_spherical::CSphsplit_merge::SM_var2_hardest_cut_off

stop split–merge or progressive-removal when the squared SM_var of the hardest protojet is below this cut-off.

Note that this is a signed square (ie SM_var*|SM_var|) to be able to handle negative values.

Note that the cut-off is set on the variable squared.

Definition at line 382 of file split_merge.h.

Referenced by CSphsplit_merge(), and perform().

◆ stable_cone_soft_E2_cutoff

double siscone_spherical::CSphsplit_merge::stable_cone_soft_E2_cutoff

Energy cutoff for the particles to put in p_uncol_hard this is meant to allow removing soft particles in the stable-cone search.

This is not collinear-safe so you should not use this variable unless you really know what you are doing Note that the cut-off is set on the variable squared.

Definition at line 391 of file split_merge.h.

Referenced by CSphsplit_merge(), and merge_collinear_and_remove_soft().


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

The SISCone project has been developed by Gavin Salam and Gregory Soyez
Documentation generated on Tue Jun 20 2023 18:08:37 for SISCone by  Doxygen 1.9.4