siscone::Csplit_merge Class Reference Class used to split and merge jets. More...
Inheritance diagram for siscone::Csplit_merge:
Collaboration diagram for siscone::Csplit_merge:
Detailed DescriptionClass used to split and merge jets. Definition at line 180 of file split_merge.h. Constructor & Destructor Documentation◆ Csplit_merge()
default ctor Definition at line 226 of file split_merge.cpp. References indices, merge_identical_protocones, siscone::Csplit_merge_ptcomparison::particles, particles, siscone::Csplit_merge_ptcomparison::pt, pt, ptcomparison, SM_var2_hardest_cut_off, and stable_cone_soft_pt2_cutoff. ◆ ~Csplit_merge()
Member Function Documentation◆ add_hardest_protocone_to_jets()
remove the hardest protocone and declare it a jet
The list of remaining particles (and the uncollinear-hard ones) is updated. Definition at line 571 of file split_merge.cpp. References siscone::Cjet::contents, siscone::Cmomentum::eta, siscone::Cmomentum::index, siscone::Csplit_merge::Cuser_scale_base::is_larger(), jets, merge_collinear_and_remove_soft(), siscone::Cjet::n, n_left, n_pass, p_remain, siscone::Cmomentum::parent_index, particles, siscone::Cmomentum::perp2(), siscone::Cmomentum::phi, pt, siscone::Cjet::pt_tilde, ptcomparison, siscone::Cjet::range, siscone::Cjet::sm_var2, twopi, and siscone::Cjet::v. Referenced by siscone::Csiscone::compute_jets_progressive_removal(). ◆ add_protocones()
add a list of protocones
Definition at line 460 of file split_merge.cpp. References siscone::Cjet::contents, siscone::Cmomentum::eta, siscone::Cmomentum::index, merge_collinear_and_remove_soft(), siscone::Cjet::n, n_left, n_pass, p_remain, siscone::Cmomentum::parent_index, particles, siscone::Cmomentum::phi, pt, siscone::Cjet::pt_tilde, siscone::Cjet::range, twopi, and siscone::Cjet::v. Referenced by siscone::Csiscone::compute_jets(), init(), and siscone::Csiscone::recompute_jets(). ◆ full_clear()
full clearance Definition at line 389 of file split_merge.cpp. References indices, partial_clear(), and particles. Referenced by init_particles(), and ~Csplit_merge(). ◆ init()
initialisation function
Definition at line 265 of file split_merge.cpp. References add_protocones(). ◆ init_particles()
initialisation function for particle list
Definition at line 274 of file split_merge.cpp. References full_clear(), indices, init_pleft(), n, siscone::Csplit_merge_ptcomparison::particles, particles, siscone::Csplit_merge_ptcomparison::pt, pt, and ptcomparison. Referenced by siscone::Csiscone::compute_jets(), and siscone::Csiscone::compute_jets_progressive_removal(). ◆ init_pleft()
build initial list of left particles for the Ceta_phi_range static member! for the Ceta_phi_range static member! Definition at line 303 of file split_merge.cpp. References siscone::Ceta_phi_range::eta_max, siscone::Ceta_phi_range::eta_min, merge_collinear_and_remove_soft(), n, n_left, n_pass, p_remain, and particles. Referenced by init_particles(), and siscone::Csiscone::recompute_jets(). ◆ merge_collinear_and_remove_soft()
build the list 'p_uncol_hard' from p_remain by clustering collinear particles and removing particles softer than stable_cone_soft_pt2_cutoff note that thins in only used for stable-cone detection so the parent_index field is unnecessary Definition at line 406 of file split_merge.cpp. References EPSILON_COLLINEAR, n_left, p_remain, p_uncol_hard, stable_cone_soft_pt2_cutoff, and twopi. Referenced by add_hardest_protocone_to_jets(), add_protocones(), and init_pleft(). ◆ partial_clear()
partial clearance Definition at line 364 of file split_merge.cpp. References jets, merge_identical_protocones, most_ambiguous_split, p_remain, and ptcomparison. Referenced by siscone::Csiscone::compute_jets(), siscone::Csiscone::compute_jets_progressive_removal(), full_clear(), and siscone::Csiscone::recompute_jets(). ◆ perform()
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.
Definition at line 716 of file split_merge.cpp. References jets, particles, show(), and SM_var2_hardest_cut_off. Referenced by siscone::Csiscone::compute_jets(), and siscone::Csiscone::recompute_jets(). ◆ save_contents()
save final jets
Definition at line 829 of file split_merge.cpp. References siscone::Cmomentum::build_etaphi(), siscone::Cjet::contents, siscone::Cmomentum::eta, jets, siscone::Cjet::n, particles, siscone::Cmomentum::perp(), siscone::Cmomentum::phi, and siscone::Cjet::v. ◆ set_pt_weighted_splitting()
use a pt-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 226 of file split_merge.h. ◆ set_user_scale()
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 280 of file split_merge.h. ◆ show()
show jets/candidates status Definition at line 859 of file split_merge.cpp. References siscone::Cjet::contents, siscone::Cmomentum::E, jets, siscone::Cjet::n, siscone::Cmomentum::px, siscone::Cmomentum::py, siscone::Cmomentum::pz, siscone::Cjet::sm_var2, and siscone::Cjet::v. Referenced by perform(). ◆ user_scale()
return the user-defined scale (NULL if none) Definition at line 285 of file split_merge.h. Member Data Documentation◆ idx_size
number of elements in indices1 Definition at line 364 of file split_merge.h. ◆ indices
maximal size array for indices works Definition at line 363 of file split_merge.h. Referenced by Csplit_merge(), full_clear(), and init_particles(). ◆ jets
list of jets Definition at line 360 of file split_merge.h. Referenced by add_hardest_protocone_to_jets(), siscone::Carea::compute_active_areas(), siscone::Carea::compute_areas(), siscone::Csiscone::compute_jets_progressive_removal(), siscone::Carea::compute_passive_areas(), partial_clear(), perform(), save_contents(), and show(). ◆ 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 374 of file split_merge.h. Referenced by Csplit_merge(), and partial_clear(). ◆ 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 357 of file split_merge.h. Referenced by partial_clear(). ◆ n
number of particles Definition at line 346 of file split_merge.h. Referenced by siscone::Carea::compute_active_areas(), siscone::Carea::compute_areas(), siscone::Carea::compute_passive_areas(), init_particles(), and init_pleft(). ◆ n_left
numer of particles that does not belong to any jet Definition at line 349 of file split_merge.h. Referenced by add_hardest_protocone_to_jets(), add_protocones(), siscone::Csiscone::compute_jets(), siscone::Csiscone::compute_jets_progressive_removal(), init_pleft(), and merge_collinear_and_remove_soft(). ◆ n_pass
index of the run Definition at line 352 of file split_merge.h. Referenced by add_hardest_protocone_to_jets(), add_protocones(), and init_pleft(). ◆ p_remain
list of particles remaining to deal with Definition at line 350 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
list of particles remaining with collinear clustering Definition at line 351 of file split_merge.h. Referenced by siscone::Csiscone::compute_jets(), siscone::Csiscone::compute_jets_progressive_removal(), and merge_collinear_and_remove_soft(). ◆ particles
list of particles Definition at line 347 of file split_merge.h. Referenced by add_hardest_protocone_to_jets(), add_protocones(), Csplit_merge(), full_clear(), init_particles(), init_pleft(), perform(), and save_contents(). ◆ pt
list of particles' pt Definition at line 348 of file split_merge.h. Referenced by add_hardest_protocone_to_jets(), add_protocones(), Csplit_merge(), and init_particles(). ◆ ptcomparison
member used for detailed comparisons of pt's Definition at line 377 of file split_merge.h. Referenced by add_hardest_protocone_to_jets(), siscone::Csiscone::compute_jets(), siscone::Csiscone::compute_jets_progressive_removal(), Csplit_merge(), init_particles(), partial_clear(), and siscone::Csiscone::recompute_jets(). ◆ 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 385 of file split_merge.h. Referenced by siscone::Carea::compute_active_areas(), siscone::Carea::compute_areas(), Csplit_merge(), and perform(). ◆ stable_cone_soft_pt2_cutoff
pt 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 394 of file split_merge.h. Referenced by siscone::Carea::compute_passive_areas(), Csplit_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 |