diff --git a/src/_ext.cpp b/src/_ext.cpp index 9d190311..2b10c7e9 100644 --- a/src/_ext.cpp +++ b/src/_ext.cpp @@ -1658,6 +1658,8 @@ PYBIND11_MODULE(_ext, m) { std::vector jet_groomed_m; std::vector jet_groomed_E; std::vector jet_groomed_pz; + std::vector jet_groomed_delta_R; + std::vector jet_groomed_symmetry; fastjet::contrib::RecursiveSymmetryCutBase::SymmetryMeasure sym_meas = fastjet::contrib::RecursiveSymmetryCutBase::SymmetryMeasure::scalar_z; if (symmetry_measure == "scalar_z") { @@ -1703,6 +1705,11 @@ PYBIND11_MODULE(_ext, m) { jet_groomed_m.push_back(soft.m()); jet_groomed_E.push_back(soft.E()); jet_groomed_pz.push_back(soft.pz()); + + auto sd_struct = soft.structure_of(); + jet_groomed_delta_R.push_back(sd_struct.delta_R()); + jet_groomed_symmetry.push_back(sd_struct.symmetry()); + for (unsigned int k = 0; k < soft.constituents().size(); k++){ consts_groomed_px.push_back(soft.constituents()[k].px()); consts_groomed_py.push_back(soft.constituents()[k].py()); @@ -1723,6 +1730,8 @@ PYBIND11_MODULE(_ext, m) { auto jet_m = py::array(jet_groomed_m.size(), jet_groomed_m.data()); auto jet_E = py::array(jet_groomed_E.size(), jet_groomed_E.data()); auto jet_pz = py::array(jet_groomed_pz.size(), jet_groomed_pz.data()); + auto jet_delta_R = py::array(jet_groomed_delta_R.size(), jet_groomed_delta_R.data()); + auto jet_symmetry = py::array(jet_groomed_symmetry.size(), jet_groomed_symmetry.data()); return std::make_tuple( consts_px, @@ -1735,7 +1744,9 @@ PYBIND11_MODULE(_ext, m) { jet_phi, jet_m, jet_E, - jet_pz + jet_pz, + jet_delta_R, + jet_symmetry ); }, R"pbdoc( Performs softdrop pruning on jets. diff --git a/src/fastjet/_generalevent.py b/src/fastjet/_generalevent.py index 3333ebff..feef6fb0 100644 --- a/src/fastjet/_generalevent.py +++ b/src/fastjet/_generalevent.py @@ -491,6 +491,8 @@ def exclusive_jets_softdrop_grooming( jetmass = ak.Array(ak.contents.NumpyArray(np_results[8])) jetE = ak.Array(ak.contents.NumpyArray(np_results[9])) jetpz = ak.Array(ak.contents.NumpyArray(np_results[10])) + jetdeltaR = ak.Array(ak.contents.NumpyArray(np_results[11])) + jetsymmetry = ak.Array(ak.contents.NumpyArray(np_results[12])) self._out.append( ak.zip( @@ -504,6 +506,8 @@ def exclusive_jets_softdrop_grooming( "phisoftdrop": jetphi, "Esoftdrop": jetE, "pzsoftdrop": jetpz, + "deltaRsoftdrop": jetdeltaR, + "symmetrysoftdrop": jetsymmetry, }, depth_limit=1, ) diff --git a/src/fastjet/_multievent.py b/src/fastjet/_multievent.py index 9358fa4e..ccce578d 100644 --- a/src/fastjet/_multievent.py +++ b/src/fastjet/_multievent.py @@ -264,6 +264,8 @@ def exclusive_jets_softdrop_grooming( jetmass = ak.Array(ak.contents.NumpyArray(np_results[8])) jetE = ak.Array(ak.contents.NumpyArray(np_results[9])) jetpz = ak.Array(ak.contents.NumpyArray(np_results[10])) + jetdeltaR = ak.Array(ak.contents.NumpyArray(np_results[11])) + jetsymmetry = ak.Array(ak.contents.NumpyArray(np_results[12])) out = ak.zip( { @@ -276,6 +278,8 @@ def exclusive_jets_softdrop_grooming( "phisoftdrop": jetphi, "Esoftdrop": jetE, "pzsoftdrop": jetpz, + "deltaRsoftdrop": jetdeltaR, + "symmetrysoftdrop": jetsymmetry, }, depth_limit=1, ) diff --git a/src/fastjet/_singleevent.py b/src/fastjet/_singleevent.py index 2c1fa77f..2fdbaa9c 100644 --- a/src/fastjet/_singleevent.py +++ b/src/fastjet/_singleevent.py @@ -248,6 +248,8 @@ def exclusive_jets_softdrop_grooming( jetmass = ak.Array(ak.contents.NumpyArray(np_results[8])) jetE = ak.Array(ak.contents.NumpyArray(np_results[9])) jetpz = ak.Array(ak.contents.NumpyArray(np_results[10])) + jetdeltaR = ak.Array(ak.contents.NumpyArray(np_results[11])) + jetsymmetry = ak.Array(ak.contents.NumpyArray(np_results[12])) out = ak.zip( { @@ -260,6 +262,8 @@ def exclusive_jets_softdrop_grooming( "phisoftdrop": jetphi, "Esoftdrop": jetE, "pzsoftdrop": jetpz, + "deltaRsoftdrop": jetdeltaR, + "symmetrysoftdrop": jetsymmetry, }, depth_limit=1, ) diff --git a/tests/test_002-exclusive_jets.py b/tests/test_002-exclusive_jets.py index b6e8376e..cb80c90a 100644 --- a/tests/test_002-exclusive_jets.py +++ b/tests/test_002-exclusive_jets.py @@ -234,6 +234,8 @@ def test_exclusive_jets_softdrop_grooming(): {"px": 32.45, "py": 63.21, "pz": 543.14, "E": 599.56}, ], "msoftdrop": 488.2395243115817, + "deltaRsoftdrop": 0.009873899817126915, + "symmetrysoftdrop": 0.49727522889673303, "ptsoftdrop": 142.88274528437645, "etasoftdrop": 2.726117171791057, "phisoftdrop": 1.1012644074821902, @@ -275,6 +277,18 @@ def test_exclusive_jets_softdrop_grooming(): rtol=1e-12, atol=0, ), + ak.isclose( + ak.Array([softdrop_output.deltaRsoftdrop]), + ak.Array([softdrop.deltaRsoftdrop]), + rtol=1e-12, + atol=0, + ), + ak.isclose( + ak.Array([softdrop_output.symmetrysoftdrop]), + ak.Array([softdrop.symmetrysoftdrop]), + rtol=1e-12, + atol=0, + ), ak.isclose( ak.Array([softdrop_output.ptsoftdrop]), ak.Array([softdrop.ptsoftdrop]), @@ -352,6 +366,8 @@ def test_exclusive_jets_softdrop_grooming_multi(): ], ), "msoftdrop": ak.Array([488.2395243115817, 488.2395243115817]), + "deltaRsoftdrop": ak.Array([0.009873899817126915, 0.009873899817126915]), + "symmetrysoftdrop": ak.Array([0.49727522889673303, 0.49727522889673303]), "ptsoftdrop": ak.Array([142.88274528437645, 142.88274528437645]), "etasoftdrop": ak.Array([2.726117171791057, 2.726117171791057]), "phisoftdrop": ak.Array([1.1012644074821902, 1.1012644074821902]), @@ -393,6 +409,18 @@ def test_exclusive_jets_softdrop_grooming_multi(): rtol=1e-12, atol=0, ), + ak.isclose( + ak.Array([softdrop_output.deltaRsoftdrop]), + ak.Array([softdrop.deltaRsoftdrop]), + rtol=1e-12, + atol=0, + ), + ak.isclose( + ak.Array([softdrop_output.symmetrysoftdrop]), + ak.Array([softdrop.symmetrysoftdrop]), + rtol=1e-12, + atol=0, + ), ak.isclose( ak.Array([softdrop_output.ptsoftdrop]), ak.Array([softdrop.ptsoftdrop]), diff --git a/tests/test_008-dask.py b/tests/test_008-dask.py index 946b7e66..d1eeada4 100644 --- a/tests/test_008-dask.py +++ b/tests/test_008-dask.py @@ -179,6 +179,12 @@ def dask_multi_test_exclusive_jets_softdrop_grooming(): {"px": 32.45, "py": 63.21, "pz": 543.14, "E": 599.56}, ], "msoftdrop": ak.Array([488.2395243115817, 488.2395243115817]), + "deltaRsoftdrop": ak.Array( + [0.009873899817126915, 0.009873899817126915] + ), + "symmetrysoftdrop": ak.Array( + [0.49727522889673303, 0.49727522889673303] + ), "ptsoftdrop": ak.Array([142.88274528437645, 142.88274528437645]), "etasoftdrop": ak.Array([2.726117171791057, 2.726117171791057]), "phisoftdrop": ak.Array([1.1012644074821902, 1.1012644074821902]), @@ -220,6 +226,18 @@ def dask_multi_test_exclusive_jets_softdrop_grooming(): rtol=1e-12, atol=0, ), + ak.isclose( + ak.Array([softdrop_output.deltaRsoftdrop]), + ak.Array([softdrop.deltaRsoftdrop]), + rtol=1e-12, + atol=0, + ), + ak.isclose( + ak.Array([softdrop_output.symmetrysoftdrop]), + ak.Array([softdrop.symmetrysoftdrop]), + rtol=1e-12, + atol=0, + ), ak.isclose( ak.Array([softdrop_output.ptsoftdrop]), ak.Array([softdrop.ptsoftdrop]),