Iguana 1.0.0
Implementation Guardian of Analysis Algorithms
Loading...
Searching...
No Matches
Algorithm.h
1#pragma once
2
3#include "iguana/algorithms/Algorithm.h"
5#include <Math/Vector3D.h>
6#include <Math/Vector4D.h>
7
8namespace iguana::physics {
9
36 {
37
39
40 public:
41
42 void Start(hipo::banklist& banks) override;
43 bool Run(hipo::banklist& banks) const override;
44 void Stop() override;
45
52 bool Run(
53 hipo::bank const& particle_bank,
54 hipo::bank const& inc_kin_bank,
55 hipo::bank& result_bank) const;
56
60 std::vector<std::pair<int, int>> PairHadrons(hipo::bank const& particle_bank) const;
61
62 private:
63
64 // banklist indices
65 hipo::banklist::size_type b_particle;
66 hipo::banklist::size_type b_inc_kin;
67 hipo::banklist::size_type b_result;
68
69 // `b_result` bank item indices
70 int i_pindex_a;
71 int i_pindex_b;
72 int i_pdg_a;
73 int i_pdg_b;
74 int i_Mh;
75 int i_z;
76 int i_PhPerp;
77 int i_MX2;
78 int i_xF;
79 int i_yB;
80 int i_phiH;
81 int i_phiR;
82 int i_theta;
83
84 // config options
85 std::set<int> o_hadron_a_pdgs;
86 std::set<int> o_hadron_b_pdgs;
87 std::string o_phi_r_method;
88 std::string o_theta_method;
89 enum { e_RT_via_covariant_kT } m_phi_r_method;
90 enum { e_hadron_a } m_theta_method;
91
92 // storage for a single hadron
93 struct Hadron {
94 int row;
95 int pdg;
96 ROOT::Math::PxPyPzMVector p;
97 double z;
98 std::optional<ROOT::Math::XYZVector> p_perp;
99 };
100 };
101
102}
#define DEFINE_IGUANA_ALGORITHM(ALGO_NAME, ALGO_FULL_NAME)
Algorithm(std::string_view name)
Definition Algorithm.h:46
Algorithm: Calculate semi-inclusive dihadron kinematic quantities defined in iguana::physics::Dihadro...
Definition Algorithm.h:36
void Stop() override
Finalize this algorithm after all events are processed.
std::vector< std::pair< int, int > > PairHadrons(hipo::bank const &particle_bank) const
form dihadrons by pairing hadrons
bool Run(hipo::banklist &banks) const override
Run Function: Process an event's hipo::banklist
void Start(hipo::banklist &banks) override
Initialize this algorithm before any events are processed, with the intent to process banks.
bool Run(hipo::bank const &particle_bank, hipo::bank const &inc_kin_bank, hipo::bank &result_bank) const
Run Function: Process an event's hipo::bank objects
Physics algorithms.
Definition Algorithm.h:5