IFNPlugin Contrib =============== This contrib provides a range of tools for studying Jet Flavour, provided jointly by several groups who are active on the subject (see [AUTHORS](AUTHORS)). It includes - [Common utilities](#common-utilities), notably the `FlavInfo` and `FlavHistory` classes in [`FlavInfo.hh`](FlavInfo.hh) - Interleaved Flavour Neutralisation ([IFNPlugin](#ifnplugin)) - [Further plugins and tools, still to be added] **The IFNPlugin code needs FastJet ≥ 3.4.1 to compile** Common Utilities ================ Various flavour-related utilities are to be found in [`FlavInfo.hh`](FlavInfo.hh): ```cpp // given a particle assign a pdg_id to it, either via a FlavInfo // (stores a static flavour) PseudoJet particle = ...; particle.set_user_info(new FlavInfo(pdg_id)); // or via a FlavHistory (can track the evolution of the flavour) // particle.set_user_info(new FlavHistory(pdg_id)); // Retrieve the amount of flavour of a given kind, e.g. amount of b-flavour // (example given for a particle with a FlavHistory) FlavInfo flav_info = FlavHistory::current_flavour_of(particle); // net amount of b-flavour int nb = flav_info[5]; cout << "nb = " << nb << ", full description: " << flav_info.description() << endl; ``` IFNPlugin ========= This code provides an implementation of the interleaved flavour-neutralisation (IFN) algorithm from > Flavoured jets with exact anti-kt kinematics and tests of infrared and collinear safety, > by Fabrizio Caola, Radoslaw Grabarczyk, Maxwell Hutt, Gavin P. Salam, Ludovic Scyboz, and Jesse Thaler > https://arxiv.org/abs/2306.07314 To learn how to use the library, the [`example-IFN.cc`](example-IFN.cc) code is a good place to get started. Main principles of IFN ---------------------- The IFN algorithm uses a base jet algorithm (anti-kt or C/A) and generates a clustering sequence that is kinematically equivalent to that base algorithm. At each clustering step, the algorithm checks whether it needs to perform flavour "neutralisation" of the particles involved in the clustering. The neutralisation can occur with other particles in the event, not involved in the kinematic clustering. Code Structure -------------- The main interface to the IFN algorithm is in [`IFNPlugin.hh`](IFNPlugin.hh): ```cpp // create a base jet definition JetDefinition base_jet_def(antikt_algorithm, R); // create an IFNPlugin based on the jet definition, with // a given alpha (recommended values, either 1 or 2) double alpha = 2.0; JetDefinition jet_def(new IFNPlugin(base_jet_def, alpha)); jet_def.delete_plugin_when_unused(); ``` The plugin can be used as standard with the FastJet package, e.g.: ```cpp vector particles; // ... fill the particles ... auto jets = jet_def(particles); for (const auto & jet : jets) { cout << "jet pt = " << jet.pt() << ", flav = " << FlavHistory::current_flavour_of(jet) << endl; } ```