--- /srv/reproducible-results/rbuild-debian/r-b-build.Qu4Z7w7H/b1/siscone_3.0.5-3_amd64.changes +++ /srv/reproducible-results/rbuild-debian/r-b-build.Qu4Z7w7H/b2/siscone_3.0.5-3_amd64.changes ├── Files │ @@ -1,10 +1,10 @@ │ │ 3b375ca0599f36fabd190452db32e6db 84168 libdevel optional libsiscone-dev_3.0.5-3_amd64.deb │ 11fe075f244335c43b81c17406806e76 75780 libdevel optional libsiscone-spherical-dev_3.0.5-3_amd64.deb │ aa496f802673c420cc8313d315a345e9 434392 debug optional libsiscone-spherical0v5-dbgsym_3.0.5-3_amd64.deb │ d73b08ae3f68a53d3abf44f57bcfb9c5 61720 libs optional libsiscone-spherical0v5_3.0.5-3_amd64.deb │ facd977e8e1ea5c1b63b7b213693abbb 507872 debug optional libsiscone0v5-dbgsym_3.0.5-3_amd64.deb │ b11c7dd8df1b57ef0d4a442640466ff3 67624 libs optional libsiscone0v5_3.0.5-3_amd64.deb │ - a29bf1d70bd51f36c2a660b2c65b7040 1187140 doc optional siscone-doc-html_3.0.5-3_all.deb │ - 565908957d34fa712b691b25603f80c4 1646696 doc optional siscone-doc-pdf_3.0.5-3_all.deb │ + 7712f4ad76ae5e7238971f61e5305482 1187892 doc optional siscone-doc-html_3.0.5-3_all.deb │ + 01a8d5b15395e55d258dc863809f45fd 1655148 doc optional siscone-doc-pdf_3.0.5-3_all.deb │ f55d27b2dd0698dc0b12d200da3aa5bf 34864 devel optional siscone-examples_3.0.5-3_all.deb ├── siscone-doc-html_3.0.5-3_all.deb │ ├── file list │ │ @@ -1,3 +1,3 @@ │ │ -rw-r--r-- 0 0 0 4 2025-01-07 11:57:28.000000 debian-binary │ │ --rw-r--r-- 0 0 0 8568 2025-01-07 11:57:28.000000 control.tar.xz │ │ --rw-r--r-- 0 0 0 1178380 2025-01-07 11:57:28.000000 data.tar.xz │ │ +-rw-r--r-- 0 0 0 8560 2025-01-07 11:57:28.000000 control.tar.xz │ │ +-rw-r--r-- 0 0 0 1179140 2025-01-07 11:57:28.000000 data.tar.xz │ ├── control.tar.xz │ │ ├── control.tar │ │ │ ├── ./control │ │ │ │ @@ -1,13 +1,13 @@ │ │ │ │ Package: siscone-doc-html │ │ │ │ Source: siscone │ │ │ │ Version: 3.0.5-3 │ │ │ │ Architecture: all │ │ │ │ Maintainer: Debian Science Maintainers │ │ │ │ -Installed-Size: 5808 │ │ │ │ +Installed-Size: 5832 │ │ │ │ Depends: libjs-jquery │ │ │ │ Section: doc │ │ │ │ Priority: optional │ │ │ │ Multi-Arch: foreign │ │ │ │ Homepage: http://projects.hepforge.org/siscone/ │ │ │ │ Description: Developer's reference manual of SISCone (HTML) │ │ │ │ SISCone implements a Seedless Infrared (IR) Safe Cone jet algorithm, it takes │ │ │ ├── ./md5sums │ │ │ │ ├── ./md5sums │ │ │ │ │┄ Files differ │ ├── data.tar.xz │ │ ├── data.tar │ │ │ ├── file list │ │ │ │ @@ -87,19 +87,19 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 3325 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1Cvicinity__inclusion-members.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 8069 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1Cvicinity__inclusion.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1000 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1Cvicinity__inherit__graph.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 8437 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1Cvicinity__inherit__graph.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5401 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1circulator-members.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 26943 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1circulator.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4951 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__cones-members.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 26287 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__cones.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 25473 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__cones.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 822 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__cones__coll__graph.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 8816 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__cones__coll__graph.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 3721 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__element-members.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 12187 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__element.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 11157 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__element.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 573 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__element__coll__graph.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5833 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__element__coll__graph.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 11137 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone__spherical_1_1CSph3vector-members.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 64270 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone__spherical_1_1CSph3vector.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 478 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone__spherical_1_1CSph3vector__coll__graph.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5961 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone__spherical_1_1CSph3vector__coll__graph.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 506 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/classsiscone__spherical_1_1CSph3vector__inherit__graph.map │ │ │ │ @@ -211,23 +211,23 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6638 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_s.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 3190 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_t.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2318 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_u.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4263 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_v.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 30417 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_vars.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2154 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_x.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5351 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_~.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 31815 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 30772 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 34266 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 31824 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2551 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/globals.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2433 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/globals_defs.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2058 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/globals_vars.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6196 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/graph_legend.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 23370 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/graph_legend.png │ │ │ │ --rw-r--r-- 0 root (0) root (0) 52932 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/hash_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 22547 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/hash_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 54599 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/hash_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 23259 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/hash_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 16740 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/hierarchy.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1949 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/index.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 213 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_0.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1411 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_0.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 272 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_1.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2185 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_1.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 271 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_10.map │ │ │ │ @@ -280,42 +280,42 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1670 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_7.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 255 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_8.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1737 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_8.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1317 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_9.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 10333 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_9.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 14156 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherits.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 30264 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/main_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 41790 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 39162 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 43382 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 41438 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 153 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_f.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 169 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_fd.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 95 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_g.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 98 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_h.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 114 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_hd.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 123 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/open.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 52456 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/options_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 19814 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/options_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 151302 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/protocones_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 42169 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/protocones_8h_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 69505 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/quadtree_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 22116 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/quadtree_8h_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 27191 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 78917 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/quadtree_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 23576 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/quadtree_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 27767 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 7901 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8h.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1021 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8h__dep__incl.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 12914 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8h__dep__incl.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 9110 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8h_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 30527 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/reference_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 24184 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/reference_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 31722 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/reference_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 25626 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/reference_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 20314 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/sample_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 82494 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone_2area_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 69584 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 22317 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 23913 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 8010 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone__error_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 14493 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone__error_8h_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 38932 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2geom__2d_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 15205 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/siscone__error_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 38354 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2geom__2d_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22147 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2geom__2d_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 47436 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2hash_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22598 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2hash_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 81643 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2momentum_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 70241 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2momentum_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 165885 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2protocones_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 43293 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-html/html/devel/spherical_2protocones_8h_source.html │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__cones.html │ │ │ │ @@ -196,15 +196,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
Returns
0 on success, 1 on error
│ │ │ │ │ │ │ │

Definition at line 171 of file hash.cpp.

│ │ │ │ │ │ │ │ -

References siscone::hash_element::eta, siscone::Cmomentum::eta, hash_array, siscone::hash_element::is_stable, mask, n_cones, siscone::hash_element::next, siscone::hash_element::phi, siscone::Cmomentum::phi, siscone::hash_element::ref, siscone::Cmomentum::ref, and siscone::Creference::ref.

│ │ │ │ +

References siscone::Cmomentum::eta, hash_array, mask, n_cones, siscone::Cmomentum::phi, siscone::Cmomentum::ref, and siscone::Creference::ref.

│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │

◆ insert() [2/2]

│ │ │ │ │ │ │ │
│ │ │ │ @@ -259,15 +259,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
Returns
0 on success, 1 on error
│ │ │ │ │ │ │ │

Definition at line 102 of file hash.cpp.

│ │ │ │ │ │ │ │ -

References siscone::Cmomentum::build_etaphi(), siscone::hash_element::eta, siscone::Cmomentum::eta, hash_array, is_inside(), siscone::hash_element::is_stable, mask, n_cones, siscone::hash_element::next, siscone::hash_element::phi, siscone::Cmomentum::phi, siscone::hash_element::ref, siscone::Cmomentum::ref, and siscone::Creference::ref.

│ │ │ │ +

References siscone::Cmomentum::build_etaphi(), siscone::Cmomentum::eta, hash_array, is_inside(), mask, n_cones, siscone::Cmomentum::phi, siscone::Cmomentum::ref, and siscone::Creference::ref.

│ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ is_inside()

│ │ │ │ │ │ │ │
│ │ │ │ ├── html2text {} │ │ │ │ │ @@ -66,18 +66,16 @@ │ │ │ │ │ insert a new candidate into the hash. │ │ │ │ │ Parameters │ │ │ │ │ v 4-momentum of te cone to add Note, in this case, we assume stability. │ │ │ │ │ We also assume that eta and phi are computed for v │ │ │ │ │ Returns │ │ │ │ │ 0 on success, 1 on error │ │ │ │ │ Definition at line _1_7_1 of file _h_a_s_h_._c_p_p. │ │ │ │ │ -References _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_e_t_a, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_e_t_a, _h_a_s_h___a_r_r_a_y, │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_i_s___s_t_a_b_l_e, _m_a_s_k, _n___c_o_n_e_s, _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_n_e_x_t, │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_p_h_i, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_p_h_i, _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_: │ │ │ │ │ -_r_e_f, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_r_e_f, and _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f. │ │ │ │ │ +References _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_e_t_a, _h_a_s_h___a_r_r_a_y, _m_a_s_k, _n___c_o_n_e_s, _s_i_s_c_o_n_e_:_: │ │ │ │ │ +_C_m_o_m_e_n_t_u_m_:_:_p_h_i, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_r_e_f, and _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f. │ │ │ │ │ ********** _?◆_? iinnsseerrtt(()) [[22//22]] ********** │ │ │ │ │ _i_n_t siscone::hash_cones::insert ( _C_m_o_m_e_n_t_u_m *  vv, │ │ │ │ │ _C_m_o_m_e_n_t_u_m *  ppaarreenntt, │ │ │ │ │ _C_m_o_m_e_n_t_u_m *  cchhiilldd, │ │ │ │ │ _b_o_o_l  pp__iioo, │ │ │ │ │ _b_o_o_l  cc__iioo  │ │ │ │ │ ) │ │ │ │ │ @@ -87,19 +85,17 @@ │ │ │ │ │ parent parent particle defining the cone │ │ │ │ │ child child particle defining the cone │ │ │ │ │ p_io whether the parent has to belong to the cone or not │ │ │ │ │ c_io whether the child has to belong to the cone or not │ │ │ │ │ Returns │ │ │ │ │ 0 on success, 1 on error │ │ │ │ │ Definition at line _1_0_2 of file _h_a_s_h_._c_p_p. │ │ │ │ │ -References _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_b_u_i_l_d___e_t_a_p_h_i_(_), _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_e_t_a, │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_e_t_a, _h_a_s_h___a_r_r_a_y, _i_s___i_n_s_i_d_e_(_), _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_: │ │ │ │ │ -_i_s___s_t_a_b_l_e, _m_a_s_k, _n___c_o_n_e_s, _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_n_e_x_t, _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_: │ │ │ │ │ -_p_h_i, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_p_h_i, _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_r_e_f, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_: │ │ │ │ │ -_r_e_f, and _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f. │ │ │ │ │ +References _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_b_u_i_l_d___e_t_a_p_h_i_(_), _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_e_t_a, │ │ │ │ │ +_h_a_s_h___a_r_r_a_y, _i_s___i_n_s_i_d_e_(_), _m_a_s_k, _n___c_o_n_e_s, _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_p_h_i, _s_i_s_c_o_n_e_:_: │ │ │ │ │ +_C_m_o_m_e_n_t_u_m_:_:_r_e_f, and _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f. │ │ │ │ │ ********** _?◆_? iiss__iinnssiiddee(()) ********** │ │ │ │ │ _b_o_o_l siscone::hash_cones::is_inside ( _C_m_o_m_e_n_t_u_m *  cceennttrree, │ │ │ │ │ _C_m_o_m_e_n_t_u_m *  vv  inline │ │ │ │ │ ) │ │ │ │ │ test if a particle is inside a cone of given centre. │ │ │ │ │ check if the particle of coordinates 'v' is inside the circle of radius R │ │ │ │ │ centered at 'centre'. │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/classsiscone_1_1hash__element.html │ │ │ │ @@ -102,16 +102,14 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

centre: eta coordinate

│ │ │ │ │ │ │ │

Definition at line 48 of file hash.h.

│ │ │ │ │ │ │ │ -

Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert().

│ │ │ │ - │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ is_stable

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ @@ -122,16 +120,14 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

true if stable w.r.t. "border particles"

│ │ │ │ │ │ │ │

Definition at line 50 of file hash.h.

│ │ │ │ │ │ │ │ -

Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert().

│ │ │ │ - │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ next

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ @@ -142,15 +138,15 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

pointer to the next element

│ │ │ │ │ │ │ │

Definition at line 52 of file hash.h.

│ │ │ │ │ │ │ │ -

Referenced by siscone::hash_cones::insert(), siscone::hash_cones::insert(), and siscone::hash_cones::~hash_cones().

│ │ │ │ +

Referenced by siscone::hash_cones::~hash_cones().

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ │ │ │ │

◆ phi

│ │ │ │ │ │ │ │
│ │ │ │ @@ -162,16 +158,14 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

centre: phi coordinate

│ │ │ │ │ │ │ │

Definition at line 49 of file hash.h.

│ │ │ │ │ │ │ │ -

Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert().

│ │ │ │ - │ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │

◆ ref

│ │ │ │ │ │ │ │
│ │ │ │
│ │ │ │ @@ -182,16 +176,14 @@ │ │ │ │ │ │ │ │
│ │ │ │ │ │ │ │

reference

│ │ │ │ │ │ │ │

Definition at line 47 of file hash.h.

│ │ │ │ │ │ │ │ -

Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert().

│ │ │ │ - │ │ │ │
│ │ │ │
│ │ │ │
The documentation for this class was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -31,34 +31,29 @@ │ │ │ │ │ stbility with the parent-child particles (border particles). │ │ │ │ │ Definition at line _4_5 of file _h_a_s_h_._h. │ │ │ │ │ ********** MMeemmbbeerr DDaattaa DDooccuummeennttaattiioonn ********** │ │ │ │ │ ********** _?◆_? eettaa ********** │ │ │ │ │ _d_o_u_b_l_e siscone::hash_element::eta │ │ │ │ │ centre: eta coordinate │ │ │ │ │ Definition at line _4_8 of file _h_a_s_h_._h. │ │ │ │ │ -Referenced by _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_), and _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_). │ │ │ │ │ ********** _?◆_? iiss__ssttaabbllee ********** │ │ │ │ │ _b_o_o_l siscone::hash_element::is_stable │ │ │ │ │ true if stable w.r.t. "border particles" │ │ │ │ │ Definition at line _5_0 of file _h_a_s_h_._h. │ │ │ │ │ -Referenced by _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_), and _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_). │ │ │ │ │ ********** _?◆_? nneexxtt ********** │ │ │ │ │ _h_a_s_h___e_l_e_m_e_n_t* siscone::hash_element::next │ │ │ │ │ pointer to the next element │ │ │ │ │ Definition at line _5_2 of file _h_a_s_h_._h. │ │ │ │ │ -Referenced by _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_), _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_), and │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_~_h_a_s_h___c_o_n_e_s_(_). │ │ │ │ │ +Referenced by _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_~_h_a_s_h___c_o_n_e_s_(_). │ │ │ │ │ ********** _?◆_? pphhii ********** │ │ │ │ │ _d_o_u_b_l_e siscone::hash_element::phi │ │ │ │ │ centre: phi coordinate │ │ │ │ │ Definition at line _4_9 of file _h_a_s_h_._h. │ │ │ │ │ -Referenced by _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_), and _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_). │ │ │ │ │ ********** _?◆_? rreeff ********** │ │ │ │ │ _C_r_e_f_e_r_e_n_c_e siscone::hash_element::ref │ │ │ │ │ reference │ │ │ │ │ Definition at line _4_7 of file _h_a_s_h_._h. │ │ │ │ │ -Referenced by _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_), and _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t_(_). │ │ │ │ │ =============================================================================== │ │ │ │ │ The documentation for this class was generated from the following file: │ │ │ │ │ * siscone/_h_a_s_h_._h │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8cpp_source.html │ │ │ │ @@ -111,55 +111,55 @@ │ │ │ │
57// ctor with initialisation
│ │ │ │
58// we initialise with a centre (in eta,phi) and a radius
│ │ │ │
59// - c_eta eta coordinate of the centre
│ │ │ │
60// - c_phi phi coordinate of the centre
│ │ │ │
61// - R radius
│ │ │ │
62//-------------------------------------------------------
│ │ │ │
│ │ │ │ -
63Ceta_phi_range::Ceta_phi_range(double c_eta, double c_phi, double R){
│ │ │ │ +
63Ceta_phi_range::Ceta_phi_range(double c_eta, double c_phi, double R){
│ │ │ │
64 // determination of the eta range
│ │ │ │
65 //-------------------------------
│ │ │ │ -
66 double xmin = max(c_eta-R,eta_min+0.0001);
│ │ │ │ -
67 double xmax = min(c_eta+R,eta_max-0.0001);
│ │ │ │ +
66 double xmin = max(c_eta-R,eta_min+0.0001);
│ │ │ │ +
67 double xmax = min(c_eta+R,eta_max-0.0001);
│ │ │ │
68
│ │ │ │ -
69 unsigned int cell_min = get_eta_cell(xmin);
│ │ │ │ -
70 unsigned int cell_max = get_eta_cell(xmax);
│ │ │ │ +
69 unsigned int cell_min = get_eta_cell(xmin);
│ │ │ │ +
70 unsigned int cell_max = get_eta_cell(xmax);
│ │ │ │
71
│ │ │ │
72 // warning: if cell_max==2^31, 2*cell_max==0 hence,
│ │ │ │
73 // even if the next formula is formally (2*cell_max-cell_min),
│ │ │ │
74 // expressing it as (cell_max-cell_min)+cell_max is safe.
│ │ │ │ -
75 eta_range = (cell_max-cell_min)+cell_max;
│ │ │ │ + │ │ │ │
76
│ │ │ │
77 // determination of the phi range
│ │ │ │
78 // !! taking care of periodicity !!
│ │ │ │
79 //---------------------------------
│ │ │ │ -
80 xmin = phi_in_range(c_phi-R);
│ │ │ │ -
81 xmax = phi_in_range(c_phi+R);
│ │ │ │ +
80 xmin = phi_in_range(c_phi-R);
│ │ │ │ +
81 xmax = phi_in_range(c_phi+R);
│ │ │ │
82
│ │ │ │ -
83 cell_min = get_phi_cell(xmin);
│ │ │ │ -
84 cell_max = get_phi_cell(xmax);
│ │ │ │ +
83 cell_min = get_phi_cell(xmin);
│ │ │ │ +
84 cell_max = get_phi_cell(xmax);
│ │ │ │
85
│ │ │ │
86 // Also, if the interval goes through pi, inversion is needed
│ │ │ │ -
87 if (xmax>xmin)
│ │ │ │ -
88 phi_range = (cell_max-cell_min)+cell_max;
│ │ │ │ +
87 if (xmax>xmin)
│ │ │ │ + │ │ │ │
89 else {
│ │ │ │ -
90 phi_range = (cell_min==cell_max)
│ │ │ │ + │ │ │ │
91 ? PHI_RANGE_MASK
│ │ │ │ -
92 : ((PHI_RANGE_MASK^(cell_min-cell_max)) + cell_max);
│ │ │ │ +
92 : ((PHI_RANGE_MASK^(cell_min-cell_max)) + cell_max);
│ │ │ │
93 }
│ │ │ │
94}
│ │ │ │
│ │ │ │
95
│ │ │ │
96// assignment of range
│ │ │ │
97// - r range to assign to current one
│ │ │ │
98//---------------------------------------
│ │ │ │
│ │ │ │ - │ │ │ │ - │ │ │ │ - │ │ │ │ + │ │ │ │ +
100 eta_range = r.eta_range;
│ │ │ │ +
101 phi_range = r.phi_range;
│ │ │ │
102
│ │ │ │
103 return *this;
│ │ │ │
104}
│ │ │ │
│ │ │ │
105
│ │ │ │
106// add a particle to the range
│ │ │ │
107// - eta eta coordinate of the particle
│ │ │ │ @@ -180,30 +180,30 @@ │ │ │ │
120
│ │ │ │
121
│ │ │ │
122// test overlap
│ │ │ │
123// - r1 first range
│ │ │ │
124// - r2 second range
│ │ │ │
125// return true if overlap, false otherwise.
│ │ │ │
126//------------------------------------------
│ │ │ │ -
127bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2){
│ │ │ │ +
127bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2){
│ │ │ │
128 // check overlap in eta AND phi
│ │ │ │ -
129 return ((r1.eta_range & r2.eta_range) && (r1.phi_range & r2.phi_range));
│ │ │ │ +
129 return ((r1.eta_range & r2.eta_range) && (r1.phi_range & r2.phi_range));
│ │ │ │
130}
│ │ │ │
131
│ │ │ │
132// compute union
│ │ │ │
133// Note: we assume that the two intervals overlap
│ │ │ │
134// - r1 first range
│ │ │ │
135// - r2 second range
│ │ │ │
136// \return union of the two ranges
│ │ │ │
137//------------------------------------------
│ │ │ │
138const Ceta_phi_range range_union (const Ceta_phi_range &r1, const Ceta_phi_range &r2){
│ │ │ │
139 Ceta_phi_range tmp;
│ │ │ │
140
│ │ │ │
141 // compute union in eta
│ │ │ │ -
142 tmp.eta_range = r1.eta_range | r2.eta_range;
│ │ │ │ +
142 tmp.eta_range = r1.eta_range | r2.eta_range;
│ │ │ │
143
│ │ │ │
144 // compute union in phi
│ │ │ │
145 tmp.phi_range = r1.phi_range | r2.phi_range;
│ │ │ │
146
│ │ │ │
147 return tmp;
│ │ │ │
148}
│ │ │ │
149
│ │ │ │ @@ -212,14 +212,15 @@ │ │ │ │
unsigned int eta_range
eta range as a binary coding of covered cells
Definition geom_2d.h:143
│ │ │ │
static double eta_max
maximal value for eta
Definition geom_2d.h:150
│ │ │ │
int add_particle(const double eta, const double phi)
add a particle to the range
Definition geom_2d.cpp:111
│ │ │ │
static double eta_min
minimal value for eta
Definition geom_2d.h:149
│ │ │ │
Ceta_phi_range & operator=(const Ceta_phi_range &r)
assignment of range
Definition geom_2d.cpp:99
│ │ │ │
Ceta_phi_range()
default ctor
Definition geom_2d.cpp:52
│ │ │ │
unsigned int phi_range
phi range as a binary coding of covered cells
Definition geom_2d.h:146
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -59,53 +59,53 @@ │ │ │ │ │ 56 │ │ │ │ │ 57// ctor with initialisation │ │ │ │ │ 58// we initialise with a centre (in eta,phi) and a radius │ │ │ │ │ 59// - c_eta eta coordinate of the centre │ │ │ │ │ 60// - c_phi phi coordinate of the centre │ │ │ │ │ 61// - R radius │ │ │ │ │ 62//------------------------------------------------------- │ │ │ │ │ -_6_3_C_e_t_a___p_h_i___r_a_n_g_e_:_:_C_e_t_a___p_h_i___r_a_n_g_e(double c_eta, double c_phi, double R){ │ │ │ │ │ +_6_3_C_e_t_a___p_h_i___r_a_n_g_e_:_:_C_e_t_a___p_h_i___r_a_n_g_e(double _c___e_t_a, double _c___p_h_i, double R){ │ │ │ │ │ 64 // determination of the eta range │ │ │ │ │ 65 //------------------------------- │ │ │ │ │ -66 double xmin = max(c_eta-R,_e_t_a___m_i_n+0.0001); │ │ │ │ │ -67 double xmax = min(c_eta+R,_e_t_a___m_a_x-0.0001); │ │ │ │ │ +66 double _x_m_i_n = _m_a_x(_c___e_t_a-R,_e_t_a___m_i_n+0.0001); │ │ │ │ │ +67 double _x_m_a_x = _m_i_n(_c___e_t_a+R,_e_t_a___m_a_x-0.0001); │ │ │ │ │ 68 │ │ │ │ │ -69 unsigned int cell_min = get_eta_cell(xmin); │ │ │ │ │ -70 unsigned int cell_max = get_eta_cell(xmax); │ │ │ │ │ +69 unsigned int _c_e_l_l___m_i_n = get_eta_cell(_x_m_i_n); │ │ │ │ │ +70 unsigned int _c_e_l_l___m_a_x = get_eta_cell(_x_m_a_x); │ │ │ │ │ 71 │ │ │ │ │ 72 // warning: if cell_max==2^31, 2*cell_max==0 hence, │ │ │ │ │ 73 // even if the next formula is formally (2*cell_max-cell_min), │ │ │ │ │ 74 // expressing it as (cell_max-cell_min)+cell_max is safe. │ │ │ │ │ -75 _e_t_a___r_a_n_g_e = (cell_max-cell_min)+cell_max; │ │ │ │ │ +75 _e_t_a___r_a_n_g_e = (_c_e_l_l___m_a_x-_c_e_l_l___m_i_n)+_c_e_l_l___m_a_x; │ │ │ │ │ 76 │ │ │ │ │ 77 // determination of the phi range │ │ │ │ │ 78 // !! taking care of periodicity !! │ │ │ │ │ 79 //--------------------------------- │ │ │ │ │ -80 xmin = phi_in_range(c_phi-R); │ │ │ │ │ -81 xmax = phi_in_range(c_phi+R); │ │ │ │ │ +80 _x_m_i_n = phi_in_range(_c___p_h_i-R); │ │ │ │ │ +81 _x_m_a_x = phi_in_range(_c___p_h_i+R); │ │ │ │ │ 82 │ │ │ │ │ -83 cell_min = get_phi_cell(xmin); │ │ │ │ │ -84 cell_max = get_phi_cell(xmax); │ │ │ │ │ +83 _c_e_l_l___m_i_n = get_phi_cell(_x_m_i_n); │ │ │ │ │ +84 _c_e_l_l___m_a_x = get_phi_cell(_x_m_a_x); │ │ │ │ │ 85 │ │ │ │ │ 86 // Also, if the interval goes through pi, inversion is needed │ │ │ │ │ -87 if (xmax>xmin) │ │ │ │ │ -88 _p_h_i___r_a_n_g_e = (cell_max-cell_min)+cell_max; │ │ │ │ │ +87 if (_x_m_a_x>_x_m_i_n) │ │ │ │ │ +88 _p_h_i___r_a_n_g_e = (_c_e_l_l___m_a_x-_c_e_l_l___m_i_n)+_c_e_l_l___m_a_x; │ │ │ │ │ 89 else { │ │ │ │ │ -90 _p_h_i___r_a_n_g_e = (cell_min==cell_max) │ │ │ │ │ +90 _p_h_i___r_a_n_g_e = (_c_e_l_l___m_i_n==_c_e_l_l___m_a_x) │ │ │ │ │ 91 ? PHI_RANGE_MASK │ │ │ │ │ -92 : ((PHI_RANGE_MASK^(cell_min-cell_max)) + cell_max); │ │ │ │ │ +92 : ((PHI_RANGE_MASK^(_c_e_l_l___m_i_n-_c_e_l_l___m_a_x)) + _c_e_l_l___m_a_x); │ │ │ │ │ 93 } │ │ │ │ │ 94} │ │ │ │ │ 95 │ │ │ │ │ 96// assignment of range │ │ │ │ │ 97// - r range to assign to current one │ │ │ │ │ 98//--------------------------------------- │ │ │ │ │ -_9_9_C_e_t_a___p_h_i___r_a_n_g_e& _C_e_t_a___p_h_i___r_a_n_g_e_:_:_o_p_e_r_a_t_o_r_ _=_ (const _C_e_t_a___p_h_i___r_a_n_g_e &r){ │ │ │ │ │ -100 _e_t_a___r_a_n_g_e = r._e_t_a___r_a_n_g_e; │ │ │ │ │ -101 _p_h_i___r_a_n_g_e = r._p_h_i___r_a_n_g_e; │ │ │ │ │ +_9_9_C_e_t_a___p_h_i___r_a_n_g_e& _C_e_t_a___p_h_i___r_a_n_g_e_:_:_o_p_e_r_a_t_o_r_ _=_ (const _C_e_t_a___p_h_i___r_a_n_g_e &_r){ │ │ │ │ │ +100 _e_t_a___r_a_n_g_e = _r.eta_range; │ │ │ │ │ +101 _p_h_i___r_a_n_g_e = _r.phi_range; │ │ │ │ │ 102 │ │ │ │ │ 103 return *this; │ │ │ │ │ 104} │ │ │ │ │ 105 │ │ │ │ │ 106// add a particle to the range │ │ │ │ │ 107// - eta eta coordinate of the particle │ │ │ │ │ 108// - phi phi coordinate of the particle │ │ │ │ │ @@ -123,31 +123,31 @@ │ │ │ │ │ 120 │ │ │ │ │ 121 │ │ │ │ │ 122// test overlap │ │ │ │ │ 123// - r1 first range │ │ │ │ │ 124// - r2 second range │ │ │ │ │ 125// return true if overlap, false otherwise. │ │ │ │ │ 126//------------------------------------------ │ │ │ │ │ -127bool is_range_overlap(const _C_e_t_a___p_h_i___r_a_n_g_e &r1, const _C_e_t_a___p_h_i___r_a_n_g_e &r2){ │ │ │ │ │ +127bool is_range_overlap(const _C_e_t_a___p_h_i___r_a_n_g_e &_r_1, const _C_e_t_a___p_h_i___r_a_n_g_e &_r_2){ │ │ │ │ │ 128 // check overlap in eta AND phi │ │ │ │ │ -129 return ((r1._e_t_a___r_a_n_g_e & r2._e_t_a___r_a_n_g_e) && (r1._p_h_i___r_a_n_g_e & r2._p_h_i___r_a_n_g_e)); │ │ │ │ │ +129 return ((_r_1.eta_range & _r_2.eta_range) && (_r_1.phi_range & _r_2.phi_range)); │ │ │ │ │ 130} │ │ │ │ │ 131 │ │ │ │ │ 132// compute union │ │ │ │ │ 133// Note: we assume that the two intervals overlap │ │ │ │ │ 134// - r1 first range │ │ │ │ │ 135// - r2 second range │ │ │ │ │ 136// \return union of the two ranges │ │ │ │ │ 137//------------------------------------------ │ │ │ │ │ 138const Ceta_phi_range range_union (const Ceta_phi_range &r1, const │ │ │ │ │ Ceta_phi_range &r2){ │ │ │ │ │ 139 Ceta_phi_range tmp; │ │ │ │ │ 140 │ │ │ │ │ 141 // compute union in eta │ │ │ │ │ -142 tmp._e_t_a___r_a_n_g_e = r1.eta_range | r2.eta_range; │ │ │ │ │ +142 tmp.eta_range = r1.eta_range | r2.eta_range; │ │ │ │ │ 143 │ │ │ │ │ 144 // compute union in phi │ │ │ │ │ 145 tmp.phi_range = r1.phi_range | r2.phi_range; │ │ │ │ │ 146 │ │ │ │ │ 147 return tmp; │ │ │ │ │ 148} │ │ │ │ │ 149 │ │ │ │ │ @@ -179,9 +179,13 @@ │ │ │ │ │ Ceta_phi_range() │ │ │ │ │ default ctor │ │ │ │ │ DDeeffiinniittiioonn _g_e_o_m___2_d_._c_p_p_:_5_2 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_e_t_a___p_h_i___r_a_n_g_e_:_:_p_h_i___r_a_n_g_e │ │ │ │ │ unsigned int phi_range │ │ │ │ │ phi range as a binary coding of covered cells │ │ │ │ │ DDeeffiinniittiioonn _g_e_o_m___2_d_._h_:_1_4_6 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8h_source.html │ │ │ │ @@ -109,21 +109,21 @@ │ │ │ │
67
│ │ │ │
68
│ │ │ │
│ │ │ │
73class Ctwovect {
│ │ │ │
74public:
│ │ │ │
76 Ctwovect() : x(0.0), y(0.0) {}
│ │ │ │
77
│ │ │ │ -
81 Ctwovect(double _x, double _y) : x(_x), y(_y) {}
│ │ │ │ +
81 Ctwovect(double _x, double _y) : x(_x), y(_y) {}
│ │ │ │
82
│ │ │ │
84 double x, y;
│ │ │ │
85
│ │ │ │
87 inline double mod2() const {return pow2(x)+pow2(y);}
│ │ │ │
88
│ │ │ │ -
90 inline double modulus() const {return sqrt(mod2());}
│ │ │ │ +
90 inline double modulus() const {return sqrt(mod2());}
│ │ │ │
91};
│ │ │ │
│ │ │ │
92
│ │ │ │
93
│ │ │ │
98inline double dot_product(const Ctwovect & a, const Ctwovect & b) {
│ │ │ │
99 return a.x*b.x + a.y*b.y;
│ │ │ │
100}
│ │ │ │ @@ -135,35 +135,35 @@ │ │ │ │
110
│ │ │ │
111
│ │ │ │
│ │ │ │ │ │ │ │
121public:
│ │ │ │ │ │ │ │
124
│ │ │ │ -
130 Ceta_phi_range(double c_eta, double c_phi, double R);
│ │ │ │ +
130 Ceta_phi_range(double c_eta, double c_phi, double R);
│ │ │ │
131
│ │ │ │ - │ │ │ │ + │ │ │ │
135
│ │ │ │
140 int add_particle(const double eta, const double phi);
│ │ │ │
141
│ │ │ │
143 unsigned int eta_range;
│ │ │ │
144
│ │ │ │
146 unsigned int phi_range;
│ │ │ │
147
│ │ │ │
148 // extremal value for eta
│ │ │ │
149 static double eta_min;
│ │ │ │
150 static double eta_max;
│ │ │ │
151
│ │ │ │
152private:
│ │ │ │
154 inline unsigned int get_eta_cell(double eta){
│ │ │ │ -
155 return (unsigned int) (1u << ((int) (32*((eta-eta_min)/(eta_max-eta_min)))));
│ │ │ │ +
155 return (unsigned int) (1u << ((int) (32*((eta-eta_min)/(eta_max-eta_min)))));
│ │ │ │
156 }
│ │ │ │
157
│ │ │ │
159 inline unsigned int get_phi_cell(double phi){
│ │ │ │ -
160 return (unsigned int) (1u << ((int) (32*phi/twopi+16)%32));
│ │ │ │ +
160 return (unsigned int) (1u << ((int) (32*phi/twopi+16)%32));
│ │ │ │
161 }
│ │ │ │
162};
│ │ │ │
│ │ │ │
163
│ │ │ │
168bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2);
│ │ │ │
169
│ │ │ │
175const Ceta_phi_range range_union(const Ceta_phi_range &r1, const Ceta_phi_range &r2);
│ │ │ │ @@ -181,14 +181,15 @@ │ │ │ │
unsigned int phi_range
phi range as a binary coding of covered cells
Definition geom_2d.h:146
│ │ │ │
class for holding a two-vector
Definition geom_2d.h:73
│ │ │ │
double mod2() const
norm (modulud square) of the vector
Definition geom_2d.h:87
│ │ │ │
double x
vector coordinates
Definition geom_2d.h:84
│ │ │ │
Ctwovect()
default ctor
Definition geom_2d.h:76
│ │ │ │
double modulus() const
modulus of the vector
Definition geom_2d.h:90
│ │ │ │
Ctwovect(double _x, double _y)
ctor with initialisation
Definition geom_2d.h:81
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
│ │ │ │
const double twopi
definition of 2*M_PI which is useful a bit everyhere!
Definition defines.h:114
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -59,21 +59,21 @@ │ │ │ │ │ 66inline double pow2(double x) {return x*x;} │ │ │ │ │ 67 │ │ │ │ │ 68 │ │ │ │ │ _7_3class _C_t_w_o_v_e_c_t { │ │ │ │ │ 74public: │ │ │ │ │ _7_6 _C_t_w_o_v_e_c_t() : _x(0.0), y(0.0) {} │ │ │ │ │ 77 │ │ │ │ │ -_8_1 _C_t_w_o_v_e_c_t(double _x, double _y) : _x(_x), y(_y) {} │ │ │ │ │ +_8_1 _C_t_w_o_v_e_c_t(double ___x, double ___y) : _x(___x), y(___y) {} │ │ │ │ │ 82 │ │ │ │ │ _8_4 double _x, y; │ │ │ │ │ 85 │ │ │ │ │ _8_7 inline double _m_o_d_2() const {return pow2(_x)+pow2(y);} │ │ │ │ │ 88 │ │ │ │ │ -_9_0 inline double _m_o_d_u_l_u_s() const {return sqrt(_m_o_d_2());} │ │ │ │ │ +_9_0 inline double _m_o_d_u_l_u_s() const {return _s_q_r_t(_m_o_d_2());} │ │ │ │ │ 91}; │ │ │ │ │ 92 │ │ │ │ │ 93 │ │ │ │ │ 98inline double dot_product(const Ctwovect & a, const Ctwovect & b) { │ │ │ │ │ 99 return a.x*b.x + a.y*b.y; │ │ │ │ │ 100} │ │ │ │ │ 101 │ │ │ │ │ @@ -83,36 +83,36 @@ │ │ │ │ │ 109} │ │ │ │ │ 110 │ │ │ │ │ 111 │ │ │ │ │ _1_2_0class _C_e_t_a___p_h_i___r_a_n_g_e{ │ │ │ │ │ 121public: │ │ │ │ │ 123 _C_e_t_a___p_h_i___r_a_n_g_e(); │ │ │ │ │ 124 │ │ │ │ │ -130 _C_e_t_a___p_h_i___r_a_n_g_e(double c_eta, double c_phi, double R); │ │ │ │ │ +130 _C_e_t_a___p_h_i___r_a_n_g_e(double _c___e_t_a, double _c___p_h_i, double R); │ │ │ │ │ 131 │ │ │ │ │ -134 _C_e_t_a___p_h_i___r_a_n_g_e& _o_p_e_r_a_t_o_r_ _=_ (const _C_e_t_a___p_h_i___r_a_n_g_e &r); │ │ │ │ │ +134 _C_e_t_a___p_h_i___r_a_n_g_e& _o_p_e_r_a_t_o_r_ _=_ (const _C_e_t_a___p_h_i___r_a_n_g_e &_r); │ │ │ │ │ 135 │ │ │ │ │ 140 int _a_d_d___p_a_r_t_i_c_l_e(const double eta, const double phi); │ │ │ │ │ 141 │ │ │ │ │ _1_4_3 unsigned int _e_t_a___r_a_n_g_e; │ │ │ │ │ 144 │ │ │ │ │ _1_4_6 unsigned int _p_h_i___r_a_n_g_e; │ │ │ │ │ 147 │ │ │ │ │ 148 // extremal value for eta │ │ │ │ │ _1_4_9 static double _e_t_a___m_i_n; │ │ │ │ │ _1_5_0 static double _e_t_a___m_a_x; │ │ │ │ │ 151 │ │ │ │ │ 152private: │ │ │ │ │ 154 inline unsigned int get_eta_cell(double eta){ │ │ │ │ │ -155 return (unsigned int) (1u << ((int) (32*((eta-_e_t_a___m_i_n)/(_e_t_a___m_a_x- │ │ │ │ │ +155 return (unsigned int) (1u << ((_i_n_t) (32*((eta-_e_t_a___m_i_n)/(_e_t_a___m_a_x- │ │ │ │ │ _e_t_a___m_i_n))))); │ │ │ │ │ 156 } │ │ │ │ │ 157 │ │ │ │ │ 159 inline unsigned int get_phi_cell(double phi){ │ │ │ │ │ -160 return (unsigned int) (1u << ((int) (32*phi/_t_w_o_p_i+16)%32)); │ │ │ │ │ +160 return (unsigned int) (1u << ((_i_n_t) (32*phi/_t_w_o_p_i+16)%32)); │ │ │ │ │ 161 } │ │ │ │ │ 162}; │ │ │ │ │ 163 │ │ │ │ │ 168bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2); │ │ │ │ │ 169 │ │ │ │ │ 175const Ceta_phi_range range_union(const Ceta_phi_range &r1, const │ │ │ │ │ Ceta_phi_range &r2); │ │ │ │ │ @@ -170,14 +170,18 @@ │ │ │ │ │ double modulus() const │ │ │ │ │ modulus of the vector │ │ │ │ │ DDeeffiinniittiioonn _g_e_o_m___2_d_._h_:_9_0 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_t_w_o_v_e_c_t_:_:_C_t_w_o_v_e_c_t │ │ │ │ │ Ctwovect(double _x, double _y) │ │ │ │ │ ctor with initialisation │ │ │ │ │ DDeeffiinniittiioonn _g_e_o_m___2_d_._h_:_8_1 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ _d_e_f_i_n_e_s_._h │ │ │ │ │ _t_w_o_p_i │ │ │ │ │ const double twopi │ │ │ │ │ definition of 2*M_PI which is useful a bit everyhere! │ │ │ │ │ DDeeffiinniittiioonn _d_e_f_i_n_e_s_._h_:_1_1_4 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/hash_8cpp_source.html │ │ │ │ @@ -93,55 +93,55 @@ │ │ │ │
41 **************************************************************/
│ │ │ │
42
│ │ │ │
43// constructor with initialisation
│ │ │ │
44// - _Np number of particles
│ │ │ │
45// - _R2 cone radius (squared)
│ │ │ │
46//-----------------------------------
│ │ │ │
│ │ │ │ -
47hash_cones::hash_cones(int _Np, double _R2){
│ │ │ │ + │ │ │ │
48 int i;
│ │ │ │
49
│ │ │ │
50 n_cones = 0;
│ │ │ │
51#ifdef DEBUG_STABLE_CONES
│ │ │ │ -
52 n_occupied_cells = 0;
│ │ │ │ + │ │ │ │
53#endif
│ │ │ │
54
│ │ │ │
55 // determine hash size
│ │ │ │
56 // for a ymax=5 and R=0.7, we observed an occupancy around 1/8 N^2 ~ N2 R2/4
│ │ │ │
57 //mask = 1 << (int) (2*log(double(_Np))/log(2.0));
│ │ │ │
58 //if (mask<=1) mask=2;
│ │ │ │ -
59 int nbits = (int) (log(_Np*_R2*_Np/4.0)/log(2.0));
│ │ │ │ -
60 if (nbits<1) nbits=1;
│ │ │ │ -
61 mask = 1 << nbits;
│ │ │ │ +
59 int nbits = (int) (log(_Np*_R2*_Np/4.0)/log(2.0));
│ │ │ │ +
60 if (nbits<1) nbits=1;
│ │ │ │ +
61 mask = 1 << nbits;
│ │ │ │
62
│ │ │ │
63 // create hash
│ │ │ │ │ │ │ │
65 mask--;
│ │ │ │
66
│ │ │ │
67 // set the array to 0
│ │ │ │
68 //? needed ?
│ │ │ │
69 for (i=0;i<mask+1;i++)
│ │ │ │ -
70 hash_array[i] = NULL;
│ │ │ │ +
70 hash_array[i] = NULL;
│ │ │ │
71
│ │ │ │ -
72 R2 = _R2;
│ │ │ │ +
72 R2 = _R2;
│ │ │ │
73}
│ │ │ │
│ │ │ │
74
│ │ │ │
75// destructor
│ │ │ │
76//------------
│ │ │ │
│ │ │ │ │ │ │ │
78 int i;
│ │ │ │ -
79 hash_element *elm;
│ │ │ │ + │ │ │ │
80
│ │ │ │
81 for (i=0;i<mask+1;i++){
│ │ │ │ -
82 while (hash_array[i]!=NULL){
│ │ │ │ -
83 elm = hash_array[i];
│ │ │ │ +
82 while (hash_array[i]!=NULL){
│ │ │ │ +
83 elm = hash_array[i];
│ │ │ │
84 hash_array[i] = hash_array[i]->next;
│ │ │ │ -
85 delete elm;
│ │ │ │ +
85 delete elm;
│ │ │ │
86 }
│ │ │ │
87 }
│ │ │ │
88
│ │ │ │
89 delete[] hash_array;
│ │ │ │
90}
│ │ │ │
│ │ │ │
91
│ │ │ │ @@ -152,71 +152,71 @@ │ │ │ │
96 * - parent parent particle defining the cone
│ │ │ │
97 * - child child particle defining the cone
│ │ │ │
98 * - p_io whether the parent has to belong to the cone or not
│ │ │ │
99 * - c_io whether the child has to belong to the cone or not
│ │ │ │
100 * return 0 on success, 1 on error
│ │ │ │
101 ***********************************************************************/
│ │ │ │
│ │ │ │ -
102int hash_cones::insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io){
│ │ │ │ -
103 hash_element *elm;
│ │ │ │ +
102int hash_cones::insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io){
│ │ │ │ + │ │ │ │
104 int index = (v->ref.ref[0]) & mask;
│ │ │ │
105
│ │ │ │
106 // check the array cell corresponding to our reference
│ │ │ │ -
107 elm = hash_array[index];
│ │ │ │ +
107 elm = hash_array[index];
│ │ │ │
108
│ │ │ │
109#ifdef DEBUG_STABLE_CONES
│ │ │ │ -
110 if (elm==NULL)
│ │ │ │ -
111 n_occupied_cells++;
│ │ │ │ +
110 if (elm==NULL)
│ │ │ │ + │ │ │ │
112#endif
│ │ │ │
113
│ │ │ │
114 do{
│ │ │ │
115 // if it is not present, add it
│ │ │ │ -
116 if (elm==NULL){
│ │ │ │ +
116 if (elm==NULL){
│ │ │ │
117 // create element
│ │ │ │ -
118 elm = new hash_element;
│ │ │ │ +
118 elm = new hash_element;
│ │ │ │
119
│ │ │ │
120 // set its varibles
│ │ │ │
121 // Note: at this level, eta and phi have already been computed
│ │ │ │
122 // through Cmomentum::build_etaphi.
│ │ │ │ -
123 elm->ref = v->ref;
│ │ │ │ +
123 elm->ref = v->ref;
│ │ │ │
124
│ │ │ │
125 //compute vectors centre
│ │ │ │
126 v->build_etaphi();
│ │ │ │ -
127 elm->eta = v->eta;
│ │ │ │ -
128 elm->phi = v->phi;
│ │ │ │ +
127 elm->eta = v->eta;
│ │ │ │ +
128 elm->phi = v->phi;
│ │ │ │
129 // if at least one of the two is_inside tests gives a result != from the expected,
│ │ │ │
130 // the || will be true hence !(...) false as wanted
│ │ │ │ -
131 elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io));
│ │ │ │ +
131 elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io));
│ │ │ │
132 //cout << "-- new status of " << v->ref[0] << ":" << elm->is_stable << endl;
│ │ │ │
133
│ │ │ │
134 // update hash
│ │ │ │ -
135 elm->next = hash_array[index];
│ │ │ │ -
136 hash_array[index] = elm;
│ │ │ │ +
135 elm->next = hash_array[index];
│ │ │ │ +
136 hash_array[index] = elm;
│ │ │ │
137
│ │ │ │
138 n_cones++;
│ │ │ │
139 return 0;
│ │ │ │
140 }
│ │ │ │
141
│ │ │ │
142 // if the cone is already there, simply update stability status
│ │ │ │ -
143 if (v->ref == elm->ref){
│ │ │ │ +
143 if (v->ref == elm->ref){
│ │ │ │
144 // there is only an update to perform to see if the cone is still stable
│ │ │ │ -
145 if (elm->is_stable){
│ │ │ │ +
145 if (elm->is_stable){
│ │ │ │
146 v->build_etaphi();
│ │ │ │ -
147 elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io));
│ │ │ │ +
147 elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io));
│ │ │ │
148 //cout << " parent/child: "
│ │ │ │
149 // << parent->ref[0] << ":" << is_inside(v, parent) << ":" << p_io << " "
│ │ │ │
150 // << child->ref[0] << ":" << is_inside(v, child) << ":" << c_io << endl;
│ │ │ │
151 //cout << "-- rep status of " << v->ref[0] << ":" << elm->is_stable << endl;
│ │ │ │
152 //cout << v->eta << " " << v->phi << endl;
│ │ │ │
153 //cout << (child->eta) << " " << child->phi << endl;
│ │ │ │
154 }
│ │ │ │
155 return 0;
│ │ │ │
156 }
│ │ │ │
157
│ │ │ │ -
158 elm = elm->next;
│ │ │ │ +
158 elm = elm->next;
│ │ │ │
159 } while (1);
│ │ │ │
160
│ │ │ │
161 return 1;
│ │ │ │
162}
│ │ │ │
│ │ │ │
163
│ │ │ │
164/*
│ │ │ │ @@ -224,48 +224,48 @@ │ │ │ │
166 * - v 4-momentum of te cone to add
│ │ │ │
167 * Note, in this case, we assume stability. We also assume
│ │ │ │
168 * that eta and phi are computed for v
│ │ │ │
169 * return 0 on success, 1 on error
│ │ │ │
170 ***********************************************************************/
│ │ │ │
│ │ │ │ │ │ │ │ -
172 hash_element *elm;
│ │ │ │ + │ │ │ │
173 int index = (v->ref.ref[0]) & mask;
│ │ │ │
174 //cout << "-- stable candidate: " << v->ref[0] << ":" << endl;
│ │ │ │
175
│ │ │ │
176 // check the array cell corresponding to our reference
│ │ │ │ -
177 elm = hash_array[index];
│ │ │ │ +
177 elm = hash_array[index];
│ │ │ │
178 do{
│ │ │ │
179 // if it is not present, add it
│ │ │ │ -
180 if (elm==NULL){
│ │ │ │ +
180 if (elm==NULL){
│ │ │ │
181 // create element
│ │ │ │ -
182 elm = new hash_element;
│ │ │ │ +
182 elm = new hash_element;
│ │ │ │
183
│ │ │ │
184 // set its varibles
│ │ │ │
185 // Note: at this level, eta and phi have already been computed
│ │ │ │
186 // through Cmomentum::build_etaphi.
│ │ │ │ -
187 elm->ref = v->ref;
│ │ │ │ -
188 elm->eta = v->eta;
│ │ │ │ -
189 elm->phi = v->phi;
│ │ │ │ -
190 elm->is_stable = true;
│ │ │ │ +
187 elm->ref = v->ref;
│ │ │ │ +
188 elm->eta = v->eta;
│ │ │ │ +
189 elm->phi = v->phi;
│ │ │ │ +
190 elm->is_stable = true;
│ │ │ │
191
│ │ │ │
192 // update hash
│ │ │ │ -
193 elm->next = hash_array[index];
│ │ │ │ -
194 hash_array[index] = elm;
│ │ │ │ +
193 elm->next = hash_array[index];
│ │ │ │ +
194 hash_array[index] = elm;
│ │ │ │
195
│ │ │ │
196 n_cones++;
│ │ │ │
197 return 0;
│ │ │ │
198 }
│ │ │ │
199
│ │ │ │
200 // if the cone is already there, we have nothing to do
│ │ │ │ -
201 if (v->ref == elm->ref){
│ │ │ │ +
201 if (v->ref == elm->ref){
│ │ │ │
202 return 0;
│ │ │ │
203 }
│ │ │ │
204
│ │ │ │ -
205 elm = elm->next;
│ │ │ │ +
205 elm = elm->next;
│ │ │ │
206 } while (1);
│ │ │ │
207
│ │ │ │
208 return 1;
│ │ │ │
209}
│ │ │ │
│ │ │ │
210
│ │ │ │
211/*
│ │ │ │ @@ -274,46 +274,43 @@ │ │ │ │
214 * centered at 'centre'.
│ │ │ │
215 * - centre centre of the circle
│ │ │ │
216 * - v particle to test
│ │ │ │
217 * return true if inside, false if outside
│ │ │ │
218 ******************************************************************************/
│ │ │ │
│ │ │ │ │ │ │ │ -
220 double dx, dy;
│ │ │ │ +
220 double dx, dy;
│ │ │ │
221
│ │ │ │ -
222 dx = centre->eta - v->eta;
│ │ │ │ -
223 dy = fabs(centre->phi - v->phi);
│ │ │ │ -
224 if (dy>M_PI)
│ │ │ │ -
225 dy -= 2.0*M_PI;
│ │ │ │ +
222 dx = centre->eta - v->eta;
│ │ │ │ +
223 dy = fabs(centre->phi - v->phi);
│ │ │ │ +
224 if (dy>M_PI)
│ │ │ │ +
225 dy -= 2.0*M_PI;
│ │ │ │
226
│ │ │ │ -
227 return dx*dx+dy*dy<R2;
│ │ │ │ +
227 return dx*dx+dy*dy<R2;
│ │ │ │
228}
│ │ │ │
│ │ │ │
229
│ │ │ │
230}
│ │ │ │
base class for dynamic coordinates management
Definition momentum.h:49
│ │ │ │
Creference ref
reference number for the vector
Definition momentum.h:122
│ │ │ │
double eta
particle pseudo-rapidity
Definition momentum.h:114
│ │ │ │
void build_etaphi()
build eta-phi from 4-momentum info !!! WARNING !!! !!! computing eta and phi is time-consuming !...
Definition momentum.cpp:134
│ │ │ │
double phi
particle azimuthal angle
Definition momentum.h:115
│ │ │ │
unsigned int ref[3]
actual data for the reference
Definition reference.h:72
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
int mask
number of occupied cells
Definition hash.h:104
│ │ │ │
hash_element ** hash_array
the cone data itself
Definition hash.h:93
│ │ │ │
int insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io)
insert a new candidate into the hash.
Definition hash.cpp:102
│ │ │ │
double R2
circle radius (squared) NOTE: need to be set before any call to 'insert'
Definition hash.h:108
│ │ │ │
int n_cones
number of elements
Definition hash.h:96
│ │ │ │
bool is_inside(Cmomentum *centre, Cmomentum *v)
test if a particle is inside a cone of given centre.
Definition hash.cpp:219
│ │ │ │
hash_cones(int _Np, double _R2)
constructor with initialisation
Definition hash.cpp:47
│ │ │ │
~hash_cones()
destructor
Definition hash.cpp:77
│ │ │ │
information on store cones candidates.
Definition hash.h:45
│ │ │ │
hash_element * next
pointer to the next element
Definition hash.h:52
│ │ │ │ -
bool is_stable
true if stable w.r.t. "border particles"
Definition hash.h:50
│ │ │ │ -
double eta
centre: eta coordinate
Definition hash.h:48
│ │ │ │ -
Creference ref
reference
Definition hash.h:47
│ │ │ │ -
double phi
centre: phi coordinate
Definition hash.h:49
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -43,53 +43,53 @@ │ │ │ │ │ 40 * functions to manipulate them. * │ │ │ │ │ 41 **************************************************************/ │ │ │ │ │ 42 │ │ │ │ │ 43// constructor with initialisation │ │ │ │ │ 44// - _Np number of particles │ │ │ │ │ 45// - _R2 cone radius (squared) │ │ │ │ │ 46//----------------------------------- │ │ │ │ │ -_4_7_h_a_s_h___c_o_n_e_s_:_:_h_a_s_h___c_o_n_e_s(int _Np, double _R2){ │ │ │ │ │ +_4_7_h_a_s_h___c_o_n_e_s_:_:_h_a_s_h___c_o_n_e_s(int ___N_p, double ___R_2){ │ │ │ │ │ 48 int i; │ │ │ │ │ 49 │ │ │ │ │ 50 _n___c_o_n_e_s = 0; │ │ │ │ │ 51#ifdef DEBUG_STABLE_CONES │ │ │ │ │ -52 n_occupied_cells = 0; │ │ │ │ │ +52 _n___o_c_c_u_p_i_e_d___c_e_l_l_s = 0; │ │ │ │ │ 53#endif │ │ │ │ │ 54 │ │ │ │ │ 55 // determine hash size │ │ │ │ │ 56 // for a ymax=5 and R=0.7, we observed an occupancy around 1/8 N^2 ~ N2 R2/4 │ │ │ │ │ 57 //mask = 1 << (int) (2*log(double(_Np))/log(2.0)); │ │ │ │ │ 58 //if (mask<=1) mask=2; │ │ │ │ │ -59 int nbits = (int) (log(_Np*_R2*_Np/4.0)/log(2.0)); │ │ │ │ │ -60 if (nbits<1) nbits=1; │ │ │ │ │ -61 _m_a_s_k = 1 << nbits; │ │ │ │ │ +59 int _n_b_i_t_s = (_i_n_t) (_l_o_g(___N_p*___R_2*___N_p/4.0)/_l_o_g(2.0)); │ │ │ │ │ +60 if (_n_b_i_t_s<1) _n_b_i_t_s=1; │ │ │ │ │ +61 _m_a_s_k = 1 << _n_b_i_t_s; │ │ │ │ │ 62 │ │ │ │ │ 63 // create hash │ │ │ │ │ 64 _h_a_s_h___a_r_r_a_y = new _h_a_s_h___e_l_e_m_e_n_t*[_m_a_s_k]; │ │ │ │ │ 65 _m_a_s_k--; │ │ │ │ │ 66 │ │ │ │ │ 67 // set the array to 0 │ │ │ │ │ 68 //? needed ? │ │ │ │ │ 69 for (i=0;i<_m_a_s_k+1;i++) │ │ │ │ │ -70 _h_a_s_h___a_r_r_a_y[i] = NULL; │ │ │ │ │ +70 _h_a_s_h___a_r_r_a_y[i] = _N_U_L_L; │ │ │ │ │ 71 │ │ │ │ │ -72 _R_2 = _R2; │ │ │ │ │ +72 _R_2 = ___R_2; │ │ │ │ │ 73} │ │ │ │ │ 74 │ │ │ │ │ 75// destructor │ │ │ │ │ 76//------------ │ │ │ │ │ _7_7_h_a_s_h___c_o_n_e_s_:_:_~_h_a_s_h___c_o_n_e_s(){ │ │ │ │ │ 78 int i; │ │ │ │ │ -79 _h_a_s_h___e_l_e_m_e_n_t *elm; │ │ │ │ │ +79 _h_a_s_h___e_l_e_m_e_n_t *_e_l_m; │ │ │ │ │ 80 │ │ │ │ │ 81 for (i=0;i<_m_a_s_k+1;i++){ │ │ │ │ │ -82 while (_h_a_s_h___a_r_r_a_y[i]!=NULL){ │ │ │ │ │ -83 elm = _h_a_s_h___a_r_r_a_y[i]; │ │ │ │ │ +82 while (_h_a_s_h___a_r_r_a_y[i]!=_N_U_L_L){ │ │ │ │ │ +83 _e_l_m = _h_a_s_h___a_r_r_a_y[i]; │ │ │ │ │ 84 _h_a_s_h___a_r_r_a_y[i] = _h_a_s_h___a_r_r_a_y[i]->_n_e_x_t; │ │ │ │ │ -85 delete elm; │ │ │ │ │ +85 delete _e_l_m; │ │ │ │ │ 86 } │ │ │ │ │ 87 } │ │ │ │ │ 88 │ │ │ │ │ 89 delete[] _h_a_s_h___a_r_r_a_y; │ │ │ │ │ 90} │ │ │ │ │ 91 │ │ │ │ │ 92 │ │ │ │ │ @@ -99,123 +99,123 @@ │ │ │ │ │ 96 * - parent parent particle defining the cone │ │ │ │ │ 97 * - child child particle defining the cone │ │ │ │ │ 98 * - p_io whether the parent has to belong to the cone or not │ │ │ │ │ 99 * - c_io whether the child has to belong to the cone or not │ │ │ │ │ 100 * return 0 on success, 1 on error │ │ │ │ │ 101 ***********************************************************************/ │ │ │ │ │ _1_0_2int _h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t(_C_m_o_m_e_n_t_u_m *v, _C_m_o_m_e_n_t_u_m *parent, _C_m_o_m_e_n_t_u_m *child, │ │ │ │ │ -bool p_io, bool c_io){ │ │ │ │ │ -103 _h_a_s_h___e_l_e_m_e_n_t *elm; │ │ │ │ │ +bool _p___i_o, bool _c___i_o){ │ │ │ │ │ +103 _h_a_s_h___e_l_e_m_e_n_t *_e_l_m; │ │ │ │ │ 104 int index = (v->_r_e_f._r_e_f[0]) & _m_a_s_k; │ │ │ │ │ 105 │ │ │ │ │ 106 // check the array cell corresponding to our reference │ │ │ │ │ -107 elm = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ +107 _e_l_m = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ 108 │ │ │ │ │ 109#ifdef DEBUG_STABLE_CONES │ │ │ │ │ -110 if (elm==NULL) │ │ │ │ │ -111 n_occupied_cells++; │ │ │ │ │ +110 if (_e_l_m==_N_U_L_L) │ │ │ │ │ +111 _n___o_c_c_u_p_i_e_d___c_e_l_l_s++; │ │ │ │ │ 112#endif │ │ │ │ │ 113 │ │ │ │ │ 114 do{ │ │ │ │ │ 115 // if it is not present, add it │ │ │ │ │ -116 if (elm==NULL){ │ │ │ │ │ +116 if (_e_l_m==_N_U_L_L){ │ │ │ │ │ 117 // create element │ │ │ │ │ -118 elm = new _h_a_s_h___e_l_e_m_e_n_t; │ │ │ │ │ +118 _e_l_m = new _h_a_s_h___e_l_e_m_e_n_t; │ │ │ │ │ 119 │ │ │ │ │ 120 // set its varibles │ │ │ │ │ 121 // Note: at this level, eta and phi have already been computed │ │ │ │ │ 122 // through Cmomentum::build_etaphi. │ │ │ │ │ -123 elm->_r_e_f = v->_r_e_f; │ │ │ │ │ +123 _e_l_m->ref = v->_r_e_f; │ │ │ │ │ 124 │ │ │ │ │ 125 //compute vectors centre │ │ │ │ │ 126 v->_b_u_i_l_d___e_t_a_p_h_i(); │ │ │ │ │ -127 elm->_e_t_a = v->_e_t_a; │ │ │ │ │ -128 elm->_p_h_i = v->_p_h_i; │ │ │ │ │ +127 _e_l_m->eta = v->_e_t_a; │ │ │ │ │ +128 _e_l_m->phi = v->_p_h_i; │ │ │ │ │ 129 // if at least one of the two is_inside tests gives a result != from the │ │ │ │ │ expected, │ │ │ │ │ 130 // the || will be true hence !(...) false as wanted │ │ │ │ │ -131 elm->_i_s___s_t_a_b_l_e = !((_i_s___i_n_s_i_d_e(v, parent)^p_io)||(_i_s___i_n_s_i_d_e(v, │ │ │ │ │ -child)^c_io)); │ │ │ │ │ +131 _e_l_m->is_stable = !((_i_s___i_n_s_i_d_e(v, parent)^_p___i_o)||(_i_s___i_n_s_i_d_e(v, │ │ │ │ │ +child)^_c___i_o)); │ │ │ │ │ 132 //cout << "-- new status of " << v->ref[0] << ":" << elm->is_stable << │ │ │ │ │ endl; │ │ │ │ │ 133 │ │ │ │ │ 134 // update hash │ │ │ │ │ -135 elm->_n_e_x_t = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ -136 _h_a_s_h___a_r_r_a_y[index] = elm; │ │ │ │ │ +135 _e_l_m->next = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ +136 _h_a_s_h___a_r_r_a_y[index] = _e_l_m; │ │ │ │ │ 137 │ │ │ │ │ 138 _n___c_o_n_e_s++; │ │ │ │ │ 139 return 0; │ │ │ │ │ 140 } │ │ │ │ │ 141 │ │ │ │ │ 142 // if the cone is already there, simply update stability status │ │ │ │ │ -143 if (v->_r_e_f == elm->_r_e_f){ │ │ │ │ │ +143 if (v->_r_e_f == _e_l_m->ref){ │ │ │ │ │ 144 // there is only an update to perform to see if the cone is still stable │ │ │ │ │ -145 if (elm->_i_s___s_t_a_b_l_e){ │ │ │ │ │ +145 if (_e_l_m->is_stable){ │ │ │ │ │ 146 v->_b_u_i_l_d___e_t_a_p_h_i(); │ │ │ │ │ -147 elm->_i_s___s_t_a_b_l_e = !((_i_s___i_n_s_i_d_e(v, parent)^p_io)||(_i_s___i_n_s_i_d_e(v, │ │ │ │ │ -child)^c_io)); │ │ │ │ │ +147 _e_l_m->is_stable = !((_i_s___i_n_s_i_d_e(v, parent)^_p___i_o)||(_i_s___i_n_s_i_d_e(v, │ │ │ │ │ +child)^_c___i_o)); │ │ │ │ │ 148 //cout << " parent/child: " │ │ │ │ │ 149 // << parent->ref[0] << ":" << is_inside(v, parent) << ":" << p_io << " " │ │ │ │ │ 150 // << child->ref[0] << ":" << is_inside(v, child) << ":" << c_io << endl; │ │ │ │ │ 151 //cout << "-- rep status of " << v->ref[0] << ":" << elm->is_stable << │ │ │ │ │ endl; │ │ │ │ │ 152 //cout << v->eta << " " << v->phi << endl; │ │ │ │ │ 153 //cout << (child->eta) << " " << child->phi << endl; │ │ │ │ │ 154 } │ │ │ │ │ 155 return 0; │ │ │ │ │ 156 } │ │ │ │ │ 157 │ │ │ │ │ -158 elm = elm->_n_e_x_t; │ │ │ │ │ +158 _e_l_m = _e_l_m->next; │ │ │ │ │ 159 } while (1); │ │ │ │ │ 160 │ │ │ │ │ 161 return 1; │ │ │ │ │ 162} │ │ │ │ │ 163 │ │ │ │ │ 164/* │ │ │ │ │ 165 * insert a new candidate into the hash. │ │ │ │ │ 166 * - v 4-momentum of te cone to add │ │ │ │ │ 167 * Note, in this case, we assume stability. We also assume │ │ │ │ │ 168 * that eta and phi are computed for v │ │ │ │ │ 169 * return 0 on success, 1 on error │ │ │ │ │ 170 ***********************************************************************/ │ │ │ │ │ _1_7_1int _h_a_s_h___c_o_n_e_s_:_:_i_n_s_e_r_t(_C_m_o_m_e_n_t_u_m *v){ │ │ │ │ │ -172 _h_a_s_h___e_l_e_m_e_n_t *elm; │ │ │ │ │ +172 _h_a_s_h___e_l_e_m_e_n_t *_e_l_m; │ │ │ │ │ 173 int index = (v->_r_e_f._r_e_f[0]) & _m_a_s_k; │ │ │ │ │ 174 //cout << "-- stable candidate: " << v->ref[0] << ":" << endl; │ │ │ │ │ 175 │ │ │ │ │ 176 // check the array cell corresponding to our reference │ │ │ │ │ -177 elm = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ +177 _e_l_m = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ 178 do{ │ │ │ │ │ 179 // if it is not present, add it │ │ │ │ │ -180 if (elm==NULL){ │ │ │ │ │ +180 if (_e_l_m==_N_U_L_L){ │ │ │ │ │ 181 // create element │ │ │ │ │ -182 elm = new _h_a_s_h___e_l_e_m_e_n_t; │ │ │ │ │ +182 _e_l_m = new _h_a_s_h___e_l_e_m_e_n_t; │ │ │ │ │ 183 │ │ │ │ │ 184 // set its varibles │ │ │ │ │ 185 // Note: at this level, eta and phi have already been computed │ │ │ │ │ 186 // through Cmomentum::build_etaphi. │ │ │ │ │ -187 elm->_r_e_f = v->_r_e_f; │ │ │ │ │ -188 elm->_e_t_a = v->_e_t_a; │ │ │ │ │ -189 elm->_p_h_i = v->_p_h_i; │ │ │ │ │ -190 elm->_i_s___s_t_a_b_l_e = true; │ │ │ │ │ +187 _e_l_m->ref = v->_r_e_f; │ │ │ │ │ +188 _e_l_m->eta = v->_e_t_a; │ │ │ │ │ +189 _e_l_m->phi = v->_p_h_i; │ │ │ │ │ +190 _e_l_m->is_stable = true; │ │ │ │ │ 191 │ │ │ │ │ 192 // update hash │ │ │ │ │ -193 elm->_n_e_x_t = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ -194 _h_a_s_h___a_r_r_a_y[index] = elm; │ │ │ │ │ +193 _e_l_m->next = _h_a_s_h___a_r_r_a_y[index]; │ │ │ │ │ +194 _h_a_s_h___a_r_r_a_y[index] = _e_l_m; │ │ │ │ │ 195 │ │ │ │ │ 196 _n___c_o_n_e_s++; │ │ │ │ │ 197 return 0; │ │ │ │ │ 198 } │ │ │ │ │ 199 │ │ │ │ │ 200 // if the cone is already there, we have nothing to do │ │ │ │ │ -201 if (v->_r_e_f == elm->_r_e_f){ │ │ │ │ │ +201 if (v->_r_e_f == _e_l_m->ref){ │ │ │ │ │ 202 return 0; │ │ │ │ │ 203 } │ │ │ │ │ 204 │ │ │ │ │ -205 elm = elm->_n_e_x_t; │ │ │ │ │ +205 _e_l_m = _e_l_m->next; │ │ │ │ │ 206 } while (1); │ │ │ │ │ 207 │ │ │ │ │ 208 return 1; │ │ │ │ │ 209} │ │ │ │ │ 210 │ │ │ │ │ 211/* │ │ │ │ │ 212 * test if a particle is inside a cone of given centre. │ │ │ │ │ @@ -223,22 +223,22 @@ │ │ │ │ │ 214 * centered at 'centre'. │ │ │ │ │ 215 * - centre centre of the circle │ │ │ │ │ 216 * - v particle to test │ │ │ │ │ 217 * return true if inside, false if outside │ │ │ │ │ 218 │ │ │ │ │ ******************************************************************************/ │ │ │ │ │ _2_1_9inline bool _h_a_s_h___c_o_n_e_s_:_:_i_s___i_n_s_i_d_e(_C_m_o_m_e_n_t_u_m *centre, _C_m_o_m_e_n_t_u_m *v){ │ │ │ │ │ -220 double dx, dy; │ │ │ │ │ +220 double _d_x, _d_y; │ │ │ │ │ 221 │ │ │ │ │ -222 dx = centre->_e_t_a - v->_e_t_a; │ │ │ │ │ -223 dy = fabs(centre->_p_h_i - v->_p_h_i); │ │ │ │ │ -224 if (dy>M_PI) │ │ │ │ │ -225 dy -= 2.0*M_PI; │ │ │ │ │ +222 _d_x = centre->_e_t_a - v->_e_t_a; │ │ │ │ │ +223 _d_y = _f_a_b_s(centre->_p_h_i - v->_p_h_i); │ │ │ │ │ +224 if (_d_y>M_PI) │ │ │ │ │ +225 _d_y -= 2.0*M_PI; │ │ │ │ │ 226 │ │ │ │ │ -227 return dx*dx+dy*dy<_R_2; │ │ │ │ │ +227 return _d_x*_d_x+_d_y*_d_y<_R_2; │ │ │ │ │ 228} │ │ │ │ │ 229 │ │ │ │ │ 230} │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m │ │ │ │ │ base class for dynamic coordinates management │ │ │ │ │ DDeeffiinniittiioonn _m_o_m_e_n_t_u_m_._h_:_4_9 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_r_e_f │ │ │ │ │ @@ -258,14 +258,18 @@ │ │ │ │ │ double phi │ │ │ │ │ particle azimuthal angle │ │ │ │ │ DDeeffiinniittiioonn _m_o_m_e_n_t_u_m_._h_:_1_1_5 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f │ │ │ │ │ unsigned int ref[3] │ │ │ │ │ actual data for the reference │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_7_2 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_m_a_s_k │ │ │ │ │ int mask │ │ │ │ │ number of occupied cells │ │ │ │ │ DDeeffiinniittiioonn _h_a_s_h_._h_:_1_0_4 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_h_a_s_h___a_r_r_a_y │ │ │ │ │ hash_element ** hash_array │ │ │ │ │ the cone data itself │ │ │ │ │ @@ -298,25 +302,9 @@ │ │ │ │ │ _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t │ │ │ │ │ information on store cones candidates. │ │ │ │ │ DDeeffiinniittiioonn _h_a_s_h_._h_:_4_5 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_n_e_x_t │ │ │ │ │ hash_element * next │ │ │ │ │ pointer to the next element │ │ │ │ │ DDeeffiinniittiioonn _h_a_s_h_._h_:_5_2 │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_i_s___s_t_a_b_l_e │ │ │ │ │ -bool is_stable │ │ │ │ │ -true if stable w.r.t. "border particles" │ │ │ │ │ -DDeeffiinniittiioonn _h_a_s_h_._h_:_5_0 │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_e_t_a │ │ │ │ │ -double eta │ │ │ │ │ -centre: eta coordinate │ │ │ │ │ -DDeeffiinniittiioonn _h_a_s_h_._h_:_4_8 │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_r_e_f │ │ │ │ │ -Creference ref │ │ │ │ │ -reference │ │ │ │ │ -DDeeffiinniittiioonn _h_a_s_h_._h_:_4_7 │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_h_a_s_h___e_l_e_m_e_n_t_:_:_p_h_i │ │ │ │ │ -double phi │ │ │ │ │ -centre: phi coordinate │ │ │ │ │ -DDeeffiinniittiioonn _h_a_s_h_._h_:_4_9 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/hash_8h_source.html │ │ │ │ @@ -95,42 +95,43 @@ │ │ │ │
52 hash_element *next;
│ │ │ │
53};
│ │ │ │ │ │ │ │
54
│ │ │ │
│ │ │ │ │ │ │ │
63 public:
│ │ │ │ -
67 hash_cones(int _Np, double _R2);
│ │ │ │ +
67 hash_cones(int _Np, double _R2);
│ │ │ │
68
│ │ │ │ │ │ │ │
71
│ │ │ │ -
81 int insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io);
│ │ │ │ +
81 int insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io);
│ │ │ │
82
│ │ │ │
90 int insert(Cmomentum *v);
│ │ │ │
91
│ │ │ │ │ │ │ │
94
│ │ │ │ │ │ │ │
97
│ │ │ │
99#ifdef DEBUG_STABLE_CONES
│ │ │ │ -
100 int n_occupied_cells;
│ │ │ │ + │ │ │ │
101#endif
│ │ │ │
102
│ │ │ │
104 int mask;
│ │ │ │
105
│ │ │ │
108 double R2;
│ │ │ │
109
│ │ │ │
118 inline bool is_inside(Cmomentum *centre, Cmomentum *v);
│ │ │ │
119};
│ │ │ │
│ │ │ │
120
│ │ │ │
121}
│ │ │ │
122#endif
│ │ │ │
base class for dynamic coordinates management
Definition momentum.h:49
│ │ │ │
references used for checksums.
Definition reference.h:43
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
list of cones candidates.
Definition hash.h:62
│ │ │ │
int mask
number of occupied cells
Definition hash.h:104
│ │ │ │
hash_element ** hash_array
the cone data itself
Definition hash.h:93
│ │ │ │
int insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io)
insert a new candidate into the hash.
Definition hash.cpp:102
│ │ │ │
double R2
circle radius (squared) NOTE: need to be set before any call to 'insert'
Definition hash.h:108
│ │ │ │
int n_cones
number of elements
Definition hash.h:96
│ │ │ │
bool is_inside(Cmomentum *centre, Cmomentum *v)
test if a particle is inside a cone of given centre.
Definition hash.cpp:219
│ │ │ │ ├── html2text {} │ │ │ │ │ @@ -43,29 +43,29 @@ │ │ │ │ │ _5_0 bool _i_s___s_t_a_b_l_e; │ │ │ │ │ 51 │ │ │ │ │ _5_2 _h_a_s_h___e_l_e_m_e_n_t *_n_e_x_t; │ │ │ │ │ 53}; │ │ │ │ │ 54 │ │ │ │ │ _6_2class _h_a_s_h___c_o_n_e_s{ │ │ │ │ │ 63 public: │ │ │ │ │ -67 _h_a_s_h___c_o_n_e_s(int _Np, double _R2); │ │ │ │ │ +67 _h_a_s_h___c_o_n_e_s(int ___N_p, double ___R_2); │ │ │ │ │ 68 │ │ │ │ │ 70 _~_h_a_s_h___c_o_n_e_s(); │ │ │ │ │ 71 │ │ │ │ │ -81 int _i_n_s_e_r_t(_C_m_o_m_e_n_t_u_m *v, _C_m_o_m_e_n_t_u_m *parent, _C_m_o_m_e_n_t_u_m *child, bool p_io, │ │ │ │ │ -bool c_io); │ │ │ │ │ +81 int _i_n_s_e_r_t(_C_m_o_m_e_n_t_u_m *v, _C_m_o_m_e_n_t_u_m *parent, _C_m_o_m_e_n_t_u_m *child, bool _p___i_o, │ │ │ │ │ +bool _c___i_o); │ │ │ │ │ 82 │ │ │ │ │ 90 int _i_n_s_e_r_t(_C_m_o_m_e_n_t_u_m *v); │ │ │ │ │ 91 │ │ │ │ │ _9_3 _h_a_s_h___e_l_e_m_e_n_t **_h_a_s_h___a_r_r_a_y; │ │ │ │ │ 94 │ │ │ │ │ _9_6 int _n___c_o_n_e_s; │ │ │ │ │ 97 │ │ │ │ │ 99#ifdef DEBUG_STABLE_CONES │ │ │ │ │ -100 int n_occupied_cells; │ │ │ │ │ +100 int _n___o_c_c_u_p_i_e_d___c_e_l_l_s; │ │ │ │ │ 101#endif │ │ │ │ │ 102 │ │ │ │ │ _1_0_4 int _m_a_s_k; │ │ │ │ │ 105 │ │ │ │ │ _1_0_8 double _R_2; │ │ │ │ │ 109 │ │ │ │ │ 118 inline bool _i_s___i_n_s_i_d_e(_C_m_o_m_e_n_t_u_m *centre, _C_m_o_m_e_n_t_u_m *v); │ │ │ │ │ @@ -75,14 +75,18 @@ │ │ │ │ │ 122#endif │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m │ │ │ │ │ base class for dynamic coordinates management │ │ │ │ │ DDeeffiinniittiioonn _m_o_m_e_n_t_u_m_._h_:_4_9 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e │ │ │ │ │ references used for checksums. │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_4_3 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s │ │ │ │ │ list of cones candidates. │ │ │ │ │ DDeeffiinniittiioonn _h_a_s_h_._h_:_6_2 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_h_a_s_h___c_o_n_e_s_:_:_m_a_s_k │ │ │ │ │ int mask │ │ │ │ │ number of occupied cells │ │ │ │ │ DDeeffiinniittiioonn _h_a_s_h_._h_:_1_0_4 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/momentum_8cpp_source.html │ │ │ │ @@ -100,34 +100,34 @@ │ │ │ │
47 index = -1;
│ │ │ │
48}
│ │ │ │ │ │ │ │
49
│ │ │ │
50// ctor with initialisation
│ │ │ │
51//--------------------------
│ │ │ │
│ │ │ │ -
52Cmomentum::Cmomentum(double _px, double _py, double _pz, double _E){
│ │ │ │ -
53 px = _px;
│ │ │ │ -
54 py = _py;
│ │ │ │ -
55 pz = _pz;
│ │ │ │ -
56 E = _E;
│ │ │ │ +
52Cmomentum::Cmomentum(double _px, double _py, double _pz, double _E){
│ │ │ │ +
53 px = _px;
│ │ │ │ +
54 py = _py;
│ │ │ │ +
55 pz = _pz;
│ │ │ │ +
56 E = _E;
│ │ │ │
57
│ │ │ │
58 // compute eta and phi
│ │ │ │ │ │ │ │
60 ref = Creference();
│ │ │ │
61}
│ │ │ │
│ │ │ │
62
│ │ │ │
63// ctor with detailed initialisation
│ │ │ │
64//-----------------------------------
│ │ │ │
│ │ │ │ -
65Cmomentum::Cmomentum(double _eta, double _phi, Creference _ref){
│ │ │ │ -
66 eta = _eta;
│ │ │ │ + │ │ │ │ +
66 eta = _eta;
│ │ │ │
67 phi = _phi;
│ │ │ │
68
│ │ │ │ -
69 ref = _ref;
│ │ │ │ +
69 ref = _ref;
│ │ │ │
70}
│ │ │ │
│ │ │ │
71
│ │ │ │
72// default dtor
│ │ │ │
73//--------------
│ │ │ │
│ │ │ │ │ │ │ │ @@ -153,16 +153,16 @@ │ │ │ │
│ │ │ │
92
│ │ │ │
93// addition of vectors
│ │ │ │
94// !!! WARNING !!! no updating of eta and phi !!!
│ │ │ │
95//------------------------------------------------
│ │ │ │
│ │ │ │ │ │ │ │ -
97 Cmomentum tmp = *this;
│ │ │ │ -
98 return tmp+=v;
│ │ │ │ +
97 Cmomentum tmp = *this;
│ │ │ │ +
98 return tmp+=v;
│ │ │ │
99}
│ │ │ │
│ │ │ │
100
│ │ │ │
101// incrementation of vectors
│ │ │ │
102// !!! WARNING !!! no updating of eta and phi !!!
│ │ │ │
103//------------------------------------------------
│ │ │ │
│ │ │ │ @@ -198,25 +198,25 @@ │ │ │ │
130// !!! computing eta and phi is time-consuming !!!
│ │ │ │
131// !!! use this whenever you need eta or phi !!!
│ │ │ │
132// !!! automatically called for single-particle !!!
│ │ │ │
133//--------------------------------------------------
│ │ │ │
│ │ │ │ │ │ │ │
135 // note: the factor n (ref.nb) cancels in all expressions !!
│ │ │ │ -
136 eta = 0.5*log((E+pz)/(E-pz));
│ │ │ │ -
137 phi = atan2(py,px);
│ │ │ │ +
136 eta = 0.5*log((E+pz)/(E-pz));
│ │ │ │ +
137 phi = atan2(py,px);
│ │ │ │
138}
│ │ │ │
│ │ │ │
139
│ │ │ │
140
│ │ │ │
141// ordering of two vectors
│ │ │ │
142// the default ordering is w.r.t. their references
│ │ │ │
143//-------------------------------------------------
│ │ │ │ -
144bool operator < (const Cmomentum &v1, const Cmomentum &v2){
│ │ │ │ -
145 return v1.ref < v2.ref;
│ │ │ │ +
144bool operator < (const Cmomentum &v1, const Cmomentum &v2){
│ │ │ │ +
145 return v1.ref < v2.ref;
│ │ │ │
146}
│ │ │ │
147
│ │ │ │
148// ordering of vectors in eta (e.g. used in collinear tests)
│ │ │ │
149//-----------------------------------------------------------
│ │ │ │
150bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2){
│ │ │ │
151 return v1.eta < v2.eta;
│ │ │ │
152}
│ │ │ │ @@ -242,14 +242,15 @@ │ │ │ │
double px
x-momentum
Definition momentum.h:109
│ │ │ │
Cmomentum & operator=(const Cmomentum &v)
assignment of vectors
Definition momentum.cpp:80
│ │ │ │
double E
energy
Definition momentum.h:112
│ │ │ │
double pz
z-momentum
Definition momentum.h:111
│ │ │ │
Cmomentum()
default ctor
Definition momentum.cpp:42
│ │ │ │
double phi
particle azimuthal angle
Definition momentum.h:115
│ │ │ │
references used for checksums.
Definition reference.h:43
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -48,32 +48,32 @@ │ │ │ │ │ 45 _p_x = _p_y = _p_z = _E = 0.0; │ │ │ │ │ 46 _r_e_f = _C_r_e_f_e_r_e_n_c_e(); │ │ │ │ │ 47 _i_n_d_e_x = -1; │ │ │ │ │ 48} │ │ │ │ │ 49 │ │ │ │ │ 50// ctor with initialisation │ │ │ │ │ 51//-------------------------- │ │ │ │ │ -_5_2_C_m_o_m_e_n_t_u_m_:_:_C_m_o_m_e_n_t_u_m(double _px, double _py, double _pz, double _E){ │ │ │ │ │ -53 _p_x = _px; │ │ │ │ │ -54 _p_y = _py; │ │ │ │ │ -55 _p_z = _pz; │ │ │ │ │ -56 _E = _E; │ │ │ │ │ +_5_2_C_m_o_m_e_n_t_u_m_:_:_C_m_o_m_e_n_t_u_m(double ___p_x, double ___p_y, double ___p_z, double ___E){ │ │ │ │ │ +53 _p_x = ___p_x; │ │ │ │ │ +54 _p_y = ___p_y; │ │ │ │ │ +55 _p_z = ___p_z; │ │ │ │ │ +56 _E = ___E; │ │ │ │ │ 57 │ │ │ │ │ 58 // compute eta and phi │ │ │ │ │ 59 _b_u_i_l_d___e_t_a_p_h_i(); │ │ │ │ │ 60 _r_e_f = _C_r_e_f_e_r_e_n_c_e(); │ │ │ │ │ 61} │ │ │ │ │ 62 │ │ │ │ │ 63// ctor with detailed initialisation │ │ │ │ │ 64//----------------------------------- │ │ │ │ │ -_6_5_C_m_o_m_e_n_t_u_m_:_:_C_m_o_m_e_n_t_u_m(double _eta, double _phi, _C_r_e_f_e_r_e_n_c_e _ref){ │ │ │ │ │ -66 _e_t_a = _eta; │ │ │ │ │ +_6_5_C_m_o_m_e_n_t_u_m_:_:_C_m_o_m_e_n_t_u_m(double ___e_t_a, double _phi, _C_r_e_f_e_r_e_n_c_e ___r_e_f){ │ │ │ │ │ +66 _e_t_a = ___e_t_a; │ │ │ │ │ 67 _p_h_i = _phi; │ │ │ │ │ 68 │ │ │ │ │ -69 _r_e_f = _ref; │ │ │ │ │ +69 _r_e_f = ___r_e_f; │ │ │ │ │ 70} │ │ │ │ │ 71 │ │ │ │ │ 72// default dtor │ │ │ │ │ 73//-------------- │ │ │ │ │ _7_4_C_m_o_m_e_n_t_u_m_:_:_~_C_m_o_m_e_n_t_u_m(){ │ │ │ │ │ 75 │ │ │ │ │ 76} │ │ │ │ │ @@ -93,16 +93,16 @@ │ │ │ │ │ 90 return *this; │ │ │ │ │ 91} │ │ │ │ │ 92 │ │ │ │ │ 93// addition of vectors │ │ │ │ │ 94// !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ 95//------------------------------------------------ │ │ │ │ │ _9_6const _C_m_o_m_e_n_t_u_m _C_m_o_m_e_n_t_u_m_:_:_o_p_e_r_a_t_o_r_ _+_ (const _C_m_o_m_e_n_t_u_m &v){ │ │ │ │ │ -97 _C_m_o_m_e_n_t_u_m tmp = *this; │ │ │ │ │ -98 return tmp+=v; │ │ │ │ │ +97 _C_m_o_m_e_n_t_u_m _t_m_p = *this; │ │ │ │ │ +98 return _t_m_p+=v; │ │ │ │ │ 99} │ │ │ │ │ 100 │ │ │ │ │ 101// incrementation of vectors │ │ │ │ │ 102// !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ 103//------------------------------------------------ │ │ │ │ │ _1_0_4_C_m_o_m_e_n_t_u_m& _C_m_o_m_e_n_t_u_m_:_:_o_p_e_r_a_t_o_r_ _+_=_ (const _C_m_o_m_e_n_t_u_m &v){ │ │ │ │ │ 105 _p_x+=v._p_x; │ │ │ │ │ @@ -132,24 +132,24 @@ │ │ │ │ │ 129// !!! WARNING !!! │ │ │ │ │ 130// !!! computing eta and phi is time-consuming !!! │ │ │ │ │ 131// !!! use this whenever you need eta or phi !!! │ │ │ │ │ 132// !!! automatically called for single-particle !!! │ │ │ │ │ 133//-------------------------------------------------- │ │ │ │ │ _1_3_4void _C_m_o_m_e_n_t_u_m_:_:_b_u_i_l_d___e_t_a_p_h_i(){ │ │ │ │ │ 135 // note: the factor n (ref.nb) cancels in all expressions !! │ │ │ │ │ -136 _e_t_a = 0.5*log((_E+_p_z)/(_E-_p_z)); │ │ │ │ │ -137 _p_h_i = atan2(_p_y,_p_x); │ │ │ │ │ +136 _e_t_a = 0.5*_l_o_g((_E+_p_z)/(_E-_p_z)); │ │ │ │ │ +137 _p_h_i = _a_t_a_n_2(_p_y,_p_x); │ │ │ │ │ 138} │ │ │ │ │ 139 │ │ │ │ │ 140 │ │ │ │ │ 141// ordering of two vectors │ │ │ │ │ 142// the default ordering is w.r.t. their references │ │ │ │ │ 143//------------------------------------------------- │ │ │ │ │ -144bool operator < (const _C_m_o_m_e_n_t_u_m &v1, const _C_m_o_m_e_n_t_u_m &v2){ │ │ │ │ │ -145 return v1._r_e_f < v2._r_e_f; │ │ │ │ │ +144bool _o_p_e_r_a_t_o_r_ _<_ (const _C_m_o_m_e_n_t_u_m &_v_1, const _C_m_o_m_e_n_t_u_m &_v_2){ │ │ │ │ │ +145 return _v_1.ref < _v_2.ref; │ │ │ │ │ 146} │ │ │ │ │ 147 │ │ │ │ │ 148// ordering of vectors in eta (e.g. used in collinear tests) │ │ │ │ │ 149//----------------------------------------------------------- │ │ │ │ │ 150bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ 151 return v1.eta < v2.eta; │ │ │ │ │ 152} │ │ │ │ │ @@ -225,9 +225,13 @@ │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_p_h_i │ │ │ │ │ double phi │ │ │ │ │ particle azimuthal angle │ │ │ │ │ DDeeffiinniittiioonn _m_o_m_e_n_t_u_m_._h_:_1_1_5 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e │ │ │ │ │ references used for checksums. │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_4_3 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/momentum_8h_source.html │ │ │ │ @@ -88,33 +88,33 @@ │ │ │ │
37namespace siscone{
│ │ │ │
38
│ │ │ │
│ │ │ │ │ │ │ │
50 public:
│ │ │ │
52 Cmomentum();
│ │ │ │
53
│ │ │ │ -
55 Cmomentum(double _px, double _py, double _pz, double _E);
│ │ │ │ +
55 Cmomentum(double _px, double _py, double _pz, double _E);
│ │ │ │
56
│ │ │ │ -
58 Cmomentum(double _eta, double _phi, Creference _ref);
│ │ │ │ +
58 Cmomentum(double _eta, double _phi, Creference _ref);
│ │ │ │
59
│ │ │ │
61 ~Cmomentum();
│ │ │ │
62
│ │ │ │ -
64 inline double perp() const {return sqrt(perp2());}
│ │ │ │ +
64 inline double perp() const {return sqrt(perp2());}
│ │ │ │
65
│ │ │ │
67 inline double perp2() const {return px*px+py*py;}
│ │ │ │
68
│ │ │ │ -
70 inline double mass() const {return sqrt(mass2());}
│ │ │ │ +
70 inline double mass() const {return sqrt(mass2());}
│ │ │ │
71
│ │ │ │
73 inline double mass2() const {return perpmass2()-perp2();}
│ │ │ │
74
│ │ │ │ -
76 inline double perpmass() const {return sqrt((E-pz)*(E+pz));}
│ │ │ │ +
76 inline double perpmass() const {return sqrt((E-pz)*(E+pz));}
│ │ │ │
77
│ │ │ │
79 inline double perpmass2() const {return (E-pz)*(E+pz);}
│ │ │ │
80
│ │ │ │ -
82 inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());}
│ │ │ │ +
82 inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());}
│ │ │ │
83
│ │ │ │
85 inline double Et2() const {return E*E/(1.0+pz*pz/perp2());}
│ │ │ │
86
│ │ │ │ │ │ │ │
89
│ │ │ │
92 const Cmomentum operator + (const Cmomentum &v);
│ │ │ │
93
│ │ │ │ @@ -135,32 +135,32 @@ │ │ │ │
117 int index;
│ │ │ │
118
│ │ │ │
120 // the following part is used for checksums //
│ │ │ │ │ │ │ │
123};
│ │ │ │
│ │ │ │
124
│ │ │ │ -
127bool operator < (const Cmomentum &v1, const Cmomentum &v2);
│ │ │ │ +
127bool operator < (const Cmomentum &v1, const Cmomentum &v2);
│ │ │ │
128
│ │ │ │ -
130bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2);
│ │ │ │ +
130bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2);
│ │ │ │
131
│ │ │ │ -
133bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2);
│ │ │ │ +
133bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2);
│ │ │ │
134
│ │ │ │
135
│ │ │ │
137// some handy utilities //
│ │ │ │
139
│ │ │ │
144inline double get_distance(double eta, double phi, Cmomentum *v){
│ │ │ │ -
145 double dx, dy;
│ │ │ │ +
145 double dx, dy;
│ │ │ │
146
│ │ │ │ -
147 dx = eta - v->eta;
│ │ │ │ -
148 dy = fabs(phi - v->phi);
│ │ │ │ -
149 if (dy>M_PI)
│ │ │ │ -
150 dy -= twopi;
│ │ │ │ +
147 dx = eta - v->eta;
│ │ │ │ +
148 dy = fabs(phi - v->phi);
│ │ │ │ +
149 if (dy>M_PI)
│ │ │ │ +
150 dy -= twopi;
│ │ │ │
151
│ │ │ │ -
152 return dx*dx+dy*dy;
│ │ │ │ +
152 return dx*dx+dy*dy;
│ │ │ │
153}
│ │ │ │
154
│ │ │ │
155}
│ │ │ │
156
│ │ │ │
157#endif
│ │ │ │
base class for dynamic coordinates management
Definition momentum.h:49
│ │ │ │
Cmomentum & operator+=(const Cmomentum &v)
incrementation of vectors !!! WARNING !!! no updating of eta and phi !!!
Definition momentum.cpp:104
│ │ │ │ @@ -184,14 +184,15 @@ │ │ │ │
double E
energy
Definition momentum.h:112
│ │ │ │
double pz
z-momentum
Definition momentum.h:111
│ │ │ │
double perp() const
computes pT
Definition momentum.h:64
│ │ │ │
Cmomentum()
default ctor
Definition momentum.cpp:42
│ │ │ │
double phi
particle azimuthal angle
Definition momentum.h:115
│ │ │ │
double perpmass() const
transverse mass, mt = sqrt(pt^2+m^2) = sqrt(E^2 - pz^2)
Definition momentum.h:76
│ │ │ │
references used for checksums.
Definition reference.h:43
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
│ │ │ │
const double twopi
definition of 2*M_PI which is useful a bit everyhere!
Definition defines.h:114
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -38,33 +38,33 @@ │ │ │ │ │ 36 │ │ │ │ │ 37namespace siscone{ │ │ │ │ │ 38 │ │ │ │ │ _4_9class _C_m_o_m_e_n_t_u_m{ │ │ │ │ │ 50 public: │ │ │ │ │ 52 _C_m_o_m_e_n_t_u_m(); │ │ │ │ │ 53 │ │ │ │ │ -55 _C_m_o_m_e_n_t_u_m(double _px, double _py, double _pz, double _E); │ │ │ │ │ +55 _C_m_o_m_e_n_t_u_m(double ___p_x, double ___p_y, double ___p_z, double ___E); │ │ │ │ │ 56 │ │ │ │ │ -58 _C_m_o_m_e_n_t_u_m(double _eta, double _phi, _C_r_e_f_e_r_e_n_c_e _ref); │ │ │ │ │ +58 _C_m_o_m_e_n_t_u_m(double ___e_t_a, double _phi, _C_r_e_f_e_r_e_n_c_e ___r_e_f); │ │ │ │ │ 59 │ │ │ │ │ 61 _~_C_m_o_m_e_n_t_u_m(); │ │ │ │ │ 62 │ │ │ │ │ -_6_4 inline double _p_e_r_p() const {return sqrt(_p_e_r_p_2());} │ │ │ │ │ +_6_4 inline double _p_e_r_p() const {return _s_q_r_t(_p_e_r_p_2());} │ │ │ │ │ 65 │ │ │ │ │ _6_7 inline double _p_e_r_p_2() const {return _p_x*_p_x+_p_y*_p_y;} │ │ │ │ │ 68 │ │ │ │ │ -_7_0 inline double _m_a_s_s() const {return sqrt(_m_a_s_s_2());} │ │ │ │ │ +_7_0 inline double _m_a_s_s() const {return _s_q_r_t(_m_a_s_s_2());} │ │ │ │ │ 71 │ │ │ │ │ _7_3 inline double _m_a_s_s_2() const {return _p_e_r_p_m_a_s_s_2()-_p_e_r_p_2();} │ │ │ │ │ 74 │ │ │ │ │ -_7_6 inline double _p_e_r_p_m_a_s_s() const {return sqrt((_E-_p_z)*(_E+_p_z));} │ │ │ │ │ +_7_6 inline double _p_e_r_p_m_a_s_s() const {return _s_q_r_t((_E-_p_z)*(_E+_p_z));} │ │ │ │ │ 77 │ │ │ │ │ _7_9 inline double _p_e_r_p_m_a_s_s_2() const {return (_E-_p_z)*(_E+_p_z);} │ │ │ │ │ 80 │ │ │ │ │ -_8_2 inline double _E_t() const {return _E/sqrt(1.0+_p_z*_p_z/_p_e_r_p_2());} │ │ │ │ │ +_8_2 inline double _E_t() const {return _E/_s_q_r_t(1.0+_p_z*_p_z/_p_e_r_p_2());} │ │ │ │ │ 83 │ │ │ │ │ _8_5 inline double _E_t_2() const {return _E*_E/(1.0+_p_z*_p_z/_p_e_r_p_2());} │ │ │ │ │ 86 │ │ │ │ │ 88 _C_m_o_m_e_n_t_u_m& _o_p_e_r_a_t_o_r_ _=_ (const _C_m_o_m_e_n_t_u_m &v); │ │ │ │ │ 89 │ │ │ │ │ 92 const _C_m_o_m_e_n_t_u_m _o_p_e_r_a_t_o_r_ _+_ (const _C_m_o_m_e_n_t_u_m &v); │ │ │ │ │ 93 │ │ │ │ │ @@ -84,32 +84,32 @@ │ │ │ │ │ _1_1_6 int _p_a_r_e_n_t___i_n_d_e_x; │ │ │ │ │ _1_1_7 int _i_n_d_e_x; │ │ │ │ │ 118 │ │ │ │ │ 120 // the following part is used for checksums // │ │ │ │ │ _1_2_2 _C_r_e_f_e_r_e_n_c_e _r_e_f; │ │ │ │ │ 123}; │ │ │ │ │ 124 │ │ │ │ │ -127bool operator < (const _C_m_o_m_e_n_t_u_m &v1, const _C_m_o_m_e_n_t_u_m &v2); │ │ │ │ │ +127bool _o_p_e_r_a_t_o_r_ _<_ (const _C_m_o_m_e_n_t_u_m &_v_1, const _C_m_o_m_e_n_t_u_m &_v_2); │ │ │ │ │ 128 │ │ │ │ │ -130bool momentum_eta_less(const _C_m_o_m_e_n_t_u_m &v1, const _C_m_o_m_e_n_t_u_m &v2); │ │ │ │ │ +130bool momentum_eta_less(const _C_m_o_m_e_n_t_u_m &_v_1, const _C_m_o_m_e_n_t_u_m &_v_2); │ │ │ │ │ 131 │ │ │ │ │ -133bool momentum_pt_less(const _C_m_o_m_e_n_t_u_m &v1, const _C_m_o_m_e_n_t_u_m &v2); │ │ │ │ │ +133bool momentum_pt_less(const _C_m_o_m_e_n_t_u_m &_v_1, const _C_m_o_m_e_n_t_u_m &_v_2); │ │ │ │ │ 134 │ │ │ │ │ 135 │ │ │ │ │ 137// some handy utilities // │ │ │ │ │ 139 │ │ │ │ │ 144inline double get_distance(double eta, double phi, _C_m_o_m_e_n_t_u_m *v){ │ │ │ │ │ -145 double dx, dy; │ │ │ │ │ +145 double _d_x, _d_y; │ │ │ │ │ 146 │ │ │ │ │ -147 dx = eta - v->_e_t_a; │ │ │ │ │ -148 dy = fabs(phi - v->_p_h_i); │ │ │ │ │ -149 if (dy>M_PI) │ │ │ │ │ -150 dy -= _t_w_o_p_i; │ │ │ │ │ +147 _d_x = eta - v->_e_t_a; │ │ │ │ │ +148 _d_y = _f_a_b_s(phi - v->_p_h_i); │ │ │ │ │ +149 if (_d_y>M_PI) │ │ │ │ │ +150 _d_y -= _t_w_o_p_i; │ │ │ │ │ 151 │ │ │ │ │ -152 return dx*dx+dy*dy; │ │ │ │ │ +152 return _d_x*_d_x+_d_y*_d_y; │ │ │ │ │ 153} │ │ │ │ │ 154 │ │ │ │ │ 155} │ │ │ │ │ 156 │ │ │ │ │ 157#endif │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m │ │ │ │ │ base class for dynamic coordinates management │ │ │ │ │ @@ -210,14 +210,18 @@ │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_m_o_m_e_n_t_u_m_:_:_p_e_r_p_m_a_s_s │ │ │ │ │ double perpmass() const │ │ │ │ │ transverse mass, mt = sqrt(pt^2+m^2) = sqrt(E^2 - pz^2) │ │ │ │ │ DDeeffiinniittiioonn _m_o_m_e_n_t_u_m_._h_:_7_6 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e │ │ │ │ │ references used for checksums. │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_4_3 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ _d_e_f_i_n_e_s_._h │ │ │ │ │ _t_w_o_p_i │ │ │ │ │ const double twopi │ │ │ │ │ definition of 2*M_PI which is useful a bit everyhere! │ │ │ │ │ DDeeffiinniittiioonn _d_e_f_i_n_e_s_._h_:_1_1_4 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/quadtree_8cpp_source.html │ │ │ │ @@ -92,44 +92,44 @@ │ │ │ │
40 * The elements at each node are of 'Cmomentum' type. *
│ │ │ │
41 *******************************************************************/
│ │ │ │
42
│ │ │ │
43// default ctor
│ │ │ │
44//--------------
│ │ │ │
│ │ │ │ │ │ │ │ -
46 v = NULL;
│ │ │ │ +
46 v = NULL;
│ │ │ │
47
│ │ │ │ -
48 children[0][0] = children[0][1] = children[1][0] = children[1][1] = NULL;
│ │ │ │ +
48 children[0][0] = children[0][1] = children[1][0] = children[1][1] = NULL;
│ │ │ │
49 has_child = false;
│ │ │ │
50}
│ │ │ │
│ │ │ │
51
│ │ │ │
52
│ │ │ │
53// ctor with initialisation (see init for details)
│ │ │ │
54//--------------------------
│ │ │ │
│ │ │ │ -
55Cquadtree::Cquadtree(double _x, double _y, double _half_size_x, double _half_size_y){
│ │ │ │ -
56 v = NULL;
│ │ │ │ +
55Cquadtree::Cquadtree(double _x, double _y, double _half_size_x, double _half_size_y){
│ │ │ │ +
56 v = NULL;
│ │ │ │
57
│ │ │ │ -
58 children[0][0] = children[0][1] = children[1][0] = children[1][1] = NULL;
│ │ │ │ +
58 children[0][0] = children[0][1] = children[1][0] = children[1][1] = NULL;
│ │ │ │
59 has_child = false;
│ │ │ │
60
│ │ │ │ -
61 init(_x, _y, _half_size_x, _half_size_y);
│ │ │ │ + │ │ │ │
62}
│ │ │ │
│ │ │ │
63
│ │ │ │
64
│ │ │ │
65// default destructor
│ │ │ │
66// at destruction, everything is destroyed except
│ │ │ │
67// physical values at the leaves
│ │ │ │
68//------------------------------------------------
│ │ │ │
│ │ │ │ │ │ │ │
70 if (has_child){
│ │ │ │ -
71 if (v!=NULL) delete v;
│ │ │ │ +
71 if (v!=NULL) delete v;
│ │ │ │
72 delete children[0][0];
│ │ │ │
73 delete children[0][1];
│ │ │ │
74 delete children[1][0];
│ │ │ │
75 delete children[1][1];
│ │ │ │
76 }
│ │ │ │
77}
│ │ │ │
│ │ │ │ @@ -143,86 +143,86 @@ │ │ │ │
85 * - _y y-position of the center
│ │ │ │
86 * - half_size_x half x-size of the cell
│ │ │ │
87 * - half_size_y half y-size of the cell
│ │ │ │
88 * return 0 on success, 1 on error. Note that if the cell
│ │ │ │
89 * is already filled, we return an error.
│ │ │ │
90 ******************************************************************/
│ │ │ │
│ │ │ │ -
91int Cquadtree::init(double _x, double _y, double _half_size_x, double _half_size_y){
│ │ │ │ -
92 if (v!=NULL)
│ │ │ │ +
91int Cquadtree::init(double _x, double _y, double _half_size_x, double _half_size_y){
│ │ │ │ +
92 if (v!=NULL)
│ │ │ │
93 return 1;
│ │ │ │
94
│ │ │ │ -
95 centre_x = _x;
│ │ │ │ -
96 centre_y = _y;
│ │ │ │ -
97 half_size_x = _half_size_x;
│ │ │ │ -
98 half_size_y = _half_size_y;
│ │ │ │ +
95 centre_x = _x;
│ │ │ │ +
96 centre_y = _y;
│ │ │ │ + │ │ │ │ + │ │ │ │
99
│ │ │ │
100 return 0;
│ │ │ │
101}
│ │ │ │
│ │ │ │
102
│ │ │ │
103
│ │ │ │
104/*
│ │ │ │
105 * adding a particle to the tree.
│ │ │ │
106 * This method adds one vector to the quadtree structure which
│ │ │ │
107 * is updated consequently.
│ │ │ │
108 * - v vector to add
│ │ │ │
109 * return 0 on success 1 on error
│ │ │ │
110 ******************************************************************/
│ │ │ │
│ │ │ │ - │ │ │ │ + │ │ │ │
112 // Description of the method:
│ │ │ │
113 // --------------------------
│ │ │ │
114 // the addition process goes as follows:
│ │ │ │
115 // 1. check if the cell is empty, in which case, add the particle
│ │ │ │
116 // here and leave.
│ │ │ │
117 // 2. If there is a unique particle already inside,
│ │ │ │
118 // (a) create children
│ │ │ │
119 // (b) forward the existing particle to the appropriate child
│ │ │ │
120 // 3. Add current particle to this cell and forward to the
│ │ │ │
121 // adequate child
│ │ │ │
122 // NOTE: we assume in the whole procedure that the particle is
│ │ │ │
123 // indeed inside the cell !
│ │ │ │
124
│ │ │ │
125 // step 1: the case of empty cells
│ │ │ │ -
126 if (v==NULL){
│ │ │ │ -
127 v = v_add;
│ │ │ │ +
126 if (v==NULL){
│ │ │ │ +
127 v = v_add;
│ │ │ │
128 return 0;
│ │ │ │
129 }
│ │ │ │
130
│ │ │ │
131 // step 2: additional work if 1! particle already present
│ │ │ │
132 // we use the fact that only 1-particle systems have no child
│ │ │ │
133 if (!has_child){
│ │ │ │ -
134 double new_half_size_x = 0.5*half_size_x;
│ │ │ │ -
135 double new_half_size_y = 0.5*half_size_y;
│ │ │ │ +
134 double new_half_size_x = 0.5*half_size_x;
│ │ │ │ +
135 double new_half_size_y = 0.5*half_size_y;
│ │ │ │
136 // create children
│ │ │ │ -
137 children[0][0] = new Cquadtree(centre_x-new_half_size_x, centre_y-new_half_size_y,
│ │ │ │ -
138 new_half_size_x, new_half_size_y);
│ │ │ │ -
139 children[0][1] = new Cquadtree(centre_x-new_half_size_x, centre_y+new_half_size_y,
│ │ │ │ -
140 new_half_size_x, new_half_size_y);
│ │ │ │ -
141 children[1][0] = new Cquadtree(centre_x+new_half_size_x, centre_y-new_half_size_y,
│ │ │ │ -
142 new_half_size_x, new_half_size_y);
│ │ │ │ -
143 children[1][1] = new Cquadtree(centre_x+new_half_size_x, centre_y+new_half_size_y,
│ │ │ │ -
144 new_half_size_x, new_half_size_y);
│ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │ + │ │ │ │
145
│ │ │ │
146 has_child = true;
│ │ │ │
147
│ │ │ │
148 // forward to child
│ │ │ │
149 //? The following line assumes 'true'==1 and 'false'==0
│ │ │ │
150 // Note: v being a single particle, eta and phi are correct
│ │ │ │ │ │ │ │
152
│ │ │ │
153 // copy physical params
│ │ │ │
154 v = new Cmomentum(*v);
│ │ │ │
155 }
│ │ │ │
156
│ │ │ │
157 // step 3: add new particle
│ │ │ │
158 // Note: v_add being a single particle, eta and phi are correct
│ │ │ │ -
159 children[v_add->eta>centre_x][v_add->phi>centre_y]->add(v_add);
│ │ │ │ -
160 *v+=*v_add;
│ │ │ │ + │ │ │ │ +
160 *v+=*v_add;
│ │ │ │
161
│ │ │ │
162 return 0;
│ │ │ │
163}
│ │ │ │
│ │ │ │
164
│ │ │ │
165
│ │ │ │
166/*
│ │ │ │ @@ -232,112 +232,112 @@ │ │ │ │
170 * in the circle.
│ │ │ │
171 * - cx circle centre x coordinate
│ │ │ │
172 * - cy circle centre y coordinate
│ │ │ │
173 * - cR2 circle radius SQUARED
│ │ │ │
174 * return the checksum for the intersection
│ │ │ │
175 ******************************************************************/
│ │ │ │
│ │ │ │ -
176Creference Cquadtree::circle_intersect(double cx, double cy, double cR2){
│ │ │ │ + │ │ │ │
177 // Description of the method:
│ │ │ │
178 // --------------------------
│ │ │ │
179 // 1. check if cell is empty => no intersection
│ │ │ │
180 // 2. if cell has 1! particle, check if it is inside the circle.
│ │ │ │
181 // If yes, add it and return, if not simply return.
│ │ │ │
182 // 3. check if the circle intersects the square. If not, return.
│ │ │ │
183 // 4. check if the square is inside the circle.
│ │ │ │
184 // If yes, add it to qt and return.
│ │ │ │
185 // 5. check intersections with children.
│ │ │ │
186
│ │ │ │
187 // step 1: if there is no particle inside te square, no reason to go further
│ │ │ │ -
188 if (v==NULL)
│ │ │ │ +
188 if (v==NULL)
│ │ │ │
189 return Creference();
│ │ │ │
190
│ │ │ │ -
191 double dx, dy;
│ │ │ │ +
191 double dx, dy;
│ │ │ │
192
│ │ │ │
193 // step 2: if there is only one particle inside the square, test if it is in
│ │ │ │
194 // the circle, in which case return associated reference
│ │ │ │
195 if (!has_child){
│ │ │ │
196 // compute the distance
│ │ │ │
197 // Note: v has only one particle => eta and phi are defined
│ │ │ │ -
198 dx = cx - v->eta;
│ │ │ │ -
199 dy = fabs(cy - v->phi);
│ │ │ │ -
200 if (dy>M_PI)
│ │ │ │ -
201 dy -= 2.0*M_PI;
│ │ │ │ +
198 dx = cx - v->eta;
│ │ │ │ +
199 dy = fabs(cy - v->phi);
│ │ │ │ +
200 if (dy>M_PI)
│ │ │ │ +
201 dy -= 2.0*M_PI;
│ │ │ │
202
│ │ │ │
203 // test distance
│ │ │ │ -
204 if (dx*dx+dy*dy<cR2){
│ │ │ │ +
204 if (dx*dx+dy*dy<cR2){
│ │ │ │
205 return v->ref;
│ │ │ │
206 }
│ │ │ │
207
│ │ │ │
208 return Creference();
│ │ │ │
209 }
│ │ │ │
210
│ │ │ │
211 // step 3: check if there is an intersection
│ │ │ │
212 //double ryp, rym;
│ │ │ │ -
213 double dx_c, dy_c;
│ │ │ │ +
213 double dx_c, dy_c;
│ │ │ │
214
│ │ │ │
215 // store distance with the centre of the square
│ │ │ │ -
216 dx_c = fabs(cx-centre_x);
│ │ │ │ -
217 dy_c = fabs(cy-centre_y);
│ │ │ │ -
218 if (dy_c>M_PI) dy_c = 2.0*M_PI-dy_c;
│ │ │ │ +
216 dx_c = fabs(cx-centre_x);
│ │ │ │ +
217 dy_c = fabs(cy-centre_y);
│ │ │ │ +
218 if (dy_c>M_PI) dy_c = 2.0*M_PI-dy_c;
│ │ │ │
219
│ │ │ │
220 // compute (minimal) the distance (pay attention to the periodicity in phi).
│ │ │ │ -
221 dx = dx_c-half_size_x;
│ │ │ │ -
222 if (dx<0) dx=0;
│ │ │ │ -
223 dy = dy_c-half_size_y;
│ │ │ │ -
224 if (dy<0) dy=0;
│ │ │ │ + │ │ │ │ +
222 if (dx<0) dx=0;
│ │ │ │ + │ │ │ │ +
224 if (dy<0) dy=0;
│ │ │ │
225
│ │ │ │
226 // check the distance
│ │ │ │ -
227 if (dx*dx+dy*dy>=cR2){
│ │ │ │ +
227 if (dx*dx+dy*dy>=cR2){
│ │ │ │
228 // no intersection
│ │ │ │
229 return Creference();
│ │ │ │
230 }
│ │ │ │
231
│ │ │ │
232 // step 4: check if included
│ │ │ │
233
│ │ │ │
234 // compute the (maximal) distance
│ │ │ │ -
235 dx = dx_c+half_size_x;
│ │ │ │ -
236 dy = dy_c+half_size_y;
│ │ │ │ -
237 if (dy>M_PI) dy = M_PI;
│ │ │ │ + │ │ │ │ + │ │ │ │ +
237 if (dy>M_PI) dy = M_PI;
│ │ │ │
238
│ │ │ │
239 // compute the distance
│ │ │ │ -
240 if (dx*dx+dy*dy<cR2){
│ │ │ │ +
240 if (dx*dx+dy*dy<cR2){
│ │ │ │
241 return v->ref;
│ │ │ │
242 }
│ │ │ │
243
│ │ │ │
244 // step 5: the square is not fully in. Recurse to children
│ │ │ │ -
245 return children[0][0]->circle_intersect(cx, cy, cR2)
│ │ │ │ -
246 + children[0][1]->circle_intersect(cx, cy, cR2)
│ │ │ │ -
247 + children[1][0]->circle_intersect(cx, cy, cR2)
│ │ │ │ -
248 + children[1][1]->circle_intersect(cx, cy, cR2);
│ │ │ │ +
245 return children[0][0]->circle_intersect(cx, cy, cR2)
│ │ │ │ +
246 + children[0][1]->circle_intersect(cx, cy, cR2)
│ │ │ │ +
247 + children[1][0]->circle_intersect(cx, cy, cR2)
│ │ │ │ +
248 + children[1][1]->circle_intersect(cx, cy, cR2);
│ │ │ │
249}
│ │ │ │
│ │ │ │
250
│ │ │ │
251
│ │ │ │
252/*
│ │ │ │
253 * output a data file for drawing the grid.
│ │ │ │
254 * This can be used to output a data file containing all the
│ │ │ │
255 * grid subdivisions. The file contents is as follows:
│ │ │ │
256 * first and second columns give center of the cell, the third
│ │ │ │
257 * gives the size.
│ │ │ │
258 * - flux opened stream to write to
│ │ │ │
259 * return 0 on success, 1 on error
│ │ │ │
260 ******************************************************************/
│ │ │ │
│ │ │ │ -
261int Cquadtree::save(FILE *flux){
│ │ │ │ + │ │ │ │
262
│ │ │ │ -
263 if (flux==NULL)
│ │ │ │ +
263 if (flux==NULL)
│ │ │ │
264 return 1;
│ │ │ │
265
│ │ │ │
266 if (has_child){
│ │ │ │ -
267 fprintf(flux, "%e\t%e\t%e\t%e\n", centre_x, centre_y, half_size_x, half_size_y);
│ │ │ │ -
268 children[0][0]->save(flux);
│ │ │ │ -
269 children[0][1]->save(flux);
│ │ │ │ -
270 children[1][0]->save(flux);
│ │ │ │ -
271 children[1][1]->save(flux);
│ │ │ │ +
267 fprintf(flux, "%e\t%e\t%e\t%e\n", centre_x, centre_y, half_size_x, half_size_y);
│ │ │ │ +
268 children[0][0]->save(flux);
│ │ │ │ +
269 children[0][1]->save(flux);
│ │ │ │ +
270 children[1][0]->save(flux);
│ │ │ │ +
271 children[1][1]->save(flux);
│ │ │ │
272 }
│ │ │ │
273
│ │ │ │
274 return 0;
│ │ │ │
275}
│ │ │ │
│ │ │ │
276
│ │ │ │
277
│ │ │ │ @@ -347,26 +347,26 @@ │ │ │ │
281 * tree leaves. The file contents is as follows:
│ │ │ │
282 * first and second columns give center of the cell, the third
│ │ │ │
283 * gives the size.
│ │ │ │
284 * - flux opened stream to write to
│ │ │ │
285 * return 0 on success, 1 on error
│ │ │ │
286 ******************************************************************/
│ │ │ │
│ │ │ │ - │ │ │ │ + │ │ │ │
288
│ │ │ │ -
289 if (flux==NULL)
│ │ │ │ +
289 if (flux==NULL)
│ │ │ │
290 return 1;
│ │ │ │
291
│ │ │ │
292 if (has_child){
│ │ │ │ -
293 if (children[0][0]!=NULL) children[0][0]->save_leaves(flux);
│ │ │ │ -
294 if (children[0][1]!=NULL) children[0][1]->save_leaves(flux);
│ │ │ │ -
295 if (children[1][0]!=NULL) children[1][0]->save_leaves(flux);
│ │ │ │ -
296 if (children[1][1]!=NULL) children[1][1]->save_leaves(flux);
│ │ │ │ +
293 if (children[0][0]!=NULL) children[0][0]->save_leaves(flux);
│ │ │ │ +
294 if (children[0][1]!=NULL) children[0][1]->save_leaves(flux);
│ │ │ │ +
295 if (children[1][0]!=NULL) children[1][0]->save_leaves(flux);
│ │ │ │ +
296 if (children[1][1]!=NULL) children[1][1]->save_leaves(flux);
│ │ │ │
297 } else {
│ │ │ │ -
298 fprintf(flux, "%e\t%e\t%e\t%e\n", centre_x, centre_y, half_size_x, half_size_y);
│ │ │ │ +
298 fprintf(flux, "%e\t%e\t%e\t%e\n", centre_x, centre_y, half_size_x, half_size_y);
│ │ │ │
299 }
│ │ │ │
300
│ │ │ │
301 return 0;
│ │ │ │
302}
│ │ │ │
│ │ │ │
303
│ │ │ │
304}
│ │ │ │ @@ -385,14 +385,15 @@ │ │ │ │
int save_leaves(FILE *flux)
output a data file for drawing the tree leaves.
Definition quadtree.cpp:287
│ │ │ │
double centre_y
y-position of the centre of the cell
Definition quadtree.h:113
│ │ │ │
bool has_child
true if not a leaf
Definition quadtree.h:120
│ │ │ │
Cmomentum * v
physical contents
Definition quadtree.h:117
│ │ │ │
int init(double _x, double _y, double _half_size_x, double _half_size_y)
init the tree.
Definition quadtree.cpp:91
│ │ │ │
Cquadtree * children[2][2]
sub-cells ( 0,1->left-right; 0,1->bottom,top)
Definition quadtree.h:119
│ │ │ │
references used for checksums.
Definition reference.h:43
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -42,41 +42,41 @@ │ │ │ │ │ 39 * This class implements the traditional two-dimensional quadtree. * │ │ │ │ │ 40 * The elements at each node are of 'Cmomentum' type. * │ │ │ │ │ 41 *******************************************************************/ │ │ │ │ │ 42 │ │ │ │ │ 43// default ctor │ │ │ │ │ 44//-------------- │ │ │ │ │ _4_5_C_q_u_a_d_t_r_e_e_:_:_C_q_u_a_d_t_r_e_e(){ │ │ │ │ │ -46 _v = NULL; │ │ │ │ │ +46 _v = _N_U_L_L; │ │ │ │ │ 47 │ │ │ │ │ -48 _c_h_i_l_d_r_e_n[0][0] = _c_h_i_l_d_r_e_n[0][1] = _c_h_i_l_d_r_e_n[1][0] = _c_h_i_l_d_r_e_n[1][1] = NULL; │ │ │ │ │ +48 _c_h_i_l_d_r_e_n[0][0] = _c_h_i_l_d_r_e_n[0][1] = _c_h_i_l_d_r_e_n[1][0] = _c_h_i_l_d_r_e_n[1][1] = _N_U_L_L; │ │ │ │ │ 49 _h_a_s___c_h_i_l_d = false; │ │ │ │ │ 50} │ │ │ │ │ 51 │ │ │ │ │ 52 │ │ │ │ │ 53// ctor with initialisation (see init for details) │ │ │ │ │ 54//-------------------------- │ │ │ │ │ -_5_5_C_q_u_a_d_t_r_e_e_:_:_C_q_u_a_d_t_r_e_e(double _x, double _y, double _half_size_x, double │ │ │ │ │ -_half_size_y){ │ │ │ │ │ -56 _v = NULL; │ │ │ │ │ +_5_5_C_q_u_a_d_t_r_e_e_:_:_C_q_u_a_d_t_r_e_e(double ___x, double ___y, double ___h_a_l_f___s_i_z_e___x, double │ │ │ │ │ +___h_a_l_f___s_i_z_e___y){ │ │ │ │ │ +56 _v = _N_U_L_L; │ │ │ │ │ 57 │ │ │ │ │ -58 _c_h_i_l_d_r_e_n[0][0] = _c_h_i_l_d_r_e_n[0][1] = _c_h_i_l_d_r_e_n[1][0] = _c_h_i_l_d_r_e_n[1][1] = NULL; │ │ │ │ │ +58 _c_h_i_l_d_r_e_n[0][0] = _c_h_i_l_d_r_e_n[0][1] = _c_h_i_l_d_r_e_n[1][0] = _c_h_i_l_d_r_e_n[1][1] = _N_U_L_L; │ │ │ │ │ 59 _h_a_s___c_h_i_l_d = false; │ │ │ │ │ 60 │ │ │ │ │ -61 _i_n_i_t(_x, _y, _half_size_x, _half_size_y); │ │ │ │ │ +61 _i_n_i_t(___x, ___y, ___h_a_l_f___s_i_z_e___x, ___h_a_l_f___s_i_z_e___y); │ │ │ │ │ 62} │ │ │ │ │ 63 │ │ │ │ │ 64 │ │ │ │ │ 65// default destructor │ │ │ │ │ 66// at destruction, everything is destroyed except │ │ │ │ │ 67// physical values at the leaves │ │ │ │ │ 68//------------------------------------------------ │ │ │ │ │ _6_9_C_q_u_a_d_t_r_e_e_:_:_~_C_q_u_a_d_t_r_e_e(){ │ │ │ │ │ 70 if (_h_a_s___c_h_i_l_d){ │ │ │ │ │ -71 if (_v!=NULL) delete _v; │ │ │ │ │ +71 if (_v!=_N_U_L_L) delete _v; │ │ │ │ │ 72 delete _c_h_i_l_d_r_e_n[0][0]; │ │ │ │ │ 73 delete _c_h_i_l_d_r_e_n[0][1]; │ │ │ │ │ 74 delete _c_h_i_l_d_r_e_n[1][0]; │ │ │ │ │ 75 delete _c_h_i_l_d_r_e_n[1][1]; │ │ │ │ │ 76 } │ │ │ │ │ 77} │ │ │ │ │ 78 │ │ │ │ │ @@ -88,89 +88,89 @@ │ │ │ │ │ 84 * - _x x-position of the center │ │ │ │ │ 85 * - _y y-position of the center │ │ │ │ │ 86 * - half_size_x half x-size of the cell │ │ │ │ │ 87 * - half_size_y half y-size of the cell │ │ │ │ │ 88 * return 0 on success, 1 on error. Note that if the cell │ │ │ │ │ 89 * is already filled, we return an error. │ │ │ │ │ 90 ******************************************************************/ │ │ │ │ │ -_9_1int _C_q_u_a_d_t_r_e_e_:_:_i_n_i_t(double _x, double _y, double _half_size_x, double │ │ │ │ │ -_half_size_y){ │ │ │ │ │ -92 if (_v!=NULL) │ │ │ │ │ +_9_1int _C_q_u_a_d_t_r_e_e_:_:_i_n_i_t(double ___x, double ___y, double ___h_a_l_f___s_i_z_e___x, double │ │ │ │ │ +___h_a_l_f___s_i_z_e___y){ │ │ │ │ │ +92 if (_v!=_N_U_L_L) │ │ │ │ │ 93 return 1; │ │ │ │ │ 94 │ │ │ │ │ -95 _c_e_n_t_r_e___x = _x; │ │ │ │ │ -96 _c_e_n_t_r_e___y = _y; │ │ │ │ │ -97 _h_a_l_f___s_i_z_e___x = _half_size_x; │ │ │ │ │ -98 _h_a_l_f___s_i_z_e___y = _half_size_y; │ │ │ │ │ +95 _c_e_n_t_r_e___x = ___x; │ │ │ │ │ +96 _c_e_n_t_r_e___y = ___y; │ │ │ │ │ +97 _h_a_l_f___s_i_z_e___x = ___h_a_l_f___s_i_z_e___x; │ │ │ │ │ +98 _h_a_l_f___s_i_z_e___y = ___h_a_l_f___s_i_z_e___y; │ │ │ │ │ 99 │ │ │ │ │ 100 return 0; │ │ │ │ │ 101} │ │ │ │ │ 102 │ │ │ │ │ 103 │ │ │ │ │ 104/* │ │ │ │ │ 105 * adding a particle to the tree. │ │ │ │ │ 106 * This method adds one vector to the quadtree structure which │ │ │ │ │ 107 * is updated consequently. │ │ │ │ │ 108 * - v vector to add │ │ │ │ │ 109 * return 0 on success 1 on error │ │ │ │ │ 110 ******************************************************************/ │ │ │ │ │ -_1_1_1int _C_q_u_a_d_t_r_e_e_:_:_a_d_d(_C_m_o_m_e_n_t_u_m *v_add){ │ │ │ │ │ +_1_1_1int _C_q_u_a_d_t_r_e_e_:_:_a_d_d(_C_m_o_m_e_n_t_u_m *_v___a_d_d){ │ │ │ │ │ 112 // Description of the method: │ │ │ │ │ 113 // -------------------------- │ │ │ │ │ 114 // the addition process goes as follows: │ │ │ │ │ 115 // 1. check if the cell is empty, in which case, add the particle │ │ │ │ │ 116 // here and leave. │ │ │ │ │ 117 // 2. If there is a unique particle already inside, │ │ │ │ │ 118 // (a) create children │ │ │ │ │ 119 // (b) forward the existing particle to the appropriate child │ │ │ │ │ 120 // 3. Add current particle to this cell and forward to the │ │ │ │ │ 121 // adequate child │ │ │ │ │ 122 // NOTE: we assume in the whole procedure that the particle is │ │ │ │ │ 123 // indeed inside the cell ! │ │ │ │ │ 124 │ │ │ │ │ 125 // step 1: the case of empty cells │ │ │ │ │ -126 if (_v==NULL){ │ │ │ │ │ -127 _v = v_add; │ │ │ │ │ +126 if (_v==_N_U_L_L){ │ │ │ │ │ +127 _v = _v___a_d_d; │ │ │ │ │ 128 return 0; │ │ │ │ │ 129 } │ │ │ │ │ 130 │ │ │ │ │ 131 // step 2: additional work if 1! particle already present │ │ │ │ │ 132 // we use the fact that only 1-particle systems have no child │ │ │ │ │ 133 if (!_h_a_s___c_h_i_l_d){ │ │ │ │ │ -134 double new_half_size_x = 0.5*_h_a_l_f___s_i_z_e___x; │ │ │ │ │ -135 double new_half_size_y = 0.5*_h_a_l_f___s_i_z_e___y; │ │ │ │ │ +134 double _n_e_w___h_a_l_f___s_i_z_e___x = 0.5*_h_a_l_f___s_i_z_e___x; │ │ │ │ │ +135 double _n_e_w___h_a_l_f___s_i_z_e___y = 0.5*_h_a_l_f___s_i_z_e___y; │ │ │ │ │ 136 // create children │ │ │ │ │ -137 _c_h_i_l_d_r_e_n[0][0] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x-new_half_size_x, _c_e_n_t_r_e___y- │ │ │ │ │ -new_half_size_y, │ │ │ │ │ -138 new_half_size_x, new_half_size_y); │ │ │ │ │ -139 _c_h_i_l_d_r_e_n[0][1] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x-new_half_size_x, │ │ │ │ │ -_c_e_n_t_r_e___y+new_half_size_y, │ │ │ │ │ -140 new_half_size_x, new_half_size_y); │ │ │ │ │ -141 _c_h_i_l_d_r_e_n[1][0] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x+new_half_size_x, _c_e_n_t_r_e___y- │ │ │ │ │ -new_half_size_y, │ │ │ │ │ -142 new_half_size_x, new_half_size_y); │ │ │ │ │ -143 _c_h_i_l_d_r_e_n[1][1] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x+new_half_size_x, │ │ │ │ │ -_c_e_n_t_r_e___y+new_half_size_y, │ │ │ │ │ -144 new_half_size_x, new_half_size_y); │ │ │ │ │ +137 _c_h_i_l_d_r_e_n[0][0] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x-_n_e_w___h_a_l_f___s_i_z_e___x, _c_e_n_t_r_e___y- │ │ │ │ │ +_n_e_w___h_a_l_f___s_i_z_e___y, │ │ │ │ │ +138 _n_e_w___h_a_l_f___s_i_z_e___x, _n_e_w___h_a_l_f___s_i_z_e___y); │ │ │ │ │ +139 _c_h_i_l_d_r_e_n[0][1] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x-_n_e_w___h_a_l_f___s_i_z_e___x, │ │ │ │ │ +_c_e_n_t_r_e___y+_n_e_w___h_a_l_f___s_i_z_e___y, │ │ │ │ │ +140 _n_e_w___h_a_l_f___s_i_z_e___x, _n_e_w___h_a_l_f___s_i_z_e___y); │ │ │ │ │ +141 _c_h_i_l_d_r_e_n[1][0] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x+_n_e_w___h_a_l_f___s_i_z_e___x, _c_e_n_t_r_e___y- │ │ │ │ │ +_n_e_w___h_a_l_f___s_i_z_e___y, │ │ │ │ │ +142 _n_e_w___h_a_l_f___s_i_z_e___x, _n_e_w___h_a_l_f___s_i_z_e___y); │ │ │ │ │ +143 _c_h_i_l_d_r_e_n[1][1] = new _C_q_u_a_d_t_r_e_e(_c_e_n_t_r_e___x+_n_e_w___h_a_l_f___s_i_z_e___x, │ │ │ │ │ +_c_e_n_t_r_e___y+_n_e_w___h_a_l_f___s_i_z_e___y, │ │ │ │ │ +144 _n_e_w___h_a_l_f___s_i_z_e___x, _n_e_w___h_a_l_f___s_i_z_e___y); │ │ │ │ │ 145 │ │ │ │ │ 146 _h_a_s___c_h_i_l_d = true; │ │ │ │ │ 147 │ │ │ │ │ 148 // forward to child │ │ │ │ │ 149 //? The following line assumes 'true'==1 and 'false'==0 │ │ │ │ │ 150 // Note: v being a single particle, eta and phi are correct │ │ │ │ │ 151 _c_h_i_l_d_r_e_n[_v->_e_t_a>_c_e_n_t_r_e___x][_v->_p_h_i>_c_e_n_t_r_e___y]->_a_d_d(_v); │ │ │ │ │ 152 │ │ │ │ │ 153 // copy physical params │ │ │ │ │ 154 _v = new _C_m_o_m_e_n_t_u_m(*_v); │ │ │ │ │ 155 } │ │ │ │ │ 156 │ │ │ │ │ 157 // step 3: add new particle │ │ │ │ │ 158 // Note: v_add being a single particle, eta and phi are correct │ │ │ │ │ -159 _c_h_i_l_d_r_e_n[v_add->_e_t_a>_c_e_n_t_r_e___x][v_add->_p_h_i>_c_e_n_t_r_e___y]->_a_d_d(v_add); │ │ │ │ │ -160 *_v+=*v_add; │ │ │ │ │ +159 _c_h_i_l_d_r_e_n[_v___a_d_d->eta>_c_e_n_t_r_e___x][_v___a_d_d->phi>_c_e_n_t_r_e___y]->_a_d_d(_v___a_d_d); │ │ │ │ │ +160 *_v+=*_v___a_d_d; │ │ │ │ │ 161 │ │ │ │ │ 162 return 0; │ │ │ │ │ 163} │ │ │ │ │ 164 │ │ │ │ │ 165 │ │ │ │ │ 166/* │ │ │ │ │ 167 * circle intersection. │ │ │ │ │ @@ -178,114 +178,114 @@ │ │ │ │ │ 169 * The output takes the form of a quadtree with all squares included │ │ │ │ │ 170 * in the circle. │ │ │ │ │ 171 * - cx circle centre x coordinate │ │ │ │ │ 172 * - cy circle centre y coordinate │ │ │ │ │ 173 * - cR2 circle radius SQUARED │ │ │ │ │ 174 * return the checksum for the intersection │ │ │ │ │ 175 ******************************************************************/ │ │ │ │ │ -_1_7_6_C_r_e_f_e_r_e_n_c_e _C_q_u_a_d_t_r_e_e_:_:_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(double cx, double cy, double cR2){ │ │ │ │ │ +_1_7_6_C_r_e_f_e_r_e_n_c_e _C_q_u_a_d_t_r_e_e_:_:_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(double _c_x, double _c_y, double _c_R_2){ │ │ │ │ │ 177 // Description of the method: │ │ │ │ │ 178 // -------------------------- │ │ │ │ │ 179 // 1. check if cell is empty => no intersection │ │ │ │ │ 180 // 2. if cell has 1! particle, check if it is inside the circle. │ │ │ │ │ 181 // If yes, add it and return, if not simply return. │ │ │ │ │ 182 // 3. check if the circle intersects the square. If not, return. │ │ │ │ │ 183 // 4. check if the square is inside the circle. │ │ │ │ │ 184 // If yes, add it to qt and return. │ │ │ │ │ 185 // 5. check intersections with children. │ │ │ │ │ 186 │ │ │ │ │ 187 // step 1: if there is no particle inside te square, no reason to go │ │ │ │ │ further │ │ │ │ │ -188 if (_v==NULL) │ │ │ │ │ +188 if (_v==_N_U_L_L) │ │ │ │ │ 189 return _C_r_e_f_e_r_e_n_c_e(); │ │ │ │ │ 190 │ │ │ │ │ -191 double dx, dy; │ │ │ │ │ +191 double _d_x, _d_y; │ │ │ │ │ 192 │ │ │ │ │ 193 // step 2: if there is only one particle inside the square, test if it is │ │ │ │ │ in │ │ │ │ │ 194 // the circle, in which case return associated reference │ │ │ │ │ 195 if (!_h_a_s___c_h_i_l_d){ │ │ │ │ │ 196 // compute the distance │ │ │ │ │ 197 // Note: v has only one particle => eta and phi are defined │ │ │ │ │ -198 dx = cx - _v->_e_t_a; │ │ │ │ │ -199 dy = fabs(cy - _v->_p_h_i); │ │ │ │ │ -200 if (dy>M_PI) │ │ │ │ │ -201 dy -= 2.0*M_PI; │ │ │ │ │ +198 _d_x = _c_x - _v->_e_t_a; │ │ │ │ │ +199 _d_y = _f_a_b_s(_c_y - _v->_p_h_i); │ │ │ │ │ +200 if (_d_y>M_PI) │ │ │ │ │ +201 _d_y -= 2.0*M_PI; │ │ │ │ │ 202 │ │ │ │ │ 203 // test distance │ │ │ │ │ -204 if (dx*dx+dy*dy_r_e_f; │ │ │ │ │ 206 } │ │ │ │ │ 207 │ │ │ │ │ 208 return _C_r_e_f_e_r_e_n_c_e(); │ │ │ │ │ 209 } │ │ │ │ │ 210 │ │ │ │ │ 211 // step 3: check if there is an intersection │ │ │ │ │ 212 //double ryp, rym; │ │ │ │ │ -213 double dx_c, dy_c; │ │ │ │ │ +213 double _d_x___c, _d_y___c; │ │ │ │ │ 214 │ │ │ │ │ 215 // store distance with the centre of the square │ │ │ │ │ -216 dx_c = fabs(cx-_c_e_n_t_r_e___x); │ │ │ │ │ -217 dy_c = fabs(cy-_c_e_n_t_r_e___y); │ │ │ │ │ -218 if (dy_c>M_PI) dy_c = 2.0*M_PI-dy_c; │ │ │ │ │ +216 _d_x___c = _f_a_b_s(_c_x-_c_e_n_t_r_e___x); │ │ │ │ │ +217 _d_y___c = _f_a_b_s(_c_y-_c_e_n_t_r_e___y); │ │ │ │ │ +218 if (_d_y___c>M_PI) _d_y___c = 2.0*M_PI-_d_y___c; │ │ │ │ │ 219 │ │ │ │ │ 220 // compute (minimal) the distance (pay attention to the periodicity in │ │ │ │ │ phi). │ │ │ │ │ -221 dx = dx_c-_h_a_l_f___s_i_z_e___x; │ │ │ │ │ -222 if (dx<0) dx=0; │ │ │ │ │ -223 dy = dy_c-_h_a_l_f___s_i_z_e___y; │ │ │ │ │ -224 if (dy<0) dy=0; │ │ │ │ │ +221 _d_x = _d_x___c-_h_a_l_f___s_i_z_e___x; │ │ │ │ │ +222 if (_d_x<0) _d_x=0; │ │ │ │ │ +223 _d_y = _d_y___c-_h_a_l_f___s_i_z_e___y; │ │ │ │ │ +224 if (_d_y<0) _d_y=0; │ │ │ │ │ 225 │ │ │ │ │ 226 // check the distance │ │ │ │ │ -227 if (dx*dx+dy*dy>=cR2){ │ │ │ │ │ +227 if (_d_x*_d_x+_d_y*_d_y>=_c_R_2){ │ │ │ │ │ 228 // no intersection │ │ │ │ │ 229 return _C_r_e_f_e_r_e_n_c_e(); │ │ │ │ │ 230 } │ │ │ │ │ 231 │ │ │ │ │ 232 // step 4: check if included │ │ │ │ │ 233 │ │ │ │ │ 234 // compute the (maximal) distance │ │ │ │ │ -235 dx = dx_c+_h_a_l_f___s_i_z_e___x; │ │ │ │ │ -236 dy = dy_c+_h_a_l_f___s_i_z_e___y; │ │ │ │ │ -237 if (dy>M_PI) dy = M_PI; │ │ │ │ │ +235 _d_x = _d_x___c+_h_a_l_f___s_i_z_e___x; │ │ │ │ │ +236 _d_y = _d_y___c+_h_a_l_f___s_i_z_e___y; │ │ │ │ │ +237 if (_d_y>M_PI) _d_y = M_PI; │ │ │ │ │ 238 │ │ │ │ │ 239 // compute the distance │ │ │ │ │ -240 if (dx*dx+dy*dy_r_e_f; │ │ │ │ │ 242 } │ │ │ │ │ 243 │ │ │ │ │ 244 // step 5: the square is not fully in. Recurse to children │ │ │ │ │ -245 return _c_h_i_l_d_r_e_n[0][0]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(cx, cy, cR2) │ │ │ │ │ -246 + _c_h_i_l_d_r_e_n[0][1]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(cx, cy, cR2) │ │ │ │ │ -247 + _c_h_i_l_d_r_e_n[1][0]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(cx, cy, cR2) │ │ │ │ │ -248 + _c_h_i_l_d_r_e_n[1][1]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(cx, cy, cR2); │ │ │ │ │ +245 return _c_h_i_l_d_r_e_n[0][0]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(_c_x, _c_y, _c_R_2) │ │ │ │ │ +246 + _c_h_i_l_d_r_e_n[0][1]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(_c_x, _c_y, _c_R_2) │ │ │ │ │ +247 + _c_h_i_l_d_r_e_n[1][0]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(_c_x, _c_y, _c_R_2) │ │ │ │ │ +248 + _c_h_i_l_d_r_e_n[1][1]->_c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(_c_x, _c_y, _c_R_2); │ │ │ │ │ 249} │ │ │ │ │ 250 │ │ │ │ │ 251 │ │ │ │ │ 252/* │ │ │ │ │ 253 * output a data file for drawing the grid. │ │ │ │ │ 254 * This can be used to output a data file containing all the │ │ │ │ │ 255 * grid subdivisions. The file contents is as follows: │ │ │ │ │ 256 * first and second columns give center of the cell, the third │ │ │ │ │ 257 * gives the size. │ │ │ │ │ 258 * - flux opened stream to write to │ │ │ │ │ 259 * return 0 on success, 1 on error │ │ │ │ │ 260 ******************************************************************/ │ │ │ │ │ -_2_6_1int _C_q_u_a_d_t_r_e_e_:_:_s_a_v_e(FILE *flux){ │ │ │ │ │ +_2_6_1int _C_q_u_a_d_t_r_e_e_:_:_s_a_v_e(_F_I_L_E *_f_l_u_x){ │ │ │ │ │ 262 │ │ │ │ │ -263 if (flux==NULL) │ │ │ │ │ +263 if (_f_l_u_x==_N_U_L_L) │ │ │ │ │ 264 return 1; │ │ │ │ │ 265 │ │ │ │ │ 266 if (_h_a_s___c_h_i_l_d){ │ │ │ │ │ -267 fprintf(flux, "%e\t%e\t%e\t%e\n", _c_e_n_t_r_e___x, _c_e_n_t_r_e___y, _h_a_l_f___s_i_z_e___x, │ │ │ │ │ +267 _f_p_r_i_n_t_f(_f_l_u_x, "%e\t%e\t%e\t%e\n", _c_e_n_t_r_e___x, _c_e_n_t_r_e___y, _h_a_l_f___s_i_z_e___x, │ │ │ │ │ _h_a_l_f___s_i_z_e___y); │ │ │ │ │ -268 _c_h_i_l_d_r_e_n[0][0]->_s_a_v_e(flux); │ │ │ │ │ -269 _c_h_i_l_d_r_e_n[0][1]->_s_a_v_e(flux); │ │ │ │ │ -270 _c_h_i_l_d_r_e_n[1][0]->_s_a_v_e(flux); │ │ │ │ │ -271 _c_h_i_l_d_r_e_n[1][1]->_s_a_v_e(flux); │ │ │ │ │ +268 _c_h_i_l_d_r_e_n[0][0]->_s_a_v_e(_f_l_u_x); │ │ │ │ │ +269 _c_h_i_l_d_r_e_n[0][1]->_s_a_v_e(_f_l_u_x); │ │ │ │ │ +270 _c_h_i_l_d_r_e_n[1][0]->_s_a_v_e(_f_l_u_x); │ │ │ │ │ +271 _c_h_i_l_d_r_e_n[1][1]->_s_a_v_e(_f_l_u_x); │ │ │ │ │ 272 } │ │ │ │ │ 273 │ │ │ │ │ 274 return 0; │ │ │ │ │ 275} │ │ │ │ │ 276 │ │ │ │ │ 277 │ │ │ │ │ 278/* │ │ │ │ │ @@ -293,26 +293,26 @@ │ │ │ │ │ 280 * This can be used to output a data file containing all the │ │ │ │ │ 281 * tree leaves. The file contents is as follows: │ │ │ │ │ 282 * first and second columns give center of the cell, the third │ │ │ │ │ 283 * gives the size. │ │ │ │ │ 284 * - flux opened stream to write to │ │ │ │ │ 285 * return 0 on success, 1 on error │ │ │ │ │ 286 ******************************************************************/ │ │ │ │ │ -_2_8_7int _C_q_u_a_d_t_r_e_e_:_:_s_a_v_e___l_e_a_v_e_s(FILE *flux){ │ │ │ │ │ +_2_8_7int _C_q_u_a_d_t_r_e_e_:_:_s_a_v_e___l_e_a_v_e_s(_F_I_L_E *_f_l_u_x){ │ │ │ │ │ 288 │ │ │ │ │ -289 if (flux==NULL) │ │ │ │ │ +289 if (_f_l_u_x==_N_U_L_L) │ │ │ │ │ 290 return 1; │ │ │ │ │ 291 │ │ │ │ │ 292 if (_h_a_s___c_h_i_l_d){ │ │ │ │ │ -293 if (_c_h_i_l_d_r_e_n[0][0]!=NULL) _c_h_i_l_d_r_e_n[0][0]->_s_a_v_e___l_e_a_v_e_s(flux); │ │ │ │ │ -294 if (_c_h_i_l_d_r_e_n[0][1]!=NULL) _c_h_i_l_d_r_e_n[0][1]->_s_a_v_e___l_e_a_v_e_s(flux); │ │ │ │ │ -295 if (_c_h_i_l_d_r_e_n[1][0]!=NULL) _c_h_i_l_d_r_e_n[1][0]->_s_a_v_e___l_e_a_v_e_s(flux); │ │ │ │ │ -296 if (_c_h_i_l_d_r_e_n[1][1]!=NULL) _c_h_i_l_d_r_e_n[1][1]->_s_a_v_e___l_e_a_v_e_s(flux); │ │ │ │ │ +293 if (_c_h_i_l_d_r_e_n[0][0]!=_N_U_L_L) _c_h_i_l_d_r_e_n[0][0]->_s_a_v_e___l_e_a_v_e_s(_f_l_u_x); │ │ │ │ │ +294 if (_c_h_i_l_d_r_e_n[0][1]!=_N_U_L_L) _c_h_i_l_d_r_e_n[0][1]->_s_a_v_e___l_e_a_v_e_s(_f_l_u_x); │ │ │ │ │ +295 if (_c_h_i_l_d_r_e_n[1][0]!=_N_U_L_L) _c_h_i_l_d_r_e_n[1][0]->_s_a_v_e___l_e_a_v_e_s(_f_l_u_x); │ │ │ │ │ +296 if (_c_h_i_l_d_r_e_n[1][1]!=_N_U_L_L) _c_h_i_l_d_r_e_n[1][1]->_s_a_v_e___l_e_a_v_e_s(_f_l_u_x); │ │ │ │ │ 297 } else { │ │ │ │ │ -298 fprintf(flux, "%e\t%e\t%e\t%e\n", _c_e_n_t_r_e___x, _c_e_n_t_r_e___y, _h_a_l_f___s_i_z_e___x, │ │ │ │ │ +298 _f_p_r_i_n_t_f(_f_l_u_x, "%e\t%e\t%e\t%e\n", _c_e_n_t_r_e___x, _c_e_n_t_r_e___y, _h_a_l_f___s_i_z_e___x, │ │ │ │ │ _h_a_l_f___s_i_z_e___y); │ │ │ │ │ 299 } │ │ │ │ │ 300 │ │ │ │ │ 301 return 0; │ │ │ │ │ 302} │ │ │ │ │ 303 │ │ │ │ │ 304} │ │ │ │ │ @@ -387,9 +387,13 @@ │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_q_u_a_d_t_r_e_e_:_:_c_h_i_l_d_r_e_n │ │ │ │ │ Cquadtree * children[2][2] │ │ │ │ │ sub-cells ( 0,1->left-right; 0,1->bottom,top) │ │ │ │ │ DDeeffiinniittiioonn _q_u_a_d_t_r_e_e_._h_:_1_1_9 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e │ │ │ │ │ references used for checksums. │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_4_3 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/quadtree_8h_source.html │ │ │ │ @@ -85,27 +85,27 @@ │ │ │ │
34namespace siscone{
│ │ │ │
35
│ │ │ │
│ │ │ │ │ │ │ │
44 public:
│ │ │ │
46 Cquadtree();
│ │ │ │
47
│ │ │ │ -
49 Cquadtree(double _x, double _y, double _half_size_x, double _half_size_y);
│ │ │ │ +
49 Cquadtree(double _x, double _y, double _half_size_x, double _half_size_y);
│ │ │ │
50
│ │ │ │
54 ~Cquadtree();
│ │ │ │
55
│ │ │ │ -
67 int init(double _x, double _y, double _half_size_x, double _half_size_y);
│ │ │ │ +
67 int init(double _x, double _y, double _half_size_x, double _half_size_y);
│ │ │ │
68
│ │ │ │ -
76 int add(Cmomentum *v_add);
│ │ │ │ +
76 int add(Cmomentum *v_add);
│ │ │ │
77
│ │ │ │ -
88 Creference circle_intersect(double cx, double cy, double cR2);
│ │ │ │ +
88 Creference circle_intersect(double cx, double cy, double cR2);
│ │ │ │
89
│ │ │ │ -
99 int save(FILE *flux);
│ │ │ │ +
99 int save(FILE *flux);
│ │ │ │
100
│ │ │ │ -
110 int save_leaves(FILE *flux);
│ │ │ │ +
110 int save_leaves(FILE *flux);
│ │ │ │
111
│ │ │ │
112 double centre_x;
│ │ │ │
113 double centre_y;
│ │ │ │
114 double half_size_x;
│ │ │ │
115 double half_size_y;
│ │ │ │
116
│ │ │ │ │ │ │ │ @@ -130,14 +130,15 @@ │ │ │ │
int save_leaves(FILE *flux)
output a data file for drawing the tree leaves.
Definition quadtree.cpp:287
│ │ │ │
double centre_y
y-position of the centre of the cell
Definition quadtree.h:113
│ │ │ │
bool has_child
true if not a leaf
Definition quadtree.h:120
│ │ │ │
Cmomentum * v
physical contents
Definition quadtree.h:117
│ │ │ │
int init(double _x, double _y, double _half_size_x, double _half_size_y)
init the tree.
Definition quadtree.cpp:91
│ │ │ │
Cquadtree * children[2][2]
sub-cells ( 0,1->left-right; 0,1->bottom,top)
Definition quadtree.h:119
│ │ │ │
references used for checksums.
Definition reference.h:43
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -35,27 +35,27 @@ │ │ │ │ │ 33 │ │ │ │ │ 34namespace siscone{ │ │ │ │ │ 35 │ │ │ │ │ _4_3class _C_q_u_a_d_t_r_e_e{ │ │ │ │ │ 44 public: │ │ │ │ │ 46 _C_q_u_a_d_t_r_e_e(); │ │ │ │ │ 47 │ │ │ │ │ -49 _C_q_u_a_d_t_r_e_e(double _x, double _y, double _half_size_x, double _half_size_y); │ │ │ │ │ +49 _C_q_u_a_d_t_r_e_e(double ___x, double ___y, double ___h_a_l_f___s_i_z_e___x, double ___h_a_l_f___s_i_z_e___y); │ │ │ │ │ 50 │ │ │ │ │ 54 _~_C_q_u_a_d_t_r_e_e(); │ │ │ │ │ 55 │ │ │ │ │ -67 int _i_n_i_t(double _x, double _y, double _half_size_x, double _half_size_y); │ │ │ │ │ +67 int _i_n_i_t(double ___x, double ___y, double ___h_a_l_f___s_i_z_e___x, double ___h_a_l_f___s_i_z_e___y); │ │ │ │ │ 68 │ │ │ │ │ -76 int _a_d_d(_C_m_o_m_e_n_t_u_m *v_add); │ │ │ │ │ +76 int _a_d_d(_C_m_o_m_e_n_t_u_m *_v___a_d_d); │ │ │ │ │ 77 │ │ │ │ │ -88 _C_r_e_f_e_r_e_n_c_e _c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(double cx, double cy, double cR2); │ │ │ │ │ +88 _C_r_e_f_e_r_e_n_c_e _c_i_r_c_l_e___i_n_t_e_r_s_e_c_t(double _c_x, double _c_y, double _c_R_2); │ │ │ │ │ 89 │ │ │ │ │ -99 int _s_a_v_e(FILE *flux); │ │ │ │ │ +99 int _s_a_v_e(_F_I_L_E *_f_l_u_x); │ │ │ │ │ 100 │ │ │ │ │ -110 int _s_a_v_e___l_e_a_v_e_s(FILE *flux); │ │ │ │ │ +110 int _s_a_v_e___l_e_a_v_e_s(_F_I_L_E *_f_l_u_x); │ │ │ │ │ 111 │ │ │ │ │ _1_1_2 double _c_e_n_t_r_e___x; │ │ │ │ │ _1_1_3 double _c_e_n_t_r_e___y; │ │ │ │ │ _1_1_4 double _h_a_l_f___s_i_z_e___x; │ │ │ │ │ _1_1_5 double _h_a_l_f___s_i_z_e___y; │ │ │ │ │ 116 │ │ │ │ │ _1_1_7 _C_m_o_m_e_n_t_u_m *_v; │ │ │ │ │ @@ -128,9 +128,13 @@ │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_q_u_a_d_t_r_e_e_:_:_c_h_i_l_d_r_e_n │ │ │ │ │ Cquadtree * children[2][2] │ │ │ │ │ sub-cells ( 0,1->left-right; 0,1->bottom,top) │ │ │ │ │ DDeeffiinniittiioonn _q_u_a_d_t_r_e_e_._h_:_1_1_9 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e │ │ │ │ │ references used for checksums. │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_4_3 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/ranlux_8cpp_source.html │ │ │ │ @@ -114,20 +114,20 @@ │ │ │ │
59
│ │ │ │
60
│ │ │ │
61// incrementation of the generator state
│ │ │ │
62//---------------------------------------
│ │ │ │
63static inline unsigned long int increment_state(){
│ │ │ │
64 unsigned int i = local_ranlux_state.i;
│ │ │ │
65 unsigned int j = local_ranlux_state.j;
│ │ │ │ -
66 long int delta = local_ranlux_state.u[j] - local_ranlux_state.u[i]
│ │ │ │ +
66 long int delta = local_ranlux_state.u[j] - local_ranlux_state.u[i]
│ │ │ │
67 - local_ranlux_state.carry;
│ │ │ │
68
│ │ │ │ -
69 if (delta & mask_hi){
│ │ │ │ +
69 if (delta & mask_hi){
│ │ │ │
70 local_ranlux_state.carry = 1;
│ │ │ │ -
71 delta &= mask_lo;
│ │ │ │ +
71 delta &= mask_lo;
│ │ │ │
72 } else {
│ │ │ │
73 local_ranlux_state.carry = 0;
│ │ │ │
74 }
│ │ │ │
75
│ │ │ │
76 local_ranlux_state.u[i] = delta;
│ │ │ │
77
│ │ │ │
78 if (i==0)
│ │ │ │ @@ -220,14 +220,15 @@ │ │ │ │
165 for (i=0;i<n;i++){
│ │ │ │
166 /* FIXME: we're assuming that a char is 8 bits */
│ │ │ │
167 printf("%.2x", *(p+i));
│ │ │ │
168 }
│ │ │ │
169}
│ │ │ │
170
│ │ │ │
171}
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -62,20 +62,20 @@ │ │ │ │ │ 59 │ │ │ │ │ 60 │ │ │ │ │ 61// incrementation of the generator state │ │ │ │ │ 62//--------------------------------------- │ │ │ │ │ 63static inline unsigned long int increment_state(){ │ │ │ │ │ 64 unsigned int i = local_ranlux_state.i; │ │ │ │ │ 65 unsigned int j = local_ranlux_state.j; │ │ │ │ │ -66 long int delta = local_ranlux_state.u[j] - local_ranlux_state.u[i] │ │ │ │ │ +66 long int _d_e_l_t_a = local_ranlux_state.u[j] - local_ranlux_state.u[i] │ │ │ │ │ 67 - local_ranlux_state.carry; │ │ │ │ │ 68 │ │ │ │ │ -69 if (delta & mask_hi){ │ │ │ │ │ +69 if (_d_e_l_t_a & mask_hi){ │ │ │ │ │ 70 local_ranlux_state.carry = 1; │ │ │ │ │ -71 delta &= mask_lo; │ │ │ │ │ +71 _d_e_l_t_a &= mask_lo; │ │ │ │ │ 72 } else { │ │ │ │ │ 73 local_ranlux_state.carry = 0; │ │ │ │ │ 74 } │ │ │ │ │ 75 │ │ │ │ │ 76 local_ranlux_state.u[i] = delta; │ │ │ │ │ 77 │ │ │ │ │ 78 if (i==0) │ │ │ │ │ @@ -168,12 +168,16 @@ │ │ │ │ │ 165 for (i=0;i │ │ │ │ │ │ │ │
55// ref[0] = reference_bit;
│ │ │ │
56// ref[1] = 0;
│ │ │ │
57// ref[2] = 0;
│ │ │ │
58// reference_bit <<= 1;
│ │ │ │
59
│ │ │ │ -
60 unsigned int r1 = ranlux_get();
│ │ │ │ -
61 unsigned int r2 = ranlux_get();
│ │ │ │ -
62 unsigned int r3 = ranlux_get();
│ │ │ │ -
63 unsigned int r4 = ranlux_get();
│ │ │ │ +
60 unsigned int r1 = ranlux_get();
│ │ │ │ +
61 unsigned int r2 = ranlux_get();
│ │ │ │ +
62 unsigned int r3 = ranlux_get();
│ │ │ │ +
63 unsigned int r4 = ranlux_get();
│ │ │ │
64 // since ranlux only produces 24 bits, take r4 and add 8 bits
│ │ │ │
65 // from it to each of r1,r2, r3 to get 3*32 bits.
│ │ │ │ -
66 ref[0] = r1+((r4 & 0x00ff0000) << 8);
│ │ │ │ -
67 ref[1] = r2+((r4 & 0x0000ff00) << 16);
│ │ │ │ -
68 ref[2] = r3+((r4 & 0x000000ff) << 24);
│ │ │ │ +
66 ref[0] = r1+((r4 & 0x00ff0000) << 8);
│ │ │ │ +
67 ref[1] = r2+((r4 & 0x0000ff00) << 16);
│ │ │ │ +
68 ref[2] = r3+((r4 & 0x000000ff) << 24);
│ │ │ │
69
│ │ │ │
70 if (is_empty()) randomize();
│ │ │ │
71}
│ │ │ │ │ │ │ │
72
│ │ │ │
73// test emptyness
│ │ │ │
74//----------------
│ │ │ │ @@ -140,49 +140,49 @@ │ │ │ │
82 return (ref[0]!=0) || (ref[1]!=0) || (ref[2]!=0);
│ │ │ │
83}
│ │ │ │ │ │ │ │
84
│ │ │ │
85// assignment of reference
│ │ │ │
86//-------------------------
│ │ │ │
│ │ │ │ - │ │ │ │ -
88 ref[0] = r.ref[0];
│ │ │ │ -
89 ref[1] = r.ref[1];
│ │ │ │ -
90 ref[2] = r.ref[2];
│ │ │ │ + │ │ │ │ +
88 ref[0] = r.ref[0];
│ │ │ │ +
89 ref[1] = r.ref[1];
│ │ │ │ +
90 ref[2] = r.ref[2];
│ │ │ │
91 return *this;
│ │ │ │
92}
│ │ │ │
│ │ │ │
93
│ │ │ │
94// addition of reference
│ │ │ │
95//-----------------------
│ │ │ │
│ │ │ │ - │ │ │ │ -
97 Creference tmp = *this;
│ │ │ │ -
98 return tmp+=r;
│ │ │ │ + │ │ │ │ +
97 Creference tmp = *this;
│ │ │ │ +
98 return tmp+=r;
│ │ │ │
99}
│ │ │ │
│ │ │ │
100
│ │ │ │
101// incrementation of reference
│ │ │ │
102//-----------------------------
│ │ │ │
│ │ │ │ - │ │ │ │ -
104 ref[0] ^= r.ref[0];
│ │ │ │ -
105 ref[1] ^= r.ref[1];
│ │ │ │ -
106 ref[2] ^= r.ref[2];
│ │ │ │ + │ │ │ │ +
104 ref[0] ^= r.ref[0];
│ │ │ │ +
105 ref[1] ^= r.ref[1];
│ │ │ │ +
106 ref[2] ^= r.ref[2];
│ │ │ │
107 return *this;
│ │ │ │
108}
│ │ │ │
│ │ │ │
109
│ │ │ │
110// decrementation of reference
│ │ │ │
111//-----------------------------
│ │ │ │
│ │ │ │ - │ │ │ │ -
113 ref[0] ^= r.ref[0];
│ │ │ │ -
114 ref[1] ^= r.ref[1];
│ │ │ │ -
115 ref[2] ^= r.ref[2];
│ │ │ │ + │ │ │ │ +
113 ref[0] ^= r.ref[0];
│ │ │ │ +
114 ref[1] ^= r.ref[1];
│ │ │ │ +
115 ref[2] ^= r.ref[2];
│ │ │ │
116 return *this;
│ │ │ │
117}
│ │ │ │
│ │ │ │
118
│ │ │ │
119}
│ │ │ │
120
│ │ │ │
references used for checksums.
Definition reference.h:43
│ │ │ │ @@ -191,14 +191,15 @@ │ │ │ │
Creference & operator=(const Creference &r)
assignment of reference
Definition reference.cpp:87
│ │ │ │
Creference()
default constructor
Definition reference.cpp:46
│ │ │ │
void randomize()
create a random reference
Definition reference.cpp:54
│ │ │ │
Creference & operator+=(const Creference &r)
incrementation of reference
│ │ │ │
bool not_empty()
test non-emptyness
Definition reference.cpp:81
│ │ │ │
Creference & operator-=(const Creference &r)
decrementation of reference
│ │ │ │
unsigned int ref[3]
actual data for the reference
Definition reference.h:72
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -55,23 +55,23 @@ │ │ │ │ │ 53//--------------------------- │ │ │ │ │ _5_4void _C_r_e_f_e_r_e_n_c_e_:_:_r_a_n_d_o_m_i_z_e(){ │ │ │ │ │ 55// ref[0] = reference_bit; │ │ │ │ │ 56// ref[1] = 0; │ │ │ │ │ 57// ref[2] = 0; │ │ │ │ │ 58// reference_bit <<= 1; │ │ │ │ │ 59 │ │ │ │ │ -60 unsigned int r1 = ranlux_get(); │ │ │ │ │ -61 unsigned int r2 = ranlux_get(); │ │ │ │ │ -62 unsigned int r3 = ranlux_get(); │ │ │ │ │ -63 unsigned int r4 = ranlux_get(); │ │ │ │ │ +60 unsigned int _r_1 = ranlux_get(); │ │ │ │ │ +61 unsigned int _r_2 = ranlux_get(); │ │ │ │ │ +62 unsigned int _r_3 = ranlux_get(); │ │ │ │ │ +63 unsigned int _r_4 = ranlux_get(); │ │ │ │ │ 64 // since ranlux only produces 24 bits, take r4 and add 8 bits │ │ │ │ │ 65 // from it to each of r1,r2, r3 to get 3*32 bits. │ │ │ │ │ -66 _r_e_f[0] = r1+((r4 & 0x00ff0000) << 8); │ │ │ │ │ -67 _r_e_f[1] = r2+((r4 & 0x0000ff00) << 16); │ │ │ │ │ -68 _r_e_f[2] = r3+((r4 & 0x000000ff) << 24); │ │ │ │ │ +66 _r_e_f[0] = _r_1+((_r_4 & 0x00ff0000) << 8); │ │ │ │ │ +67 _r_e_f[1] = _r_2+((_r_4 & 0x0000ff00) << 16); │ │ │ │ │ +68 _r_e_f[2] = _r_3+((_r_4 & 0x000000ff) << 24); │ │ │ │ │ 69 │ │ │ │ │ 70 if (_i_s___e_m_p_t_y()) _r_a_n_d_o_m_i_z_e(); │ │ │ │ │ 71} │ │ │ │ │ 72 │ │ │ │ │ 73// test emptyness │ │ │ │ │ 74//---------------- │ │ │ │ │ _7_5bool _C_r_e_f_e_r_e_n_c_e_:_:_i_s___e_m_p_t_y(){ │ │ │ │ │ @@ -82,43 +82,43 @@ │ │ │ │ │ 80//-------------------- │ │ │ │ │ _8_1bool _C_r_e_f_e_r_e_n_c_e_:_:_n_o_t___e_m_p_t_y(){ │ │ │ │ │ 82 return (_r_e_f[0]!=0) || (_r_e_f[1]!=0) || (_r_e_f[2]!=0); │ │ │ │ │ 83} │ │ │ │ │ 84 │ │ │ │ │ 85// assignment of reference │ │ │ │ │ 86//------------------------- │ │ │ │ │ -_8_7_C_r_e_f_e_r_e_n_c_e& _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _=_ (const _C_r_e_f_e_r_e_n_c_e &r){ │ │ │ │ │ -88 _r_e_f[0] = r._r_e_f[0]; │ │ │ │ │ -89 _r_e_f[1] = r._r_e_f[1]; │ │ │ │ │ -90 _r_e_f[2] = r._r_e_f[2]; │ │ │ │ │ +_8_7_C_r_e_f_e_r_e_n_c_e& _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _=_ (const _C_r_e_f_e_r_e_n_c_e &_r){ │ │ │ │ │ +88 _r_e_f[0] = _r.ref[0]; │ │ │ │ │ +89 _r_e_f[1] = _r.ref[1]; │ │ │ │ │ +90 _r_e_f[2] = _r.ref[2]; │ │ │ │ │ 91 return *this; │ │ │ │ │ 92} │ │ │ │ │ 93 │ │ │ │ │ 94// addition of reference │ │ │ │ │ 95//----------------------- │ │ │ │ │ -_9_6_C_r_e_f_e_r_e_n_c_e _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _+_ (const _C_r_e_f_e_r_e_n_c_e &r){ │ │ │ │ │ -97 _C_r_e_f_e_r_e_n_c_e tmp = *this; │ │ │ │ │ -98 return tmp+=r; │ │ │ │ │ +_9_6_C_r_e_f_e_r_e_n_c_e _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _+_ (const _C_r_e_f_e_r_e_n_c_e &_r){ │ │ │ │ │ +97 _C_r_e_f_e_r_e_n_c_e _t_m_p = *this; │ │ │ │ │ +98 return _t_m_p+=_r; │ │ │ │ │ 99} │ │ │ │ │ 100 │ │ │ │ │ 101// incrementation of reference │ │ │ │ │ 102//----------------------------- │ │ │ │ │ -_1_0_3_C_r_e_f_e_r_e_n_c_e& _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _+_=_ (const _C_r_e_f_e_r_e_n_c_e &r){ │ │ │ │ │ -104 _r_e_f[0] ^= r._r_e_f[0]; │ │ │ │ │ -105 _r_e_f[1] ^= r._r_e_f[1]; │ │ │ │ │ -106 _r_e_f[2] ^= r._r_e_f[2]; │ │ │ │ │ +_1_0_3_C_r_e_f_e_r_e_n_c_e& _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _+_=_ (const _C_r_e_f_e_r_e_n_c_e &_r){ │ │ │ │ │ +104 _r_e_f[0] ^= _r.ref[0]; │ │ │ │ │ +105 _r_e_f[1] ^= _r.ref[1]; │ │ │ │ │ +106 _r_e_f[2] ^= _r.ref[2]; │ │ │ │ │ 107 return *this; │ │ │ │ │ 108} │ │ │ │ │ 109 │ │ │ │ │ 110// decrementation of reference │ │ │ │ │ 111//----------------------------- │ │ │ │ │ -_1_1_2_C_r_e_f_e_r_e_n_c_e& _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _-_=_ (const _C_r_e_f_e_r_e_n_c_e &r){ │ │ │ │ │ -113 _r_e_f[0] ^= r._r_e_f[0]; │ │ │ │ │ -114 _r_e_f[1] ^= r._r_e_f[1]; │ │ │ │ │ -115 _r_e_f[2] ^= r._r_e_f[2]; │ │ │ │ │ +_1_1_2_C_r_e_f_e_r_e_n_c_e& _C_r_e_f_e_r_e_n_c_e_:_:_o_p_e_r_a_t_o_r_ _-_=_ (const _C_r_e_f_e_r_e_n_c_e &_r){ │ │ │ │ │ +113 _r_e_f[0] ^= _r.ref[0]; │ │ │ │ │ +114 _r_e_f[1] ^= _r.ref[1]; │ │ │ │ │ +115 _r_e_f[2] ^= _r.ref[2]; │ │ │ │ │ 116 return *this; │ │ │ │ │ 117} │ │ │ │ │ 118 │ │ │ │ │ 119} │ │ │ │ │ 120 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e │ │ │ │ │ references used for checksums. │ │ │ │ │ @@ -155,10 +155,14 @@ │ │ │ │ │ Creference & operator-=(const Creference &r) │ │ │ │ │ decrementation of reference │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._c_p_p_:_1_1_2 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f │ │ │ │ │ unsigned int ref[3] │ │ │ │ │ actual data for the reference │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_7_2 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ _r_a_n_l_u_x_._h │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/reference_8h_source.html │ │ │ │ @@ -88,43 +88,43 @@ │ │ │ │
47
│ │ │ │
49 void randomize();
│ │ │ │
50
│ │ │ │
52 bool is_empty();
│ │ │ │
53
│ │ │ │
55 bool not_empty();
│ │ │ │
56
│ │ │ │ - │ │ │ │ + │ │ │ │
59
│ │ │ │ - │ │ │ │ + │ │ │ │
62
│ │ │ │ - │ │ │ │ + │ │ │ │
65
│ │ │ │ - │ │ │ │ + │ │ │ │
68
│ │ │ │
70 inline unsigned int operator[] (int i) {return ref[i];}
│ │ │ │
71
│ │ │ │
72 unsigned int ref[3];
│ │ │ │
73};
│ │ │ │ │ │ │ │
74
│ │ │ │ -
76Creference operator + (Creference &r1, Creference &r2);
│ │ │ │ + │ │ │ │
77
│ │ │ │ -
79bool operator == (const Creference &r1, const Creference &r2);
│ │ │ │ +
79bool operator == (const Creference &r1, const Creference &r2);
│ │ │ │
80
│ │ │ │ -
82bool operator != (const Creference &r1, const Creference &r2);
│ │ │ │ +
82bool operator != (const Creference &r1, const Creference &r2);
│ │ │ │
83
│ │ │ │ -
85bool operator < (const Creference &r1, const Creference &r2);
│ │ │ │ +
85bool operator < (const Creference &r1, const Creference &r2);
│ │ │ │
86
│ │ │ │
87
│ │ │ │
88//=============== inline material ================
│ │ │ │
89
│ │ │ │
90// equality test for two references
│ │ │ │
91//----------------------------------
│ │ │ │ -
92inline bool operator == (const Creference &r1, const Creference &r2){
│ │ │ │ -
93 return (r1.ref[0]==r2.ref[0]) && (r1.ref[1]==r2.ref[1]) && (r1.ref[2]==r2.ref[2]);
│ │ │ │ +
92inline bool operator == (const Creference &r1, const Creference &r2){
│ │ │ │ +
93 return (r1.ref[0]==r2.ref[0]) && (r1.ref[1]==r2.ref[1]) && (r1.ref[2]==r2.ref[2]);
│ │ │ │
94}
│ │ │ │
95
│ │ │ │
96// difference test for two references
│ │ │ │
97//----------------------------------
│ │ │ │
98inline bool operator != (const Creference &r1, const Creference &r2){
│ │ │ │
99 return (r1.ref[0]!=r2.ref[0]) || (r1.ref[1]!=r2.ref[1]) || (r1.ref[2]!=r2.ref[2]);
│ │ │ │
100}
│ │ │ │ @@ -146,14 +146,15 @@ │ │ │ │
unsigned int operator[](int i)
accessing the reference
Definition reference.h:70
│ │ │ │
Creference()
default constructor
Definition reference.cpp:46
│ │ │ │
void randomize()
create a random reference
Definition reference.cpp:54
│ │ │ │
Creference & operator+=(const Creference &r)
incrementation of reference
│ │ │ │
bool not_empty()
test non-emptyness
Definition reference.cpp:81
│ │ │ │
Creference & operator-=(const Creference &r)
decrementation of reference
│ │ │ │
unsigned int ref[3]
actual data for the reference
Definition reference.h:72
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -38,43 +38,43 @@ │ │ │ │ │ 47 │ │ │ │ │ 49 void _r_a_n_d_o_m_i_z_e(); │ │ │ │ │ 50 │ │ │ │ │ 52 bool _i_s___e_m_p_t_y(); │ │ │ │ │ 53 │ │ │ │ │ 55 bool _n_o_t___e_m_p_t_y(); │ │ │ │ │ 56 │ │ │ │ │ -58 _C_r_e_f_e_r_e_n_c_e& _o_p_e_r_a_t_o_r_ _=_ (const _C_r_e_f_e_r_e_n_c_e &r); │ │ │ │ │ +58 _C_r_e_f_e_r_e_n_c_e& _o_p_e_r_a_t_o_r_ _=_ (const _C_r_e_f_e_r_e_n_c_e &_r); │ │ │ │ │ 59 │ │ │ │ │ -61 _C_r_e_f_e_r_e_n_c_e _o_p_e_r_a_t_o_r_ _+_ (const _C_r_e_f_e_r_e_n_c_e &r); │ │ │ │ │ +61 _C_r_e_f_e_r_e_n_c_e _o_p_e_r_a_t_o_r_ _+_ (const _C_r_e_f_e_r_e_n_c_e &_r); │ │ │ │ │ 62 │ │ │ │ │ -64 _C_r_e_f_e_r_e_n_c_e& _o_p_e_r_a_t_o_r_ _+_=_ (const _C_r_e_f_e_r_e_n_c_e &r); │ │ │ │ │ +64 _C_r_e_f_e_r_e_n_c_e& _o_p_e_r_a_t_o_r_ _+_=_ (const _C_r_e_f_e_r_e_n_c_e &_r); │ │ │ │ │ 65 │ │ │ │ │ -67 _C_r_e_f_e_r_e_n_c_e& _o_p_e_r_a_t_o_r_ _-_=_ (const _C_r_e_f_e_r_e_n_c_e &r); │ │ │ │ │ +67 _C_r_e_f_e_r_e_n_c_e& _o_p_e_r_a_t_o_r_ _-_=_ (const _C_r_e_f_e_r_e_n_c_e &_r); │ │ │ │ │ 68 │ │ │ │ │ _7_0 inline unsigned int _o_p_e_r_a_t_o_r_[_]_ (int i) {return _r_e_f[i];} │ │ │ │ │ 71 │ │ │ │ │ _7_2 unsigned int _r_e_f[3]; │ │ │ │ │ 73}; │ │ │ │ │ 74 │ │ │ │ │ -76_C_r_e_f_e_r_e_n_c_e operator + (_C_r_e_f_e_r_e_n_c_e &r1, _C_r_e_f_e_r_e_n_c_e &r2); │ │ │ │ │ +76_C_r_e_f_e_r_e_n_c_e _o_p_e_r_a_t_o_r_ _+_ (_C_r_e_f_e_r_e_n_c_e &_r_1, _C_r_e_f_e_r_e_n_c_e &_r_2); │ │ │ │ │ 77 │ │ │ │ │ -79bool operator == (const _C_r_e_f_e_r_e_n_c_e &r1, const _C_r_e_f_e_r_e_n_c_e &r2); │ │ │ │ │ +79bool _o_p_e_r_a_t_o_r_ _=_=_ (const _C_r_e_f_e_r_e_n_c_e &_r_1, const _C_r_e_f_e_r_e_n_c_e &_r_2); │ │ │ │ │ 80 │ │ │ │ │ -82bool operator != (const _C_r_e_f_e_r_e_n_c_e &r1, const _C_r_e_f_e_r_e_n_c_e &r2); │ │ │ │ │ +82bool _o_p_e_r_a_t_o_r_ _!_=_ (const _C_r_e_f_e_r_e_n_c_e &_r_1, const _C_r_e_f_e_r_e_n_c_e &_r_2); │ │ │ │ │ 83 │ │ │ │ │ -85bool operator < (const _C_r_e_f_e_r_e_n_c_e &r1, const _C_r_e_f_e_r_e_n_c_e &r2); │ │ │ │ │ +85bool _o_p_e_r_a_t_o_r_ _<_ (const _C_r_e_f_e_r_e_n_c_e &_r_1, const _C_r_e_f_e_r_e_n_c_e &_r_2); │ │ │ │ │ 86 │ │ │ │ │ 87 │ │ │ │ │ 88//=============== inline material ================ │ │ │ │ │ 89 │ │ │ │ │ 90// equality test for two references │ │ │ │ │ 91//---------------------------------- │ │ │ │ │ -92inline bool operator == (const _C_r_e_f_e_r_e_n_c_e &r1, const _C_r_e_f_e_r_e_n_c_e &r2){ │ │ │ │ │ -93 return (r1._r_e_f[0]==r2._r_e_f[0]) && (r1._r_e_f[1]==r2._r_e_f[1]) && (r1._r_e_f │ │ │ │ │ -[2]==r2._r_e_f[2]); │ │ │ │ │ +92inline bool _o_p_e_r_a_t_o_r_ _=_=_ (const _C_r_e_f_e_r_e_n_c_e &_r_1, const _C_r_e_f_e_r_e_n_c_e &_r_2){ │ │ │ │ │ +93 return (_r_1.ref[0]==_r_2.ref[0]) && (_r_1.ref[1]==_r_2.ref[1]) && (_r_1.ref │ │ │ │ │ +[2]==_r_2.ref[2]); │ │ │ │ │ 94} │ │ │ │ │ 95 │ │ │ │ │ 96// difference test for two references │ │ │ │ │ 97//---------------------------------- │ │ │ │ │ 98inline bool operator != (const Creference &r1, const Creference &r2){ │ │ │ │ │ 99 return (r1.ref[0]!=r2.ref[0]) || (r1.ref[1]!=r2.ref[1]) || (r1.ref │ │ │ │ │ [2]!=r2.ref[2]); │ │ │ │ │ @@ -129,9 +129,13 @@ │ │ │ │ │ Creference & operator-=(const Creference &r) │ │ │ │ │ decrementation of reference │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._c_p_p_:_1_1_2 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_r_e_f_e_r_e_n_c_e_:_:_r_e_f │ │ │ │ │ unsigned int ref[3] │ │ │ │ │ actual data for the reference │ │ │ │ │ DDeeffiinniittiioonn _r_e_f_e_r_e_n_c_e_._h_:_7_2 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/siscone_8h_source.html │ │ │ │ @@ -87,35 +87,35 @@ │ │ │ │
│ │ │ │
48class Csiscone : public Cstable_cones, public Csplit_merge{
│ │ │ │
49 public:
│ │ │ │
51 Csiscone();
│ │ │ │
52
│ │ │ │
54 ~Csiscone();
│ │ │ │
55
│ │ │ │ -
76 int compute_jets(std::vector<Cmomentum> &_particles, double _radius, double _f,
│ │ │ │ -
77 int _n_pass_max=0, double _ptmin=0.0,
│ │ │ │ -
78 Esplit_merge_scale _split_merge_scale=SM_pttilde);
│ │ │ │ +
76 int compute_jets(std::vector<Cmomentum> &_particles, double _radius, double _f,
│ │ │ │ +
77 int _n_pass_max=0, double _ptmin=0.0,
│ │ │ │ +
78 Esplit_merge_scale _split_merge_scale=SM_pttilde);
│ │ │ │
79
│ │ │ │ -
97 int compute_jets_progressive_removal(std::vector<Cmomentum> &_particles, double _radius,
│ │ │ │ -
98 int _n_pass_max=0, double _ptmin=0.0,
│ │ │ │ -
99 Esplit_merge_scale _ordering_scale=SM_pttilde);
│ │ │ │ +
97 int compute_jets_progressive_removal(std::vector<Cmomentum> &_particles, double _radius,
│ │ │ │ +
98 int _n_pass_max=0, double _ptmin=0.0,
│ │ │ │ +
99 Esplit_merge_scale _ordering_scale=SM_pttilde);
│ │ │ │
100
│ │ │ │ -
113 int recompute_jets(double _f, double _ptmin = 0.0,
│ │ │ │ -
114 Esplit_merge_scale _split_merge_scale=SM_pttilde);
│ │ │ │ +
113 int recompute_jets(double _f, double _ptmin = 0.0,
│ │ │ │ +
114 Esplit_merge_scale _split_merge_scale=SM_pttilde);
│ │ │ │
115
│ │ │ │
117 std::vector<std::vector<Cmomentum> > protocones_list;
│ │ │ │
118
│ │ │ │
119 // random number initialisation
│ │ │ │
120 static bool init_done;
│ │ │ │
121
│ │ │ │
122#ifdef DEBUG_STABLE_CONES
│ │ │ │ -
123 int nb_hash_cones_total, nb_hash_occupied_total;
│ │ │ │ + │ │ │ │
124#endif
│ │ │ │
125
│ │ │ │ -
137 static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;}
│ │ │ │ +
137 static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;}
│ │ │ │
138
│ │ │ │
143 static std::ostream * banner_stream() {return _banner_ostr;}
│ │ │ │
144
│ │ │ │
145 private:
│ │ │ │
146 bool rerun_allowed;
│ │ │ │
147 static std::ostream * _banner_ostr;
│ │ │ │
148
│ │ │ │ @@ -143,14 +143,15 @@ │ │ │ │
int compute_jets_progressive_removal(std::vector< Cmomentum > &_particles, double _radius, int _n_pass_max=0, double _ptmin=0.0, Esplit_merge_scale _ordering_scale=SM_pttilde)
compute the jets from a given particle set.
Definition siscone.cpp:156
│ │ │ │
static bool init_done
check random generator initialisation
Definition siscone.h:120
│ │ │ │
static void set_banner_stream(std::ostream *ostr)
A call to this function modifies the stream used to print banners (by default cout).
Definition siscone.h:137
│ │ │ │
static std::ostream * banner_stream()
returns a pointer to the stream to be used to print banners (cout by default)
Definition siscone.h:143
│ │ │ │
Csiscone()
default ctor
Definition siscone.cpp:51
│ │ │ │
Class used to split and merge jets.
│ │ │ │
Computes the list of stable comes from a particle list.
Definition protocones.h:82
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -37,37 +37,37 @@ │ │ │ │ │ 35 │ │ │ │ │ _4_8class _C_s_i_s_c_o_n_e : public _C_s_t_a_b_l_e___c_o_n_e_s, public _C_s_p_l_i_t___m_e_r_g_e{ │ │ │ │ │ 49 public: │ │ │ │ │ 51 _C_s_i_s_c_o_n_e(); │ │ │ │ │ 52 │ │ │ │ │ 54 _~_C_s_i_s_c_o_n_e(); │ │ │ │ │ 55 │ │ │ │ │ -76 int _c_o_m_p_u_t_e___j_e_t_s(std::vector &_particles, double _radius, double │ │ │ │ │ -_f, │ │ │ │ │ -77 int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ -78 Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ +76 int _c_o_m_p_u_t_e___j_e_t_s(std::vector &___p_a_r_t_i_c_l_e_s, double ___r_a_d_i_u_s, double │ │ │ │ │ +___f, │ │ │ │ │ +77 int ___n___p_a_s_s___m_a_x=0, double ___p_t_m_i_n=0.0, │ │ │ │ │ +78 Esplit_merge_scale ___s_p_l_i_t___m_e_r_g_e___s_c_a_l_e=SM_pttilde); │ │ │ │ │ 79 │ │ │ │ │ -97 int _c_o_m_p_u_t_e___j_e_t_s___p_r_o_g_r_e_s_s_i_v_e___r_e_m_o_v_a_l(std::vector &_particles, │ │ │ │ │ -double _radius, │ │ │ │ │ -98 int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ -99 Esplit_merge_scale _ordering_scale=SM_pttilde); │ │ │ │ │ +97 int _c_o_m_p_u_t_e___j_e_t_s___p_r_o_g_r_e_s_s_i_v_e___r_e_m_o_v_a_l(std::vector &___p_a_r_t_i_c_l_e_s, │ │ │ │ │ +double ___r_a_d_i_u_s, │ │ │ │ │ +98 int ___n___p_a_s_s___m_a_x=0, double ___p_t_m_i_n=0.0, │ │ │ │ │ +99 Esplit_merge_scale ___o_r_d_e_r_i_n_g___s_c_a_l_e=SM_pttilde); │ │ │ │ │ 100 │ │ │ │ │ -113 int _r_e_c_o_m_p_u_t_e___j_e_t_s(double _f, double _ptmin = 0.0, │ │ │ │ │ -114 Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ +113 int _r_e_c_o_m_p_u_t_e___j_e_t_s(double ___f, double ___p_t_m_i_n = 0.0, │ │ │ │ │ +114 Esplit_merge_scale ___s_p_l_i_t___m_e_r_g_e___s_c_a_l_e=SM_pttilde); │ │ │ │ │ 115 │ │ │ │ │ _1_1_7 std::vector > _p_r_o_t_o_c_o_n_e_s___l_i_s_t; │ │ │ │ │ 118 │ │ │ │ │ 119 // random number initialisation │ │ │ │ │ _1_2_0 static bool _i_n_i_t___d_o_n_e; │ │ │ │ │ 121 │ │ │ │ │ 122#ifdef DEBUG_STABLE_CONES │ │ │ │ │ -123 int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ +123 int _n_b___h_a_s_h___c_o_n_e_s___t_o_t_a_l, _n_b___h_a_s_h___o_c_c_u_p_i_e_d___t_o_t_a_l; │ │ │ │ │ 124#endif │ │ │ │ │ 125 │ │ │ │ │ -_1_3_7 static void _s_e_t___b_a_n_n_e_r___s_t_r_e_a_m(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ +_1_3_7 static void _s_e_t___b_a_n_n_e_r___s_t_r_e_a_m(std::ostream * _o_s_t_r) {_banner_ostr = _o_s_t_r;} │ │ │ │ │ 138 │ │ │ │ │ _1_4_3 static std::ostream * _b_a_n_n_e_r___s_t_r_e_a_m() {return _banner_ostr;} │ │ │ │ │ 144 │ │ │ │ │ 145 private: │ │ │ │ │ 146 bool rerun_allowed; │ │ │ │ │ 147 static std::ostream * _banner_ostr; │ │ │ │ │ 148 │ │ │ │ │ @@ -134,9 +134,13 @@ │ │ │ │ │ DDeeffiinniittiioonn _s_i_s_c_o_n_e_._c_p_p_:_5_1 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_s_p_l_i_t___m_e_r_g_e │ │ │ │ │ Class used to split and merge jets. │ │ │ │ │ DDeeffiinniittiioonn _s_p_l_i_t___m_e_r_g_e_._h_:_1_8_0 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_s_t_a_b_l_e___c_o_n_e_s │ │ │ │ │ Computes the list of stable comes from a particle list. │ │ │ │ │ DDeeffiinniittiioonn _p_r_o_t_o_c_o_n_e_s_._h_:_8_2 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/siscone__error_8h_source.html │ │ │ │ @@ -86,25 +86,25 @@ │ │ │ │
35
│ │ │ │
│ │ │ │ │ │ │ │
39public:
│ │ │ │ │ │ │ │
42
│ │ │ │
│ │ │ │ -
45 Csiscone_error(const std::string & message_in) {
│ │ │ │ -
46 m_message = message_in;
│ │ │ │ -
47 if (m_print_errors) std::cerr << "siscone::Csiscone_error: "<< message_in << std::endl;
│ │ │ │ +
45 Csiscone_error(const std::string & message_in) {
│ │ │ │ +
46 m_message = message_in;
│ │ │ │ +
47 if (m_print_errors) std::cerr << "siscone::Csiscone_error: "<< message_in << std::endl;
│ │ │ │
48 };
│ │ │ │
│ │ │ │
49
│ │ │ │
51 std::string message() const {return m_message;};
│ │ │ │
52
│ │ │ │
│ │ │ │ -
55 static void setm_print_errors(bool print_errors) {
│ │ │ │ -
56 m_print_errors = print_errors;};
│ │ │ │ +
55 static void setm_print_errors(bool print_errors) {
│ │ │ │ +
56 m_print_errors = print_errors;};
│ │ │ │
│ │ │ │
57
│ │ │ │
58private:
│ │ │ │
59 std::string m_message;
│ │ │ │
60 static bool m_print_errors;
│ │ │ │
61};
│ │ │ │
│ │ │ │ @@ -112,14 +112,15 @@ │ │ │ │
63}
│ │ │ │
64#endif
│ │ │ │
class corresponding to errors that will be thrown by siscone
│ │ │ │
Csiscone_error()
default ctor
│ │ │ │
Csiscone_error(const std::string &message_in)
ctor with a given error message
│ │ │ │
std::string message() const
access to the error message
│ │ │ │
static void setm_print_errors(bool print_errors)
switch on/off the error message printing
│ │ │ │ +
a circulator that is foreseen to take as template member either a pointer or an iterator;
Definition circulator.h:36
│ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -35,24 +35,24 @@ │ │ │ │ │ 33 │ │ │ │ │ 34namespace siscone{ │ │ │ │ │ 35 │ │ │ │ │ _3_8class _C_s_i_s_c_o_n_e___e_r_r_o_r { │ │ │ │ │ 39public: │ │ │ │ │ _4_1 _C_s_i_s_c_o_n_e___e_r_r_o_r() {;}; │ │ │ │ │ 42 │ │ │ │ │ -_4_5 _C_s_i_s_c_o_n_e___e_r_r_o_r(const std::string & message_in) { │ │ │ │ │ -46 m_message = message_in; │ │ │ │ │ -47 if (m_print_errors) std::cerr << "siscone::Csiscone_error: "<< message_in << │ │ │ │ │ +_4_5 _C_s_i_s_c_o_n_e___e_r_r_o_r(const std::string & _m_e_s_s_a_g_e___i_n) { │ │ │ │ │ +46 m_message = _m_e_s_s_a_g_e___i_n; │ │ │ │ │ +47 if (m_print_errors) std::cerr << "siscone::Csiscone_error: "<< _m_e_s_s_a_g_e___i_n << │ │ │ │ │ std::endl; │ │ │ │ │ 48 }; │ │ │ │ │ 49 │ │ │ │ │ _5_1 std::string _m_e_s_s_a_g_e() const {return m_message;}; │ │ │ │ │ 52 │ │ │ │ │ -_5_5 static void _s_e_t_m___p_r_i_n_t___e_r_r_o_r_s(bool print_errors) { │ │ │ │ │ -56 m_print_errors = print_errors;}; │ │ │ │ │ +_5_5 static void _s_e_t_m___p_r_i_n_t___e_r_r_o_r_s(bool _p_r_i_n_t___e_r_r_o_r_s) { │ │ │ │ │ +56 m_print_errors = _p_r_i_n_t___e_r_r_o_r_s;}; │ │ │ │ │ 57 │ │ │ │ │ 58private: │ │ │ │ │ 59 std::string m_message; │ │ │ │ │ 60 static bool m_print_errors; │ │ │ │ │ 61}; │ │ │ │ │ 62 │ │ │ │ │ 63} │ │ │ │ │ @@ -72,9 +72,13 @@ │ │ │ │ │ std::string message() const │ │ │ │ │ access to the error message │ │ │ │ │ DDeeffiinniittiioonn _s_i_s_c_o_n_e___e_r_r_o_r_._h_:_5_1 │ │ │ │ │ _s_i_s_c_o_n_e_:_:_C_s_i_s_c_o_n_e___e_r_r_o_r_:_:_s_e_t_m___p_r_i_n_t___e_r_r_o_r_s │ │ │ │ │ static void setm_print_errors(bool print_errors) │ │ │ │ │ switch on/off the error message printing │ │ │ │ │ DDeeffiinniittiioonn _s_i_s_c_o_n_e___e_r_r_o_r_._h_:_5_5 │ │ │ │ │ +_s_i_s_c_o_n_e_:_:_c_i_r_c_u_l_a_t_o_r │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +DDeeffiinniittiioonn _c_i_r_c_u_l_a_t_o_r_._h_:_3_6 │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by _[_d_o_x_y_g_e_n_] 1.9.8 │ │ │ ├── ./usr/share/doc/siscone-doc-html/html/devel/spherical_2geom__2d_8cpp_source.html │ │ │ │ @@ -226,21 +226,20 @@ │ │ │ │
166const CSphtheta_phi_range range_union (const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2){
│ │ │ │
167 CSphtheta_phi_range tmp;
│ │ │ │
168
│ │ │ │
169 // compute union in eta
│ │ │ │
170 tmp.theta_range = r1.theta_range | r2.theta_range;
│ │ │ │
171
│ │ │ │
172 // compute union in phi
│ │ │ │ -
173 tmp.phi_range = r1.phi_range | r2.phi_range;
│ │ │ │ +
173 tmp.phi_range = r1.phi_range | r2.phi_range;
│ │ │ │
174
│ │ │ │
175 return tmp;
│ │ │ │
176}
│ │ │ │
177
│ │ │ │
178}
│ │ │ │ -
unsigned int phi_range
phi range as a binary coding of covered cells
Definition geom_2d.h:146
│ │ │ │
class for holding a covering range in eta-phi
Definition geom_2d.h:52
│ │ │ │
int add_particle(const double theta, const double phi)
add a particle to the range
Definition geom_2d.cpp:130
│ │ │ │
CSphtheta_phi_range & operator=(const CSphtheta_phi_range &r)
assignment of range
Definition geom_2d.cpp:118
│ │ │ │
static double theta_max
maximal value for theta (set to pi)
Definition geom_2d.h:82
│ │ │ │
unsigned int theta_range
theta range as a binary coding of covered cells
Definition geom_2d.h:75
│ │ │ │
static double theta_min
extremal value for theta
Definition geom_2d.h:81
│ │ │ │ │ │ │ │ ├── html2text {} │ │ │ │ │ @@ -175,24 +175,20 @@ │ │ │ │ │ CSphtheta_phi_range &r2){ │ │ │ │ │ 167 CSphtheta_phi_range tmp; │ │ │ │ │ 168 │ │ │ │ │ 169 // compute union in eta │ │ │ │ │ 170 tmp.theta_range = r1.theta_range | r2.theta_range; │ │ │ │ │ 171 │ │ │ │ │ 172 // compute union in phi │ │ │ │ │ -173 tmp._p_h_i___r_a_n_g_e = r1.phi_range | r2.phi_range; │ │ │ │ │ +173 tmp.phi_range = r1.phi_range | r2.phi_range; │ │ │ │ │ 174 │ │ │ │ │ 175 return tmp; │ │ │ │ │ 176} │ │ │ │ │ 177 │ │ │ │ │ 178} │ │ │ │ │ -_s_i_s_c_o_n_e_:_:_C_e_t_a___p_h_i___r_a_n_g_e_:_:_p_h_i___r_a_n_g_e │ │ │ │ │ -unsigned int phi_range │ │ │ │ │ -phi range as a binary coding of covered cells │ │ │ │ │ -DDeeffiinniittiioonn _g_e_o_m___2_d_._h_:_1_4_6 │ │ │ │ │ _s_i_s_c_o_n_e___s_p_h_e_r_i_c_a_l_:_:_C_S_p_h_t_h_e_t_a___p_h_i___r_a_n_g_e │ │ │ │ │ class for holding a covering range in eta-phi │ │ │ │ │ DDeeffiinniittiioonn _g_e_o_m___2_d_._h_:_5_2 │ │ │ │ │ _s_i_s_c_o_n_e___s_p_h_e_r_i_c_a_l_:_:_C_S_p_h_t_h_e_t_a___p_h_i___r_a_n_g_e_:_:_a_d_d___p_a_r_t_i_c_l_e │ │ │ │ │ int add_particle(const double theta, const double phi) │ │ │ │ │ add a particle to the range │ │ │ │ │ DDeeffiinniittiioonn _g_e_o_m___2_d_._c_p_p_:_1_3_0 ├── siscone-doc-pdf_3.0.5-3_all.deb │ ├── file list │ │ @@ -1,3 +1,3 @@ │ │ -rw-r--r-- 0 0 0 4 2025-01-07 11:57:28.000000 debian-binary │ │ -rw-r--r-- 0 0 0 808 2025-01-07 11:57:28.000000 control.tar.xz │ │ --rw-r--r-- 0 0 0 1645696 2025-01-07 11:57:28.000000 data.tar.xz │ │ +-rw-r--r-- 0 0 0 1654148 2025-01-07 11:57:28.000000 data.tar.xz │ ├── control.tar.xz │ │ ├── control.tar │ │ │ ├── ./control │ │ │ │ @@ -1,13 +1,13 @@ │ │ │ │ Package: siscone-doc-pdf │ │ │ │ Source: siscone │ │ │ │ Version: 3.0.5-3 │ │ │ │ Architecture: all │ │ │ │ Maintainer: Debian Science Maintainers │ │ │ │ -Installed-Size: 1618 │ │ │ │ +Installed-Size: 1626 │ │ │ │ Section: doc │ │ │ │ Priority: optional │ │ │ │ Multi-Arch: foreign │ │ │ │ Homepage: http://projects.hepforge.org/siscone/ │ │ │ │ Description: Developer's reference manual of SISCone (PDF) │ │ │ │ SISCone implements a Seedless Infrared (IR) Safe Cone jet algorithm, it takes │ │ │ │ N^2*ln(N) time to find jets among N particles, comparing to N*2^N time of │ │ │ ├── ./md5sums │ │ │ │ ├── ./md5sums │ │ │ │ │┄ Files differ │ ├── data.tar.xz │ │ ├── data.tar │ │ │ ├── file list │ │ │ │ @@ -3,10 +3,10 @@ │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2025-01-07 11:57:28.000000 ./usr/share/ │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2025-01-07 11:57:28.000000 ./usr/share/doc/ │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-pdf/ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1083 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-pdf/changelog.Debian.gz │ │ │ │ -rw-r--r-- 0 root (0) root (0) 16688 2020-04-24 08:56:01.000000 ./usr/share/doc/siscone-doc-pdf/changelog.gz │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1151 2025-01-07 11:56:31.000000 ./usr/share/doc/siscone-doc-pdf/copyright │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-pdf/pdf/ │ │ │ │ --rw-r--r-- 0 root (0) root (0) 1625743 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-pdf/pdf/refman.pdf.gz │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 1634098 2025-01-07 11:57:28.000000 ./usr/share/doc/siscone-doc-pdf/pdf/refman.pdf.gz │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2025-01-07 11:57:28.000000 ./usr/share/doc-base/ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 240 2025-01-07 11:56:31.000000 ./usr/share/doc-base/siscone-doc-pdf.siscone-pdf │ │ │ ├── ./usr/share/doc/siscone-doc-pdf/pdf/refman.pdf.gz │ │ │ │ ├── refman.pdf │ │ │ │ │ ├── pdftotext {} - │ │ │ │ │ │ @@ -1577,15 +1577,15 @@ │ │ │ │ │ │ 4.33.2.2 ∼hash_cones() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166 │ │ │ │ │ │ 4.33.3 Member Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166 │ │ │ │ │ │ 4.33.3.1 insert() [1/2] . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166 │ │ │ │ │ │ 4.33.3.2 insert() [2/2] . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166 │ │ │ │ │ │ 4.33.3.3 is_inside() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 │ │ │ │ │ │ 4.33.4 Member Data Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 │ │ │ │ │ │ 4.33.4.1 hash_array . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 │ │ │ │ │ │ -4.33.4.2 mask . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 │ │ │ │ │ │ +4.33.4.2 mask . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 │ │ │ │ │ │ 4.33.4.3 n_cones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 │ │ │ │ │ │ 4.33.4.4 R2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 │ │ │ │ │ │ 4.34 siscone::hash_element Class Reference │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 │ │ │ │ │ │ │ │ │ │ │ │ 4.34.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 169 │ │ │ │ │ │ @@ -1600,25 +1600,25 @@ │ │ │ │ │ │ │ │ │ │ │ │ xiv │ │ │ │ │ │ │ │ │ │ │ │ 4.35 siscone::ranlux_state_t Struct Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170 │ │ │ │ │ │ 4.35.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170 │ │ │ │ │ │ 4.35.2 Member Data Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170 │ │ │ │ │ │ 4.35.2.1 carry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170 │ │ │ │ │ │ -4.35.2.2 i . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171 │ │ │ │ │ │ +4.35.2.2 i . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170 │ │ │ │ │ │ 4.35.2.3 j . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171 │ │ │ │ │ │ 4.35.2.4 n . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171 │ │ │ │ │ │ 4.35.2.5 skip │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171 │ │ │ │ │ │ │ │ │ │ │ │ 4.35.2.6 u . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171 │ │ │ │ │ │ 4.36 siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . 172 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . 171 │ │ │ │ │ │ │ │ │ │ │ │ 4.36.1 Detailed Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 │ │ │ │ │ │ 4.36.2 Constructor & Destructor Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 │ │ │ │ │ │ 4.36.2.1 sph_hash_cones() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 │ │ │ │ │ │ 4.36.2.2 ∼sph_hash_cones() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 │ │ │ │ │ │ 4.36.3 Member Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 │ │ │ │ │ │ 4.36.3.1 insert() [1/2] . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 │ │ │ │ │ │ @@ -1635,35 +1635,35 @@ │ │ │ │ │ │ 4.37.2.1 centre . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177 │ │ │ │ │ │ 4.37.2.2 is_stable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177 │ │ │ │ │ │ 4.37.2.3 next . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177 │ │ │ │ │ │ 5 File Documentation │ │ │ │ │ │ │ │ │ │ │ │ 179 │ │ │ │ │ │ │ │ │ │ │ │ -5.1 main.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179 │ │ │ │ │ │ -5.2 options.cpp │ │ │ │ │ │ +5.1 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179 │ │ │ │ │ │ +5.2 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180 │ │ │ │ │ │ +5.3 main.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 184 │ │ │ │ │ │ +5.4 options.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 │ │ │ │ │ │ │ │ │ │ │ │ -5.3 options.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 183 │ │ │ │ │ │ -5.4 sample.cpp │ │ │ │ │ │ +5.5 options.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 │ │ │ │ │ │ +5.6 sample.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 184 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 │ │ │ │ │ │ │ │ │ │ │ │ -5.5 spherical.cpp │ │ │ │ │ │ +5.7 spherical.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 191 │ │ │ │ │ │ │ │ │ │ │ │ -5.6 test.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 │ │ │ │ │ │ -5.7 times.cpp │ │ │ │ │ │ +5.8 test.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 192 │ │ │ │ │ │ +5.9 times.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 188 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 193 │ │ │ │ │ │ │ │ │ │ │ │ -5.8 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 │ │ │ │ │ │ -5.9 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 191 │ │ │ │ │ │ 5.10 area.h │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 195 │ │ │ │ │ │ │ │ │ │ │ │ 5.11 circulator.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ @@ -1683,66 +1683,66 @@ │ │ │ │ │ │ 5.14.1.4 PT_TSHOLD │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201 │ │ │ │ │ │ │ │ │ │ │ │ 5.14.2 Variable Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201 │ │ │ │ │ │ 5.14.2.1 twopi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201 │ │ │ │ │ │ 5.15 defines.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201 │ │ │ │ │ │ -5.16 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202 │ │ │ │ │ │ -5.17 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 203 │ │ │ │ │ │ -5.18 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204 │ │ │ │ │ │ -5.19 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 206 │ │ │ │ │ │ -5.20 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209 │ │ │ │ │ │ -5.21 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211 │ │ │ │ │ │ -5.22 quadtree.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 213 │ │ │ │ │ │ -5.23 quadtree.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 216 │ │ │ │ │ │ -5.24 ranlux.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 217 │ │ │ │ │ │ -5.25 siscone/ranlux.h File Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219 │ │ │ │ │ │ -5.25.1 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220 │ │ │ │ │ │ -5.25.1.1 ranlux_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220 │ │ │ │ │ │ -5.25.1.2 ranlux_init() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220 │ │ │ │ │ │ -5.25.1.3 ranlux_print_state() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220 │ │ │ │ │ │ -5.26 ranlux.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220 │ │ │ │ │ │ -5.27 reference.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 221 │ │ │ │ │ │ -5.28 reference.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 222 │ │ │ │ │ │ -5.29 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223 │ │ │ │ │ │ -5.30 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 224 │ │ │ │ │ │ -5.31 siscone_error.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225 │ │ │ │ │ │ -5.32 siscone_error.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226 │ │ │ │ │ │ -5.33 geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227 │ │ │ │ │ │ -5.34 geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228 │ │ │ │ │ │ -5.35 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 230 │ │ │ │ │ │ -5.36 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 │ │ │ │ │ │ -5.37 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 233 │ │ │ │ │ │ -5.38 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236 │ │ │ │ │ │ -5.39 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 238 │ │ │ │ │ │ -5.40 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 247 │ │ │ │ │ │ -5.41 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257 │ │ │ │ │ │ -5.42 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 259 │ │ │ │ │ │ +5.16 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202 │ │ │ │ │ │ +5.17 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 212 │ │ │ │ │ │ +5.18 quadtree.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 221 │ │ │ │ │ │ +5.19 quadtree.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225 │ │ │ │ │ │ +5.20 ranlux.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226 │ │ │ │ │ │ +5.21 siscone/ranlux.h File Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228 │ │ │ │ │ │ +5.21.1 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228 │ │ │ │ │ │ +5.21.1.1 ranlux_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228 │ │ │ │ │ │ +5.21.1.2 ranlux_init() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228 │ │ │ │ │ │ +5.21.1.3 ranlux_print_state() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229 │ │ │ │ │ │ +5.22 ranlux.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229 │ │ │ │ │ │ +5.23 reference.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 229 │ │ │ │ │ │ +5.24 reference.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231 │ │ │ │ │ │ +5.25 siscone_error.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 │ │ │ │ │ │ +5.26 siscone_error.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 │ │ │ │ │ │ +5.27 geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 233 │ │ │ │ │ │ +5.28 geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235 │ │ │ │ │ │ +5.29 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237 │ │ │ │ │ │ +5.30 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 238 │ │ │ │ │ │ +5.31 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239 │ │ │ │ │ │ +5.32 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242 │ │ │ │ │ │ +5.33 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244 │ │ │ │ │ │ +5.34 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245 │ │ │ │ │ │ +5.35 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246 │ │ │ │ │ │ +5.36 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248 │ │ │ │ │ │ +5.37 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 252 │ │ │ │ │ │ +5.38 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 253 │ │ │ │ │ │ +5.39 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 255 │ │ │ │ │ │ +5.40 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257 │ │ │ │ │ │ +5.41 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 259 │ │ │ │ │ │ +5.42 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 263 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ xvi │ │ │ │ │ │ │ │ │ │ │ │ -5.43 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 261 │ │ │ │ │ │ -5.44 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 264 │ │ │ │ │ │ -5.45 split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 268 │ │ │ │ │ │ -5.46 split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271 │ │ │ │ │ │ -5.47 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 273 │ │ │ │ │ │ -5.48 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 275 │ │ │ │ │ │ -5.49 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 276 │ │ │ │ │ │ - │ │ │ │ │ │ -5.50 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 290 │ │ │ │ │ │ - │ │ │ │ │ │ -5.51 vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303 │ │ │ │ │ │ -5.52 vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 307 │ │ │ │ │ │ +5.43 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 266 │ │ │ │ │ │ +5.44 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267 │ │ │ │ │ │ +5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 268 │ │ │ │ │ │ + │ │ │ │ │ │ +5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 282 │ │ │ │ │ │ + │ │ │ │ │ │ +5.47 split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 295 │ │ │ │ │ │ +5.48 split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 298 │ │ │ │ │ │ +5.49 vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301 │ │ │ │ │ │ +5.50 vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304 │ │ │ │ │ │ +5.51 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308 │ │ │ │ │ │ +5.52 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309 │ │ │ │ │ │ Index │ │ │ │ │ │ │ │ │ │ │ │ 311 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 1 │ │ │ │ │ │ @@ -1826,15 +1826,15 @@ │ │ │ │ │ │ siscone_spherical::sph_hash_cones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone_spherical::sph_hash_element . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ │ │ │ │ │ │ 163 │ │ │ │ │ │ 164 │ │ │ │ │ │ 168 │ │ │ │ │ │ 170 │ │ │ │ │ │ -172 │ │ │ │ │ │ +171 │ │ │ │ │ │ 176 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 2 │ │ │ │ │ │ │ │ │ │ │ │ Class Index │ │ │ │ │ │ @@ -1958,15 +1958,15 @@ │ │ │ │ │ │ 153 │ │ │ │ │ │ 160 │ │ │ │ │ │ │ │ │ │ │ │ 163 │ │ │ │ │ │ 164 │ │ │ │ │ │ 168 │ │ │ │ │ │ 170 │ │ │ │ │ │ -172 │ │ │ │ │ │ +171 │ │ │ │ │ │ 176 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 3 │ │ │ │ │ │ │ │ │ │ │ │ File Index │ │ │ │ │ │ @@ -2009,49 +2009,49 @@ │ │ │ │ │ │ siscone/siscone_error.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/siscone_error.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/split_merge.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -189 │ │ │ │ │ │ 179 │ │ │ │ │ │ -180 │ │ │ │ │ │ -183 │ │ │ │ │ │ 184 │ │ │ │ │ │ -185 │ │ │ │ │ │ 186 │ │ │ │ │ │ -188 │ │ │ │ │ │ +189 │ │ │ │ │ │ +189 │ │ │ │ │ │ 191 │ │ │ │ │ │ +192 │ │ │ │ │ │ +193 │ │ │ │ │ │ +180 │ │ │ │ │ │ 195 │ │ │ │ │ │ 196 │ │ │ │ │ │ 197 │ │ │ │ │ │ 198 │ │ │ │ │ │ 199 │ │ │ │ │ │ -227 │ │ │ │ │ │ -230 │ │ │ │ │ │ 233 │ │ │ │ │ │ +237 │ │ │ │ │ │ +239 │ │ │ │ │ │ +244 │ │ │ │ │ │ +246 │ │ │ │ │ │ +252 │ │ │ │ │ │ 202 │ │ │ │ │ │ -204 │ │ │ │ │ │ -209 │ │ │ │ │ │ -238 │ │ │ │ │ │ -257 │ │ │ │ │ │ -213 │ │ │ │ │ │ -216 │ │ │ │ │ │ -217 │ │ │ │ │ │ -219 │ │ │ │ │ │ +255 │ │ │ │ │ │ 221 │ │ │ │ │ │ -222 │ │ │ │ │ │ -261 │ │ │ │ │ │ -223 │ │ │ │ │ │ 225 │ │ │ │ │ │ 226 │ │ │ │ │ │ -290 │ │ │ │ │ │ -271 │ │ │ │ │ │ -307 │ │ │ │ │ │ +228 │ │ │ │ │ │ +229 │ │ │ │ │ │ +231 │ │ │ │ │ │ +259 │ │ │ │ │ │ +266 │ │ │ │ │ │ +232 │ │ │ │ │ │ +232 │ │ │ │ │ │ +282 │ │ │ │ │ │ +298 │ │ │ │ │ │ +304 │ │ │ │ │ │ │ │ │ │ │ │ 6 │ │ │ │ │ │ │ │ │ │ │ │ File Index │ │ │ │ │ │ │ │ │ │ │ │ siscone/vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ @@ -2065,29 +2065,29 @@ │ │ │ │ │ │ siscone/spherical/siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/split_merge.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ │ │ │ │ │ │ -275 │ │ │ │ │ │ -228 │ │ │ │ │ │ -232 │ │ │ │ │ │ -236 │ │ │ │ │ │ -203 │ │ │ │ │ │ -206 │ │ │ │ │ │ -211 │ │ │ │ │ │ -247 │ │ │ │ │ │ -259 │ │ │ │ │ │ -264 │ │ │ │ │ │ -224 │ │ │ │ │ │ -276 │ │ │ │ │ │ +309 │ │ │ │ │ │ +235 │ │ │ │ │ │ +238 │ │ │ │ │ │ +242 │ │ │ │ │ │ +245 │ │ │ │ │ │ +248 │ │ │ │ │ │ +253 │ │ │ │ │ │ +212 │ │ │ │ │ │ +257 │ │ │ │ │ │ +263 │ │ │ │ │ │ +267 │ │ │ │ │ │ 268 │ │ │ │ │ │ -303 │ │ │ │ │ │ -273 │ │ │ │ │ │ +295 │ │ │ │ │ │ +301 │ │ │ │ │ │ +308 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 4 │ │ │ │ │ │ │ │ │ │ │ │ Class Documentation │ │ │ │ │ │ │ │ │ │ │ │ @@ -11656,17 +11656,16 @@ │ │ │ │ │ │ 4-momentum of te cone to add Note, in this case, we assume stability. We also assume that eta and phi are │ │ │ │ │ │ computed for v │ │ │ │ │ │ │ │ │ │ │ │ Returns │ │ │ │ │ │ 0 on success, 1 on error │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 171 of file hash.cpp. │ │ │ │ │ │ -References siscone::hash_element::eta, siscone::Cmomentum::eta, hash_array, siscone::hash_element::is_stable, │ │ │ │ │ │ -mask, n_cones, siscone::hash_element::next, siscone::hash_element::phi, siscone::Cmomentum::phi, siscone::hash_element::ref, │ │ │ │ │ │ -siscone::Cmomentum::ref, and siscone::Creference::ref. │ │ │ │ │ │ +References siscone::Cmomentum::eta, hash_array, mask, n_cones, siscone::Cmomentum::phi, siscone::Cmomentum::ref, │ │ │ │ │ │ +and siscone::Creference::ref. │ │ │ │ │ │ │ │ │ │ │ │ 4.33.3.2 │ │ │ │ │ │ │ │ │ │ │ │ insert() [2/2] │ │ │ │ │ │ │ │ │ │ │ │ int siscone::hash_cones::insert ( │ │ │ │ │ │ Cmomentum ∗ v, │ │ │ │ │ │ @@ -11701,41 +11700,38 @@ │ │ │ │ │ │ │ │ │ │ │ │ 167 │ │ │ │ │ │ │ │ │ │ │ │ Returns │ │ │ │ │ │ 0 on success, 1 on error │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 102 of file hash.cpp. │ │ │ │ │ │ -References siscone::Cmomentum::build_etaphi(), │ │ │ │ │ │ -siscone::hash_element::eta, │ │ │ │ │ │ -siscone::Cmomentum::eta, │ │ │ │ │ │ -hash_array, is_inside(), siscone::hash_element::is_stable, mask, n_cones, siscone::hash_element::next, │ │ │ │ │ │ -siscone::hash_element::phi, siscone::Cmomentum::phi, siscone::hash_element::ref, siscone::Cmomentum::ref, │ │ │ │ │ │ -and siscone::Creference::ref. │ │ │ │ │ │ +References siscone::Cmomentum::build_etaphi(), siscone::Cmomentum::eta, hash_array, is_inside(), mask, │ │ │ │ │ │ +n_cones, siscone::Cmomentum::phi, siscone::Cmomentum::ref, and siscone::Creference::ref. │ │ │ │ │ │ │ │ │ │ │ │ 4.33.3.3 │ │ │ │ │ │ │ │ │ │ │ │ is_inside() │ │ │ │ │ │ │ │ │ │ │ │ bool siscone::hash_cones::is_inside ( │ │ │ │ │ │ Cmomentum ∗ centre, │ │ │ │ │ │ -Cmomentum ∗ v ) [inline] │ │ │ │ │ │ +Cmomentum ∗ v ) │ │ │ │ │ │ + │ │ │ │ │ │ +[inline] │ │ │ │ │ │ │ │ │ │ │ │ test if a particle is inside a cone of given centre. │ │ │ │ │ │ check if the particle of coordinates 'v' is inside the circle of radius R centered at 'centre'. │ │ │ │ │ │ Parameters │ │ │ │ │ │ centre │ │ │ │ │ │ v │ │ │ │ │ │ │ │ │ │ │ │ centre of the circle │ │ │ │ │ │ particle to test │ │ │ │ │ │ │ │ │ │ │ │ Returns │ │ │ │ │ │ true if inside, false if outside │ │ │ │ │ │ - │ │ │ │ │ │ Definition at line 219 of file hash.cpp. │ │ │ │ │ │ References siscone::Cmomentum::eta, siscone::Cmomentum::phi, and R2. │ │ │ │ │ │ Referenced by insert(). │ │ │ │ │ │ │ │ │ │ │ │ 4.33.4 │ │ │ │ │ │ │ │ │ │ │ │ Member Data Documentation │ │ │ │ │ │ @@ -11746,30 +11742,29 @@ │ │ │ │ │ │ │ │ │ │ │ │ hash_element∗∗ siscone::hash_cones::hash_array │ │ │ │ │ │ │ │ │ │ │ │ the cone data itself │ │ │ │ │ │ Definition at line 93 of file hash.h. │ │ │ │ │ │ Referenced by hash_cones(), insert(), insert(), and ∼hash_cones(). │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 168 │ │ │ │ │ │ - │ │ │ │ │ │ -Class Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 4.33.4.2 │ │ │ │ │ │ │ │ │ │ │ │ mask │ │ │ │ │ │ │ │ │ │ │ │ int siscone::hash_cones::mask │ │ │ │ │ │ │ │ │ │ │ │ number of occupied cells │ │ │ │ │ │ number of cells-1 │ │ │ │ │ │ Definition at line 104 of file hash.h. │ │ │ │ │ │ Referenced by hash_cones(), insert(), insert(), and ∼hash_cones(). │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 168 │ │ │ │ │ │ + │ │ │ │ │ │ +Class Documentation │ │ │ │ │ │ │ │ │ │ │ │ 4.33.4.3 │ │ │ │ │ │ │ │ │ │ │ │ n_cones │ │ │ │ │ │ │ │ │ │ │ │ int siscone::hash_cones::n_cones │ │ │ │ │ │ │ │ │ │ │ │ @@ -11783,14 +11778,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ double siscone::hash_cones::R2 │ │ │ │ │ │ │ │ │ │ │ │ circle radius (squared) NOTE: need to be set before any call to 'insert' │ │ │ │ │ │ Definition at line 108 of file hash.h. │ │ │ │ │ │ Referenced by hash_cones(), and is_inside(). │ │ │ │ │ │ The documentation for this class was generated from the following files: │ │ │ │ │ │ + │ │ │ │ │ │ • siscone/hash.h │ │ │ │ │ │ • siscone/hash.cpp │ │ │ │ │ │ │ │ │ │ │ │ 4.34 │ │ │ │ │ │ │ │ │ │ │ │ siscone::hash_element Class Reference │ │ │ │ │ │ │ │ │ │ │ │ @@ -11844,62 +11840,57 @@ │ │ │ │ │ │ │ │ │ │ │ │ eta │ │ │ │ │ │ │ │ │ │ │ │ double siscone::hash_element::eta │ │ │ │ │ │ │ │ │ │ │ │ centre: eta coordinate │ │ │ │ │ │ Definition at line 48 of file hash.h. │ │ │ │ │ │ -Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert(). │ │ │ │ │ │ │ │ │ │ │ │ 4.34.2.2 │ │ │ │ │ │ │ │ │ │ │ │ is_stable │ │ │ │ │ │ │ │ │ │ │ │ bool siscone::hash_element::is_stable │ │ │ │ │ │ │ │ │ │ │ │ true if stable w.r.t. "border particles" │ │ │ │ │ │ Definition at line 50 of file hash.h. │ │ │ │ │ │ -Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert(). │ │ │ │ │ │ │ │ │ │ │ │ 4.34.2.3 │ │ │ │ │ │ │ │ │ │ │ │ next │ │ │ │ │ │ │ │ │ │ │ │ hash_element∗ siscone::hash_element::next │ │ │ │ │ │ │ │ │ │ │ │ pointer to the next element │ │ │ │ │ │ Definition at line 52 of file hash.h. │ │ │ │ │ │ -Referenced by siscone::hash_cones::insert(), siscone::hash_cones::insert(), and siscone::hash_cones::∼hash_cones(). │ │ │ │ │ │ +Referenced by siscone::hash_cones::∼hash_cones(). │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 170 │ │ │ │ │ │ │ │ │ │ │ │ Class Documentation │ │ │ │ │ │ │ │ │ │ │ │ 4.34.2.4 │ │ │ │ │ │ │ │ │ │ │ │ phi │ │ │ │ │ │ │ │ │ │ │ │ double siscone::hash_element::phi │ │ │ │ │ │ │ │ │ │ │ │ centre: phi coordinate │ │ │ │ │ │ Definition at line 49 of file hash.h. │ │ │ │ │ │ -Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert(). │ │ │ │ │ │ │ │ │ │ │ │ 4.34.2.5 │ │ │ │ │ │ │ │ │ │ │ │ ref │ │ │ │ │ │ │ │ │ │ │ │ Creference siscone::hash_element::ref │ │ │ │ │ │ │ │ │ │ │ │ reference │ │ │ │ │ │ Definition at line 47 of file hash.h. │ │ │ │ │ │ -Referenced by siscone::hash_cones::insert(), and siscone::hash_cones::insert(). │ │ │ │ │ │ The documentation for this class was generated from the following file: │ │ │ │ │ │ - │ │ │ │ │ │ • siscone/hash.h │ │ │ │ │ │ │ │ │ │ │ │ 4.35 │ │ │ │ │ │ │ │ │ │ │ │ siscone::ranlux_state_t Struct Reference │ │ │ │ │ │ │ │ │ │ │ │ Public Attributes │ │ │ │ │ │ @@ -11923,25 +11914,25 @@ │ │ │ │ │ │ 4.35.2.1 │ │ │ │ │ │ │ │ │ │ │ │ carry │ │ │ │ │ │ │ │ │ │ │ │ unsigned int siscone::ranlux_state_t::carry │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 51 of file ranlux.cpp. │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 4.35 siscone::ranlux_state_t Struct Reference │ │ │ │ │ │ │ │ │ │ │ │ 4.35.2.2 │ │ │ │ │ │ │ │ │ │ │ │ i │ │ │ │ │ │ │ │ │ │ │ │ unsigned int siscone::ranlux_state_t::i │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 47 of file ranlux.cpp. │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 4.36 siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ │ │ │ │ │ │ 4.35.2.3 │ │ │ │ │ │ │ │ │ │ │ │ j │ │ │ │ │ │ │ │ │ │ │ │ unsigned int siscone::ranlux_state_t::j │ │ │ │ │ │ │ │ │ │ │ │ @@ -11970,29 +11961,30 @@ │ │ │ │ │ │ unsigned long int siscone::ranlux_state_t::u[24] │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 52 of file ranlux.cpp. │ │ │ │ │ │ The documentation for this struct was generated from the following file: │ │ │ │ │ │ │ │ │ │ │ │ • siscone/ranlux.cpp │ │ │ │ │ │ │ │ │ │ │ │ +4.36 │ │ │ │ │ │ + │ │ │ │ │ │ +siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ + │ │ │ │ │ │ +list of cones candidates. │ │ │ │ │ │ + │ │ │ │ │ │ +#include │ │ │ │ │ │ + │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 171 │ │ │ │ │ │ │ │ │ │ │ │ 172 │ │ │ │ │ │ │ │ │ │ │ │ Class Documentation │ │ │ │ │ │ │ │ │ │ │ │ -4.36 │ │ │ │ │ │ - │ │ │ │ │ │ -siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ - │ │ │ │ │ │ -list of cones candidates. │ │ │ │ │ │ - │ │ │ │ │ │ -#include │ │ │ │ │ │ Collaboration diagram for siscone_spherical::sph_hash_cones: │ │ │ │ │ │ │ │ │ │ │ │ siscone::Creference │ │ │ │ │ │ ref │ │ │ │ │ │ siscone_spherical:: │ │ │ │ │ │ CSph3vector │ │ │ │ │ │ centre │ │ │ │ │ │ @@ -12018,29 +12010,31 @@ │ │ │ │ │ │ │ │ │ │ │ │ Public Attributes │ │ │ │ │ │ • sph_hash_element ∗∗ hash_array │ │ │ │ │ │ the cone data itself │ │ │ │ │ │ │ │ │ │ │ │ • int n_cones │ │ │ │ │ │ number of elements │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 4.36 siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ │ │ │ │ │ │ • int mask │ │ │ │ │ │ number of occupied cells │ │ │ │ │ │ │ │ │ │ │ │ • double R2 │ │ │ │ │ │ circle radius (squared) NOTE: need to be set before any call to 'insert' │ │ │ │ │ │ │ │ │ │ │ │ • double tan2R │ │ │ │ │ │ its squreed tangent │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 4.36 siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ │ │ │ │ │ │ 4.36.1 │ │ │ │ │ │ │ │ │ │ │ │ +173 │ │ │ │ │ │ + │ │ │ │ │ │ Detailed Description │ │ │ │ │ │ │ │ │ │ │ │ list of cones candidates. │ │ │ │ │ │ We store in this class all the hash_elements and give functions to manipulate them. │ │ │ │ │ │ Definition at line 61 of file hash.h. │ │ │ │ │ │ │ │ │ │ │ │ 4.36.2 │ │ │ │ │ │ @@ -12064,14 +12058,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ cone radius │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 49 of file hash.cpp. │ │ │ │ │ │ References hash_array, mask, n_cones, and tan2R. │ │ │ │ │ │ │ │ │ │ │ │ 4.36.2.2 ∼sph_hash_cones() │ │ │ │ │ │ + │ │ │ │ │ │ siscone_spherical::sph_hash_cones::∼sph_hash_cones ( ) │ │ │ │ │ │ │ │ │ │ │ │ destructor │ │ │ │ │ │ Definition at line 80 of file hash.cpp. │ │ │ │ │ │ References hash_array, mask, and siscone_spherical::sph_hash_element::next. │ │ │ │ │ │ │ │ │ │ │ │ 4.36.3 │ │ │ │ │ │ @@ -12082,29 +12077,26 @@ │ │ │ │ │ │ │ │ │ │ │ │ insert() [1/2] │ │ │ │ │ │ │ │ │ │ │ │ int siscone_spherical::sph_hash_cones::insert ( │ │ │ │ │ │ CSphmomentum ∗ v ) │ │ │ │ │ │ │ │ │ │ │ │ insert a new candidate into the hash. │ │ │ │ │ │ +Parameters │ │ │ │ │ │ +v │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ +4-momentum of te cone to add Note, in this case, we assume stability. We also assume that eta and phi are │ │ │ │ │ │ +computed for v │ │ │ │ │ │ │ │ │ │ │ │ -173 │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 174 │ │ │ │ │ │ │ │ │ │ │ │ Class Documentation │ │ │ │ │ │ │ │ │ │ │ │ -Parameters │ │ │ │ │ │ -v │ │ │ │ │ │ - │ │ │ │ │ │ -4-momentum of te cone to add Note, in this case, we assume stability. We also assume that eta and phi are │ │ │ │ │ │ -computed for v │ │ │ │ │ │ - │ │ │ │ │ │ Returns │ │ │ │ │ │ 0 on success, 1 on error │ │ │ │ │ │ │ │ │ │ │ │ Definition at line 169 of file hash.cpp. │ │ │ │ │ │ References siscone_spherical::sph_hash_element::centre, hash_array, siscone_spherical::sph_hash_element::is_stable, │ │ │ │ │ │ mask, n_cones, siscone_spherical::sph_hash_element::next, siscone::Creference::ref, and siscone_spherical::CSph3vector::ref. │ │ │ │ │ │ │ │ │ │ │ │ @@ -12137,14 +12129,15 @@ │ │ │ │ │ │ │ │ │ │ │ │ c_io │ │ │ │ │ │ │ │ │ │ │ │ whether the child has to belong to the cone or not │ │ │ │ │ │ │ │ │ │ │ │ Returns │ │ │ │ │ │ 0 on success, 1 on error │ │ │ │ │ │ + │ │ │ │ │ │ Definition at line 105 of file hash.cpp. │ │ │ │ │ │ References siscone_spherical::sph_hash_element::centre, hash_array, siscone_spherical::sph_hash_element::is_stable, │ │ │ │ │ │ mask, n_cones, siscone_spherical::sph_hash_element::next, siscone::Creference::ref, siscone_spherical::CSph3vector::ref, │ │ │ │ │ │ and tan2R. │ │ │ │ │ │ │ │ │ │ │ │ 4.36.4 │ │ │ │ │ │ │ │ │ │ │ │ @@ -12155,14 +12148,15 @@ │ │ │ │ │ │ hash_array │ │ │ │ │ │ │ │ │ │ │ │ sph_hash_element∗∗ siscone_spherical::sph_hash_cones::hash_array │ │ │ │ │ │ │ │ │ │ │ │ the cone data itself │ │ │ │ │ │ Definition at line 91 of file hash.h. │ │ │ │ │ │ Referenced by insert(), insert(), sph_hash_cones(), and ∼sph_hash_cones(). │ │ │ │ │ │ + │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 4.36 siscone_spherical::sph_hash_cones Class Reference │ │ │ │ │ │ │ │ │ │ │ │ 4.36.4.2 │ │ │ │ │ │ │ │ │ │ │ │ mask │ │ │ │ │ │ @@ -12306,15 +12300,15 @@ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 5 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ 5.1 │ │ │ │ │ │ │ │ │ │ │ │ -main.cpp │ │ │ │ │ │ +area.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: main.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: main program that runs siscone from the command line │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ @@ -12350,14 +12344,852 @@ │ │ │ │ │ │ 00019 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00022 // │ │ │ │ │ │ // │ │ │ │ │ │ +00023 // $Revision:: 171 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00024 // $Date:: 2007-06-19 10:26:05 -0400 (Tue, 19 Jun 2007) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00026 │ │ │ │ │ │ +00027 #include │ │ │ │ │ │ +00028 #include │ │ │ │ │ │ +00029 #include │ │ │ │ │ │ +00030 #include "siscone/momentum.h" │ │ │ │ │ │ +00031 #include "siscone/siscone.h" │ │ │ │ │ │ +00032 #include "siscone/area.h" │ │ │ │ │ │ +00033 #include "options.h" │ │ │ │ │ │ +00034 │ │ │ │ │ │ +00035 using namespace std; │ │ │ │ │ │ +00036 using namespace siscone; │ │ │ │ │ │ +00037 │ │ │ │ │ │ +00038 int main(int argc, char *argv[]){ │ │ │ │ │ │ +00039 │ │ │ │ │ │ +vector particles; │ │ │ │ │ │ +00040 │ │ │ │ │ │ +Carea siscone_with_area; │ │ │ │ │ │ +00041 │ │ │ │ │ │ +int i,N; │ │ │ │ │ │ +00042 │ │ │ │ │ │ +double px,py,pz,E; │ │ │ │ │ │ +00043 │ │ │ │ │ │ +Coptions opts; │ │ │ │ │ │ +00044 │ │ │ │ │ │ +char fline[512]; │ │ │ │ │ │ +00045 │ │ │ │ │ │ +00046 │ │ │ │ │ │ +if (opts.parse_options(argc, argv)) │ │ │ │ │ │ +00047 │ │ │ │ │ │ +exit(1); │ │ │ │ │ │ +00048 │ │ │ │ │ │ +00049 │ │ │ │ │ │ +// deal with help message │ │ │ │ │ │ +00050 │ │ │ │ │ │ +if (opts.help_flag){ │ │ │ │ │ │ +00051 │ │ │ │ │ │ +opts.print_help(); │ │ │ │ │ │ +00052 │ │ │ │ │ │ +exit(0); │ │ │ │ │ │ +00053 │ │ │ │ │ │ +} │ │ │ │ │ │ +00054 │ │ │ │ │ │ +00055 │ │ │ │ │ │ +// deal with version flag │ │ │ │ │ │ +00056 │ │ │ │ │ │ +if (opts.version_flag){ │ │ │ │ │ │ +00057 │ │ │ │ │ │ +opts.print_version(); │ │ │ │ │ │ +00058 │ │ │ │ │ │ +exit(0); │ │ │ │ │ │ +00059 │ │ │ │ │ │ +} │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 180 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00060 │ │ │ │ │ │ +00061 │ │ │ │ │ │ +// various files used to read input data and store results │ │ │ │ │ │ +00062 │ │ │ │ │ │ +FILE *flux; │ │ │ │ │ │ +00063 │ │ │ │ │ │ +FILE *fpart; │ │ │ │ │ │ +00064 │ │ │ │ │ │ +00065 │ │ │ │ │ │ +// read particles │ │ │ │ │ │ +00066 │ │ │ │ │ │ +if (opts.verbose_flag) cout « "reading particles" « endl; │ │ │ │ │ │ +00067 │ │ │ │ │ │ +flux = fopen(opts.ev_name, "r"); │ │ │ │ │ │ +00068 │ │ │ │ │ │ +if (flux==NULL){ │ │ │ │ │ │ +00069 │ │ │ │ │ │ +cerr « "cannot read event" « endl; │ │ │ │ │ │ +00070 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ +00071 │ │ │ │ │ │ +} │ │ │ │ │ │ +00072 │ │ │ │ │ │ +00073 │ │ │ │ │ │ +N=0; │ │ │ │ │ │ +00074 │ │ │ │ │ │ +fpart = fopen("particles.dat", "w+"); │ │ │ │ │ │ +00075 │ │ │ │ │ │ +while ((opts.N_stop!=0) && (fgets(fline, 512, flux)!=NULL)){ │ │ │ │ │ │ +00076 │ │ │ │ │ │ +if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ +00077 │ │ │ │ │ │ +if (sscanf(fline, "%le%le%le%le", &px, &py, &pz, &E)==4){ │ │ │ │ │ │ +00078 │ │ │ │ │ │ +particles.push_back(Cmomentum(px, py, pz, E)); │ │ │ │ │ │ +00079 │ │ │ │ │ │ +fprintf(fpart, "%e\t%e\n", │ │ │ │ │ │ +particles[N].eta, particles[N].phi); │ │ │ │ │ │ +00080 │ │ │ │ │ │ +N++; │ │ │ │ │ │ +00081 │ │ │ │ │ │ +opts.N_stop--; │ │ │ │ │ │ +00082 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00083 │ │ │ │ │ │ +cout « "error in reading event file Giving up." « endl; │ │ │ │ │ │ +00084 │ │ │ │ │ │ +fclose(flux); │ │ │ │ │ │ +00085 │ │ │ │ │ │ +fclose(fpart); │ │ │ │ │ │ +00086 │ │ │ │ │ │ +exit(2); │ │ │ │ │ │ +00087 │ │ │ │ │ │ +} │ │ │ │ │ │ +00088 │ │ │ │ │ │ +} │ │ │ │ │ │ +00089 │ │ │ │ │ │ +} │ │ │ │ │ │ +00090 │ │ │ │ │ │ +fclose(flux); │ │ │ │ │ │ +00091 │ │ │ │ │ │ +fclose(fpart); │ │ │ │ │ │ +00092 │ │ │ │ │ │ +if (opts.verbose_flag) │ │ │ │ │ │ +00093 │ │ │ │ │ │ +cout « " working with " « N « " particles" « endl; │ │ │ │ │ │ +00094 │ │ │ │ │ │ +00095 │ │ │ │ │ │ +// compute jets │ │ │ │ │ │ +00096 │ │ │ │ │ │ +if (opts.verbose_flag) cout « "computing jet contents" « endl; │ │ │ │ │ │ +00097 │ │ │ │ │ │ +i=siscone_with_area.compute_areas(particles, opts.R, opts.f, opts.npass, opts.SM_var); │ │ │ │ │ │ +00098 │ │ │ │ │ │ +if (opts.verbose_flag){ │ │ │ │ │ │ +00099 │ │ │ │ │ │ +unsigned int pass; │ │ │ │ │ │ +00100 │ │ │ │ │ │ +for (pass=0;pass::iterator ja; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +for (ja=siscone_with_area.jet_areas.begin();ja!=siscone_with_area.jet_areas.end();ja++){ │ │ │ │ │ │ +00112 │ │ │ │ │ │ +fprintf(flux, "%e\t%e\t%e\t%e\t%e\n", │ │ │ │ │ │ +00113 │ │ │ │ │ │ +ja->v.perp(), ja->v.eta, ja->v.phi, │ │ │ │ │ │ +00114 │ │ │ │ │ │ +ja->active_area, ja->passive_area); │ │ │ │ │ │ +00115 │ │ │ │ │ │ +} │ │ │ │ │ │ +00116 │ │ │ │ │ │ +00117 │ │ │ │ │ │ +fclose(flux); │ │ │ │ │ │ +00118 │ │ │ │ │ │ +00119 │ │ │ │ │ │ +if (opts.verbose_flag) │ │ │ │ │ │ +00120 │ │ │ │ │ │ +cout « "bye..." « endl; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +00122 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00123 } │ │ │ │ │ │ + │ │ │ │ │ │ +5.2 │ │ │ │ │ │ + │ │ │ │ │ │ +area.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: area.h │ │ │ │ │ │ +00004 // Description: header file for the computation of jet area │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +00007 // │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +00009 // │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +00013 // (at your option) any later version. │ │ │ │ │ │ +00014 // │ │ │ │ │ │ +00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.2 area.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00018 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00023 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // $Revision:: 149 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00025 // $Date:: 2007-03-15 00:13:58 +0100 (Thu, 15 Mar 2007) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 │ │ │ │ │ │ +00028 #include "area.h" │ │ │ │ │ │ +00029 #include "momentum.h" │ │ │ │ │ │ +00030 #include │ │ │ │ │ │ +00031 #include │ │ │ │ │ │ +00032 │ │ │ │ │ │ +00033 namespace siscone{ │ │ │ │ │ │ +00034 using namespace std; │ │ │ │ │ │ +00035 │ │ │ │ │ │ +00036 /******************************************************* │ │ │ │ │ │ +00037 * Cjet_area implementation │ │ │ │ │ │ +* │ │ │ │ │ │ +00038 * real Jet information, including its area(s) │ │ │ │ │ │ +* │ │ │ │ │ │ +00039 * │ │ │ │ │ │ +* │ │ │ │ │ │ +00040 * This class contains information for one single jet. * │ │ │ │ │ │ +00041 * That is, first, its momentum carrying information │ │ │ │ │ │ +* │ │ │ │ │ │ +00042 * about its centre and pT, and second, its particle │ │ │ │ │ │ +* │ │ │ │ │ │ +00043 * contents (from CJeT). │ │ │ │ │ │ +* │ │ │ │ │ │ +00044 * Compared to the Cjet class, it also includes the │ │ │ │ │ │ +* │ │ │ │ │ │ +00045 * passive and active areas of the jet computed using * │ │ │ │ │ │ +00046 * the Carea class. │ │ │ │ │ │ +* │ │ │ │ │ │ +00047 *******************************************************/ │ │ │ │ │ │ +00048 │ │ │ │ │ │ +00049 // default ctor │ │ │ │ │ │ +00050 //-------------00051 Cjet_area::Cjet_area(){ │ │ │ │ │ │ +00052 │ │ │ │ │ │ +active_area = passive_area = 0.0; │ │ │ │ │ │ +00053 } │ │ │ │ │ │ +00054 │ │ │ │ │ │ +00055 // jet-initiated ctor │ │ │ │ │ │ +00056 //------------------00057 Cjet_area::Cjet_area(Cjet &j){ │ │ │ │ │ │ +00058 │ │ │ │ │ │ +v = j.v; │ │ │ │ │ │ +00059 │ │ │ │ │ │ +n = j.n; │ │ │ │ │ │ +00060 │ │ │ │ │ │ +contents = j.contents; │ │ │ │ │ │ +00061 │ │ │ │ │ │ +00062 │ │ │ │ │ │ +pass = j.pass; │ │ │ │ │ │ +00063 │ │ │ │ │ │ +00064 │ │ │ │ │ │ +pt_tilde = j.pt_tilde; │ │ │ │ │ │ +00065 │ │ │ │ │ │ +sm_var2 = j.sm_var2; │ │ │ │ │ │ +00066 │ │ │ │ │ │ +00067 │ │ │ │ │ │ +active_area = passive_area = 0.0; │ │ │ │ │ │ +00068 } │ │ │ │ │ │ +00069 │ │ │ │ │ │ +00070 // default dtor │ │ │ │ │ │ +00071 //-------------00072 Cjet_area::~Cjet_area(){ │ │ │ │ │ │ +00073 │ │ │ │ │ │ +00074 } │ │ │ │ │ │ +00075 │ │ │ │ │ │ +00076 │ │ │ │ │ │ +00077 /****************************************************************** │ │ │ │ │ │ +00078 * Csiscone_area implementation │ │ │ │ │ │ +* │ │ │ │ │ │ +00079 * class for the computation of jet areas. │ │ │ │ │ │ +* │ │ │ │ │ │ +00080 * │ │ │ │ │ │ +* │ │ │ │ │ │ +00081 * This is the class user should use whenever you want to compute * │ │ │ │ │ │ +00082 * the jet area (passive and active). │ │ │ │ │ │ +* │ │ │ │ │ │ +00083 * It uses the SISCone algorithm to perform the jet analysis. │ │ │ │ │ │ +* │ │ │ │ │ │ +00084 ******************************************************************/ │ │ │ │ │ │ +00085 │ │ │ │ │ │ +00086 // default ctor │ │ │ │ │ │ +00087 //------------00088 Carea::Carea(){ │ │ │ │ │ │ +00089 │ │ │ │ │ │ +grid_size = 60; │ │ │ │ │ │ +// 3600 particles added │ │ │ │ │ │ +00090 │ │ │ │ │ │ +grid_eta_max = 6.0; // maybe having twice more points in eta than in phi should be nice │ │ │ │ │ │ +00091 │ │ │ │ │ │ +grid_shift = 0.5; │ │ │ │ │ │ +// 50% "shacking" │ │ │ │ │ │ +00092 │ │ │ │ │ │ +00093 │ │ │ │ │ │ +pt_soft = 1e-100; │ │ │ │ │ │ +00094 │ │ │ │ │ │ +pt_shift = 0.05; │ │ │ │ │ │ +00095 │ │ │ │ │ │ +pt_soft_min = 1e-90; │ │ │ │ │ │ +00096 } │ │ │ │ │ │ +00097 │ │ │ │ │ │ +00098 // default dtor │ │ │ │ │ │ +00099 //------------00100 Carea::~Carea(){ │ │ │ │ │ │ +00101 │ │ │ │ │ │ +00102 } │ │ │ │ │ │ +00103 │ │ │ │ │ │ +00104 /* │ │ │ │ │ │ +00105 * compute the jet areas from a given particle set. │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +181 │ │ │ │ │ │ + │ │ │ │ │ │ + 182 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00106 * The parameters of this method are the ones which control the jet clustering alghorithm. │ │ │ │ │ │ +00107 * Note that the pt_min is not allowed here soince the jet-area determination involves soft │ │ │ │ │ │ +00108 * particles/jets and thus is used internally. │ │ │ │ │ │ +00109 * - _particles │ │ │ │ │ │ +list of particles │ │ │ │ │ │ +00110 * - _radius │ │ │ │ │ │ +cone radius │ │ │ │ │ │ +00111 * - _f │ │ │ │ │ │ +shared energy threshold for splitting&merging │ │ │ │ │ │ +00112 * - _n_pass_max maximum number of passes (0=full search, the default) │ │ │ │ │ │ +00113 * - _split_merge_scale │ │ │ │ │ │ +the scale choice for the split-merge procedure │ │ │ │ │ │ +00114 * │ │ │ │ │ │ +NOTE: SM_pt leads to IR unsafety for some events with momentum conservation. │ │ │ │ │ │ +00115 * │ │ │ │ │ │ +SM_Et is IR safe but not boost invariant and not implemented(!) │ │ │ │ │ │ +00116 * │ │ │ │ │ │ +SM_mt is IR safe for hadronic events, but not for decays of two │ │ │ │ │ │ +00117 * │ │ │ │ │ │ +back-to-back particles of identical mass │ │ │ │ │ │ +00118 * │ │ │ │ │ │ +SM_pttilde │ │ │ │ │ │ +00119 * │ │ │ │ │ │ +is always IR safe, and also boost invariant (default) │ │ │ │ │ │ +00120 * - _hard_only │ │ │ │ │ │ +when this is set on, only hard jets are computed │ │ │ │ │ │ +00121 * │ │ │ │ │ │ +and not the purely ghosted jets (default: false) │ │ │ │ │ │ +00122 * return the jets together with their areas │ │ │ │ │ │ +00123 * The return value is the number of jets (including pure-ghost ones if they are included) │ │ │ │ │ │ +00124 ********************************************************************************************/ │ │ │ │ │ │ +00125 int Carea::compute_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ +00126 │ │ │ │ │ │ +int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ +00127 │ │ │ │ │ │ +bool _hard_only){ │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00129 │ │ │ │ │ │ +vector all_particles; │ │ │ │ │ │ +00130 │ │ │ │ │ │ +00131 │ │ │ │ │ │ +// put "hardest cut-off" if needed │ │ │ │ │ │ +00132 │ │ │ │ │ │ +// this avoids computation of ghosted jets when not required and │ │ │ │ │ │ +00133 │ │ │ │ │ │ +// significantly shortens the SM. │ │ │ │ │ │ +00134 │ │ │ │ │ │ +if (_hard_only){ │ │ │ │ │ │ +00135 │ │ │ │ │ │ +SM_var2_hardest_cut_off = pt_soft_min*pt_soft_min; │ │ │ │ │ │ +00136 │ │ │ │ │ │ +} │ │ │ │ │ │ +00137 │ │ │ │ │ │ +00138 │ │ │ │ │ │ +// clear potential previous runs │ │ │ │ │ │ +00139 │ │ │ │ │ │ +jet_areas.clear(); │ │ │ │ │ │ +00140 │ │ │ │ │ │ +00141 │ │ │ │ │ │ +// put initial set of particles in the list │ │ │ │ │ │ +00142 │ │ │ │ │ │ +int n_hard = _particles.size(); │ │ │ │ │ │ +00143 │ │ │ │ │ │ +all_particles = _particles; │ │ │ │ │ │ +00144 │ │ │ │ │ │ +00145 │ │ │ │ │ │ +// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ +00146 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +double eta_g,phi_g,pt_g; │ │ │ │ │ │ +00148 │ │ │ │ │ │ +00149 │ │ │ │ │ │ +for (i=0;i= n_hard │ │ │ │ │ │ +00167 │ │ │ │ │ │ +// and deduce the number of ghosts in the jet, hence the area. │ │ │ │ │ │ +00168 │ │ │ │ │ │ +double area_factor = (2.0*grid_eta_max/grid_size)*(twopi/grid_size); │ │ │ │ │ │ +00169 │ │ │ │ │ │ +00170 │ │ │ │ │ │ +for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ +00171 │ │ │ │ │ │ +jet_areas.push_back(jets[i]); │ │ │ │ │ │ +00172 │ │ │ │ │ │ +j=0; │ │ │ │ │ │ +00173 │ │ │ │ │ │ +while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ +00218 │ │ │ │ │ │ +int _n_pass_max, Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ +00219 │ │ │ │ │ │ +00220 │ │ │ │ │ │ +vector all_particles; │ │ │ │ │ │ +00221 │ │ │ │ │ │ +00222 │ │ │ │ │ │ +// in the case of passive area, we do not need │ │ │ │ │ │ +00223 │ │ │ │ │ │ +// to put the ghosts in the stable-cone search │ │ │ │ │ │ +00224 │ │ │ │ │ │ +// (they do no influence the list of stable cones) │ │ │ │ │ │ +00225 │ │ │ │ │ │ +// Here’s how it goes... │ │ │ │ │ │ +00226 │ │ │ │ │ │ +stable_cone_soft_pt2_cutoff = pt_soft_min*pt_soft_min; │ │ │ │ │ │ +00227 │ │ │ │ │ │ +00228 │ │ │ │ │ │ +// clear potential previous runs │ │ │ │ │ │ +00229 │ │ │ │ │ │ +jet_areas.clear(); │ │ │ │ │ │ +00230 │ │ │ │ │ │ +00231 │ │ │ │ │ │ +// put initial set of particles in the list │ │ │ │ │ │ +00232 │ │ │ │ │ │ +int n_hard = _particles.size(); │ │ │ │ │ │ +00233 │ │ │ │ │ │ +all_particles = _particles; │ │ │ │ │ │ +00234 │ │ │ │ │ │ +00235 │ │ │ │ │ │ +// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ +00236 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ +00237 │ │ │ │ │ │ +double eta_g,phi_g,pt_g; │ │ │ │ │ │ +00238 │ │ │ │ │ │ +00239 │ │ │ │ │ │ +for (i=0;i= n_hard │ │ │ │ │ │ +00257 │ │ │ │ │ │ +// and deduce the number of ghosts in the jet, hence the area. │ │ │ │ │ │ +00258 │ │ │ │ │ │ +double area_factor = (2.0*grid_eta_max/grid_size)*(twopi/grid_size); │ │ │ │ │ │ +00259 │ │ │ │ │ │ +for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ +00260 │ │ │ │ │ │ +j=0; │ │ │ │ │ │ +00261 │ │ │ │ │ │ +while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ +00292 │ │ │ │ │ │ +int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ +00293 │ │ │ │ │ │ +bool _hard_only){ │ │ │ │ │ │ +00294 │ │ │ │ │ │ +00295 │ │ │ │ │ │ +vector all_particles; │ │ │ │ │ │ +00296 │ │ │ │ │ │ +00297 │ │ │ │ │ │ +// put "hardest cut-off" if needed │ │ │ │ │ │ +00298 │ │ │ │ │ │ +// this avoids computation of ghosted jets when not required and │ │ │ │ │ │ +00299 │ │ │ │ │ │ +// significantly shortens the SM. │ │ │ │ │ │ +00300 │ │ │ │ │ │ +if (_hard_only){ │ │ │ │ │ │ +00301 │ │ │ │ │ │ +SM_var2_hardest_cut_off = pt_soft_min*pt_soft_min; │ │ │ │ │ │ +00302 │ │ │ │ │ │ +} │ │ │ │ │ │ +00303 │ │ │ │ │ │ +00304 │ │ │ │ │ │ +// clear potential previous runs │ │ │ │ │ │ +00305 │ │ │ │ │ │ +jet_areas.clear(); │ │ │ │ │ │ +00306 │ │ │ │ │ │ +00307 │ │ │ │ │ │ +// put initial set of particles in the list │ │ │ │ │ │ +00308 │ │ │ │ │ │ +int n_hard = _particles.size(); │ │ │ │ │ │ +00309 │ │ │ │ │ │ +all_particles = _particles; │ │ │ │ │ │ +00310 │ │ │ │ │ │ +00311 │ │ │ │ │ │ +// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ +00312 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ +00313 │ │ │ │ │ │ +double eta_g,phi_g,pt_g; │ │ │ │ │ │ +00314 │ │ │ │ │ │ +00315 │ │ │ │ │ │ +for (i=0;i= n_hard │ │ │ │ │ │ +00333 │ │ │ │ │ │ +// and deduce the number of ghosts in the jet, hence the area. │ │ │ │ │ │ +00334 │ │ │ │ │ │ +double area_factor = (2.0*grid_eta_max/grid_size)*(twopi/grid_size); │ │ │ │ │ │ +00335 │ │ │ │ │ │ +00336 │ │ │ │ │ │ +for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ +00337 │ │ │ │ │ │ +jet_areas.push_back(jets[i]); │ │ │ │ │ │ +00338 │ │ │ │ │ │ +j=0; │ │ │ │ │ │ +00339 │ │ │ │ │ │ +while ((j │ │ │ │ │ │ 00028 #include │ │ │ │ │ │ @@ -12406,21 +13238,14 @@ │ │ │ │ │ │ 00056 │ │ │ │ │ │ opts.print_version(); │ │ │ │ │ │ 00057 │ │ │ │ │ │ exit(0); │ │ │ │ │ │ 00058 │ │ │ │ │ │ } │ │ │ │ │ │ 00059 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 180 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00060 │ │ │ │ │ │ // various files used to read input data and store results │ │ │ │ │ │ 00061 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00062 │ │ │ │ │ │ FILE *fpart; │ │ │ │ │ │ 00063 │ │ │ │ │ │ @@ -12485,14 +13310,23 @@ │ │ │ │ │ │ 00093 │ │ │ │ │ │ cout « " working with " « N « " particles" « endl; │ │ │ │ │ │ 00094 │ │ │ │ │ │ 00095 │ │ │ │ │ │ // compute jets │ │ │ │ │ │ 00096 │ │ │ │ │ │ if (opts.verbose_flag) cout « "computing jet contents" « endl; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +185 │ │ │ │ │ │ + │ │ │ │ │ │ + 186 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00097 │ │ │ │ │ │ i=siscone.compute_jets(particles, opts.R, opts.f, opts.npass, opts.ptmin, opts.SM_var); │ │ │ │ │ │ 00098 │ │ │ │ │ │ if (opts.verbose_flag){ │ │ │ │ │ │ 00099 │ │ │ │ │ │ unsigned int pass; │ │ │ │ │ │ 00100 │ │ │ │ │ │ @@ -12525,15 +13359,15 @@ │ │ │ │ │ │ 00114 │ │ │ │ │ │ cout « "bye..." « endl; │ │ │ │ │ │ 00115 │ │ │ │ │ │ 00116 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00117 } │ │ │ │ │ │ │ │ │ │ │ │ -5.2 │ │ │ │ │ │ +5.4 │ │ │ │ │ │ │ │ │ │ │ │ options.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: options.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: management of the cmdline options of the main program │ │ │ │ │ │ @@ -12571,21 +13405,18 @@ │ │ │ │ │ │ 00019 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00022 // │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.2 options.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00023 // $Revision:: 213 │ │ │ │ │ │ +$// │ │ │ │ │ │ 00024 // $Date:: 2008-03-17 17:05:59 +0100 (Mon, 17 Mar 2008) │ │ │ │ │ │ +$// │ │ │ │ │ │ 00026 │ │ │ │ │ │ 00027 #include "options.h" │ │ │ │ │ │ 00028 #include │ │ │ │ │ │ 00029 #include │ │ │ │ │ │ 00030 #include │ │ │ │ │ │ 00031 │ │ │ │ │ │ 00032 using namespace std; │ │ │ │ │ │ @@ -12629,14 +13460,21 @@ │ │ │ │ │ │ N_stop = N_DEFAULT; │ │ │ │ │ │ 00058 │ │ │ │ │ │ R = R_DEFAULT; │ │ │ │ │ │ 00059 │ │ │ │ │ │ f = THRESHOLD_DEFAULT; │ │ │ │ │ │ 00060 │ │ │ │ │ │ npass = NPASS_DEFAULT; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.4 options.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +187 │ │ │ │ │ │ + │ │ │ │ │ │ 00061 │ │ │ │ │ │ ev_name = NULL; │ │ │ │ │ │ 00062 │ │ │ │ │ │ SM_var = SM_DEFAULT; │ │ │ │ │ │ 00063 } │ │ │ │ │ │ 00064 │ │ │ │ │ │ 00065 │ │ │ │ │ │ @@ -12716,55 +13554,41 @@ │ │ │ │ │ │ 00107 │ │ │ │ │ │ // retreive options │ │ │ │ │ │ 00108 │ │ │ │ │ │ opt_param = getopt_long(argc, argv, "hvqN:R:f:p:n:e:s:", │ │ │ │ │ │ 00109 │ │ │ │ │ │ siscone_options, &option_index); │ │ │ │ │ │ 00110 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -181 │ │ │ │ │ │ - │ │ │ │ │ │ -$// │ │ │ │ │ │ -$// │ │ │ │ │ │ - │ │ │ │ │ │ - 182 │ │ │ │ │ │ - │ │ │ │ │ │ 00111 │ │ │ │ │ │ +// Detect the end of the options. │ │ │ │ │ │ 00112 │ │ │ │ │ │ +if (opt_param == -1) │ │ │ │ │ │ 00113 │ │ │ │ │ │ +stop=true; │ │ │ │ │ │ 00114 │ │ │ │ │ │ 00115 │ │ │ │ │ │ -00116 │ │ │ │ │ │ -00117 │ │ │ │ │ │ -00118 │ │ │ │ │ │ -00119 │ │ │ │ │ │ -00120 │ │ │ │ │ │ -00121 │ │ │ │ │ │ -00122 │ │ │ │ │ │ -00123 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -// Detect the end of the options. │ │ │ │ │ │ -if (opt_param == -1) │ │ │ │ │ │ -stop=true; │ │ │ │ │ │ - │ │ │ │ │ │ // branch according to ’opt_param’ │ │ │ │ │ │ +00116 │ │ │ │ │ │ switch (opt_param){ │ │ │ │ │ │ +00117 │ │ │ │ │ │ case ’h’: help_flag = 1; │ │ │ │ │ │ break; // help │ │ │ │ │ │ +00118 │ │ │ │ │ │ case ’v’: verbose_flag = 1; │ │ │ │ │ │ break; // verbose │ │ │ │ │ │ +00119 │ │ │ │ │ │ case ’q’: verbose_flag = 0; │ │ │ │ │ │ break; // quiet │ │ │ │ │ │ +00120 │ │ │ │ │ │ case ’N’: // max number of paprticles │ │ │ │ │ │ +00121 │ │ │ │ │ │ sscanf(optarg, "%d", &N_stop); │ │ │ │ │ │ +00122 │ │ │ │ │ │ if (N_stop<=0){ │ │ │ │ │ │ +00123 │ │ │ │ │ │ cout « "Warning: the specified number of particles must be positive. Using default one" « │ │ │ │ │ │ endl; │ │ │ │ │ │ 00124 │ │ │ │ │ │ N_stop = N_DEFAULT; │ │ │ │ │ │ 00125 │ │ │ │ │ │ } │ │ │ │ │ │ 00126 │ │ │ │ │ │ @@ -12804,25 +13628,33 @@ │ │ │ │ │ │ sscanf(optarg, "%lf", &ptmin); │ │ │ │ │ │ 00143 │ │ │ │ │ │ if (ptmin<0){ │ │ │ │ │ │ 00144 │ │ │ │ │ │ cout « "Warning: the specified minimal pT must be non-negative. Using default one" « endl; │ │ │ │ │ │ 00145 │ │ │ │ │ │ ptmin = PTMIN_DEFAULT; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 188 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00146 │ │ │ │ │ │ -} │ │ │ │ │ │ 00147 │ │ │ │ │ │ -break; │ │ │ │ │ │ 00148 │ │ │ │ │ │ -case ’n’: // max number of paprticles │ │ │ │ │ │ 00149 │ │ │ │ │ │ -sscanf(optarg, "%d", &npass); │ │ │ │ │ │ 00150 │ │ │ │ │ │ -if (npass<0){ │ │ │ │ │ │ 00151 │ │ │ │ │ │ + │ │ │ │ │ │ +} │ │ │ │ │ │ +break; │ │ │ │ │ │ +case ’n’: // max number of paprticles │ │ │ │ │ │ +sscanf(optarg, "%d", &npass); │ │ │ │ │ │ +if (npass<0){ │ │ │ │ │ │ cout « "Warning: the specified number of passes must be non negative. Using default one" « │ │ │ │ │ │ endl; │ │ │ │ │ │ 00152 │ │ │ │ │ │ npass = NPASS_DEFAULT; │ │ │ │ │ │ 00153 │ │ │ │ │ │ } │ │ │ │ │ │ 00154 │ │ │ │ │ │ @@ -12901,21 +13733,14 @@ │ │ │ │ │ │ 00190 │ │ │ │ │ │ } while (!stop); │ │ │ │ │ │ 00191 │ │ │ │ │ │ 00192 │ │ │ │ │ │ if (ev_name==NULL){ │ │ │ │ │ │ 00193 │ │ │ │ │ │ ev_name = new char[strlen(DEFAULT_EVENT)+1]; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.3 options.h │ │ │ │ │ │ - │ │ │ │ │ │ -183 │ │ │ │ │ │ - │ │ │ │ │ │ 00194 │ │ │ │ │ │ strcpy(ev_name, DEFAULT_EVENT); │ │ │ │ │ │ 00195 │ │ │ │ │ │ } │ │ │ │ │ │ 00196 │ │ │ │ │ │ 00197 │ │ │ │ │ │ return 0; │ │ │ │ │ │ @@ -12973,14 +13798,19 @@ │ │ │ │ │ │ cout « endl; │ │ │ │ │ │ 00223 │ │ │ │ │ │ 00224 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00225 } │ │ │ │ │ │ 00226 │ │ │ │ │ │ 00227 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.5 options.h │ │ │ │ │ │ + │ │ │ │ │ │ 00228 // print program version │ │ │ │ │ │ 00229 //----------------------00230 int Coptions::print_version(){ │ │ │ │ │ │ 00231 │ │ │ │ │ │ cout « siscone_package_name() « " " « siscone_version() « endl; │ │ │ │ │ │ 00232 │ │ │ │ │ │ cout « "Copyright (C) 2006." « endl; │ │ │ │ │ │ 00233 │ │ │ │ │ │ @@ -12998,15 +13828,15 @@ │ │ │ │ │ │ 00239 │ │ │ │ │ │ cout « "Please send bugs or comments to AUTHORS" « endl; │ │ │ │ │ │ 00240 │ │ │ │ │ │ 00241 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00242 } │ │ │ │ │ │ │ │ │ │ │ │ -5.3 │ │ │ │ │ │ +5.5 │ │ │ │ │ │ │ │ │ │ │ │ options.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: options.h │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: management of the cmdline options of the main program │ │ │ │ │ │ @@ -13052,21 +13882,14 @@ │ │ │ │ │ │ $// │ │ │ │ │ │ 00024 // $Date:: 2007-10-03 19:21:19 +0200 (Wed, 03 Oct 2007) │ │ │ │ │ │ $// │ │ │ │ │ │ 00026 │ │ │ │ │ │ 00027 #ifndef __OPTIONS_H__ │ │ │ │ │ │ 00028 #define __OPTIONS_H__ │ │ │ │ │ │ 00029 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 184 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00030 #include "siscone/siscone.h" │ │ │ │ │ │ 00031 │ │ │ │ │ │ 00037 class Coptions{ │ │ │ │ │ │ 00038 public: │ │ │ │ │ │ 00040 │ │ │ │ │ │ Coptions(); │ │ │ │ │ │ 00041 │ │ │ │ │ │ @@ -13108,19 +13931,28 @@ │ │ │ │ │ │ 00069 │ │ │ │ │ │ 00071 │ │ │ │ │ │ siscone::Esplit_merge_scale SM_var; │ │ │ │ │ │ 00072 }; │ │ │ │ │ │ 00073 │ │ │ │ │ │ 00074 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.4 │ │ │ │ │ │ +5.6 │ │ │ │ │ │ │ │ │ │ │ │ sample.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +189 │ │ │ │ │ │ + │ │ │ │ │ │ + 190 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00002 // File: sample.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: example program for the Csiscone class (see documentation) │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ @@ -13200,115 +14032,116 @@ │ │ │ │ │ │ 00047 │ │ │ │ │ │ 00048 │ │ │ │ │ │ // read particles │ │ │ │ │ │ 00049 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00050 │ │ │ │ │ │ flux = fopen("events/single-event.dat", "r"); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.5 spherical.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00051 │ │ │ │ │ │ +if (flux==NULL){ │ │ │ │ │ │ 00052 │ │ │ │ │ │ +cerr « "cannot read event" « endl; │ │ │ │ │ │ 00053 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00054 │ │ │ │ │ │ +} │ │ │ │ │ │ 00055 │ │ │ │ │ │ 00056 │ │ │ │ │ │ +N=0; │ │ │ │ │ │ 00057 │ │ │ │ │ │ +while (fgets(fline, 512, flux)!=NULL){ │ │ │ │ │ │ 00058 │ │ │ │ │ │ +if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ 00059 │ │ │ │ │ │ +if (sscanf(fline, "%le%le%le%le", &px, &py, &pz, &E)==4){ │ │ │ │ │ │ 00060 │ │ │ │ │ │ +particles.push_back(Cmomentum(px, py, pz, E)); │ │ │ │ │ │ 00061 │ │ │ │ │ │ +N++; │ │ │ │ │ │ 00062 │ │ │ │ │ │ +} else { │ │ │ │ │ │ 00063 │ │ │ │ │ │ +cout « "error in reading event file Giving up." « endl; │ │ │ │ │ │ 00064 │ │ │ │ │ │ +fclose(flux); │ │ │ │ │ │ 00065 │ │ │ │ │ │ +return 2; │ │ │ │ │ │ 00066 │ │ │ │ │ │ +} │ │ │ │ │ │ 00067 │ │ │ │ │ │ +} │ │ │ │ │ │ 00068 │ │ │ │ │ │ +} │ │ │ │ │ │ 00069 │ │ │ │ │ │ +fclose(flux); │ │ │ │ │ │ 00070 │ │ │ │ │ │ 00071 │ │ │ │ │ │ +// compute jets │ │ │ │ │ │ 00072 │ │ │ │ │ │ +// first compute with multiple passes (default) │ │ │ │ │ │ 00073 │ │ │ │ │ │ +i=siscone.compute_jets(particles, R, f); │ │ │ │ │ │ 00074 │ │ │ │ │ │ +cout « " " « i « " jets found in multi-pass run" « endl; │ │ │ │ │ │ 00075 │ │ │ │ │ │ 00076 │ │ │ │ │ │ +// then, recompute it with a different f │ │ │ │ │ │ 00077 │ │ │ │ │ │ +i=siscone.recompute_jets(f_alt); │ │ │ │ │ │ 00078 │ │ │ │ │ │ +cout « " " « i « " jets found with alternative f" « endl; │ │ │ │ │ │ 00079 │ │ │ │ │ │ 00080 │ │ │ │ │ │ +// one pass │ │ │ │ │ │ 00081 │ │ │ │ │ │ +i=siscone.compute_jets(particles, R, f, 1); │ │ │ │ │ │ 00082 │ │ │ │ │ │ +cout « " " « i « " jets found in single-pass run" « endl; │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00084 │ │ │ │ │ │ -00085 │ │ │ │ │ │ -00086 │ │ │ │ │ │ -00087 │ │ │ │ │ │ - │ │ │ │ │ │ -if (flux==NULL){ │ │ │ │ │ │ -cerr « "cannot read event" « endl; │ │ │ │ │ │ -return 1; │ │ │ │ │ │ -} │ │ │ │ │ │ -N=0; │ │ │ │ │ │ -while (fgets(fline, 512, flux)!=NULL){ │ │ │ │ │ │ -if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ -if (sscanf(fline, "%le%le%le%le", &px, &py, &pz, &E)==4){ │ │ │ │ │ │ -particles.push_back(Cmomentum(px, py, pz, E)); │ │ │ │ │ │ -N++; │ │ │ │ │ │ -} else { │ │ │ │ │ │ -cout « "error in reading event file Giving up." « endl; │ │ │ │ │ │ -fclose(flux); │ │ │ │ │ │ -return 2; │ │ │ │ │ │ -} │ │ │ │ │ │ -} │ │ │ │ │ │ -} │ │ │ │ │ │ -fclose(flux); │ │ │ │ │ │ -// compute jets │ │ │ │ │ │ -// first compute with multiple passes (default) │ │ │ │ │ │ -i=siscone.compute_jets(particles, R, f); │ │ │ │ │ │ -cout « " " « i « " jets found in multi-pass run" « endl; │ │ │ │ │ │ -// then, recompute it with a different f │ │ │ │ │ │ -i=siscone.recompute_jets(f_alt); │ │ │ │ │ │ -cout « " " « i « " jets found with alternative f" « endl; │ │ │ │ │ │ -// one pass │ │ │ │ │ │ -i=siscone.compute_jets(particles, R, f, 1); │ │ │ │ │ │ -cout « " " « i « " jets found in single-pass run" « endl; │ │ │ │ │ │ - │ │ │ │ │ │ // show jets │ │ │ │ │ │ +00085 │ │ │ │ │ │ vector::iterator it_j; │ │ │ │ │ │ +00086 │ │ │ │ │ │ int i1; │ │ │ │ │ │ +00087 │ │ │ │ │ │ fprintf(stdout, "# │ │ │ │ │ │ pT │ │ │ │ │ │ eta │ │ │ │ │ │ phi │ │ │ │ │ │ px │ │ │ │ │ │ py │ │ │ │ │ │ \n"); │ │ │ │ │ │ 00088 │ │ │ │ │ │ for (it_j = siscone.jets.begin(), i1=0 ; │ │ │ │ │ │ + │ │ │ │ │ │ +pz │ │ │ │ │ │ + │ │ │ │ │ │ +E │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.7 spherical.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00089 │ │ │ │ │ │ -it_j != siscone.jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00090 │ │ │ │ │ │ -fprintf(stdout, "Jet %3d: %10.3f %8.3f %8.3f %10.3f %10.3f %10.3f %10.3f\n", │ │ │ │ │ │ 00091 │ │ │ │ │ │ + │ │ │ │ │ │ +it_j != siscone.jets.end() ; it_j++, i1++){ │ │ │ │ │ │ +fprintf(stdout, "Jet %3d: %10.3f %8.3f %8.3f %10.3f %10.3f %10.3f %10.3f\n", │ │ │ │ │ │ i1, it_j->v.perp(), it_j->v.eta, it_j->v.phi, it_j->v.px, it_j->v.py, │ │ │ │ │ │ it_j->v.E); │ │ │ │ │ │ 00092 │ │ │ │ │ │ } │ │ │ │ │ │ 00093 │ │ │ │ │ │ 00094 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00095 } │ │ │ │ │ │ │ │ │ │ │ │ -5.5 │ │ │ │ │ │ - │ │ │ │ │ │ -185 │ │ │ │ │ │ +5.7 │ │ │ │ │ │ │ │ │ │ │ │ spherical.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: spherical.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: example program for the CSphsiscone class (spherical SISCone)// │ │ │ │ │ │ @@ -13361,27 +14194,14 @@ │ │ │ │ │ │ 00028 │ │ │ │ │ │ 00029 #include │ │ │ │ │ │ 00030 #include │ │ │ │ │ │ 00031 #include │ │ │ │ │ │ 00032 #include "siscone/spherical/momentum.h" │ │ │ │ │ │ 00033 #include "siscone/spherical/siscone.h" │ │ │ │ │ │ 00034 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -pz │ │ │ │ │ │ - │ │ │ │ │ │ -it_j->v.pz, │ │ │ │ │ │ - │ │ │ │ │ │ -E │ │ │ │ │ │ - │ │ │ │ │ │ - 186 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00035 #define R │ │ │ │ │ │ 0.7 │ │ │ │ │ │ 00036 #define f │ │ │ │ │ │ 0.5 │ │ │ │ │ │ 00037 #define f_alt 0.75 │ │ │ │ │ │ 00038 │ │ │ │ │ │ 00039 using namespace std; │ │ │ │ │ │ @@ -13448,14 +14268,25 @@ │ │ │ │ │ │ 00070 │ │ │ │ │ │ } │ │ │ │ │ │ 00071 │ │ │ │ │ │ fclose(flux); │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 │ │ │ │ │ │ // compute jets │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +191 │ │ │ │ │ │ + │ │ │ │ │ │ +it_j->v.pz, │ │ │ │ │ │ + │ │ │ │ │ │ + 192 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00074 │ │ │ │ │ │ // first compute with multiple passes (default) │ │ │ │ │ │ 00075 │ │ │ │ │ │ i=siscone.compute_jets(particles, R, f); │ │ │ │ │ │ 00076 │ │ │ │ │ │ cout « " " « i « " jets found in multi-pass run" « endl; │ │ │ │ │ │ 00077 │ │ │ │ │ │ @@ -13497,67 +14328,58 @@ │ │ │ │ │ │ 00094 │ │ │ │ │ │ } │ │ │ │ │ │ 00095 │ │ │ │ │ │ 00096 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00097 } │ │ │ │ │ │ │ │ │ │ │ │ -5.6 │ │ │ │ │ │ +5.8 │ │ │ │ │ │ │ │ │ │ │ │ E │ │ │ │ │ │ │ │ │ │ │ │ \n"); │ │ │ │ │ │ │ │ │ │ │ │ it_j->v.E); │ │ │ │ │ │ │ │ │ │ │ │ test.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: test.cpp │ │ │ │ │ │ -00003 // Description: example program that implements tests with random particles │ │ │ │ │ │ +// │ │ │ │ │ │ +00003 // Description: example program that implements tests with random particles // │ │ │ │ │ │ 00004 // │ │ │ │ │ │ and output various informations │ │ │ │ │ │ +// │ │ │ │ │ │ 00005 // │ │ │ │ │ │ +// │ │ │ │ │ │ 00006 // Note: for a usage example of SISCone, we advise looking at main.cpp │ │ │ │ │ │ +// │ │ │ │ │ │ 00007 // │ │ │ │ │ │ or http://projects.hepforge.org/siscone/usage.html │ │ │ │ │ │ -00008 // │ │ │ │ │ │ -00009 // This file is part of the SISCone project. │ │ │ │ │ │ -00010 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -00011 // │ │ │ │ │ │ -00012 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00013 // │ │ │ │ │ │ -00014 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -00015 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -00016 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -00017 // (at your option) any later version. │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ // │ │ │ │ │ │ +00008 // │ │ │ │ │ │ // │ │ │ │ │ │ +00009 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ +00010 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ +00011 // │ │ │ │ │ │ // │ │ │ │ │ │ +00012 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ +00013 // │ │ │ │ │ │ // │ │ │ │ │ │ +00014 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ +00015 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ +00016 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ +00017 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.6 test.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -187 │ │ │ │ │ │ - │ │ │ │ │ │ 00018 // │ │ │ │ │ │ // │ │ │ │ │ │ 00019 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ @@ -13608,14 +14430,21 @@ │ │ │ │ │ │ unsigned int N; │ │ │ │ │ │ 00054 │ │ │ │ │ │ 00055 │ │ │ │ │ │ unsigned int i; │ │ │ │ │ │ 00056 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00057 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.9 times.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +193 │ │ │ │ │ │ + │ │ │ │ │ │ 00058 │ │ │ │ │ │ if (argc==1){ │ │ │ │ │ │ 00059 │ │ │ │ │ │ //cout « "using default number of particles" « endl; │ │ │ │ │ │ 00060 │ │ │ │ │ │ N = N_default; │ │ │ │ │ │ 00061 │ │ │ │ │ │ @@ -13693,21 +14522,14 @@ │ │ │ │ │ │ cout « "save stable cone results:" « endl; │ │ │ │ │ │ 00102 │ │ │ │ │ │ unsigned int pass; │ │ │ │ │ │ 00103 │ │ │ │ │ │ flux = fopen("protocones.dat", "w+"); │ │ │ │ │ │ 00104 │ │ │ │ │ │ for (pass=0;pass particles; │ │ │ │ │ │ 00066 │ │ │ │ │ │ Csiscone siscone; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.8 area.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00067 │ │ │ │ │ │ double eta,phi; │ │ │ │ │ │ 00068 │ │ │ │ │ │ 00069 │ │ │ │ │ │ // number of events and particles │ │ │ │ │ │ 00070 │ │ │ │ │ │ int i, N; │ │ │ │ │ │ @@ -13908,14 +14733,19 @@ │ │ │ │ │ │ 00102 │ │ │ │ │ │ 00103 │ │ │ │ │ │ // run siscone │ │ │ │ │ │ 00104 │ │ │ │ │ │ gettimeofday(&time_start, NULL); │ │ │ │ │ │ 00105 │ │ │ │ │ │ siscone.compute_jets(particles, R, f); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.10 area.h │ │ │ │ │ │ + │ │ │ │ │ │ 00106 │ │ │ │ │ │ gettimeofday(&time_end, NULL); │ │ │ │ │ │ 00107 │ │ │ │ │ │ time_siscone+=time_spent(); │ │ │ │ │ │ 00108 │ │ │ │ │ │ } │ │ │ │ │ │ 00109 │ │ │ │ │ │ @@ -13941,856 +14771,14 @@ │ │ │ │ │ │ 00121 │ │ │ │ │ │ cout « "bye..." « endl; │ │ │ │ │ │ 00122 │ │ │ │ │ │ 00123 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00124 } │ │ │ │ │ │ │ │ │ │ │ │ -5.8 │ │ │ │ │ │ - │ │ │ │ │ │ -area.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00001 │ │ │ │ │ │ -00002 // File: main.cpp │ │ │ │ │ │ -// │ │ │ │ │ │ -00003 // Description: main program that runs siscone from the command line │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00022 // │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -189 │ │ │ │ │ │ - │ │ │ │ │ │ - 190 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00023 // $Revision:: 171 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00024 // $Date:: 2007-06-19 10:26:05 -0400 (Tue, 19 Jun 2007) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00026 │ │ │ │ │ │ -00027 #include │ │ │ │ │ │ -00028 #include │ │ │ │ │ │ -00029 #include │ │ │ │ │ │ -00030 #include "siscone/momentum.h" │ │ │ │ │ │ -00031 #include "siscone/siscone.h" │ │ │ │ │ │ -00032 #include "siscone/area.h" │ │ │ │ │ │ -00033 #include "options.h" │ │ │ │ │ │ -00034 │ │ │ │ │ │ -00035 using namespace std; │ │ │ │ │ │ -00036 using namespace siscone; │ │ │ │ │ │ -00037 │ │ │ │ │ │ -00038 int main(int argc, char *argv[]){ │ │ │ │ │ │ -00039 │ │ │ │ │ │ -vector particles; │ │ │ │ │ │ -00040 │ │ │ │ │ │ -Carea siscone_with_area; │ │ │ │ │ │ -00041 │ │ │ │ │ │ -int i,N; │ │ │ │ │ │ -00042 │ │ │ │ │ │ -double px,py,pz,E; │ │ │ │ │ │ -00043 │ │ │ │ │ │ -Coptions opts; │ │ │ │ │ │ -00044 │ │ │ │ │ │ -char fline[512]; │ │ │ │ │ │ -00045 │ │ │ │ │ │ -00046 │ │ │ │ │ │ -if (opts.parse_options(argc, argv)) │ │ │ │ │ │ -00047 │ │ │ │ │ │ -exit(1); │ │ │ │ │ │ -00048 │ │ │ │ │ │ -00049 │ │ │ │ │ │ -// deal with help message │ │ │ │ │ │ -00050 │ │ │ │ │ │ -if (opts.help_flag){ │ │ │ │ │ │ -00051 │ │ │ │ │ │ -opts.print_help(); │ │ │ │ │ │ -00052 │ │ │ │ │ │ -exit(0); │ │ │ │ │ │ -00053 │ │ │ │ │ │ -} │ │ │ │ │ │ -00054 │ │ │ │ │ │ -00055 │ │ │ │ │ │ -// deal with version flag │ │ │ │ │ │ -00056 │ │ │ │ │ │ -if (opts.version_flag){ │ │ │ │ │ │ -00057 │ │ │ │ │ │ -opts.print_version(); │ │ │ │ │ │ -00058 │ │ │ │ │ │ -exit(0); │ │ │ │ │ │ -00059 │ │ │ │ │ │ -} │ │ │ │ │ │ -00060 │ │ │ │ │ │ -00061 │ │ │ │ │ │ -// various files used to read input data and store results │ │ │ │ │ │ -00062 │ │ │ │ │ │ -FILE *flux; │ │ │ │ │ │ -00063 │ │ │ │ │ │ -FILE *fpart; │ │ │ │ │ │ -00064 │ │ │ │ │ │ -00065 │ │ │ │ │ │ -// read particles │ │ │ │ │ │ -00066 │ │ │ │ │ │ -if (opts.verbose_flag) cout « "reading particles" « endl; │ │ │ │ │ │ -00067 │ │ │ │ │ │ -flux = fopen(opts.ev_name, "r"); │ │ │ │ │ │ -00068 │ │ │ │ │ │ -if (flux==NULL){ │ │ │ │ │ │ -00069 │ │ │ │ │ │ -cerr « "cannot read event" « endl; │ │ │ │ │ │ -00070 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ -00071 │ │ │ │ │ │ -} │ │ │ │ │ │ -00072 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -N=0; │ │ │ │ │ │ -00074 │ │ │ │ │ │ -fpart = fopen("particles.dat", "w+"); │ │ │ │ │ │ -00075 │ │ │ │ │ │ -while ((opts.N_stop!=0) && (fgets(fline, 512, flux)!=NULL)){ │ │ │ │ │ │ -00076 │ │ │ │ │ │ -if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ -00077 │ │ │ │ │ │ -if (sscanf(fline, "%le%le%le%le", &px, &py, &pz, &E)==4){ │ │ │ │ │ │ -00078 │ │ │ │ │ │ -particles.push_back(Cmomentum(px, py, pz, E)); │ │ │ │ │ │ -00079 │ │ │ │ │ │ -fprintf(fpart, "%e\t%e\n", │ │ │ │ │ │ -particles[N].eta, particles[N].phi); │ │ │ │ │ │ -00080 │ │ │ │ │ │ -N++; │ │ │ │ │ │ -00081 │ │ │ │ │ │ -opts.N_stop--; │ │ │ │ │ │ -00082 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00083 │ │ │ │ │ │ -cout « "error in reading event file Giving up." « endl; │ │ │ │ │ │ -00084 │ │ │ │ │ │ -fclose(flux); │ │ │ │ │ │ -00085 │ │ │ │ │ │ -fclose(fpart); │ │ │ │ │ │ -00086 │ │ │ │ │ │ -exit(2); │ │ │ │ │ │ -00087 │ │ │ │ │ │ -} │ │ │ │ │ │ -00088 │ │ │ │ │ │ -} │ │ │ │ │ │ -00089 │ │ │ │ │ │ -} │ │ │ │ │ │ -00090 │ │ │ │ │ │ -fclose(flux); │ │ │ │ │ │ -00091 │ │ │ │ │ │ -fclose(fpart); │ │ │ │ │ │ -00092 │ │ │ │ │ │ -if (opts.verbose_flag) │ │ │ │ │ │ -00093 │ │ │ │ │ │ -cout « " working with " « N « " particles" « endl; │ │ │ │ │ │ -00094 │ │ │ │ │ │ -00095 │ │ │ │ │ │ -// compute jets │ │ │ │ │ │ -00096 │ │ │ │ │ │ -if (opts.verbose_flag) cout « "computing jet contents" « endl; │ │ │ │ │ │ -00097 │ │ │ │ │ │ -i=siscone_with_area.compute_areas(particles, opts.R, opts.f, opts.npass, opts.SM_var); │ │ │ │ │ │ -00098 │ │ │ │ │ │ -if (opts.verbose_flag){ │ │ │ │ │ │ -00099 │ │ │ │ │ │ -unsigned int pass; │ │ │ │ │ │ -00100 │ │ │ │ │ │ -for (pass=0;pass::iterator ja; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.9 area.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00111 │ │ │ │ │ │ -for (ja=siscone_with_area.jet_areas.begin();ja!=siscone_with_area.jet_areas.end();ja++){ │ │ │ │ │ │ -00112 │ │ │ │ │ │ -fprintf(flux, "%e\t%e\t%e\t%e\t%e\n", │ │ │ │ │ │ -00113 │ │ │ │ │ │ -ja->v.perp(), ja->v.eta, ja->v.phi, │ │ │ │ │ │ -00114 │ │ │ │ │ │ -ja->active_area, ja->passive_area); │ │ │ │ │ │ -00115 │ │ │ │ │ │ -} │ │ │ │ │ │ -00116 │ │ │ │ │ │ -00117 │ │ │ │ │ │ -fclose(flux); │ │ │ │ │ │ -00118 │ │ │ │ │ │ -00119 │ │ │ │ │ │ -if (opts.verbose_flag) │ │ │ │ │ │ -00120 │ │ │ │ │ │ -cout « "bye..." « endl; │ │ │ │ │ │ -00121 │ │ │ │ │ │ -00122 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00123 } │ │ │ │ │ │ - │ │ │ │ │ │ -5.9 │ │ │ │ │ │ - │ │ │ │ │ │ -area.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: area.h │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // Description: header file for the computation of jet area │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00023 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // $Revision:: 149 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00025 // $Date:: 2007-03-15 00:13:58 +0100 (Thu, 15 Mar 2007) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 │ │ │ │ │ │ -00028 #include "area.h" │ │ │ │ │ │ -00029 #include "momentum.h" │ │ │ │ │ │ -00030 #include │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 namespace siscone{ │ │ │ │ │ │ -00034 using namespace std; │ │ │ │ │ │ -00035 │ │ │ │ │ │ -00036 /******************************************************* │ │ │ │ │ │ -00037 * Cjet_area implementation │ │ │ │ │ │ -* │ │ │ │ │ │ -00038 * real Jet information, including its area(s) │ │ │ │ │ │ -* │ │ │ │ │ │ -00039 * │ │ │ │ │ │ -* │ │ │ │ │ │ -00040 * This class contains information for one single jet. * │ │ │ │ │ │ -00041 * That is, first, its momentum carrying information │ │ │ │ │ │ -* │ │ │ │ │ │ -00042 * about its centre and pT, and second, its particle │ │ │ │ │ │ -* │ │ │ │ │ │ -00043 * contents (from CJeT). │ │ │ │ │ │ -* │ │ │ │ │ │ -00044 * Compared to the Cjet class, it also includes the │ │ │ │ │ │ -* │ │ │ │ │ │ -00045 * passive and active areas of the jet computed using * │ │ │ │ │ │ -00046 * the Carea class. │ │ │ │ │ │ -* │ │ │ │ │ │ -00047 *******************************************************/ │ │ │ │ │ │ -00048 │ │ │ │ │ │ -00049 // default ctor │ │ │ │ │ │ -00050 //-------------00051 Cjet_area::Cjet_area(){ │ │ │ │ │ │ -00052 │ │ │ │ │ │ -active_area = passive_area = 0.0; │ │ │ │ │ │ -00053 } │ │ │ │ │ │ -00054 │ │ │ │ │ │ -00055 // jet-initiated ctor │ │ │ │ │ │ -00056 //------------------00057 Cjet_area::Cjet_area(Cjet &j){ │ │ │ │ │ │ -00058 │ │ │ │ │ │ -v = j.v; │ │ │ │ │ │ -00059 │ │ │ │ │ │ -n = j.n; │ │ │ │ │ │ -00060 │ │ │ │ │ │ -contents = j.contents; │ │ │ │ │ │ -00061 │ │ │ │ │ │ -00062 │ │ │ │ │ │ -pass = j.pass; │ │ │ │ │ │ -00063 │ │ │ │ │ │ -00064 │ │ │ │ │ │ -pt_tilde = j.pt_tilde; │ │ │ │ │ │ -00065 │ │ │ │ │ │ -sm_var2 = j.sm_var2; │ │ │ │ │ │ -00066 │ │ │ │ │ │ -00067 │ │ │ │ │ │ -active_area = passive_area = 0.0; │ │ │ │ │ │ -00068 } │ │ │ │ │ │ -00069 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -191 │ │ │ │ │ │ - │ │ │ │ │ │ - 192 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00070 // default dtor │ │ │ │ │ │ -00071 //-------------00072 Cjet_area::~Cjet_area(){ │ │ │ │ │ │ -00073 │ │ │ │ │ │ -00074 } │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -00077 /****************************************************************** │ │ │ │ │ │ -00078 * Csiscone_area implementation │ │ │ │ │ │ -* │ │ │ │ │ │ -00079 * class for the computation of jet areas. │ │ │ │ │ │ -* │ │ │ │ │ │ -00080 * │ │ │ │ │ │ -* │ │ │ │ │ │ -00081 * This is the class user should use whenever you want to compute * │ │ │ │ │ │ -00082 * the jet area (passive and active). │ │ │ │ │ │ -* │ │ │ │ │ │ -00083 * It uses the SISCone algorithm to perform the jet analysis. │ │ │ │ │ │ -* │ │ │ │ │ │ -00084 ******************************************************************/ │ │ │ │ │ │ -00085 │ │ │ │ │ │ -00086 // default ctor │ │ │ │ │ │ -00087 //------------00088 Carea::Carea(){ │ │ │ │ │ │ -00089 │ │ │ │ │ │ -grid_size = 60; │ │ │ │ │ │ -// 3600 particles added │ │ │ │ │ │ -00090 │ │ │ │ │ │ -grid_eta_max = 6.0; // maybe having twice more points in eta than in phi should be nice │ │ │ │ │ │ -00091 │ │ │ │ │ │ -grid_shift = 0.5; │ │ │ │ │ │ -// 50% "shacking" │ │ │ │ │ │ -00092 │ │ │ │ │ │ -00093 │ │ │ │ │ │ -pt_soft = 1e-100; │ │ │ │ │ │ -00094 │ │ │ │ │ │ -pt_shift = 0.05; │ │ │ │ │ │ -00095 │ │ │ │ │ │ -pt_soft_min = 1e-90; │ │ │ │ │ │ -00096 } │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00098 // default dtor │ │ │ │ │ │ -00099 //------------00100 Carea::~Carea(){ │ │ │ │ │ │ -00101 │ │ │ │ │ │ -00102 } │ │ │ │ │ │ -00103 │ │ │ │ │ │ -00104 /* │ │ │ │ │ │ -00105 * compute the jet areas from a given particle set. │ │ │ │ │ │ -00106 * The parameters of this method are the ones which control the jet clustering alghorithm. │ │ │ │ │ │ -00107 * Note that the pt_min is not allowed here soince the jet-area determination involves soft │ │ │ │ │ │ -00108 * particles/jets and thus is used internally. │ │ │ │ │ │ -00109 * - _particles │ │ │ │ │ │ -list of particles │ │ │ │ │ │ -00110 * - _radius │ │ │ │ │ │ -cone radius │ │ │ │ │ │ -00111 * - _f │ │ │ │ │ │ -shared energy threshold for splitting&merging │ │ │ │ │ │ -00112 * - _n_pass_max maximum number of passes (0=full search, the default) │ │ │ │ │ │ -00113 * - _split_merge_scale │ │ │ │ │ │ -the scale choice for the split-merge procedure │ │ │ │ │ │ -00114 * │ │ │ │ │ │ -NOTE: SM_pt leads to IR unsafety for some events with momentum conservation. │ │ │ │ │ │ -00115 * │ │ │ │ │ │ -SM_Et is IR safe but not boost invariant and not implemented(!) │ │ │ │ │ │ -00116 * │ │ │ │ │ │ -SM_mt is IR safe for hadronic events, but not for decays of two │ │ │ │ │ │ -00117 * │ │ │ │ │ │ -back-to-back particles of identical mass │ │ │ │ │ │ -00118 * │ │ │ │ │ │ -SM_pttilde │ │ │ │ │ │ -00119 * │ │ │ │ │ │ -is always IR safe, and also boost invariant (default) │ │ │ │ │ │ -00120 * - _hard_only │ │ │ │ │ │ -when this is set on, only hard jets are computed │ │ │ │ │ │ -00121 * │ │ │ │ │ │ -and not the purely ghosted jets (default: false) │ │ │ │ │ │ -00122 * return the jets together with their areas │ │ │ │ │ │ -00123 * The return value is the number of jets (including pure-ghost ones if they are included) │ │ │ │ │ │ -00124 ********************************************************************************************/ │ │ │ │ │ │ -00125 int Carea::compute_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ -00126 │ │ │ │ │ │ -int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ -00127 │ │ │ │ │ │ -bool _hard_only){ │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00129 │ │ │ │ │ │ -vector all_particles; │ │ │ │ │ │ -00130 │ │ │ │ │ │ -00131 │ │ │ │ │ │ -// put "hardest cut-off" if needed │ │ │ │ │ │ -00132 │ │ │ │ │ │ -// this avoids computation of ghosted jets when not required and │ │ │ │ │ │ -00133 │ │ │ │ │ │ -// significantly shortens the SM. │ │ │ │ │ │ -00134 │ │ │ │ │ │ -if (_hard_only){ │ │ │ │ │ │ -00135 │ │ │ │ │ │ -SM_var2_hardest_cut_off = pt_soft_min*pt_soft_min; │ │ │ │ │ │ -00136 │ │ │ │ │ │ -} │ │ │ │ │ │ -00137 │ │ │ │ │ │ -00138 │ │ │ │ │ │ -// clear potential previous runs │ │ │ │ │ │ -00139 │ │ │ │ │ │ -jet_areas.clear(); │ │ │ │ │ │ -00140 │ │ │ │ │ │ -00141 │ │ │ │ │ │ -// put initial set of particles in the list │ │ │ │ │ │ -00142 │ │ │ │ │ │ -int n_hard = _particles.size(); │ │ │ │ │ │ -00143 │ │ │ │ │ │ -all_particles = _particles; │ │ │ │ │ │ -00144 │ │ │ │ │ │ -00145 │ │ │ │ │ │ -// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ -00146 │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ -00147 │ │ │ │ │ │ -double eta_g,phi_g,pt_g; │ │ │ │ │ │ -00148 │ │ │ │ │ │ -00149 │ │ │ │ │ │ -for (i=0;i= n_hard │ │ │ │ │ │ -00167 │ │ │ │ │ │ -// and deduce the number of ghosts in the jet, hence the area. │ │ │ │ │ │ -00168 │ │ │ │ │ │ -double area_factor = (2.0*grid_eta_max/grid_size)*(twopi/grid_size); │ │ │ │ │ │ -00169 │ │ │ │ │ │ -00170 │ │ │ │ │ │ -for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ -00171 │ │ │ │ │ │ -jet_areas.push_back(jets[i]); │ │ │ │ │ │ -00172 │ │ │ │ │ │ -j=0; │ │ │ │ │ │ -00173 │ │ │ │ │ │ -while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ -00218 │ │ │ │ │ │ -int _n_pass_max, Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ -00219 │ │ │ │ │ │ -00220 │ │ │ │ │ │ -vector all_particles; │ │ │ │ │ │ -00221 │ │ │ │ │ │ -00222 │ │ │ │ │ │ -// in the case of passive area, we do not need │ │ │ │ │ │ -00223 │ │ │ │ │ │ -// to put the ghosts in the stable-cone search │ │ │ │ │ │ -00224 │ │ │ │ │ │ -// (they do no influence the list of stable cones) │ │ │ │ │ │ -00225 │ │ │ │ │ │ -// Here’s how it goes... │ │ │ │ │ │ -00226 │ │ │ │ │ │ -stable_cone_soft_pt2_cutoff = pt_soft_min*pt_soft_min; │ │ │ │ │ │ -00227 │ │ │ │ │ │ -00228 │ │ │ │ │ │ -// clear potential previous runs │ │ │ │ │ │ -00229 │ │ │ │ │ │ -jet_areas.clear(); │ │ │ │ │ │ -00230 │ │ │ │ │ │ -00231 │ │ │ │ │ │ -// put initial set of particles in the list │ │ │ │ │ │ -00232 │ │ │ │ │ │ -int n_hard = _particles.size(); │ │ │ │ │ │ -00233 │ │ │ │ │ │ -all_particles = _particles; │ │ │ │ │ │ -00234 │ │ │ │ │ │ -00235 │ │ │ │ │ │ -// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ -00236 │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ -00237 │ │ │ │ │ │ -double eta_g,phi_g,pt_g; │ │ │ │ │ │ -00238 │ │ │ │ │ │ -00239 │ │ │ │ │ │ -for (i=0;i= n_hard │ │ │ │ │ │ -00257 │ │ │ │ │ │ -// and deduce the number of ghosts in the jet, hence the area. │ │ │ │ │ │ -00258 │ │ │ │ │ │ -double area_factor = (2.0*grid_eta_max/grid_size)*(twopi/grid_size); │ │ │ │ │ │ -00259 │ │ │ │ │ │ -for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ -00260 │ │ │ │ │ │ -j=0; │ │ │ │ │ │ -00261 │ │ │ │ │ │ -while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ -00292 │ │ │ │ │ │ -int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ -00293 │ │ │ │ │ │ -bool _hard_only){ │ │ │ │ │ │ -00294 │ │ │ │ │ │ -00295 │ │ │ │ │ │ -vector all_particles; │ │ │ │ │ │ -00296 │ │ │ │ │ │ -00297 │ │ │ │ │ │ -// put "hardest cut-off" if needed │ │ │ │ │ │ -00298 │ │ │ │ │ │ -// this avoids computation of ghosted jets when not required and │ │ │ │ │ │ -00299 │ │ │ │ │ │ -// significantly shortens the SM. │ │ │ │ │ │ -00300 │ │ │ │ │ │ -if (_hard_only){ │ │ │ │ │ │ -00301 │ │ │ │ │ │ -SM_var2_hardest_cut_off = pt_soft_min*pt_soft_min; │ │ │ │ │ │ -00302 │ │ │ │ │ │ -} │ │ │ │ │ │ -00303 │ │ │ │ │ │ -00304 │ │ │ │ │ │ -// clear potential previous runs │ │ │ │ │ │ -00305 │ │ │ │ │ │ -jet_areas.clear(); │ │ │ │ │ │ -00306 │ │ │ │ │ │ -00307 │ │ │ │ │ │ -// put initial set of particles in the list │ │ │ │ │ │ -00308 │ │ │ │ │ │ -int n_hard = _particles.size(); │ │ │ │ │ │ -00309 │ │ │ │ │ │ -all_particles = _particles; │ │ │ │ │ │ -00310 │ │ │ │ │ │ -00311 │ │ │ │ │ │ -// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ -00312 │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ -00313 │ │ │ │ │ │ -double eta_g,phi_g,pt_g; │ │ │ │ │ │ -00314 │ │ │ │ │ │ -00315 │ │ │ │ │ │ -for (i=0;i= n_hard │ │ │ │ │ │ -00333 │ │ │ │ │ │ -// and deduce the number of ghosts in the jet, hence the area. │ │ │ │ │ │ -00334 │ │ │ │ │ │ -double area_factor = (2.0*grid_eta_max/grid_size)*(twopi/grid_size); │ │ │ │ │ │ -00335 │ │ │ │ │ │ -00336 │ │ │ │ │ │ -for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ -00337 │ │ │ │ │ │ -jet_areas.push_back(jets[i]); │ │ │ │ │ │ -00338 │ │ │ │ │ │ -j=0; │ │ │ │ │ │ -00339 │ │ │ │ │ │ -while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ 00113 │ │ │ │ │ │ int _n_pass_max=0, Esplit_merge_scale _split_merge_scale=SM_pttilde, │ │ │ │ │ │ 00114 │ │ │ │ │ │ bool _hard_only=false); │ │ │ │ │ │ +00115 │ │ │ │ │ │ +00123 │ │ │ │ │ │ +int compute_passive_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 195 │ │ │ │ │ │ │ │ │ │ │ │ 196 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00115 │ │ │ │ │ │ -00123 │ │ │ │ │ │ -int compute_passive_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ 00124 │ │ │ │ │ │ int _n_pass_max=0, Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ 00125 │ │ │ │ │ │ 00126 │ │ │ │ │ │ int grid_size; │ │ │ │ │ │ 00127 │ │ │ │ │ │ double grid_eta_max; │ │ │ │ │ │ @@ -15023,21 +15011,21 @@ │ │ │ │ │ │ 00082 │ │ │ │ │ │ bool operator!=(const circulator & other) const {return m_here != other.m_here;} │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00084 private: │ │ │ │ │ │ 00085 │ │ │ │ │ │ T m_here, m_begin, m_end; │ │ │ │ │ │ 00086 }; │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00088 } │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 5.12 config.h │ │ │ │ │ │ │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00088 } │ │ │ │ │ │ 00089 │ │ │ │ │ │ 00090 #endif // __CIRCULATOR_H__ │ │ │ │ │ │ │ │ │ │ │ │ 5.12 │ │ │ │ │ │ │ │ │ │ │ │ config.h │ │ │ │ │ │ │ │ │ │ │ │ @@ -15113,25 +15101,25 @@ │ │ │ │ │ │ 00070 #define SISCONE_PACKAGE "siscone" │ │ │ │ │ │ 00071 #endif │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 /* Define to the address where bug reports for this package should be sent. */ │ │ │ │ │ │ 00074 #ifndef SISCONE_PACKAGE_BUGREPORT │ │ │ │ │ │ 00075 #define SISCONE_PACKAGE_BUGREPORT "" │ │ │ │ │ │ 00076 #endif │ │ │ │ │ │ +00077 │ │ │ │ │ │ +00078 /* Define to the full name of this package. */ │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 197 │ │ │ │ │ │ │ │ │ │ │ │ 198 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00077 │ │ │ │ │ │ -00078 /* Define to the full name of this package. */ │ │ │ │ │ │ 00079 #ifndef SISCONE_PACKAGE_NAME │ │ │ │ │ │ 00080 #define SISCONE_PACKAGE_NAME "SISCone" │ │ │ │ │ │ 00081 #endif │ │ │ │ │ │ 00082 │ │ │ │ │ │ 00083 /* Define to the full name and version of this package. */ │ │ │ │ │ │ 00084 #ifndef SISCONE_PACKAGE_STRING │ │ │ │ │ │ 00085 #define SISCONE_PACKAGE_STRING "SISCone 3.0.5" │ │ │ │ │ │ @@ -15174,15 +15162,15 @@ │ │ │ │ │ │ 00120 /* once: _SISCONE_CONFIG_H */ │ │ │ │ │ │ 00121 #endif │ │ │ │ │ │ │ │ │ │ │ │ 5.13 │ │ │ │ │ │ │ │ │ │ │ │ config_raw.h │ │ │ │ │ │ │ │ │ │ │ │ -00001 /* siscone/config_raw.h. Generated from config.h.in by configure. │ │ │ │ │ │ +00001 /* siscone/config_raw.h. Generated from config.h.in by configure. */ │ │ │ │ │ │ 00002 /* config.h.in. Generated from configure.ac by autoheader. */ │ │ │ │ │ │ 00003 │ │ │ │ │ │ 00004 /* Define to 1 if you have the header file. */ │ │ │ │ │ │ 00005 #define HAVE_DLFCN_H 1 │ │ │ │ │ │ 00006 │ │ │ │ │ │ 00007 /* Define to 1 if you have the header file. */ │ │ │ │ │ │ 00008 #define HAVE_INTTYPES_H 1 │ │ │ │ │ │ @@ -15209,25 +15197,23 @@ │ │ │ │ │ │ 00029 #define HAVE_SYS_STAT_H 1 │ │ │ │ │ │ 00030 │ │ │ │ │ │ 00031 /* Define to 1 if you have the header file. */ │ │ │ │ │ │ 00032 #define HAVE_SYS_TYPES_H 1 │ │ │ │ │ │ 00033 │ │ │ │ │ │ 00034 /* Define to 1 if you have the header file. */ │ │ │ │ │ │ 00035 #define HAVE_UNISTD_H 1 │ │ │ │ │ │ - │ │ │ │ │ │ -*/ │ │ │ │ │ │ +00036 │ │ │ │ │ │ +00037 /* Define to the sub-directory where libtool stores uninstalled libraries. */ │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 5.14 siscone/defines.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ 199 │ │ │ │ │ │ │ │ │ │ │ │ -00036 │ │ │ │ │ │ -00037 /* Define to the sub-directory where libtool stores uninstalled libraries. */ │ │ │ │ │ │ 00038 #define LT_OBJDIR ".libs/" │ │ │ │ │ │ 00039 │ │ │ │ │ │ 00040 /* Name of package */ │ │ │ │ │ │ 00041 #define PACKAGE "siscone" │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 /* Define to the address where bug reports for this package should be sent. */ │ │ │ │ │ │ 00044 #define PACKAGE_BUGREPORT "" │ │ │ │ │ │ @@ -15575,257 +15561,20 @@ │ │ │ │ │ │ 00125 #endif │ │ │ │ │ │ 00126 │ │ │ │ │ │ 00127 #endif // __DEFINES_H__ │ │ │ │ │ │ 00128 │ │ │ │ │ │ │ │ │ │ │ │ 5.16 │ │ │ │ │ │ │ │ │ │ │ │ -hash.h │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: hash.h │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // Description: header file for classes hash_element and hash_cones │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00023 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // $Revision:: 224 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00025 // $Date:: 2008-05-16 19:58:30 +0200 (Fri, 16 May 2008) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 │ │ │ │ │ │ -00028 #ifndef __HASH_H__ │ │ │ │ │ │ -00029 #define __HASH_H__ │ │ │ │ │ │ -00030 │ │ │ │ │ │ -00031 #include "momentum.h" │ │ │ │ │ │ -00032 #include "reference.h" │ │ │ │ │ │ -00033 │ │ │ │ │ │ -00034 namespace siscone{ │ │ │ │ │ │ -00035 │ │ │ │ │ │ -00045 class hash_element{ │ │ │ │ │ │ -00046 public: │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.17 hash.h │ │ │ │ │ │ - │ │ │ │ │ │ -203 │ │ │ │ │ │ - │ │ │ │ │ │ -00047 │ │ │ │ │ │ -Creference ref; │ │ │ │ │ │ -00048 │ │ │ │ │ │ -double eta; │ │ │ │ │ │ -00049 │ │ │ │ │ │ -double phi; │ │ │ │ │ │ -00050 │ │ │ │ │ │ -bool is_stable; │ │ │ │ │ │ -00051 │ │ │ │ │ │ -00052 │ │ │ │ │ │ -hash_element *next; │ │ │ │ │ │ -00053 }; │ │ │ │ │ │ -00054 │ │ │ │ │ │ -00062 class hash_cones{ │ │ │ │ │ │ -00063 public: │ │ │ │ │ │ -00067 │ │ │ │ │ │ -hash_cones(int _Np, double _R2); │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00070 │ │ │ │ │ │ -~hash_cones(); │ │ │ │ │ │ -00071 │ │ │ │ │ │ -00081 │ │ │ │ │ │ -int insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io); │ │ │ │ │ │ -00082 │ │ │ │ │ │ -00090 │ │ │ │ │ │ -int insert(Cmomentum *v); │ │ │ │ │ │ -00091 │ │ │ │ │ │ -00093 │ │ │ │ │ │ -hash_element **hash_array; │ │ │ │ │ │ -00094 │ │ │ │ │ │ -00096 │ │ │ │ │ │ -int n_cones; │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00099 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00100 │ │ │ │ │ │ -int n_occupied_cells; │ │ │ │ │ │ -00101 #endif │ │ │ │ │ │ -00102 │ │ │ │ │ │ -00104 │ │ │ │ │ │ -int mask; │ │ │ │ │ │ -00105 │ │ │ │ │ │ -00108 │ │ │ │ │ │ -double R2; │ │ │ │ │ │ -00109 │ │ │ │ │ │ -00118 │ │ │ │ │ │ -inline bool is_inside(Cmomentum *centre, Cmomentum *v); │ │ │ │ │ │ -00119 }; │ │ │ │ │ │ -00120 │ │ │ │ │ │ -00121 } │ │ │ │ │ │ -00122 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.17 │ │ │ │ │ │ - │ │ │ │ │ │ -hash.h │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: hash.h │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // Description: header file for classes hash_element and hash_cones │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -an adaptation to spherical coordinates │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00011 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00025 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00026 // $Revision:: 294 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 // $Date:: 2009-05-01 17:15:04 +0200 (Fri, 01 May 2009) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00029 │ │ │ │ │ │ -00030 #ifndef __SPH_HASH_H__ │ │ │ │ │ │ -00031 #define __SPH_HASH_H__ │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 #include "momentum.h" │ │ │ │ │ │ -00034 │ │ │ │ │ │ -00035 namespace siscone_spherical{ │ │ │ │ │ │ -00036 │ │ │ │ │ │ -00046 class sph_hash_element{ │ │ │ │ │ │ -00047 public: │ │ │ │ │ │ -00048 │ │ │ │ │ │ -CSph3vector centre; │ │ │ │ │ │ -00049 │ │ │ │ │ │ -bool is_stable; │ │ │ │ │ │ -00050 │ │ │ │ │ │ -00051 │ │ │ │ │ │ -sph_hash_element *next; │ │ │ │ │ │ -00052 }; │ │ │ │ │ │ -00053 │ │ │ │ │ │ -00061 class sph_hash_cones{ │ │ │ │ │ │ -00062 public: │ │ │ │ │ │ -00065 │ │ │ │ │ │ -sph_hash_cones(int _Np, double _radius); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 204 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00066 │ │ │ │ │ │ -00068 │ │ │ │ │ │ -~sph_hash_cones(); │ │ │ │ │ │ -00069 │ │ │ │ │ │ -00079 │ │ │ │ │ │ -int insert(CSphmomentum *v, CSphmomentum *parent, CSphmomentum *child, bool p_io, bool c_io); │ │ │ │ │ │ -00080 │ │ │ │ │ │ -00088 │ │ │ │ │ │ -int insert(CSphmomentum *v); │ │ │ │ │ │ -00089 │ │ │ │ │ │ -00091 │ │ │ │ │ │ -sph_hash_element **hash_array; │ │ │ │ │ │ -00092 │ │ │ │ │ │ -00094 │ │ │ │ │ │ -int n_cones; │ │ │ │ │ │ -00095 │ │ │ │ │ │ -00097 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00098 │ │ │ │ │ │ -int n_occupied_cells; │ │ │ │ │ │ -00099 #endif │ │ │ │ │ │ -00100 │ │ │ │ │ │ -00102 │ │ │ │ │ │ -int mask; │ │ │ │ │ │ -00103 │ │ │ │ │ │ -00106 │ │ │ │ │ │ -double R2; │ │ │ │ │ │ -00107 │ │ │ │ │ │ -00109 │ │ │ │ │ │ -double tan2R; │ │ │ │ │ │ -00110 }; │ │ │ │ │ │ -00111 │ │ │ │ │ │ -00112 } │ │ │ │ │ │ -00113 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.18 │ │ │ │ │ │ - │ │ │ │ │ │ -momentum.cpp │ │ │ │ │ │ +protocones.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ -00002 // File: momentum.cpp │ │ │ │ │ │ +00002 // File: protocones.cpp │ │ │ │ │ │ // │ │ │ │ │ │ -00003 // Description: source file for 4-momentum class Cmomentum │ │ │ │ │ │ +00003 // Description: source file for stable cones determination (Cstable_cones) │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // │ │ │ │ │ │ // │ │ │ │ │ │ @@ -15856,1161 +15605,2901 @@ │ │ │ │ │ │ 00019 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00022 // │ │ │ │ │ │ // │ │ │ │ │ │ -00023 // $Revision:: 123 │ │ │ │ │ │ +00023 // $Revision:: 322 │ │ │ │ │ │ $// │ │ │ │ │ │ -00024 // $Date:: 2007-03-01 02:52:16 +0100 (Thu, 01 Mar 2007) │ │ │ │ │ │ +00024 // $Date:: 2011-11-15 10:12:36 +0100 (Tue, 15 Nov 2011) │ │ │ │ │ │ $// │ │ │ │ │ │ 00026 │ │ │ │ │ │ -00027 #include "momentum.h" │ │ │ │ │ │ -00028 #include │ │ │ │ │ │ -00029 #include │ │ │ │ │ │ -00030 │ │ │ │ │ │ -00031 namespace siscone{ │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 /************************************************************************* │ │ │ │ │ │ -00034 * class Cmomentum │ │ │ │ │ │ +00027 /******************************************************* │ │ │ │ │ │ +00028 * Introductory note: │ │ │ │ │ │ * │ │ │ │ │ │ -00035 * This class contains the information for particle or group of │ │ │ │ │ │ +00029 * Since this file has many member functions, we have * │ │ │ │ │ │ +00030 * structured them in categories: │ │ │ │ │ │ * │ │ │ │ │ │ -00036 * particles management. │ │ │ │ │ │ +00031 * INITIALISATION FUNCTIONS │ │ │ │ │ │ +* │ │ │ │ │ │ +00032 * - ctor() │ │ │ │ │ │ +* │ │ │ │ │ │ +00033 * - ctor(particle_list) │ │ │ │ │ │ +* │ │ │ │ │ │ +00034 * - dtor() │ │ │ │ │ │ +* │ │ │ │ │ │ +00035 * - init(particle_list) │ │ │ │ │ │ +* │ │ │ │ │ │ +00036 * ALGORITHM MAIN ENTRY │ │ │ │ │ │ * │ │ │ │ │ │ -00037 * It includes all Lorentz properties as well as tools for summing them. * │ │ │ │ │ │ -00038 *************************************************************************/ │ │ │ │ │ │ -00039 │ │ │ │ │ │ -00040 // default ctor │ │ │ │ │ │ -00041 //-------------00042 Cmomentum::Cmomentum(){ │ │ │ │ │ │ -00043 │ │ │ │ │ │ -eta = 0.0; │ │ │ │ │ │ -00044 │ │ │ │ │ │ -phi = 0.0; │ │ │ │ │ │ -00045 │ │ │ │ │ │ -px = py = pz = E = 0.0; │ │ │ │ │ │ -00046 │ │ │ │ │ │ -ref = Creference(); │ │ │ │ │ │ -00047 │ │ │ │ │ │ -index = -1; │ │ │ │ │ │ -00048 } │ │ │ │ │ │ -00049 │ │ │ │ │ │ -00050 // ctor with initialisation │ │ │ │ │ │ -00051 //-------------------------00052 Cmomentum::Cmomentum(double _px, double _py, double _pz, double _E){ │ │ │ │ │ │ -00053 │ │ │ │ │ │ -px = _px; │ │ │ │ │ │ -00054 │ │ │ │ │ │ -py = _py; │ │ │ │ │ │ -00055 │ │ │ │ │ │ -pz = _pz; │ │ │ │ │ │ -00056 │ │ │ │ │ │ -E = _E; │ │ │ │ │ │ -00057 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.18 momentum.cpp │ │ │ │ │ │ + 5.16 protocones.cpp │ │ │ │ │ │ │ │ │ │ │ │ +00037 * - get_stable_cone(radius) │ │ │ │ │ │ +* │ │ │ │ │ │ +00038 * ALGORITHM MAIN STEPS │ │ │ │ │ │ +* │ │ │ │ │ │ +00039 * - init_cone() │ │ │ │ │ │ +* │ │ │ │ │ │ +00040 * - test_cone() │ │ │ │ │ │ +* │ │ │ │ │ │ +00041 * - update_cone() │ │ │ │ │ │ +* │ │ │ │ │ │ +00042 * - proceed_with_stability() │ │ │ │ │ │ +* │ │ │ │ │ │ +00043 * ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ +* │ │ │ │ │ │ +00044 * - cocircular_pt_less(v1, v2) │ │ │ │ │ │ +* │ │ │ │ │ │ +00045 * - prepare_cocircular_list() │ │ │ │ │ │ +* │ │ │ │ │ │ +00046 * - test_cone_cocircular() │ │ │ │ │ │ +* │ │ │ │ │ │ +00047 * - test_stability(candidate, border_list) │ │ │ │ │ │ +* │ │ │ │ │ │ +00048 * - updat_cone_cocircular() │ │ │ │ │ │ +* │ │ │ │ │ │ +00049 * RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ +* │ │ │ │ │ │ +00050 * - compute_cone_contents() │ │ │ │ │ │ +* │ │ │ │ │ │ +00051 * - recompute_cone_contents() │ │ │ │ │ │ +* │ │ │ │ │ │ +00052 * - recompute_cone_contents_if_needed() │ │ │ │ │ │ +* │ │ │ │ │ │ +00053 * VARIOUS TOOLS │ │ │ │ │ │ +* │ │ │ │ │ │ +00054 * - circle_intersect() │ │ │ │ │ │ +* │ │ │ │ │ │ +00055 * - is_inside() │ │ │ │ │ │ +* │ │ │ │ │ │ +00056 * - abs_dangle() │ │ │ │ │ │ +* │ │ │ │ │ │ +00057 *******************************************************/ │ │ │ │ │ │ 00058 │ │ │ │ │ │ -// compute eta and phi │ │ │ │ │ │ -00059 │ │ │ │ │ │ -build_etaphi(); │ │ │ │ │ │ -00060 │ │ │ │ │ │ -ref = Creference(); │ │ │ │ │ │ -00061 } │ │ │ │ │ │ -00062 │ │ │ │ │ │ -00063 // ctor with detailed initialisation │ │ │ │ │ │ -00064 //----------------------------------00065 Cmomentum::Cmomentum(double _eta, double _phi, Creference _ref){ │ │ │ │ │ │ +00059 #include "protocones.h" │ │ │ │ │ │ +00060 #include "siscone_error.h" │ │ │ │ │ │ +00061 #include "defines.h" │ │ │ │ │ │ +00062 #include │ │ │ │ │ │ +00063 #include │ │ │ │ │ │ +00064 #include "circulator.h" │ │ │ │ │ │ +00065 #include │ │ │ │ │ │ 00066 │ │ │ │ │ │ -eta = _eta; │ │ │ │ │ │ -00067 │ │ │ │ │ │ -phi = _phi; │ │ │ │ │ │ +00067 namespace siscone{ │ │ │ │ │ │ 00068 │ │ │ │ │ │ -00069 │ │ │ │ │ │ -ref = _ref; │ │ │ │ │ │ -00070 } │ │ │ │ │ │ -00071 │ │ │ │ │ │ -00072 // default dtor │ │ │ │ │ │ -00073 //-------------00074 Cmomentum::~Cmomentum(){ │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00076 } │ │ │ │ │ │ -00077 │ │ │ │ │ │ -00078 // assignment of vectors │ │ │ │ │ │ -00079 //----------------------00080 Cmomentum& Cmomentum::operator = (const Cmomentum &v){ │ │ │ │ │ │ -00081 │ │ │ │ │ │ -px = v.px; │ │ │ │ │ │ -00082 │ │ │ │ │ │ -py = v.py; │ │ │ │ │ │ -00083 │ │ │ │ │ │ -pz = v.pz; │ │ │ │ │ │ -00084 │ │ │ │ │ │ -E = v.E; │ │ │ │ │ │ -00085 │ │ │ │ │ │ +00069 using namespace std; │ │ │ │ │ │ +00070 │ │ │ │ │ │ +00071 /********************************************************************** │ │ │ │ │ │ +00072 * Cstable_cones implementation │ │ │ │ │ │ +* │ │ │ │ │ │ +00073 * Computes the list of stable comes from a particle list. │ │ │ │ │ │ +* │ │ │ │ │ │ +00074 * This class does the first fundamental task of te cone algorithm: │ │ │ │ │ │ +* │ │ │ │ │ │ +00075 * it is used to compute the list of stable cones given a list │ │ │ │ │ │ +* │ │ │ │ │ │ +00076 * of particles. │ │ │ │ │ │ +* │ │ │ │ │ │ +00077 **********************************************************************/ │ │ │ │ │ │ +00078 │ │ │ │ │ │ +00080 // INITIALISATION FUNCTIONS │ │ │ │ │ │ +// │ │ │ │ │ │ +00081 // - ctor() │ │ │ │ │ │ +// │ │ │ │ │ │ +00082 // - ctor(particle_list) │ │ │ │ │ │ +// │ │ │ │ │ │ +00083 // - dtor() │ │ │ │ │ │ +// │ │ │ │ │ │ +00084 // - init(particle_list) │ │ │ │ │ │ +// │ │ │ │ │ │ 00086 │ │ │ │ │ │ -eta = v.eta; │ │ │ │ │ │ -00087 │ │ │ │ │ │ -phi = v.phi; │ │ │ │ │ │ -00088 │ │ │ │ │ │ -00089 │ │ │ │ │ │ -ref = v.ref; │ │ │ │ │ │ +00087 // default ctor │ │ │ │ │ │ +00088 //-------------00089 Cstable_cones::Cstable_cones(){ │ │ │ │ │ │ 00090 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00091 } │ │ │ │ │ │ -00092 │ │ │ │ │ │ -00093 // addition of vectors │ │ │ │ │ │ -00094 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00095 //-----------------------------------------------00096 const Cmomentum Cmomentum::operator + (const Cmomentum &v){ │ │ │ │ │ │ +nb_tot = 0; │ │ │ │ │ │ +00091 │ │ │ │ │ │ +hc = NULL; │ │ │ │ │ │ +00092 } │ │ │ │ │ │ +00093 │ │ │ │ │ │ +00094 // ctor with initialisation │ │ │ │ │ │ +00095 //-------------------------00096 Cstable_cones::Cstable_cones(vector &_particle_list) │ │ │ │ │ │ 00097 │ │ │ │ │ │ -Cmomentum tmp = *this; │ │ │ │ │ │ +: Cvicinity(_particle_list){ │ │ │ │ │ │ 00098 │ │ │ │ │ │ -return tmp+=v; │ │ │ │ │ │ -00099 } │ │ │ │ │ │ +00099 │ │ │ │ │ │ +nb_tot = 0; │ │ │ │ │ │ 00100 │ │ │ │ │ │ -00101 // incrementation of vectors │ │ │ │ │ │ -00102 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00103 //-----------------------------------------------00104 Cmomentum& Cmomentum::operator += (const Cmomentum &v){ │ │ │ │ │ │ -00105 │ │ │ │ │ │ -px+=v.px; │ │ │ │ │ │ +hc = NULL; │ │ │ │ │ │ +00101 } │ │ │ │ │ │ +00102 │ │ │ │ │ │ +00103 // default dtor │ │ │ │ │ │ +00104 //-------------00105 Cstable_cones::~Cstable_cones(){ │ │ │ │ │ │ 00106 │ │ │ │ │ │ -py+=v.py; │ │ │ │ │ │ -00107 │ │ │ │ │ │ -pz+=v.pz; │ │ │ │ │ │ +if (hc!=NULL) delete hc; │ │ │ │ │ │ +00107 } │ │ │ │ │ │ 00108 │ │ │ │ │ │ -E +=v.E; │ │ │ │ │ │ -00109 │ │ │ │ │ │ -00110 │ │ │ │ │ │ -ref+=v.ref; │ │ │ │ │ │ -00111 │ │ │ │ │ │ -00112 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00113 } │ │ │ │ │ │ -00114 │ │ │ │ │ │ -00115 // incrementation of vectors │ │ │ │ │ │ -00116 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00117 //-----------------------------------------------00118 Cmomentum& Cmomentum::operator -= (const Cmomentum &v){ │ │ │ │ │ │ +00109 /* │ │ │ │ │ │ +00110 * initialisation │ │ │ │ │ │ +00111 * - _particle_list list of particles │ │ │ │ │ │ +00112 * - _n │ │ │ │ │ │ +number of particles │ │ │ │ │ │ +00113 *********************************************************************/ │ │ │ │ │ │ +00114 void Cstable_cones::init(vector &_particle_list){ │ │ │ │ │ │ +00115 │ │ │ │ │ │ +// check already allocated mem │ │ │ │ │ │ +00116 │ │ │ │ │ │ +if (hc!=NULL){ │ │ │ │ │ │ +00117 │ │ │ │ │ │ +delete hc; │ │ │ │ │ │ +00118 │ │ │ │ │ │ +} │ │ │ │ │ │ 00119 │ │ │ │ │ │ -px-=v.px; │ │ │ │ │ │ +if (protocones.size()!=0) │ │ │ │ │ │ 00120 │ │ │ │ │ │ -py-=v.py; │ │ │ │ │ │ +protocones.clear(); │ │ │ │ │ │ 00121 │ │ │ │ │ │ -pz-=v.pz; │ │ │ │ │ │ 00122 │ │ │ │ │ │ -E -=v.E; │ │ │ │ │ │ +multiple_centre_done.clear(); │ │ │ │ │ │ 00123 │ │ │ │ │ │ 00124 │ │ │ │ │ │ -ref-=v.ref; │ │ │ │ │ │ +// initialisation │ │ │ │ │ │ 00125 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00126 } │ │ │ │ │ │ -00127 │ │ │ │ │ │ -00128 // build eta-phi from 4-momentum info │ │ │ │ │ │ -00129 // !!! │ │ │ │ │ │ -WARNING │ │ │ │ │ │ -!!! │ │ │ │ │ │ -00130 // !!! computing eta and phi is time-consuming !!! │ │ │ │ │ │ -00131 // !!! use this whenever you need eta or phi │ │ │ │ │ │ -!!! │ │ │ │ │ │ -00132 // !!! automatically called for single-particle !!! │ │ │ │ │ │ -00133 //-------------------------------------------------00134 void Cmomentum::build_etaphi(){ │ │ │ │ │ │ -00135 │ │ │ │ │ │ -// note: the factor n (ref.nb) cancels in all expressions !! │ │ │ │ │ │ -00136 │ │ │ │ │ │ -eta = 0.5*log((E+pz)/(E-pz)); │ │ │ │ │ │ -00137 │ │ │ │ │ │ -phi = atan2(py,px); │ │ │ │ │ │ -00138 } │ │ │ │ │ │ -00139 │ │ │ │ │ │ -00140 │ │ │ │ │ │ -00141 // ordering of two vectors │ │ │ │ │ │ -00142 // the default ordering is w.r.t. their references │ │ │ │ │ │ -00143 //------------------------------------------------00144 bool operator < (const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ │ +set_particle_list(_particle_list); │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -205 │ │ │ │ │ │ +203 │ │ │ │ │ │ │ │ │ │ │ │ - 206 │ │ │ │ │ │ + 204 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00145 │ │ │ │ │ │ -return v1.ref < v2.ref; │ │ │ │ │ │ -00146 } │ │ │ │ │ │ -00147 │ │ │ │ │ │ -00148 // ordering of vectors in eta (e.g. used in collinear tests) │ │ │ │ │ │ -00149 //----------------------------------------------------------00150 bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ │ -00151 │ │ │ │ │ │ -return v1.eta < v2.eta; │ │ │ │ │ │ -00152 } │ │ │ │ │ │ -00153 │ │ │ │ │ │ -00154 // ordering of vectors in pt │ │ │ │ │ │ -00155 //--------------------------00156 bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ │ -00157 │ │ │ │ │ │ -return v1.perp2() < v2.perp2(); │ │ │ │ │ │ -00158 } │ │ │ │ │ │ -00159 │ │ │ │ │ │ -00160 } │ │ │ │ │ │ -00161 │ │ │ │ │ │ - │ │ │ │ │ │ -5.19 │ │ │ │ │ │ - │ │ │ │ │ │ -momentum.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00001 │ │ │ │ │ │ -00002 // File: momentum.cpp │ │ │ │ │ │ -// │ │ │ │ │ │ -00003 // Description: source file for 4-momentum class Cmomentum │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // │ │ │ │ │ │ -an adaptation to spherical coordinates │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00010 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00023 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00024 // │ │ │ │ │ │ +00126 } │ │ │ │ │ │ +00127 │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00130 // ALGORITHM MAIN ENTRY │ │ │ │ │ │ // │ │ │ │ │ │ -00025 // $Revision:: 255 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00026 // $Date:: 2008-07-12 17:40:35 +0200 (Sat, 12 Jul 2008) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00028 │ │ │ │ │ │ -00029 #include "momentum.h" │ │ │ │ │ │ -00030 #include │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 namespace siscone_spherical{ │ │ │ │ │ │ -00034 │ │ │ │ │ │ -00035 /************************************************************************* │ │ │ │ │ │ -00036 * class CSph3vector │ │ │ │ │ │ -* │ │ │ │ │ │ -00037 * This class contains the information for particle or group of │ │ │ │ │ │ -* │ │ │ │ │ │ -00038 * particles management. │ │ │ │ │ │ -* │ │ │ │ │ │ -00039 *************************************************************************/ │ │ │ │ │ │ -00040 │ │ │ │ │ │ -00041 // default ctor │ │ │ │ │ │ -00042 //-------------00043 CSph3vector::CSph3vector(){ │ │ │ │ │ │ -00044 │ │ │ │ │ │ -_theta = _phi = _norm = 0.0; │ │ │ │ │ │ -00045 │ │ │ │ │ │ -px = py = pz = 0.0; │ │ │ │ │ │ -00046 │ │ │ │ │ │ -ref = siscone::Creference(); │ │ │ │ │ │ -00047 } │ │ │ │ │ │ -00048 │ │ │ │ │ │ -00049 // ctor with initialisation │ │ │ │ │ │ -00050 //-------------------------00051 CSph3vector::CSph3vector(double _px, double _py, double _pz){ │ │ │ │ │ │ -00052 │ │ │ │ │ │ -px = _px; │ │ │ │ │ │ -00053 │ │ │ │ │ │ -py = _py; │ │ │ │ │ │ -00054 │ │ │ │ │ │ -pz = _pz; │ │ │ │ │ │ -00055 │ │ │ │ │ │ -00056 │ │ │ │ │ │ -// compute the norm │ │ │ │ │ │ -00057 │ │ │ │ │ │ -build_norm(); │ │ │ │ │ │ -00058 │ │ │ │ │ │ -00059 │ │ │ │ │ │ -ref = siscone::Creference(); │ │ │ │ │ │ -00060 } │ │ │ │ │ │ -00061 │ │ │ │ │ │ -00062 // default dtor │ │ │ │ │ │ -00063 //-------------00064 CSph3vector::~CSph3vector(){ │ │ │ │ │ │ - │ │ │ │ │ │ +00131 // - get_stable_cone(radius) │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.19 momentum.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00065 │ │ │ │ │ │ -00066 } │ │ │ │ │ │ -00067 │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00069 // assignment of vectors │ │ │ │ │ │ -00070 //----------------------00071 CSph3vector& CSph3vector::operator = (const CSph3vector &v){ │ │ │ │ │ │ -00072 │ │ │ │ │ │ -px = v.px; │ │ │ │ │ │ -00073 │ │ │ │ │ │ -py = v.py; │ │ │ │ │ │ -00074 │ │ │ │ │ │ -pz = v.pz; │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -_norm = v._norm; │ │ │ │ │ │ -00077 │ │ │ │ │ │ -_theta = v._theta; │ │ │ │ │ │ -00078 │ │ │ │ │ │ -_phi │ │ │ │ │ │ -= v._phi; │ │ │ │ │ │ -00079 │ │ │ │ │ │ -00080 │ │ │ │ │ │ -ref = v.ref; │ │ │ │ │ │ -00081 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00082 } │ │ │ │ │ │ -00083 │ │ │ │ │ │ -00084 // addition of vectors │ │ │ │ │ │ -00085 //-----------------------------------------------00086 const CSph3vector CSph3vector::operator + (const CSph3vector &v){ │ │ │ │ │ │ -00087 │ │ │ │ │ │ -CSph3vector tmp = *this; │ │ │ │ │ │ -00088 │ │ │ │ │ │ -return tmp+=v; │ │ │ │ │ │ -00089 } │ │ │ │ │ │ -00090 │ │ │ │ │ │ -00091 // subtraction of vectors │ │ │ │ │ │ -00092 //-----------------------------------------------00093 const CSph3vector CSph3vector::operator - (const CSph3vector &v){ │ │ │ │ │ │ -00094 │ │ │ │ │ │ -CSph3vector tmp = *this; │ │ │ │ │ │ -00095 │ │ │ │ │ │ -return tmp-=v; │ │ │ │ │ │ -00096 } │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00098 // division by constant │ │ │ │ │ │ -00099 //-----------------------------------------------00100 const CSph3vector CSph3vector::operator / (const double &r){ │ │ │ │ │ │ -00101 │ │ │ │ │ │ -CSph3vector tmp = *this; │ │ │ │ │ │ -00102 │ │ │ │ │ │ -return tmp/=r; │ │ │ │ │ │ -00103 } │ │ │ │ │ │ -00104 │ │ │ │ │ │ -00105 // incrementation │ │ │ │ │ │ -00106 //-----------------------------------------------00107 CSph3vector& CSph3vector::operator += (const CSph3vector &v){ │ │ │ │ │ │ -00108 │ │ │ │ │ │ -px+=v.px; │ │ │ │ │ │ -00109 │ │ │ │ │ │ -py+=v.py; │ │ │ │ │ │ -00110 │ │ │ │ │ │ -pz+=v.pz; │ │ │ │ │ │ -00111 │ │ │ │ │ │ -00112 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00113 } │ │ │ │ │ │ -00114 │ │ │ │ │ │ -00115 // decrementation │ │ │ │ │ │ -00116 //-----------------------------------------------00117 CSph3vector& CSph3vector::operator -= (const CSph3vector &v){ │ │ │ │ │ │ -00118 │ │ │ │ │ │ -px-=v.px; │ │ │ │ │ │ -00119 │ │ │ │ │ │ -py-=v.py; │ │ │ │ │ │ -00120 │ │ │ │ │ │ -pz-=v.pz; │ │ │ │ │ │ -00121 │ │ │ │ │ │ -00122 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00123 } │ │ │ │ │ │ -00124 │ │ │ │ │ │ -00125 // multiplication by a constant │ │ │ │ │ │ -00126 //-----------------------------------------------00127 CSph3vector& CSph3vector::operator *= (const double &r){ │ │ │ │ │ │ -00128 │ │ │ │ │ │ -px*=r; │ │ │ │ │ │ -00129 │ │ │ │ │ │ -py*=r; │ │ │ │ │ │ -00130 │ │ │ │ │ │ -pz*=r; │ │ │ │ │ │ -00131 │ │ │ │ │ │ -00132 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00133 } │ │ │ │ │ │ -00134 │ │ │ │ │ │ -00135 // division by a constant │ │ │ │ │ │ -00136 //-----------------------------------------------00137 CSph3vector& CSph3vector::operator /= (const double &r){ │ │ │ │ │ │ -00138 │ │ │ │ │ │ -px/=r; │ │ │ │ │ │ -00139 │ │ │ │ │ │ -py/=r; │ │ │ │ │ │ -00140 │ │ │ │ │ │ -pz/=r; │ │ │ │ │ │ -00141 │ │ │ │ │ │ +00133 │ │ │ │ │ │ +00134 /* │ │ │ │ │ │ +00135 * compute stable cones. │ │ │ │ │ │ +00136 * This function really does the job i.e. computes │ │ │ │ │ │ +00137 * the list of stable cones (in a seedless way) │ │ │ │ │ │ +00138 * - _radius: radius of the cones │ │ │ │ │ │ +00139 * The number of stable cones found is returned │ │ │ │ │ │ +00140 *********************************************************************/ │ │ │ │ │ │ +00141 int Cstable_cones::get_stable_cones(double _radius){ │ │ │ │ │ │ 00142 │ │ │ │ │ │ -_norm/=r; │ │ │ │ │ │ +int p_idx; │ │ │ │ │ │ 00143 │ │ │ │ │ │ 00144 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00145 } │ │ │ │ │ │ +// check if everything is correctly initialised │ │ │ │ │ │ +00145 │ │ │ │ │ │ +if (n_part==0){ │ │ │ │ │ │ 00146 │ │ │ │ │ │ -00147 // build norm from 3-momentum info │ │ │ │ │ │ -00148 void CSph3vector::build_norm(){ │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +} │ │ │ │ │ │ +00148 │ │ │ │ │ │ 00149 │ │ │ │ │ │ -_norm = norm(); │ │ │ │ │ │ -00150 } │ │ │ │ │ │ +R = _radius; │ │ │ │ │ │ +00150 │ │ │ │ │ │ +R2 = R*R; │ │ │ │ │ │ 00151 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -207 │ │ │ │ │ │ - │ │ │ │ │ │ - 208 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00152 // build norm from 3-momentum info │ │ │ │ │ │ -00153 void CSph3vector::build_thetaphi(){ │ │ │ │ │ │ +00152 │ │ │ │ │ │ +// allow hash for cones candidates │ │ │ │ │ │ +00153 │ │ │ │ │ │ +hc = new hash_cones(n_part, R2); │ │ │ │ │ │ 00154 │ │ │ │ │ │ -_theta = theta(); │ │ │ │ │ │ 00155 │ │ │ │ │ │ -_phi = phi(); │ │ │ │ │ │ -00156 } │ │ │ │ │ │ +// browse all particles │ │ │ │ │ │ +00156 │ │ │ │ │ │ +for (p_idx=0;p_idxv; │ │ │ │ │ │ +00216 │ │ │ │ │ │ +centre_idx = first_cone; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.16 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00217 │ │ │ │ │ │ +00218 │ │ │ │ │ │ +// build the initial cone (nodist: avoids calculating distances -00219 │ │ │ │ │ │ +// just deduces contents by circulating around all in/out operations) │ │ │ │ │ │ +00220 │ │ │ │ │ │ +// this function also sets the list of included particles │ │ │ │ │ │ 00221 │ │ │ │ │ │ -00222 // assignment of vectors │ │ │ │ │ │ -00223 //----------------------00224 CSphmomentum& CSphmomentum::operator = (const CSphmomentum &v){ │ │ │ │ │ │ +compute_cone_contents(); │ │ │ │ │ │ +00222 │ │ │ │ │ │ +00223 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00224 } │ │ │ │ │ │ 00225 │ │ │ │ │ │ -px = v.px; │ │ │ │ │ │ 00226 │ │ │ │ │ │ -py = v.py; │ │ │ │ │ │ -00227 │ │ │ │ │ │ -pz = v.pz; │ │ │ │ │ │ -00228 │ │ │ │ │ │ -E = v.E; │ │ │ │ │ │ -00229 │ │ │ │ │ │ -00230 │ │ │ │ │ │ -_norm = v._norm; │ │ │ │ │ │ -00231 │ │ │ │ │ │ -_theta = v._theta; │ │ │ │ │ │ -00232 │ │ │ │ │ │ -_phi │ │ │ │ │ │ -= v._phi; │ │ │ │ │ │ -00233 │ │ │ │ │ │ +00227 /* │ │ │ │ │ │ +00228 * test cones. │ │ │ │ │ │ +00229 * We check if the cone(s) built with the present parent and child │ │ │ │ │ │ +00230 * are stable │ │ │ │ │ │ +00231 * return 0 on success 1 on error │ │ │ │ │ │ +00232 *********************************************************************/ │ │ │ │ │ │ +00233 int Cstable_cones::test_cone(){ │ │ │ │ │ │ 00234 │ │ │ │ │ │ -ref = v.ref; │ │ │ │ │ │ +Creference weighted_cone_ref; │ │ │ │ │ │ 00235 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00236 } │ │ │ │ │ │ +00236 │ │ │ │ │ │ +// depending on the side we are taking the child particle, │ │ │ │ │ │ 00237 │ │ │ │ │ │ -00238 // addition of vectors │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.20 momentum.h │ │ │ │ │ │ - │ │ │ │ │ │ -00239 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00240 //-----------------------------------------------00241 const CSphmomentum CSphmomentum::operator + (const CSphmomentum &v){ │ │ │ │ │ │ +// we test different configuration. │ │ │ │ │ │ +00238 │ │ │ │ │ │ +// Each time, two configurations are tested in such a way that │ │ │ │ │ │ +00239 │ │ │ │ │ │ +// all 4 possible cases (parent or child in or out the cone) │ │ │ │ │ │ +00240 │ │ │ │ │ │ +// are tested when taking the pair of particle parent+child │ │ │ │ │ │ +00241 │ │ │ │ │ │ +// and child+parent. │ │ │ │ │ │ 00242 │ │ │ │ │ │ -CSphmomentum tmp = *this; │ │ │ │ │ │ 00243 │ │ │ │ │ │ -return tmp+=v; │ │ │ │ │ │ -00244 } │ │ │ │ │ │ +// here are the tests entering the first series: │ │ │ │ │ │ +00244 │ │ │ │ │ │ +// 1. check if the cone is already inserted │ │ │ │ │ │ 00245 │ │ │ │ │ │ -00246 // incrementation of vectors │ │ │ │ │ │ -00247 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00248 //-----------------------------------------------00249 CSphmomentum& CSphmomentum::operator += (const CSphmomentum &v){ │ │ │ │ │ │ +// 2. check cone stability for the parent and child particles │ │ │ │ │ │ +00246 │ │ │ │ │ │ +00247 │ │ │ │ │ │ +if (centre->side){ │ │ │ │ │ │ +00248 │ │ │ │ │ │ +// test when both particles are not in the cone │ │ │ │ │ │ +00249 │ │ │ │ │ │ +// or when both are in. │ │ │ │ │ │ 00250 │ │ │ │ │ │ -px+=v.px; │ │ │ │ │ │ +// Note: for the totally exclusive case, test emptyness before │ │ │ │ │ │ 00251 │ │ │ │ │ │ -py+=v.py; │ │ │ │ │ │ +cone_candidate = cone; │ │ │ │ │ │ 00252 │ │ │ │ │ │ -pz+=v.pz; │ │ │ │ │ │ +if (cone.ref.not_empty()){ │ │ │ │ │ │ 00253 │ │ │ │ │ │ -E +=v.E; │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ 00254 │ │ │ │ │ │ +} │ │ │ │ │ │ 00255 │ │ │ │ │ │ -ref+=v.ref; │ │ │ │ │ │ 00256 │ │ │ │ │ │ +cone_candidate = cone; │ │ │ │ │ │ 00257 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00258 } │ │ │ │ │ │ +cone_candidate+= *parent + *child; │ │ │ │ │ │ +00258 │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ 00259 │ │ │ │ │ │ -00260 // decrementation of vectors │ │ │ │ │ │ -00261 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00262 //-----------------------------------------------00263 CSphmomentum& CSphmomentum::operator -= (const CSphmomentum &v){ │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00260 │ │ │ │ │ │ +// test when 1! of the particles is in the cone │ │ │ │ │ │ +00261 │ │ │ │ │ │ +cone_candidate = cone + *parent; │ │ │ │ │ │ +00262 │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, true, false); │ │ │ │ │ │ +00263 │ │ │ │ │ │ 00264 │ │ │ │ │ │ -px-=v.px; │ │ │ │ │ │ +cone_candidate = cone + *child; │ │ │ │ │ │ 00265 │ │ │ │ │ │ -py-=v.py; │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ 00266 │ │ │ │ │ │ -pz-=v.pz; │ │ │ │ │ │ +} │ │ │ │ │ │ 00267 │ │ │ │ │ │ -E -=v.E; │ │ │ │ │ │ 00268 │ │ │ │ │ │ +nb_tot+=2; │ │ │ │ │ │ 00269 │ │ │ │ │ │ -ref-=v.ref; │ │ │ │ │ │ 00270 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ +return 0; │ │ │ │ │ │ 00271 } │ │ │ │ │ │ 00272 │ │ │ │ │ │ 00273 │ │ │ │ │ │ -00274 // ordering of two vectors │ │ │ │ │ │ -00275 // the default ordering is w.r.t. their references │ │ │ │ │ │ -00276 //------------------------------------------------00277 bool operator < (const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ -00278 │ │ │ │ │ │ -return v1.ref < v2.ref; │ │ │ │ │ │ -00279 } │ │ │ │ │ │ +00274 /* │ │ │ │ │ │ +00275 * update the cone │ │ │ │ │ │ +00276 * go to the next child for that parent and update ’cone’ appropriately │ │ │ │ │ │ +00277 * return 0 if update candidate found, 1 otherwise │ │ │ │ │ │ +00278 ***********************************************************************/ │ │ │ │ │ │ +00279 int Cstable_cones::update_cone(){ │ │ │ │ │ │ 00280 │ │ │ │ │ │ -00281 // ordering of vectors in eta (e.g. used in collinear tests) │ │ │ │ │ │ -00282 //----------------------------------------------------------00283 bool momentum_theta_less(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ +// get the next child and centre │ │ │ │ │ │ +00281 │ │ │ │ │ │ +centre_idx++; │ │ │ │ │ │ +00282 │ │ │ │ │ │ +if (centre_idx==vicinity_size) │ │ │ │ │ │ +00283 │ │ │ │ │ │ +centre_idx=0; │ │ │ │ │ │ 00284 │ │ │ │ │ │ -return v1._theta < v2._theta; │ │ │ │ │ │ -00285 } │ │ │ │ │ │ +if (centre_idx==first_cone) │ │ │ │ │ │ +00285 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00286 │ │ │ │ │ │ -00287 // ordering of vectors in pt │ │ │ │ │ │ -00288 //--------------------------00289 bool momentum_pt_less(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ +00287 │ │ │ │ │ │ +// update the cone w.r.t. the old child │ │ │ │ │ │ +00288 │ │ │ │ │ │ +// only required if the old child is entering inside in which │ │ │ │ │ │ +00289 │ │ │ │ │ │ +// case we need to add it. We also know that the child is │ │ │ │ │ │ 00290 │ │ │ │ │ │ -return v1.perp2() < v2.perp2(); │ │ │ │ │ │ -00291 } │ │ │ │ │ │ +// inside iff its side is -. │ │ │ │ │ │ +00291 │ │ │ │ │ │ +if (!centre->side){ │ │ │ │ │ │ 00292 │ │ │ │ │ │ -00293 } │ │ │ │ │ │ +// update cone │ │ │ │ │ │ +00293 │ │ │ │ │ │ +cone += (*child); │ │ │ │ │ │ 00294 │ │ │ │ │ │ - │ │ │ │ │ │ -5.20 │ │ │ │ │ │ - │ │ │ │ │ │ -momentum.h │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: momentum.h │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // Description: header file for 4-momentum class Cmomentum │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00023 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // $Revision:: 163 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00025 // $Date:: 2007-04-26 22:31:02 +0200 (Thu, 26 Apr 2007) │ │ │ │ │ │ -$// │ │ │ │ │ │ +00295 │ │ │ │ │ │ +// update info on particles inside │ │ │ │ │ │ +00296 │ │ │ │ │ │ +centre->is_inside->cone = true; │ │ │ │ │ │ +00297 │ │ │ │ │ │ +00298 │ │ │ │ │ │ +// update stability check quantities │ │ │ │ │ │ +00299 │ │ │ │ │ │ +dpt += fabs(child->px)+fabs(child->py); │ │ │ │ │ │ +00300 │ │ │ │ │ │ +} │ │ │ │ │ │ +00301 │ │ │ │ │ │ +00302 │ │ │ │ │ │ +// update centre and child to correspond to the new position │ │ │ │ │ │ +00303 │ │ │ │ │ │ +centre = vicinity[centre_idx]; │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -209 │ │ │ │ │ │ +205 │ │ │ │ │ │ │ │ │ │ │ │ - 210 │ │ │ │ │ │ + 206 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00027 │ │ │ │ │ │ -00028 #ifndef __VECTOR_H__ │ │ │ │ │ │ -00029 #define __VECTOR_H__ │ │ │ │ │ │ -00030 │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ -00032 #include │ │ │ │ │ │ -00033 #include "reference.h" │ │ │ │ │ │ -00034 #include "geom_2d.h" │ │ │ │ │ │ -00035 #include "defines.h" │ │ │ │ │ │ -00036 │ │ │ │ │ │ -00037 namespace siscone{ │ │ │ │ │ │ -00038 │ │ │ │ │ │ -00049 class Cmomentum{ │ │ │ │ │ │ -00050 public: │ │ │ │ │ │ -00052 │ │ │ │ │ │ -Cmomentum(); │ │ │ │ │ │ -00053 │ │ │ │ │ │ -00055 │ │ │ │ │ │ -Cmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ -00056 │ │ │ │ │ │ -00058 │ │ │ │ │ │ -Cmomentum(double _eta, double _phi, Creference _ref); │ │ │ │ │ │ -00059 │ │ │ │ │ │ -00061 │ │ │ │ │ │ -~Cmomentum(); │ │ │ │ │ │ -00062 │ │ │ │ │ │ -00064 │ │ │ │ │ │ -inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ -00065 │ │ │ │ │ │ -00067 │ │ │ │ │ │ -inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00070 │ │ │ │ │ │ -inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ -00071 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ -00074 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ -00077 │ │ │ │ │ │ -00079 │ │ │ │ │ │ -inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ -00080 │ │ │ │ │ │ -00082 │ │ │ │ │ │ -inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ -00083 │ │ │ │ │ │ -00085 │ │ │ │ │ │ -inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ -00086 │ │ │ │ │ │ -00088 │ │ │ │ │ │ -Cmomentum& operator = (const Cmomentum &v); │ │ │ │ │ │ -00089 │ │ │ │ │ │ -00092 │ │ │ │ │ │ -const Cmomentum operator + (const Cmomentum &v); │ │ │ │ │ │ -00093 │ │ │ │ │ │ -00096 │ │ │ │ │ │ -Cmomentum& operator += (const Cmomentum &v); │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00100 │ │ │ │ │ │ -Cmomentum& operator -= (const Cmomentum &v); │ │ │ │ │ │ -00101 │ │ │ │ │ │ -00107 │ │ │ │ │ │ -void build_etaphi(); │ │ │ │ │ │ -00108 │ │ │ │ │ │ -00109 │ │ │ │ │ │ -double px; │ │ │ │ │ │ -00110 │ │ │ │ │ │ -double py; │ │ │ │ │ │ -00111 │ │ │ │ │ │ -double pz; │ │ │ │ │ │ -00112 │ │ │ │ │ │ -double E; │ │ │ │ │ │ -00113 │ │ │ │ │ │ -00114 │ │ │ │ │ │ -double eta; │ │ │ │ │ │ -00115 │ │ │ │ │ │ -double phi; │ │ │ │ │ │ -00116 │ │ │ │ │ │ -int parent_index; │ │ │ │ │ │ -00117 │ │ │ │ │ │ -int index; │ │ │ │ │ │ -00118 │ │ │ │ │ │ -00120 │ │ │ │ │ │ -// the following part is used for checksums // │ │ │ │ │ │ -00122 │ │ │ │ │ │ -Creference ref; │ │ │ │ │ │ -00123 }; │ │ │ │ │ │ -00124 │ │ │ │ │ │ -00127 bool operator < (const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00130 bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ -00131 │ │ │ │ │ │ -00133 bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ -00134 │ │ │ │ │ │ -00135 │ │ │ │ │ │ -00137 // some handy utilities // │ │ │ │ │ │ -00139 │ │ │ │ │ │ -00144 inline double get_distance(double eta, double phi, Cmomentum *v){ │ │ │ │ │ │ -00145 │ │ │ │ │ │ -double dx, dy; │ │ │ │ │ │ -00146 │ │ │ │ │ │ -00147 │ │ │ │ │ │ -dx = eta - v->eta; │ │ │ │ │ │ -00148 │ │ │ │ │ │ -dy = fabs(phi - v->phi); │ │ │ │ │ │ -00149 │ │ │ │ │ │ -if (dy>M_PI) │ │ │ │ │ │ -00150 │ │ │ │ │ │ -dy -= twopi; │ │ │ │ │ │ -00151 │ │ │ │ │ │ -00152 │ │ │ │ │ │ -return dx*dx+dy*dy; │ │ │ │ │ │ -00153 } │ │ │ │ │ │ -00154 │ │ │ │ │ │ -00155 } │ │ │ │ │ │ -00156 │ │ │ │ │ │ -00157 #endif │ │ │ │ │ │ +00304 │ │ │ │ │ │ +child = centre->v; │ │ │ │ │ │ +00305 │ │ │ │ │ │ +00306 │ │ │ │ │ │ +// check cocircularity │ │ │ │ │ │ +00307 │ │ │ │ │ │ +// note that if cocirculaity is detected (i.e. if we receive 1 │ │ │ │ │ │ +00308 │ │ │ │ │ │ +// in the next test), we need to recall ’update_cone’ directly │ │ │ │ │ │ +00309 │ │ │ │ │ │ +// since tests and remaining part of te update has been performed │ │ │ │ │ │ +00310 │ │ │ │ │ │ +//if (cocircular_check()) │ │ │ │ │ │ +00311 │ │ │ │ │ │ +if (cocircular_check()) │ │ │ │ │ │ +00312 │ │ │ │ │ │ +return update_cone(); │ │ │ │ │ │ +00313 │ │ │ │ │ │ +00314 │ │ │ │ │ │ +00315 │ │ │ │ │ │ +// update the cone w.r.t. the new child │ │ │ │ │ │ +00316 │ │ │ │ │ │ +// only required if the new child was already inside in which │ │ │ │ │ │ +00317 │ │ │ │ │ │ +// case we need to remove it. We also know that the child is │ │ │ │ │ │ +00318 │ │ │ │ │ │ +// inside iff its side is +. │ │ │ │ │ │ +00319 │ │ │ │ │ │ +if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ +00320 │ │ │ │ │ │ +// update cone │ │ │ │ │ │ +00321 │ │ │ │ │ │ +cone -= (*child); │ │ │ │ │ │ +00322 │ │ │ │ │ │ +00323 │ │ │ │ │ │ +// update info on particles inside │ │ │ │ │ │ +00324 │ │ │ │ │ │ +centre->is_inside->cone = false; │ │ │ │ │ │ +00325 │ │ │ │ │ │ +00326 │ │ │ │ │ │ +// update stability check quantities │ │ │ │ │ │ +00327 │ │ │ │ │ │ +dpt += fabs(child->px)+fabs(child->py); //child->perp2(); │ │ │ │ │ │ +00328 │ │ │ │ │ │ +} │ │ │ │ │ │ +00329 │ │ │ │ │ │ +00330 │ │ │ │ │ │ +// check that the addition and subtraction of vectors does │ │ │ │ │ │ +00331 │ │ │ │ │ │ +// not lead to too much rounding error │ │ │ │ │ │ +00332 │ │ │ │ │ │ +// for that, we compute the sum of pt modifications and of |pt| │ │ │ │ │ │ +00333 │ │ │ │ │ │ +// since last recomputation and once the ratio overpasses a threshold │ │ │ │ │ │ +00334 │ │ │ │ │ │ +// we recompute vicinity. │ │ │ │ │ │ +00335 │ │ │ │ │ │ +if ((dpt>PT_TSHOLD*(fabs(cone.px)+fabs(cone.py))) && (cone.ref.not_empty())){ │ │ │ │ │ │ +00336 │ │ │ │ │ │ +recompute_cone_contents(); │ │ │ │ │ │ +00337 │ │ │ │ │ │ +} │ │ │ │ │ │ +00338 │ │ │ │ │ │ +if (cone.ref.is_empty()){ │ │ │ │ │ │ +00339 │ │ │ │ │ │ +cone = Cmomentum(); │ │ │ │ │ │ +00340 │ │ │ │ │ │ +dpt=0.0; │ │ │ │ │ │ +00341 │ │ │ │ │ │ +} │ │ │ │ │ │ +00342 │ │ │ │ │ │ +00343 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00344 } │ │ │ │ │ │ +00345 │ │ │ │ │ │ +00346 │ │ │ │ │ │ +00347 /* │ │ │ │ │ │ +00348 * compute stability of all enumerated candidates. │ │ │ │ │ │ +00349 * For all candidate cones which are stable w.r.t. their border particles, │ │ │ │ │ │ +00350 * pass the last test: stability with quadtree intersection │ │ │ │ │ │ +00351 ************************************************************************/ │ │ │ │ │ │ +00352 int Cstable_cones::proceed_with_stability(){ │ │ │ │ │ │ +00353 │ │ │ │ │ │ +int i; // ,n; │ │ │ │ │ │ +00354 │ │ │ │ │ │ +hash_element *elm; │ │ │ │ │ │ +00355 │ │ │ │ │ │ +00356 │ │ │ │ │ │ +//n=0; │ │ │ │ │ │ +00357 │ │ │ │ │ │ +for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ +00358 │ │ │ │ │ │ +// test ith cell of the hash array │ │ │ │ │ │ +00359 │ │ │ │ │ │ +elm = hc->hash_array[i]; │ │ │ │ │ │ +00360 │ │ │ │ │ │ +00361 │ │ │ │ │ │ +// browse elements therein │ │ │ │ │ │ +00362 │ │ │ │ │ │ +while (elm!=NULL){ │ │ │ │ │ │ +00363 │ │ │ │ │ │ +// test stability │ │ │ │ │ │ +00364 │ │ │ │ │ │ +if (elm->is_stable){ │ │ │ │ │ │ +00365 │ │ │ │ │ │ +// stability is not ensured by all pairs of "edges" already browsed │ │ │ │ │ │ +00366 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ +00367 │ │ │ │ │ │ +// => testing stability with quadtree intersection │ │ │ │ │ │ +00368 │ │ │ │ │ │ +if (quadtree->circle_intersect(elm->eta, elm->phi, R2)==elm->ref){ │ │ │ │ │ │ +00369 #else │ │ │ │ │ │ +00370 │ │ │ │ │ │ +// => testing stability with the particle-list intersection │ │ │ │ │ │ +00371 │ │ │ │ │ │ +if (circle_intersect(elm->eta, elm->phi)==elm->ref){ │ │ │ │ │ │ +00372 #endif │ │ │ │ │ │ +00373 │ │ │ │ │ │ +// add it to the list of protocones │ │ │ │ │ │ +00374 │ │ │ │ │ │ +// note that in its present form, we do not allocate the │ │ │ │ │ │ +00375 │ │ │ │ │ │ +// 4-vector components of the momentum. There’s no need to │ │ │ │ │ │ +00376 │ │ │ │ │ │ +// do it here as it will be recomputed in │ │ │ │ │ │ +00377 │ │ │ │ │ │ +// │ │ │ │ │ │ +Csplit_merge::add_protocones │ │ │ │ │ │ +00378 │ │ │ │ │ │ +protocones.push_back(Cmomentum(elm->eta, elm->phi, elm->ref)); │ │ │ │ │ │ +00379 │ │ │ │ │ │ +} │ │ │ │ │ │ +00380 │ │ │ │ │ │ +} │ │ │ │ │ │ +00381 │ │ │ │ │ │ +00382 │ │ │ │ │ │ +// jump to the next one │ │ │ │ │ │ +00383 │ │ │ │ │ │ +elm = elm->next; │ │ │ │ │ │ +00384 │ │ │ │ │ │ +} │ │ │ │ │ │ +00385 │ │ │ │ │ │ +} │ │ │ │ │ │ +00386 │ │ │ │ │ │ +00387 │ │ │ │ │ │ +// free hash │ │ │ │ │ │ +00388 │ │ │ │ │ │ +// we do that at this level because hash eats rather a lot of memory │ │ │ │ │ │ +00389 │ │ │ │ │ │ +// we want to free it before running the split/merge algorithm │ │ │ │ │ │ +00390 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.21 momentum.h │ │ │ │ │ │ - │ │ │ │ │ │ -5.21 │ │ │ │ │ │ - │ │ │ │ │ │ -momentum.h │ │ │ │ │ │ + 5.16 protocones.cpp │ │ │ │ │ │ │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: momentum.h │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // Description: header file for 4-momentum class Cmomentum │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -an adaptation to spherical coordinates │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +00391 │ │ │ │ │ │ +nb_hash_cones = hc->n_cones; │ │ │ │ │ │ +00392 │ │ │ │ │ │ +nb_hash_occupied = hc->n_occupied_cells; │ │ │ │ │ │ +00393 #endif │ │ │ │ │ │ +00394 │ │ │ │ │ │ +00395 │ │ │ │ │ │ +delete hc; │ │ │ │ │ │ +00396 │ │ │ │ │ │ +hc=NULL; │ │ │ │ │ │ +00397 │ │ │ │ │ │ +00398 │ │ │ │ │ │ +return protocones.size(); │ │ │ │ │ │ +00399 } │ │ │ │ │ │ +00400 │ │ │ │ │ │ +00401 │ │ │ │ │ │ +00403 // ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ // │ │ │ │ │ │ -00020 // GNU General Public License for more details. │ │ │ │ │ │ +00404 // - cocircular_pt_less(v1, v2) │ │ │ │ │ │ // │ │ │ │ │ │ -00021 // │ │ │ │ │ │ +00405 // - prepare_cocircular_list() │ │ │ │ │ │ // │ │ │ │ │ │ -00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +00406 // - test_cone_cocircular() │ │ │ │ │ │ // │ │ │ │ │ │ -00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +00407 // - test_stability(candidate, border_vect) │ │ │ │ │ │ // │ │ │ │ │ │ -00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00025 // │ │ │ │ │ │ +00408 // - updat_cone_cocircular() │ │ │ │ │ │ // │ │ │ │ │ │ -00026 // $Revision:: 256 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 // $Date:: 2008-07-14 13:52:16 +0200 (Mon, 14 Jul 2008) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00029 │ │ │ │ │ │ -00030 #ifndef __SPH_VECTOR_H__ │ │ │ │ │ │ -00031 #define __SPH_VECTOR_H__ │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 #include │ │ │ │ │ │ -00034 #include │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include "geom_2d.h" │ │ │ │ │ │ -00037 #include │ │ │ │ │ │ -00038 │ │ │ │ │ │ -00039 namespace siscone_spherical{ │ │ │ │ │ │ -00040 │ │ │ │ │ │ -00054 class CSph3vector{ │ │ │ │ │ │ -00055 public: │ │ │ │ │ │ -00057 │ │ │ │ │ │ -CSph3vector(); │ │ │ │ │ │ -00058 │ │ │ │ │ │ -00060 │ │ │ │ │ │ -CSph3vector(double _px, double _py, double _pz); │ │ │ │ │ │ -00061 │ │ │ │ │ │ -00063 │ │ │ │ │ │ -~CSph3vector(); │ │ │ │ │ │ -00064 │ │ │ │ │ │ -00066 │ │ │ │ │ │ -CSph3vector& operator = (const CSph3vector &v); │ │ │ │ │ │ -00067 │ │ │ │ │ │ -00070 │ │ │ │ │ │ -const CSph3vector operator + (const CSph3vector &v); │ │ │ │ │ │ -00071 │ │ │ │ │ │ -00074 │ │ │ │ │ │ -const CSph3vector operator - (const CSph3vector &v); │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00078 │ │ │ │ │ │ -const CSph3vector operator / (const double &r); │ │ │ │ │ │ -00079 │ │ │ │ │ │ -00082 │ │ │ │ │ │ -CSph3vector& operator += (const CSph3vector &v); │ │ │ │ │ │ -00083 │ │ │ │ │ │ -00086 │ │ │ │ │ │ -CSph3vector& operator -= (const CSph3vector &v); │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00090 │ │ │ │ │ │ -CSph3vector& operator *= (const double &r); │ │ │ │ │ │ -00091 │ │ │ │ │ │ -00094 │ │ │ │ │ │ -CSph3vector& operator /= (const double &r); │ │ │ │ │ │ -00095 │ │ │ │ │ │ -00097 │ │ │ │ │ │ -inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ -00098 │ │ │ │ │ │ -00100 │ │ │ │ │ │ -inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ -00101 │ │ │ │ │ │ -00103 │ │ │ │ │ │ -inline double norm() const {return sqrt(px*px+py*py+pz*pz);} │ │ │ │ │ │ -00104 │ │ │ │ │ │ -00106 │ │ │ │ │ │ -inline double norm2() const {return px*px+py*py+pz*pz;} │ │ │ │ │ │ -00107 │ │ │ │ │ │ -00109 │ │ │ │ │ │ -inline double phi() const {return atan2(py, px);} │ │ │ │ │ │ -00110 │ │ │ │ │ │ -00112 │ │ │ │ │ │ -inline double theta() const {return atan2(perp(),pz);} │ │ │ │ │ │ -00113 │ │ │ │ │ │ -00120 │ │ │ │ │ │ -void build_norm(); │ │ │ │ │ │ -00121 │ │ │ │ │ │ -00125 │ │ │ │ │ │ -void build_thetaphi(); │ │ │ │ │ │ -00126 │ │ │ │ │ │ -00129 │ │ │ │ │ │ -void get_angular_directions(CSph3vector &angular_dir1, CSph3vector &angular_dir2); │ │ │ │ │ │ -00130 │ │ │ │ │ │ -00131 │ │ │ │ │ │ -double px; │ │ │ │ │ │ -00132 │ │ │ │ │ │ -double py; │ │ │ │ │ │ -00133 │ │ │ │ │ │ -double pz; │ │ │ │ │ │ -00134 │ │ │ │ │ │ -00135 │ │ │ │ │ │ -double _norm; │ │ │ │ │ │ +00410 │ │ │ │ │ │ +00412 bool cocircular_pt_less(Cmomentum *v1, Cmomentum *v2){ │ │ │ │ │ │ +00413 │ │ │ │ │ │ +return v1->perp2() < v2->perp2(); │ │ │ │ │ │ +00414 } │ │ │ │ │ │ +00415 │ │ │ │ │ │ +00416 /* │ │ │ │ │ │ +00417 * run through the vicinity of the current parent and for each child │ │ │ │ │ │ +00418 * establish which other members are cocircular... Note that the list │ │ │ │ │ │ +00419 * associated with each child contains references to vicinity │ │ │ │ │ │ +00420 * elements: thus two vicinity elements each associated with one given │ │ │ │ │ │ +00421 * particle may appear in a list -- this needs to be watched out for │ │ │ │ │ │ +00422 * later on... │ │ │ │ │ │ +00423 **********************************************************************/ │ │ │ │ │ │ +00424 void Cstable_cones::prepare_cocircular_lists() { │ │ │ │ │ │ +00425 │ │ │ │ │ │ +circulator::iterator > here(vicinity.begin(), │ │ │ │ │ │ +00426 │ │ │ │ │ │ +vicinity.begin(), │ │ │ │ │ │ +00427 │ │ │ │ │ │ +vicinity.end()); │ │ │ │ │ │ +00428 │ │ │ │ │ │ +00429 │ │ │ │ │ │ +circulator::iterator > search(here); │ │ │ │ │ │ +00430 │ │ │ │ │ │ +00431 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00432 │ │ │ │ │ │ +Cvicinity_elm* here_pntr = *here(); │ │ │ │ │ │ +00433 │ │ │ │ │ │ +search.set_position(here); │ │ │ │ │ │ +00434 │ │ │ │ │ │ +00435 │ │ │ │ │ │ +// search forwards for things that should have "here" included in │ │ │ │ │ │ +00436 │ │ │ │ │ │ +// their cocircularity list │ │ │ │ │ │ +00437 │ │ │ │ │ │ +while (true) { │ │ │ │ │ │ +00438 │ │ │ │ │ │ +++search; │ │ │ │ │ │ +00439 │ │ │ │ │ │ +if ( abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ +00440 │ │ │ │ │ │ +here_pntr->cocircular_range │ │ │ │ │ │ +00441 │ │ │ │ │ │ +&& search() != here()) { │ │ │ │ │ │ +00442 │ │ │ │ │ │ +(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ +00443 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00444 │ │ │ │ │ │ +break; │ │ │ │ │ │ +00445 │ │ │ │ │ │ +} │ │ │ │ │ │ +00446 │ │ │ │ │ │ +} │ │ │ │ │ │ +00447 │ │ │ │ │ │ +00448 │ │ │ │ │ │ +// search backwards │ │ │ │ │ │ +00449 │ │ │ │ │ │ +search.set_position(here); │ │ │ │ │ │ +00450 │ │ │ │ │ │ +while (true) { │ │ │ │ │ │ +00451 │ │ │ │ │ │ +--search; │ │ │ │ │ │ +00452 │ │ │ │ │ │ +if ( abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ +00453 │ │ │ │ │ │ +here_pntr->cocircular_range │ │ │ │ │ │ +00454 │ │ │ │ │ │ +&& search() != here()) { │ │ │ │ │ │ +00455 │ │ │ │ │ │ +(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ +00456 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00457 │ │ │ │ │ │ +break; │ │ │ │ │ │ +00458 │ │ │ │ │ │ +} │ │ │ │ │ │ +00459 │ │ │ │ │ │ +} │ │ │ │ │ │ +00460 │ │ │ │ │ │ +00461 │ │ │ │ │ │ +++here; │ │ │ │ │ │ +00462 │ │ │ │ │ │ +} while (here() != vicinity.begin()); │ │ │ │ │ │ +00463 │ │ │ │ │ │ +00464 } │ │ │ │ │ │ +00465 │ │ │ │ │ │ +00466 /* │ │ │ │ │ │ +00467 * Testing cocircular configurations in p^3 time, │ │ │ │ │ │ +00468 * rather than 2^p time; we will test all contiguous subsets of points │ │ │ │ │ │ +00469 * on the border --- note that this is till probably overkill, since │ │ │ │ │ │ +00470 * in principle we only have to test situations where up to a │ │ │ │ │ │ +00471 * half-circle is filled (but going to a full circle is simpler) │ │ │ │ │ │ +00472 ******************************************************************/ │ │ │ │ │ │ +00473 void Cstable_cones::test_cone_cocircular(Cmomentum & borderless_cone, │ │ │ │ │ │ +00474 │ │ │ │ │ │ +list & border_list) { │ │ │ │ │ │ +00475 │ │ │ │ │ │ +vector border_vect; │ │ │ │ │ │ +00476 │ │ │ │ │ │ +00477 │ │ │ │ │ │ +border_vect.reserve(border_list.size()); │ │ │ │ │ │ +00478 │ │ │ │ │ │ +for (list::iterator it = border_list.begin(); │ │ │ │ │ │ +00479 │ │ │ │ │ │ +it != border_list.end(); it++) { │ │ │ │ │ │ +00480 │ │ │ │ │ │ +border_vect.push_back(Cborder_store(*it, centre->eta, centre->phi)); │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -211 │ │ │ │ │ │ +207 │ │ │ │ │ │ │ │ │ │ │ │ - 212 │ │ │ │ │ │ + 208 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00136 │ │ │ │ │ │ -double _theta; │ │ │ │ │ │ -00137 │ │ │ │ │ │ -double _phi; │ │ │ │ │ │ -00138 │ │ │ │ │ │ -00140 │ │ │ │ │ │ -// the following part is used for checksums // │ │ │ │ │ │ -00142 │ │ │ │ │ │ -siscone::Creference ref; │ │ │ │ │ │ -00143 }; │ │ │ │ │ │ -00144 │ │ │ │ │ │ -00158 class CSphmomentum : public CSph3vector{ │ │ │ │ │ │ -00159 public: │ │ │ │ │ │ -00161 │ │ │ │ │ │ -CSphmomentum(); │ │ │ │ │ │ -00162 │ │ │ │ │ │ -00164 │ │ │ │ │ │ -CSphmomentum(CSph3vector &init, double E=0.0); │ │ │ │ │ │ -00165 │ │ │ │ │ │ -00167 │ │ │ │ │ │ -CSphmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ -00168 │ │ │ │ │ │ -00170 │ │ │ │ │ │ -//CSphmomentum(double _eta, double _phi, siscone::Creference _ref); │ │ │ │ │ │ -00171 │ │ │ │ │ │ -00173 │ │ │ │ │ │ -~CSphmomentum(); │ │ │ │ │ │ -00174 │ │ │ │ │ │ -00176 │ │ │ │ │ │ -inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ -00177 │ │ │ │ │ │ -00179 │ │ │ │ │ │ -inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ -00180 │ │ │ │ │ │ -00182 │ │ │ │ │ │ -inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ -00183 │ │ │ │ │ │ -00185 │ │ │ │ │ │ -inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ -00186 │ │ │ │ │ │ -00188 │ │ │ │ │ │ -inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ -00189 │ │ │ │ │ │ -00191 │ │ │ │ │ │ -inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ -00192 │ │ │ │ │ │ -00194 │ │ │ │ │ │ -CSphmomentum& operator = (const CSphmomentum &v); │ │ │ │ │ │ -00195 │ │ │ │ │ │ -00198 │ │ │ │ │ │ -const CSphmomentum operator + (const CSphmomentum &v); │ │ │ │ │ │ -00199 │ │ │ │ │ │ -00202 │ │ │ │ │ │ -CSphmomentum& operator += (const CSphmomentum &v); │ │ │ │ │ │ -00203 │ │ │ │ │ │ -00206 │ │ │ │ │ │ -CSphmomentum& operator -= (const CSphmomentum &v); │ │ │ │ │ │ -00207 │ │ │ │ │ │ -00208 │ │ │ │ │ │ -double E; │ │ │ │ │ │ -00209 │ │ │ │ │ │ -00210 │ │ │ │ │ │ -int parent_index; │ │ │ │ │ │ -00211 │ │ │ │ │ │ -int index; │ │ │ │ │ │ -00212 }; │ │ │ │ │ │ -00213 │ │ │ │ │ │ -00216 bool operator < (const CSphmomentum &v1, const CSphmomentum &v2); │ │ │ │ │ │ -00217 │ │ │ │ │ │ -00219 bool momentum_theta_less(const CSphmomentum &v1, const CSphmomentum &v2); │ │ │ │ │ │ -00220 │ │ │ │ │ │ -00222 bool momentum_pt_less(const CSphmomentum &v1, const CSphmomentum &v2); │ │ │ │ │ │ -00223 │ │ │ │ │ │ -00224 │ │ │ │ │ │ -00226 // some handy utilities // │ │ │ │ │ │ -00228 │ │ │ │ │ │ -00230 inline double sqr(double x){return x*x;} │ │ │ │ │ │ -00231 │ │ │ │ │ │ -00235 inline double dot_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ -00236 │ │ │ │ │ │ -//double tmp = v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ -00237 │ │ │ │ │ │ -//if (!isfinite(tmp)){ │ │ │ │ │ │ -00238 │ │ │ │ │ │ -// std::cout « "dot_product inf: " « std::endl; │ │ │ │ │ │ -00239 │ │ │ │ │ │ -// std::cout « " angles: " « v1._theta « " " « v1._phi « " and " « v2._theta « " " « v2._phi « │ │ │ │ │ │ -std::endl; │ │ │ │ │ │ -00240 │ │ │ │ │ │ -// std::cout « " moms : " « v1.px « " " « v1.py « " " « v1.pz │ │ │ │ │ │ -00241 │ │ │ │ │ │ -// │ │ │ │ │ │ -« " and " │ │ │ │ │ │ -« v2.px « " " « v2.py « " " « v2.pz « std::endl; │ │ │ │ │ │ -00242 │ │ │ │ │ │ -//} │ │ │ │ │ │ -00243 │ │ │ │ │ │ -return v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ -00244 } │ │ │ │ │ │ -00245 │ │ │ │ │ │ -00249 inline CSph3vector cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ -00250 │ │ │ │ │ │ -//CSph3vector tmp; │ │ │ │ │ │ -00251 │ │ │ │ │ │ -//tmp.px = v1.py*v2.pz-v1.pz*v2.py; │ │ │ │ │ │ -00252 │ │ │ │ │ │ -//tmp.py = v1.pz*v2.px-v1.px*v2.pz; │ │ │ │ │ │ -00253 │ │ │ │ │ │ -//tmp.pz = v1.px*v2.py-v1.py*v2.px; │ │ │ │ │ │ -00254 │ │ │ │ │ │ -//return tmp; │ │ │ │ │ │ -00255 │ │ │ │ │ │ -return CSph3vector(v1.py*v2.pz-v1.pz*v2.py, │ │ │ │ │ │ -00256 │ │ │ │ │ │ -v1.pz*v2.px-v1.px*v2.pz, │ │ │ │ │ │ -00257 │ │ │ │ │ │ -v1.px*v2.py-v1.py*v2.px); │ │ │ │ │ │ -00258 } │ │ │ │ │ │ -00259 │ │ │ │ │ │ -00263 inline double norm2_cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ -00264 │ │ │ │ │ │ -return sqr(v1.py*v2.pz-v1.pz*v2.py) + sqr(v1.pz*v2.px-v1.px*v2.pz) + sqr(v1.px*v2.py-v1.py*v2.px); │ │ │ │ │ │ -00265 } │ │ │ │ │ │ -00266 │ │ │ │ │ │ -00270 inline double get_tan2_distance(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ -00271 │ │ │ │ │ │ -return norm2_cross_product3(v1,v2)/sqr(dot_product3(v1,v2)); │ │ │ │ │ │ -00272 } │ │ │ │ │ │ -00273 │ │ │ │ │ │ +00481 │ │ │ │ │ │ +} │ │ │ │ │ │ +00482 │ │ │ │ │ │ +00483 │ │ │ │ │ │ +// get them into order of angle │ │ │ │ │ │ +00484 │ │ │ │ │ │ +sort(border_vect.begin(), border_vect.end()); │ │ │ │ │ │ +00485 │ │ │ │ │ │ +00486 │ │ │ │ │ │ +// set up some circulators, since these will help us go around the │ │ │ │ │ │ +00487 │ │ │ │ │ │ +// circle easily │ │ │ │ │ │ +00488 │ │ │ │ │ │ +circulator::iterator > │ │ │ │ │ │ +00489 │ │ │ │ │ │ +start(border_vect.begin(), border_vect.begin(),border_vect.end()); │ │ │ │ │ │ +00490 │ │ │ │ │ │ +circulator::iterator > mid(start), end(start); │ │ │ │ │ │ +00491 │ │ │ │ │ │ +00492 │ │ │ │ │ │ +// test the borderless cone │ │ │ │ │ │ +00493 │ │ │ │ │ │ +Cmomentum candidate = borderless_cone; │ │ │ │ │ │ +00494 │ │ │ │ │ │ +candidate.build_etaphi(); │ │ │ │ │ │ +00495 │ │ │ │ │ │ +if (candidate.ref.not_empty()) │ │ │ │ │ │ +00496 │ │ │ │ │ │ +test_stability(candidate, border_vect); │ │ │ │ │ │ +00497 │ │ │ │ │ │ +00498 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00499 │ │ │ │ │ │ +// reset status wrt inclusion in the cone │ │ │ │ │ │ +00500 │ │ │ │ │ │ +mid = start; │ │ │ │ │ │ +00501 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00502 │ │ │ │ │ │ +mid()->is_in = false; │ │ │ │ │ │ +00503 │ │ │ │ │ │ +} while (++mid != start); │ │ │ │ │ │ +00504 │ │ │ │ │ │ +00505 │ │ │ │ │ │ +// now run over all inclusion possibilities with this starting point │ │ │ │ │ │ +00506 │ │ │ │ │ │ +candidate = borderless_cone; │ │ │ │ │ │ +00507 │ │ │ │ │ │ +while (++mid != start) { │ │ │ │ │ │ +00508 │ │ │ │ │ │ +// will begin with start+1 and go up to start-1 │ │ │ │ │ │ +00509 │ │ │ │ │ │ +mid()->is_in = true; │ │ │ │ │ │ +00510 │ │ │ │ │ │ +candidate += *(mid()->mom); │ │ │ │ │ │ +00511 │ │ │ │ │ │ +test_stability(candidate, border_vect); │ │ │ │ │ │ +00512 │ │ │ │ │ │ +} │ │ │ │ │ │ +00513 │ │ │ │ │ │ +00514 │ │ │ │ │ │ +} while (++start != end); │ │ │ │ │ │ +00515 │ │ │ │ │ │ +00516 │ │ │ │ │ │ +// mid corresponds to momentum that we need to include to get the │ │ │ │ │ │ +00517 │ │ │ │ │ │ +// full cone │ │ │ │ │ │ +00518 │ │ │ │ │ │ +mid()->is_in = true; │ │ │ │ │ │ +00519 │ │ │ │ │ │ +candidate += *(mid()->mom); │ │ │ │ │ │ +00520 │ │ │ │ │ │ +test_stability(candidate, border_vect); │ │ │ │ │ │ +00521 } │ │ │ │ │ │ +00522 │ │ │ │ │ │ +00523 │ │ │ │ │ │ +00530 void Cstable_cones::test_stability(Cmomentum & candidate, const vector & border_vect) { │ │ │ │ │ │ +00531 │ │ │ │ │ │ +00532 │ │ │ │ │ │ +// this almost certainly has not been done... │ │ │ │ │ │ +00533 │ │ │ │ │ │ +candidate.build_etaphi(); │ │ │ │ │ │ +00534 │ │ │ │ │ │ +00535 │ │ │ │ │ │ +bool stable = true; │ │ │ │ │ │ +00536 │ │ │ │ │ │ +for (unsigned i = 0; i < border_vect.size(); i++) { │ │ │ │ │ │ +00537 │ │ │ │ │ │ +if (is_inside(&candidate, border_vect[i].mom) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ +00538 │ │ │ │ │ │ +stable = false; │ │ │ │ │ │ +00539 │ │ │ │ │ │ +break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ +00540 │ │ │ │ │ │ +} │ │ │ │ │ │ +00541 │ │ │ │ │ │ +} │ │ │ │ │ │ +00542 │ │ │ │ │ │ +00543 │ │ │ │ │ │ +if (stable) hc->insert(&candidate); │ │ │ │ │ │ +00544 } │ │ │ │ │ │ +00545 │ │ │ │ │ │ +00546 /* │ │ │ │ │ │ +00547 * check if we are in a situation of cocircularity. │ │ │ │ │ │ +00548 * if it is the case, update and test in the corresponding way │ │ │ │ │ │ +00549 * return ’false’ if no cocircularity detected, ’true’ otherwise │ │ │ │ │ │ +00550 * Note that if cocircularity is detected, we need to │ │ │ │ │ │ +00551 * recall ’update’ from ’update’ !!! │ │ │ │ │ │ +00552 ***************************************************************/ │ │ │ │ │ │ +00553 bool Cstable_cones::cocircular_check(){ │ │ │ │ │ │ +00554 │ │ │ │ │ │ +// check if many configurations have the same centre. │ │ │ │ │ │ +00555 │ │ │ │ │ │ +// if this is the case, branch on the algorithm for this │ │ │ │ │ │ +00556 │ │ │ │ │ │ +// special case. │ │ │ │ │ │ +00557 │ │ │ │ │ │ +// Note that those situation, being considered separately in │ │ │ │ │ │ +00558 │ │ │ │ │ │ +// test_cone_multiple, must only be considered here if all │ │ │ │ │ │ +00559 │ │ │ │ │ │ +// angles are on the same side (this avoid multiple counting) │ │ │ │ │ │ +00560 │ │ │ │ │ │ +00561 │ │ │ │ │ │ +if (centre->cocircular.empty()) return false; │ │ │ │ │ │ +00562 │ │ │ │ │ │ +00563 │ │ │ │ │ │ +// first get cone into status required at end... │ │ │ │ │ │ +00564 │ │ │ │ │ │ +if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ +00565 │ │ │ │ │ │ +// update cone │ │ │ │ │ │ +00566 │ │ │ │ │ │ +cone -= (*child); │ │ │ │ │ │ +00567 │ │ │ │ │ │ +00568 │ │ │ │ │ │ +// update info on particles inside │ │ │ │ │ │ +00569 │ │ │ │ │ │ +centre->is_inside->cone = false; │ │ │ │ │ │ +00570 │ │ │ │ │ │ +00571 │ │ │ │ │ │ +// update stability check quantities │ │ │ │ │ │ +00572 │ │ │ │ │ │ +dpt += fabs(child->px)+fabs(child->py); //child->perp2(); │ │ │ │ │ │ +00573 │ │ │ │ │ │ +} │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.22 quadtree.cpp │ │ │ │ │ │ + 5.16 protocones.cpp │ │ │ │ │ │ │ │ │ │ │ │ -00277 inline double get_distance(const CSph3vector *v1, const CSph3vector *v2){ │ │ │ │ │ │ -00278 │ │ │ │ │ │ -return atan2(sqrt(norm2_cross_product3(*v1,*v2)), dot_product3(*v1,*v2)); │ │ │ │ │ │ -00279 } │ │ │ │ │ │ -00280 │ │ │ │ │ │ -00289 inline bool is_closer(const CSph3vector *v1, const CSph3vector *v2, const double tan2R){ │ │ │ │ │ │ -00290 │ │ │ │ │ │ -double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ -00291 │ │ │ │ │ │ -return (dot>=0) && (norm2_cross_product3(*v1,*v2)<=tan2R*dot*dot); │ │ │ │ │ │ -00292 } │ │ │ │ │ │ +00574 │ │ │ │ │ │ +00575 │ │ │ │ │ │ +00576 │ │ │ │ │ │ +00577 │ │ │ │ │ │ +00578 │ │ │ │ │ │ +00579 │ │ │ │ │ │ +00580 │ │ │ │ │ │ +00581 │ │ │ │ │ │ +00582 │ │ │ │ │ │ +00583 │ │ │ │ │ │ +00584 │ │ │ │ │ │ +00585 │ │ │ │ │ │ +00586 │ │ │ │ │ │ +00587 │ │ │ │ │ │ +00588 │ │ │ │ │ │ +00589 │ │ │ │ │ │ +00590 │ │ │ │ │ │ +00591 │ │ │ │ │ │ +00592 │ │ │ │ │ │ +00593 │ │ │ │ │ │ +00594 │ │ │ │ │ │ +00595 │ │ │ │ │ │ +00596 │ │ │ │ │ │ +00597 │ │ │ │ │ │ +00598 │ │ │ │ │ │ +00599 │ │ │ │ │ │ +00600 │ │ │ │ │ │ +00601 │ │ │ │ │ │ +00602 │ │ │ │ │ │ +00603 │ │ │ │ │ │ +00604 │ │ │ │ │ │ +00605 │ │ │ │ │ │ +00606 │ │ │ │ │ │ +00607 │ │ │ │ │ │ +00608 │ │ │ │ │ │ +00609 │ │ │ │ │ │ +00610 │ │ │ │ │ │ +00611 │ │ │ │ │ │ +00612 │ │ │ │ │ │ +00613 │ │ │ │ │ │ +00614 │ │ │ │ │ │ +00615 │ │ │ │ │ │ +00616 │ │ │ │ │ │ +00617 │ │ │ │ │ │ +00618 │ │ │ │ │ │ +00619 │ │ │ │ │ │ +00620 │ │ │ │ │ │ +00621 │ │ │ │ │ │ +00622 │ │ │ │ │ │ +00623 │ │ │ │ │ │ +00624 │ │ │ │ │ │ +00625 │ │ │ │ │ │ +00626 │ │ │ │ │ │ +00627 │ │ │ │ │ │ +00628 │ │ │ │ │ │ +00629 │ │ │ │ │ │ +00630 │ │ │ │ │ │ +00631 │ │ │ │ │ │ +00632 │ │ │ │ │ │ +00633 │ │ │ │ │ │ +00634 │ │ │ │ │ │ +00635 │ │ │ │ │ │ +00636 │ │ │ │ │ │ +00637 │ │ │ │ │ │ +00638 │ │ │ │ │ │ +00639 │ │ │ │ │ │ +00640 │ │ │ │ │ │ +00641 │ │ │ │ │ │ +00642 │ │ │ │ │ │ +00643 │ │ │ │ │ │ +00644 │ │ │ │ │ │ +00645 │ │ │ │ │ │ +00646 │ │ │ │ │ │ +00647 │ │ │ │ │ │ +00648 │ │ │ │ │ │ +00649 │ │ │ │ │ │ +00650 │ │ │ │ │ │ +00651 │ │ │ │ │ │ +00652 │ │ │ │ │ │ +00653 │ │ │ │ │ │ +00654 │ │ │ │ │ │ +00655 │ │ │ │ │ │ +00656 │ │ │ │ │ │ +00657 │ │ │ │ │ │ +00658 │ │ │ │ │ │ +00659 │ │ │ │ │ │ +00660 │ │ │ │ │ │ + │ │ │ │ │ │ +// now establish the list of unique children in the list │ │ │ │ │ │ +// first make sure parent and child are in! │ │ │ │ │ │ +list removed_from_cone; │ │ │ │ │ │ +list put_in_border; │ │ │ │ │ │ +list border_list; │ │ │ │ │ │ +Cmomentum cone_removal; │ │ │ │ │ │ +Cmomentum border = *parent; │ │ │ │ │ │ +border_list.push_back(parent); │ │ │ │ │ │ +// make sure child appears in the border region │ │ │ │ │ │ +centre->cocircular.push_back(centre); │ │ │ │ │ │ +// now establish the full contents of the cone minus the cocircular │ │ │ │ │ │ +// region and of the cocircular region itself │ │ │ │ │ │ +for(list::iterator it = centre->cocircular.begin(); │ │ │ │ │ │ +it != centre->cocircular.end(); it++) { │ │ │ │ │ │ +if ((*it)->is_inside->cone) { │ │ │ │ │ │ +cone_removal │ │ │ │ │ │ ++= *((*it)->v); │ │ │ │ │ │ +(*it)->is_inside->cone = false; │ │ │ │ │ │ +removed_from_cone.push_back((*it)->is_inside); │ │ │ │ │ │ +} │ │ │ │ │ │ +// if a point appears twice (i.e. with + and - sign) in the list of │ │ │ │ │ │ +// points on the border, we take care not to include it twice. │ │ │ │ │ │ +// Note that this situation may appear when a point is at a distance │ │ │ │ │ │ +// close to 2R from the parent │ │ │ │ │ │ +if (!(*it)->is_inside->cocirc) { │ │ │ │ │ │ +border += *((*it)->v); │ │ │ │ │ │ +(*it)->is_inside->cocirc = true; │ │ │ │ │ │ +put_in_border.push_back((*it)->is_inside); │ │ │ │ │ │ +border_list.push_back((*it)->v); │ │ │ │ │ │ +} │ │ │ │ │ │ +} │ │ │ │ │ │ + │ │ │ │ │ │ +// figure out whether this pairing has been observed before │ │ │ │ │ │ +Cmomentum borderless_cone = cone; │ │ │ │ │ │ +borderless_cone -= cone_removal; │ │ │ │ │ │ +bool consider = true; │ │ │ │ │ │ +for (unsigned int i=0;i(borderless_cone.ref, │ │ │ │ │ │ +border.ref)); │ │ │ │ │ │ +// first figure out whether our cone momentum is good │ │ │ │ │ │ +double local_dpt = fabs(cone_removal.px) + fabs(cone_removal.py); │ │ │ │ │ │ +double total_dpt = dpt + local_dpt; │ │ │ │ │ │ +recompute_cone_contents_if_needed(borderless_cone, total_dpt); │ │ │ │ │ │ +if (total_dpt == 0) { │ │ │ │ │ │ +// a recomputation has taken place -- so take advantage of this │ │ │ │ │ │ +// and update the member cone momentum │ │ │ │ │ │ +cone = borderless_cone + cone_removal; │ │ │ │ │ │ +dpt = local_dpt; │ │ │ │ │ │ +} │ │ │ │ │ │ +test_cone_cocircular(borderless_cone, border_list); │ │ │ │ │ │ +} │ │ │ │ │ │ + │ │ │ │ │ │ +// relabel things that were in the cone but got removed │ │ │ │ │ │ +for(list::iterator is_in = removed_from_cone.begin(); │ │ │ │ │ │ +is_in != removed_from_cone.end(); is_in++) { │ │ │ │ │ │ +(*is_in)->cone = true; │ │ │ │ │ │ +} │ │ │ │ │ │ +// relabel things that got put into the border │ │ │ │ │ │ +for(list::iterator is_in = put_in_border.begin(); │ │ │ │ │ │ +is_in != put_in_border.end(); is_in++) { │ │ │ │ │ │ +(*is_in)->cocirc = false; │ │ │ │ │ │ +} │ │ │ │ │ │ +// we’re done with everything -- return true to signal to user that we’ve │ │ │ │ │ │ +// been through the co-circularity rigmarole │ │ │ │ │ │ +return true; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +209 │ │ │ │ │ │ + │ │ │ │ │ │ + 210 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00661 } │ │ │ │ │ │ +00662 │ │ │ │ │ │ +00663 │ │ │ │ │ │ +00665 // RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ +// │ │ │ │ │ │ +00666 // - compute_cone_contents() │ │ │ │ │ │ +// │ │ │ │ │ │ +00667 // - recompute_cone_contents() │ │ │ │ │ │ +// │ │ │ │ │ │ +00668 // - recompute_cone_contents_if_needed() │ │ │ │ │ │ +// │ │ │ │ │ │ +00670 │ │ │ │ │ │ +00679 void Cstable_cones::compute_cone_contents() { │ │ │ │ │ │ +00680 │ │ │ │ │ │ +circulator::iterator > │ │ │ │ │ │ +00681 │ │ │ │ │ │ +start(vicinity.begin()+first_cone, vicinity.begin(), vicinity.end()); │ │ │ │ │ │ +00682 │ │ │ │ │ │ +00683 │ │ │ │ │ │ +circulator::iterator > here(start); │ │ │ │ │ │ +00684 │ │ │ │ │ │ +00685 │ │ │ │ │ │ +// note that in the following algorithm, the cone contents never includes │ │ │ │ │ │ +00686 │ │ │ │ │ │ +// the child. Indeed, if it has positive sign, then it will be set as │ │ │ │ │ │ +00687 │ │ │ │ │ │ +// outside at the last step in the loop. If it has negative sign, then the │ │ │ │ │ │ +00688 │ │ │ │ │ │ +// loop will at some point go to the corresponding situation with positive │ │ │ │ │ │ +00689 │ │ │ │ │ │ +// sign and set the inclusion status to 0. │ │ │ │ │ │ +00690 │ │ │ │ │ │ +00691 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00692 │ │ │ │ │ │ +// as we leave this position a particle enters if its side is │ │ │ │ │ │ +00693 │ │ │ │ │ │ +// negative (i.e. the centre is the one at -ve angle wrt to the │ │ │ │ │ │ +00694 │ │ │ │ │ │ +// parent-child line │ │ │ │ │ │ +00695 │ │ │ │ │ │ +if (!(*here())->side) ((*here())->is_inside->cone) = 1; │ │ │ │ │ │ +00696 │ │ │ │ │ │ +00697 │ │ │ │ │ │ +// move on to the next position │ │ │ │ │ │ +00698 │ │ │ │ │ │ +++here; │ │ │ │ │ │ +00699 │ │ │ │ │ │ +00700 │ │ │ │ │ │ +// as we arrive at this position a particle leaves if its side is positive │ │ │ │ │ │ +00701 │ │ │ │ │ │ +if ((*here())->side) ((*here())->is_inside->cone) = 0; │ │ │ │ │ │ +00702 │ │ │ │ │ │ +} while (here != start); │ │ │ │ │ │ +00703 │ │ │ │ │ │ +00704 │ │ │ │ │ │ +// once we’ve reached the start the ’is_inside’ information should be │ │ │ │ │ │ +00705 │ │ │ │ │ │ +// 100% complete, so we can use it to calculate the cone contents │ │ │ │ │ │ +00706 │ │ │ │ │ │ +// and then exit │ │ │ │ │ │ +00707 │ │ │ │ │ │ +recompute_cone_contents(); │ │ │ │ │ │ +00708 │ │ │ │ │ │ +return; │ │ │ │ │ │ +00709 │ │ │ │ │ │ +00710 } │ │ │ │ │ │ +00711 │ │ │ │ │ │ +00712 │ │ │ │ │ │ +00713 /* │ │ │ │ │ │ +00714 * compute the cone momentum from particle list. │ │ │ │ │ │ +00715 * in this version, we use the ’pincluded’ information │ │ │ │ │ │ +00716 * from the Cvicinity class │ │ │ │ │ │ +00717 */ │ │ │ │ │ │ +00718 void Cstable_cones::recompute_cone_contents(){ │ │ │ │ │ │ +00719 │ │ │ │ │ │ +unsigned int i; │ │ │ │ │ │ +00720 │ │ │ │ │ │ +00721 │ │ │ │ │ │ +// set momentum to 0 │ │ │ │ │ │ +00722 │ │ │ │ │ │ +cone = Cmomentum(); │ │ │ │ │ │ +00723 │ │ │ │ │ │ +00724 │ │ │ │ │ │ +// Important note: we can browse only the particles │ │ │ │ │ │ +00725 │ │ │ │ │ │ +// in vicinity since all particles in the cone are │ │ │ │ │ │ +00726 │ │ │ │ │ │ +// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ +00727 │ │ │ │ │ │ +// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ +00728 │ │ │ │ │ │ +// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ +00729 │ │ │ │ │ │ +for (i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ +00732 │ │ │ │ │ │ +cone += *vicinity[i]->v; │ │ │ │ │ │ +00733 │ │ │ │ │ │ +} │ │ │ │ │ │ +00734 │ │ │ │ │ │ +00735 │ │ │ │ │ │ +// set check variables back to 0 │ │ │ │ │ │ +00736 │ │ │ │ │ │ +dpt = 0.0; │ │ │ │ │ │ +00737 } │ │ │ │ │ │ +00738 │ │ │ │ │ │ +00739 │ │ │ │ │ │ +00740 /* │ │ │ │ │ │ +00741 * if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ +00742 * the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ +00743 * ’pincluded’ information from the Cvicinity class, but we don’t │ │ │ │ │ │ +00744 * change the member cone, only the locally supplied one │ │ │ │ │ │ +00745 */ │ │ │ │ │ │ +00746 void Cstable_cones::recompute_cone_contents_if_needed(Cmomentum & this_cone, │ │ │ │ │ │ +00747 │ │ │ │ │ │ +double & this_dpt){ │ │ │ │ │ │ +00748 │ │ │ │ │ │ +00749 │ │ │ │ │ │ +if (this_dpt > PT_TSHOLD*(fabs(this_cone.px)+fabs(this_cone.py))) { │ │ │ │ │ │ +00750 │ │ │ │ │ │ +if (cone.ref.is_empty()) { │ │ │ │ │ │ +00751 │ │ │ │ │ │ +this_cone = Cmomentum(); │ │ │ │ │ │ +00752 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00753 │ │ │ │ │ │ +// set momentum to 0 │ │ │ │ │ │ +00754 │ │ │ │ │ │ +this_cone = Cmomentum(); │ │ │ │ │ │ +00755 │ │ │ │ │ │ +00756 │ │ │ │ │ │ +// Important note: we can browse only the particles │ │ │ │ │ │ +00757 │ │ │ │ │ │ +// in vicinity since all particles in the this_cone are │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.16 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00758 │ │ │ │ │ │ +// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ +00759 │ │ │ │ │ │ +// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ +00760 │ │ │ │ │ │ +// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ +00761 │ │ │ │ │ │ +for (unsigned int i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ +00764 │ │ │ │ │ │ +this_cone += *vicinity[i]->v; │ │ │ │ │ │ +00765 │ │ │ │ │ │ +} │ │ │ │ │ │ +00766 │ │ │ │ │ │ +00767 │ │ │ │ │ │ +} │ │ │ │ │ │ +00768 │ │ │ │ │ │ +// set check variables back to 0 │ │ │ │ │ │ +00769 │ │ │ │ │ │ +this_dpt = 0.0; │ │ │ │ │ │ +00770 │ │ │ │ │ │ +} │ │ │ │ │ │ +00771 │ │ │ │ │ │ +00772 } │ │ │ │ │ │ +00773 │ │ │ │ │ │ +00774 │ │ │ │ │ │ +00776 // VARIOUS TOOLS │ │ │ │ │ │ +// │ │ │ │ │ │ +00777 // - circle_intersect() │ │ │ │ │ │ +// │ │ │ │ │ │ +00778 // - is_inside() │ │ │ │ │ │ +// │ │ │ │ │ │ +00779 // - abs_dangle() │ │ │ │ │ │ +// │ │ │ │ │ │ +00781 │ │ │ │ │ │ +00782 │ │ │ │ │ │ +00783 /* │ │ │ │ │ │ +00784 * circle intersection. │ │ │ │ │ │ +00785 * computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ +00786 * The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ +00787 * - cx │ │ │ │ │ │ +circle centre x coordinate │ │ │ │ │ │ +00788 * - cy │ │ │ │ │ │ +circle centre y coordinate │ │ │ │ │ │ +00789 * return the checkxor for the intersection │ │ │ │ │ │ +00790 ******************************************************************/ │ │ │ │ │ │ +00791 Creference Cstable_cones::circle_intersect(double cx, double cy){ │ │ │ │ │ │ +00792 │ │ │ │ │ │ +Creference intersection; │ │ │ │ │ │ +00793 │ │ │ │ │ │ +int i; │ │ │ │ │ │ +00794 │ │ │ │ │ │ +double dx, dy; │ │ │ │ │ │ +00795 │ │ │ │ │ │ +00796 │ │ │ │ │ │ +for (i=0;iM_PI) │ │ │ │ │ │ +00803 │ │ │ │ │ │ +dy -= twopi; │ │ │ │ │ │ +00804 │ │ │ │ │ │ +00805 │ │ │ │ │ │ +// really check if the distance is less than VR │ │ │ │ │ │ +00806 │ │ │ │ │ │ +if (dx*dx+dy*dyeta - v->eta; │ │ │ │ │ │ +00825 │ │ │ │ │ │ +dy = fabs(centre_in->phi - v->phi); │ │ │ │ │ │ +00826 │ │ │ │ │ │ +if (dy>M_PI) │ │ │ │ │ │ +00827 │ │ │ │ │ │ +dy -= twopi; │ │ │ │ │ │ +00828 │ │ │ │ │ │ +00829 │ │ │ │ │ │ +return dx*dx+dy*dyM_PI) │ │ │ │ │ │ +00844 │ │ │ │ │ │ +dphi = dphi-twopi; │ │ │ │ │ │ +00845 │ │ │ │ │ │ +00846 │ │ │ │ │ │ +return dphi; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +211 │ │ │ │ │ │ + │ │ │ │ │ │ + 212 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00847 } │ │ │ │ │ │ +00848 │ │ │ │ │ │ +00849 } │ │ │ │ │ │ + │ │ │ │ │ │ +5.17 │ │ │ │ │ │ + │ │ │ │ │ │ +protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00001 │ │ │ │ │ │ +00002 // File: protocones.cpp │ │ │ │ │ │ +// │ │ │ │ │ │ +00003 // Description: source file for stable cones determination (Cstable_cones) │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // │ │ │ │ │ │ +an adaptation to spherical coordinates │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +// │ │ │ │ │ │ +00010 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00023 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00024 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00025 // $Revision:: 311 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00026 // $Date:: 2011-10-05 23:27:09 +0200 (Wed, 05 Oct 2011) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00028 │ │ │ │ │ │ +00029 /******************************************************* │ │ │ │ │ │ +00030 * Introductory note: │ │ │ │ │ │ +* │ │ │ │ │ │ +00031 * Since this file has many member functions, we have * │ │ │ │ │ │ +00032 * structured them in categories: │ │ │ │ │ │ +* │ │ │ │ │ │ +00033 * INITIALISATION FUNCTIONS │ │ │ │ │ │ +* │ │ │ │ │ │ +00034 * - ctor() │ │ │ │ │ │ +* │ │ │ │ │ │ +00035 * - ctor(particle_list) │ │ │ │ │ │ +* │ │ │ │ │ │ +00036 * - dtor() │ │ │ │ │ │ +* │ │ │ │ │ │ +00037 * - init(particle_list) │ │ │ │ │ │ +* │ │ │ │ │ │ +00038 * ALGORITHM MAIN ENTRY │ │ │ │ │ │ +* │ │ │ │ │ │ +00039 * - get_stable_cone(radius) │ │ │ │ │ │ +* │ │ │ │ │ │ +00040 * ALGORITHM MAIN STEPS │ │ │ │ │ │ +* │ │ │ │ │ │ +00041 * - init_cone() │ │ │ │ │ │ +* │ │ │ │ │ │ +00042 * - test_cone() │ │ │ │ │ │ +* │ │ │ │ │ │ +00043 * - update_cone() │ │ │ │ │ │ +* │ │ │ │ │ │ +00044 * - proceed_with_stability() │ │ │ │ │ │ +* │ │ │ │ │ │ +00045 * ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ +* │ │ │ │ │ │ +00046 * - cocircular_pt_less(v1, v2) │ │ │ │ │ │ +* │ │ │ │ │ │ +00047 * - prepare_cocircular_list() │ │ │ │ │ │ +* │ │ │ │ │ │ +00048 * - test_cone_cocircular() │ │ │ │ │ │ +* │ │ │ │ │ │ +00049 * - test_stability(candidate, border_list) │ │ │ │ │ │ +* │ │ │ │ │ │ +00050 * - updat_cone_cocircular() │ │ │ │ │ │ +* │ │ │ │ │ │ +00051 * RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ +* │ │ │ │ │ │ +00052 * - compute_cone_contents() │ │ │ │ │ │ +* │ │ │ │ │ │ +00053 * - recompute_cone_contents() │ │ │ │ │ │ +* │ │ │ │ │ │ +00054 * - recompute_cone_contents_if_needed() │ │ │ │ │ │ +* │ │ │ │ │ │ +00055 * VARIOUS TOOLS │ │ │ │ │ │ +* │ │ │ │ │ │ +00056 * - circle_intersect() │ │ │ │ │ │ +* │ │ │ │ │ │ +00057 * - is_inside() │ │ │ │ │ │ +* │ │ │ │ │ │ +00058 * - abs_dangle() │ │ │ │ │ │ +* │ │ │ │ │ │ +00059 *******************************************************/ │ │ │ │ │ │ +00060 │ │ │ │ │ │ +00061 #include │ │ │ │ │ │ +00062 #include │ │ │ │ │ │ +00063 #include │ │ │ │ │ │ +00064 #include "protocones.h" │ │ │ │ │ │ +00065 #include │ │ │ │ │ │ +00066 #include │ │ │ │ │ │ +00067 #include │ │ │ │ │ │ +00068 │ │ │ │ │ │ +00069 namespace siscone_spherical{ │ │ │ │ │ │ +00070 │ │ │ │ │ │ +00071 using namespace std; │ │ │ │ │ │ +00072 │ │ │ │ │ │ +00073 /********************************************************************** │ │ │ │ │ │ +00074 * CSphstable_cones implementation │ │ │ │ │ │ +* │ │ │ │ │ │ +00075 * Computes the list of stable comes from a particle list. │ │ │ │ │ │ +* │ │ │ │ │ │ +00076 * This class does the first fundamental task of te cone algorithm: │ │ │ │ │ │ +* │ │ │ │ │ │ +00077 * it is used to compute the list of stable cones given a list │ │ │ │ │ │ +* │ │ │ │ │ │ +00078 * of particles. │ │ │ │ │ │ +* │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.17 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00079 **********************************************************************/ │ │ │ │ │ │ +00080 │ │ │ │ │ │ +00082 // INITIALISATION FUNCTIONS │ │ │ │ │ │ +// │ │ │ │ │ │ +00083 // - ctor() │ │ │ │ │ │ +// │ │ │ │ │ │ +00084 // - ctor(particle_list) │ │ │ │ │ │ +// │ │ │ │ │ │ +00085 // - dtor() │ │ │ │ │ │ +// │ │ │ │ │ │ +00086 // - init(particle_list) │ │ │ │ │ │ +// │ │ │ │ │ │ +00088 │ │ │ │ │ │ +00089 // default ctor │ │ │ │ │ │ +00090 //-------------00091 CSphstable_cones::CSphstable_cones(){ │ │ │ │ │ │ +00092 │ │ │ │ │ │ +nb_tot = 0; │ │ │ │ │ │ +00093 │ │ │ │ │ │ +hc = NULL; │ │ │ │ │ │ +00094 } │ │ │ │ │ │ +00095 │ │ │ │ │ │ +00096 // ctor with initialisation │ │ │ │ │ │ +00097 //-------------------------00098 CSphstable_cones::CSphstable_cones(vector &_particle_list) │ │ │ │ │ │ +00099 │ │ │ │ │ │ +: CSphvicinity(_particle_list){ │ │ │ │ │ │ +00100 │ │ │ │ │ │ +00101 │ │ │ │ │ │ +nb_tot = 0; │ │ │ │ │ │ +00102 │ │ │ │ │ │ +hc = NULL; │ │ │ │ │ │ +00103 } │ │ │ │ │ │ +00104 │ │ │ │ │ │ +00105 // default dtor │ │ │ │ │ │ +00106 //-------------00107 CSphstable_cones::~CSphstable_cones(){ │ │ │ │ │ │ +00108 │ │ │ │ │ │ +if (hc!=NULL) delete hc; │ │ │ │ │ │ +00109 } │ │ │ │ │ │ +00110 │ │ │ │ │ │ +00111 /* │ │ │ │ │ │ +00112 * initialisation │ │ │ │ │ │ +00113 * - _particle_list list of particles │ │ │ │ │ │ +00114 * - _n │ │ │ │ │ │ +number of particles │ │ │ │ │ │ +00115 *********************************************************************/ │ │ │ │ │ │ +00116 void CSphstable_cones::init(vector &_particle_list){ │ │ │ │ │ │ +00117 │ │ │ │ │ │ +// check already allocated mem │ │ │ │ │ │ +00118 │ │ │ │ │ │ +if (hc!=NULL){ │ │ │ │ │ │ +00119 │ │ │ │ │ │ +delete hc; │ │ │ │ │ │ +00120 │ │ │ │ │ │ +} │ │ │ │ │ │ +00121 │ │ │ │ │ │ +if (protocones.size()!=0) │ │ │ │ │ │ +00122 │ │ │ │ │ │ +protocones.clear(); │ │ │ │ │ │ +00123 │ │ │ │ │ │ +00124 │ │ │ │ │ │ +multiple_centre_done.clear(); │ │ │ │ │ │ +00125 │ │ │ │ │ │ +00126 │ │ │ │ │ │ +// initialisation │ │ │ │ │ │ +00127 │ │ │ │ │ │ +set_particle_list(_particle_list); │ │ │ │ │ │ +00128 } │ │ │ │ │ │ +00129 │ │ │ │ │ │ +00130 │ │ │ │ │ │ +00132 // ALGORITHM MAIN ENTRY │ │ │ │ │ │ +// │ │ │ │ │ │ +00133 // - get_stable_cone(radius) │ │ │ │ │ │ +// │ │ │ │ │ │ +00135 │ │ │ │ │ │ +00136 /* │ │ │ │ │ │ +00137 * compute stable cones. │ │ │ │ │ │ +00138 * This function really does the job i.e. computes │ │ │ │ │ │ +00139 * the list of stable cones (in a seedless way) │ │ │ │ │ │ +00140 * - _radius: radius of the cones │ │ │ │ │ │ +00141 * The number of stable cones found is returned │ │ │ │ │ │ +00142 *********************************************************************/ │ │ │ │ │ │ +00143 int CSphstable_cones::get_stable_cones(double _radius){ │ │ │ │ │ │ +00144 │ │ │ │ │ │ +int p_idx; │ │ │ │ │ │ +00145 │ │ │ │ │ │ +00146 │ │ │ │ │ │ +// check if everything is correctly initialised │ │ │ │ │ │ +00147 │ │ │ │ │ │ +if (n_part==0){ │ │ │ │ │ │ +00148 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00149 │ │ │ │ │ │ +} │ │ │ │ │ │ +00150 │ │ │ │ │ │ +00151 │ │ │ │ │ │ +R = _radius; │ │ │ │ │ │ +00152 │ │ │ │ │ │ +R2 = R*R; │ │ │ │ │ │ +00153 │ │ │ │ │ │ +tan2R = tan(R); │ │ │ │ │ │ +00154 │ │ │ │ │ │ +tan2R *= tan2R; │ │ │ │ │ │ +00155 │ │ │ │ │ │ +00156 │ │ │ │ │ │ +// allow hash for cones candidates │ │ │ │ │ │ +00157 │ │ │ │ │ │ +hc = new sph_hash_cones(n_part, R); │ │ │ │ │ │ +00158 │ │ │ │ │ │ +00159 │ │ │ │ │ │ +// browse all particles │ │ │ │ │ │ +00160 │ │ │ │ │ │ +for (p_idx=0;p_idx_phi « ", " « parent->_theta « endl; │ │ │ │ │ │ +00177 #endif │ │ │ │ │ │ +00178 │ │ │ │ │ │ +00179 │ │ │ │ │ │ +// step 1: initialise with the first cone candidate │ │ │ │ │ │ +00180 │ │ │ │ │ │ +init_cone(); │ │ │ │ │ │ +00181 │ │ │ │ │ │ +00182 │ │ │ │ │ │ +do{ │ │ │ │ │ │ +00183 │ │ │ │ │ │ +// step 2: test cone stability for that pair (P,C) │ │ │ │ │ │ +00184 │ │ │ │ │ │ +test_cone(); │ │ │ │ │ │ +00185 │ │ │ │ │ │ +00186 │ │ │ │ │ │ +// step 3: go to the next cone child candidate C │ │ │ │ │ │ +00187 │ │ │ │ │ │ +} while (!update_cone()); │ │ │ │ │ │ +00188 │ │ │ │ │ │ +} │ │ │ │ │ │ +00189 │ │ │ │ │ │ +00190 │ │ │ │ │ │ +return proceed_with_stability(); │ │ │ │ │ │ +00191 } │ │ │ │ │ │ +00192 │ │ │ │ │ │ +00193 │ │ │ │ │ │ +00195 // ALGORITHM MAIN STEPS │ │ │ │ │ │ +// │ │ │ │ │ │ +00196 // - init_cone() │ │ │ │ │ │ +// │ │ │ │ │ │ +00197 // - test_cone() │ │ │ │ │ │ +// │ │ │ │ │ │ +00198 // - update_cone() │ │ │ │ │ │ +// │ │ │ │ │ │ +00199 // - proceed_with_stability() │ │ │ │ │ │ +// │ │ │ │ │ │ +00201 │ │ │ │ │ │ +00202 /* │ │ │ │ │ │ +00203 * initialise the cone. │ │ │ │ │ │ +00204 * We take the first particle in the angular ordering to compute │ │ │ │ │ │ +00205 * this one │ │ │ │ │ │ +00206 * return 0 on success, 1 on error │ │ │ │ │ │ +00207 *********************************************************************/ │ │ │ │ │ │ +00208 int CSphstable_cones::init_cone(){ │ │ │ │ │ │ +00209 │ │ │ │ │ │ +// The previous version of the algorithm was starting the │ │ │ │ │ │ +00210 │ │ │ │ │ │ +// loop around vicinity elements with the "most isolated" child. │ │ │ │ │ │ +00211 │ │ │ │ │ │ +// given the nodist method to calculate the cone contents, we no │ │ │ │ │ │ +00212 │ │ │ │ │ │ +// longer need to worry about which cone comes first... │ │ │ │ │ │ +00213 │ │ │ │ │ │ +first_cone=0; │ │ │ │ │ │ +00214 │ │ │ │ │ │ +00215 │ │ │ │ │ │ +// now make sure we have lists of the cocircular particles │ │ │ │ │ │ +00216 │ │ │ │ │ │ +prepare_cocircular_lists(); │ │ │ │ │ │ +00217 │ │ │ │ │ │ +00218 │ │ │ │ │ │ +//TODO? deal with a configuration with only degeneracies ? │ │ │ │ │ │ +00219 │ │ │ │ │ │ +// The only possibility seems a regular hexagon with a parent point │ │ │ │ │ │ +00220 │ │ │ │ │ │ +// in the centre. And this situation is by itself unclear. │ │ │ │ │ │ +00221 │ │ │ │ │ │ +// Hence, we do nothing here ! │ │ │ │ │ │ +00222 │ │ │ │ │ │ +00223 │ │ │ │ │ │ +// init set child C │ │ │ │ │ │ +00224 │ │ │ │ │ │ +centre = vicinity[first_cone]; │ │ │ │ │ │ +00225 │ │ │ │ │ │ +child = centre->v; │ │ │ │ │ │ +00226 │ │ │ │ │ │ +centre_idx = first_cone; │ │ │ │ │ │ +00227 │ │ │ │ │ │ +00228 │ │ │ │ │ │ +// build the initial cone (nodist: avoids calculating distances -00229 │ │ │ │ │ │ +// just deduces contents by circulating around all in/out operations) │ │ │ │ │ │ +00230 │ │ │ │ │ │ +// this function also sets the list of included particles │ │ │ │ │ │ +00231 │ │ │ │ │ │ +compute_cone_contents(); │ │ │ │ │ │ +00232 │ │ │ │ │ │ +00233 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00234 } │ │ │ │ │ │ +00235 │ │ │ │ │ │ +00236 │ │ │ │ │ │ +00237 /* │ │ │ │ │ │ +00238 * test cones. │ │ │ │ │ │ +00239 * We check if the cone(s) built with the present parent and child │ │ │ │ │ │ +00240 * are stable │ │ │ │ │ │ +00241 * return 0 on success 1 on error │ │ │ │ │ │ +00242 *********************************************************************/ │ │ │ │ │ │ +00243 int CSphstable_cones::test_cone(){ │ │ │ │ │ │ +00244 │ │ │ │ │ │ +siscone::Creference weighted_cone_ref; │ │ │ │ │ │ +00245 │ │ │ │ │ │ +00246 │ │ │ │ │ │ +// depending on the side we are taking the child particle, │ │ │ │ │ │ +00247 │ │ │ │ │ │ +// we test different configuration. │ │ │ │ │ │ +00248 │ │ │ │ │ │ +// Each time, two configurations are tested in such a way that │ │ │ │ │ │ +00249 │ │ │ │ │ │ +// all 4 possible cases (parent or child in or out the cone) │ │ │ │ │ │ +00250 │ │ │ │ │ │ +// are tested when taking the pair of particle parent+child │ │ │ │ │ │ +00251 │ │ │ │ │ │ +// and child+parent. │ │ │ │ │ │ +00252 │ │ │ │ │ │ +00253 │ │ │ │ │ │ +// here are the tests entering the first series: │ │ │ │ │ │ +00254 │ │ │ │ │ │ +// 1. check if the cone is already inserted │ │ │ │ │ │ +00255 │ │ │ │ │ │ +// 2. check cone stability for the parent and child particles │ │ │ │ │ │ +00256 │ │ │ │ │ │ +00257 │ │ │ │ │ │ +//UPDATED(see below): if (centre->side){ │ │ │ │ │ │ +00258 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +// test when both particles are not in the cone │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.17 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00259 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +// or when both are in. │ │ │ │ │ │ +00260 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +// Note: for the totally exclusive case, test emptyness before │ │ │ │ │ │ +00261 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +cone_candidate = cone; │ │ │ │ │ │ +00262 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +if (cone.ref.not_empty()){ │ │ │ │ │ │ +00263 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ +00264 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +} │ │ │ │ │ │ +00265 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +00266 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +cone_candidate = cone; │ │ │ │ │ │ +00267 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +cone_candidate+= *parent + *child; │ │ │ │ │ │ +00268 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ +00269 │ │ │ │ │ │ +//UPDATED(see below): } else { │ │ │ │ │ │ +00270 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +// test when 1! of the particles is in the cone │ │ │ │ │ │ +00271 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +cone_candidate = cone + *parent; │ │ │ │ │ │ +00272 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, true, false); │ │ │ │ │ │ +00273 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +00274 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +cone_candidate = cone + *child; │ │ │ │ │ │ +00275 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ +00276 │ │ │ │ │ │ +//UPDATED(see below): } │ │ │ │ │ │ +00277 │ │ │ │ │ │ +//UPDATED(see below): │ │ │ │ │ │ +00278 │ │ │ │ │ │ +//UPDATED(see below): nb_tot+=2; │ │ │ │ │ │ +00279 │ │ │ │ │ │ +00280 │ │ │ │ │ │ +// instead of testing 2 inclusion/exclusion states for every pair, we test the 4 of them │ │ │ │ │ │ +00281 │ │ │ │ │ │ +// when the parent has an energy bigger than the child │ │ │ │ │ │ +00282 │ │ │ │ │ │ +if (parent->E >= child->E){ │ │ │ │ │ │ +00283 │ │ │ │ │ │ +// test when both particles are not in the cone │ │ │ │ │ │ +00284 │ │ │ │ │ │ +// Note: for the totally exclusive case, test emptiness before │ │ │ │ │ │ +00285 │ │ │ │ │ │ +cone_candidate = cone; │ │ │ │ │ │ +00286 │ │ │ │ │ │ +if (cone.ref.not_empty()){ │ │ │ │ │ │ +00287 │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ +00288 │ │ │ │ │ │ +} │ │ │ │ │ │ +00289 │ │ │ │ │ │ +00290 │ │ │ │ │ │ +// test when 1! of the particles is in the cone │ │ │ │ │ │ +00291 │ │ │ │ │ │ +cone_candidate += *parent; │ │ │ │ │ │ +00292 │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, true, false); │ │ │ │ │ │ 00293 │ │ │ │ │ │ -00299 inline bool is_closer_safer(const CSph3vector *v1, const CSph3vector *v2, const double cosR){ │ │ │ │ │ │ +00294 │ │ │ │ │ │ +cone_candidate = cone; │ │ │ │ │ │ +00295 │ │ │ │ │ │ +cone_candidate += *child; │ │ │ │ │ │ +00296 │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ +00297 │ │ │ │ │ │ +00298 │ │ │ │ │ │ +// test when both are in. │ │ │ │ │ │ +00299 │ │ │ │ │ │ +cone_candidate += *parent; │ │ │ │ │ │ 00300 │ │ │ │ │ │ -return dot_product3(*v1,*v2)>=cosR*sqrt(v1->norm2()*v2->norm2()); │ │ │ │ │ │ +hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ 00301 │ │ │ │ │ │ -//double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ 00302 │ │ │ │ │ │ -//return (dot>=0) && (norm2_cross_product3(*v1,*v2)centre.px « "’ ’" │ │ │ │ │ │ +00318 │ │ │ │ │ │ +« centre->centre.py « "’ ’" « centre->centre.pz « "’" « endl │ │ │ │ │ │ +00319 │ │ │ │ │ │ +« "pause -1 ’(" « centre->angle « " " « (centre->side ? ’+’ : ’-’) « ")"; │ │ │ │ │ │ +00320 #endif │ │ │ │ │ │ +00321 │ │ │ │ │ │ +00322 │ │ │ │ │ │ +// get the next child and centre │ │ │ │ │ │ +00323 │ │ │ │ │ │ +centre_idx++; │ │ │ │ │ │ +00324 │ │ │ │ │ │ +if (centre_idx==vicinity_size) │ │ │ │ │ │ +00325 │ │ │ │ │ │ +centre_idx=0; │ │ │ │ │ │ +00326 │ │ │ │ │ │ +if (centre_idx==first_cone) │ │ │ │ │ │ +00327 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ +00328 │ │ │ │ │ │ +00329 │ │ │ │ │ │ +// update the cone w.r.t. the old child │ │ │ │ │ │ +00330 │ │ │ │ │ │ +// only required if the old child is entering inside in which │ │ │ │ │ │ +00331 │ │ │ │ │ │ +// case we need to add it. We also know that the child is │ │ │ │ │ │ +00332 │ │ │ │ │ │ +// inside iff its side is -. │ │ │ │ │ │ +00333 │ │ │ │ │ │ +if (!centre->side){ │ │ │ │ │ │ +00334 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00335 │ │ │ │ │ │ +cout « " old_enter"; │ │ │ │ │ │ +00336 #endif │ │ │ │ │ │ +00337 │ │ │ │ │ │ +// update cone │ │ │ │ │ │ +00338 │ │ │ │ │ │ +cone += (*child); │ │ │ │ │ │ +00339 │ │ │ │ │ │ +00340 │ │ │ │ │ │ +// update info on particles inside │ │ │ │ │ │ +00341 │ │ │ │ │ │ +centre->is_inside->cone = true; │ │ │ │ │ │ +00342 │ │ │ │ │ │ +00343 │ │ │ │ │ │ +// update stability check quantities │ │ │ │ │ │ +00344 │ │ │ │ │ │ +dpt += fabs(child->px)+fabs(child->py)+fabs(child->pz); │ │ │ │ │ │ +00345 │ │ │ │ │ │ +} │ │ │ │ │ │ │ │ │ │ │ │ -5.22 │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +215 │ │ │ │ │ │ + │ │ │ │ │ │ + 216 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00346 │ │ │ │ │ │ +00347 │ │ │ │ │ │ +// update centre and child to correspond to the new position │ │ │ │ │ │ +00348 │ │ │ │ │ │ +centre = vicinity[centre_idx]; │ │ │ │ │ │ +00349 │ │ │ │ │ │ +child = centre->v; │ │ │ │ │ │ +00350 │ │ │ │ │ │ +00351 │ │ │ │ │ │ +// check cocircularity │ │ │ │ │ │ +00352 │ │ │ │ │ │ +// note that if cocirculaity is detected (i.e. if we receive 1 │ │ │ │ │ │ +00353 │ │ │ │ │ │ +// in the next test), we need to recall ’update_cone’ directly │ │ │ │ │ │ +00354 │ │ │ │ │ │ +// since tests and remaining part of te update has been performed │ │ │ │ │ │ +00355 │ │ │ │ │ │ +//if (cocircular_check()) │ │ │ │ │ │ +00356 │ │ │ │ │ │ +if (cocircular_check()){ │ │ │ │ │ │ +00357 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00358 │ │ │ │ │ │ +cout « " Co-circular case detected" « endl; │ │ │ │ │ │ +00359 #endif │ │ │ │ │ │ +00360 │ │ │ │ │ │ +return update_cone(); │ │ │ │ │ │ +00361 │ │ │ │ │ │ +} │ │ │ │ │ │ +00362 │ │ │ │ │ │ +00363 │ │ │ │ │ │ +// update the cone w.r.t. the new child │ │ │ │ │ │ +00364 │ │ │ │ │ │ +// only required if the new child was already inside in which │ │ │ │ │ │ +00365 │ │ │ │ │ │ +// case we need to remove it. We also know that the child is │ │ │ │ │ │ +00366 │ │ │ │ │ │ +// inside iff its side is +. │ │ │ │ │ │ +00367 │ │ │ │ │ │ +if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ +00368 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00369 │ │ │ │ │ │ +cout « " new exit"; │ │ │ │ │ │ +00370 #endif │ │ │ │ │ │ +00371 │ │ │ │ │ │ +00372 │ │ │ │ │ │ +// update cone │ │ │ │ │ │ +00373 │ │ │ │ │ │ +cone -= (*child); │ │ │ │ │ │ +00374 │ │ │ │ │ │ +00375 │ │ │ │ │ │ +// update info on particles inside │ │ │ │ │ │ +00376 │ │ │ │ │ │ +centre->is_inside->cone = false; │ │ │ │ │ │ +00377 │ │ │ │ │ │ +00378 │ │ │ │ │ │ +// update stability check quantities │ │ │ │ │ │ +00379 │ │ │ │ │ │ +dpt += fabs(child->px)+fabs(child->py)+fabs(child->pz); //child->perp2(); │ │ │ │ │ │ +00380 │ │ │ │ │ │ +} │ │ │ │ │ │ +00381 │ │ │ │ │ │ +00382 │ │ │ │ │ │ +// check that the addition and subtraction of vectors does │ │ │ │ │ │ +00383 │ │ │ │ │ │ +// not lead to too much rounding error │ │ │ │ │ │ +00384 │ │ │ │ │ │ +// for that, we compute the sum of pt modifications and of |pt| │ │ │ │ │ │ +00385 │ │ │ │ │ │ +// since last recomputation and once the ratio overpasses a threshold │ │ │ │ │ │ +00386 │ │ │ │ │ │ +// we recompute vicinity. │ │ │ │ │ │ +00387 │ │ │ │ │ │ +if ((dpt>PT_TSHOLD*(fabs(cone.px)+fabs(cone.py)+fabs(cone.pz))) && (cone.ref.not_empty())){ │ │ │ │ │ │ +00388 │ │ │ │ │ │ +recompute_cone_contents(); │ │ │ │ │ │ +00389 │ │ │ │ │ │ +} │ │ │ │ │ │ +00390 │ │ │ │ │ │ +if (cone.ref.is_empty()){ │ │ │ │ │ │ +00391 │ │ │ │ │ │ +cone = CSphmomentum(); │ │ │ │ │ │ +00392 │ │ │ │ │ │ +dpt=0.0; │ │ │ │ │ │ +00393 │ │ │ │ │ │ +} │ │ │ │ │ │ +00394 │ │ │ │ │ │ +00395 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00396 │ │ │ │ │ │ +cout « "’" « endl; │ │ │ │ │ │ +00397 #endif │ │ │ │ │ │ +00398 │ │ │ │ │ │ +00399 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00400 } │ │ │ │ │ │ +00401 │ │ │ │ │ │ +00402 │ │ │ │ │ │ +00403 /* │ │ │ │ │ │ +00404 * compute stability of all enumerated candidates. │ │ │ │ │ │ +00405 * For all candidate cones which are stable w.r.t. their border particles, │ │ │ │ │ │ +00406 * pass the last test: stability with quadtree intersection │ │ │ │ │ │ +00407 ************************************************************************/ │ │ │ │ │ │ +00408 int CSphstable_cones::proceed_with_stability(){ │ │ │ │ │ │ +00409 │ │ │ │ │ │ +int i; │ │ │ │ │ │ +00410 │ │ │ │ │ │ +sph_hash_element *elm; │ │ │ │ │ │ +00411 │ │ │ │ │ │ +00412 │ │ │ │ │ │ +for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ +00413 │ │ │ │ │ │ +// test ith cell of the hash array │ │ │ │ │ │ +00414 │ │ │ │ │ │ +elm = hc->hash_array[i]; │ │ │ │ │ │ +00415 │ │ │ │ │ │ +00416 │ │ │ │ │ │ +// browse elements therein │ │ │ │ │ │ +00417 │ │ │ │ │ │ +while (elm!=NULL){ │ │ │ │ │ │ +00418 │ │ │ │ │ │ +// test stability │ │ │ │ │ │ +00419 │ │ │ │ │ │ +if (elm->is_stable){ │ │ │ │ │ │ +00420 │ │ │ │ │ │ +// stability is not ensured by all pairs of "edges" already browsed │ │ │ │ │ │ +00421 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ +00422 │ │ │ │ │ │ +// => testing stability with quadtree intersection │ │ │ │ │ │ +00423 │ │ │ │ │ │ +if (quadtree->circle_intersect(elm->eta, elm->phi, R2)==elm->ref) │ │ │ │ │ │ +00424 #else │ │ │ │ │ │ +00425 │ │ │ │ │ │ +// => testing stability with the particle-list intersection │ │ │ │ │ │ +00426 │ │ │ │ │ │ +if (circle_intersect(elm->centre)==elm->centre.ref) │ │ │ │ │ │ +00427 #endif │ │ │ │ │ │ +00428 │ │ │ │ │ │ +protocones.push_back(CSphmomentum(elm->centre,1.0)); │ │ │ │ │ │ +00429 │ │ │ │ │ │ +} │ │ │ │ │ │ +00430 │ │ │ │ │ │ +00431 │ │ │ │ │ │ +// jump to the next one │ │ │ │ │ │ +00432 │ │ │ │ │ │ +elm = elm->next; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.17 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00433 │ │ │ │ │ │ +} │ │ │ │ │ │ +00434 │ │ │ │ │ │ +} │ │ │ │ │ │ +00435 │ │ │ │ │ │ +00436 │ │ │ │ │ │ +// free hash │ │ │ │ │ │ +00437 │ │ │ │ │ │ +// we do that at this level because hash eats rather a lot of memory │ │ │ │ │ │ +00438 │ │ │ │ │ │ +// we want to free it before running the split/merge algorithm │ │ │ │ │ │ +00439 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00440 │ │ │ │ │ │ +nb_hash_cones = hc->n_cones; │ │ │ │ │ │ +00441 │ │ │ │ │ │ +nb_hash_occupied = hc->n_occupied_cells; │ │ │ │ │ │ +00442 #endif │ │ │ │ │ │ +00443 │ │ │ │ │ │ +00444 │ │ │ │ │ │ +delete hc; │ │ │ │ │ │ +00445 │ │ │ │ │ │ +hc=NULL; │ │ │ │ │ │ +00446 │ │ │ │ │ │ +00447 │ │ │ │ │ │ +return protocones.size(); │ │ │ │ │ │ +00448 } │ │ │ │ │ │ +00449 │ │ │ │ │ │ +00450 │ │ │ │ │ │ +00452 // ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ +// │ │ │ │ │ │ +00453 // - cocircular_pt_less(v1, v2) │ │ │ │ │ │ +// │ │ │ │ │ │ +00454 // - prepare_cocircular_list() │ │ │ │ │ │ +// │ │ │ │ │ │ +00455 // - test_cone_cocircular() │ │ │ │ │ │ +// │ │ │ │ │ │ +00456 // - test_stability(candidate, border_vect) │ │ │ │ │ │ +// │ │ │ │ │ │ +00457 // - updat_cone_cocircular() │ │ │ │ │ │ +// │ │ │ │ │ │ +00459 │ │ │ │ │ │ +00461 //NEVER USED │ │ │ │ │ │ +00462 //bool cocircular_pt_less(CSphmomentum *v1, CSphmomentum *v2){ │ │ │ │ │ │ +00463 // return v1->perp2() < v2->perp2(); │ │ │ │ │ │ +00464 //} │ │ │ │ │ │ +00465 │ │ │ │ │ │ +00466 /* │ │ │ │ │ │ +00467 * run through the vicinity of the current parent and for each child │ │ │ │ │ │ +00468 * establish which other members are cocircular... Note that the list │ │ │ │ │ │ +00469 * associated with each child contains references to vicinity │ │ │ │ │ │ +00470 * elements: thus two vicinity elements each associated with one given │ │ │ │ │ │ +00471 * particle may appear in a list -- this needs to be watched out for │ │ │ │ │ │ +00472 * later on... │ │ │ │ │ │ +00473 **********************************************************************/ │ │ │ │ │ │ +00474 void CSphstable_cones::prepare_cocircular_lists() { │ │ │ │ │ │ +00475 │ │ │ │ │ │ +siscone::circulator::iterator > here(vicinity.begin(), │ │ │ │ │ │ +00476 │ │ │ │ │ │ +vicinity.begin(), │ │ │ │ │ │ +00477 │ │ │ │ │ │ +vicinity.end()); │ │ │ │ │ │ +00478 │ │ │ │ │ │ +00479 │ │ │ │ │ │ +siscone::circulator::iterator > search(here); │ │ │ │ │ │ +00480 │ │ │ │ │ │ +00481 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00482 │ │ │ │ │ │ +CSphvicinity_elm* here_pntr = *here(); │ │ │ │ │ │ +00483 │ │ │ │ │ │ +search.set_position(here); │ │ │ │ │ │ +00484 │ │ │ │ │ │ +00485 │ │ │ │ │ │ +// search forwards for things that should have "here" included in │ │ │ │ │ │ +00486 │ │ │ │ │ │ +// their cocircularity list │ │ │ │ │ │ +00487 │ │ │ │ │ │ +while (true) { │ │ │ │ │ │ +00488 │ │ │ │ │ │ +++search; │ │ │ │ │ │ +00489 │ │ │ │ │ │ +if ( siscone::abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ +00490 │ │ │ │ │ │ +here_pntr->cocircular_range │ │ │ │ │ │ +00491 │ │ │ │ │ │ +&& search() != here()) { │ │ │ │ │ │ +00492 │ │ │ │ │ │ +(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ +00493 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00494 │ │ │ │ │ │ +break; │ │ │ │ │ │ +00495 │ │ │ │ │ │ +} │ │ │ │ │ │ +00496 │ │ │ │ │ │ +} │ │ │ │ │ │ +00497 │ │ │ │ │ │ +00498 │ │ │ │ │ │ +// search backwards │ │ │ │ │ │ +00499 │ │ │ │ │ │ +search.set_position(here); │ │ │ │ │ │ +00500 │ │ │ │ │ │ +while (true) { │ │ │ │ │ │ +00501 │ │ │ │ │ │ +--search; │ │ │ │ │ │ +00502 │ │ │ │ │ │ +if ( siscone::abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ +00503 │ │ │ │ │ │ +here_pntr->cocircular_range │ │ │ │ │ │ +00504 │ │ │ │ │ │ +&& search() != here()) { │ │ │ │ │ │ +00505 │ │ │ │ │ │ +(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ +00506 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00507 │ │ │ │ │ │ +break; │ │ │ │ │ │ +00508 │ │ │ │ │ │ +} │ │ │ │ │ │ +00509 │ │ │ │ │ │ +} │ │ │ │ │ │ +00510 │ │ │ │ │ │ +00511 │ │ │ │ │ │ +++here; │ │ │ │ │ │ +00512 │ │ │ │ │ │ +} while (here() != vicinity.begin()); │ │ │ │ │ │ +00513 } │ │ │ │ │ │ +00514 │ │ │ │ │ │ +00515 /* │ │ │ │ │ │ +00516 * Testing cocircular configurations in p^3 time, │ │ │ │ │ │ +00517 * rather than 2^p time; we will test all contiguous subsets of points │ │ │ │ │ │ +00518 * on the border --- note that this is till probably overkill, since │ │ │ │ │ │ +00519 * in principle we only have to test situations where up to a │ │ │ │ │ │ +00520 * half-circle is filled (but going to a full circle is simpler) │ │ │ │ │ │ +00521 ******************************************************************/ │ │ │ │ │ │ +00522 void CSphstable_cones::test_cone_cocircular(CSphmomentum & borderless_cone, │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +217 │ │ │ │ │ │ + │ │ │ │ │ │ + 218 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00523 │ │ │ │ │ │ +list & border_list) { │ │ │ │ │ │ +00524 │ │ │ │ │ │ +// in spherical coordinates, we don’t have a universal x-y axis system │ │ │ │ │ │ +00525 │ │ │ │ │ │ +// to measure the angles. So we first determine one minimising │ │ │ │ │ │ +00526 │ │ │ │ │ │ +// the uncertainties │ │ │ │ │ │ +00527 │ │ │ │ │ │ +CSph3vector angl_dir1, angl_dir2; │ │ │ │ │ │ +00528 │ │ │ │ │ │ +centre->centre.get_angular_directions(angl_dir1, angl_dir2); │ │ │ │ │ │ +00529 │ │ │ │ │ │ +angl_dir1/=angl_dir1._norm; │ │ │ │ │ │ +00530 │ │ │ │ │ │ +angl_dir2/=angl_dir2._norm; │ │ │ │ │ │ +00531 │ │ │ │ │ │ +00532 │ │ │ │ │ │ +// now we have te reference axis, create the CSphborder_store structure │ │ │ │ │ │ +00533 │ │ │ │ │ │ +vector border_vect; │ │ │ │ │ │ +00534 │ │ │ │ │ │ +border_vect.reserve(border_list.size()); │ │ │ │ │ │ +00535 │ │ │ │ │ │ +for (list::iterator it = border_list.begin(); │ │ │ │ │ │ +00536 │ │ │ │ │ │ +it != border_list.end(); it++) { │ │ │ │ │ │ +00537 │ │ │ │ │ │ +border_vect.push_back(CSphborder_store(*it, centre->centre, angl_dir1, angl_dir2)); │ │ │ │ │ │ +00538 │ │ │ │ │ │ +} │ │ │ │ │ │ +00539 │ │ │ │ │ │ +00540 │ │ │ │ │ │ +// get them into order of angle │ │ │ │ │ │ +00541 │ │ │ │ │ │ +sort(border_vect.begin(), border_vect.end()); │ │ │ │ │ │ +00542 │ │ │ │ │ │ +00543 │ │ │ │ │ │ +// set up some circulators, since these will help us go around the │ │ │ │ │ │ +00544 │ │ │ │ │ │ +// circle easily │ │ │ │ │ │ +00545 │ │ │ │ │ │ +siscone::circulator::iterator > │ │ │ │ │ │ +00546 │ │ │ │ │ │ +start(border_vect.begin(), border_vect.begin(),border_vect.end()); │ │ │ │ │ │ +00547 │ │ │ │ │ │ +siscone::circulator::iterator > mid(start), end(start); │ │ │ │ │ │ +00548 │ │ │ │ │ │ +00549 │ │ │ │ │ │ +// test the borderless cone │ │ │ │ │ │ +00550 │ │ │ │ │ │ +CSphmomentum candidate = borderless_cone; │ │ │ │ │ │ +00551 │ │ │ │ │ │ +//candidate.build_etaphi(); │ │ │ │ │ │ +00552 │ │ │ │ │ │ +if (candidate.ref.not_empty()) │ │ │ │ │ │ +00553 │ │ │ │ │ │ +test_stability(candidate, border_vect); │ │ │ │ │ │ +00554 │ │ │ │ │ │ +00555 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00556 │ │ │ │ │ │ +// reset status wrt inclusion in the cone │ │ │ │ │ │ +00557 │ │ │ │ │ │ +mid = start; │ │ │ │ │ │ +00558 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00559 │ │ │ │ │ │ +mid()->is_in = false; │ │ │ │ │ │ +00560 │ │ │ │ │ │ +} while (++mid != start); │ │ │ │ │ │ +00561 │ │ │ │ │ │ +00562 │ │ │ │ │ │ +// now run over all inclusion possibilities with this starting point │ │ │ │ │ │ +00563 │ │ │ │ │ │ +candidate = borderless_cone; │ │ │ │ │ │ +00564 │ │ │ │ │ │ +while (++mid != start) { │ │ │ │ │ │ +00565 │ │ │ │ │ │ +// will begin with start+1 and go up to start-1 │ │ │ │ │ │ +00566 │ │ │ │ │ │ +mid()->is_in = true; │ │ │ │ │ │ +00567 │ │ │ │ │ │ +candidate += *(mid()->mom); │ │ │ │ │ │ +00568 │ │ │ │ │ │ +test_stability(candidate, border_vect); │ │ │ │ │ │ +00569 │ │ │ │ │ │ +} │ │ │ │ │ │ +00570 │ │ │ │ │ │ +00571 │ │ │ │ │ │ +} while (++start != end); │ │ │ │ │ │ +00572 │ │ │ │ │ │ +00573 │ │ │ │ │ │ +// mid corresponds to momentum that we need to include to get the │ │ │ │ │ │ +00574 │ │ │ │ │ │ +// full cone │ │ │ │ │ │ +00575 │ │ │ │ │ │ +mid()->is_in = true; │ │ │ │ │ │ +00576 │ │ │ │ │ │ +candidate += *(mid()->mom); │ │ │ │ │ │ +00577 │ │ │ │ │ │ +test_stability(candidate, border_vect); │ │ │ │ │ │ +00578 } │ │ │ │ │ │ +00579 │ │ │ │ │ │ +00580 │ │ │ │ │ │ +00587 void CSphstable_cones::test_stability(CSphmomentum & candidate, const vector & │ │ │ │ │ │ +border_vect) { │ │ │ │ │ │ +00588 │ │ │ │ │ │ +00589 │ │ │ │ │ │ +// this almost certainly has not been done... │ │ │ │ │ │ +00590 │ │ │ │ │ │ +//candidate.build_etaphi(); │ │ │ │ │ │ +00591 │ │ │ │ │ │ +00592 │ │ │ │ │ │ +bool stable = true; │ │ │ │ │ │ +00593 │ │ │ │ │ │ +for (unsigned i = 0; i < border_vect.size(); i++) { │ │ │ │ │ │ +00594 │ │ │ │ │ │ +if (is_closer(&candidate, border_vect[i].mom,tan2R) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ +00595 │ │ │ │ │ │ +stable = false; │ │ │ │ │ │ +00596 │ │ │ │ │ │ +break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ +00597 │ │ │ │ │ │ +} │ │ │ │ │ │ +00598 │ │ │ │ │ │ +} │ │ │ │ │ │ +00599 │ │ │ │ │ │ +00600 │ │ │ │ │ │ +if (stable) hc->insert(&candidate); │ │ │ │ │ │ +00601 } │ │ │ │ │ │ +00602 │ │ │ │ │ │ +00603 /* │ │ │ │ │ │ +00604 * check if we are in a situation of cocircularity. │ │ │ │ │ │ +00605 * if it is the case, update and test in the corresponding way │ │ │ │ │ │ +00606 * return ’false’ if no cocircularity detected, ’true’ otherwise │ │ │ │ │ │ +00607 * Note that if cocircularity is detected, we need to │ │ │ │ │ │ +00608 * recall ’update’ from ’update’ !!! │ │ │ │ │ │ +00609 ***************************************************************/ │ │ │ │ │ │ +00610 bool CSphstable_cones::cocircular_check(){ │ │ │ │ │ │ +00611 │ │ │ │ │ │ +// check if many configurations have the same centre. │ │ │ │ │ │ +00612 │ │ │ │ │ │ +// if this is the case, branch on the algorithm for this │ │ │ │ │ │ +00613 │ │ │ │ │ │ +// special case. │ │ │ │ │ │ +00614 │ │ │ │ │ │ +// Note that those situation, being considered separately in │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.17 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00615 │ │ │ │ │ │ +00616 │ │ │ │ │ │ +00617 │ │ │ │ │ │ +00618 │ │ │ │ │ │ +00619 │ │ │ │ │ │ +00620 │ │ │ │ │ │ +00621 │ │ │ │ │ │ +00622 │ │ │ │ │ │ +00623 │ │ │ │ │ │ +00624 │ │ │ │ │ │ +00625 │ │ │ │ │ │ +00626 │ │ │ │ │ │ +00627 │ │ │ │ │ │ +00628 │ │ │ │ │ │ +00629 │ │ │ │ │ │ +00630 │ │ │ │ │ │ +00631 │ │ │ │ │ │ +00632 │ │ │ │ │ │ +00633 │ │ │ │ │ │ +00634 │ │ │ │ │ │ +00635 │ │ │ │ │ │ +00636 │ │ │ │ │ │ +00637 │ │ │ │ │ │ +00638 │ │ │ │ │ │ +00639 │ │ │ │ │ │ +00640 │ │ │ │ │ │ +00641 │ │ │ │ │ │ +00642 │ │ │ │ │ │ +00643 │ │ │ │ │ │ +00644 │ │ │ │ │ │ +00645 │ │ │ │ │ │ +00646 │ │ │ │ │ │ +00647 │ │ │ │ │ │ +00648 │ │ │ │ │ │ +00649 │ │ │ │ │ │ +00650 │ │ │ │ │ │ +00651 │ │ │ │ │ │ +00652 │ │ │ │ │ │ +00653 │ │ │ │ │ │ +00654 │ │ │ │ │ │ +00655 │ │ │ │ │ │ +00656 │ │ │ │ │ │ +00657 │ │ │ │ │ │ +00658 │ │ │ │ │ │ +00659 │ │ │ │ │ │ +00660 │ │ │ │ │ │ +00661 │ │ │ │ │ │ +00662 │ │ │ │ │ │ +00663 │ │ │ │ │ │ +00664 │ │ │ │ │ │ +00665 │ │ │ │ │ │ +00666 │ │ │ │ │ │ +00667 │ │ │ │ │ │ + │ │ │ │ │ │ +219 │ │ │ │ │ │ + │ │ │ │ │ │ +// test_cone_multiple, must only be considered here if all │ │ │ │ │ │ +// angles are on the same side (this avoid multiple counting) │ │ │ │ │ │ +if (centre->cocircular.empty()) return false; │ │ │ │ │ │ +// first get cone into status required at end... │ │ │ │ │ │ +if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ +// update cone │ │ │ │ │ │ +cone -= (*child); │ │ │ │ │ │ +// update info on particles inside │ │ │ │ │ │ +centre->is_inside->cone = false; │ │ │ │ │ │ +// update stability check quantities │ │ │ │ │ │ +dpt += fabs(child->px)+fabs(child->py)+fabs(child->pz); //child->perp2(); │ │ │ │ │ │ +} │ │ │ │ │ │ + │ │ │ │ │ │ +// now establish the list of unique children in the list │ │ │ │ │ │ +// first make sure parent and child are in! │ │ │ │ │ │ +list removed_from_cone; │ │ │ │ │ │ +list put_in_border; │ │ │ │ │ │ +list border_list; │ │ │ │ │ │ +CSphmomentum cone_removal; │ │ │ │ │ │ +CSphmomentum border = *parent; │ │ │ │ │ │ +border_list.push_back(parent); │ │ │ │ │ │ +// make sure child appears in the border region │ │ │ │ │ │ +centre->cocircular.push_back(centre); │ │ │ │ │ │ +// now establish the full contents of the cone minus the cocircular │ │ │ │ │ │ +// region and of the cocircular region itself │ │ │ │ │ │ +for(list::iterator it = centre->cocircular.begin(); │ │ │ │ │ │ +it != centre->cocircular.end(); it++) { │ │ │ │ │ │ +if ((*it)->is_inside->cone) { │ │ │ │ │ │ +cone_removal │ │ │ │ │ │ ++= *((*it)->v); │ │ │ │ │ │ +(*it)->is_inside->cone = false; │ │ │ │ │ │ +removed_from_cone.push_back((*it)->is_inside); │ │ │ │ │ │ +} │ │ │ │ │ │ + │ │ │ │ │ │ +// if a point appears twice (i.e. with + and - sign) in the list of │ │ │ │ │ │ +// points on the border, we take care not to include it twice. │ │ │ │ │ │ +// Note that this situation may appear when a point is at a distance │ │ │ │ │ │ +// close to 2R from the parent │ │ │ │ │ │ +if (!(*it)->is_inside->cocirc) { │ │ │ │ │ │ +border += *((*it)->v); │ │ │ │ │ │ +(*it)->is_inside->cocirc = true; │ │ │ │ │ │ +put_in_border.push_back((*it)->is_inside); │ │ │ │ │ │ +border_list.push_back((*it)->v); │ │ │ │ │ │ +//cout « " adding particle " « (*it)->v->_theta « ", " « (*it)->v->_phi « " to the border list" │ │ │ │ │ │ +« endl; │ │ │ │ │ │ +00668 │ │ │ │ │ │ +} │ │ │ │ │ │ +00669 │ │ │ │ │ │ +} │ │ │ │ │ │ +00670 │ │ │ │ │ │ +00671 │ │ │ │ │ │ +00672 │ │ │ │ │ │ +// figure out whether this pairing has been observed before │ │ │ │ │ │ +00673 │ │ │ │ │ │ +CSphmomentum borderless_cone = cone; │ │ │ │ │ │ +00674 │ │ │ │ │ │ +borderless_cone -= cone_removal; │ │ │ │ │ │ +00675 │ │ │ │ │ │ +bool consider = true; │ │ │ │ │ │ +00676 │ │ │ │ │ │ +for (unsigned int i=0;i(borderless_cone.ref, │ │ │ │ │ │ +00686 │ │ │ │ │ │ +border.ref)); │ │ │ │ │ │ +00687 │ │ │ │ │ │ +00688 │ │ │ │ │ │ +// first figure out whether our cone momentum is good │ │ │ │ │ │ +00689 │ │ │ │ │ │ +double local_dpt = fabs(cone_removal.px) + fabs(cone_removal.py); │ │ │ │ │ │ +00690 │ │ │ │ │ │ +double total_dpt = dpt + local_dpt; │ │ │ │ │ │ +00691 │ │ │ │ │ │ +00692 │ │ │ │ │ │ +recompute_cone_contents_if_needed(borderless_cone, total_dpt); │ │ │ │ │ │ +00693 │ │ │ │ │ │ +if (total_dpt == 0) { │ │ │ │ │ │ +00694 │ │ │ │ │ │ +// a recomputation has taken place -- so take advantage of this │ │ │ │ │ │ +00695 │ │ │ │ │ │ +// and update the member cone momentum │ │ │ │ │ │ +00696 │ │ │ │ │ │ +cone = borderless_cone + cone_removal; │ │ │ │ │ │ +00697 │ │ │ │ │ │ +dpt = local_dpt; │ │ │ │ │ │ +00698 │ │ │ │ │ │ +} │ │ │ │ │ │ +00699 │ │ │ │ │ │ +00700 │ │ │ │ │ │ +test_cone_cocircular(borderless_cone, border_list); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 220 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00701 │ │ │ │ │ │ +} │ │ │ │ │ │ +00702 │ │ │ │ │ │ +00703 │ │ │ │ │ │ +00704 │ │ │ │ │ │ +// relabel things that were in the cone but got removed │ │ │ │ │ │ +00705 │ │ │ │ │ │ +for(list::iterator is_in = removed_from_cone.begin(); │ │ │ │ │ │ +00706 │ │ │ │ │ │ +is_in != removed_from_cone.end(); is_in++) { │ │ │ │ │ │ +00707 │ │ │ │ │ │ +(*is_in)->cone = true; │ │ │ │ │ │ +00708 │ │ │ │ │ │ +} │ │ │ │ │ │ +00709 │ │ │ │ │ │ +00710 │ │ │ │ │ │ +// relabel things that got put into the border │ │ │ │ │ │ +00711 │ │ │ │ │ │ +for(list::iterator is_in = put_in_border.begin(); │ │ │ │ │ │ +00712 │ │ │ │ │ │ +is_in != put_in_border.end(); is_in++) { │ │ │ │ │ │ +00713 │ │ │ │ │ │ +(*is_in)->cocirc = false; │ │ │ │ │ │ +00714 │ │ │ │ │ │ +} │ │ │ │ │ │ +00715 │ │ │ │ │ │ +00716 │ │ │ │ │ │ +// we’re done with everything -- return true to signal to user that we’ve │ │ │ │ │ │ +00717 │ │ │ │ │ │ +// been through the co-circularity rigmarole │ │ │ │ │ │ +00718 │ │ │ │ │ │ +return true; │ │ │ │ │ │ +00719 } │ │ │ │ │ │ +00720 │ │ │ │ │ │ +00721 │ │ │ │ │ │ +00723 // RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ +// │ │ │ │ │ │ +00724 // - compute_cone_contents() │ │ │ │ │ │ +// │ │ │ │ │ │ +00725 // - recompute_cone_contents() │ │ │ │ │ │ +// │ │ │ │ │ │ +00726 // - recompute_cone_contents_if_needed() │ │ │ │ │ │ +// │ │ │ │ │ │ +00728 │ │ │ │ │ │ +00737 void CSphstable_cones::compute_cone_contents() { │ │ │ │ │ │ +00738 │ │ │ │ │ │ +siscone::circulator::iterator > │ │ │ │ │ │ +00739 │ │ │ │ │ │ +start(vicinity.begin()+first_cone, vicinity.begin(), vicinity.end()); │ │ │ │ │ │ +00740 │ │ │ │ │ │ +00741 │ │ │ │ │ │ +siscone::circulator::iterator > here(start); │ │ │ │ │ │ +00742 │ │ │ │ │ │ +00743 │ │ │ │ │ │ +// note that in the following algorithm, the cone contents never includes │ │ │ │ │ │ +00744 │ │ │ │ │ │ +// the child. Indeed, if it has positive sign, then it will be set as │ │ │ │ │ │ +00745 │ │ │ │ │ │ +// outside at the last step in the loop. If it has negative sign, then the │ │ │ │ │ │ +00746 │ │ │ │ │ │ +// loop will at some point go to the corresponding situation with positive │ │ │ │ │ │ +00747 │ │ │ │ │ │ +// sign and set the inclusion status to 0. │ │ │ │ │ │ +00748 │ │ │ │ │ │ +00749 │ │ │ │ │ │ +do { │ │ │ │ │ │ +00750 │ │ │ │ │ │ +// as we leave this position a particle enters if its side is │ │ │ │ │ │ +00751 │ │ │ │ │ │ +// negative (i.e. the centre is the one at -ve angle wrt to the │ │ │ │ │ │ +00752 │ │ │ │ │ │ +// parent-child line │ │ │ │ │ │ +00753 │ │ │ │ │ │ +if (!(*here())->side) ((*here())->is_inside->cone) = 1; │ │ │ │ │ │ +00754 │ │ │ │ │ │ +00755 │ │ │ │ │ │ +// move on to the next position │ │ │ │ │ │ +00756 │ │ │ │ │ │ +++here; │ │ │ │ │ │ +00757 │ │ │ │ │ │ +00758 │ │ │ │ │ │ +// as we arrive at this position a particle leaves if its side is positive │ │ │ │ │ │ +00759 │ │ │ │ │ │ +if ((*here())->side) ((*here())->is_inside->cone) = 0; │ │ │ │ │ │ +00760 │ │ │ │ │ │ +} while (here != start); │ │ │ │ │ │ +00761 │ │ │ │ │ │ +00762 │ │ │ │ │ │ +// once we’ve reached the start the ’is_inside’ information should be │ │ │ │ │ │ +00763 │ │ │ │ │ │ +// 100% complete, so we can use it to calculate the cone contents │ │ │ │ │ │ +00764 │ │ │ │ │ │ +// and then exit │ │ │ │ │ │ +00765 │ │ │ │ │ │ +recompute_cone_contents(); │ │ │ │ │ │ +00766 │ │ │ │ │ │ +return; │ │ │ │ │ │ +00767 │ │ │ │ │ │ +00768 } │ │ │ │ │ │ +00769 │ │ │ │ │ │ +00770 │ │ │ │ │ │ +00771 /* │ │ │ │ │ │ +00772 * compute the cone momentum from particle list. │ │ │ │ │ │ +00773 * in this version, we use the ’pincluded’ information │ │ │ │ │ │ +00774 * from the CSphvicinity class │ │ │ │ │ │ +00775 */ │ │ │ │ │ │ +00776 void CSphstable_cones::recompute_cone_contents(){ │ │ │ │ │ │ +00777 │ │ │ │ │ │ +unsigned int i; │ │ │ │ │ │ +00778 │ │ │ │ │ │ +00779 │ │ │ │ │ │ +// set momentum to 0 │ │ │ │ │ │ +00780 │ │ │ │ │ │ +cone = CSphmomentum(); │ │ │ │ │ │ +00781 │ │ │ │ │ │ +00782 │ │ │ │ │ │ +// Important note: we can browse only the particles │ │ │ │ │ │ +00783 │ │ │ │ │ │ +// in vicinity since all particles in the cone are │ │ │ │ │ │ +00784 │ │ │ │ │ │ +// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ +00785 │ │ │ │ │ │ +// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ +00786 │ │ │ │ │ │ +// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ +00787 │ │ │ │ │ │ +for (i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ +00790 │ │ │ │ │ │ +cone += *vicinity[i]->v; │ │ │ │ │ │ +00791 │ │ │ │ │ │ +} │ │ │ │ │ │ +00792 │ │ │ │ │ │ +00793 │ │ │ │ │ │ +// set check variables back to 0 │ │ │ │ │ │ +00794 │ │ │ │ │ │ +dpt = 0.0; │ │ │ │ │ │ +00795 } │ │ │ │ │ │ +00796 │ │ │ │ │ │ +00797 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.18 quadtree.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +221 │ │ │ │ │ │ + │ │ │ │ │ │ +00798 /* │ │ │ │ │ │ +00799 * if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ +00800 * the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ +00801 * ’pincluded’ information from the CSphvicinity class, but we don’t │ │ │ │ │ │ +00802 * change the member cone, only the locally supplied one │ │ │ │ │ │ +00803 */ │ │ │ │ │ │ +00804 void CSphstable_cones::recompute_cone_contents_if_needed(CSphmomentum & this_cone, │ │ │ │ │ │ +00805 │ │ │ │ │ │ +double & this_dpt){ │ │ │ │ │ │ +00806 │ │ │ │ │ │ +00807 │ │ │ │ │ │ +if (this_dpt > PT_TSHOLD*(fabs(this_cone.px)+fabs(this_cone.py))) { │ │ │ │ │ │ +00808 │ │ │ │ │ │ +if (cone.ref.is_empty()) { │ │ │ │ │ │ +00809 │ │ │ │ │ │ +this_cone = CSphmomentum(); │ │ │ │ │ │ +00810 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +00811 │ │ │ │ │ │ +// set momentum to 0 │ │ │ │ │ │ +00812 │ │ │ │ │ │ +this_cone = CSphmomentum(); │ │ │ │ │ │ +00813 │ │ │ │ │ │ +00814 │ │ │ │ │ │ +// Important note: we can browse only the particles │ │ │ │ │ │ +00815 │ │ │ │ │ │ +// in vicinity since all particles in the this_cone are │ │ │ │ │ │ +00816 │ │ │ │ │ │ +// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ +00817 │ │ │ │ │ │ +// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ +00818 │ │ │ │ │ │ +// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ +00819 │ │ │ │ │ │ +for (unsigned int i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ +00822 │ │ │ │ │ │ +this_cone += *vicinity[i]->v; │ │ │ │ │ │ +00823 │ │ │ │ │ │ +} │ │ │ │ │ │ +00824 │ │ │ │ │ │ +00825 │ │ │ │ │ │ +} │ │ │ │ │ │ +00826 │ │ │ │ │ │ +// set check variables back to 0 │ │ │ │ │ │ +00827 │ │ │ │ │ │ +this_dpt = 0.0; │ │ │ │ │ │ +00828 │ │ │ │ │ │ +} │ │ │ │ │ │ +00829 │ │ │ │ │ │ +00830 } │ │ │ │ │ │ +00831 │ │ │ │ │ │ +00832 │ │ │ │ │ │ +00834 // VARIOUS TOOLS │ │ │ │ │ │ +// │ │ │ │ │ │ +00835 // - circle_intersect() │ │ │ │ │ │ +// │ │ │ │ │ │ +00836 // - is_inside() │ │ │ │ │ │ +// │ │ │ │ │ │ +00837 // - abs_dangle() │ │ │ │ │ │ +// │ │ │ │ │ │ +00839 │ │ │ │ │ │ +00840 │ │ │ │ │ │ +00841 /* │ │ │ │ │ │ +00842 * circle intersection. │ │ │ │ │ │ +00843 * computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ +00844 * The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ +00845 * - cx │ │ │ │ │ │ +circle centre x coordinate │ │ │ │ │ │ +00846 * - cy │ │ │ │ │ │ +circle centre y coordinate │ │ │ │ │ │ +00847 * return the checkxor for the intersection │ │ │ │ │ │ +00848 ******************************************************************/ │ │ │ │ │ │ +00849 siscone::Creference CSphstable_cones::circle_intersect(CSph3vector &cone_centre){ │ │ │ │ │ │ +00850 │ │ │ │ │ │ +siscone::Creference intersection; │ │ │ │ │ │ +00851 │ │ │ │ │ │ +int i; │ │ │ │ │ │ +00852 │ │ │ │ │ │ +00853 │ │ │ │ │ │ +for (i=0;iM_PI) dy = M_PI; │ │ │ │ │ │ 00238 │ │ │ │ │ │ @@ -17441,14 +18921,19 @@ │ │ │ │ │ │ 00274 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00275 } │ │ │ │ │ │ 00276 │ │ │ │ │ │ 00277 │ │ │ │ │ │ 00278 /* │ │ │ │ │ │ 00279 * output a data file for drawing the tree leaves. │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.19 quadtree.h │ │ │ │ │ │ + │ │ │ │ │ │ 00280 * This can be used to output a data file containing all the │ │ │ │ │ │ 00281 * tree leaves. The file contents is as follows: │ │ │ │ │ │ 00282 * first and second columns give center of the cell, the third │ │ │ │ │ │ 00283 * gives the size. │ │ │ │ │ │ 00284 * - flux opened stream to write to │ │ │ │ │ │ 00285 * return 0 on success, 1 on error │ │ │ │ │ │ 00286 ******************************************************************/ │ │ │ │ │ │ @@ -17478,42 +18963,36 @@ │ │ │ │ │ │ 00300 │ │ │ │ │ │ 00301 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00302 } │ │ │ │ │ │ 00303 │ │ │ │ │ │ 00304 } │ │ │ │ │ │ │ │ │ │ │ │ -5.23 │ │ │ │ │ │ +5.19 │ │ │ │ │ │ │ │ │ │ │ │ quadtree.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: quadtree.h │ │ │ │ │ │ -00004 // Description: header file for quadtree management (Cquadtree class) │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ - │ │ │ │ │ │ // │ │ │ │ │ │ +00004 // Description: header file for quadtree management (Cquadtree class) │ │ │ │ │ │ // │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ +00007 // │ │ │ │ │ │ // │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ +00009 // │ │ │ │ │ │ // │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.24 ranlux.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ 00013 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ 00014 // │ │ │ │ │ │ // │ │ │ │ │ │ 00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ @@ -17576,28 +19055,37 @@ │ │ │ │ │ │ double centre_x; │ │ │ │ │ │ 00113 │ │ │ │ │ │ double centre_y; │ │ │ │ │ │ 00114 │ │ │ │ │ │ double half_size_x; │ │ │ │ │ │ 00115 │ │ │ │ │ │ double half_size_y; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +225 │ │ │ │ │ │ + │ │ │ │ │ │ + 226 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00116 │ │ │ │ │ │ 00117 │ │ │ │ │ │ Cmomentum *v; │ │ │ │ │ │ 00118 │ │ │ │ │ │ 00119 │ │ │ │ │ │ Cquadtree* children[2][2]; │ │ │ │ │ │ 00120 │ │ │ │ │ │ bool has_child; │ │ │ │ │ │ 00121 }; │ │ │ │ │ │ 00122 │ │ │ │ │ │ 00123 } │ │ │ │ │ │ 00124 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.24 │ │ │ │ │ │ +5.20 │ │ │ │ │ │ │ │ │ │ │ │ ranlux.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 // file: ranlux.xpp │ │ │ │ │ │ 00002 #include "ranlux.h" │ │ │ │ │ │ 00003 #include │ │ │ │ │ │ 00004 #include │ │ │ │ │ │ @@ -17632,23 +19120,14 @@ │ │ │ │ │ │ 00022 │ │ │ │ │ │ 00023 │ │ │ │ │ │ Available on the net as hep-lat/9309020 at http://xxx.lanl.gov/ │ │ │ │ │ │ 00024 │ │ │ │ │ │ 00025 │ │ │ │ │ │ See also, │ │ │ │ │ │ 00026 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -217 │ │ │ │ │ │ - │ │ │ │ │ │ - 218 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00027 │ │ │ │ │ │ F. James, "RANLUX: A Fortran implementation of the high-quality │ │ │ │ │ │ 00028 │ │ │ │ │ │ pseudo-random number generator of Luscher", Computer Physics │ │ │ │ │ │ 00029 │ │ │ │ │ │ Communications, 79 (1994) 111-114 │ │ │ │ │ │ 00030 │ │ │ │ │ │ @@ -17704,14 +19183,19 @@ │ │ │ │ │ │ 00068 │ │ │ │ │ │ 00069 │ │ │ │ │ │ if (delta & mask_hi){ │ │ │ │ │ │ 00070 │ │ │ │ │ │ local_ranlux_state.carry = 1; │ │ │ │ │ │ 00071 │ │ │ │ │ │ delta &= mask_lo; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.20 ranlux.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00072 │ │ │ │ │ │ } else { │ │ │ │ │ │ 00073 │ │ │ │ │ │ local_ranlux_state.carry = 0; │ │ │ │ │ │ 00074 │ │ │ │ │ │ } │ │ │ │ │ │ 00075 │ │ │ │ │ │ @@ -17772,21 +19256,14 @@ │ │ │ │ │ │ for (i=0;i<24;i++){ │ │ │ │ │ │ 00111 │ │ │ │ │ │ unsigned long int k = seed/53668; │ │ │ │ │ │ 00112 │ │ │ │ │ │ seed = 40014*(seed-k*53668)-k*12211; │ │ │ │ │ │ 00113 │ │ │ │ │ │ if (seed<0){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.25 siscone/ranlux.h File Reference │ │ │ │ │ │ - │ │ │ │ │ │ -219 │ │ │ │ │ │ - │ │ │ │ │ │ 00114 │ │ │ │ │ │ seed += 2147483563; │ │ │ │ │ │ 00115 │ │ │ │ │ │ } │ │ │ │ │ │ 00116 │ │ │ │ │ │ local_ranlux_state.u[i] = seed%two24; │ │ │ │ │ │ 00117 │ │ │ │ │ │ @@ -17847,14 +19324,23 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 00154 │ │ │ │ │ │ 00155 │ │ │ │ │ │ return r; │ │ │ │ │ │ 00156 } │ │ │ │ │ │ 00157 │ │ │ │ │ │ 00158 // print generator state │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +227 │ │ │ │ │ │ + │ │ │ │ │ │ + 228 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00159 //----------------------00160 void ranlux_print_state(){ │ │ │ │ │ │ 00161 │ │ │ │ │ │ size_t i; │ │ │ │ │ │ 00162 │ │ │ │ │ │ unsigned char *p = (unsigned char *) (&local_ranlux_state); │ │ │ │ │ │ 00163 │ │ │ │ │ │ const size_t n = sizeof (ranlux_state_t); │ │ │ │ │ │ @@ -17867,78 +19353,77 @@ │ │ │ │ │ │ printf("%.2x", *(p+i)); │ │ │ │ │ │ 00168 │ │ │ │ │ │ } │ │ │ │ │ │ 00169 } │ │ │ │ │ │ 00170 │ │ │ │ │ │ 00171 } │ │ │ │ │ │ │ │ │ │ │ │ -5.25 │ │ │ │ │ │ +5.21 │ │ │ │ │ │ │ │ │ │ │ │ siscone/ranlux.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ This graph shows which files directly or indirectly include this file: │ │ │ │ │ │ │ │ │ │ │ │ siscone/ranlux.h │ │ │ │ │ │ │ │ │ │ │ │ siscone/ranlux.cpp │ │ │ │ │ │ │ │ │ │ │ │ siscone/reference.cpp │ │ │ │ │ │ │ │ │ │ │ │ -Functions │ │ │ │ │ │ -• void siscone::ranlux_init () │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ siscone/siscone.cpp │ │ │ │ │ │ │ │ │ │ │ │ siscone/spherical/siscone.cpp │ │ │ │ │ │ │ │ │ │ │ │ - 220 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +Functions │ │ │ │ │ │ +• void siscone::ranlux_init () │ │ │ │ │ │ initialize 'ranlux' generator │ │ │ │ │ │ │ │ │ │ │ │ • unsigned long int siscone::ranlux_get () │ │ │ │ │ │ generate random value (24 bits) │ │ │ │ │ │ │ │ │ │ │ │ • void siscone::ranlux_print_state () │ │ │ │ │ │ save state of the generator │ │ │ │ │ │ │ │ │ │ │ │ -5.25.1 │ │ │ │ │ │ +5.21.1 │ │ │ │ │ │ │ │ │ │ │ │ Function Documentation │ │ │ │ │ │ │ │ │ │ │ │ -5.25.1.1 │ │ │ │ │ │ +5.21.1.1 │ │ │ │ │ │ │ │ │ │ │ │ ranlux_get() │ │ │ │ │ │ │ │ │ │ │ │ unsigned long int siscone::ranlux_get ( ) │ │ │ │ │ │ │ │ │ │ │ │ generate random value (24 bits) │ │ │ │ │ │ Definition at line 142 of file ranlux.cpp. │ │ │ │ │ │ │ │ │ │ │ │ -5.25.1.2 │ │ │ │ │ │ +5.21.1.2 │ │ │ │ │ │ │ │ │ │ │ │ ranlux_init() │ │ │ │ │ │ │ │ │ │ │ │ void siscone::ranlux_init ( ) │ │ │ │ │ │ │ │ │ │ │ │ initialize 'ranlux' generator │ │ │ │ │ │ Definition at line 134 of file ranlux.cpp. │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -5.25.1.3 │ │ │ │ │ │ + 5.22 ranlux.h │ │ │ │ │ │ + │ │ │ │ │ │ +5.21.1.3 │ │ │ │ │ │ + │ │ │ │ │ │ +229 │ │ │ │ │ │ │ │ │ │ │ │ ranlux_print_state() │ │ │ │ │ │ │ │ │ │ │ │ void siscone::ranlux_print_state ( ) │ │ │ │ │ │ │ │ │ │ │ │ save state of the generator │ │ │ │ │ │ Definition at line 160 of file ranlux.cpp. │ │ │ │ │ │ │ │ │ │ │ │ -5.26 │ │ │ │ │ │ +5.22 │ │ │ │ │ │ │ │ │ │ │ │ ranlux.h │ │ │ │ │ │ │ │ │ │ │ │ Go to the documentation of this file. │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 │ │ │ │ │ │ 00003 #ifndef __RANLUX_H__ │ │ │ │ │ │ @@ -17968,19 +19453,14 @@ │ │ │ │ │ │ 00019 │ │ │ │ │ │ From: M. Luescher, "A portable high-quality random number generator │ │ │ │ │ │ 00020 │ │ │ │ │ │ for lattice field theory calculations", Computer Physics │ │ │ │ │ │ 00021 │ │ │ │ │ │ Communications, 79 (1994) 100-110. │ │ │ │ │ │ 00022 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.27 reference.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00023 │ │ │ │ │ │ Available on the net as hep-lat/9309020 at http://xxx.lanl.gov/ │ │ │ │ │ │ 00024 │ │ │ │ │ │ 00025 │ │ │ │ │ │ See also, │ │ │ │ │ │ 00026 │ │ │ │ │ │ 00027 │ │ │ │ │ │ @@ -18007,43 +19487,51 @@ │ │ │ │ │ │ 00043 unsigned long int ranlux_get(); │ │ │ │ │ │ 00044 │ │ │ │ │ │ 00046 void ranlux_print_state(); │ │ │ │ │ │ 00047 │ │ │ │ │ │ 00048 } │ │ │ │ │ │ 00049 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.27 │ │ │ │ │ │ +5.23 │ │ │ │ │ │ │ │ │ │ │ │ reference.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: reference.cpp │ │ │ │ │ │ -// │ │ │ │ │ │ 00003 // Description: source file for checkxor management (Creference class) │ │ │ │ │ │ -// │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ 00006 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00007 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ 00008 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00009 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ 00010 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ 00011 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ 00012 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ 00013 // │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ // │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 230 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00014 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ 00015 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ 00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ // │ │ │ │ │ │ 00017 // GNU General Public License for more details. │ │ │ │ │ │ @@ -18097,23 +19585,14 @@ │ │ │ │ │ │ 00051 │ │ │ │ │ │ 00052 // create a random reference │ │ │ │ │ │ 00053 //--------------------------00054 void Creference::randomize(){ │ │ │ │ │ │ 00055 // ref[0] = reference_bit; │ │ │ │ │ │ 00056 // ref[1] = 0; │ │ │ │ │ │ 00057 // ref[2] = 0; │ │ │ │ │ │ 00058 // reference_bit «= 1; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -221 │ │ │ │ │ │ - │ │ │ │ │ │ - 222 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00059 │ │ │ │ │ │ 00060 │ │ │ │ │ │ unsigned int r1 = ranlux_get(); │ │ │ │ │ │ 00061 │ │ │ │ │ │ unsigned int r2 = ranlux_get(); │ │ │ │ │ │ 00062 │ │ │ │ │ │ unsigned int r3 = ranlux_get(); │ │ │ │ │ │ @@ -18163,15 +19642,21 @@ │ │ │ │ │ │ 00097 │ │ │ │ │ │ Creference tmp = *this; │ │ │ │ │ │ 00098 │ │ │ │ │ │ return tmp+=r; │ │ │ │ │ │ 00099 } │ │ │ │ │ │ 00100 │ │ │ │ │ │ 00101 // incrementation of reference │ │ │ │ │ │ -00102 //----------------------------00103 Creference& Creference::operator += (const Creference &r){ │ │ │ │ │ │ +00102 //----------------------------- │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.24 reference.h │ │ │ │ │ │ + │ │ │ │ │ │ +00103 Creference& Creference::operator += (const Creference &r){ │ │ │ │ │ │ 00104 │ │ │ │ │ │ ref[0] ^= r.ref[0]; │ │ │ │ │ │ 00105 │ │ │ │ │ │ ref[1] ^= r.ref[1]; │ │ │ │ │ │ 00106 │ │ │ │ │ │ ref[2] ^= r.ref[2]; │ │ │ │ │ │ 00107 │ │ │ │ │ │ @@ -18189,60 +19674,52 @@ │ │ │ │ │ │ 00116 │ │ │ │ │ │ return *this; │ │ │ │ │ │ 00117 } │ │ │ │ │ │ 00118 │ │ │ │ │ │ 00119 } │ │ │ │ │ │ 00120 │ │ │ │ │ │ │ │ │ │ │ │ -5.28 │ │ │ │ │ │ +5.24 │ │ │ │ │ │ │ │ │ │ │ │ reference.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: reference.h │ │ │ │ │ │ -00004 // Description: header file for checkxor management (Creference class) │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -00013 // (at your option) any later version. │ │ │ │ │ │ -00014 // │ │ │ │ │ │ -00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -00018 // GNU General Public License for more details. │ │ │ │ │ │ -00019 // │ │ │ │ │ │ - │ │ │ │ │ │ // │ │ │ │ │ │ +00004 // Description: header file for checkxor management (Creference class) │ │ │ │ │ │ // │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ +00007 // │ │ │ │ │ │ // │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ +00009 // │ │ │ │ │ │ // │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ +00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ +00013 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ +00014 // │ │ │ │ │ │ // │ │ │ │ │ │ +00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ +00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ +00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ // │ │ │ │ │ │ +00018 // GNU General Public License for more details. │ │ │ │ │ │ // │ │ │ │ │ │ +00019 // │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.29 siscone.h │ │ │ │ │ │ - │ │ │ │ │ │ -223 │ │ │ │ │ │ - │ │ │ │ │ │ 00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00023 // │ │ │ │ │ │ // │ │ │ │ │ │ @@ -18294,14 +19771,23 @@ │ │ │ │ │ │ 00079 bool operator == (const Creference &r1, const Creference &r2); │ │ │ │ │ │ 00080 │ │ │ │ │ │ 00082 bool operator != (const Creference &r1, const Creference &r2); │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00085 bool operator < (const Creference &r1, const Creference &r2); │ │ │ │ │ │ 00086 │ │ │ │ │ │ 00087 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +231 │ │ │ │ │ │ + │ │ │ │ │ │ + 232 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00088 //=============== inline material ================ │ │ │ │ │ │ 00089 │ │ │ │ │ │ 00090 // equality test for two references │ │ │ │ │ │ 00091 //---------------------------------00092 inline bool operator == (const Creference &r1, const Creference &r2){ │ │ │ │ │ │ 00093 │ │ │ │ │ │ return (r1.ref[0]==r2.ref[0]) && (r1.ref[1]==r2.ref[1]) && (r1.ref[2]==r2.ref[2]); │ │ │ │ │ │ 00094 } │ │ │ │ │ │ @@ -18322,308 +19808,27 @@ │ │ │ │ │ │ 00107 │ │ │ │ │ │ )); │ │ │ │ │ │ 00108 } │ │ │ │ │ │ 00109 │ │ │ │ │ │ 00110 } │ │ │ │ │ │ 00111 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.29 │ │ │ │ │ │ - │ │ │ │ │ │ -siscone.h │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: siscone.h │ │ │ │ │ │ -00004 // Description: header file for the main SISCone class │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 224 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00013 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00023 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // $Revision:: 401 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00025 // $Date:: 2016-05-19 16:44:37 +0200 (Thu, 19 May 2016) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 │ │ │ │ │ │ -00028 #ifndef __SISCONE_H__ │ │ │ │ │ │ -00029 #define __SISCONE_H__ │ │ │ │ │ │ -00030 │ │ │ │ │ │ -00031 #include "protocones.h" │ │ │ │ │ │ -00032 #include "split_merge.h" │ │ │ │ │ │ -00033 │ │ │ │ │ │ -00034 namespace siscone{ │ │ │ │ │ │ -00035 │ │ │ │ │ │ -00048 class Csiscone : public Cstable_cones, public Csplit_merge{ │ │ │ │ │ │ -00049 public: │ │ │ │ │ │ -00051 │ │ │ │ │ │ -Csiscone(); │ │ │ │ │ │ -00052 │ │ │ │ │ │ -00054 │ │ │ │ │ │ -~Csiscone(); │ │ │ │ │ │ -00055 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -int compute_jets(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ -00077 │ │ │ │ │ │ -int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ │ -00078 │ │ │ │ │ │ -Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ -00079 │ │ │ │ │ │ -00097 │ │ │ │ │ │ -int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ -00098 │ │ │ │ │ │ -int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ │ -00099 │ │ │ │ │ │ -Esplit_merge_scale _ordering_scale=SM_pttilde); │ │ │ │ │ │ -00100 │ │ │ │ │ │ -00113 │ │ │ │ │ │ -int recompute_jets(double _f, double _ptmin = 0.0, │ │ │ │ │ │ -00114 │ │ │ │ │ │ -Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ -00115 │ │ │ │ │ │ -00117 │ │ │ │ │ │ -std::vector > protocones_list; │ │ │ │ │ │ -00118 │ │ │ │ │ │ -00119 │ │ │ │ │ │ -// random number initialisation │ │ │ │ │ │ -00120 │ │ │ │ │ │ -static bool init_done; │ │ │ │ │ │ -00121 │ │ │ │ │ │ -00122 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00123 │ │ │ │ │ │ -int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ │ -00124 #endif │ │ │ │ │ │ -00125 │ │ │ │ │ │ -00137 │ │ │ │ │ │ -static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ -00138 │ │ │ │ │ │ -00143 │ │ │ │ │ │ -static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ -00144 │ │ │ │ │ │ -00145 private: │ │ │ │ │ │ -00146 │ │ │ │ │ │ -bool rerun_allowed; │ │ │ │ │ │ -00147 │ │ │ │ │ │ -static std::ostream * _banner_ostr; │ │ │ │ │ │ -00148 │ │ │ │ │ │ -00150 │ │ │ │ │ │ -void _initialise_if_needed(); │ │ │ │ │ │ -00151 │ │ │ │ │ │ -00152 }; │ │ │ │ │ │ -00153 │ │ │ │ │ │ -00154 │ │ │ │ │ │ -00155 // finally, a bunch of functions to access to │ │ │ │ │ │ -00156 // basic information (package name, version) │ │ │ │ │ │ -00157 //--------------------------------------------00158 │ │ │ │ │ │ -00166 std::string siscone_package_name(); │ │ │ │ │ │ -00167 │ │ │ │ │ │ -00173 std::string siscone_version(); │ │ │ │ │ │ -00174 │ │ │ │ │ │ -00175 } │ │ │ │ │ │ -00176 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.30 │ │ │ │ │ │ - │ │ │ │ │ │ -siscone.h │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: siscone.h │ │ │ │ │ │ -00004 // Description: header file for the main SISCone class │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -an adaptation to spherical coordinates │ │ │ │ │ │ -00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.31 siscone_error.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -225 │ │ │ │ │ │ - │ │ │ │ │ │ -00011 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00025 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00026 // $Revision:: 401 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 // $Date:: 2016-05-19 16:44:37 +0200 (Thu, 19 May 2016) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00029 │ │ │ │ │ │ -00030 #ifndef __SPH_SISCONE_H__ │ │ │ │ │ │ -00031 #define __SPH_SISCONE_H__ │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 #include "protocones.h" │ │ │ │ │ │ -00034 #include "split_merge.h" │ │ │ │ │ │ -00035 │ │ │ │ │ │ -00036 namespace siscone_spherical{ │ │ │ │ │ │ -00037 │ │ │ │ │ │ -00050 class CSphsiscone : public CSphstable_cones, public CSphsplit_merge{ │ │ │ │ │ │ -00051 public: │ │ │ │ │ │ -00053 │ │ │ │ │ │ -CSphsiscone(); │ │ │ │ │ │ -00054 │ │ │ │ │ │ -00056 │ │ │ │ │ │ -~CSphsiscone(); │ │ │ │ │ │ -00057 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -int compute_jets(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ -00077 │ │ │ │ │ │ -int _n_pass_max=0, double _Emin=0.0, │ │ │ │ │ │ -00078 │ │ │ │ │ │ -Esplit_merge_scale _split_merge_scale=SM_Etilde); │ │ │ │ │ │ -00079 │ │ │ │ │ │ -00094 │ │ │ │ │ │ -int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ -00095 │ │ │ │ │ │ -int _n_pass_max=0, double _Emin=0.0, │ │ │ │ │ │ -00096 │ │ │ │ │ │ -Esplit_merge_scale _ordering_scale=SM_Etilde); │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00110 │ │ │ │ │ │ -int recompute_jets(double _f, double _Emin = 0.0, │ │ │ │ │ │ -00111 │ │ │ │ │ │ -Esplit_merge_scale _split_merge_scale=SM_Etilde); │ │ │ │ │ │ -00112 │ │ │ │ │ │ -00114 │ │ │ │ │ │ -std::vector > protocones_list; │ │ │ │ │ │ -00115 │ │ │ │ │ │ -00116 │ │ │ │ │ │ -// random number initialisation │ │ │ │ │ │ -00117 │ │ │ │ │ │ -static bool init_done; │ │ │ │ │ │ -00118 │ │ │ │ │ │ -00119 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00120 │ │ │ │ │ │ -int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ │ -00121 #endif │ │ │ │ │ │ -00122 │ │ │ │ │ │ -00134 │ │ │ │ │ │ -static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ -00135 │ │ │ │ │ │ -00140 │ │ │ │ │ │ -static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ -00141 │ │ │ │ │ │ -00142 private: │ │ │ │ │ │ -00143 │ │ │ │ │ │ -bool rerun_allowed; │ │ │ │ │ │ -00144 │ │ │ │ │ │ -static std::ostream * _banner_ostr; │ │ │ │ │ │ -00145 │ │ │ │ │ │ -00147 │ │ │ │ │ │ -void _initialise_if_needed(); │ │ │ │ │ │ -00148 │ │ │ │ │ │ -00149 }; │ │ │ │ │ │ -00150 │ │ │ │ │ │ -00151 │ │ │ │ │ │ -00152 // finally, a bunch of functions to access to │ │ │ │ │ │ -00153 // basic information (package name, version) │ │ │ │ │ │ -00154 //--------------------------------------------00155 │ │ │ │ │ │ -00163 std::string siscone_package_name(); │ │ │ │ │ │ -00164 │ │ │ │ │ │ -00170 std::string siscone_version(); │ │ │ │ │ │ -00171 │ │ │ │ │ │ -00172 } │ │ │ │ │ │ -00173 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.31 │ │ │ │ │ │ +5.25 │ │ │ │ │ │ │ │ │ │ │ │ siscone_error.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: siscone_error.cpp │ │ │ │ │ │ -00003 // Description: source file for SISCone error messages (Csiscone_error) │ │ │ │ │ │ -00004 // This file is part of the SISCone project. │ │ │ │ │ │ -00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ // │ │ │ │ │ │ +00003 // Description: source file for SISCone error messages (Csiscone_error) │ │ │ │ │ │ // │ │ │ │ │ │ +00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ +00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ - 226 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00006 // │ │ │ │ │ │ // │ │ │ │ │ │ 00007 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ 00008 // │ │ │ │ │ │ // │ │ │ │ │ │ 00009 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ @@ -18662,48 +19867,54 @@ │ │ │ │ │ │ 00028 │ │ │ │ │ │ 00029 namespace siscone{ │ │ │ │ │ │ 00030 │ │ │ │ │ │ 00031 bool Csiscone_error::m_print_errors = true; │ │ │ │ │ │ 00032 │ │ │ │ │ │ 00033 } │ │ │ │ │ │ │ │ │ │ │ │ -5.32 │ │ │ │ │ │ +5.26 │ │ │ │ │ │ │ │ │ │ │ │ siscone_error.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: siscone_error.h │ │ │ │ │ │ -// │ │ │ │ │ │ 00004 // Description: header file for SISCone error messages (Csiscone_error) │ │ │ │ │ │ -// │ │ │ │ │ │ 00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ 00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ 00007 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ 00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ 00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ 00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ 00013 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ 00014 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ 00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ 00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ // │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.27 geom_2d.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00018 // GNU General Public License for more details. │ │ │ │ │ │ // │ │ │ │ │ │ 00019 // │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ @@ -18752,19 +19963,15 @@ │ │ │ │ │ │ 00060 │ │ │ │ │ │ static bool m_print_errors; │ │ │ │ │ │ 00061 }; │ │ │ │ │ │ 00062 │ │ │ │ │ │ 00063 } │ │ │ │ │ │ 00064 #endif │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.33 geom_2d.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -5.33 │ │ │ │ │ │ +5.27 │ │ │ │ │ │ │ │ │ │ │ │ geom_2d.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: geom_2d.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: source file for two-dimensional geometry tools │ │ │ │ │ │ @@ -18828,14 +20035,23 @@ │ │ │ │ │ │ 00038 * This class deals with ranges in the eta-phi plane. It * │ │ │ │ │ │ 00039 * implements methods to test if two ranges overlap and * │ │ │ │ │ │ 00040 * to take the union of two overlapping intervals. │ │ │ │ │ │ * │ │ │ │ │ │ 00041 *********************************************************/ │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 using namespace std; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +233 │ │ │ │ │ │ + │ │ │ │ │ │ + 234 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00044 │ │ │ │ │ │ 00045 // static member default init │ │ │ │ │ │ 00046 //---------------------------00047 double Ceta_phi_range::eta_min = -100.0; │ │ │ │ │ │ 00048 double Ceta_phi_range::eta_max = 100.0; │ │ │ │ │ │ 00049 │ │ │ │ │ │ 00050 // default ctor │ │ │ │ │ │ 00051 //-------------00052 Ceta_phi_range::Ceta_phi_range(){ │ │ │ │ │ │ @@ -18889,23 +20105,14 @@ │ │ │ │ │ │ 00083 │ │ │ │ │ │ cell_min = get_phi_cell(xmin); │ │ │ │ │ │ 00084 │ │ │ │ │ │ cell_max = get_phi_cell(xmax); │ │ │ │ │ │ 00085 │ │ │ │ │ │ 00086 │ │ │ │ │ │ // Also, if the interval goes through pi, inversion is needed │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -227 │ │ │ │ │ │ - │ │ │ │ │ │ - 228 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00087 │ │ │ │ │ │ if (xmax>xmin) │ │ │ │ │ │ 00088 │ │ │ │ │ │ phi_range = (cell_max-cell_min)+cell_max; │ │ │ │ │ │ 00089 │ │ │ │ │ │ else { │ │ │ │ │ │ 00090 │ │ │ │ │ │ @@ -18957,14 +20164,21 @@ │ │ │ │ │ │ 00125 // return true if overlap, false otherwise. │ │ │ │ │ │ 00126 //-----------------------------------------00127 bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2){ │ │ │ │ │ │ 00128 │ │ │ │ │ │ // check overlap in eta AND phi │ │ │ │ │ │ 00129 │ │ │ │ │ │ return ((r1.eta_range & r2.eta_range) && (r1.phi_range & r2.phi_range)); │ │ │ │ │ │ 00130 } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.28 geom_2d.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +235 │ │ │ │ │ │ + │ │ │ │ │ │ 00131 │ │ │ │ │ │ 00132 // compute union │ │ │ │ │ │ 00133 // Note: we assume that the two intervals overlap │ │ │ │ │ │ 00134 // - r1 first range │ │ │ │ │ │ 00135 // - r2 second range │ │ │ │ │ │ 00136 // \return union of the two ranges │ │ │ │ │ │ 00137 //-----------------------------------------00138 const Ceta_phi_range range_union (const Ceta_phi_range &r1, const Ceta_phi_range &r2){ │ │ │ │ │ │ @@ -18983,56 +20197,49 @@ │ │ │ │ │ │ 00146 │ │ │ │ │ │ 00147 │ │ │ │ │ │ return tmp; │ │ │ │ │ │ 00148 } │ │ │ │ │ │ 00149 │ │ │ │ │ │ 00150 } │ │ │ │ │ │ │ │ │ │ │ │ -5.34 │ │ │ │ │ │ +5.28 │ │ │ │ │ │ │ │ │ │ │ │ geom_2d.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: geom_2d.cpp │ │ │ │ │ │ +// │ │ │ │ │ │ 00003 // Description: source file for two-dimensional geometry tools │ │ │ │ │ │ +// │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ 00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +// │ │ │ │ │ │ 00006 // │ │ │ │ │ │ an adaptation to spherical coordinates │ │ │ │ │ │ +// │ │ │ │ │ │ 00007 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ 00008 // │ │ │ │ │ │ +// │ │ │ │ │ │ 00009 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ 00010 // │ │ │ │ │ │ -00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -00014 // (at your option) any later version. │ │ │ │ │ │ -00015 // │ │ │ │ │ │ -00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ // │ │ │ │ │ │ +00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ +00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ +00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ +00014 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ +00015 // │ │ │ │ │ │ // │ │ │ │ │ │ +00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.34 geom_2d.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ 00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ // │ │ │ │ │ │ 00019 // GNU General Public License for more details. │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // │ │ │ │ │ │ @@ -19082,14 +20289,23 @@ │ │ │ │ │ │ 00056 │ │ │ │ │ │ phi_range = 0; │ │ │ │ │ │ 00057 } │ │ │ │ │ │ 00058 │ │ │ │ │ │ 00059 // ctor with initialisation │ │ │ │ │ │ 00060 // we initialise with a centre (in eta,phi) and a radius │ │ │ │ │ │ 00061 // - c_theta theta coordinate of the centre │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 236 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00062 // - c_phi │ │ │ │ │ │ phi coordinate of the centre │ │ │ │ │ │ 00063 // - R │ │ │ │ │ │ radius │ │ │ │ │ │ 00064 //------------------------------------------------------00065 CSphtheta_phi_range::CSphtheta_phi_range(double c_theta, double c_phi, double R){ │ │ │ │ │ │ 00066 │ │ │ │ │ │ // determination of the eta range │ │ │ │ │ │ @@ -19160,23 +20376,14 @@ │ │ │ │ │ │ 00101 │ │ │ │ │ │ } │ │ │ │ │ │ 00102 │ │ │ │ │ │ cell_min = get_phi_cell(ymin); │ │ │ │ │ │ 00103 │ │ │ │ │ │ cell_max = get_phi_cell(ymax); │ │ │ │ │ │ 00104 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -229 │ │ │ │ │ │ - │ │ │ │ │ │ - 230 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00105 │ │ │ │ │ │ // Also, if the interval goes through pi, inversion is needed │ │ │ │ │ │ 00106 │ │ │ │ │ │ if (ymax>ymin) │ │ │ │ │ │ 00107 │ │ │ │ │ │ phi_range = (cell_max-cell_min)+cell_max; │ │ │ │ │ │ 00108 │ │ │ │ │ │ @@ -19236,14 +20443,21 @@ │ │ │ │ │ │ 00144 │ │ │ │ │ │ phi_range |= get_phi_cell(phi); │ │ │ │ │ │ 00145 │ │ │ │ │ │ 00146 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00147 } │ │ │ │ │ │ 00148 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.29 geom_2d.h │ │ │ │ │ │ + │ │ │ │ │ │ +237 │ │ │ │ │ │ + │ │ │ │ │ │ 00149 │ │ │ │ │ │ 00150 // test overlap │ │ │ │ │ │ 00151 // - r1 first range │ │ │ │ │ │ 00152 // - r2 second range │ │ │ │ │ │ 00153 // return true if overlap, false otherwise. │ │ │ │ │ │ 00154 //-----------------------------------------00155 bool is_range_overlap(const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2){ │ │ │ │ │ │ 00156 │ │ │ │ │ │ @@ -19273,34 +20487,28 @@ │ │ │ │ │ │ 00174 │ │ │ │ │ │ 00175 │ │ │ │ │ │ return tmp; │ │ │ │ │ │ 00176 } │ │ │ │ │ │ 00177 │ │ │ │ │ │ 00178 } │ │ │ │ │ │ │ │ │ │ │ │ -5.35 │ │ │ │ │ │ +5.29 │ │ │ │ │ │ │ │ │ │ │ │ geom_2d.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: geom_2d.h │ │ │ │ │ │ -00004 // Description: header file for two-dimensional geometry tools │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -00007 // │ │ │ │ │ │ - │ │ │ │ │ │ // │ │ │ │ │ │ +00004 // Description: header file for two-dimensional geometry tools │ │ │ │ │ │ // │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ +00007 // │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.35 geom_2d.h │ │ │ │ │ │ - │ │ │ │ │ │ 00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ 00009 // │ │ │ │ │ │ // │ │ │ │ │ │ 00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ 00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ @@ -19360,14 +20568,21 @@ │ │ │ │ │ │ 00052 inline double dphi(double phi1, double phi2) { │ │ │ │ │ │ 00053 │ │ │ │ │ │ return phi_in_range(phi1-phi2); │ │ │ │ │ │ 00054 } │ │ │ │ │ │ 00055 │ │ │ │ │ │ 00056 │ │ │ │ │ │ 00060 inline double abs_dphi(double phi1, double phi2) { │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 238 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00061 │ │ │ │ │ │ double delta = fabs(phi1-phi2); │ │ │ │ │ │ 00062 │ │ │ │ │ │ return delta > M_PI ? twopi-delta : delta; │ │ │ │ │ │ 00063 } │ │ │ │ │ │ 00064 │ │ │ │ │ │ 00066 inline double pow2(double x) {return x*x;} │ │ │ │ │ │ @@ -19417,23 +20632,14 @@ │ │ │ │ │ │ 00135 │ │ │ │ │ │ 00140 │ │ │ │ │ │ int add_particle(const double eta, const double phi); │ │ │ │ │ │ 00141 │ │ │ │ │ │ 00143 │ │ │ │ │ │ unsigned int eta_range; │ │ │ │ │ │ 00144 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -231 │ │ │ │ │ │ - │ │ │ │ │ │ - 232 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00146 │ │ │ │ │ │ unsigned int phi_range; │ │ │ │ │ │ 00147 │ │ │ │ │ │ 00148 │ │ │ │ │ │ // extremal value for eta │ │ │ │ │ │ 00149 │ │ │ │ │ │ static double eta_min; │ │ │ │ │ │ @@ -19460,44 +20666,53 @@ │ │ │ │ │ │ 00169 │ │ │ │ │ │ 00175 const Ceta_phi_range range_union(const Ceta_phi_range &r1, const Ceta_phi_range &r2); │ │ │ │ │ │ 00176 │ │ │ │ │ │ 00177 } │ │ │ │ │ │ 00178 │ │ │ │ │ │ 00179 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.36 │ │ │ │ │ │ +5.30 │ │ │ │ │ │ │ │ │ │ │ │ geom_2d.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: geom_2d.h │ │ │ │ │ │ -// │ │ │ │ │ │ 00004 // Description: header file for two-dimensional geometry tools │ │ │ │ │ │ -// │ │ │ │ │ │ 00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ 00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ -// │ │ │ │ │ │ 00007 // │ │ │ │ │ │ an adaptation to spherical coordinates │ │ │ │ │ │ -// │ │ │ │ │ │ 00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ 00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ 00011 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ 00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ 00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ 00015 // (at your option) any later version. │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ // │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.31 hash.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +239 │ │ │ │ │ │ + │ │ │ │ │ │ 00016 // │ │ │ │ │ │ // │ │ │ │ │ │ 00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ 00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ 00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ @@ -19552,23 +20767,14 @@ │ │ │ │ │ │ 00078 │ │ │ │ │ │ unsigned int phi_range; │ │ │ │ │ │ 00079 │ │ │ │ │ │ 00081 │ │ │ │ │ │ static double theta_min; │ │ │ │ │ │ 00082 │ │ │ │ │ │ static double theta_max; │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.37 hash.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -233 │ │ │ │ │ │ - │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00084 private: │ │ │ │ │ │ 00086 │ │ │ │ │ │ inline unsigned int get_theta_cell(double theta){ │ │ │ │ │ │ 00087 │ │ │ │ │ │ if (theta>=theta_max) return 1u«31; │ │ │ │ │ │ 00088 │ │ │ │ │ │ @@ -19588,53 +20794,61 @@ │ │ │ │ │ │ 00102 │ │ │ │ │ │ 00108 const CSphtheta_phi_range range_union(const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2); │ │ │ │ │ │ 00109 │ │ │ │ │ │ 00110 } │ │ │ │ │ │ 00111 │ │ │ │ │ │ 00112 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.37 │ │ │ │ │ │ +5.31 │ │ │ │ │ │ │ │ │ │ │ │ hash.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: hash.cpp │ │ │ │ │ │ -// │ │ │ │ │ │ 00003 // Description: source file for classes hash_element and hash_cones │ │ │ │ │ │ -// │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ 00006 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00007 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ 00008 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00009 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ 00010 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ 00011 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ 00012 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ 00013 // │ │ │ │ │ │ -// │ │ │ │ │ │ 00014 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ 00015 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ 00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ 00017 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ 00018 // │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ // │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 240 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00019 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00022 // │ │ │ │ │ │ // │ │ │ │ │ │ @@ -19688,21 +20902,14 @@ │ │ │ │ │ │ 00059 │ │ │ │ │ │ int nbits = (int) (log(_Np*_R2*_Np/4.0)/log(2.0)); │ │ │ │ │ │ 00060 │ │ │ │ │ │ if (nbits<1) nbits=1; │ │ │ │ │ │ 00061 │ │ │ │ │ │ mask = 1 « nbits; │ │ │ │ │ │ 00062 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 234 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00063 │ │ │ │ │ │ // create hash │ │ │ │ │ │ 00064 │ │ │ │ │ │ hash_array = new hash_element*[mask]; │ │ │ │ │ │ 00065 │ │ │ │ │ │ mask--; │ │ │ │ │ │ 00066 │ │ │ │ │ │ @@ -19763,14 +20970,19 @@ │ │ │ │ │ │ 00103 │ │ │ │ │ │ hash_element *elm; │ │ │ │ │ │ 00104 │ │ │ │ │ │ int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ 00105 │ │ │ │ │ │ 00106 │ │ │ │ │ │ // check the array cell corresponding to our reference │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.31 hash.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00107 │ │ │ │ │ │ elm = hash_array[index]; │ │ │ │ │ │ 00108 │ │ │ │ │ │ 00109 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00110 │ │ │ │ │ │ if (elm==NULL) │ │ │ │ │ │ 00111 │ │ │ │ │ │ @@ -19842,19 +21054,14 @@ │ │ │ │ │ │ 00147 │ │ │ │ │ │ elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io)); │ │ │ │ │ │ 00148 │ │ │ │ │ │ //cout « " parent/child: " │ │ │ │ │ │ 00149 │ │ │ │ │ │ // │ │ │ │ │ │ « parent->ref[0] « ":" « is_inside(v, parent) « ":" « p_io « " " │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.37 hash.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00150 │ │ │ │ │ │ // │ │ │ │ │ │ « child->ref[0] « ":" « is_inside(v, child) « ":" « c_io « endl; │ │ │ │ │ │ 00151 │ │ │ │ │ │ //cout « "-- rep status of " « v->ref[0] « ":" « elm->is_stable « endl; │ │ │ │ │ │ 00152 │ │ │ │ │ │ //cout « v->eta « " " « v->phi « endl; │ │ │ │ │ │ @@ -19923,14 +21130,23 @@ │ │ │ │ │ │ 00190 │ │ │ │ │ │ elm->is_stable = true; │ │ │ │ │ │ 00191 │ │ │ │ │ │ 00192 │ │ │ │ │ │ // update hash │ │ │ │ │ │ 00193 │ │ │ │ │ │ elm->next = hash_array[index]; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +241 │ │ │ │ │ │ + │ │ │ │ │ │ + 242 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00194 │ │ │ │ │ │ hash_array[index] = elm; │ │ │ │ │ │ 00195 │ │ │ │ │ │ 00196 │ │ │ │ │ │ n_cones++; │ │ │ │ │ │ 00197 │ │ │ │ │ │ return 0; │ │ │ │ │ │ @@ -19980,23 +21196,15 @@ │ │ │ │ │ │ 00226 │ │ │ │ │ │ 00227 │ │ │ │ │ │ return dx*dx+dy*dynext; │ │ │ │ │ │ 00088 │ │ │ │ │ │ delete elm; │ │ │ │ │ │ 00089 │ │ │ │ │ │ } │ │ │ │ │ │ 00090 │ │ │ │ │ │ @@ -20209,14 +21417,21 @@ │ │ │ │ │ │ 00127 │ │ │ │ │ │ 00128 │ │ │ │ │ │ // if at least one of the two is_closer tests gives a result != from the expected, │ │ │ │ │ │ 00129 │ │ │ │ │ │ // the || will be true hence !(...) false as wanted │ │ │ │ │ │ 00130 │ │ │ │ │ │ elm->is_stable = !((is_closer(v, parent, tan2R)^p_io)||(is_closer(v, child, tan2R)^c_io)); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 244 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00131 │ │ │ │ │ │ //cout « "-- new status of " « v->ref[0] « ":" « elm->is_stable « endl; │ │ │ │ │ │ 00132 │ │ │ │ │ │ 00133 │ │ │ │ │ │ // update hash │ │ │ │ │ │ 00134 │ │ │ │ │ │ elm->next = hash_array[index]; │ │ │ │ │ │ @@ -20281,21 +21496,14 @@ │ │ │ │ │ │ 00169 int sph_hash_cones::insert(CSphmomentum *v){ │ │ │ │ │ │ 00170 │ │ │ │ │ │ sph_hash_element *elm; │ │ │ │ │ │ 00171 │ │ │ │ │ │ int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ 00172 │ │ │ │ │ │ //cout « "-- stable candidate: " « v->ref[0] « ":" « endl; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 238 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00173 │ │ │ │ │ │ 00174 │ │ │ │ │ │ // check the array cell corresponding to our reference │ │ │ │ │ │ 00175 │ │ │ │ │ │ elm = hash_array[index]; │ │ │ │ │ │ 00176 │ │ │ │ │ │ do{ │ │ │ │ │ │ @@ -20350,22 +21558,260 @@ │ │ │ │ │ │ 00203 │ │ │ │ │ │ 00204 │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00205 } │ │ │ │ │ │ 00206 │ │ │ │ │ │ 00207 } │ │ │ │ │ │ │ │ │ │ │ │ -5.39 │ │ │ │ │ │ +5.33 │ │ │ │ │ │ │ │ │ │ │ │ -protocones.cpp │ │ │ │ │ │ +hash.h │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: hash.h │ │ │ │ │ │ +00004 // Description: header file for classes hash_element and hash_cones │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.34 hash.h │ │ │ │ │ │ + │ │ │ │ │ │ +245 │ │ │ │ │ │ + │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00023 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // $Revision:: 224 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00025 // $Date:: 2008-05-16 19:58:30 +0200 (Fri, 16 May 2008) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 │ │ │ │ │ │ +00028 #ifndef __HASH_H__ │ │ │ │ │ │ +00029 #define __HASH_H__ │ │ │ │ │ │ +00030 │ │ │ │ │ │ +00031 #include "momentum.h" │ │ │ │ │ │ +00032 #include "reference.h" │ │ │ │ │ │ +00033 │ │ │ │ │ │ +00034 namespace siscone{ │ │ │ │ │ │ +00035 │ │ │ │ │ │ +00045 class hash_element{ │ │ │ │ │ │ +00046 public: │ │ │ │ │ │ +00047 │ │ │ │ │ │ +Creference ref; │ │ │ │ │ │ +00048 │ │ │ │ │ │ +double eta; │ │ │ │ │ │ +00049 │ │ │ │ │ │ +double phi; │ │ │ │ │ │ +00050 │ │ │ │ │ │ +bool is_stable; │ │ │ │ │ │ +00051 │ │ │ │ │ │ +00052 │ │ │ │ │ │ +hash_element *next; │ │ │ │ │ │ +00053 }; │ │ │ │ │ │ +00054 │ │ │ │ │ │ +00062 class hash_cones{ │ │ │ │ │ │ +00063 public: │ │ │ │ │ │ +00067 │ │ │ │ │ │ +hash_cones(int _Np, double _R2); │ │ │ │ │ │ +00068 │ │ │ │ │ │ +00070 │ │ │ │ │ │ +~hash_cones(); │ │ │ │ │ │ +00071 │ │ │ │ │ │ +00081 │ │ │ │ │ │ +int insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io); │ │ │ │ │ │ +00082 │ │ │ │ │ │ +00090 │ │ │ │ │ │ +int insert(Cmomentum *v); │ │ │ │ │ │ +00091 │ │ │ │ │ │ +00093 │ │ │ │ │ │ +hash_element **hash_array; │ │ │ │ │ │ +00094 │ │ │ │ │ │ +00096 │ │ │ │ │ │ +int n_cones; │ │ │ │ │ │ +00097 │ │ │ │ │ │ +00099 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00100 │ │ │ │ │ │ +int n_occupied_cells; │ │ │ │ │ │ +00101 #endif │ │ │ │ │ │ +00102 │ │ │ │ │ │ +00104 │ │ │ │ │ │ +int mask; │ │ │ │ │ │ +00105 │ │ │ │ │ │ +00108 │ │ │ │ │ │ +double R2; │ │ │ │ │ │ +00109 │ │ │ │ │ │ +00118 │ │ │ │ │ │ +inline bool is_inside(Cmomentum *centre, Cmomentum *v); │ │ │ │ │ │ +00119 }; │ │ │ │ │ │ +00120 │ │ │ │ │ │ +00121 } │ │ │ │ │ │ +00122 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.34 │ │ │ │ │ │ + │ │ │ │ │ │ +hash.h │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: hash.h │ │ │ │ │ │ +00004 // Description: header file for classes hash_element and hash_cones │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ +00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +00007 // │ │ │ │ │ │ +an adaptation to spherical coordinates │ │ │ │ │ │ +00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +00009 // │ │ │ │ │ │ +00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +00011 // │ │ │ │ │ │ +00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 246 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00015 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00025 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00026 // $Revision:: 294 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 // $Date:: 2009-05-01 17:15:04 +0200 (Fri, 01 May 2009) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00029 │ │ │ │ │ │ +00030 #ifndef __SPH_HASH_H__ │ │ │ │ │ │ +00031 #define __SPH_HASH_H__ │ │ │ │ │ │ +00032 │ │ │ │ │ │ +00033 #include "momentum.h" │ │ │ │ │ │ +00034 │ │ │ │ │ │ +00035 namespace siscone_spherical{ │ │ │ │ │ │ +00036 │ │ │ │ │ │ +00046 class sph_hash_element{ │ │ │ │ │ │ +00047 public: │ │ │ │ │ │ +00048 │ │ │ │ │ │ +CSph3vector centre; │ │ │ │ │ │ +00049 │ │ │ │ │ │ +bool is_stable; │ │ │ │ │ │ +00050 │ │ │ │ │ │ +00051 │ │ │ │ │ │ +sph_hash_element *next; │ │ │ │ │ │ +00052 }; │ │ │ │ │ │ +00053 │ │ │ │ │ │ +00061 class sph_hash_cones{ │ │ │ │ │ │ +00062 public: │ │ │ │ │ │ +00065 │ │ │ │ │ │ +sph_hash_cones(int _Np, double _radius); │ │ │ │ │ │ +00066 │ │ │ │ │ │ +00068 │ │ │ │ │ │ +~sph_hash_cones(); │ │ │ │ │ │ +00069 │ │ │ │ │ │ +00079 │ │ │ │ │ │ +int insert(CSphmomentum *v, CSphmomentum *parent, CSphmomentum *child, bool p_io, bool c_io); │ │ │ │ │ │ +00080 │ │ │ │ │ │ +00088 │ │ │ │ │ │ +int insert(CSphmomentum *v); │ │ │ │ │ │ +00089 │ │ │ │ │ │ +00091 │ │ │ │ │ │ +sph_hash_element **hash_array; │ │ │ │ │ │ +00092 │ │ │ │ │ │ +00094 │ │ │ │ │ │ +int n_cones; │ │ │ │ │ │ +00095 │ │ │ │ │ │ +00097 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00098 │ │ │ │ │ │ +int n_occupied_cells; │ │ │ │ │ │ +00099 #endif │ │ │ │ │ │ +00100 │ │ │ │ │ │ +00102 │ │ │ │ │ │ +int mask; │ │ │ │ │ │ +00103 │ │ │ │ │ │ +00106 │ │ │ │ │ │ +double R2; │ │ │ │ │ │ +00107 │ │ │ │ │ │ +00109 │ │ │ │ │ │ +double tan2R; │ │ │ │ │ │ +00110 }; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +00112 } │ │ │ │ │ │ +00113 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.35 │ │ │ │ │ │ + │ │ │ │ │ │ +momentum.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ -00002 // File: protocones.cpp │ │ │ │ │ │ +00002 // File: momentum.cpp │ │ │ │ │ │ // │ │ │ │ │ │ -00003 // Description: source file for stable cones determination (Cstable_cones) │ │ │ │ │ │ +00003 // Description: source file for 4-momentum class Cmomentum │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // │ │ │ │ │ │ // │ │ │ │ │ │ @@ -20396,2852 +21842,1128 @@ │ │ │ │ │ │ 00019 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00022 // │ │ │ │ │ │ // │ │ │ │ │ │ -00023 // $Revision:: 322 │ │ │ │ │ │ +00023 // $Revision:: 123 │ │ │ │ │ │ $// │ │ │ │ │ │ -00024 // $Date:: 2011-11-15 10:12:36 +0100 (Tue, 15 Nov 2011) │ │ │ │ │ │ +00024 // $Date:: 2007-03-01 02:52:16 +0100 (Thu, 01 Mar 2007) │ │ │ │ │ │ $// │ │ │ │ │ │ -00026 │ │ │ │ │ │ -00027 /******************************************************* │ │ │ │ │ │ -00028 * Introductory note: │ │ │ │ │ │ -* │ │ │ │ │ │ -00029 * Since this file has many member functions, we have * │ │ │ │ │ │ -00030 * structured them in categories: │ │ │ │ │ │ -* │ │ │ │ │ │ -00031 * INITIALISATION FUNCTIONS │ │ │ │ │ │ -* │ │ │ │ │ │ -00032 * - ctor() │ │ │ │ │ │ -* │ │ │ │ │ │ -00033 * - ctor(particle_list) │ │ │ │ │ │ -* │ │ │ │ │ │ -00034 * - dtor() │ │ │ │ │ │ -* │ │ │ │ │ │ -00035 * - init(particle_list) │ │ │ │ │ │ -* │ │ │ │ │ │ -00036 * ALGORITHM MAIN ENTRY │ │ │ │ │ │ -* │ │ │ │ │ │ -00037 * - get_stable_cone(radius) │ │ │ │ │ │ -* │ │ │ │ │ │ -00038 * ALGORITHM MAIN STEPS │ │ │ │ │ │ -* │ │ │ │ │ │ -00039 * - init_cone() │ │ │ │ │ │ -* │ │ │ │ │ │ -00040 * - test_cone() │ │ │ │ │ │ -* │ │ │ │ │ │ -00041 * - update_cone() │ │ │ │ │ │ -* │ │ │ │ │ │ -00042 * - proceed_with_stability() │ │ │ │ │ │ -* │ │ │ │ │ │ -00043 * ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ -* │ │ │ │ │ │ -00044 * - cocircular_pt_less(v1, v2) │ │ │ │ │ │ -* │ │ │ │ │ │ -00045 * - prepare_cocircular_list() │ │ │ │ │ │ -* │ │ │ │ │ │ -00046 * - test_cone_cocircular() │ │ │ │ │ │ -* │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.39 protocones.cpp │ │ │ │ │ │ + 5.35 momentum.cpp │ │ │ │ │ │ │ │ │ │ │ │ -00047 * - test_stability(candidate, border_list) │ │ │ │ │ │ -* │ │ │ │ │ │ -00048 * - updat_cone_cocircular() │ │ │ │ │ │ -* │ │ │ │ │ │ -00049 * RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ -* │ │ │ │ │ │ -00050 * - compute_cone_contents() │ │ │ │ │ │ -* │ │ │ │ │ │ -00051 * - recompute_cone_contents() │ │ │ │ │ │ -* │ │ │ │ │ │ -00052 * - recompute_cone_contents_if_needed() │ │ │ │ │ │ -* │ │ │ │ │ │ -00053 * VARIOUS TOOLS │ │ │ │ │ │ -* │ │ │ │ │ │ -00054 * - circle_intersect() │ │ │ │ │ │ +00026 │ │ │ │ │ │ +00027 #include "momentum.h" │ │ │ │ │ │ +00028 #include │ │ │ │ │ │ +00029 #include │ │ │ │ │ │ +00030 │ │ │ │ │ │ +00031 namespace siscone{ │ │ │ │ │ │ +00032 │ │ │ │ │ │ +00033 /************************************************************************* │ │ │ │ │ │ +00034 * class Cmomentum │ │ │ │ │ │ * │ │ │ │ │ │ -00055 * - is_inside() │ │ │ │ │ │ +00035 * This class contains the information for particle or group of │ │ │ │ │ │ * │ │ │ │ │ │ -00056 * - abs_dangle() │ │ │ │ │ │ +00036 * particles management. │ │ │ │ │ │ * │ │ │ │ │ │ -00057 *******************************************************/ │ │ │ │ │ │ +00037 * It includes all Lorentz properties as well as tools for summing them. * │ │ │ │ │ │ +00038 *************************************************************************/ │ │ │ │ │ │ +00039 │ │ │ │ │ │ +00040 // default ctor │ │ │ │ │ │ +00041 //-------------00042 Cmomentum::Cmomentum(){ │ │ │ │ │ │ +00043 │ │ │ │ │ │ +eta = 0.0; │ │ │ │ │ │ +00044 │ │ │ │ │ │ +phi = 0.0; │ │ │ │ │ │ +00045 │ │ │ │ │ │ +px = py = pz = E = 0.0; │ │ │ │ │ │ +00046 │ │ │ │ │ │ +ref = Creference(); │ │ │ │ │ │ +00047 │ │ │ │ │ │ +index = -1; │ │ │ │ │ │ +00048 } │ │ │ │ │ │ +00049 │ │ │ │ │ │ +00050 // ctor with initialisation │ │ │ │ │ │ +00051 //-------------------------00052 Cmomentum::Cmomentum(double _px, double _py, double _pz, double _E){ │ │ │ │ │ │ +00053 │ │ │ │ │ │ +px = _px; │ │ │ │ │ │ +00054 │ │ │ │ │ │ +py = _py; │ │ │ │ │ │ +00055 │ │ │ │ │ │ +pz = _pz; │ │ │ │ │ │ +00056 │ │ │ │ │ │ +E = _E; │ │ │ │ │ │ +00057 │ │ │ │ │ │ 00058 │ │ │ │ │ │ -00059 #include "protocones.h" │ │ │ │ │ │ -00060 #include "siscone_error.h" │ │ │ │ │ │ -00061 #include "defines.h" │ │ │ │ │ │ -00062 #include │ │ │ │ │ │ -00063 #include │ │ │ │ │ │ -00064 #include "circulator.h" │ │ │ │ │ │ -00065 #include │ │ │ │ │ │ +// compute eta and phi │ │ │ │ │ │ +00059 │ │ │ │ │ │ +build_etaphi(); │ │ │ │ │ │ +00060 │ │ │ │ │ │ +ref = Creference(); │ │ │ │ │ │ +00061 } │ │ │ │ │ │ +00062 │ │ │ │ │ │ +00063 // ctor with detailed initialisation │ │ │ │ │ │ +00064 //----------------------------------00065 Cmomentum::Cmomentum(double _eta, double _phi, Creference _ref){ │ │ │ │ │ │ 00066 │ │ │ │ │ │ -00067 namespace siscone{ │ │ │ │ │ │ +eta = _eta; │ │ │ │ │ │ +00067 │ │ │ │ │ │ +phi = _phi; │ │ │ │ │ │ 00068 │ │ │ │ │ │ -00069 using namespace std; │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 /********************************************************************** │ │ │ │ │ │ -00072 * Cstable_cones implementation │ │ │ │ │ │ -* │ │ │ │ │ │ -00073 * Computes the list of stable comes from a particle list. │ │ │ │ │ │ -* │ │ │ │ │ │ -00074 * This class does the first fundamental task of te cone algorithm: │ │ │ │ │ │ -* │ │ │ │ │ │ -00075 * it is used to compute the list of stable cones given a list │ │ │ │ │ │ -* │ │ │ │ │ │ -00076 * of particles. │ │ │ │ │ │ -* │ │ │ │ │ │ -00077 **********************************************************************/ │ │ │ │ │ │ -00078 │ │ │ │ │ │ -00080 // INITIALISATION FUNCTIONS │ │ │ │ │ │ -// │ │ │ │ │ │ -00081 // - ctor() │ │ │ │ │ │ -// │ │ │ │ │ │ -00082 // - ctor(particle_list) │ │ │ │ │ │ -// │ │ │ │ │ │ -00083 // - dtor() │ │ │ │ │ │ -// │ │ │ │ │ │ -00084 // - init(particle_list) │ │ │ │ │ │ -// │ │ │ │ │ │ +00069 │ │ │ │ │ │ +ref = _ref; │ │ │ │ │ │ +00070 } │ │ │ │ │ │ +00071 │ │ │ │ │ │ +00072 // default dtor │ │ │ │ │ │ +00073 //-------------00074 Cmomentum::~Cmomentum(){ │ │ │ │ │ │ +00075 │ │ │ │ │ │ +00076 } │ │ │ │ │ │ +00077 │ │ │ │ │ │ +00078 // assignment of vectors │ │ │ │ │ │ +00079 //----------------------00080 Cmomentum& Cmomentum::operator = (const Cmomentum &v){ │ │ │ │ │ │ +00081 │ │ │ │ │ │ +px = v.px; │ │ │ │ │ │ +00082 │ │ │ │ │ │ +py = v.py; │ │ │ │ │ │ +00083 │ │ │ │ │ │ +pz = v.pz; │ │ │ │ │ │ +00084 │ │ │ │ │ │ +E = v.E; │ │ │ │ │ │ +00085 │ │ │ │ │ │ 00086 │ │ │ │ │ │ -00087 // default ctor │ │ │ │ │ │ -00088 //-------------00089 Cstable_cones::Cstable_cones(){ │ │ │ │ │ │ +eta = v.eta; │ │ │ │ │ │ +00087 │ │ │ │ │ │ +phi = v.phi; │ │ │ │ │ │ +00088 │ │ │ │ │ │ +00089 │ │ │ │ │ │ +ref = v.ref; │ │ │ │ │ │ 00090 │ │ │ │ │ │ -nb_tot = 0; │ │ │ │ │ │ -00091 │ │ │ │ │ │ -hc = NULL; │ │ │ │ │ │ -00092 } │ │ │ │ │ │ -00093 │ │ │ │ │ │ -00094 // ctor with initialisation │ │ │ │ │ │ -00095 //-------------------------00096 Cstable_cones::Cstable_cones(vector &_particle_list) │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00091 } │ │ │ │ │ │ +00092 │ │ │ │ │ │ +00093 // addition of vectors │ │ │ │ │ │ +00094 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00095 //-----------------------------------------------00096 const Cmomentum Cmomentum::operator + (const Cmomentum &v){ │ │ │ │ │ │ 00097 │ │ │ │ │ │ -: Cvicinity(_particle_list){ │ │ │ │ │ │ +Cmomentum tmp = *this; │ │ │ │ │ │ 00098 │ │ │ │ │ │ -00099 │ │ │ │ │ │ -nb_tot = 0; │ │ │ │ │ │ +return tmp+=v; │ │ │ │ │ │ +00099 } │ │ │ │ │ │ 00100 │ │ │ │ │ │ -hc = NULL; │ │ │ │ │ │ -00101 } │ │ │ │ │ │ -00102 │ │ │ │ │ │ -00103 // default dtor │ │ │ │ │ │ -00104 //-------------00105 Cstable_cones::~Cstable_cones(){ │ │ │ │ │ │ +00101 // incrementation of vectors │ │ │ │ │ │ +00102 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00103 //-----------------------------------------------00104 Cmomentum& Cmomentum::operator += (const Cmomentum &v){ │ │ │ │ │ │ +00105 │ │ │ │ │ │ +px+=v.px; │ │ │ │ │ │ 00106 │ │ │ │ │ │ -if (hc!=NULL) delete hc; │ │ │ │ │ │ -00107 } │ │ │ │ │ │ +py+=v.py; │ │ │ │ │ │ +00107 │ │ │ │ │ │ +pz+=v.pz; │ │ │ │ │ │ 00108 │ │ │ │ │ │ -00109 /* │ │ │ │ │ │ -00110 * initialisation │ │ │ │ │ │ -00111 * - _particle_list list of particles │ │ │ │ │ │ -00112 * - _n │ │ │ │ │ │ -number of particles │ │ │ │ │ │ -00113 *********************************************************************/ │ │ │ │ │ │ -00114 void Cstable_cones::init(vector &_particle_list){ │ │ │ │ │ │ -00115 │ │ │ │ │ │ -// check already allocated mem │ │ │ │ │ │ -00116 │ │ │ │ │ │ -if (hc!=NULL){ │ │ │ │ │ │ -00117 │ │ │ │ │ │ -delete hc; │ │ │ │ │ │ -00118 │ │ │ │ │ │ -} │ │ │ │ │ │ +E +=v.E; │ │ │ │ │ │ +00109 │ │ │ │ │ │ +00110 │ │ │ │ │ │ +ref+=v.ref; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +00112 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +247 │ │ │ │ │ │ + │ │ │ │ │ │ + 248 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00113 } │ │ │ │ │ │ +00114 │ │ │ │ │ │ +00115 // incrementation of vectors │ │ │ │ │ │ +00116 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00117 //-----------------------------------------------00118 Cmomentum& Cmomentum::operator -= (const Cmomentum &v){ │ │ │ │ │ │ 00119 │ │ │ │ │ │ -if (protocones.size()!=0) │ │ │ │ │ │ +px-=v.px; │ │ │ │ │ │ 00120 │ │ │ │ │ │ -protocones.clear(); │ │ │ │ │ │ +py-=v.py; │ │ │ │ │ │ 00121 │ │ │ │ │ │ +pz-=v.pz; │ │ │ │ │ │ 00122 │ │ │ │ │ │ -multiple_centre_done.clear(); │ │ │ │ │ │ +E -=v.E; │ │ │ │ │ │ 00123 │ │ │ │ │ │ 00124 │ │ │ │ │ │ -// initialisation │ │ │ │ │ │ +ref-=v.ref; │ │ │ │ │ │ 00125 │ │ │ │ │ │ -set_particle_list(_particle_list); │ │ │ │ │ │ +return *this; │ │ │ │ │ │ 00126 } │ │ │ │ │ │ 00127 │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00130 // ALGORITHM MAIN ENTRY │ │ │ │ │ │ +00128 // build eta-phi from 4-momentum info │ │ │ │ │ │ +00129 // !!! │ │ │ │ │ │ +WARNING │ │ │ │ │ │ +!!! │ │ │ │ │ │ +00130 // !!! computing eta and phi is time-consuming !!! │ │ │ │ │ │ +00131 // !!! use this whenever you need eta or phi │ │ │ │ │ │ +!!! │ │ │ │ │ │ +00132 // !!! automatically called for single-particle !!! │ │ │ │ │ │ +00133 //-------------------------------------------------00134 void Cmomentum::build_etaphi(){ │ │ │ │ │ │ +00135 │ │ │ │ │ │ +// note: the factor n (ref.nb) cancels in all expressions !! │ │ │ │ │ │ +00136 │ │ │ │ │ │ +eta = 0.5*log((E+pz)/(E-pz)); │ │ │ │ │ │ +00137 │ │ │ │ │ │ +phi = atan2(py,px); │ │ │ │ │ │ +00138 } │ │ │ │ │ │ +00139 │ │ │ │ │ │ +00140 │ │ │ │ │ │ +00141 // ordering of two vectors │ │ │ │ │ │ +00142 // the default ordering is w.r.t. their references │ │ │ │ │ │ +00143 //------------------------------------------------00144 bool operator < (const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ │ +00145 │ │ │ │ │ │ +return v1.ref < v2.ref; │ │ │ │ │ │ +00146 } │ │ │ │ │ │ +00147 │ │ │ │ │ │ +00148 // ordering of vectors in eta (e.g. used in collinear tests) │ │ │ │ │ │ +00149 //----------------------------------------------------------00150 bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ │ +00151 │ │ │ │ │ │ +return v1.eta < v2.eta; │ │ │ │ │ │ +00152 } │ │ │ │ │ │ +00153 │ │ │ │ │ │ +00154 // ordering of vectors in pt │ │ │ │ │ │ +00155 //--------------------------00156 bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2){ │ │ │ │ │ │ +00157 │ │ │ │ │ │ +return v1.perp2() < v2.perp2(); │ │ │ │ │ │ +00158 } │ │ │ │ │ │ +00159 │ │ │ │ │ │ +00160 } │ │ │ │ │ │ +00161 │ │ │ │ │ │ + │ │ │ │ │ │ +5.36 │ │ │ │ │ │ + │ │ │ │ │ │ +momentum.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00001 │ │ │ │ │ │ +00002 // File: momentum.cpp │ │ │ │ │ │ // │ │ │ │ │ │ -00131 // - get_stable_cone(radius) │ │ │ │ │ │ +00003 // Description: source file for 4-momentum class Cmomentum │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // │ │ │ │ │ │ +an adaptation to spherical coordinates │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +00010 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00023 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00024 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00025 // $Revision:: 255 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00026 // $Date:: 2008-07-12 17:40:35 +0200 (Sat, 12 Jul 2008) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00028 │ │ │ │ │ │ +00029 #include "momentum.h" │ │ │ │ │ │ +00030 #include │ │ │ │ │ │ +00031 #include │ │ │ │ │ │ +00032 │ │ │ │ │ │ + │ │ │ │ │ │ // │ │ │ │ │ │ -00133 │ │ │ │ │ │ -00134 /* │ │ │ │ │ │ -00135 * compute stable cones. │ │ │ │ │ │ -00136 * This function really does the job i.e. computes │ │ │ │ │ │ -00137 * the list of stable cones (in a seedless way) │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -239 │ │ │ │ │ │ + 5.36 momentum.cpp │ │ │ │ │ │ │ │ │ │ │ │ - 240 │ │ │ │ │ │ +00033 namespace siscone_spherical{ │ │ │ │ │ │ +00034 │ │ │ │ │ │ +00035 /************************************************************************* │ │ │ │ │ │ +00036 * class CSph3vector │ │ │ │ │ │ +* │ │ │ │ │ │ +00037 * This class contains the information for particle or group of │ │ │ │ │ │ +* │ │ │ │ │ │ +00038 * particles management. │ │ │ │ │ │ +* │ │ │ │ │ │ +00039 *************************************************************************/ │ │ │ │ │ │ +00040 │ │ │ │ │ │ +00041 // default ctor │ │ │ │ │ │ +00042 //-------------00043 CSph3vector::CSph3vector(){ │ │ │ │ │ │ +00044 │ │ │ │ │ │ +_theta = _phi = _norm = 0.0; │ │ │ │ │ │ +00045 │ │ │ │ │ │ +px = py = pz = 0.0; │ │ │ │ │ │ +00046 │ │ │ │ │ │ +ref = siscone::Creference(); │ │ │ │ │ │ +00047 } │ │ │ │ │ │ +00048 │ │ │ │ │ │ +00049 // ctor with initialisation │ │ │ │ │ │ +00050 //-------------------------00051 CSph3vector::CSph3vector(double _px, double _py, double _pz){ │ │ │ │ │ │ +00052 │ │ │ │ │ │ +px = _px; │ │ │ │ │ │ +00053 │ │ │ │ │ │ +py = _py; │ │ │ │ │ │ +00054 │ │ │ │ │ │ +pz = _pz; │ │ │ │ │ │ +00055 │ │ │ │ │ │ +00056 │ │ │ │ │ │ +// compute the norm │ │ │ │ │ │ +00057 │ │ │ │ │ │ +build_norm(); │ │ │ │ │ │ +00058 │ │ │ │ │ │ +00059 │ │ │ │ │ │ +ref = siscone::Creference(); │ │ │ │ │ │ +00060 } │ │ │ │ │ │ +00061 │ │ │ │ │ │ +00062 // default dtor │ │ │ │ │ │ +00063 //-------------00064 CSph3vector::~CSph3vector(){ │ │ │ │ │ │ +00065 │ │ │ │ │ │ +00066 } │ │ │ │ │ │ +00067 │ │ │ │ │ │ +00068 │ │ │ │ │ │ +00069 // assignment of vectors │ │ │ │ │ │ +00070 //----------------------00071 CSph3vector& CSph3vector::operator = (const CSph3vector &v){ │ │ │ │ │ │ +00072 │ │ │ │ │ │ +px = v.px; │ │ │ │ │ │ +00073 │ │ │ │ │ │ +py = v.py; │ │ │ │ │ │ +00074 │ │ │ │ │ │ +pz = v.pz; │ │ │ │ │ │ +00075 │ │ │ │ │ │ +00076 │ │ │ │ │ │ +_norm = v._norm; │ │ │ │ │ │ +00077 │ │ │ │ │ │ +_theta = v._theta; │ │ │ │ │ │ +00078 │ │ │ │ │ │ +_phi │ │ │ │ │ │ += v._phi; │ │ │ │ │ │ +00079 │ │ │ │ │ │ +00080 │ │ │ │ │ │ +ref = v.ref; │ │ │ │ │ │ +00081 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00082 } │ │ │ │ │ │ +00083 │ │ │ │ │ │ +00084 // addition of vectors │ │ │ │ │ │ +00085 //-----------------------------------------------00086 const CSph3vector CSph3vector::operator + (const CSph3vector &v){ │ │ │ │ │ │ +00087 │ │ │ │ │ │ +CSph3vector tmp = *this; │ │ │ │ │ │ +00088 │ │ │ │ │ │ +return tmp+=v; │ │ │ │ │ │ +00089 } │ │ │ │ │ │ +00090 │ │ │ │ │ │ +00091 // subtraction of vectors │ │ │ │ │ │ +00092 //-----------------------------------------------00093 const CSph3vector CSph3vector::operator - (const CSph3vector &v){ │ │ │ │ │ │ +00094 │ │ │ │ │ │ +CSph3vector tmp = *this; │ │ │ │ │ │ +00095 │ │ │ │ │ │ +return tmp-=v; │ │ │ │ │ │ +00096 } │ │ │ │ │ │ +00097 │ │ │ │ │ │ +00098 // division by constant │ │ │ │ │ │ +00099 //-----------------------------------------------00100 const CSph3vector CSph3vector::operator / (const double &r){ │ │ │ │ │ │ +00101 │ │ │ │ │ │ +CSph3vector tmp = *this; │ │ │ │ │ │ +00102 │ │ │ │ │ │ +return tmp/=r; │ │ │ │ │ │ +00103 } │ │ │ │ │ │ +00104 │ │ │ │ │ │ +00105 // incrementation │ │ │ │ │ │ +00106 //-----------------------------------------------00107 CSph3vector& CSph3vector::operator += (const CSph3vector &v){ │ │ │ │ │ │ +00108 │ │ │ │ │ │ +px+=v.px; │ │ │ │ │ │ +00109 │ │ │ │ │ │ +py+=v.py; │ │ │ │ │ │ +00110 │ │ │ │ │ │ +pz+=v.pz; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +00112 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00113 } │ │ │ │ │ │ +00114 │ │ │ │ │ │ +00115 // decrementation │ │ │ │ │ │ +00116 //-----------------------------------------------00117 CSph3vector& CSph3vector::operator -= (const CSph3vector &v){ │ │ │ │ │ │ +00118 │ │ │ │ │ │ +px-=v.px; │ │ │ │ │ │ +00119 │ │ │ │ │ │ +py-=v.py; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +249 │ │ │ │ │ │ + │ │ │ │ │ │ + 250 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00138 * - _radius: radius of the cones │ │ │ │ │ │ -00139 * The number of stable cones found is returned │ │ │ │ │ │ -00140 *********************************************************************/ │ │ │ │ │ │ -00141 int Cstable_cones::get_stable_cones(double _radius){ │ │ │ │ │ │ +00120 │ │ │ │ │ │ +pz-=v.pz; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +00122 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00123 } │ │ │ │ │ │ +00124 │ │ │ │ │ │ +00125 // multiplication by a constant │ │ │ │ │ │ +00126 //-----------------------------------------------00127 CSph3vector& CSph3vector::operator *= (const double &r){ │ │ │ │ │ │ +00128 │ │ │ │ │ │ +px*=r; │ │ │ │ │ │ +00129 │ │ │ │ │ │ +py*=r; │ │ │ │ │ │ +00130 │ │ │ │ │ │ +pz*=r; │ │ │ │ │ │ +00131 │ │ │ │ │ │ +00132 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00133 } │ │ │ │ │ │ +00134 │ │ │ │ │ │ +00135 // division by a constant │ │ │ │ │ │ +00136 //-----------------------------------------------00137 CSph3vector& CSph3vector::operator /= (const double &r){ │ │ │ │ │ │ +00138 │ │ │ │ │ │ +px/=r; │ │ │ │ │ │ +00139 │ │ │ │ │ │ +py/=r; │ │ │ │ │ │ +00140 │ │ │ │ │ │ +pz/=r; │ │ │ │ │ │ +00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ -int p_idx; │ │ │ │ │ │ +_norm/=r; │ │ │ │ │ │ 00143 │ │ │ │ │ │ 00144 │ │ │ │ │ │ -// check if everything is correctly initialised │ │ │ │ │ │ -00145 │ │ │ │ │ │ -if (n_part==0){ │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00145 } │ │ │ │ │ │ 00146 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00147 │ │ │ │ │ │ -} │ │ │ │ │ │ -00148 │ │ │ │ │ │ +00147 // build norm from 3-momentum info │ │ │ │ │ │ +00148 void CSph3vector::build_norm(){ │ │ │ │ │ │ 00149 │ │ │ │ │ │ -R = _radius; │ │ │ │ │ │ -00150 │ │ │ │ │ │ -R2 = R*R; │ │ │ │ │ │ +_norm = norm(); │ │ │ │ │ │ +00150 } │ │ │ │ │ │ 00151 │ │ │ │ │ │ -00152 │ │ │ │ │ │ -// allow hash for cones candidates │ │ │ │ │ │ -00153 │ │ │ │ │ │ -hc = new hash_cones(n_part, R2); │ │ │ │ │ │ +00152 // build norm from 3-momentum info │ │ │ │ │ │ +00153 void CSph3vector::build_thetaphi(){ │ │ │ │ │ │ 00154 │ │ │ │ │ │ +_theta = theta(); │ │ │ │ │ │ 00155 │ │ │ │ │ │ -// browse all particles │ │ │ │ │ │ -00156 │ │ │ │ │ │ -for (p_idx=0;p_idxv; │ │ │ │ │ │ -00216 │ │ │ │ │ │ -centre_idx = first_cone; │ │ │ │ │ │ -00217 │ │ │ │ │ │ -00218 │ │ │ │ │ │ -// build the initial cone (nodist: avoids calculating distances -00219 │ │ │ │ │ │ -// just deduces contents by circulating around all in/out operations) │ │ │ │ │ │ -00220 │ │ │ │ │ │ -// this function also sets the list of included particles │ │ │ │ │ │ +00216 // default dtor │ │ │ │ │ │ +00217 //-------------00218 CSphmomentum::~CSphmomentum(){ │ │ │ │ │ │ +00219 │ │ │ │ │ │ +00220 } │ │ │ │ │ │ 00221 │ │ │ │ │ │ -compute_cone_contents(); │ │ │ │ │ │ -00222 │ │ │ │ │ │ -00223 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00224 } │ │ │ │ │ │ +00222 // assignment of vectors │ │ │ │ │ │ +00223 //----------------------00224 CSphmomentum& CSphmomentum::operator = (const CSphmomentum &v){ │ │ │ │ │ │ 00225 │ │ │ │ │ │ +px = v.px; │ │ │ │ │ │ 00226 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.39 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00227 /* │ │ │ │ │ │ -00228 * test cones. │ │ │ │ │ │ -00229 * We check if the cone(s) built with the present parent and child │ │ │ │ │ │ -00230 * are stable │ │ │ │ │ │ -00231 * return 0 on success 1 on error │ │ │ │ │ │ -00232 *********************************************************************/ │ │ │ │ │ │ -00233 int Cstable_cones::test_cone(){ │ │ │ │ │ │ +py = v.py; │ │ │ │ │ │ +00227 │ │ │ │ │ │ +pz = v.pz; │ │ │ │ │ │ +00228 │ │ │ │ │ │ +E = v.E; │ │ │ │ │ │ +00229 │ │ │ │ │ │ +00230 │ │ │ │ │ │ +_norm = v._norm; │ │ │ │ │ │ +00231 │ │ │ │ │ │ +_theta = v._theta; │ │ │ │ │ │ +00232 │ │ │ │ │ │ +_phi │ │ │ │ │ │ += v._phi; │ │ │ │ │ │ +00233 │ │ │ │ │ │ 00234 │ │ │ │ │ │ -Creference weighted_cone_ref; │ │ │ │ │ │ +ref = v.ref; │ │ │ │ │ │ 00235 │ │ │ │ │ │ -00236 │ │ │ │ │ │ -// depending on the side we are taking the child particle, │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00236 } │ │ │ │ │ │ 00237 │ │ │ │ │ │ -// we test different configuration. │ │ │ │ │ │ -00238 │ │ │ │ │ │ -// Each time, two configurations are tested in such a way that │ │ │ │ │ │ -00239 │ │ │ │ │ │ -// all 4 possible cases (parent or child in or out the cone) │ │ │ │ │ │ -00240 │ │ │ │ │ │ -// are tested when taking the pair of particle parent+child │ │ │ │ │ │ -00241 │ │ │ │ │ │ -// and child+parent. │ │ │ │ │ │ +00238 // addition of vectors │ │ │ │ │ │ +00239 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00240 //-----------------------------------------------00241 const CSphmomentum CSphmomentum::operator + (const CSphmomentum &v){ │ │ │ │ │ │ 00242 │ │ │ │ │ │ +CSphmomentum tmp = *this; │ │ │ │ │ │ 00243 │ │ │ │ │ │ -// here are the tests entering the first series: │ │ │ │ │ │ -00244 │ │ │ │ │ │ -// 1. check if the cone is already inserted │ │ │ │ │ │ +return tmp+=v; │ │ │ │ │ │ +00244 } │ │ │ │ │ │ 00245 │ │ │ │ │ │ -// 2. check cone stability for the parent and child particles │ │ │ │ │ │ -00246 │ │ │ │ │ │ -00247 │ │ │ │ │ │ -if (centre->side){ │ │ │ │ │ │ -00248 │ │ │ │ │ │ -// test when both particles are not in the cone │ │ │ │ │ │ -00249 │ │ │ │ │ │ -// or when both are in. │ │ │ │ │ │ +00246 // incrementation of vectors │ │ │ │ │ │ +00247 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00248 //-----------------------------------------------00249 CSphmomentum& CSphmomentum::operator += (const CSphmomentum &v){ │ │ │ │ │ │ 00250 │ │ │ │ │ │ -// Note: for the totally exclusive case, test emptyness before │ │ │ │ │ │ +px+=v.px; │ │ │ │ │ │ 00251 │ │ │ │ │ │ -cone_candidate = cone; │ │ │ │ │ │ +py+=v.py; │ │ │ │ │ │ 00252 │ │ │ │ │ │ -if (cone.ref.not_empty()){ │ │ │ │ │ │ +pz+=v.pz; │ │ │ │ │ │ 00253 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ +E +=v.E; │ │ │ │ │ │ 00254 │ │ │ │ │ │ -} │ │ │ │ │ │ 00255 │ │ │ │ │ │ +ref+=v.ref; │ │ │ │ │ │ 00256 │ │ │ │ │ │ -cone_candidate = cone; │ │ │ │ │ │ 00257 │ │ │ │ │ │ -cone_candidate+= *parent + *child; │ │ │ │ │ │ -00258 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00258 } │ │ │ │ │ │ 00259 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00260 │ │ │ │ │ │ -// test when 1! of the particles is in the cone │ │ │ │ │ │ -00261 │ │ │ │ │ │ -cone_candidate = cone + *parent; │ │ │ │ │ │ -00262 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, true, false); │ │ │ │ │ │ -00263 │ │ │ │ │ │ +00260 // decrementation of vectors │ │ │ │ │ │ +00261 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00262 //-----------------------------------------------00263 CSphmomentum& CSphmomentum::operator -= (const CSphmomentum &v){ │ │ │ │ │ │ 00264 │ │ │ │ │ │ -cone_candidate = cone + *child; │ │ │ │ │ │ +px-=v.px; │ │ │ │ │ │ 00265 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ +py-=v.py; │ │ │ │ │ │ 00266 │ │ │ │ │ │ -} │ │ │ │ │ │ +pz-=v.pz; │ │ │ │ │ │ 00267 │ │ │ │ │ │ +E -=v.E; │ │ │ │ │ │ 00268 │ │ │ │ │ │ -nb_tot+=2; │ │ │ │ │ │ 00269 │ │ │ │ │ │ +ref-=v.ref; │ │ │ │ │ │ 00270 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ +return *this; │ │ │ │ │ │ 00271 } │ │ │ │ │ │ 00272 │ │ │ │ │ │ 00273 │ │ │ │ │ │ -00274 /* │ │ │ │ │ │ -00275 * update the cone │ │ │ │ │ │ -00276 * go to the next child for that parent and update ’cone’ appropriately │ │ │ │ │ │ -00277 * return 0 if update candidate found, 1 otherwise │ │ │ │ │ │ -00278 ***********************************************************************/ │ │ │ │ │ │ -00279 int Cstable_cones::update_cone(){ │ │ │ │ │ │ +00274 // ordering of two vectors │ │ │ │ │ │ +00275 // the default ordering is w.r.t. their references │ │ │ │ │ │ +00276 //------------------------------------------------00277 bool operator < (const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ +00278 │ │ │ │ │ │ +return v1.ref < v2.ref; │ │ │ │ │ │ +00279 } │ │ │ │ │ │ 00280 │ │ │ │ │ │ -// get the next child and centre │ │ │ │ │ │ -00281 │ │ │ │ │ │ -centre_idx++; │ │ │ │ │ │ -00282 │ │ │ │ │ │ -if (centre_idx==vicinity_size) │ │ │ │ │ │ -00283 │ │ │ │ │ │ -centre_idx=0; │ │ │ │ │ │ +00281 // ordering of vectors in eta (e.g. used in collinear tests) │ │ │ │ │ │ +00282 //----------------------------------------------------------00283 bool momentum_theta_less(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ 00284 │ │ │ │ │ │ -if (centre_idx==first_cone) │ │ │ │ │ │ -00285 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ +return v1._theta < v2._theta; │ │ │ │ │ │ +00285 } │ │ │ │ │ │ 00286 │ │ │ │ │ │ -00287 │ │ │ │ │ │ -// update the cone w.r.t. the old child │ │ │ │ │ │ -00288 │ │ │ │ │ │ -// only required if the old child is entering inside in which │ │ │ │ │ │ -00289 │ │ │ │ │ │ -// case we need to add it. We also know that the child is │ │ │ │ │ │ +00287 // ordering of vectors in pt │ │ │ │ │ │ +00288 //--------------------------00289 bool momentum_pt_less(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ 00290 │ │ │ │ │ │ -// inside iff its side is -. │ │ │ │ │ │ -00291 │ │ │ │ │ │ -if (!centre->side){ │ │ │ │ │ │ +return v1.perp2() < v2.perp2(); │ │ │ │ │ │ +00291 } │ │ │ │ │ │ 00292 │ │ │ │ │ │ -// update cone │ │ │ │ │ │ -00293 │ │ │ │ │ │ -cone += (*child); │ │ │ │ │ │ -00294 │ │ │ │ │ │ -00295 │ │ │ │ │ │ -// update info on particles inside │ │ │ │ │ │ -00296 │ │ │ │ │ │ -centre->is_inside->cone = true; │ │ │ │ │ │ -00297 │ │ │ │ │ │ -00298 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ -00299 │ │ │ │ │ │ -dpt += fabs(child->px)+fabs(child->py); │ │ │ │ │ │ -00300 │ │ │ │ │ │ -} │ │ │ │ │ │ -00301 │ │ │ │ │ │ -00302 │ │ │ │ │ │ -// update centre and child to correspond to the new position │ │ │ │ │ │ -00303 │ │ │ │ │ │ -centre = vicinity[centre_idx]; │ │ │ │ │ │ -00304 │ │ │ │ │ │ -child = centre->v; │ │ │ │ │ │ -00305 │ │ │ │ │ │ -00306 │ │ │ │ │ │ -// check cocircularity │ │ │ │ │ │ -00307 │ │ │ │ │ │ -// note that if cocirculaity is detected (i.e. if we receive 1 │ │ │ │ │ │ -00308 │ │ │ │ │ │ -// in the next test), we need to recall ’update_cone’ directly │ │ │ │ │ │ -00309 │ │ │ │ │ │ -// since tests and remaining part of te update has been performed │ │ │ │ │ │ -00310 │ │ │ │ │ │ -//if (cocircular_check()) │ │ │ │ │ │ -00311 │ │ │ │ │ │ -if (cocircular_check()) │ │ │ │ │ │ -00312 │ │ │ │ │ │ -return update_cone(); │ │ │ │ │ │ -00313 │ │ │ │ │ │ +00293 } │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -241 │ │ │ │ │ │ +251 │ │ │ │ │ │ │ │ │ │ │ │ - 242 │ │ │ │ │ │ + 252 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00314 │ │ │ │ │ │ -00315 │ │ │ │ │ │ -// update the cone w.r.t. the new child │ │ │ │ │ │ -00316 │ │ │ │ │ │ -// only required if the new child was already inside in which │ │ │ │ │ │ -00317 │ │ │ │ │ │ -// case we need to remove it. We also know that the child is │ │ │ │ │ │ -00318 │ │ │ │ │ │ -// inside iff its side is +. │ │ │ │ │ │ -00319 │ │ │ │ │ │ -if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00320 │ │ │ │ │ │ -// update cone │ │ │ │ │ │ -00321 │ │ │ │ │ │ -cone -= (*child); │ │ │ │ │ │ -00322 │ │ │ │ │ │ -00323 │ │ │ │ │ │ -// update info on particles inside │ │ │ │ │ │ -00324 │ │ │ │ │ │ -centre->is_inside->cone = false; │ │ │ │ │ │ -00325 │ │ │ │ │ │ -00326 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ -00327 │ │ │ │ │ │ -dpt += fabs(child->px)+fabs(child->py); //child->perp2(); │ │ │ │ │ │ -00328 │ │ │ │ │ │ -} │ │ │ │ │ │ -00329 │ │ │ │ │ │ -00330 │ │ │ │ │ │ -// check that the addition and subtraction of vectors does │ │ │ │ │ │ -00331 │ │ │ │ │ │ -// not lead to too much rounding error │ │ │ │ │ │ -00332 │ │ │ │ │ │ -// for that, we compute the sum of pt modifications and of |pt| │ │ │ │ │ │ -00333 │ │ │ │ │ │ -// since last recomputation and once the ratio overpasses a threshold │ │ │ │ │ │ -00334 │ │ │ │ │ │ -// we recompute vicinity. │ │ │ │ │ │ -00335 │ │ │ │ │ │ -if ((dpt>PT_TSHOLD*(fabs(cone.px)+fabs(cone.py))) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00336 │ │ │ │ │ │ -recompute_cone_contents(); │ │ │ │ │ │ -00337 │ │ │ │ │ │ -} │ │ │ │ │ │ -00338 │ │ │ │ │ │ -if (cone.ref.is_empty()){ │ │ │ │ │ │ -00339 │ │ │ │ │ │ -cone = Cmomentum(); │ │ │ │ │ │ -00340 │ │ │ │ │ │ -dpt=0.0; │ │ │ │ │ │ -00341 │ │ │ │ │ │ -} │ │ │ │ │ │ -00342 │ │ │ │ │ │ -00343 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00344 } │ │ │ │ │ │ -00345 │ │ │ │ │ │ -00346 │ │ │ │ │ │ -00347 /* │ │ │ │ │ │ -00348 * compute stability of all enumerated candidates. │ │ │ │ │ │ -00349 * For all candidate cones which are stable w.r.t. their border particles, │ │ │ │ │ │ -00350 * pass the last test: stability with quadtree intersection │ │ │ │ │ │ -00351 ************************************************************************/ │ │ │ │ │ │ -00352 int Cstable_cones::proceed_with_stability(){ │ │ │ │ │ │ -00353 │ │ │ │ │ │ -int i; // ,n; │ │ │ │ │ │ -00354 │ │ │ │ │ │ -hash_element *elm; │ │ │ │ │ │ -00355 │ │ │ │ │ │ -00356 │ │ │ │ │ │ -//n=0; │ │ │ │ │ │ -00357 │ │ │ │ │ │ -for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ -00358 │ │ │ │ │ │ -// test ith cell of the hash array │ │ │ │ │ │ -00359 │ │ │ │ │ │ -elm = hc->hash_array[i]; │ │ │ │ │ │ -00360 │ │ │ │ │ │ -00361 │ │ │ │ │ │ -// browse elements therein │ │ │ │ │ │ -00362 │ │ │ │ │ │ -while (elm!=NULL){ │ │ │ │ │ │ -00363 │ │ │ │ │ │ -// test stability │ │ │ │ │ │ -00364 │ │ │ │ │ │ -if (elm->is_stable){ │ │ │ │ │ │ -00365 │ │ │ │ │ │ -// stability is not ensured by all pairs of "edges" already browsed │ │ │ │ │ │ -00366 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ -00367 │ │ │ │ │ │ -// => testing stability with quadtree intersection │ │ │ │ │ │ -00368 │ │ │ │ │ │ -if (quadtree->circle_intersect(elm->eta, elm->phi, R2)==elm->ref){ │ │ │ │ │ │ -00369 #else │ │ │ │ │ │ -00370 │ │ │ │ │ │ -// => testing stability with the particle-list intersection │ │ │ │ │ │ -00371 │ │ │ │ │ │ -if (circle_intersect(elm->eta, elm->phi)==elm->ref){ │ │ │ │ │ │ -00372 #endif │ │ │ │ │ │ -00373 │ │ │ │ │ │ -// add it to the list of protocones │ │ │ │ │ │ -00374 │ │ │ │ │ │ -// note that in its present form, we do not allocate the │ │ │ │ │ │ -00375 │ │ │ │ │ │ -// 4-vector components of the momentum. There’s no need to │ │ │ │ │ │ -00376 │ │ │ │ │ │ -// do it here as it will be recomputed in │ │ │ │ │ │ -00377 │ │ │ │ │ │ -// │ │ │ │ │ │ -Csplit_merge::add_protocones │ │ │ │ │ │ -00378 │ │ │ │ │ │ -protocones.push_back(Cmomentum(elm->eta, elm->phi, elm->ref)); │ │ │ │ │ │ -00379 │ │ │ │ │ │ -} │ │ │ │ │ │ -00380 │ │ │ │ │ │ -} │ │ │ │ │ │ -00381 │ │ │ │ │ │ -00382 │ │ │ │ │ │ -// jump to the next one │ │ │ │ │ │ -00383 │ │ │ │ │ │ -elm = elm->next; │ │ │ │ │ │ -00384 │ │ │ │ │ │ -} │ │ │ │ │ │ -00385 │ │ │ │ │ │ -} │ │ │ │ │ │ -00386 │ │ │ │ │ │ -00387 │ │ │ │ │ │ -// free hash │ │ │ │ │ │ -00388 │ │ │ │ │ │ -// we do that at this level because hash eats rather a lot of memory │ │ │ │ │ │ -00389 │ │ │ │ │ │ -// we want to free it before running the split/merge algorithm │ │ │ │ │ │ -00390 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00391 │ │ │ │ │ │ -nb_hash_cones = hc->n_cones; │ │ │ │ │ │ -00392 │ │ │ │ │ │ -nb_hash_occupied = hc->n_occupied_cells; │ │ │ │ │ │ -00393 #endif │ │ │ │ │ │ -00394 │ │ │ │ │ │ -00395 │ │ │ │ │ │ -delete hc; │ │ │ │ │ │ -00396 │ │ │ │ │ │ -hc=NULL; │ │ │ │ │ │ -00397 │ │ │ │ │ │ -00398 │ │ │ │ │ │ -return protocones.size(); │ │ │ │ │ │ -00399 } │ │ │ │ │ │ -00400 │ │ │ │ │ │ +00294 │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ +5.37 │ │ │ │ │ │ │ │ │ │ │ │ - 5.39 protocones.cpp │ │ │ │ │ │ +momentum.h │ │ │ │ │ │ │ │ │ │ │ │ -00401 │ │ │ │ │ │ -00403 // ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: momentum.h │ │ │ │ │ │ // │ │ │ │ │ │ -00404 // - cocircular_pt_less(v1, v2) │ │ │ │ │ │ +00004 // Description: header file for 4-momentum class Cmomentum │ │ │ │ │ │ // │ │ │ │ │ │ -00405 // - prepare_cocircular_list() │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ -00406 // - test_cone_cocircular() │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ -00407 // - test_stability(candidate, border_vect) │ │ │ │ │ │ +00007 // │ │ │ │ │ │ // │ │ │ │ │ │ -00408 // - updat_cone_cocircular() │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ -00410 │ │ │ │ │ │ -00412 bool cocircular_pt_less(Cmomentum *v1, Cmomentum *v2){ │ │ │ │ │ │ -00413 │ │ │ │ │ │ -return v1->perp2() < v2->perp2(); │ │ │ │ │ │ -00414 } │ │ │ │ │ │ -00415 │ │ │ │ │ │ -00416 /* │ │ │ │ │ │ -00417 * run through the vicinity of the current parent and for each child │ │ │ │ │ │ -00418 * establish which other members are cocircular... Note that the list │ │ │ │ │ │ -00419 * associated with each child contains references to vicinity │ │ │ │ │ │ -00420 * elements: thus two vicinity elements each associated with one given │ │ │ │ │ │ -00421 * particle may appear in a list -- this needs to be watched out for │ │ │ │ │ │ -00422 * later on... │ │ │ │ │ │ -00423 **********************************************************************/ │ │ │ │ │ │ -00424 void Cstable_cones::prepare_cocircular_lists() { │ │ │ │ │ │ -00425 │ │ │ │ │ │ -circulator::iterator > here(vicinity.begin(), │ │ │ │ │ │ -00426 │ │ │ │ │ │ -vicinity.begin(), │ │ │ │ │ │ -00427 │ │ │ │ │ │ -vicinity.end()); │ │ │ │ │ │ -00428 │ │ │ │ │ │ -00429 │ │ │ │ │ │ -circulator::iterator > search(here); │ │ │ │ │ │ -00430 │ │ │ │ │ │ -00431 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00432 │ │ │ │ │ │ -Cvicinity_elm* here_pntr = *here(); │ │ │ │ │ │ -00433 │ │ │ │ │ │ -search.set_position(here); │ │ │ │ │ │ -00434 │ │ │ │ │ │ -00435 │ │ │ │ │ │ -// search forwards for things that should have "here" included in │ │ │ │ │ │ -00436 │ │ │ │ │ │ -// their cocircularity list │ │ │ │ │ │ -00437 │ │ │ │ │ │ -while (true) { │ │ │ │ │ │ -00438 │ │ │ │ │ │ -++search; │ │ │ │ │ │ -00439 │ │ │ │ │ │ -if ( abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ -00440 │ │ │ │ │ │ -here_pntr->cocircular_range │ │ │ │ │ │ -00441 │ │ │ │ │ │ -&& search() != here()) { │ │ │ │ │ │ -00442 │ │ │ │ │ │ -(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ -00443 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00444 │ │ │ │ │ │ -break; │ │ │ │ │ │ -00445 │ │ │ │ │ │ -} │ │ │ │ │ │ -00446 │ │ │ │ │ │ -} │ │ │ │ │ │ -00447 │ │ │ │ │ │ -00448 │ │ │ │ │ │ -// search backwards │ │ │ │ │ │ -00449 │ │ │ │ │ │ -search.set_position(here); │ │ │ │ │ │ -00450 │ │ │ │ │ │ -while (true) { │ │ │ │ │ │ -00451 │ │ │ │ │ │ ---search; │ │ │ │ │ │ -00452 │ │ │ │ │ │ -if ( abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ -00453 │ │ │ │ │ │ -here_pntr->cocircular_range │ │ │ │ │ │ -00454 │ │ │ │ │ │ -&& search() != here()) { │ │ │ │ │ │ -00455 │ │ │ │ │ │ -(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ -00456 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00457 │ │ │ │ │ │ -break; │ │ │ │ │ │ -00458 │ │ │ │ │ │ -} │ │ │ │ │ │ -00459 │ │ │ │ │ │ -} │ │ │ │ │ │ -00460 │ │ │ │ │ │ -00461 │ │ │ │ │ │ -++here; │ │ │ │ │ │ -00462 │ │ │ │ │ │ -} while (here() != vicinity.begin()); │ │ │ │ │ │ -00463 │ │ │ │ │ │ -00464 } │ │ │ │ │ │ -00465 │ │ │ │ │ │ -00466 /* │ │ │ │ │ │ -00467 * Testing cocircular configurations in p^3 time, │ │ │ │ │ │ -00468 * rather than 2^p time; we will test all contiguous subsets of points │ │ │ │ │ │ -00469 * on the border --- note that this is till probably overkill, since │ │ │ │ │ │ -00470 * in principle we only have to test situations where up to a │ │ │ │ │ │ -00471 * half-circle is filled (but going to a full circle is simpler) │ │ │ │ │ │ -00472 ******************************************************************/ │ │ │ │ │ │ -00473 void Cstable_cones::test_cone_cocircular(Cmomentum & borderless_cone, │ │ │ │ │ │ -00474 │ │ │ │ │ │ -list & border_list) { │ │ │ │ │ │ -00475 │ │ │ │ │ │ -vector border_vect; │ │ │ │ │ │ -00476 │ │ │ │ │ │ -00477 │ │ │ │ │ │ -border_vect.reserve(border_list.size()); │ │ │ │ │ │ -00478 │ │ │ │ │ │ -for (list::iterator it = border_list.begin(); │ │ │ │ │ │ -00479 │ │ │ │ │ │ -it != border_list.end(); it++) { │ │ │ │ │ │ -00480 │ │ │ │ │ │ -border_vect.push_back(Cborder_store(*it, centre->eta, centre->phi)); │ │ │ │ │ │ -00481 │ │ │ │ │ │ -} │ │ │ │ │ │ -00482 │ │ │ │ │ │ -00483 │ │ │ │ │ │ -// get them into order of angle │ │ │ │ │ │ -00484 │ │ │ │ │ │ -sort(border_vect.begin(), border_vect.end()); │ │ │ │ │ │ -00485 │ │ │ │ │ │ -00486 │ │ │ │ │ │ -// set up some circulators, since these will help us go around the │ │ │ │ │ │ -00487 │ │ │ │ │ │ -// circle easily │ │ │ │ │ │ -00488 │ │ │ │ │ │ -circulator::iterator > │ │ │ │ │ │ -00489 │ │ │ │ │ │ -start(border_vect.begin(), border_vect.begin(),border_vect.end()); │ │ │ │ │ │ -00490 │ │ │ │ │ │ -circulator::iterator > mid(start), end(start); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -243 │ │ │ │ │ │ - │ │ │ │ │ │ - 244 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00491 │ │ │ │ │ │ -00492 │ │ │ │ │ │ -// test the borderless cone │ │ │ │ │ │ -00493 │ │ │ │ │ │ -Cmomentum candidate = borderless_cone; │ │ │ │ │ │ -00494 │ │ │ │ │ │ -candidate.build_etaphi(); │ │ │ │ │ │ -00495 │ │ │ │ │ │ -if (candidate.ref.not_empty()) │ │ │ │ │ │ -00496 │ │ │ │ │ │ -test_stability(candidate, border_vect); │ │ │ │ │ │ -00497 │ │ │ │ │ │ -00498 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00499 │ │ │ │ │ │ -// reset status wrt inclusion in the cone │ │ │ │ │ │ -00500 │ │ │ │ │ │ -mid = start; │ │ │ │ │ │ -00501 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00502 │ │ │ │ │ │ -mid()->is_in = false; │ │ │ │ │ │ -00503 │ │ │ │ │ │ -} while (++mid != start); │ │ │ │ │ │ -00504 │ │ │ │ │ │ -00505 │ │ │ │ │ │ -// now run over all inclusion possibilities with this starting point │ │ │ │ │ │ -00506 │ │ │ │ │ │ -candidate = borderless_cone; │ │ │ │ │ │ -00507 │ │ │ │ │ │ -while (++mid != start) { │ │ │ │ │ │ -00508 │ │ │ │ │ │ -// will begin with start+1 and go up to start-1 │ │ │ │ │ │ -00509 │ │ │ │ │ │ -mid()->is_in = true; │ │ │ │ │ │ -00510 │ │ │ │ │ │ -candidate += *(mid()->mom); │ │ │ │ │ │ -00511 │ │ │ │ │ │ -test_stability(candidate, border_vect); │ │ │ │ │ │ -00512 │ │ │ │ │ │ -} │ │ │ │ │ │ -00513 │ │ │ │ │ │ -00514 │ │ │ │ │ │ -} while (++start != end); │ │ │ │ │ │ -00515 │ │ │ │ │ │ -00516 │ │ │ │ │ │ -// mid corresponds to momentum that we need to include to get the │ │ │ │ │ │ -00517 │ │ │ │ │ │ -// full cone │ │ │ │ │ │ -00518 │ │ │ │ │ │ -mid()->is_in = true; │ │ │ │ │ │ -00519 │ │ │ │ │ │ -candidate += *(mid()->mom); │ │ │ │ │ │ -00520 │ │ │ │ │ │ -test_stability(candidate, border_vect); │ │ │ │ │ │ -00521 } │ │ │ │ │ │ -00522 │ │ │ │ │ │ -00523 │ │ │ │ │ │ -00530 void Cstable_cones::test_stability(Cmomentum & candidate, const vector & border_vect) { │ │ │ │ │ │ -00531 │ │ │ │ │ │ -00532 │ │ │ │ │ │ -// this almost certainly has not been done... │ │ │ │ │ │ -00533 │ │ │ │ │ │ -candidate.build_etaphi(); │ │ │ │ │ │ -00534 │ │ │ │ │ │ -00535 │ │ │ │ │ │ -bool stable = true; │ │ │ │ │ │ -00536 │ │ │ │ │ │ -for (unsigned i = 0; i < border_vect.size(); i++) { │ │ │ │ │ │ -00537 │ │ │ │ │ │ -if (is_inside(&candidate, border_vect[i].mom) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ -00538 │ │ │ │ │ │ -stable = false; │ │ │ │ │ │ -00539 │ │ │ │ │ │ -break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ -00540 │ │ │ │ │ │ -} │ │ │ │ │ │ -00541 │ │ │ │ │ │ -} │ │ │ │ │ │ -00542 │ │ │ │ │ │ -00543 │ │ │ │ │ │ -if (stable) hc->insert(&candidate); │ │ │ │ │ │ -00544 } │ │ │ │ │ │ -00545 │ │ │ │ │ │ -00546 /* │ │ │ │ │ │ -00547 * check if we are in a situation of cocircularity. │ │ │ │ │ │ -00548 * if it is the case, update and test in the corresponding way │ │ │ │ │ │ -00549 * return ’false’ if no cocircularity detected, ’true’ otherwise │ │ │ │ │ │ -00550 * Note that if cocircularity is detected, we need to │ │ │ │ │ │ -00551 * recall ’update’ from ’update’ !!! │ │ │ │ │ │ -00552 ***************************************************************/ │ │ │ │ │ │ -00553 bool Cstable_cones::cocircular_check(){ │ │ │ │ │ │ -00554 │ │ │ │ │ │ -// check if many configurations have the same centre. │ │ │ │ │ │ -00555 │ │ │ │ │ │ -// if this is the case, branch on the algorithm for this │ │ │ │ │ │ -00556 │ │ │ │ │ │ -// special case. │ │ │ │ │ │ -00557 │ │ │ │ │ │ -// Note that those situation, being considered separately in │ │ │ │ │ │ -00558 │ │ │ │ │ │ -// test_cone_multiple, must only be considered here if all │ │ │ │ │ │ -00559 │ │ │ │ │ │ -// angles are on the same side (this avoid multiple counting) │ │ │ │ │ │ -00560 │ │ │ │ │ │ -00561 │ │ │ │ │ │ -if (centre->cocircular.empty()) return false; │ │ │ │ │ │ -00562 │ │ │ │ │ │ -00563 │ │ │ │ │ │ -// first get cone into status required at end... │ │ │ │ │ │ -00564 │ │ │ │ │ │ -if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00565 │ │ │ │ │ │ -// update cone │ │ │ │ │ │ -00566 │ │ │ │ │ │ -cone -= (*child); │ │ │ │ │ │ -00567 │ │ │ │ │ │ -00568 │ │ │ │ │ │ -// update info on particles inside │ │ │ │ │ │ -00569 │ │ │ │ │ │ -centre->is_inside->cone = false; │ │ │ │ │ │ -00570 │ │ │ │ │ │ -00571 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ -00572 │ │ │ │ │ │ -dpt += fabs(child->px)+fabs(child->py); //child->perp2(); │ │ │ │ │ │ -00573 │ │ │ │ │ │ -} │ │ │ │ │ │ -00574 │ │ │ │ │ │ -00575 │ │ │ │ │ │ -00576 │ │ │ │ │ │ -// now establish the list of unique children in the list │ │ │ │ │ │ -00577 │ │ │ │ │ │ -// first make sure parent and child are in! │ │ │ │ │ │ -00578 │ │ │ │ │ │ -00579 │ │ │ │ │ │ -list removed_from_cone; │ │ │ │ │ │ -00580 │ │ │ │ │ │ -list put_in_border; │ │ │ │ │ │ -00581 │ │ │ │ │ │ -list border_list; │ │ │ │ │ │ -00582 │ │ │ │ │ │ -00583 │ │ │ │ │ │ -Cmomentum cone_removal; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.39 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00584 │ │ │ │ │ │ -Cmomentum border = *parent; │ │ │ │ │ │ -00585 │ │ │ │ │ │ -border_list.push_back(parent); │ │ │ │ │ │ -00586 │ │ │ │ │ │ -00587 │ │ │ │ │ │ -// make sure child appears in the border region │ │ │ │ │ │ -00588 │ │ │ │ │ │ -centre->cocircular.push_back(centre); │ │ │ │ │ │ -00589 │ │ │ │ │ │ -00590 │ │ │ │ │ │ -// now establish the full contents of the cone minus the cocircular │ │ │ │ │ │ -00591 │ │ │ │ │ │ -// region and of the cocircular region itself │ │ │ │ │ │ -00592 │ │ │ │ │ │ -for(list::iterator it = centre->cocircular.begin(); │ │ │ │ │ │ -00593 │ │ │ │ │ │ -it != centre->cocircular.end(); it++) { │ │ │ │ │ │ -00594 │ │ │ │ │ │ -00595 │ │ │ │ │ │ -if ((*it)->is_inside->cone) { │ │ │ │ │ │ -00596 │ │ │ │ │ │ -cone_removal │ │ │ │ │ │ -+= *((*it)->v); │ │ │ │ │ │ -00597 │ │ │ │ │ │ -(*it)->is_inside->cone = false; │ │ │ │ │ │ -00598 │ │ │ │ │ │ -removed_from_cone.push_back((*it)->is_inside); │ │ │ │ │ │ -00599 │ │ │ │ │ │ -} │ │ │ │ │ │ -00600 │ │ │ │ │ │ -00601 │ │ │ │ │ │ -// if a point appears twice (i.e. with + and - sign) in the list of │ │ │ │ │ │ -00602 │ │ │ │ │ │ -// points on the border, we take care not to include it twice. │ │ │ │ │ │ -00603 │ │ │ │ │ │ -// Note that this situation may appear when a point is at a distance │ │ │ │ │ │ -00604 │ │ │ │ │ │ -// close to 2R from the parent │ │ │ │ │ │ -00605 │ │ │ │ │ │ -if (!(*it)->is_inside->cocirc) { │ │ │ │ │ │ -00606 │ │ │ │ │ │ -border += *((*it)->v); │ │ │ │ │ │ -00607 │ │ │ │ │ │ -(*it)->is_inside->cocirc = true; │ │ │ │ │ │ -00608 │ │ │ │ │ │ -put_in_border.push_back((*it)->is_inside); │ │ │ │ │ │ -00609 │ │ │ │ │ │ -border_list.push_back((*it)->v); │ │ │ │ │ │ -00610 │ │ │ │ │ │ -} │ │ │ │ │ │ -00611 │ │ │ │ │ │ -} │ │ │ │ │ │ -00612 │ │ │ │ │ │ -00613 │ │ │ │ │ │ -00614 │ │ │ │ │ │ -// figure out whether this pairing has been observed before │ │ │ │ │ │ -00615 │ │ │ │ │ │ -Cmomentum borderless_cone = cone; │ │ │ │ │ │ -00616 │ │ │ │ │ │ -borderless_cone -= cone_removal; │ │ │ │ │ │ -00617 │ │ │ │ │ │ -bool consider = true; │ │ │ │ │ │ -00618 │ │ │ │ │ │ -for (unsigned int i=0;i(borderless_cone.ref, │ │ │ │ │ │ -00628 │ │ │ │ │ │ -border.ref)); │ │ │ │ │ │ -00629 │ │ │ │ │ │ -00630 │ │ │ │ │ │ -// first figure out whether our cone momentum is good │ │ │ │ │ │ -00631 │ │ │ │ │ │ -double local_dpt = fabs(cone_removal.px) + fabs(cone_removal.py); │ │ │ │ │ │ -00632 │ │ │ │ │ │ -double total_dpt = dpt + local_dpt; │ │ │ │ │ │ -00633 │ │ │ │ │ │ -00634 │ │ │ │ │ │ -recompute_cone_contents_if_needed(borderless_cone, total_dpt); │ │ │ │ │ │ -00635 │ │ │ │ │ │ -if (total_dpt == 0) { │ │ │ │ │ │ -00636 │ │ │ │ │ │ -// a recomputation has taken place -- so take advantage of this │ │ │ │ │ │ -00637 │ │ │ │ │ │ -// and update the member cone momentum │ │ │ │ │ │ -00638 │ │ │ │ │ │ -cone = borderless_cone + cone_removal; │ │ │ │ │ │ -00639 │ │ │ │ │ │ -dpt = local_dpt; │ │ │ │ │ │ -00640 │ │ │ │ │ │ -} │ │ │ │ │ │ -00641 │ │ │ │ │ │ -00642 │ │ │ │ │ │ -test_cone_cocircular(borderless_cone, border_list); │ │ │ │ │ │ -00643 │ │ │ │ │ │ -} │ │ │ │ │ │ -00644 │ │ │ │ │ │ -00645 │ │ │ │ │ │ -00646 │ │ │ │ │ │ -// relabel things that were in the cone but got removed │ │ │ │ │ │ -00647 │ │ │ │ │ │ -for(list::iterator is_in = removed_from_cone.begin(); │ │ │ │ │ │ -00648 │ │ │ │ │ │ -is_in != removed_from_cone.end(); is_in++) { │ │ │ │ │ │ -00649 │ │ │ │ │ │ -(*is_in)->cone = true; │ │ │ │ │ │ -00650 │ │ │ │ │ │ -} │ │ │ │ │ │ -00651 │ │ │ │ │ │ -00652 │ │ │ │ │ │ -// relabel things that got put into the border │ │ │ │ │ │ -00653 │ │ │ │ │ │ -for(list::iterator is_in = put_in_border.begin(); │ │ │ │ │ │ -00654 │ │ │ │ │ │ -is_in != put_in_border.end(); is_in++) { │ │ │ │ │ │ -00655 │ │ │ │ │ │ -(*is_in)->cocirc = false; │ │ │ │ │ │ -00656 │ │ │ │ │ │ -} │ │ │ │ │ │ -00657 │ │ │ │ │ │ -00658 │ │ │ │ │ │ -// we’re done with everything -- return true to signal to user that we’ve │ │ │ │ │ │ -00659 │ │ │ │ │ │ -// been through the co-circularity rigmarole │ │ │ │ │ │ -00660 │ │ │ │ │ │ -return true; │ │ │ │ │ │ -00661 } │ │ │ │ │ │ -00662 │ │ │ │ │ │ -00663 │ │ │ │ │ │ -00665 // RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ +00009 // │ │ │ │ │ │ // │ │ │ │ │ │ -00666 // - compute_cone_contents() │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ -00667 // - recompute_cone_contents() │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ -00668 // - recompute_cone_contents_if_needed() │ │ │ │ │ │ +00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ -00670 │ │ │ │ │ │ -00679 void Cstable_cones::compute_cone_contents() { │ │ │ │ │ │ -00680 │ │ │ │ │ │ -circulator::iterator > │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -245 │ │ │ │ │ │ - │ │ │ │ │ │ - 246 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00681 │ │ │ │ │ │ -start(vicinity.begin()+first_cone, vicinity.begin(), vicinity.end()); │ │ │ │ │ │ -00682 │ │ │ │ │ │ -00683 │ │ │ │ │ │ -circulator::iterator > here(start); │ │ │ │ │ │ -00684 │ │ │ │ │ │ -00685 │ │ │ │ │ │ -// note that in the following algorithm, the cone contents never includes │ │ │ │ │ │ -00686 │ │ │ │ │ │ -// the child. Indeed, if it has positive sign, then it will be set as │ │ │ │ │ │ -00687 │ │ │ │ │ │ -// outside at the last step in the loop. If it has negative sign, then the │ │ │ │ │ │ -00688 │ │ │ │ │ │ -// loop will at some point go to the corresponding situation with positive │ │ │ │ │ │ -00689 │ │ │ │ │ │ -// sign and set the inclusion status to 0. │ │ │ │ │ │ -00690 │ │ │ │ │ │ -00691 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00692 │ │ │ │ │ │ -// as we leave this position a particle enters if its side is │ │ │ │ │ │ -00693 │ │ │ │ │ │ -// negative (i.e. the centre is the one at -ve angle wrt to the │ │ │ │ │ │ -00694 │ │ │ │ │ │ -// parent-child line │ │ │ │ │ │ -00695 │ │ │ │ │ │ -if (!(*here())->side) ((*here())->is_inside->cone) = 1; │ │ │ │ │ │ -00696 │ │ │ │ │ │ -00697 │ │ │ │ │ │ -// move on to the next position │ │ │ │ │ │ -00698 │ │ │ │ │ │ -++here; │ │ │ │ │ │ -00699 │ │ │ │ │ │ -00700 │ │ │ │ │ │ -// as we arrive at this position a particle leaves if its side is positive │ │ │ │ │ │ -00701 │ │ │ │ │ │ -if ((*here())->side) ((*here())->is_inside->cone) = 0; │ │ │ │ │ │ -00702 │ │ │ │ │ │ -} while (here != start); │ │ │ │ │ │ -00703 │ │ │ │ │ │ -00704 │ │ │ │ │ │ -// once we’ve reached the start the ’is_inside’ information should be │ │ │ │ │ │ -00705 │ │ │ │ │ │ -// 100% complete, so we can use it to calculate the cone contents │ │ │ │ │ │ -00706 │ │ │ │ │ │ -// and then exit │ │ │ │ │ │ -00707 │ │ │ │ │ │ -recompute_cone_contents(); │ │ │ │ │ │ -00708 │ │ │ │ │ │ -return; │ │ │ │ │ │ -00709 │ │ │ │ │ │ -00710 } │ │ │ │ │ │ -00711 │ │ │ │ │ │ -00712 │ │ │ │ │ │ -00713 /* │ │ │ │ │ │ -00714 * compute the cone momentum from particle list. │ │ │ │ │ │ -00715 * in this version, we use the ’pincluded’ information │ │ │ │ │ │ -00716 * from the Cvicinity class │ │ │ │ │ │ -00717 */ │ │ │ │ │ │ -00718 void Cstable_cones::recompute_cone_contents(){ │ │ │ │ │ │ -00719 │ │ │ │ │ │ -unsigned int i; │ │ │ │ │ │ -00720 │ │ │ │ │ │ -00721 │ │ │ │ │ │ -// set momentum to 0 │ │ │ │ │ │ -00722 │ │ │ │ │ │ -cone = Cmomentum(); │ │ │ │ │ │ -00723 │ │ │ │ │ │ -00724 │ │ │ │ │ │ -// Important note: we can browse only the particles │ │ │ │ │ │ -00725 │ │ │ │ │ │ -// in vicinity since all particles in the cone are │ │ │ │ │ │ -00726 │ │ │ │ │ │ -// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ -00727 │ │ │ │ │ │ -// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ -00728 │ │ │ │ │ │ -// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ -00729 │ │ │ │ │ │ -for (i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ -00732 │ │ │ │ │ │ -cone += *vicinity[i]->v; │ │ │ │ │ │ -00733 │ │ │ │ │ │ -} │ │ │ │ │ │ -00734 │ │ │ │ │ │ -00735 │ │ │ │ │ │ -// set check variables back to 0 │ │ │ │ │ │ -00736 │ │ │ │ │ │ -dpt = 0.0; │ │ │ │ │ │ -00737 } │ │ │ │ │ │ -00738 │ │ │ │ │ │ -00739 │ │ │ │ │ │ -00740 /* │ │ │ │ │ │ -00741 * if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ -00742 * the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ -00743 * ’pincluded’ information from the Cvicinity class, but we don’t │ │ │ │ │ │ -00744 * change the member cone, only the locally supplied one │ │ │ │ │ │ -00745 */ │ │ │ │ │ │ -00746 void Cstable_cones::recompute_cone_contents_if_needed(Cmomentum & this_cone, │ │ │ │ │ │ -00747 │ │ │ │ │ │ -double & this_dpt){ │ │ │ │ │ │ -00748 │ │ │ │ │ │ -00749 │ │ │ │ │ │ -if (this_dpt > PT_TSHOLD*(fabs(this_cone.px)+fabs(this_cone.py))) { │ │ │ │ │ │ -00750 │ │ │ │ │ │ -if (cone.ref.is_empty()) { │ │ │ │ │ │ -00751 │ │ │ │ │ │ -this_cone = Cmomentum(); │ │ │ │ │ │ -00752 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00753 │ │ │ │ │ │ -// set momentum to 0 │ │ │ │ │ │ -00754 │ │ │ │ │ │ -this_cone = Cmomentum(); │ │ │ │ │ │ -00755 │ │ │ │ │ │ -00756 │ │ │ │ │ │ -// Important note: we can browse only the particles │ │ │ │ │ │ -00757 │ │ │ │ │ │ -// in vicinity since all particles in the this_cone are │ │ │ │ │ │ -00758 │ │ │ │ │ │ -// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ -00759 │ │ │ │ │ │ -// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ -00760 │ │ │ │ │ │ -// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ -00761 │ │ │ │ │ │ -for (unsigned int i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ -00764 │ │ │ │ │ │ -this_cone += *vicinity[i]->v; │ │ │ │ │ │ -00765 │ │ │ │ │ │ -} │ │ │ │ │ │ -00766 │ │ │ │ │ │ -00767 │ │ │ │ │ │ -} │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.40 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00768 │ │ │ │ │ │ -// set check variables back to 0 │ │ │ │ │ │ -00769 │ │ │ │ │ │ -this_dpt = 0.0; │ │ │ │ │ │ -00770 │ │ │ │ │ │ -} │ │ │ │ │ │ -00771 │ │ │ │ │ │ -00772 } │ │ │ │ │ │ -00773 │ │ │ │ │ │ -00774 │ │ │ │ │ │ -00776 // VARIOUS TOOLS │ │ │ │ │ │ +00013 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ -00777 // - circle_intersect() │ │ │ │ │ │ +00014 // │ │ │ │ │ │ // │ │ │ │ │ │ -00778 // - is_inside() │ │ │ │ │ │ +00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ -00779 // - abs_dangle() │ │ │ │ │ │ +00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ -00781 │ │ │ │ │ │ -00782 │ │ │ │ │ │ -00783 /* │ │ │ │ │ │ -00784 * circle intersection. │ │ │ │ │ │ -00785 * computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ -00786 * The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ -00787 * - cx │ │ │ │ │ │ -circle centre x coordinate │ │ │ │ │ │ -00788 * - cy │ │ │ │ │ │ -circle centre y coordinate │ │ │ │ │ │ -00789 * return the checkxor for the intersection │ │ │ │ │ │ -00790 ******************************************************************/ │ │ │ │ │ │ -00791 Creference Cstable_cones::circle_intersect(double cx, double cy){ │ │ │ │ │ │ -00792 │ │ │ │ │ │ -Creference intersection; │ │ │ │ │ │ -00793 │ │ │ │ │ │ -int i; │ │ │ │ │ │ -00794 │ │ │ │ │ │ -double dx, dy; │ │ │ │ │ │ -00795 │ │ │ │ │ │ -00796 │ │ │ │ │ │ -for (i=0;iM_PI) │ │ │ │ │ │ -00803 │ │ │ │ │ │ -dy -= twopi; │ │ │ │ │ │ -00804 │ │ │ │ │ │ -00805 │ │ │ │ │ │ -// really check if the distance is less than VR │ │ │ │ │ │ -00806 │ │ │ │ │ │ -if (dx*dx+dy*dyeta - v->eta; │ │ │ │ │ │ -00825 │ │ │ │ │ │ -dy = fabs(centre_in->phi - v->phi); │ │ │ │ │ │ -00826 │ │ │ │ │ │ -if (dy>M_PI) │ │ │ │ │ │ -00827 │ │ │ │ │ │ -dy -= twopi; │ │ │ │ │ │ -00828 │ │ │ │ │ │ -00829 │ │ │ │ │ │ -return dx*dx+dy*dyM_PI) │ │ │ │ │ │ -00844 │ │ │ │ │ │ -dphi = dphi-twopi; │ │ │ │ │ │ -00845 │ │ │ │ │ │ -00846 │ │ │ │ │ │ -return dphi; │ │ │ │ │ │ -00847 } │ │ │ │ │ │ -00848 │ │ │ │ │ │ -00849 } │ │ │ │ │ │ - │ │ │ │ │ │ -5.40 │ │ │ │ │ │ - │ │ │ │ │ │ -protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00001 │ │ │ │ │ │ +00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00023 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // $Revision:: 163 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00025 // $Date:: 2007-04-26 22:31:02 +0200 (Thu, 26 Apr 2007) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 │ │ │ │ │ │ +00028 #ifndef __VECTOR_H__ │ │ │ │ │ │ +00029 #define __VECTOR_H__ │ │ │ │ │ │ +00030 │ │ │ │ │ │ +00031 #include │ │ │ │ │ │ +00032 #include │ │ │ │ │ │ +00033 #include "reference.h" │ │ │ │ │ │ +00034 #include "geom_2d.h" │ │ │ │ │ │ +00035 #include "defines.h" │ │ │ │ │ │ +00036 │ │ │ │ │ │ +00037 namespace siscone{ │ │ │ │ │ │ +00038 │ │ │ │ │ │ +00049 class Cmomentum{ │ │ │ │ │ │ +00050 public: │ │ │ │ │ │ +00052 │ │ │ │ │ │ +Cmomentum(); │ │ │ │ │ │ +00053 │ │ │ │ │ │ +00055 │ │ │ │ │ │ +Cmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ +00056 │ │ │ │ │ │ +00058 │ │ │ │ │ │ +Cmomentum(double _eta, double _phi, Creference _ref); │ │ │ │ │ │ +00059 │ │ │ │ │ │ +00061 │ │ │ │ │ │ +~Cmomentum(); │ │ │ │ │ │ +00062 │ │ │ │ │ │ +00064 │ │ │ │ │ │ +inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ +00065 │ │ │ │ │ │ +00067 │ │ │ │ │ │ +inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ +00068 │ │ │ │ │ │ +00070 │ │ │ │ │ │ +inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ +00071 │ │ │ │ │ │ +00073 │ │ │ │ │ │ +inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ +00074 │ │ │ │ │ │ +00076 │ │ │ │ │ │ +inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ +00077 │ │ │ │ │ │ +00079 │ │ │ │ │ │ +inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ +00080 │ │ │ │ │ │ +00082 │ │ │ │ │ │ +inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ +00083 │ │ │ │ │ │ +00085 │ │ │ │ │ │ +inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ +00086 │ │ │ │ │ │ +00088 │ │ │ │ │ │ +Cmomentum& operator = (const Cmomentum &v); │ │ │ │ │ │ +00089 │ │ │ │ │ │ +00092 │ │ │ │ │ │ +const Cmomentum operator + (const Cmomentum &v); │ │ │ │ │ │ +00093 │ │ │ │ │ │ +00096 │ │ │ │ │ │ +Cmomentum& operator += (const Cmomentum &v); │ │ │ │ │ │ +00097 │ │ │ │ │ │ +00100 │ │ │ │ │ │ +Cmomentum& operator -= (const Cmomentum &v); │ │ │ │ │ │ +00101 │ │ │ │ │ │ +00107 │ │ │ │ │ │ +void build_etaphi(); │ │ │ │ │ │ +00108 │ │ │ │ │ │ +00109 │ │ │ │ │ │ +double px; │ │ │ │ │ │ +00110 │ │ │ │ │ │ +double py; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +double pz; │ │ │ │ │ │ +00112 │ │ │ │ │ │ +double E; │ │ │ │ │ │ +00113 │ │ │ │ │ │ +00114 │ │ │ │ │ │ +double eta; │ │ │ │ │ │ +00115 │ │ │ │ │ │ +double phi; │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -247 │ │ │ │ │ │ + 5.38 momentum.h │ │ │ │ │ │ │ │ │ │ │ │ - 248 │ │ │ │ │ │ +00116 │ │ │ │ │ │ +int parent_index; │ │ │ │ │ │ +00117 │ │ │ │ │ │ +int index; │ │ │ │ │ │ +00118 │ │ │ │ │ │ +00120 │ │ │ │ │ │ +// the following part is used for checksums // │ │ │ │ │ │ +00122 │ │ │ │ │ │ +Creference ref; │ │ │ │ │ │ +00123 }; │ │ │ │ │ │ +00124 │ │ │ │ │ │ +00127 bool operator < (const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00130 bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ +00131 │ │ │ │ │ │ +00133 bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ +00134 │ │ │ │ │ │ +00135 │ │ │ │ │ │ +00137 // some handy utilities // │ │ │ │ │ │ +00139 │ │ │ │ │ │ +00144 inline double get_distance(double eta, double phi, Cmomentum *v){ │ │ │ │ │ │ +00145 │ │ │ │ │ │ +double dx, dy; │ │ │ │ │ │ +00146 │ │ │ │ │ │ +00147 │ │ │ │ │ │ +dx = eta - v->eta; │ │ │ │ │ │ +00148 │ │ │ │ │ │ +dy = fabs(phi - v->phi); │ │ │ │ │ │ +00149 │ │ │ │ │ │ +if (dy>M_PI) │ │ │ │ │ │ +00150 │ │ │ │ │ │ +dy -= twopi; │ │ │ │ │ │ +00151 │ │ │ │ │ │ +00152 │ │ │ │ │ │ +return dx*dx+dy*dy; │ │ │ │ │ │ +00153 } │ │ │ │ │ │ +00154 │ │ │ │ │ │ +00155 } │ │ │ │ │ │ +00156 │ │ │ │ │ │ +00157 #endif │ │ │ │ │ │ │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ +5.38 │ │ │ │ │ │ │ │ │ │ │ │ -00002 // File: protocones.cpp │ │ │ │ │ │ +momentum.h │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: momentum.h │ │ │ │ │ │ // │ │ │ │ │ │ -00003 // Description: source file for stable cones determination (Cstable_cones) │ │ │ │ │ │ +00004 // Description: header file for 4-momentum class Cmomentum │ │ │ │ │ │ // │ │ │ │ │ │ -00004 // This file is part of the SISCone project. │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ -00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ // │ │ │ │ │ │ -00006 // │ │ │ │ │ │ +00007 // │ │ │ │ │ │ an adaptation to spherical coordinates │ │ │ │ │ │ // │ │ │ │ │ │ -00007 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ -00008 // │ │ │ │ │ │ +00009 // │ │ │ │ │ │ // │ │ │ │ │ │ -00009 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ // │ │ │ │ │ │ -00010 // │ │ │ │ │ │ +00011 // │ │ │ │ │ │ // │ │ │ │ │ │ -00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ -00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ -00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ -00014 // (at your option) any later version. │ │ │ │ │ │ +00015 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ -00015 // │ │ │ │ │ │ +00016 // │ │ │ │ │ │ // │ │ │ │ │ │ -00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ -00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ -00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ // │ │ │ │ │ │ -00019 // GNU General Public License for more details. │ │ │ │ │ │ +00020 // GNU General Public License for more details. │ │ │ │ │ │ // │ │ │ │ │ │ -00020 // │ │ │ │ │ │ +00021 // │ │ │ │ │ │ // │ │ │ │ │ │ -00021 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ -00022 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ -00023 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00024 // │ │ │ │ │ │ +00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00025 // │ │ │ │ │ │ // │ │ │ │ │ │ -00025 // $Revision:: 311 │ │ │ │ │ │ +00026 // $Revision:: 256 │ │ │ │ │ │ $// │ │ │ │ │ │ -00026 // $Date:: 2011-10-05 23:27:09 +0200 (Wed, 05 Oct 2011) │ │ │ │ │ │ +00027 // $Date:: 2008-07-14 13:52:16 +0200 (Mon, 14 Jul 2008) │ │ │ │ │ │ $// │ │ │ │ │ │ -00028 │ │ │ │ │ │ -00029 /******************************************************* │ │ │ │ │ │ -00030 * Introductory note: │ │ │ │ │ │ -* │ │ │ │ │ │ -00031 * Since this file has many member functions, we have * │ │ │ │ │ │ -00032 * structured them in categories: │ │ │ │ │ │ -* │ │ │ │ │ │ -00033 * INITIALISATION FUNCTIONS │ │ │ │ │ │ -* │ │ │ │ │ │ -00034 * - ctor() │ │ │ │ │ │ -* │ │ │ │ │ │ -00035 * - ctor(particle_list) │ │ │ │ │ │ -* │ │ │ │ │ │ -00036 * - dtor() │ │ │ │ │ │ -* │ │ │ │ │ │ -00037 * - init(particle_list) │ │ │ │ │ │ -* │ │ │ │ │ │ -00038 * ALGORITHM MAIN ENTRY │ │ │ │ │ │ -* │ │ │ │ │ │ -00039 * - get_stable_cone(radius) │ │ │ │ │ │ -* │ │ │ │ │ │ -00040 * ALGORITHM MAIN STEPS │ │ │ │ │ │ -* │ │ │ │ │ │ -00041 * - init_cone() │ │ │ │ │ │ -* │ │ │ │ │ │ -00042 * - test_cone() │ │ │ │ │ │ -* │ │ │ │ │ │ -00043 * - update_cone() │ │ │ │ │ │ -* │ │ │ │ │ │ -00044 * - proceed_with_stability() │ │ │ │ │ │ -* │ │ │ │ │ │ -00045 * ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ -* │ │ │ │ │ │ -00046 * - cocircular_pt_less(v1, v2) │ │ │ │ │ │ -* │ │ │ │ │ │ -00047 * - prepare_cocircular_list() │ │ │ │ │ │ -* │ │ │ │ │ │ -00048 * - test_cone_cocircular() │ │ │ │ │ │ -* │ │ │ │ │ │ -00049 * - test_stability(candidate, border_list) │ │ │ │ │ │ -* │ │ │ │ │ │ -00050 * - updat_cone_cocircular() │ │ │ │ │ │ -* │ │ │ │ │ │ -00051 * RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ -* │ │ │ │ │ │ -00052 * - compute_cone_contents() │ │ │ │ │ │ -* │ │ │ │ │ │ -00053 * - recompute_cone_contents() │ │ │ │ │ │ -* │ │ │ │ │ │ -00054 * - recompute_cone_contents_if_needed() │ │ │ │ │ │ -* │ │ │ │ │ │ -00055 * VARIOUS TOOLS │ │ │ │ │ │ -* │ │ │ │ │ │ -00056 * - circle_intersect() │ │ │ │ │ │ -* │ │ │ │ │ │ -00057 * - is_inside() │ │ │ │ │ │ -* │ │ │ │ │ │ -00058 * - abs_dangle() │ │ │ │ │ │ -* │ │ │ │ │ │ -00059 *******************************************************/ │ │ │ │ │ │ +00029 │ │ │ │ │ │ +00030 #ifndef __SPH_VECTOR_H__ │ │ │ │ │ │ +00031 #define __SPH_VECTOR_H__ │ │ │ │ │ │ +00032 │ │ │ │ │ │ +00033 #include │ │ │ │ │ │ +00034 #include │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include "geom_2d.h" │ │ │ │ │ │ +00037 #include │ │ │ │ │ │ +00038 │ │ │ │ │ │ +00039 namespace siscone_spherical{ │ │ │ │ │ │ +00040 │ │ │ │ │ │ +00054 class CSph3vector{ │ │ │ │ │ │ +00055 public: │ │ │ │ │ │ +00057 │ │ │ │ │ │ +CSph3vector(); │ │ │ │ │ │ +00058 │ │ │ │ │ │ 00060 │ │ │ │ │ │ -00061 #include │ │ │ │ │ │ -00062 #include │ │ │ │ │ │ -00063 #include │ │ │ │ │ │ -00064 #include "protocones.h" │ │ │ │ │ │ -00065 #include │ │ │ │ │ │ -00066 #include │ │ │ │ │ │ -00067 #include │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00069 namespace siscone_spherical{ │ │ │ │ │ │ +CSph3vector(double _px, double _py, double _pz); │ │ │ │ │ │ +00061 │ │ │ │ │ │ +00063 │ │ │ │ │ │ +~CSph3vector(); │ │ │ │ │ │ +00064 │ │ │ │ │ │ +00066 │ │ │ │ │ │ +CSph3vector& operator = (const CSph3vector &v); │ │ │ │ │ │ +00067 │ │ │ │ │ │ 00070 │ │ │ │ │ │ -00071 using namespace std; │ │ │ │ │ │ -00072 │ │ │ │ │ │ -00073 /********************************************************************** │ │ │ │ │ │ -00074 * CSphstable_cones implementation │ │ │ │ │ │ -* │ │ │ │ │ │ -00075 * Computes the list of stable comes from a particle list. │ │ │ │ │ │ -* │ │ │ │ │ │ -00076 * This class does the first fundamental task of te cone algorithm: │ │ │ │ │ │ -* │ │ │ │ │ │ -00077 * it is used to compute the list of stable cones given a list │ │ │ │ │ │ -* │ │ │ │ │ │ -00078 * of particles. │ │ │ │ │ │ -* │ │ │ │ │ │ -00079 **********************************************************************/ │ │ │ │ │ │ -00080 │ │ │ │ │ │ -00082 // INITIALISATION FUNCTIONS │ │ │ │ │ │ -// │ │ │ │ │ │ -00083 // - ctor() │ │ │ │ │ │ -// │ │ │ │ │ │ -00084 // - ctor(particle_list) │ │ │ │ │ │ -// │ │ │ │ │ │ -00085 // - dtor() │ │ │ │ │ │ -// │ │ │ │ │ │ -00086 // - init(particle_list) │ │ │ │ │ │ -// │ │ │ │ │ │ -00088 │ │ │ │ │ │ -00089 // default ctor │ │ │ │ │ │ -00090 //-------------00091 CSphstable_cones::CSphstable_cones(){ │ │ │ │ │ │ +const CSph3vector operator + (const CSph3vector &v); │ │ │ │ │ │ +00071 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.40 protocones.cpp │ │ │ │ │ │ +253 │ │ │ │ │ │ │ │ │ │ │ │ -00092 │ │ │ │ │ │ -nb_tot = 0; │ │ │ │ │ │ -00093 │ │ │ │ │ │ -hc = NULL; │ │ │ │ │ │ -00094 } │ │ │ │ │ │ + 254 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00074 │ │ │ │ │ │ +const CSph3vector operator - (const CSph3vector &v); │ │ │ │ │ │ +00075 │ │ │ │ │ │ +00078 │ │ │ │ │ │ +const CSph3vector operator / (const double &r); │ │ │ │ │ │ +00079 │ │ │ │ │ │ +00082 │ │ │ │ │ │ +CSph3vector& operator += (const CSph3vector &v); │ │ │ │ │ │ +00083 │ │ │ │ │ │ +00086 │ │ │ │ │ │ +CSph3vector& operator -= (const CSph3vector &v); │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00090 │ │ │ │ │ │ +CSph3vector& operator *= (const double &r); │ │ │ │ │ │ +00091 │ │ │ │ │ │ +00094 │ │ │ │ │ │ +CSph3vector& operator /= (const double &r); │ │ │ │ │ │ 00095 │ │ │ │ │ │ -00096 // ctor with initialisation │ │ │ │ │ │ -00097 //-------------------------00098 CSphstable_cones::CSphstable_cones(vector &_particle_list) │ │ │ │ │ │ -00099 │ │ │ │ │ │ -: CSphvicinity(_particle_list){ │ │ │ │ │ │ +00097 │ │ │ │ │ │ +inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ +00098 │ │ │ │ │ │ 00100 │ │ │ │ │ │ +inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ 00101 │ │ │ │ │ │ -nb_tot = 0; │ │ │ │ │ │ -00102 │ │ │ │ │ │ -hc = NULL; │ │ │ │ │ │ -00103 } │ │ │ │ │ │ +00103 │ │ │ │ │ │ +inline double norm() const {return sqrt(px*px+py*py+pz*pz);} │ │ │ │ │ │ 00104 │ │ │ │ │ │ -00105 // default dtor │ │ │ │ │ │ -00106 //-------------00107 CSphstable_cones::~CSphstable_cones(){ │ │ │ │ │ │ -00108 │ │ │ │ │ │ -if (hc!=NULL) delete hc; │ │ │ │ │ │ -00109 } │ │ │ │ │ │ +00106 │ │ │ │ │ │ +inline double norm2() const {return px*px+py*py+pz*pz;} │ │ │ │ │ │ +00107 │ │ │ │ │ │ +00109 │ │ │ │ │ │ +inline double phi() const {return atan2(py, px);} │ │ │ │ │ │ 00110 │ │ │ │ │ │ -00111 /* │ │ │ │ │ │ -00112 * initialisation │ │ │ │ │ │ -00113 * - _particle_list list of particles │ │ │ │ │ │ -00114 * - _n │ │ │ │ │ │ -number of particles │ │ │ │ │ │ -00115 *********************************************************************/ │ │ │ │ │ │ -00116 void CSphstable_cones::init(vector &_particle_list){ │ │ │ │ │ │ -00117 │ │ │ │ │ │ -// check already allocated mem │ │ │ │ │ │ -00118 │ │ │ │ │ │ -if (hc!=NULL){ │ │ │ │ │ │ -00119 │ │ │ │ │ │ -delete hc; │ │ │ │ │ │ +00112 │ │ │ │ │ │ +inline double theta() const {return atan2(perp(),pz);} │ │ │ │ │ │ +00113 │ │ │ │ │ │ 00120 │ │ │ │ │ │ -} │ │ │ │ │ │ +void build_norm(); │ │ │ │ │ │ 00121 │ │ │ │ │ │ -if (protocones.size()!=0) │ │ │ │ │ │ -00122 │ │ │ │ │ │ -protocones.clear(); │ │ │ │ │ │ -00123 │ │ │ │ │ │ -00124 │ │ │ │ │ │ -multiple_centre_done.clear(); │ │ │ │ │ │ 00125 │ │ │ │ │ │ +void build_thetaphi(); │ │ │ │ │ │ 00126 │ │ │ │ │ │ -// initialisation │ │ │ │ │ │ -00127 │ │ │ │ │ │ -set_particle_list(_particle_list); │ │ │ │ │ │ -00128 } │ │ │ │ │ │ 00129 │ │ │ │ │ │ +void get_angular_directions(CSph3vector &angular_dir1, CSph3vector &angular_dir2); │ │ │ │ │ │ 00130 │ │ │ │ │ │ -00132 // ALGORITHM MAIN ENTRY │ │ │ │ │ │ -// │ │ │ │ │ │ -00133 // - get_stable_cone(radius) │ │ │ │ │ │ -// │ │ │ │ │ │ +00131 │ │ │ │ │ │ +double px; │ │ │ │ │ │ +00132 │ │ │ │ │ │ +double py; │ │ │ │ │ │ +00133 │ │ │ │ │ │ +double pz; │ │ │ │ │ │ +00134 │ │ │ │ │ │ 00135 │ │ │ │ │ │ -00136 /* │ │ │ │ │ │ -00137 * compute stable cones. │ │ │ │ │ │ -00138 * This function really does the job i.e. computes │ │ │ │ │ │ -00139 * the list of stable cones (in a seedless way) │ │ │ │ │ │ -00140 * - _radius: radius of the cones │ │ │ │ │ │ -00141 * The number of stable cones found is returned │ │ │ │ │ │ -00142 *********************************************************************/ │ │ │ │ │ │ -00143 int CSphstable_cones::get_stable_cones(double _radius){ │ │ │ │ │ │ +double _norm; │ │ │ │ │ │ +00136 │ │ │ │ │ │ +double _theta; │ │ │ │ │ │ +00137 │ │ │ │ │ │ +double _phi; │ │ │ │ │ │ +00138 │ │ │ │ │ │ +00140 │ │ │ │ │ │ +// the following part is used for checksums // │ │ │ │ │ │ +00142 │ │ │ │ │ │ +siscone::Creference ref; │ │ │ │ │ │ +00143 }; │ │ │ │ │ │ 00144 │ │ │ │ │ │ -int p_idx; │ │ │ │ │ │ -00145 │ │ │ │ │ │ -00146 │ │ │ │ │ │ -// check if everything is correctly initialised │ │ │ │ │ │ -00147 │ │ │ │ │ │ -if (n_part==0){ │ │ │ │ │ │ -00148 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00149 │ │ │ │ │ │ -} │ │ │ │ │ │ -00150 │ │ │ │ │ │ -00151 │ │ │ │ │ │ -R = _radius; │ │ │ │ │ │ -00152 │ │ │ │ │ │ -R2 = R*R; │ │ │ │ │ │ -00153 │ │ │ │ │ │ -tan2R = tan(R); │ │ │ │ │ │ -00154 │ │ │ │ │ │ -tan2R *= tan2R; │ │ │ │ │ │ -00155 │ │ │ │ │ │ -00156 │ │ │ │ │ │ -// allow hash for cones candidates │ │ │ │ │ │ -00157 │ │ │ │ │ │ -hc = new sph_hash_cones(n_part, R); │ │ │ │ │ │ -00158 │ │ │ │ │ │ -00159 │ │ │ │ │ │ -// browse all particles │ │ │ │ │ │ -00160 │ │ │ │ │ │ -for (p_idx=0;p_idx_phi « ", " « parent->_theta « endl; │ │ │ │ │ │ -00177 #endif │ │ │ │ │ │ -00178 │ │ │ │ │ │ +inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ +00177 │ │ │ │ │ │ 00179 │ │ │ │ │ │ -// step 1: initialise with the first cone candidate │ │ │ │ │ │ +inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ 00180 │ │ │ │ │ │ -init_cone(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -249 │ │ │ │ │ │ - │ │ │ │ │ │ - 250 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00181 │ │ │ │ │ │ 00182 │ │ │ │ │ │ -do{ │ │ │ │ │ │ +inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ 00183 │ │ │ │ │ │ -// step 2: test cone stability for that pair (P,C) │ │ │ │ │ │ -00184 │ │ │ │ │ │ -test_cone(); │ │ │ │ │ │ 00185 │ │ │ │ │ │ +inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ 00186 │ │ │ │ │ │ -// step 3: go to the next cone child candidate C │ │ │ │ │ │ -00187 │ │ │ │ │ │ -} while (!update_cone()); │ │ │ │ │ │ 00188 │ │ │ │ │ │ -} │ │ │ │ │ │ +inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ 00189 │ │ │ │ │ │ -00190 │ │ │ │ │ │ -return proceed_with_stability(); │ │ │ │ │ │ -00191 } │ │ │ │ │ │ +00191 │ │ │ │ │ │ +inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ 00192 │ │ │ │ │ │ -00193 │ │ │ │ │ │ -00195 // ALGORITHM MAIN STEPS │ │ │ │ │ │ -// │ │ │ │ │ │ -00196 // - init_cone() │ │ │ │ │ │ -// │ │ │ │ │ │ -00197 // - test_cone() │ │ │ │ │ │ -// │ │ │ │ │ │ -00198 // - update_cone() │ │ │ │ │ │ -// │ │ │ │ │ │ -00199 // - proceed_with_stability() │ │ │ │ │ │ -// │ │ │ │ │ │ -00201 │ │ │ │ │ │ -00202 /* │ │ │ │ │ │ -00203 * initialise the cone. │ │ │ │ │ │ -00204 * We take the first particle in the angular ordering to compute │ │ │ │ │ │ -00205 * this one │ │ │ │ │ │ -00206 * return 0 on success, 1 on error │ │ │ │ │ │ -00207 *********************************************************************/ │ │ │ │ │ │ -00208 int CSphstable_cones::init_cone(){ │ │ │ │ │ │ +00194 │ │ │ │ │ │ +CSphmomentum& operator = (const CSphmomentum &v); │ │ │ │ │ │ +00195 │ │ │ │ │ │ +00198 │ │ │ │ │ │ +const CSphmomentum operator + (const CSphmomentum &v); │ │ │ │ │ │ +00199 │ │ │ │ │ │ +00202 │ │ │ │ │ │ +CSphmomentum& operator += (const CSphmomentum &v); │ │ │ │ │ │ +00203 │ │ │ │ │ │ +00206 │ │ │ │ │ │ +CSphmomentum& operator -= (const CSphmomentum &v); │ │ │ │ │ │ +00207 │ │ │ │ │ │ +00208 │ │ │ │ │ │ +double E; │ │ │ │ │ │ 00209 │ │ │ │ │ │ -// The previous version of the algorithm was starting the │ │ │ │ │ │ 00210 │ │ │ │ │ │ -// loop around vicinity elements with the "most isolated" child. │ │ │ │ │ │ +int parent_index; │ │ │ │ │ │ 00211 │ │ │ │ │ │ -// given the nodist method to calculate the cone contents, we no │ │ │ │ │ │ -00212 │ │ │ │ │ │ -// longer need to worry about which cone comes first... │ │ │ │ │ │ +int index; │ │ │ │ │ │ +00212 }; │ │ │ │ │ │ 00213 │ │ │ │ │ │ -first_cone=0; │ │ │ │ │ │ -00214 │ │ │ │ │ │ -00215 │ │ │ │ │ │ -// now make sure we have lists of the cocircular particles │ │ │ │ │ │ -00216 │ │ │ │ │ │ -prepare_cocircular_lists(); │ │ │ │ │ │ +00216 bool operator < (const CSphmomentum &v1, const CSphmomentum &v2); │ │ │ │ │ │ 00217 │ │ │ │ │ │ -00218 │ │ │ │ │ │ -//TODO? deal with a configuration with only degeneracies ? │ │ │ │ │ │ -00219 │ │ │ │ │ │ -// The only possibility seems a regular hexagon with a parent point │ │ │ │ │ │ +00219 bool momentum_theta_less(const CSphmomentum &v1, const CSphmomentum &v2); │ │ │ │ │ │ 00220 │ │ │ │ │ │ -// in the centre. And this situation is by itself unclear. │ │ │ │ │ │ -00221 │ │ │ │ │ │ -// Hence, we do nothing here ! │ │ │ │ │ │ -00222 │ │ │ │ │ │ +00222 bool momentum_pt_less(const CSphmomentum &v1, const CSphmomentum &v2); │ │ │ │ │ │ 00223 │ │ │ │ │ │ -// init set child C │ │ │ │ │ │ 00224 │ │ │ │ │ │ -centre = vicinity[first_cone]; │ │ │ │ │ │ -00225 │ │ │ │ │ │ -child = centre->v; │ │ │ │ │ │ -00226 │ │ │ │ │ │ -centre_idx = first_cone; │ │ │ │ │ │ -00227 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.39 protocones.h │ │ │ │ │ │ + │ │ │ │ │ │ +255 │ │ │ │ │ │ + │ │ │ │ │ │ +00226 // some handy utilities // │ │ │ │ │ │ 00228 │ │ │ │ │ │ -// build the initial cone (nodist: avoids calculating distances -00229 │ │ │ │ │ │ -// just deduces contents by circulating around all in/out operations) │ │ │ │ │ │ -00230 │ │ │ │ │ │ -// this function also sets the list of included particles │ │ │ │ │ │ +00230 inline double sqr(double x){return x*x;} │ │ │ │ │ │ 00231 │ │ │ │ │ │ -compute_cone_contents(); │ │ │ │ │ │ -00232 │ │ │ │ │ │ -00233 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00234 } │ │ │ │ │ │ -00235 │ │ │ │ │ │ +00235 inline double dot_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ 00236 │ │ │ │ │ │ -00237 /* │ │ │ │ │ │ -00238 * test cones. │ │ │ │ │ │ -00239 * We check if the cone(s) built with the present parent and child │ │ │ │ │ │ -00240 * are stable │ │ │ │ │ │ -00241 * return 0 on success 1 on error │ │ │ │ │ │ -00242 *********************************************************************/ │ │ │ │ │ │ -00243 int CSphstable_cones::test_cone(){ │ │ │ │ │ │ -00244 │ │ │ │ │ │ -siscone::Creference weighted_cone_ref; │ │ │ │ │ │ +//double tmp = v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ +00237 │ │ │ │ │ │ +//if (!isfinite(tmp)){ │ │ │ │ │ │ +00238 │ │ │ │ │ │ +// std::cout « "dot_product inf: " « std::endl; │ │ │ │ │ │ +00239 │ │ │ │ │ │ +// std::cout « " angles: " « v1._theta « " " « v1._phi « " and " « v2._theta « " " « v2._phi « │ │ │ │ │ │ +std::endl; │ │ │ │ │ │ +00240 │ │ │ │ │ │ +// std::cout « " moms : " « v1.px « " " « v1.py « " " « v1.pz │ │ │ │ │ │ +00241 │ │ │ │ │ │ +// │ │ │ │ │ │ +« " and " │ │ │ │ │ │ +« v2.px « " " « v2.py « " " « v2.pz « std::endl; │ │ │ │ │ │ +00242 │ │ │ │ │ │ +//} │ │ │ │ │ │ +00243 │ │ │ │ │ │ +return v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ +00244 } │ │ │ │ │ │ 00245 │ │ │ │ │ │ -00246 │ │ │ │ │ │ -// depending on the side we are taking the child particle, │ │ │ │ │ │ -00247 │ │ │ │ │ │ -// we test different configuration. │ │ │ │ │ │ -00248 │ │ │ │ │ │ -// Each time, two configurations are tested in such a way that │ │ │ │ │ │ -00249 │ │ │ │ │ │ -// all 4 possible cases (parent or child in or out the cone) │ │ │ │ │ │ +00249 inline CSph3vector cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ 00250 │ │ │ │ │ │ -// are tested when taking the pair of particle parent+child │ │ │ │ │ │ +//CSph3vector tmp; │ │ │ │ │ │ 00251 │ │ │ │ │ │ -// and child+parent. │ │ │ │ │ │ +//tmp.px = v1.py*v2.pz-v1.pz*v2.py; │ │ │ │ │ │ 00252 │ │ │ │ │ │ +//tmp.py = v1.pz*v2.px-v1.px*v2.pz; │ │ │ │ │ │ 00253 │ │ │ │ │ │ -// here are the tests entering the first series: │ │ │ │ │ │ +//tmp.pz = v1.px*v2.py-v1.py*v2.px; │ │ │ │ │ │ 00254 │ │ │ │ │ │ -// 1. check if the cone is already inserted │ │ │ │ │ │ +//return tmp; │ │ │ │ │ │ 00255 │ │ │ │ │ │ -// 2. check cone stability for the parent and child particles │ │ │ │ │ │ +return CSph3vector(v1.py*v2.pz-v1.pz*v2.py, │ │ │ │ │ │ 00256 │ │ │ │ │ │ +v1.pz*v2.px-v1.px*v2.pz, │ │ │ │ │ │ 00257 │ │ │ │ │ │ -//UPDATED(see below): if (centre->side){ │ │ │ │ │ │ -00258 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -// test when both particles are not in the cone │ │ │ │ │ │ +v1.px*v2.py-v1.py*v2.px); │ │ │ │ │ │ +00258 } │ │ │ │ │ │ 00259 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -// or when both are in. │ │ │ │ │ │ -00260 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -// Note: for the totally exclusive case, test emptyness before │ │ │ │ │ │ -00261 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -cone_candidate = cone; │ │ │ │ │ │ -00262 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -if (cone.ref.not_empty()){ │ │ │ │ │ │ -00263 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ +00263 inline double norm2_cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ 00264 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -} │ │ │ │ │ │ -00265 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ +return sqr(v1.py*v2.pz-v1.pz*v2.py) + sqr(v1.pz*v2.px-v1.px*v2.pz) + sqr(v1.px*v2.py-v1.py*v2.px); │ │ │ │ │ │ +00265 } │ │ │ │ │ │ 00266 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -cone_candidate = cone; │ │ │ │ │ │ -00267 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -cone_candidate+= *parent + *child; │ │ │ │ │ │ -00268 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ -00269 │ │ │ │ │ │ -//UPDATED(see below): } else { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.40 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00270 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -// test when 1! of the particles is in the cone │ │ │ │ │ │ +00270 inline double get_tan2_distance(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ 00271 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -cone_candidate = cone + *parent; │ │ │ │ │ │ -00272 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, true, false); │ │ │ │ │ │ +return norm2_cross_product3(v1,v2)/sqr(dot_product3(v1,v2)); │ │ │ │ │ │ +00272 } │ │ │ │ │ │ 00273 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -00274 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -cone_candidate = cone + *child; │ │ │ │ │ │ -00275 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ -00276 │ │ │ │ │ │ -//UPDATED(see below): } │ │ │ │ │ │ -00277 │ │ │ │ │ │ -//UPDATED(see below): │ │ │ │ │ │ +00277 inline double get_distance(const CSph3vector *v1, const CSph3vector *v2){ │ │ │ │ │ │ 00278 │ │ │ │ │ │ -//UPDATED(see below): nb_tot+=2; │ │ │ │ │ │ -00279 │ │ │ │ │ │ +return atan2(sqrt(norm2_cross_product3(*v1,*v2)), dot_product3(*v1,*v2)); │ │ │ │ │ │ +00279 } │ │ │ │ │ │ 00280 │ │ │ │ │ │ -// instead of testing 2 inclusion/exclusion states for every pair, we test the 4 of them │ │ │ │ │ │ -00281 │ │ │ │ │ │ -// when the parent has an energy bigger than the child │ │ │ │ │ │ -00282 │ │ │ │ │ │ -if (parent->E >= child->E){ │ │ │ │ │ │ -00283 │ │ │ │ │ │ -// test when both particles are not in the cone │ │ │ │ │ │ -00284 │ │ │ │ │ │ -// Note: for the totally exclusive case, test emptiness before │ │ │ │ │ │ -00285 │ │ │ │ │ │ -cone_candidate = cone; │ │ │ │ │ │ -00286 │ │ │ │ │ │ -if (cone.ref.not_empty()){ │ │ │ │ │ │ -00287 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ -00288 │ │ │ │ │ │ -} │ │ │ │ │ │ -00289 │ │ │ │ │ │ +00289 inline bool is_closer(const CSph3vector *v1, const CSph3vector *v2, const double tan2R){ │ │ │ │ │ │ 00290 │ │ │ │ │ │ -// test when 1! of the particles is in the cone │ │ │ │ │ │ +double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ 00291 │ │ │ │ │ │ -cone_candidate += *parent; │ │ │ │ │ │ -00292 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, true, false); │ │ │ │ │ │ +return (dot>=0) && (norm2_cross_product3(*v1,*v2)<=tan2R*dot*dot); │ │ │ │ │ │ +00292 } │ │ │ │ │ │ 00293 │ │ │ │ │ │ -00294 │ │ │ │ │ │ -cone_candidate = cone; │ │ │ │ │ │ -00295 │ │ │ │ │ │ -cone_candidate += *child; │ │ │ │ │ │ -00296 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ -00297 │ │ │ │ │ │ -00298 │ │ │ │ │ │ -// test when both are in. │ │ │ │ │ │ -00299 │ │ │ │ │ │ -cone_candidate += *parent; │ │ │ │ │ │ +00299 inline bool is_closer_safer(const CSph3vector *v1, const CSph3vector *v2, const double cosR){ │ │ │ │ │ │ 00300 │ │ │ │ │ │ -hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ +return dot_product3(*v1,*v2)>=cosR*sqrt(v1->norm2()*v2->norm2()); │ │ │ │ │ │ 00301 │ │ │ │ │ │ +//double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ 00302 │ │ │ │ │ │ -nb_tot += 4; │ │ │ │ │ │ -00303 │ │ │ │ │ │ -} │ │ │ │ │ │ +//return (dot>=0) && (norm2_cross_product3(*v1,*v2)centre.px « "’ ’" │ │ │ │ │ │ -00318 │ │ │ │ │ │ -« centre->centre.py « "’ ’" « centre->centre.pz « "’" « endl │ │ │ │ │ │ -00319 │ │ │ │ │ │ -« "pause -1 ’(" « centre->angle « " " « (centre->side ? ’+’ : ’-’) « ")"; │ │ │ │ │ │ -00320 #endif │ │ │ │ │ │ -00321 │ │ │ │ │ │ -00322 │ │ │ │ │ │ -// get the next child and centre │ │ │ │ │ │ -00323 │ │ │ │ │ │ -centre_idx++; │ │ │ │ │ │ -00324 │ │ │ │ │ │ -if (centre_idx==vicinity_size) │ │ │ │ │ │ -00325 │ │ │ │ │ │ -centre_idx=0; │ │ │ │ │ │ -00326 │ │ │ │ │ │ -if (centre_idx==first_cone) │ │ │ │ │ │ -00327 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ -00328 │ │ │ │ │ │ -00329 │ │ │ │ │ │ -// update the cone w.r.t. the old child │ │ │ │ │ │ -00330 │ │ │ │ │ │ -// only required if the old child is entering inside in which │ │ │ │ │ │ -00331 │ │ │ │ │ │ -// case we need to add it. We also know that the child is │ │ │ │ │ │ -00332 │ │ │ │ │ │ -// inside iff its side is -. │ │ │ │ │ │ -00333 │ │ │ │ │ │ -if (!centre->side){ │ │ │ │ │ │ -00334 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00335 │ │ │ │ │ │ -cout « " old_enter"; │ │ │ │ │ │ -00336 #endif │ │ │ │ │ │ -00337 │ │ │ │ │ │ -// update cone │ │ │ │ │ │ -00338 │ │ │ │ │ │ -cone += (*child); │ │ │ │ │ │ -00339 │ │ │ │ │ │ -00340 │ │ │ │ │ │ -// update info on particles inside │ │ │ │ │ │ -00341 │ │ │ │ │ │ -centre->is_inside->cone = true; │ │ │ │ │ │ -00342 │ │ │ │ │ │ -00343 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ -00344 │ │ │ │ │ │ -dpt += fabs(child->px)+fabs(child->py)+fabs(child->pz); │ │ │ │ │ │ -00345 │ │ │ │ │ │ -} │ │ │ │ │ │ -00346 │ │ │ │ │ │ -00347 │ │ │ │ │ │ -// update centre and child to correspond to the new position │ │ │ │ │ │ -00348 │ │ │ │ │ │ -centre = vicinity[centre_idx]; │ │ │ │ │ │ -00349 │ │ │ │ │ │ -child = centre->v; │ │ │ │ │ │ -00350 │ │ │ │ │ │ -00351 │ │ │ │ │ │ -// check cocircularity │ │ │ │ │ │ -00352 │ │ │ │ │ │ -// note that if cocirculaity is detected (i.e. if we receive 1 │ │ │ │ │ │ -00353 │ │ │ │ │ │ -// in the next test), we need to recall ’update_cone’ directly │ │ │ │ │ │ -00354 │ │ │ │ │ │ -// since tests and remaining part of te update has been performed │ │ │ │ │ │ -00355 │ │ │ │ │ │ -//if (cocircular_check()) │ │ │ │ │ │ -00356 │ │ │ │ │ │ -if (cocircular_check()){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -251 │ │ │ │ │ │ - │ │ │ │ │ │ - 252 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00357 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00358 │ │ │ │ │ │ -cout « " Co-circular case detected" « endl; │ │ │ │ │ │ -00359 #endif │ │ │ │ │ │ -00360 │ │ │ │ │ │ -return update_cone(); │ │ │ │ │ │ -00361 │ │ │ │ │ │ -} │ │ │ │ │ │ -00362 │ │ │ │ │ │ -00363 │ │ │ │ │ │ -// update the cone w.r.t. the new child │ │ │ │ │ │ -00364 │ │ │ │ │ │ -// only required if the new child was already inside in which │ │ │ │ │ │ -00365 │ │ │ │ │ │ -// case we need to remove it. We also know that the child is │ │ │ │ │ │ -00366 │ │ │ │ │ │ -// inside iff its side is +. │ │ │ │ │ │ -00367 │ │ │ │ │ │ -if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00368 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00369 │ │ │ │ │ │ -cout « " new exit"; │ │ │ │ │ │ -00370 #endif │ │ │ │ │ │ -00371 │ │ │ │ │ │ -00372 │ │ │ │ │ │ -// update cone │ │ │ │ │ │ -00373 │ │ │ │ │ │ -cone -= (*child); │ │ │ │ │ │ -00374 │ │ │ │ │ │ -00375 │ │ │ │ │ │ -// update info on particles inside │ │ │ │ │ │ -00376 │ │ │ │ │ │ -centre->is_inside->cone = false; │ │ │ │ │ │ -00377 │ │ │ │ │ │ -00378 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ -00379 │ │ │ │ │ │ -dpt += fabs(child->px)+fabs(child->py)+fabs(child->pz); //child->perp2(); │ │ │ │ │ │ -00380 │ │ │ │ │ │ -} │ │ │ │ │ │ -00381 │ │ │ │ │ │ -00382 │ │ │ │ │ │ -// check that the addition and subtraction of vectors does │ │ │ │ │ │ -00383 │ │ │ │ │ │ -// not lead to too much rounding error │ │ │ │ │ │ -00384 │ │ │ │ │ │ -// for that, we compute the sum of pt modifications and of |pt| │ │ │ │ │ │ -00385 │ │ │ │ │ │ -// since last recomputation and once the ratio overpasses a threshold │ │ │ │ │ │ -00386 │ │ │ │ │ │ -// we recompute vicinity. │ │ │ │ │ │ -00387 │ │ │ │ │ │ -if ((dpt>PT_TSHOLD*(fabs(cone.px)+fabs(cone.py)+fabs(cone.pz))) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00388 │ │ │ │ │ │ -recompute_cone_contents(); │ │ │ │ │ │ -00389 │ │ │ │ │ │ -} │ │ │ │ │ │ -00390 │ │ │ │ │ │ -if (cone.ref.is_empty()){ │ │ │ │ │ │ -00391 │ │ │ │ │ │ -cone = CSphmomentum(); │ │ │ │ │ │ -00392 │ │ │ │ │ │ -dpt=0.0; │ │ │ │ │ │ -00393 │ │ │ │ │ │ -} │ │ │ │ │ │ -00394 │ │ │ │ │ │ -00395 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00396 │ │ │ │ │ │ -cout « "’" « endl; │ │ │ │ │ │ -00397 #endif │ │ │ │ │ │ -00398 │ │ │ │ │ │ -00399 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00400 } │ │ │ │ │ │ -00401 │ │ │ │ │ │ -00402 │ │ │ │ │ │ -00403 /* │ │ │ │ │ │ -00404 * compute stability of all enumerated candidates. │ │ │ │ │ │ -00405 * For all candidate cones which are stable w.r.t. their border particles, │ │ │ │ │ │ -00406 * pass the last test: stability with quadtree intersection │ │ │ │ │ │ -00407 ************************************************************************/ │ │ │ │ │ │ -00408 int CSphstable_cones::proceed_with_stability(){ │ │ │ │ │ │ -00409 │ │ │ │ │ │ -int i; │ │ │ │ │ │ -00410 │ │ │ │ │ │ -sph_hash_element *elm; │ │ │ │ │ │ -00411 │ │ │ │ │ │ -00412 │ │ │ │ │ │ -for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ -00413 │ │ │ │ │ │ -// test ith cell of the hash array │ │ │ │ │ │ -00414 │ │ │ │ │ │ -elm = hc->hash_array[i]; │ │ │ │ │ │ -00415 │ │ │ │ │ │ -00416 │ │ │ │ │ │ -// browse elements therein │ │ │ │ │ │ -00417 │ │ │ │ │ │ -while (elm!=NULL){ │ │ │ │ │ │ -00418 │ │ │ │ │ │ -// test stability │ │ │ │ │ │ -00419 │ │ │ │ │ │ -if (elm->is_stable){ │ │ │ │ │ │ -00420 │ │ │ │ │ │ -// stability is not ensured by all pairs of "edges" already browsed │ │ │ │ │ │ -00421 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ -00422 │ │ │ │ │ │ -// => testing stability with quadtree intersection │ │ │ │ │ │ -00423 │ │ │ │ │ │ -if (quadtree->circle_intersect(elm->eta, elm->phi, R2)==elm->ref) │ │ │ │ │ │ -00424 #else │ │ │ │ │ │ -00425 │ │ │ │ │ │ -// => testing stability with the particle-list intersection │ │ │ │ │ │ -00426 │ │ │ │ │ │ -if (circle_intersect(elm->centre)==elm->centre.ref) │ │ │ │ │ │ -00427 #endif │ │ │ │ │ │ -00428 │ │ │ │ │ │ -protocones.push_back(CSphmomentum(elm->centre,1.0)); │ │ │ │ │ │ -00429 │ │ │ │ │ │ -} │ │ │ │ │ │ -00430 │ │ │ │ │ │ -00431 │ │ │ │ │ │ -// jump to the next one │ │ │ │ │ │ -00432 │ │ │ │ │ │ -elm = elm->next; │ │ │ │ │ │ -00433 │ │ │ │ │ │ -} │ │ │ │ │ │ -00434 │ │ │ │ │ │ -} │ │ │ │ │ │ -00435 │ │ │ │ │ │ -00436 │ │ │ │ │ │ -// free hash │ │ │ │ │ │ -00437 │ │ │ │ │ │ -// we do that at this level because hash eats rather a lot of memory │ │ │ │ │ │ -00438 │ │ │ │ │ │ -// we want to free it before running the split/merge algorithm │ │ │ │ │ │ -00439 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00440 │ │ │ │ │ │ -nb_hash_cones = hc->n_cones; │ │ │ │ │ │ -00441 │ │ │ │ │ │ -nb_hash_occupied = hc->n_occupied_cells; │ │ │ │ │ │ -00442 #endif │ │ │ │ │ │ -00443 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.40 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00444 │ │ │ │ │ │ -delete hc; │ │ │ │ │ │ -00445 │ │ │ │ │ │ -hc=NULL; │ │ │ │ │ │ -00446 │ │ │ │ │ │ -00447 │ │ │ │ │ │ -return protocones.size(); │ │ │ │ │ │ -00448 } │ │ │ │ │ │ -00449 │ │ │ │ │ │ -00450 │ │ │ │ │ │ -00452 // ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ -// │ │ │ │ │ │ -00453 // - cocircular_pt_less(v1, v2) │ │ │ │ │ │ -// │ │ │ │ │ │ -00454 // - prepare_cocircular_list() │ │ │ │ │ │ -// │ │ │ │ │ │ -00455 // - test_cone_cocircular() │ │ │ │ │ │ -// │ │ │ │ │ │ -00456 // - test_stability(candidate, border_vect) │ │ │ │ │ │ -// │ │ │ │ │ │ -00457 // - updat_cone_cocircular() │ │ │ │ │ │ -// │ │ │ │ │ │ -00459 │ │ │ │ │ │ -00461 //NEVER USED │ │ │ │ │ │ -00462 //bool cocircular_pt_less(CSphmomentum *v1, CSphmomentum *v2){ │ │ │ │ │ │ -00463 // return v1->perp2() < v2->perp2(); │ │ │ │ │ │ -00464 //} │ │ │ │ │ │ -00465 │ │ │ │ │ │ -00466 /* │ │ │ │ │ │ -00467 * run through the vicinity of the current parent and for each child │ │ │ │ │ │ -00468 * establish which other members are cocircular... Note that the list │ │ │ │ │ │ -00469 * associated with each child contains references to vicinity │ │ │ │ │ │ -00470 * elements: thus two vicinity elements each associated with one given │ │ │ │ │ │ -00471 * particle may appear in a list -- this needs to be watched out for │ │ │ │ │ │ -00472 * later on... │ │ │ │ │ │ -00473 **********************************************************************/ │ │ │ │ │ │ -00474 void CSphstable_cones::prepare_cocircular_lists() { │ │ │ │ │ │ -00475 │ │ │ │ │ │ -siscone::circulator::iterator > here(vicinity.begin(), │ │ │ │ │ │ -00476 │ │ │ │ │ │ -vicinity.begin(), │ │ │ │ │ │ -00477 │ │ │ │ │ │ -vicinity.end()); │ │ │ │ │ │ -00478 │ │ │ │ │ │ -00479 │ │ │ │ │ │ -siscone::circulator::iterator > search(here); │ │ │ │ │ │ -00480 │ │ │ │ │ │ -00481 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00482 │ │ │ │ │ │ -CSphvicinity_elm* here_pntr = *here(); │ │ │ │ │ │ -00483 │ │ │ │ │ │ -search.set_position(here); │ │ │ │ │ │ -00484 │ │ │ │ │ │ -00485 │ │ │ │ │ │ -// search forwards for things that should have "here" included in │ │ │ │ │ │ -00486 │ │ │ │ │ │ -// their cocircularity list │ │ │ │ │ │ -00487 │ │ │ │ │ │ -while (true) { │ │ │ │ │ │ -00488 │ │ │ │ │ │ -++search; │ │ │ │ │ │ -00489 │ │ │ │ │ │ -if ( siscone::abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ -00490 │ │ │ │ │ │ -here_pntr->cocircular_range │ │ │ │ │ │ -00491 │ │ │ │ │ │ -&& search() != here()) { │ │ │ │ │ │ -00492 │ │ │ │ │ │ -(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ -00493 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00494 │ │ │ │ │ │ -break; │ │ │ │ │ │ -00495 │ │ │ │ │ │ -} │ │ │ │ │ │ -00496 │ │ │ │ │ │ -} │ │ │ │ │ │ -00497 │ │ │ │ │ │ -00498 │ │ │ │ │ │ -// search backwards │ │ │ │ │ │ -00499 │ │ │ │ │ │ -search.set_position(here); │ │ │ │ │ │ -00500 │ │ │ │ │ │ -while (true) { │ │ │ │ │ │ -00501 │ │ │ │ │ │ ---search; │ │ │ │ │ │ -00502 │ │ │ │ │ │ -if ( siscone::abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ -00503 │ │ │ │ │ │ -here_pntr->cocircular_range │ │ │ │ │ │ -00504 │ │ │ │ │ │ -&& search() != here()) { │ │ │ │ │ │ -00505 │ │ │ │ │ │ -(*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ -00506 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00507 │ │ │ │ │ │ -break; │ │ │ │ │ │ -00508 │ │ │ │ │ │ -} │ │ │ │ │ │ -00509 │ │ │ │ │ │ -} │ │ │ │ │ │ -00510 │ │ │ │ │ │ -00511 │ │ │ │ │ │ -++here; │ │ │ │ │ │ -00512 │ │ │ │ │ │ -} while (here() != vicinity.begin()); │ │ │ │ │ │ -00513 } │ │ │ │ │ │ -00514 │ │ │ │ │ │ -00515 /* │ │ │ │ │ │ -00516 * Testing cocircular configurations in p^3 time, │ │ │ │ │ │ -00517 * rather than 2^p time; we will test all contiguous subsets of points │ │ │ │ │ │ -00518 * on the border --- note that this is till probably overkill, since │ │ │ │ │ │ -00519 * in principle we only have to test situations where up to a │ │ │ │ │ │ -00520 * half-circle is filled (but going to a full circle is simpler) │ │ │ │ │ │ -00521 ******************************************************************/ │ │ │ │ │ │ -00522 void CSphstable_cones::test_cone_cocircular(CSphmomentum & borderless_cone, │ │ │ │ │ │ -00523 │ │ │ │ │ │ -list & border_list) { │ │ │ │ │ │ -00524 │ │ │ │ │ │ -// in spherical coordinates, we don’t have a universal x-y axis system │ │ │ │ │ │ -00525 │ │ │ │ │ │ -// to measure the angles. So we first determine one minimising │ │ │ │ │ │ -00526 │ │ │ │ │ │ -// the uncertainties │ │ │ │ │ │ -00527 │ │ │ │ │ │ -CSph3vector angl_dir1, angl_dir2; │ │ │ │ │ │ -00528 │ │ │ │ │ │ -centre->centre.get_angular_directions(angl_dir1, angl_dir2); │ │ │ │ │ │ -00529 │ │ │ │ │ │ -angl_dir1/=angl_dir1._norm; │ │ │ │ │ │ -00530 │ │ │ │ │ │ -angl_dir2/=angl_dir2._norm; │ │ │ │ │ │ -00531 │ │ │ │ │ │ -00532 │ │ │ │ │ │ -// now we have te reference axis, create the CSphborder_store structure │ │ │ │ │ │ -00533 │ │ │ │ │ │ -vector border_vect; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -253 │ │ │ │ │ │ - │ │ │ │ │ │ - 254 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00534 │ │ │ │ │ │ -border_vect.reserve(border_list.size()); │ │ │ │ │ │ -00535 │ │ │ │ │ │ -for (list::iterator it = border_list.begin(); │ │ │ │ │ │ -00536 │ │ │ │ │ │ -it != border_list.end(); it++) { │ │ │ │ │ │ -00537 │ │ │ │ │ │ -border_vect.push_back(CSphborder_store(*it, centre->centre, angl_dir1, angl_dir2)); │ │ │ │ │ │ -00538 │ │ │ │ │ │ -} │ │ │ │ │ │ -00539 │ │ │ │ │ │ -00540 │ │ │ │ │ │ -// get them into order of angle │ │ │ │ │ │ -00541 │ │ │ │ │ │ -sort(border_vect.begin(), border_vect.end()); │ │ │ │ │ │ -00542 │ │ │ │ │ │ -00543 │ │ │ │ │ │ -// set up some circulators, since these will help us go around the │ │ │ │ │ │ -00544 │ │ │ │ │ │ -// circle easily │ │ │ │ │ │ -00545 │ │ │ │ │ │ -siscone::circulator::iterator > │ │ │ │ │ │ -00546 │ │ │ │ │ │ -start(border_vect.begin(), border_vect.begin(),border_vect.end()); │ │ │ │ │ │ -00547 │ │ │ │ │ │ -siscone::circulator::iterator > mid(start), end(start); │ │ │ │ │ │ -00548 │ │ │ │ │ │ -00549 │ │ │ │ │ │ -// test the borderless cone │ │ │ │ │ │ -00550 │ │ │ │ │ │ -CSphmomentum candidate = borderless_cone; │ │ │ │ │ │ -00551 │ │ │ │ │ │ -//candidate.build_etaphi(); │ │ │ │ │ │ -00552 │ │ │ │ │ │ -if (candidate.ref.not_empty()) │ │ │ │ │ │ -00553 │ │ │ │ │ │ -test_stability(candidate, border_vect); │ │ │ │ │ │ -00554 │ │ │ │ │ │ -00555 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00556 │ │ │ │ │ │ -// reset status wrt inclusion in the cone │ │ │ │ │ │ -00557 │ │ │ │ │ │ -mid = start; │ │ │ │ │ │ -00558 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00559 │ │ │ │ │ │ -mid()->is_in = false; │ │ │ │ │ │ -00560 │ │ │ │ │ │ -} while (++mid != start); │ │ │ │ │ │ -00561 │ │ │ │ │ │ -00562 │ │ │ │ │ │ -// now run over all inclusion possibilities with this starting point │ │ │ │ │ │ -00563 │ │ │ │ │ │ -candidate = borderless_cone; │ │ │ │ │ │ -00564 │ │ │ │ │ │ -while (++mid != start) { │ │ │ │ │ │ -00565 │ │ │ │ │ │ -// will begin with start+1 and go up to start-1 │ │ │ │ │ │ -00566 │ │ │ │ │ │ -mid()->is_in = true; │ │ │ │ │ │ -00567 │ │ │ │ │ │ -candidate += *(mid()->mom); │ │ │ │ │ │ -00568 │ │ │ │ │ │ -test_stability(candidate, border_vect); │ │ │ │ │ │ -00569 │ │ │ │ │ │ -} │ │ │ │ │ │ -00570 │ │ │ │ │ │ -00571 │ │ │ │ │ │ -} while (++start != end); │ │ │ │ │ │ -00572 │ │ │ │ │ │ -00573 │ │ │ │ │ │ -// mid corresponds to momentum that we need to include to get the │ │ │ │ │ │ -00574 │ │ │ │ │ │ -// full cone │ │ │ │ │ │ -00575 │ │ │ │ │ │ -mid()->is_in = true; │ │ │ │ │ │ -00576 │ │ │ │ │ │ -candidate += *(mid()->mom); │ │ │ │ │ │ -00577 │ │ │ │ │ │ -test_stability(candidate, border_vect); │ │ │ │ │ │ -00578 } │ │ │ │ │ │ -00579 │ │ │ │ │ │ -00580 │ │ │ │ │ │ -00587 void CSphstable_cones::test_stability(CSphmomentum & candidate, const vector & │ │ │ │ │ │ -border_vect) { │ │ │ │ │ │ -00588 │ │ │ │ │ │ -00589 │ │ │ │ │ │ -// this almost certainly has not been done... │ │ │ │ │ │ -00590 │ │ │ │ │ │ -//candidate.build_etaphi(); │ │ │ │ │ │ -00591 │ │ │ │ │ │ -00592 │ │ │ │ │ │ -bool stable = true; │ │ │ │ │ │ -00593 │ │ │ │ │ │ -for (unsigned i = 0; i < border_vect.size(); i++) { │ │ │ │ │ │ -00594 │ │ │ │ │ │ -if (is_closer(&candidate, border_vect[i].mom,tan2R) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ -00595 │ │ │ │ │ │ -stable = false; │ │ │ │ │ │ -00596 │ │ │ │ │ │ -break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ -00597 │ │ │ │ │ │ -} │ │ │ │ │ │ -00598 │ │ │ │ │ │ -} │ │ │ │ │ │ -00599 │ │ │ │ │ │ -00600 │ │ │ │ │ │ -if (stable) hc->insert(&candidate); │ │ │ │ │ │ -00601 } │ │ │ │ │ │ -00602 │ │ │ │ │ │ -00603 /* │ │ │ │ │ │ -00604 * check if we are in a situation of cocircularity. │ │ │ │ │ │ -00605 * if it is the case, update and test in the corresponding way │ │ │ │ │ │ -00606 * return ’false’ if no cocircularity detected, ’true’ otherwise │ │ │ │ │ │ -00607 * Note that if cocircularity is detected, we need to │ │ │ │ │ │ -00608 * recall ’update’ from ’update’ !!! │ │ │ │ │ │ -00609 ***************************************************************/ │ │ │ │ │ │ -00610 bool CSphstable_cones::cocircular_check(){ │ │ │ │ │ │ -00611 │ │ │ │ │ │ -// check if many configurations have the same centre. │ │ │ │ │ │ -00612 │ │ │ │ │ │ -// if this is the case, branch on the algorithm for this │ │ │ │ │ │ -00613 │ │ │ │ │ │ -// special case. │ │ │ │ │ │ -00614 │ │ │ │ │ │ -// Note that those situation, being considered separately in │ │ │ │ │ │ -00615 │ │ │ │ │ │ -// test_cone_multiple, must only be considered here if all │ │ │ │ │ │ -00616 │ │ │ │ │ │ -// angles are on the same side (this avoid multiple counting) │ │ │ │ │ │ -00617 │ │ │ │ │ │ -00618 │ │ │ │ │ │ -if (centre->cocircular.empty()) return false; │ │ │ │ │ │ -00619 │ │ │ │ │ │ -00620 │ │ │ │ │ │ -// first get cone into status required at end... │ │ │ │ │ │ -00621 │ │ │ │ │ │ -if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00622 │ │ │ │ │ │ -// update cone │ │ │ │ │ │ -00623 │ │ │ │ │ │ -cone -= (*child); │ │ │ │ │ │ -00624 │ │ │ │ │ │ -00625 │ │ │ │ │ │ -// update info on particles inside │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.40 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00626 │ │ │ │ │ │ -00627 │ │ │ │ │ │ -00628 │ │ │ │ │ │ -00629 │ │ │ │ │ │ -00630 │ │ │ │ │ │ -00631 │ │ │ │ │ │ -00632 │ │ │ │ │ │ -00633 │ │ │ │ │ │ -00634 │ │ │ │ │ │ -00635 │ │ │ │ │ │ -00636 │ │ │ │ │ │ -00637 │ │ │ │ │ │ -00638 │ │ │ │ │ │ -00639 │ │ │ │ │ │ -00640 │ │ │ │ │ │ -00641 │ │ │ │ │ │ -00642 │ │ │ │ │ │ -00643 │ │ │ │ │ │ -00644 │ │ │ │ │ │ -00645 │ │ │ │ │ │ -00646 │ │ │ │ │ │ -00647 │ │ │ │ │ │ -00648 │ │ │ │ │ │ -00649 │ │ │ │ │ │ -00650 │ │ │ │ │ │ -00651 │ │ │ │ │ │ -00652 │ │ │ │ │ │ -00653 │ │ │ │ │ │ -00654 │ │ │ │ │ │ -00655 │ │ │ │ │ │ -00656 │ │ │ │ │ │ -00657 │ │ │ │ │ │ -00658 │ │ │ │ │ │ -00659 │ │ │ │ │ │ -00660 │ │ │ │ │ │ -00661 │ │ │ │ │ │ -00662 │ │ │ │ │ │ -00663 │ │ │ │ │ │ -00664 │ │ │ │ │ │ -00665 │ │ │ │ │ │ -00666 │ │ │ │ │ │ -00667 │ │ │ │ │ │ - │ │ │ │ │ │ -255 │ │ │ │ │ │ - │ │ │ │ │ │ -centre->is_inside->cone = false; │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ -dpt += fabs(child->px)+fabs(child->py)+fabs(child->pz); //child->perp2(); │ │ │ │ │ │ -} │ │ │ │ │ │ - │ │ │ │ │ │ -// now establish the list of unique children in the list │ │ │ │ │ │ -// first make sure parent and child are in! │ │ │ │ │ │ -list removed_from_cone; │ │ │ │ │ │ -list put_in_border; │ │ │ │ │ │ -list border_list; │ │ │ │ │ │ -CSphmomentum cone_removal; │ │ │ │ │ │ -CSphmomentum border = *parent; │ │ │ │ │ │ -border_list.push_back(parent); │ │ │ │ │ │ -// make sure child appears in the border region │ │ │ │ │ │ -centre->cocircular.push_back(centre); │ │ │ │ │ │ -// now establish the full contents of the cone minus the cocircular │ │ │ │ │ │ -// region and of the cocircular region itself │ │ │ │ │ │ -for(list::iterator it = centre->cocircular.begin(); │ │ │ │ │ │ -it != centre->cocircular.end(); it++) { │ │ │ │ │ │ -if ((*it)->is_inside->cone) { │ │ │ │ │ │ -cone_removal │ │ │ │ │ │ -+= *((*it)->v); │ │ │ │ │ │ -(*it)->is_inside->cone = false; │ │ │ │ │ │ -removed_from_cone.push_back((*it)->is_inside); │ │ │ │ │ │ -} │ │ │ │ │ │ - │ │ │ │ │ │ -// if a point appears twice (i.e. with + and - sign) in the list of │ │ │ │ │ │ -// points on the border, we take care not to include it twice. │ │ │ │ │ │ -// Note that this situation may appear when a point is at a distance │ │ │ │ │ │ -// close to 2R from the parent │ │ │ │ │ │ -if (!(*it)->is_inside->cocirc) { │ │ │ │ │ │ -border += *((*it)->v); │ │ │ │ │ │ -(*it)->is_inside->cocirc = true; │ │ │ │ │ │ -put_in_border.push_back((*it)->is_inside); │ │ │ │ │ │ -border_list.push_back((*it)->v); │ │ │ │ │ │ -//cout « " adding particle " « (*it)->v->_theta « ", " « (*it)->v->_phi « " to the border list" │ │ │ │ │ │ -« endl; │ │ │ │ │ │ -00668 │ │ │ │ │ │ -} │ │ │ │ │ │ -00669 │ │ │ │ │ │ -} │ │ │ │ │ │ -00670 │ │ │ │ │ │ -00671 │ │ │ │ │ │ -00672 │ │ │ │ │ │ -// figure out whether this pairing has been observed before │ │ │ │ │ │ -00673 │ │ │ │ │ │ -CSphmomentum borderless_cone = cone; │ │ │ │ │ │ -00674 │ │ │ │ │ │ -borderless_cone -= cone_removal; │ │ │ │ │ │ -00675 │ │ │ │ │ │ -bool consider = true; │ │ │ │ │ │ -00676 │ │ │ │ │ │ -for (unsigned int i=0;i(borderless_cone.ref, │ │ │ │ │ │ -00686 │ │ │ │ │ │ -border.ref)); │ │ │ │ │ │ -00687 │ │ │ │ │ │ -00688 │ │ │ │ │ │ -// first figure out whether our cone momentum is good │ │ │ │ │ │ -00689 │ │ │ │ │ │ -double local_dpt = fabs(cone_removal.px) + fabs(cone_removal.py); │ │ │ │ │ │ -00690 │ │ │ │ │ │ -double total_dpt = dpt + local_dpt; │ │ │ │ │ │ -00691 │ │ │ │ │ │ -00692 │ │ │ │ │ │ -recompute_cone_contents_if_needed(borderless_cone, total_dpt); │ │ │ │ │ │ -00693 │ │ │ │ │ │ -if (total_dpt == 0) { │ │ │ │ │ │ -00694 │ │ │ │ │ │ -// a recomputation has taken place -- so take advantage of this │ │ │ │ │ │ -00695 │ │ │ │ │ │ -// and update the member cone momentum │ │ │ │ │ │ -00696 │ │ │ │ │ │ -cone = borderless_cone + cone_removal; │ │ │ │ │ │ -00697 │ │ │ │ │ │ -dpt = local_dpt; │ │ │ │ │ │ -00698 │ │ │ │ │ │ -} │ │ │ │ │ │ -00699 │ │ │ │ │ │ -00700 │ │ │ │ │ │ -test_cone_cocircular(borderless_cone, border_list); │ │ │ │ │ │ -00701 │ │ │ │ │ │ -} │ │ │ │ │ │ -00702 │ │ │ │ │ │ -00703 │ │ │ │ │ │ -00704 │ │ │ │ │ │ -// relabel things that were in the cone but got removed │ │ │ │ │ │ -00705 │ │ │ │ │ │ -for(list::iterator is_in = removed_from_cone.begin(); │ │ │ │ │ │ -00706 │ │ │ │ │ │ -is_in != removed_from_cone.end(); is_in++) { │ │ │ │ │ │ -00707 │ │ │ │ │ │ -(*is_in)->cone = true; │ │ │ │ │ │ -00708 │ │ │ │ │ │ -} │ │ │ │ │ │ -00709 │ │ │ │ │ │ -00710 │ │ │ │ │ │ -// relabel things that got put into the border │ │ │ │ │ │ -00711 │ │ │ │ │ │ -for(list::iterator is_in = put_in_border.begin(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 256 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00712 │ │ │ │ │ │ -is_in != put_in_border.end(); is_in++) { │ │ │ │ │ │ -00713 │ │ │ │ │ │ -(*is_in)->cocirc = false; │ │ │ │ │ │ -00714 │ │ │ │ │ │ -} │ │ │ │ │ │ -00715 │ │ │ │ │ │ -00716 │ │ │ │ │ │ -// we’re done with everything -- return true to signal to user that we’ve │ │ │ │ │ │ -00717 │ │ │ │ │ │ -// been through the co-circularity rigmarole │ │ │ │ │ │ -00718 │ │ │ │ │ │ -return true; │ │ │ │ │ │ -00719 } │ │ │ │ │ │ -00720 │ │ │ │ │ │ -00721 │ │ │ │ │ │ -00723 // RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ -// │ │ │ │ │ │ -00724 // - compute_cone_contents() │ │ │ │ │ │ -// │ │ │ │ │ │ -00725 // - recompute_cone_contents() │ │ │ │ │ │ -// │ │ │ │ │ │ -00726 // - recompute_cone_contents_if_needed() │ │ │ │ │ │ -// │ │ │ │ │ │ -00728 │ │ │ │ │ │ -00737 void CSphstable_cones::compute_cone_contents() { │ │ │ │ │ │ -00738 │ │ │ │ │ │ -siscone::circulator::iterator > │ │ │ │ │ │ -00739 │ │ │ │ │ │ -start(vicinity.begin()+first_cone, vicinity.begin(), vicinity.end()); │ │ │ │ │ │ -00740 │ │ │ │ │ │ -00741 │ │ │ │ │ │ -siscone::circulator::iterator > here(start); │ │ │ │ │ │ -00742 │ │ │ │ │ │ -00743 │ │ │ │ │ │ -// note that in the following algorithm, the cone contents never includes │ │ │ │ │ │ -00744 │ │ │ │ │ │ -// the child. Indeed, if it has positive sign, then it will be set as │ │ │ │ │ │ -00745 │ │ │ │ │ │ -// outside at the last step in the loop. If it has negative sign, then the │ │ │ │ │ │ -00746 │ │ │ │ │ │ -// loop will at some point go to the corresponding situation with positive │ │ │ │ │ │ -00747 │ │ │ │ │ │ -// sign and set the inclusion status to 0. │ │ │ │ │ │ -00748 │ │ │ │ │ │ -00749 │ │ │ │ │ │ -do { │ │ │ │ │ │ -00750 │ │ │ │ │ │ -// as we leave this position a particle enters if its side is │ │ │ │ │ │ -00751 │ │ │ │ │ │ -// negative (i.e. the centre is the one at -ve angle wrt to the │ │ │ │ │ │ -00752 │ │ │ │ │ │ -// parent-child line │ │ │ │ │ │ -00753 │ │ │ │ │ │ -if (!(*here())->side) ((*here())->is_inside->cone) = 1; │ │ │ │ │ │ -00754 │ │ │ │ │ │ -00755 │ │ │ │ │ │ -// move on to the next position │ │ │ │ │ │ -00756 │ │ │ │ │ │ -++here; │ │ │ │ │ │ -00757 │ │ │ │ │ │ -00758 │ │ │ │ │ │ -// as we arrive at this position a particle leaves if its side is positive │ │ │ │ │ │ -00759 │ │ │ │ │ │ -if ((*here())->side) ((*here())->is_inside->cone) = 0; │ │ │ │ │ │ -00760 │ │ │ │ │ │ -} while (here != start); │ │ │ │ │ │ -00761 │ │ │ │ │ │ -00762 │ │ │ │ │ │ -// once we’ve reached the start the ’is_inside’ information should be │ │ │ │ │ │ -00763 │ │ │ │ │ │ -// 100% complete, so we can use it to calculate the cone contents │ │ │ │ │ │ -00764 │ │ │ │ │ │ -// and then exit │ │ │ │ │ │ -00765 │ │ │ │ │ │ -recompute_cone_contents(); │ │ │ │ │ │ -00766 │ │ │ │ │ │ -return; │ │ │ │ │ │ -00767 │ │ │ │ │ │ -00768 } │ │ │ │ │ │ -00769 │ │ │ │ │ │ -00770 │ │ │ │ │ │ -00771 /* │ │ │ │ │ │ -00772 * compute the cone momentum from particle list. │ │ │ │ │ │ -00773 * in this version, we use the ’pincluded’ information │ │ │ │ │ │ -00774 * from the CSphvicinity class │ │ │ │ │ │ -00775 */ │ │ │ │ │ │ -00776 void CSphstable_cones::recompute_cone_contents(){ │ │ │ │ │ │ -00777 │ │ │ │ │ │ -unsigned int i; │ │ │ │ │ │ -00778 │ │ │ │ │ │ -00779 │ │ │ │ │ │ -// set momentum to 0 │ │ │ │ │ │ -00780 │ │ │ │ │ │ -cone = CSphmomentum(); │ │ │ │ │ │ -00781 │ │ │ │ │ │ -00782 │ │ │ │ │ │ -// Important note: we can browse only the particles │ │ │ │ │ │ -00783 │ │ │ │ │ │ -// in vicinity since all particles in the cone are │ │ │ │ │ │ -00784 │ │ │ │ │ │ -// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ -00785 │ │ │ │ │ │ -// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ -00786 │ │ │ │ │ │ -// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ -00787 │ │ │ │ │ │ -for (i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ -00790 │ │ │ │ │ │ -cone += *vicinity[i]->v; │ │ │ │ │ │ -00791 │ │ │ │ │ │ -} │ │ │ │ │ │ -00792 │ │ │ │ │ │ -00793 │ │ │ │ │ │ -// set check variables back to 0 │ │ │ │ │ │ -00794 │ │ │ │ │ │ -dpt = 0.0; │ │ │ │ │ │ -00795 } │ │ │ │ │ │ -00796 │ │ │ │ │ │ -00797 │ │ │ │ │ │ -00798 /* │ │ │ │ │ │ -00799 * if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ -00800 * the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ -00801 * ’pincluded’ information from the CSphvicinity class, but we don’t │ │ │ │ │ │ -00802 * change the member cone, only the locally supplied one │ │ │ │ │ │ -00803 */ │ │ │ │ │ │ -00804 void CSphstable_cones::recompute_cone_contents_if_needed(CSphmomentum & this_cone, │ │ │ │ │ │ -00805 │ │ │ │ │ │ -double & this_dpt){ │ │ │ │ │ │ -00806 │ │ │ │ │ │ -00807 │ │ │ │ │ │ -if (this_dpt > PT_TSHOLD*(fabs(this_cone.px)+fabs(this_cone.py))) { │ │ │ │ │ │ -00808 │ │ │ │ │ │ -if (cone.ref.is_empty()) { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.41 protocones.h │ │ │ │ │ │ - │ │ │ │ │ │ -00809 │ │ │ │ │ │ -this_cone = CSphmomentum(); │ │ │ │ │ │ -00810 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00811 │ │ │ │ │ │ -// set momentum to 0 │ │ │ │ │ │ -00812 │ │ │ │ │ │ -this_cone = CSphmomentum(); │ │ │ │ │ │ -00813 │ │ │ │ │ │ -00814 │ │ │ │ │ │ -// Important note: we can browse only the particles │ │ │ │ │ │ -00815 │ │ │ │ │ │ -// in vicinity since all particles in the this_cone are │ │ │ │ │ │ -00816 │ │ │ │ │ │ -// withing a distance 2R w.r.t. parent hence in vicinity. │ │ │ │ │ │ -00817 │ │ │ │ │ │ -// Among those, we only add the particles for which ’is_inside’ is true ! │ │ │ │ │ │ -00818 │ │ │ │ │ │ -// This methos rather than a direct comparison avoids rounding errors │ │ │ │ │ │ -00819 │ │ │ │ │ │ -for (unsigned int i=0;iside) && (vicinity[i]->is_inside->cone)) │ │ │ │ │ │ -00822 │ │ │ │ │ │ -this_cone += *vicinity[i]->v; │ │ │ │ │ │ -00823 │ │ │ │ │ │ -} │ │ │ │ │ │ -00824 │ │ │ │ │ │ -00825 │ │ │ │ │ │ -} │ │ │ │ │ │ -00826 │ │ │ │ │ │ -// set check variables back to 0 │ │ │ │ │ │ -00827 │ │ │ │ │ │ -this_dpt = 0.0; │ │ │ │ │ │ -00828 │ │ │ │ │ │ -} │ │ │ │ │ │ -00829 │ │ │ │ │ │ -00830 } │ │ │ │ │ │ -00831 │ │ │ │ │ │ -00832 │ │ │ │ │ │ -00834 // VARIOUS TOOLS │ │ │ │ │ │ -// │ │ │ │ │ │ -00835 // - circle_intersect() │ │ │ │ │ │ -// │ │ │ │ │ │ -00836 // - is_inside() │ │ │ │ │ │ -// │ │ │ │ │ │ -00837 // - abs_dangle() │ │ │ │ │ │ -// │ │ │ │ │ │ -00839 │ │ │ │ │ │ -00840 │ │ │ │ │ │ -00841 /* │ │ │ │ │ │ -00842 * circle intersection. │ │ │ │ │ │ -00843 * computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ -00844 * The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ -00845 * - cx │ │ │ │ │ │ -circle centre x coordinate │ │ │ │ │ │ -00846 * - cy │ │ │ │ │ │ -circle centre y coordinate │ │ │ │ │ │ -00847 * return the checkxor for the intersection │ │ │ │ │ │ -00848 ******************************************************************/ │ │ │ │ │ │ -00849 siscone::Creference CSphstable_cones::circle_intersect(CSph3vector &cone_centre){ │ │ │ │ │ │ -00850 │ │ │ │ │ │ -siscone::Creference intersection; │ │ │ │ │ │ -00851 │ │ │ │ │ │ -int i; │ │ │ │ │ │ -00852 │ │ │ │ │ │ -00853 │ │ │ │ │ │ -for (i=0;i │ │ │ │ │ │ 00034 #include │ │ │ │ │ │ 00035 #include │ │ │ │ │ │ 00036 #include "hash.h" │ │ │ │ │ │ 00037 │ │ │ │ │ │ @@ -23414,28 +23134,28 @@ │ │ │ │ │ │ bool cocircular_check(); │ │ │ │ │ │ 00180 │ │ │ │ │ │ 00185 │ │ │ │ │ │ void test_cone_cocircular(Cmomentum & borderless_cone, │ │ │ │ │ │ 00186 │ │ │ │ │ │ std::list & border_list); │ │ │ │ │ │ 00187 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.40 protocones.h │ │ │ │ │ │ + │ │ │ │ │ │ +257 │ │ │ │ │ │ + │ │ │ │ │ │ 00194 │ │ │ │ │ │ void test_stability(Cmomentum & candidate, │ │ │ │ │ │ 00195 │ │ │ │ │ │ const std::vector & border_vect); │ │ │ │ │ │ 00196 │ │ │ │ │ │ 00203 │ │ │ │ │ │ void compute_cone_contents(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.42 protocones.h │ │ │ │ │ │ - │ │ │ │ │ │ -259 │ │ │ │ │ │ - │ │ │ │ │ │ 00204 │ │ │ │ │ │ 00210 │ │ │ │ │ │ void recompute_cone_contents(); │ │ │ │ │ │ 00211 │ │ │ │ │ │ 00212 │ │ │ │ │ │ /* │ │ │ │ │ │ 00213 │ │ │ │ │ │ @@ -23503,15 +23223,15 @@ │ │ │ │ │ │ 00266 * \return the absolute value of the difference between the angles │ │ │ │ │ │ 00267 *****************************************************************/ │ │ │ │ │ │ 00268 inline double abs_dangle(double &angle1, double &angle2); │ │ │ │ │ │ 00269 │ │ │ │ │ │ 00270 } │ │ │ │ │ │ 00271 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.42 │ │ │ │ │ │ +5.40 │ │ │ │ │ │ │ │ │ │ │ │ protocones.h │ │ │ │ │ │ │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: protocones.h │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // Description: header file for stable cones determination (Cstable_cones) │ │ │ │ │ │ // │ │ │ │ │ │ @@ -23560,27 +23280,27 @@ │ │ │ │ │ │ $// │ │ │ │ │ │ 00027 // $Date:: 2008-07-12 17:40:35 +0200 (Sat, 12 Jul 2008) │ │ │ │ │ │ $// │ │ │ │ │ │ 00029 │ │ │ │ │ │ 00030 #ifndef __SPH_PROTOCONES_H__ │ │ │ │ │ │ 00031 #define __SPH_PROTOCONES_H__ │ │ │ │ │ │ 00032 │ │ │ │ │ │ -00033 #include "momentum.h" │ │ │ │ │ │ -00034 #include "vicinity.h" │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ // │ │ │ │ │ │ │ │ │ │ │ │ - 260 │ │ │ │ │ │ + 258 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ +00033 #include "momentum.h" │ │ │ │ │ │ +00034 #include "vicinity.h" │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include │ │ │ │ │ │ 00037 #include │ │ │ │ │ │ 00038 #include "hash.h" │ │ │ │ │ │ 00039 │ │ │ │ │ │ 00040 #include │ │ │ │ │ │ 00041 │ │ │ │ │ │ 00042 namespace siscone_spherical{ │ │ │ │ │ │ 00043 │ │ │ │ │ │ @@ -23694,25 +23414,25 @@ │ │ │ │ │ │ 00179 │ │ │ │ │ │ */ │ │ │ │ │ │ 00180 │ │ │ │ │ │ void prepare_cocircular_lists(); │ │ │ │ │ │ 00181 │ │ │ │ │ │ 00189 │ │ │ │ │ │ bool cocircular_check(); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.41 siscone.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00190 │ │ │ │ │ │ 00195 │ │ │ │ │ │ void test_cone_cocircular(CSphmomentum & borderless_cone, │ │ │ │ │ │ 00196 │ │ │ │ │ │ std::list & border_list); │ │ │ │ │ │ 00197 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.43 siscone.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00204 │ │ │ │ │ │ void test_stability(CSphmomentum & candidate, │ │ │ │ │ │ 00205 │ │ │ │ │ │ const std::vector & border_vect); │ │ │ │ │ │ 00206 │ │ │ │ │ │ 00213 │ │ │ │ │ │ void compute_cone_contents(); │ │ │ │ │ │ @@ -23773,15 +23493,15 @@ │ │ │ │ │ │ 00258 │ │ │ │ │ │ double dpt; │ │ │ │ │ │ 00259 }; │ │ │ │ │ │ 00260 │ │ │ │ │ │ 00261 } │ │ │ │ │ │ 00262 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.43 │ │ │ │ │ │ +5.41 │ │ │ │ │ │ │ │ │ │ │ │ siscone.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: siscone.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: source file for the main SISCone class │ │ │ │ │ │ @@ -23836,28 +23556,28 @@ │ │ │ │ │ │ 00032 #include "siscone_error.h" │ │ │ │ │ │ 00033 #include │ │ │ │ │ │ 00034 #include │ │ │ │ │ │ 00035 #include │ │ │ │ │ │ 00036 │ │ │ │ │ │ 00037 namespace siscone{ │ │ │ │ │ │ 00038 using namespace std; │ │ │ │ │ │ -00039 │ │ │ │ │ │ -00040 /*************************************************************** │ │ │ │ │ │ -00041 * Csiscone implementation │ │ │ │ │ │ -* │ │ │ │ │ │ -00042 * final class: gather everything to compute the jet contents. * │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -261 │ │ │ │ │ │ +259 │ │ │ │ │ │ │ │ │ │ │ │ - 262 │ │ │ │ │ │ + 260 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ +00039 │ │ │ │ │ │ +00040 /*************************************************************** │ │ │ │ │ │ +00041 * Csiscone implementation │ │ │ │ │ │ +* │ │ │ │ │ │ +00042 * final class: gather everything to compute the jet contents. * │ │ │ │ │ │ 00043 * │ │ │ │ │ │ * │ │ │ │ │ │ 00044 * This is the class user should use. │ │ │ │ │ │ * │ │ │ │ │ │ 00045 * It computes the jet contents of a list of particles │ │ │ │ │ │ * │ │ │ │ │ │ 00046 * given a cone radius and a threshold for splitting/merging. * │ │ │ │ │ │ @@ -23977,26 +23697,26 @@ │ │ │ │ │ │ 00122 │ │ │ │ │ │ // on top of eta and phi. │ │ │ │ │ │ 00123 │ │ │ │ │ │ add_protocones(&protocones, R2, _ptmin); │ │ │ │ │ │ 00124 │ │ │ │ │ │ protocones_list.push_back(protocones); │ │ │ │ │ │ 00125 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.41 siscone.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00126 │ │ │ │ │ │ nb_hash_cones_total += nb_hash_cones; │ │ │ │ │ │ 00127 │ │ │ │ │ │ nb_hash_occupied_total += nb_hash_occupied; │ │ │ │ │ │ 00128 #endif │ │ │ │ │ │ 00129 │ │ │ │ │ │ } else { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.43 siscone.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00130 │ │ │ │ │ │ // no new protocone: leave │ │ │ │ │ │ 00131 │ │ │ │ │ │ finished=true; │ │ │ │ │ │ 00132 │ │ │ │ │ │ } │ │ │ │ │ │ 00133 │ │ │ │ │ │ @@ -24125,28 +23845,28 @@ │ │ │ │ │ │ minimum pT of the protojets │ │ │ │ │ │ 00210 * - _split_merge_scale │ │ │ │ │ │ the scale choice for the split-merge procedure │ │ │ │ │ │ 00211 * │ │ │ │ │ │ NOTE: using pt leads to IR unsafety for some events with momentum │ │ │ │ │ │ 00212 * │ │ │ │ │ │ conservation. So we strongly advise not to change the default │ │ │ │ │ │ -00213 * │ │ │ │ │ │ -value. │ │ │ │ │ │ -00214 * return the number of jets found, -1 if recomputation not allowed. │ │ │ │ │ │ -00215 ********************************************************************/ │ │ │ │ │ │ -00216 int Csiscone::recompute_jets(double _f, double _ptmin, │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -263 │ │ │ │ │ │ +261 │ │ │ │ │ │ │ │ │ │ │ │ - 264 │ │ │ │ │ │ + 262 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ +00213 * │ │ │ │ │ │ +value. │ │ │ │ │ │ +00214 * return the number of jets found, -1 if recomputation not allowed. │ │ │ │ │ │ +00215 ********************************************************************/ │ │ │ │ │ │ +00216 int Csiscone::recompute_jets(double _f, double _ptmin, │ │ │ │ │ │ 00217 │ │ │ │ │ │ Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ 00218 │ │ │ │ │ │ if (!rerun_allowed) │ │ │ │ │ │ 00219 │ │ │ │ │ │ return -1; │ │ │ │ │ │ 00220 │ │ │ │ │ │ @@ -24270,24 +23990,23 @@ │ │ │ │ │ │ 00290 string siscone_version(){ │ │ │ │ │ │ 00291 │ │ │ │ │ │ return SISCONE_VERSION; │ │ │ │ │ │ 00292 } │ │ │ │ │ │ 00293 │ │ │ │ │ │ 00294 } │ │ │ │ │ │ │ │ │ │ │ │ -5.44 │ │ │ │ │ │ - │ │ │ │ │ │ -siscone.cpp │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -00001 │ │ │ │ │ │ + 5.42 siscone.cpp │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ +5.42 │ │ │ │ │ │ │ │ │ │ │ │ - 5.44 siscone.cpp │ │ │ │ │ │ +siscone.cpp │ │ │ │ │ │ │ │ │ │ │ │ +00001 │ │ │ │ │ │ 00002 // File: siscone.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: source file for the main SISCone class │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ @@ -24405,29 +24124,29 @@ │ │ │ │ │ │ 00083 │ │ │ │ │ │ Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ 00084 │ │ │ │ │ │ // make sure things are initialised │ │ │ │ │ │ 00085 │ │ │ │ │ │ _initialise_if_needed(); │ │ │ │ │ │ 00086 │ │ │ │ │ │ -00087 │ │ │ │ │ │ -// run some general safety tests (NB: f will be checked in split-merge) │ │ │ │ │ │ -00088 │ │ │ │ │ │ -if (_radius <= 0.0 || _radius >= 0.5*M_PI) { │ │ │ │ │ │ -00089 │ │ │ │ │ │ -ostringstream message; │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -265 │ │ │ │ │ │ +263 │ │ │ │ │ │ │ │ │ │ │ │ - 266 │ │ │ │ │ │ + 264 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ +00087 │ │ │ │ │ │ +// run some general safety tests (NB: f will be checked in split-merge) │ │ │ │ │ │ +00088 │ │ │ │ │ │ +if (_radius <= 0.0 || _radius >= 0.5*M_PI) { │ │ │ │ │ │ +00089 │ │ │ │ │ │ +ostringstream message; │ │ │ │ │ │ 00090 │ │ │ │ │ │ message « "Illegal value for cone radius, R = " « _radius │ │ │ │ │ │ 00091 │ │ │ │ │ │ « " (legal values are 0 │ │ │ │ │ │ -00034 #include │ │ │ │ │ │ -00035 #include "geom_2d.h" │ │ │ │ │ │ -00036 #include "momentum.h" │ │ │ │ │ │ -00037 #include │ │ │ │ │ │ -00038 #include │ │ │ │ │ │ -00039 #include │ │ │ │ │ │ -00040 #include │ │ │ │ │ │ -00041 #include │ │ │ │ │ │ -00042 │ │ │ │ │ │ -00043 namespace siscone_spherical{ │ │ │ │ │ │ -00044 │ │ │ │ │ │ -00045 const int CJET_INEXISTENT_PASS = -2; │ │ │ │ │ │ -00046 │ │ │ │ │ │ -00056 class CSphjet{ │ │ │ │ │ │ +siscone.h │ │ │ │ │ │ │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: siscone.h │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.45 split_merge.h │ │ │ │ │ │ - │ │ │ │ │ │ -269 │ │ │ │ │ │ - │ │ │ │ │ │ -00057 public: │ │ │ │ │ │ -00059 │ │ │ │ │ │ -CSphjet(); │ │ │ │ │ │ -00060 │ │ │ │ │ │ -00062 │ │ │ │ │ │ -~CSphjet(); │ │ │ │ │ │ -00063 │ │ │ │ │ │ -00064 │ │ │ │ │ │ -CSphmomentum v; │ │ │ │ │ │ -00065 │ │ │ │ │ │ -double E_tilde; │ │ │ │ │ │ -00066 │ │ │ │ │ │ -int n; │ │ │ │ │ │ -00067 │ │ │ │ │ │ -std::vector contents; │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00080 │ │ │ │ │ │ -double sm_var2; │ │ │ │ │ │ -00081 │ │ │ │ │ │ -00083 │ │ │ │ │ │ -CSphtheta_phi_range range; │ │ │ │ │ │ -00084 │ │ │ │ │ │ -00089 │ │ │ │ │ │ -int pass; │ │ │ │ │ │ -00090 }; │ │ │ │ │ │ -00091 │ │ │ │ │ │ -00094 │ │ │ │ │ │ -00096 bool jets_E_less(const CSphjet &j1, const CSphjet &j2); │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00098 │ │ │ │ │ │ -00106 enum Esplit_merge_scale { │ │ │ │ │ │ -00107 │ │ │ │ │ │ -SM_E, │ │ │ │ │ │ -00108 │ │ │ │ │ │ -SM_Etilde │ │ │ │ │ │ -00109 }; │ │ │ │ │ │ -00110 │ │ │ │ │ │ -00112 std::string split_merge_scale_name(Esplit_merge_scale sms); │ │ │ │ │ │ -00113 │ │ │ │ │ │ -00119 class CSphsplit_merge_ptcomparison{ │ │ │ │ │ │ -00120 public: │ │ │ │ │ │ -00122 │ │ │ │ │ │ -CSphsplit_merge_ptcomparison() : │ │ │ │ │ │ -00123 │ │ │ │ │ │ -particles(0), split_merge_scale(SM_Etilde){}; │ │ │ │ │ │ -00124 │ │ │ │ │ │ -00126 │ │ │ │ │ │ -std::string SM_scale_name() const { │ │ │ │ │ │ -00127 │ │ │ │ │ │ -return split_merge_scale_name(split_merge_scale);} │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00129 │ │ │ │ │ │ -std::vector * particles; │ │ │ │ │ │ -00130 │ │ │ │ │ │ -std::vector * particles_norm2; │ │ │ │ │ │ -00131 │ │ │ │ │ │ -00133 │ │ │ │ │ │ -bool operator()(const CSphjet &jet1, const CSphjet &jet2) const; │ │ │ │ │ │ -00134 │ │ │ │ │ │ -00146 │ │ │ │ │ │ -void get_difference(const CSphjet &j1, const CSphjet &j2, CSphmomentum *v, double *E_tilde) const; │ │ │ │ │ │ -00147 │ │ │ │ │ │ -00158 │ │ │ │ │ │ -Esplit_merge_scale split_merge_scale; │ │ │ │ │ │ -00159 }; │ │ │ │ │ │ -00160 │ │ │ │ │ │ -00161 │ │ │ │ │ │ -00162 // iterator types │ │ │ │ │ │ -00164 typedef std::multiset::iterator │ │ │ │ │ │ -cjet_iterator; │ │ │ │ │ │ -00165 │ │ │ │ │ │ -00167 typedef std::vector::iterator jet_iterator; │ │ │ │ │ │ -00168 │ │ │ │ │ │ -00169 │ │ │ │ │ │ -00170 │ │ │ │ │ │ -00175 class CSphsplit_merge{ │ │ │ │ │ │ -00176 public: │ │ │ │ │ │ -00178 │ │ │ │ │ │ -CSphsplit_merge(); │ │ │ │ │ │ -00179 │ │ │ │ │ │ -00181 │ │ │ │ │ │ -~CSphsplit_merge(); │ │ │ │ │ │ -00182 │ │ │ │ │ │ -00183 │ │ │ │ │ │ -00185 │ │ │ │ │ │ -// initialisation functions // │ │ │ │ │ │ -00187 │ │ │ │ │ │ -00196 │ │ │ │ │ │ -int init(std::vector &_particles, std::vector *protocones, double R2, │ │ │ │ │ │ -double Emin=0.0); │ │ │ │ │ │ -00197 │ │ │ │ │ │ -00203 │ │ │ │ │ │ -int init_particles(std::vector &_particles); │ │ │ │ │ │ -00204 │ │ │ │ │ │ -00208 │ │ │ │ │ │ -int init_pleft(); │ │ │ │ │ │ -00209 │ │ │ │ │ │ -00221 │ │ │ │ │ │ -inline int set_E_weighted_splitting(bool _use_E_weighted_splitting){ │ │ │ │ │ │ -00222 │ │ │ │ │ │ -use_E_weighted_splitting = _use_E_weighted_splitting; │ │ │ │ │ │ -00223 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00224 │ │ │ │ │ │ -} │ │ │ │ │ │ -00225 │ │ │ │ │ │ -00227 │ │ │ │ │ │ -// cleaning functions // │ │ │ │ │ │ -00229 │ │ │ │ │ │ -00231 │ │ │ │ │ │ -int partial_clear(); │ │ │ │ │ │ -00232 │ │ │ │ │ │ -00234 │ │ │ │ │ │ -int full_clear(); │ │ │ │ │ │ -00235 │ │ │ │ │ │ -00237 │ │ │ │ │ │ -// user-defined stable-cone ordering // │ │ │ │ │ │ -00239 │ │ │ │ │ │ -00245 │ │ │ │ │ │ -class Cuser_scale_base{ │ │ │ │ │ │ -00246 │ │ │ │ │ │ -public: │ │ │ │ │ │ -00248 │ │ │ │ │ │ -virtual ~Cuser_scale_base(){} │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 270 │ │ │ │ │ │ - │ │ │ │ │ │ -00249 │ │ │ │ │ │ -00254 │ │ │ │ │ │ -00255 │ │ │ │ │ │ -00266 │ │ │ │ │ │ -00267 │ │ │ │ │ │ -00268 │ │ │ │ │ │ -00269 │ │ │ │ │ │ -00270 │ │ │ │ │ │ -00275 │ │ │ │ │ │ -00276 │ │ │ │ │ │ -00277 │ │ │ │ │ │ -00278 │ │ │ │ │ │ -00280 │ │ │ │ │ │ -00281 │ │ │ │ │ │ -00282 │ │ │ │ │ │ -00284 │ │ │ │ │ │ -00286 │ │ │ │ │ │ -00296 │ │ │ │ │ │ -00297 │ │ │ │ │ │ -00305 │ │ │ │ │ │ -00306 │ │ │ │ │ │ -00317 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -virtual double operator()(const CSphjet & jet) const = 0; │ │ │ │ │ │ -virtual bool is_larger(const CSphjet & a, const CSphjet & b) const{ │ │ │ │ │ │ -return (a.sm_var2 > b.sm_var2); │ │ │ │ │ │ -} │ │ │ │ │ │ -}; │ │ │ │ │ │ -void set_user_scale(const Cuser_scale_base * user_scale_in){ │ │ │ │ │ │ -_user_scale = user_scale_in; │ │ │ │ │ │ -} │ │ │ │ │ │ -const Cuser_scale_base * user_scale() const { return _user_scale; } │ │ │ │ │ │ -// main parts of the algorithm // │ │ │ │ │ │ -int merge_collinear_and_remove_soft(); │ │ │ │ │ │ -int add_protocones(std::vector *protocones, double R2, double Emin=0.0); │ │ │ │ │ │ -int add_hardest_protocone_to_jets(std::vector *protocones, double R2, double │ │ │ │ │ │ -Emin=0.0); │ │ │ │ │ │ - │ │ │ │ │ │ -00318 │ │ │ │ │ │ -00328 │ │ │ │ │ │ -int perform(double overlap_tshold, double Emin=0.0); │ │ │ │ │ │ -00329 │ │ │ │ │ │ -00330 │ │ │ │ │ │ -00332 │ │ │ │ │ │ -// save and debug functions // │ │ │ │ │ │ -00334 │ │ │ │ │ │ -00337 │ │ │ │ │ │ -int save_contents(FILE *flux); │ │ │ │ │ │ -00338 │ │ │ │ │ │ -00340 │ │ │ │ │ │ -int show(); │ │ │ │ │ │ -00341 │ │ │ │ │ │ -00342 │ │ │ │ │ │ -// particle information │ │ │ │ │ │ -00343 │ │ │ │ │ │ -int n; │ │ │ │ │ │ -00344 │ │ │ │ │ │ -std::vector particles; │ │ │ │ │ │ -00345 │ │ │ │ │ │ -std::vector particles_norm2; │ │ │ │ │ │ -00346 │ │ │ │ │ │ -int n_left; │ │ │ │ │ │ -00347 │ │ │ │ │ │ -std::vector p_remain; │ │ │ │ │ │ -00348 │ │ │ │ │ │ -std::vector p_uncol_hard; │ │ │ │ │ │ -00349 │ │ │ │ │ │ -int n_pass; │ │ │ │ │ │ -00350 │ │ │ │ │ │ -00354 │ │ │ │ │ │ -double most_ambiguous_split; │ │ │ │ │ │ -00355 │ │ │ │ │ │ -00356 │ │ │ │ │ │ -// jets information │ │ │ │ │ │ -00357 │ │ │ │ │ │ -std::vector jets; │ │ │ │ │ │ -00358 │ │ │ │ │ │ -00359 │ │ │ │ │ │ -// working entries │ │ │ │ │ │ -00360 │ │ │ │ │ │ -int *indices; │ │ │ │ │ │ -00361 │ │ │ │ │ │ -int idx_size; │ │ │ │ │ │ -00362 │ │ │ │ │ │ -00371 │ │ │ │ │ │ -bool merge_identical_protocones; │ │ │ │ │ │ -00372 │ │ │ │ │ │ -00374 │ │ │ │ │ │ -CSphsplit_merge_ptcomparison ptcomparison; │ │ │ │ │ │ -00375 │ │ │ │ │ │ -00382 │ │ │ │ │ │ -double SM_var2_hardest_cut_off; │ │ │ │ │ │ -00383 │ │ │ │ │ │ -00391 │ │ │ │ │ │ -double stable_cone_soft_E2_cutoff; │ │ │ │ │ │ -00392 │ │ │ │ │ │ -00393 private: │ │ │ │ │ │ -00401 │ │ │ │ │ │ -bool get_overlap(const CSphjet &j1, const CSphjet &j2, double *v); │ │ │ │ │ │ -00402 │ │ │ │ │ │ -00403 │ │ │ │ │ │ -00415 │ │ │ │ │ │ -bool split(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ -00416 │ │ │ │ │ │ -00425 │ │ │ │ │ │ -bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ -00426 │ │ │ │ │ │ -00433 │ │ │ │ │ │ -bool insert(CSphjet &jet); │ │ │ │ │ │ -00434 │ │ │ │ │ │ -00441 │ │ │ │ │ │ -double get_sm_var2(CSphmomentum &v, double &E_tilde); │ │ │ │ │ │ -00442 │ │ │ │ │ │ -00444 │ │ │ │ │ │ -void compute_Etilde(CSphjet &j); │ │ │ │ │ │ -00445 │ │ │ │ │ │ -00446 │ │ │ │ │ │ -// jet information │ │ │ │ │ │ -00448 #ifdef SISCONE_USES_UNIQUE_PTR_AS_AUTO_PTR │ │ │ │ │ │ -00449 │ │ │ │ │ │ -std::unique_ptr > candidates; │ │ │ │ │ │ -00450 #else │ │ │ │ │ │ -00451 │ │ │ │ │ │ -std::auto_ptr > candidates; │ │ │ │ │ │ -00452 #endif │ │ │ │ │ │ -00453 │ │ │ │ │ │ -00455 │ │ │ │ │ │ -double E_min; │ │ │ │ │ │ -00456 │ │ │ │ │ │ -00462 │ │ │ │ │ │ -bool use_E_weighted_splitting; │ │ │ │ │ │ -00463 │ │ │ │ │ │ -00466 │ │ │ │ │ │ -const Cuser_scale_base *_user_scale; │ │ │ │ │ │ -00467 │ │ │ │ │ │ -00468 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.46 split_merge.h │ │ │ │ │ │ - │ │ │ │ │ │ -00470 │ │ │ │ │ │ -std::set cand_refs; │ │ │ │ │ │ -00471 #endif │ │ │ │ │ │ -00472 }; │ │ │ │ │ │ -00473 │ │ │ │ │ │ -00474 } │ │ │ │ │ │ -00475 │ │ │ │ │ │ -00476 │ │ │ │ │ │ -00477 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.46 │ │ │ │ │ │ - │ │ │ │ │ │ -split_merge.h │ │ │ │ │ │ - │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: split_merge.h │ │ │ │ │ │ +00004 // Description: header file for the main SISCone class │ │ │ │ │ │ // │ │ │ │ │ │ -00004 // Description: header file for splitting/merging (contains the CJet class) // │ │ │ │ │ │ 00005 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ 00007 // │ │ │ │ │ │ // │ │ │ │ │ │ 00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ @@ -25194,693 +24552,242 @@ │ │ │ │ │ │ 00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00023 // │ │ │ │ │ │ // │ │ │ │ │ │ -00024 // $Revision:: 405 │ │ │ │ │ │ +00024 // $Revision:: 401 │ │ │ │ │ │ $// │ │ │ │ │ │ -00025 // $Date:: 2016-05-23 20:15:02 +0200 (Mon, 23 May 2016) │ │ │ │ │ │ +00025 // $Date:: 2016-05-19 16:44:37 +0200 (Thu, 19 May 2016) │ │ │ │ │ │ $// │ │ │ │ │ │ 00027 │ │ │ │ │ │ -00028 #ifndef __SPLIT_MERGE_H__ │ │ │ │ │ │ -00029 #define __SPLIT_MERGE_H__ │ │ │ │ │ │ +00028 #ifndef __SISCONE_H__ │ │ │ │ │ │ +00029 #define __SISCONE_H__ │ │ │ │ │ │ 00030 │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ -00032 #include "defines.h" │ │ │ │ │ │ -00033 #include "geom_2d.h" │ │ │ │ │ │ -00034 #include "momentum.h" │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include │ │ │ │ │ │ -00037 #include │ │ │ │ │ │ -00038 #include │ │ │ │ │ │ -00039 #include │ │ │ │ │ │ -00040 │ │ │ │ │ │ -00041 namespace siscone{ │ │ │ │ │ │ -00042 │ │ │ │ │ │ -00043 const int CJET_INEXISTENT_PASS = -2; │ │ │ │ │ │ -00044 │ │ │ │ │ │ -00054 class Cjet{ │ │ │ │ │ │ -00055 public: │ │ │ │ │ │ -00057 │ │ │ │ │ │ -Cjet(); │ │ │ │ │ │ -00058 │ │ │ │ │ │ -00060 │ │ │ │ │ │ -~Cjet(); │ │ │ │ │ │ -00061 │ │ │ │ │ │ -00062 │ │ │ │ │ │ -Cmomentum v; │ │ │ │ │ │ -00063 │ │ │ │ │ │ -double pt_tilde; │ │ │ │ │ │ -00064 │ │ │ │ │ │ -int n; │ │ │ │ │ │ -00065 │ │ │ │ │ │ -std::vector contents; │ │ │ │ │ │ -00066 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -double sm_var2; │ │ │ │ │ │ -00074 │ │ │ │ │ │ +00031 #include "protocones.h" │ │ │ │ │ │ +00032 #include "split_merge.h" │ │ │ │ │ │ +00033 │ │ │ │ │ │ +00034 namespace siscone{ │ │ │ │ │ │ +00035 │ │ │ │ │ │ +00048 class Csiscone : public Cstable_cones, public Csplit_merge{ │ │ │ │ │ │ +00049 public: │ │ │ │ │ │ +00051 │ │ │ │ │ │ +Csiscone(); │ │ │ │ │ │ +00052 │ │ │ │ │ │ +00054 │ │ │ │ │ │ +~Csiscone(); │ │ │ │ │ │ +00055 │ │ │ │ │ │ 00076 │ │ │ │ │ │ -Ceta_phi_range range; │ │ │ │ │ │ +int compute_jets(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ 00077 │ │ │ │ │ │ -00082 │ │ │ │ │ │ -int pass; │ │ │ │ │ │ -00083 }; │ │ │ │ │ │ -00084 │ │ │ │ │ │ -00086 bool jets_pt_less(const Cjet &j1, const Cjet &j2); │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00088 │ │ │ │ │ │ -00096 enum Esplit_merge_scale { │ │ │ │ │ │ -00097 │ │ │ │ │ │ -SM_pt, │ │ │ │ │ │ -00098 │ │ │ │ │ │ -SM_Et, │ │ │ │ │ │ -00100 │ │ │ │ │ │ -SM_mt, │ │ │ │ │ │ -00102 │ │ │ │ │ │ -SM_pttilde │ │ │ │ │ │ -00104 }; │ │ │ │ │ │ -00105 │ │ │ │ │ │ -00107 std::string split_merge_scale_name(Esplit_merge_scale sms); │ │ │ │ │ │ -00108 │ │ │ │ │ │ +int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ │ +00078 │ │ │ │ │ │ +Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -271 │ │ │ │ │ │ - │ │ │ │ │ │ - 272 │ │ │ │ │ │ + 5.44 siscone.h │ │ │ │ │ │ │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ +267 │ │ │ │ │ │ │ │ │ │ │ │ -00116 class Csplit_merge_ptcomparison{ │ │ │ │ │ │ -00117 public: │ │ │ │ │ │ +00079 │ │ │ │ │ │ +00097 │ │ │ │ │ │ +int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ +00098 │ │ │ │ │ │ +int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ │ +00099 │ │ │ │ │ │ +Esplit_merge_scale _ordering_scale=SM_pttilde); │ │ │ │ │ │ +00100 │ │ │ │ │ │ +00113 │ │ │ │ │ │ +int recompute_jets(double _f, double _ptmin = 0.0, │ │ │ │ │ │ +00114 │ │ │ │ │ │ +Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ +00115 │ │ │ │ │ │ +00117 │ │ │ │ │ │ +std::vector > protocones_list; │ │ │ │ │ │ +00118 │ │ │ │ │ │ 00119 │ │ │ │ │ │ -Csplit_merge_ptcomparison() : │ │ │ │ │ │ +// random number initialisation │ │ │ │ │ │ 00120 │ │ │ │ │ │ -particles(0), split_merge_scale(SM_pttilde){}; │ │ │ │ │ │ +static bool init_done; │ │ │ │ │ │ 00121 │ │ │ │ │ │ +00122 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00123 │ │ │ │ │ │ -std::string SM_scale_name() const { │ │ │ │ │ │ -00124 │ │ │ │ │ │ -return split_merge_scale_name(split_merge_scale);} │ │ │ │ │ │ +int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ │ +00124 #endif │ │ │ │ │ │ 00125 │ │ │ │ │ │ -00126 │ │ │ │ │ │ -std::vector * particles; │ │ │ │ │ │ -00127 │ │ │ │ │ │ -std::vector * pt; │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00130 │ │ │ │ │ │ -bool operator()(const Cjet &jet1, const Cjet &jet2) const; │ │ │ │ │ │ -00131 │ │ │ │ │ │ +00137 │ │ │ │ │ │ +static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ +00138 │ │ │ │ │ │ 00143 │ │ │ │ │ │ -void get_difference(const Cjet &j1, const Cjet &j2, Cmomentum *v, double *pt_tilde) const; │ │ │ │ │ │ +static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ 00144 │ │ │ │ │ │ -00163 │ │ │ │ │ │ -Esplit_merge_scale split_merge_scale; │ │ │ │ │ │ -00164 }; │ │ │ │ │ │ -00165 │ │ │ │ │ │ -00166 │ │ │ │ │ │ -00167 // iterator types │ │ │ │ │ │ -00169 typedef std::multiset::iterator cjet_iterator; │ │ │ │ │ │ -00170 │ │ │ │ │ │ -00172 typedef std::vector::iterator jet_iterator; │ │ │ │ │ │ -00173 │ │ │ │ │ │ +00145 private: │ │ │ │ │ │ +00146 │ │ │ │ │ │ +bool rerun_allowed; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +static std::ostream * _banner_ostr; │ │ │ │ │ │ +00148 │ │ │ │ │ │ +00150 │ │ │ │ │ │ +void _initialise_if_needed(); │ │ │ │ │ │ +00151 │ │ │ │ │ │ +00152 }; │ │ │ │ │ │ +00153 │ │ │ │ │ │ +00154 │ │ │ │ │ │ +00155 // finally, a bunch of functions to access to │ │ │ │ │ │ +00156 // basic information (package name, version) │ │ │ │ │ │ +00157 //--------------------------------------------00158 │ │ │ │ │ │ +00166 std::string siscone_package_name(); │ │ │ │ │ │ +00167 │ │ │ │ │ │ +00173 std::string siscone_version(); │ │ │ │ │ │ 00174 │ │ │ │ │ │ -00175 │ │ │ │ │ │ -00180 class Csplit_merge{ │ │ │ │ │ │ -00181 public: │ │ │ │ │ │ -00183 │ │ │ │ │ │ -Csplit_merge(); │ │ │ │ │ │ -00184 │ │ │ │ │ │ -00186 │ │ │ │ │ │ -~Csplit_merge(); │ │ │ │ │ │ -00187 │ │ │ │ │ │ -00188 │ │ │ │ │ │ -00190 │ │ │ │ │ │ -// initialisation functions // │ │ │ │ │ │ -00192 │ │ │ │ │ │ -00201 │ │ │ │ │ │ -int init(std::vector &_particles, std::vector *protocones, double R2, double │ │ │ │ │ │ -ptmin=0.0); │ │ │ │ │ │ -00202 │ │ │ │ │ │ -00208 │ │ │ │ │ │ -int init_particles(std::vector &_particles); │ │ │ │ │ │ -00209 │ │ │ │ │ │ -00213 │ │ │ │ │ │ -int init_pleft(); │ │ │ │ │ │ -00214 │ │ │ │ │ │ -00226 │ │ │ │ │ │ -inline int set_pt_weighted_splitting(bool _use_pt_weighted_splitting){ │ │ │ │ │ │ -00227 │ │ │ │ │ │ -use_pt_weighted_splitting = _use_pt_weighted_splitting; │ │ │ │ │ │ -00228 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00229 │ │ │ │ │ │ -} │ │ │ │ │ │ -00230 │ │ │ │ │ │ -00232 │ │ │ │ │ │ -// cleaning functions // │ │ │ │ │ │ -00234 │ │ │ │ │ │ -00236 │ │ │ │ │ │ -int partial_clear(); │ │ │ │ │ │ -00237 │ │ │ │ │ │ -00239 │ │ │ │ │ │ -int full_clear(); │ │ │ │ │ │ -00240 │ │ │ │ │ │ -00242 │ │ │ │ │ │ -// user-defined stable-cone ordering // │ │ │ │ │ │ -00244 │ │ │ │ │ │ -00250 │ │ │ │ │ │ -class Cuser_scale_base{ │ │ │ │ │ │ -00251 │ │ │ │ │ │ -public: │ │ │ │ │ │ -00253 │ │ │ │ │ │ -virtual ~Cuser_scale_base(){} │ │ │ │ │ │ -00254 │ │ │ │ │ │ -00259 │ │ │ │ │ │ -virtual double operator()(const Cjet & jet) const = 0; │ │ │ │ │ │ -00260 │ │ │ │ │ │ -00271 │ │ │ │ │ │ -virtual bool is_larger(const Cjet & a, const Cjet & b) const{ │ │ │ │ │ │ -00272 │ │ │ │ │ │ -return (a.sm_var2 > b.sm_var2); │ │ │ │ │ │ -00273 │ │ │ │ │ │ -} │ │ │ │ │ │ -00274 │ │ │ │ │ │ -}; │ │ │ │ │ │ -00275 │ │ │ │ │ │ -00280 │ │ │ │ │ │ -void set_user_scale(const Cuser_scale_base * user_scale_in){ │ │ │ │ │ │ -00281 │ │ │ │ │ │ -_user_scale = user_scale_in; │ │ │ │ │ │ -00282 │ │ │ │ │ │ -} │ │ │ │ │ │ -00283 │ │ │ │ │ │ -00285 │ │ │ │ │ │ -const Cuser_scale_base * user_scale() const { return _user_scale; } │ │ │ │ │ │ -00286 │ │ │ │ │ │ -00287 │ │ │ │ │ │ -00289 │ │ │ │ │ │ -// main parts of the algorithm // │ │ │ │ │ │ -00291 │ │ │ │ │ │ -00299 │ │ │ │ │ │ -int merge_collinear_and_remove_soft(); │ │ │ │ │ │ -00300 │ │ │ │ │ │ -00308 │ │ │ │ │ │ -int add_protocones(std::vector *protocones, double R2, double ptmin=0.0); │ │ │ │ │ │ -00309 │ │ │ │ │ │ -00320 │ │ │ │ │ │ -int add_hardest_protocone_to_jets(std::vector *protocones, double R2, double ptmin=0.0); │ │ │ │ │ │ -00321 │ │ │ │ │ │ -00331 │ │ │ │ │ │ -int perform(double overlap_tshold, double ptmin=0.0); │ │ │ │ │ │ -00332 │ │ │ │ │ │ -00333 │ │ │ │ │ │ -00335 │ │ │ │ │ │ -// save and debug functions // │ │ │ │ │ │ -00337 │ │ │ │ │ │ -00340 │ │ │ │ │ │ -int save_contents(FILE *flux); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.47 vicinity.h │ │ │ │ │ │ - │ │ │ │ │ │ -273 │ │ │ │ │ │ - │ │ │ │ │ │ -00341 │ │ │ │ │ │ -00343 │ │ │ │ │ │ -int show(); │ │ │ │ │ │ -00344 │ │ │ │ │ │ -00345 │ │ │ │ │ │ -// particle information │ │ │ │ │ │ -00346 │ │ │ │ │ │ -int n; │ │ │ │ │ │ -00347 │ │ │ │ │ │ -std::vector particles; │ │ │ │ │ │ -00348 │ │ │ │ │ │ -std::vector pt; │ │ │ │ │ │ -00349 │ │ │ │ │ │ -int n_left; │ │ │ │ │ │ -00350 │ │ │ │ │ │ -std::vector p_remain; │ │ │ │ │ │ -00351 │ │ │ │ │ │ -std::vector p_uncol_hard; │ │ │ │ │ │ -00352 │ │ │ │ │ │ -int n_pass; │ │ │ │ │ │ -00353 │ │ │ │ │ │ -00357 │ │ │ │ │ │ -double most_ambiguous_split; │ │ │ │ │ │ -00358 │ │ │ │ │ │ -00359 │ │ │ │ │ │ -// jets information │ │ │ │ │ │ -00360 │ │ │ │ │ │ -std::vector jets; │ │ │ │ │ │ -00361 │ │ │ │ │ │ -00362 │ │ │ │ │ │ -// working entries │ │ │ │ │ │ -00363 │ │ │ │ │ │ -int *indices; │ │ │ │ │ │ -00364 │ │ │ │ │ │ -int idx_size; │ │ │ │ │ │ -00365 │ │ │ │ │ │ -00374 │ │ │ │ │ │ -bool merge_identical_protocones; │ │ │ │ │ │ -00375 │ │ │ │ │ │ -00377 │ │ │ │ │ │ -Csplit_merge_ptcomparison ptcomparison; │ │ │ │ │ │ -00378 │ │ │ │ │ │ -00385 │ │ │ │ │ │ -double SM_var2_hardest_cut_off; │ │ │ │ │ │ -00386 │ │ │ │ │ │ -00394 │ │ │ │ │ │ -double stable_cone_soft_pt2_cutoff; │ │ │ │ │ │ -00395 │ │ │ │ │ │ -00396 private: │ │ │ │ │ │ -00404 │ │ │ │ │ │ -bool get_overlap(const Cjet &j1, const Cjet &j2, double *v); │ │ │ │ │ │ -00405 │ │ │ │ │ │ -00406 │ │ │ │ │ │ -00418 │ │ │ │ │ │ -bool split(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ -00419 │ │ │ │ │ │ -00428 │ │ │ │ │ │ -bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ -00429 │ │ │ │ │ │ -00436 │ │ │ │ │ │ -bool insert(Cjet &jet); │ │ │ │ │ │ -00437 │ │ │ │ │ │ -00444 │ │ │ │ │ │ -double get_sm_var2(Cmomentum &v, double &pt_tilde); │ │ │ │ │ │ -00445 │ │ │ │ │ │ -00446 │ │ │ │ │ │ -// jet information │ │ │ │ │ │ -00448 #ifdef SISCONE_USES_UNIQUE_PTR_AS_AUTO_PTR │ │ │ │ │ │ -00449 │ │ │ │ │ │ -std::unique_ptr > candidates; │ │ │ │ │ │ -00450 #else │ │ │ │ │ │ -00451 │ │ │ │ │ │ -std::auto_ptr > candidates; │ │ │ │ │ │ -00452 #endif │ │ │ │ │ │ -00453 │ │ │ │ │ │ -00455 │ │ │ │ │ │ -double pt_min2; │ │ │ │ │ │ -00456 │ │ │ │ │ │ -00462 │ │ │ │ │ │ -bool use_pt_weighted_splitting; │ │ │ │ │ │ -00463 │ │ │ │ │ │ -00466 │ │ │ │ │ │ -const Cuser_scale_base *_user_scale; │ │ │ │ │ │ -00467 │ │ │ │ │ │ -00468 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ -00470 │ │ │ │ │ │ -std::set cand_refs; │ │ │ │ │ │ -00471 #endif │ │ │ │ │ │ -00472 }; │ │ │ │ │ │ -00473 │ │ │ │ │ │ -00474 } │ │ │ │ │ │ -00475 │ │ │ │ │ │ -00476 │ │ │ │ │ │ -00477 #endif │ │ │ │ │ │ +00175 } │ │ │ │ │ │ +00176 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.47 │ │ │ │ │ │ +5.44 │ │ │ │ │ │ │ │ │ │ │ │ -vicinity.h │ │ │ │ │ │ +siscone.h │ │ │ │ │ │ │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: vicinity.h │ │ │ │ │ │ -00004 // Description: header file for particle vicinity (Cvicinity class) │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: siscone.h │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // Description: header file for the main SISCone class │ │ │ │ │ │ +// │ │ │ │ │ │ 00005 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ 00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +// │ │ │ │ │ │ 00007 // │ │ │ │ │ │ an adaptation to spherical coordinates │ │ │ │ │ │ +// │ │ │ │ │ │ 00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ 00009 // │ │ │ │ │ │ +// │ │ │ │ │ │ 00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ 00011 // │ │ │ │ │ │ -00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -00015 // (at your option) any later version. │ │ │ │ │ │ -00016 // │ │ │ │ │ │ -00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ // │ │ │ │ │ │ +00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ // │ │ │ │ │ │ +00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ // │ │ │ │ │ │ +00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ // │ │ │ │ │ │ +00015 // (at your option) any later version. │ │ │ │ │ │ // │ │ │ │ │ │ +00016 // │ │ │ │ │ │ // │ │ │ │ │ │ +00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ // │ │ │ │ │ │ +00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ - 274 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ // │ │ │ │ │ │ 00020 // GNU General Public License for more details. │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // │ │ │ │ │ │ // │ │ │ │ │ │ 00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00025 // │ │ │ │ │ │ // │ │ │ │ │ │ -00026 // $Revision:: 255 │ │ │ │ │ │ +00026 // $Revision:: 401 │ │ │ │ │ │ $// │ │ │ │ │ │ -00027 // $Date:: 2008-07-12 17:40:35 +0200 (Sat, 12 Jul 2008) │ │ │ │ │ │ +00027 // $Date:: 2016-05-19 16:44:37 +0200 (Thu, 19 May 2016) │ │ │ │ │ │ $// │ │ │ │ │ │ 00029 │ │ │ │ │ │ -00030 #ifndef __SPH_VICINITY_H__ │ │ │ │ │ │ -00031 #define __SPH_VICINITY_H__ │ │ │ │ │ │ +00030 #ifndef __SPH_SISCONE_H__ │ │ │ │ │ │ +00031 #define __SPH_SISCONE_H__ │ │ │ │ │ │ 00032 │ │ │ │ │ │ -00033 #include │ │ │ │ │ │ -00034 #include │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include "momentum.h" │ │ │ │ │ │ -00037 #include │ │ │ │ │ │ -00038 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ -00039 #include │ │ │ │ │ │ -00040 #endif │ │ │ │ │ │ -00041 │ │ │ │ │ │ -00042 namespace siscone_spherical{ │ │ │ │ │ │ -00043 │ │ │ │ │ │ -00044 │ │ │ │ │ │ -00052 class CSphvicinity_elm{ │ │ │ │ │ │ -00053 public: │ │ │ │ │ │ -00055 │ │ │ │ │ │ -CSphmomentum *v; │ │ │ │ │ │ +00033 #include "protocones.h" │ │ │ │ │ │ +00034 #include "split_merge.h" │ │ │ │ │ │ +00035 │ │ │ │ │ │ +00036 namespace siscone_spherical{ │ │ │ │ │ │ +00037 │ │ │ │ │ │ +00050 class CSphsiscone : public CSphstable_cones, public CSphsplit_merge{ │ │ │ │ │ │ +00051 public: │ │ │ │ │ │ +00053 │ │ │ │ │ │ +CSphsiscone(); │ │ │ │ │ │ +00054 │ │ │ │ │ │ 00056 │ │ │ │ │ │ -00058 │ │ │ │ │ │ -siscone::Cvicinity_inclusion *is_inside; │ │ │ │ │ │ -00059 │ │ │ │ │ │ -00060 │ │ │ │ │ │ -// centre variables │ │ │ │ │ │ -00061 │ │ │ │ │ │ -CSph3vector centre; │ │ │ │ │ │ -00062 │ │ │ │ │ │ -double angle; │ │ │ │ │ │ -00063 │ │ │ │ │ │ -bool side; │ │ │ │ │ │ -00064 │ │ │ │ │ │ -double cocircular_range; │ │ │ │ │ │ -00066 │ │ │ │ │ │ -00069 │ │ │ │ │ │ -std::list cocircular; │ │ │ │ │ │ -00070 }; │ │ │ │ │ │ -00071 │ │ │ │ │ │ -00073 bool ve_less(CSphvicinity_elm *ve1, CSphvicinity_elm *ve2); │ │ │ │ │ │ -00074 │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00083 class CSphvicinity{ │ │ │ │ │ │ -00084 public: │ │ │ │ │ │ -00086 │ │ │ │ │ │ -CSphvicinity(); │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00089 │ │ │ │ │ │ -CSphvicinity(std::vector &_particle_list); │ │ │ │ │ │ -00090 │ │ │ │ │ │ -00092 │ │ │ │ │ │ -~CSphvicinity(); │ │ │ │ │ │ -00093 │ │ │ │ │ │ -00098 │ │ │ │ │ │ -void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ -00099 │ │ │ │ │ │ -00105 │ │ │ │ │ │ -void build(CSphmomentum *_parent, double _VR); │ │ │ │ │ │ -00106 │ │ │ │ │ │ -00107 │ │ │ │ │ │ -// cone kinematical information │ │ │ │ │ │ -00108 │ │ │ │ │ │ -CSphmomentum *parent; │ │ │ │ │ │ -00109 │ │ │ │ │ │ -double VR; │ │ │ │ │ │ -00110 │ │ │ │ │ │ -double VR2; │ │ │ │ │ │ -00111 │ │ │ │ │ │ -double cosVR; │ │ │ │ │ │ -00112 │ │ │ │ │ │ -double R; │ │ │ │ │ │ -00113 │ │ │ │ │ │ -double R2; │ │ │ │ │ │ -00114 │ │ │ │ │ │ -double tan2R; │ │ │ │ │ │ -00115 │ │ │ │ │ │ -double D2_R; │ │ │ │ │ │ -00116 │ │ │ │ │ │ -double inv_R_EPS_COCIRC; │ │ │ │ │ │ -00117 │ │ │ │ │ │ -double inv_R_2EPS_COCIRC; │ │ │ │ │ │ -00118 │ │ │ │ │ │ -00119 │ │ │ │ │ │ -// particle list information │ │ │ │ │ │ -00120 │ │ │ │ │ │ -int n_part; │ │ │ │ │ │ -00121 │ │ │ │ │ │ -std::vector plist; │ │ │ │ │ │ -00123 │ │ │ │ │ │ -std::vector pincluded; │ │ │ │ │ │ -00124 │ │ │ │ │ │ -CSphvicinity_elm *ve_list; │ │ │ │ │ │ -00125 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ -00126 │ │ │ │ │ │ -siscone::Cquadtree *quadtree; │ │ │ │ │ │ -00127 #endif │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00129 │ │ │ │ │ │ -// vicinity information │ │ │ │ │ │ -00130 │ │ │ │ │ │ -std::vector vicinity; │ │ │ │ │ │ -00131 │ │ │ │ │ │ -unsigned int vicinity_size; │ │ │ │ │ │ -00132 │ │ │ │ │ │ -00133 protected: │ │ │ │ │ │ -00139 │ │ │ │ │ │ -void append_to_vicinity(CSphmomentum *v); │ │ │ │ │ │ -00140 │ │ │ │ │ │ -00141 │ │ │ │ │ │ -// internal variables │ │ │ │ │ │ -00142 │ │ │ │ │ │ -CSph3vector parent_centre; │ │ │ │ │ │ -00143 │ │ │ │ │ │ -CSph3vector angular_dir1; │ │ │ │ │ │ -00144 │ │ │ │ │ │ -CSph3vector angular_dir2; │ │ │ │ │ │ +~CSphsiscone(); │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.48 vicinity.h │ │ │ │ │ │ - │ │ │ │ │ │ -00145 }; │ │ │ │ │ │ -00146 │ │ │ │ │ │ -00147 } │ │ │ │ │ │ -00148 │ │ │ │ │ │ -00149 #endif │ │ │ │ │ │ +// │ │ │ │ │ │ │ │ │ │ │ │ -5.48 │ │ │ │ │ │ + 268 │ │ │ │ │ │ │ │ │ │ │ │ -vicinity.h │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: vicinity.h │ │ │ │ │ │ -// │ │ │ │ │ │ -00004 // Description: header file for particle vicinity (Cvicinity class) │ │ │ │ │ │ -// │ │ │ │ │ │ -00005 // This file is part of the SISCone project. │ │ │ │ │ │ -// │ │ │ │ │ │ -00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ -// │ │ │ │ │ │ -00007 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -// │ │ │ │ │ │ -00009 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ -// │ │ │ │ │ │ -00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ -// │ │ │ │ │ │ -00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ -// │ │ │ │ │ │ -00013 // (at your option) any later version. │ │ │ │ │ │ -// │ │ │ │ │ │ -00014 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ -// │ │ │ │ │ │ -00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ -// │ │ │ │ │ │ -00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ -// │ │ │ │ │ │ -00018 // GNU General Public License for more details. │ │ │ │ │ │ -// │ │ │ │ │ │ -00019 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ -// │ │ │ │ │ │ -00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ -// │ │ │ │ │ │ -00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ -00023 // │ │ │ │ │ │ -// │ │ │ │ │ │ -00024 // $Revision:: 123 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00025 // $Date:: 2007-03-01 02:52:16 +0100 (Thu, 01 Mar 2007) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 │ │ │ │ │ │ -00028 #ifndef __VICINITY_H__ │ │ │ │ │ │ -00029 #define __VICINITY_H__ │ │ │ │ │ │ -00030 │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ -00032 #include │ │ │ │ │ │ -00033 #include "momentum.h" │ │ │ │ │ │ -00034 #include "defines.h" │ │ │ │ │ │ -00035 #include "quadtree.h" │ │ │ │ │ │ -00036 │ │ │ │ │ │ -00037 namespace siscone{ │ │ │ │ │ │ -00038 │ │ │ │ │ │ -00039 │ │ │ │ │ │ -00040 │ │ │ │ │ │ -00046 class Cvicinity_inclusion { │ │ │ │ │ │ -00047 public: │ │ │ │ │ │ -00049 │ │ │ │ │ │ -Cvicinity_inclusion() : cone(false), cocirc(false) {} │ │ │ │ │ │ -00050 │ │ │ │ │ │ -00051 │ │ │ │ │ │ -bool cone; │ │ │ │ │ │ -00052 │ │ │ │ │ │ -bool cocirc; │ │ │ │ │ │ -00053 }; │ │ │ │ │ │ -00054 │ │ │ │ │ │ -00055 │ │ │ │ │ │ -00063 class Cvicinity_elm{ │ │ │ │ │ │ -00064 public: │ │ │ │ │ │ -00066 │ │ │ │ │ │ -Cmomentum *v; │ │ │ │ │ │ -00067 │ │ │ │ │ │ -00069 │ │ │ │ │ │ -Cvicinity_inclusion *is_inside; │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 │ │ │ │ │ │ -// centre variables │ │ │ │ │ │ -00072 │ │ │ │ │ │ -double eta; │ │ │ │ │ │ -00073 │ │ │ │ │ │ -double phi; │ │ │ │ │ │ -00074 │ │ │ │ │ │ -double angle; │ │ │ │ │ │ -00075 │ │ │ │ │ │ -bool side; │ │ │ │ │ │ +00057 │ │ │ │ │ │ 00076 │ │ │ │ │ │ -double cocircular_range; │ │ │ │ │ │ +int compute_jets(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ +00077 │ │ │ │ │ │ +int _n_pass_max=0, double _Emin=0.0, │ │ │ │ │ │ 00078 │ │ │ │ │ │ -00081 │ │ │ │ │ │ -std::list cocircular; │ │ │ │ │ │ -00082 }; │ │ │ │ │ │ -00083 │ │ │ │ │ │ -00085 bool ve_less(Cvicinity_elm *ve1, Cvicinity_elm *ve2); │ │ │ │ │ │ -00086 │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00095 class Cvicinity{ │ │ │ │ │ │ -00096 public: │ │ │ │ │ │ -00098 │ │ │ │ │ │ -Cvicinity(); │ │ │ │ │ │ -00099 │ │ │ │ │ │ -00101 │ │ │ │ │ │ -Cvicinity(std::vector &_particle_list); │ │ │ │ │ │ -00102 │ │ │ │ │ │ -00104 │ │ │ │ │ │ -~Cvicinity(); │ │ │ │ │ │ -00105 │ │ │ │ │ │ +Esplit_merge_scale _split_merge_scale=SM_Etilde); │ │ │ │ │ │ +00079 │ │ │ │ │ │ +00094 │ │ │ │ │ │ +int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ +00095 │ │ │ │ │ │ +int _n_pass_max=0, double _Emin=0.0, │ │ │ │ │ │ +00096 │ │ │ │ │ │ +Esplit_merge_scale _ordering_scale=SM_Etilde); │ │ │ │ │ │ +00097 │ │ │ │ │ │ 00110 │ │ │ │ │ │ -void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -275 │ │ │ │ │ │ - │ │ │ │ │ │ - 276 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +int recompute_jets(double _f, double _Emin = 0.0, │ │ │ │ │ │ 00111 │ │ │ │ │ │ +Esplit_merge_scale _split_merge_scale=SM_Etilde); │ │ │ │ │ │ +00112 │ │ │ │ │ │ +00114 │ │ │ │ │ │ +std::vector > protocones_list; │ │ │ │ │ │ +00115 │ │ │ │ │ │ +00116 │ │ │ │ │ │ +// random number initialisation │ │ │ │ │ │ 00117 │ │ │ │ │ │ -void build(Cmomentum *_parent, double _VR); │ │ │ │ │ │ +static bool init_done; │ │ │ │ │ │ 00118 │ │ │ │ │ │ -00119 │ │ │ │ │ │ -// cone kinematical information │ │ │ │ │ │ +00119 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00120 │ │ │ │ │ │ -Cmomentum *parent; │ │ │ │ │ │ -00121 │ │ │ │ │ │ -double VR; │ │ │ │ │ │ +int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ │ +00121 #endif │ │ │ │ │ │ 00122 │ │ │ │ │ │ -double VR2; │ │ │ │ │ │ -00123 │ │ │ │ │ │ -double R; │ │ │ │ │ │ -00124 │ │ │ │ │ │ -double R2; │ │ │ │ │ │ -00125 │ │ │ │ │ │ -double inv_R_EPS_COCIRC; │ │ │ │ │ │ -00126 │ │ │ │ │ │ -double inv_R_2EPS_COCIRC; │ │ │ │ │ │ -00127 │ │ │ │ │ │ -00128 │ │ │ │ │ │ -// particle list information │ │ │ │ │ │ -00129 │ │ │ │ │ │ -int n_part; │ │ │ │ │ │ -00130 │ │ │ │ │ │ -std::vector plist; │ │ │ │ │ │ -00131 │ │ │ │ │ │ -std::vector pincluded; │ │ │ │ │ │ -00132 │ │ │ │ │ │ -Cvicinity_elm *ve_list; │ │ │ │ │ │ -00133 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00134 │ │ │ │ │ │ -Cquadtree *quadtree; │ │ │ │ │ │ -00135 #endif │ │ │ │ │ │ -00136 │ │ │ │ │ │ -00137 │ │ │ │ │ │ -// vicinity information │ │ │ │ │ │ -00138 │ │ │ │ │ │ -std::vector vicinity; │ │ │ │ │ │ -00139 │ │ │ │ │ │ -unsigned int vicinity_size; │ │ │ │ │ │ +static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ +00135 │ │ │ │ │ │ 00140 │ │ │ │ │ │ -00141 protected: │ │ │ │ │ │ +static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ +00141 │ │ │ │ │ │ +00142 private: │ │ │ │ │ │ +00143 │ │ │ │ │ │ +bool rerun_allowed; │ │ │ │ │ │ +00144 │ │ │ │ │ │ +static std::ostream * _banner_ostr; │ │ │ │ │ │ +00145 │ │ │ │ │ │ 00147 │ │ │ │ │ │ -void append_to_vicinity(Cmomentum *v); │ │ │ │ │ │ +void _initialise_if_needed(); │ │ │ │ │ │ 00148 │ │ │ │ │ │ -00149 │ │ │ │ │ │ -// internal variables │ │ │ │ │ │ +00149 }; │ │ │ │ │ │ 00150 │ │ │ │ │ │ -double pcx; │ │ │ │ │ │ 00151 │ │ │ │ │ │ -double pcy; │ │ │ │ │ │ -00152 }; │ │ │ │ │ │ -00153 │ │ │ │ │ │ -00154 } │ │ │ │ │ │ -00155 │ │ │ │ │ │ -00156 #endif │ │ │ │ │ │ +00152 // finally, a bunch of functions to access to │ │ │ │ │ │ +00153 // basic information (package name, version) │ │ │ │ │ │ +00154 //--------------------------------------------00155 │ │ │ │ │ │ +00163 std::string siscone_package_name(); │ │ │ │ │ │ +00164 │ │ │ │ │ │ +00170 std::string siscone_version(); │ │ │ │ │ │ +00171 │ │ │ │ │ │ +00172 } │ │ │ │ │ │ +00173 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.49 │ │ │ │ │ │ +5.45 │ │ │ │ │ │ │ │ │ │ │ │ split_merge.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: split_merge.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: source file for splitting/merging (contains the CJet class) // │ │ │ │ │ │ @@ -25937,29 +24844,29 @@ │ │ │ │ │ │ 00032 #include │ │ │ │ │ │ // for max │ │ │ │ │ │ 00033 #include │ │ │ │ │ │ 00034 #include │ │ │ │ │ │ 00035 #include │ │ │ │ │ │ 00036 #include │ │ │ │ │ │ 00037 #include │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00038 │ │ │ │ │ │ 00039 namespace siscone_spherical{ │ │ │ │ │ │ 00040 │ │ │ │ │ │ 00041 using namespace std; │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 /******************************************************** │ │ │ │ │ │ 00044 * class CSphjet implementation │ │ │ │ │ │ * │ │ │ │ │ │ 00045 * real Jet information. │ │ │ │ │ │ * │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.49 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00046 * This class contains information for one single jet. * │ │ │ │ │ │ 00047 * That is, first, its momentum carrying information │ │ │ │ │ │ * │ │ │ │ │ │ 00048 * about its centre and pT, and second, its particle │ │ │ │ │ │ * │ │ │ │ │ │ 00049 * contents │ │ │ │ │ │ * │ │ │ │ │ │ @@ -26059,14 +24966,23 @@ │ │ │ │ │ │ double qdiff; │ │ │ │ │ │ 00122 │ │ │ │ │ │ CSphmomentum sum = jet1.v ; │ │ │ │ │ │ 00123 │ │ │ │ │ │ sum += jet2.v; │ │ │ │ │ │ 00124 │ │ │ │ │ │ double E_tilde_sum = jet1.E_tilde + jet2.E_tilde; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +269 │ │ │ │ │ │ + │ │ │ │ │ │ + 270 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00125 │ │ │ │ │ │ 00126 │ │ │ │ │ │ // depending on the choice of ordering variable, set the result │ │ │ │ │ │ 00127 │ │ │ │ │ │ switch (split_merge_scale){ │ │ │ │ │ │ 00128 │ │ │ │ │ │ case SM_Etilde: │ │ │ │ │ │ @@ -26074,23 +24990,14 @@ │ │ │ │ │ │ qdiff = E_tilde_sum*E_tilde_difference; │ │ │ │ │ │ 00130 │ │ │ │ │ │ break; │ │ │ │ │ │ 00131 │ │ │ │ │ │ case SM_E: │ │ │ │ │ │ 00132 │ │ │ │ │ │ qdiff = sum.E*difference.E; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -277 │ │ │ │ │ │ - │ │ │ │ │ │ - 278 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00133 │ │ │ │ │ │ break; │ │ │ │ │ │ 00134 │ │ │ │ │ │ default: │ │ │ │ │ │ 00135 │ │ │ │ │ │ throw siscone::Csiscone_error("Unsupported split-merge scale choice: " │ │ │ │ │ │ 00136 │ │ │ │ │ │ @@ -26222,14 +25129,19 @@ │ │ │ │ │ │ const CSphmomentum &p = (*particles)[j1.contents[i1]]; │ │ │ │ │ │ 00210 │ │ │ │ │ │ (*v) += p; │ │ │ │ │ │ 00211 │ │ │ │ │ │ (*E_tilde) += p.E*norm2_cross_product3(p,jet1_axis)/(*particles_norm2)[j1.contents[i1]]; │ │ │ │ │ │ 00212 │ │ │ │ │ │ i1++; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00213 │ │ │ │ │ │ } │ │ │ │ │ │ 00214 │ │ │ │ │ │ while (i2 < j2.n) { │ │ │ │ │ │ 00215 │ │ │ │ │ │ const CSphmomentum &p = (*particles)[j2.contents[i2]]; │ │ │ │ │ │ 00216 │ │ │ │ │ │ @@ -26237,19 +25149,14 @@ │ │ │ │ │ │ 00217 │ │ │ │ │ │ (*E_tilde) -= p.E*norm2_cross_product3(p,jet2_axis)/(*particles_norm2)[j2.contents[i2]]; │ │ │ │ │ │ 00218 │ │ │ │ │ │ i2++; │ │ │ │ │ │ 00219 │ │ │ │ │ │ } │ │ │ │ │ │ 00220 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.49 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00221 │ │ │ │ │ │ // add the direct energy contribution to Etilde │ │ │ │ │ │ 00222 │ │ │ │ │ │ (*E_tilde) += v->E; │ │ │ │ │ │ 00223 } │ │ │ │ │ │ 00224 │ │ │ │ │ │ 00225 │ │ │ │ │ │ @@ -26354,35 +25261,35 @@ │ │ │ │ │ │ 00295 │ │ │ │ │ │ // ensure that ptcomparison points to our set of particles (though params not correct) │ │ │ │ │ │ 00296 │ │ │ │ │ │ ptcomparison.particles = &particles; │ │ │ │ │ │ 00297 │ │ │ │ │ │ ptcomparison.particles_norm2 = &particles_norm2; │ │ │ │ │ │ 00298 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +271 │ │ │ │ │ │ + │ │ │ │ │ │ + 272 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00299 │ │ │ │ │ │ // set up the list of particles left. │ │ │ │ │ │ 00300 │ │ │ │ │ │ init_pleft(); │ │ │ │ │ │ 00301 │ │ │ │ │ │ 00302 │ │ │ │ │ │ indices = new int[n]; │ │ │ │ │ │ 00303 │ │ │ │ │ │ 00304 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00305 } │ │ │ │ │ │ 00306 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -279 │ │ │ │ │ │ - │ │ │ │ │ │ - 280 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00307 │ │ │ │ │ │ 00308 // build initial list of remaining particles │ │ │ │ │ │ 00309 //-----------------------------------------00310 int CSphsplit_merge::init_pleft(){ │ │ │ │ │ │ 00311 │ │ │ │ │ │ // at this level, we only rule out particles with │ │ │ │ │ │ 00312 │ │ │ │ │ │ // infinite rapidity │ │ │ │ │ │ @@ -26505,35 +25412,36 @@ │ │ │ │ │ │ 00379 │ │ │ │ │ │ 00380 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00381 } │ │ │ │ │ │ 00382 │ │ │ │ │ │ 00383 │ │ │ │ │ │ 00384 // full clearance │ │ │ │ │ │ -00385 //---------------00386 int CSphsplit_merge::full_clear(){ │ │ │ │ │ │ +00385 //---------------- │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +273 │ │ │ │ │ │ + │ │ │ │ │ │ +00386 int CSphsplit_merge::full_clear(){ │ │ │ │ │ │ 00387 │ │ │ │ │ │ partial_clear(); │ │ │ │ │ │ 00388 │ │ │ │ │ │ 00389 │ │ │ │ │ │ // clear previously allocated memory │ │ │ │ │ │ 00390 │ │ │ │ │ │ if (indices != NULL){ │ │ │ │ │ │ 00391 │ │ │ │ │ │ delete[] indices; │ │ │ │ │ │ 00392 │ │ │ │ │ │ } │ │ │ │ │ │ 00393 │ │ │ │ │ │ particles.clear(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.49 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -281 │ │ │ │ │ │ - │ │ │ │ │ │ 00394 │ │ │ │ │ │ 00395 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00396 } │ │ │ │ │ │ 00397 │ │ │ │ │ │ 00398 │ │ │ │ │ │ 00399 // build the list ’p_uncol_hard’ from p_remain by clustering collinear particles │ │ │ │ │ │ @@ -26656,35 +25564,35 @@ │ │ │ │ │ │ CSphjet jet; │ │ │ │ │ │ 00468 │ │ │ │ │ │ 00469 │ │ │ │ │ │ if (protocones->size()==0) │ │ │ │ │ │ 00470 │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00471 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 274 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00472 │ │ │ │ │ │ E_min = Emin; │ │ │ │ │ │ 00473 │ │ │ │ │ │ double R = sqrt(R2); │ │ │ │ │ │ 00474 │ │ │ │ │ │ tan2R = tan(R); │ │ │ │ │ │ 00475 │ │ │ │ │ │ tan2R *= tan2R; │ │ │ │ │ │ 00476 │ │ │ │ │ │ 00477 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00478 │ │ │ │ │ │ cout « "particle list: "; │ │ │ │ │ │ 00479 │ │ │ │ │ │ for (int i2=0;i2is_larger(jet_candidate, jet) │ │ │ │ │ │ 00647 │ │ │ │ │ │ : ptcomparison(jet_candidate, jet))){ │ │ │ │ │ │ 00648 │ │ │ │ │ │ @@ -26986,21 +25901,14 @@ │ │ │ │ │ │ 00649 │ │ │ │ │ │ found_jet = true; │ │ │ │ │ │ 00650 │ │ │ │ │ │ } │ │ │ │ │ │ 00651 │ │ │ │ │ │ } │ │ │ │ │ │ 00652 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 284 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00653 │ │ │ │ │ │ // make sure at least one of the jets has passed the selection │ │ │ │ │ │ 00654 │ │ │ │ │ │ if (!found_jet) return 1; │ │ │ │ │ │ 00655 │ │ │ │ │ │ 00656 │ │ │ │ │ │ // add the jet to the list of jets │ │ │ │ │ │ @@ -27124,33 +26032,33 @@ │ │ │ │ │ │ 00728 │ │ │ │ │ │ message « " (legal values are 0size()>0){ │ │ │ │ │ │ 00742 │ │ │ │ │ │ // browse for the first jet │ │ │ │ │ │ 00743 │ │ │ │ │ │ @@ -27284,34 +26192,34 @@ │ │ │ │ │ │ 00815 │ │ │ │ │ │ } │ │ │ │ │ │ 00816 │ │ │ │ │ │ } while (candidates->size()>0); │ │ │ │ │ │ 00817 │ │ │ │ │ │ 00818 │ │ │ │ │ │ // sort jets by Energy │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +277 │ │ │ │ │ │ + │ │ │ │ │ │ + 278 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00819 │ │ │ │ │ │ sort(jets.begin(), jets.end(), jets_E_less); │ │ │ │ │ │ 00820 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00821 │ │ │ │ │ │ show(); │ │ │ │ │ │ 00822 #endif │ │ │ │ │ │ 00823 │ │ │ │ │ │ 00824 │ │ │ │ │ │ return jets.size(); │ │ │ │ │ │ 00825 } │ │ │ │ │ │ 00826 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -285 │ │ │ │ │ │ - │ │ │ │ │ │ - 286 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00827 │ │ │ │ │ │ 00828 │ │ │ │ │ │ 00829 // save the event on disk │ │ │ │ │ │ 00830 // - flux │ │ │ │ │ │ stream used to save jet contents │ │ │ │ │ │ 00831 //-------------------------------------------00832 int CSphsplit_merge::save_contents(FILE *flux){ │ │ │ │ │ │ 00833 │ │ │ │ │ │ @@ -27438,30 +26346,29 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 00902 │ │ │ │ │ │ 00903 │ │ │ │ │ │ fprintf(stdout, "\n"); │ │ │ │ │ │ 00904 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00905 } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00906 │ │ │ │ │ │ 00907 │ │ │ │ │ │ 00908 // get the overlap between 2 jets │ │ │ │ │ │ 00909 // - j1 │ │ │ │ │ │ first jet │ │ │ │ │ │ 00910 // - j2 │ │ │ │ │ │ second jet │ │ │ │ │ │ 00911 // - overlap2 returned overlap^2 (determined by the choice of SM variable) │ │ │ │ │ │ 00912 // return true if overlapping, false if disjoint │ │ │ │ │ │ -00913 //--------------------------------------------------------------------- │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.49 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00914 bool CSphsplit_merge::get_overlap(const CSphjet &j1, const CSphjet &j2, double *overlap2){ │ │ │ │ │ │ +00913 //--------------------------------------------------------------------00914 bool CSphsplit_merge::get_overlap(const CSphjet &j1, const CSphjet &j2, double *overlap2){ │ │ │ │ │ │ 00915 │ │ │ │ │ │ // check if ranges overlap │ │ │ │ │ │ 00916 │ │ │ │ │ │ if (!is_range_overlap(j1.range,j2.range)) │ │ │ │ │ │ 00917 │ │ │ │ │ │ return false; │ │ │ │ │ │ 00918 │ │ │ │ │ │ @@ -27589,14 +26496,23 @@ │ │ │ │ │ │ 00990 │ │ │ │ │ │ i1=i2=0; │ │ │ │ │ │ 00991 │ │ │ │ │ │ jet2.v = jet1.v = CSphmomentum(); │ │ │ │ │ │ 00992 │ │ │ │ │ │ 00993 │ │ │ │ │ │ // compute centroids │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +279 │ │ │ │ │ │ + │ │ │ │ │ │ + 280 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00994 │ │ │ │ │ │ // When use_E_weighted_splitting is activated, the │ │ │ │ │ │ 00995 │ │ │ │ │ │ // "geometrical" distance is weighted by the inverse │ │ │ │ │ │ 00996 │ │ │ │ │ │ // of the E of the protojet │ │ │ │ │ │ 00997 │ │ │ │ │ │ @@ -27604,23 +26520,14 @@ │ │ │ │ │ │ 00998 │ │ │ │ │ │ E1_weight = (use_E_weighted_splitting) ? 1.0/j1.v.E/j1.v.E : 1.0; │ │ │ │ │ │ 00999 │ │ │ │ │ │ E2_weight = (use_E_weighted_splitting) ? 1.0/j2.v.E/j2.v.E : 1.0; │ │ │ │ │ │ 01000 │ │ │ │ │ │ 01001 │ │ │ │ │ │ // compute jet splitting │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -287 │ │ │ │ │ │ - │ │ │ │ │ │ - 288 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 01002 │ │ │ │ │ │ do{ │ │ │ │ │ │ 01003 │ │ │ │ │ │ if (j1.contents[i1]erase(it_j1); │ │ │ │ │ │ 01085 │ │ │ │ │ │ candidates->erase(it_j2); │ │ │ │ │ │ 01086 │ │ │ │ │ │ 01087 │ │ │ │ │ │ // reinsert new ones │ │ │ │ │ │ 01088 │ │ │ │ │ │ insert(jet1); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.49 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 01089 │ │ │ │ │ │ insert(jet2); │ │ │ │ │ │ 01090 │ │ │ │ │ │ 01091 │ │ │ │ │ │ return true; │ │ │ │ │ │ 01092 } │ │ │ │ │ │ 01093 │ │ │ │ │ │ @@ -27907,35 +26814,35 @@ │ │ │ │ │ │ + ptcomparison.SM_scale_name()); │ │ │ │ │ │ 01176 │ │ │ │ │ │ } │ │ │ │ │ │ 01177 │ │ │ │ │ │ 01178 │ │ │ │ │ │ //return 0.0; │ │ │ │ │ │ 01179 } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +281 │ │ │ │ │ │ + │ │ │ │ │ │ + 282 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 01180 │ │ │ │ │ │ 01181 │ │ │ │ │ │ 01182 │ │ │ │ │ │ 01184 void CSphsplit_merge::compute_Etilde(CSphjet &jet){ │ │ │ │ │ │ 01185 │ │ │ │ │ │ jet.v.build_norm(); │ │ │ │ │ │ 01186 │ │ │ │ │ │ jet.E_tilde=0.0; │ │ │ │ │ │ 01187 │ │ │ │ │ │ CSph3vector jet_axis = jet.v; │ │ │ │ │ │ 01188 │ │ │ │ │ │ //if (jet.v._norm==0){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -289 │ │ │ │ │ │ - │ │ │ │ │ │ - 290 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 01189 │ │ │ │ │ │ // jet_axis = CSph3vector(0.0,0.0,0.0); │ │ │ │ │ │ 01190 │ │ │ │ │ │ //} else { │ │ │ │ │ │ 01191 │ │ │ │ │ │ jet_axis/=jet.v.E; │ │ │ │ │ │ 01192 │ │ │ │ │ │ @@ -27952,15 +26859,15 @@ │ │ │ │ │ │ jet.E_tilde+=p.E*(1.0+norm2_cross_product3(p,jet_axis)/particles_norm2[*cont_it]); │ │ │ │ │ │ 01198 │ │ │ │ │ │ } │ │ │ │ │ │ 01199 } │ │ │ │ │ │ 01200 │ │ │ │ │ │ 01201 } │ │ │ │ │ │ │ │ │ │ │ │ -5.50 │ │ │ │ │ │ +5.46 │ │ │ │ │ │ │ │ │ │ │ │ split_merge.cpp │ │ │ │ │ │ │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: split_merge.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: source file for splitting/merging (contains the CJet class) // │ │ │ │ │ │ @@ -28047,25 +26954,25 @@ │ │ │ │ │ │ 00056 │ │ │ │ │ │ pass = CJET_INEXISTENT_PASS; // initialised to a value that should │ │ │ │ │ │ 00057 │ │ │ │ │ │ // notappear in the end (after clustering) │ │ │ │ │ │ 00058 } │ │ │ │ │ │ 00059 │ │ │ │ │ │ 00060 // default dtor │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00061 //-------------00062 Cjet::~Cjet(){ │ │ │ │ │ │ 00063 │ │ │ │ │ │ 00064 } │ │ │ │ │ │ 00065 │ │ │ │ │ │ 00066 // ordering of jets in pt (e.g. used in final jets ordering) │ │ │ │ │ │ 00067 //----------------------------------------------------------00068 bool jets_pt_less(const Cjet &j1, const Cjet &j2){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.50 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00069 │ │ │ │ │ │ return j1.v.perp2() > j2.v.perp2(); │ │ │ │ │ │ 00070 } │ │ │ │ │ │ 00071 │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 /******************************************************** │ │ │ │ │ │ 00074 * Csplit_merge_ptcomparison implementation │ │ │ │ │ │ @@ -28186,33 +27093,33 @@ │ │ │ │ │ │ + SM_scale_name()); │ │ │ │ │ │ 00145 │ │ │ │ │ │ } │ │ │ │ │ │ 00146 │ │ │ │ │ │ res = qdiff > 0; │ │ │ │ │ │ 00147 │ │ │ │ │ │ } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +283 │ │ │ │ │ │ + │ │ │ │ │ │ + 284 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00148 #endif // EPSILON_SPLITMERGE │ │ │ │ │ │ 00149 │ │ │ │ │ │ 00150 │ │ │ │ │ │ return res; │ │ │ │ │ │ 00151 } │ │ │ │ │ │ 00152 │ │ │ │ │ │ 00153 │ │ │ │ │ │ 00156 std::string split_merge_scale_name(Esplit_merge_scale sms) { │ │ │ │ │ │ 00157 │ │ │ │ │ │ switch(sms) { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -291 │ │ │ │ │ │ - │ │ │ │ │ │ - 292 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00158 │ │ │ │ │ │ case SM_pt: │ │ │ │ │ │ 00159 │ │ │ │ │ │ return "pt (IR unsafe)"; │ │ │ │ │ │ 00160 │ │ │ │ │ │ case SM_Et: │ │ │ │ │ │ 00161 │ │ │ │ │ │ @@ -28337,35 +27244,35 @@ │ │ │ │ │ │ 00231 #endif │ │ │ │ │ │ 00232 #endif │ │ │ │ │ │ 00233 │ │ │ │ │ │ _user_scale = NULL; │ │ │ │ │ │ 00234 │ │ │ │ │ │ indices = NULL; │ │ │ │ │ │ 00235 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +285 │ │ │ │ │ │ + │ │ │ │ │ │ 00236 │ │ │ │ │ │ // ensure that ptcomparison points to our set of particles (though params not correct) │ │ │ │ │ │ 00237 │ │ │ │ │ │ ptcomparison.particles = &particles; │ │ │ │ │ │ 00238 │ │ │ │ │ │ ptcomparison.pt = &pt; │ │ │ │ │ │ 00239 │ │ │ │ │ │ candidates.reset(new multiset(ptcomparison)); │ │ │ │ │ │ 00240 │ │ │ │ │ │ 00241 │ │ │ │ │ │ // no hardest cut (col-unsafe) │ │ │ │ │ │ 00242 │ │ │ │ │ │ SM_var2_hardest_cut_off = -numeric_limits::max(); │ │ │ │ │ │ 00243 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.50 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -293 │ │ │ │ │ │ - │ │ │ │ │ │ 00244 │ │ │ │ │ │ // no pt cutoff for the particles to put in p_uncol_hard │ │ │ │ │ │ 00245 │ │ │ │ │ │ stable_cone_soft_pt2_cutoff = -1.0; │ │ │ │ │ │ 00246 │ │ │ │ │ │ 00247 │ │ │ │ │ │ // no pt-weighted splitting │ │ │ │ │ │ @@ -28476,14 +27383,21 @@ │ │ │ │ │ │ p_remain.clear(); │ │ │ │ │ │ 00319 │ │ │ │ │ │ for (i=0;i p_sorted; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +287 │ │ │ │ │ │ + │ │ │ │ │ │ 00409 │ │ │ │ │ │ bool collinear; │ │ │ │ │ │ 00410 │ │ │ │ │ │ double dphi; │ │ │ │ │ │ 00411 │ │ │ │ │ │ 00412 │ │ │ │ │ │ p_uncol_hard.clear(); │ │ │ │ │ │ 00413 │ │ │ │ │ │ 00414 │ │ │ │ │ │ // we first sort the particles according to their rapidity │ │ │ │ │ │ 00415 │ │ │ │ │ │ for (i=0;ipz)!=v->E){ │ │ │ │ │ │ 00495 │ │ │ │ │ │ dx = eta - v->eta; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 288 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00496 │ │ │ │ │ │ dy = fabs(phi - v->phi); │ │ │ │ │ │ 00497 │ │ │ │ │ │ if (dy>M_PI) │ │ │ │ │ │ 00498 │ │ │ │ │ │ dy -= twopi; │ │ │ │ │ │ 00499 │ │ │ │ │ │ @@ -28800,21 +27714,14 @@ │ │ │ │ │ │ jet.contents.push_back(v->parent_index); │ │ │ │ │ │ 00501 │ │ │ │ │ │ jet.v+= *v; │ │ │ │ │ │ 00502 │ │ │ │ │ │ jet.pt_tilde+= pt[v->parent_index]; │ │ │ │ │ │ 00503 │ │ │ │ │ │ v->index=0; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 296 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00504 │ │ │ │ │ │ } │ │ │ │ │ │ 00505 │ │ │ │ │ │ } │ │ │ │ │ │ 00506 │ │ │ │ │ │ jet.n=jet.contents.size(); │ │ │ │ │ │ 00507 │ │ │ │ │ │ @@ -28934,33 +27841,33 @@ │ │ │ │ │ │ 00578 │ │ │ │ │ │ double R; │ │ │ │ │ │ 00579 │ │ │ │ │ │ Cjet jet, jet_candidate; │ │ │ │ │ │ 00580 │ │ │ │ │ │ bool found_jet = false; │ │ │ │ │ │ 00581 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00582 │ │ │ │ │ │ if (protocones->size()==0) │ │ │ │ │ │ 00583 │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00584 │ │ │ │ │ │ 00585 │ │ │ │ │ │ pt_min2 = ptmin*ptmin; │ │ │ │ │ │ 00586 │ │ │ │ │ │ R = sqrt(R2); │ │ │ │ │ │ 00587 │ │ │ │ │ │ 00588 │ │ │ │ │ │ // browse protocones │ │ │ │ │ │ 00589 │ │ │ │ │ │ // for each of them, build the list of particles in them │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.50 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00590 │ │ │ │ │ │ for (vector::iterator p_it = protocones->begin();p_it != protocones->end();p_it++){ │ │ │ │ │ │ 00591 │ │ │ │ │ │ // initialise variables │ │ │ │ │ │ 00592 │ │ │ │ │ │ c = &(*p_it); │ │ │ │ │ │ 00593 │ │ │ │ │ │ @@ -29098,14 +28005,23 @@ │ │ │ │ │ │ 00665 │ │ │ │ │ │ 00666 │ │ │ │ │ │ // update the list of what particles are left │ │ │ │ │ │ 00667 │ │ │ │ │ │ int p_remain_index = 0; │ │ │ │ │ │ 00668 │ │ │ │ │ │ int contents_index = 0; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +289 │ │ │ │ │ │ + │ │ │ │ │ │ + 290 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00669 │ │ │ │ │ │ //sort(next_jet.contents.begin(),next_jet.contents.end()); │ │ │ │ │ │ 00670 │ │ │ │ │ │ for (int index=0;indexend()){ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00756 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00757 │ │ │ │ │ │ show(); │ │ │ │ │ │ 00758 #endif │ │ │ │ │ │ 00759 │ │ │ │ │ │ // check overlapping │ │ │ │ │ │ 00760 │ │ │ │ │ │ if (get_overlap(*j1, *j2, &overlap2)){ │ │ │ │ │ │ 00761 │ │ │ │ │ │ // check if overlapping energy passes threshold │ │ │ │ │ │ 00762 │ │ │ │ │ │ // Note that this depends on the ordering variable │ │ │ │ │ │ 00763 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.50 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00764 │ │ │ │ │ │ cout « "overlap between cdt 1 and cdt " « j2_relindex+1 « " with overlap " │ │ │ │ │ │ 00765 │ │ │ │ │ │ « sqrt(overlap2/j2->sm_var2) « endl«endl; │ │ │ │ │ │ 00766 #endif │ │ │ │ │ │ 00767 │ │ │ │ │ │ if (overlap2sm_var2){ │ │ │ │ │ │ @@ -29410,14 +28317,23 @@ │ │ │ │ │ │ 00840 │ │ │ │ │ │ j1->v.eta, j1->v.phi, j1->v.perp(), j1->n); │ │ │ │ │ │ 00841 │ │ │ │ │ │ } │ │ │ │ │ │ 00842 │ │ │ │ │ │ 00843 │ │ │ │ │ │ fprintf(flux, "# jet contents\n"); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +291 │ │ │ │ │ │ + │ │ │ │ │ │ + 292 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00844 │ │ │ │ │ │ fprintf(flux, "# columns are: eta, phi, pt, particle index and jet number\n"); │ │ │ │ │ │ 00845 │ │ │ │ │ │ for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00846 │ │ │ │ │ │ j1 = &(*it_j); │ │ │ │ │ │ 00847 │ │ │ │ │ │ @@ -29426,23 +28342,14 @@ │ │ │ │ │ │ fprintf(flux, "%f\t%f\t%e\t%d\t%d\n", │ │ │ │ │ │ 00849 │ │ │ │ │ │ particles[j1->contents[i2]].eta, particles[j1->contents[i2]].phi, │ │ │ │ │ │ 00850 │ │ │ │ │ │ particles[j1->contents[i2]].perp(), j1->contents[i2], i1); │ │ │ │ │ │ 00851 │ │ │ │ │ │ } │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -299 │ │ │ │ │ │ - │ │ │ │ │ │ - 300 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00852 │ │ │ │ │ │ 00853 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00854 } │ │ │ │ │ │ 00855 │ │ │ │ │ │ 00856 │ │ │ │ │ │ 00857 // show current jets/candidate status │ │ │ │ │ │ @@ -29569,14 +28476,19 @@ │ │ │ │ │ │ 00927 │ │ │ │ │ │ } while ((i1eta; │ │ │ │ │ │ 01021 │ │ │ │ │ │ dy1 = fabs(phi1 - v->phi); │ │ │ │ │ │ 01022 │ │ │ │ │ │ @@ -29742,23 +28658,14 @@ │ │ │ │ │ │ 01023 │ │ │ │ │ │ dy1 -= twopi; │ │ │ │ │ │ 01024 │ │ │ │ │ │ 01025 │ │ │ │ │ │ // distance w.r.t. centroid 2 │ │ │ │ │ │ 01026 │ │ │ │ │ │ dx2 = eta2 - v->eta; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -301 │ │ │ │ │ │ - │ │ │ │ │ │ - 302 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 01027 │ │ │ │ │ │ dy2 = fabs(phi2 - v->phi); │ │ │ │ │ │ 01028 │ │ │ │ │ │ if (dy2>M_PI) │ │ │ │ │ │ 01029 │ │ │ │ │ │ dy2 -= twopi; │ │ │ │ │ │ 01030 │ │ │ │ │ │ @@ -29889,14 +28796,21 @@ │ │ │ │ │ │ 01099 // merge the two given jet. │ │ │ │ │ │ 01100 // during this procedure, the jets j1 & j2 are replaced │ │ │ │ │ │ 01101 // by 1 single jets containing both of them. │ │ │ │ │ │ 01102 // - it_j1 iterator of the first jet in ’candidates’ │ │ │ │ │ │ 01103 // - it_j2 iterator of the second jet in ’candidates’ │ │ │ │ │ │ 01104 // return true on success, false on error │ │ │ │ │ │ 01106 bool Csplit_merge::merge(cjet_iterator &it_j1, cjet_iterator &it_j2){ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.47 split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ +295 │ │ │ │ │ │ + │ │ │ │ │ │ 01107 │ │ │ │ │ │ Cjet jet; │ │ │ │ │ │ 01108 │ │ │ │ │ │ int i; │ │ │ │ │ │ 01109 │ │ │ │ │ │ 01110 │ │ │ │ │ │ // build new jet │ │ │ │ │ │ @@ -29904,21 +28818,14 @@ │ │ │ │ │ │ // note: particles within j1 & j2 have already been stored in indices │ │ │ │ │ │ 01112 │ │ │ │ │ │ for (i=0;i │ │ │ │ │ │ +00034 #include │ │ │ │ │ │ +00035 #include "geom_2d.h" │ │ │ │ │ │ +00036 #include "momentum.h" │ │ │ │ │ │ +00037 #include │ │ │ │ │ │ +00038 #include │ │ │ │ │ │ +00039 #include │ │ │ │ │ │ +00040 #include │ │ │ │ │ │ +00041 #include │ │ │ │ │ │ +00042 │ │ │ │ │ │ +00043 namespace siscone_spherical{ │ │ │ │ │ │ +00044 │ │ │ │ │ │ +00045 const int CJET_INEXISTENT_PASS = -2; │ │ │ │ │ │ +00046 │ │ │ │ │ │ +00056 class CSphjet{ │ │ │ │ │ │ +00057 public: │ │ │ │ │ │ +00059 │ │ │ │ │ │ +CSphjet(); │ │ │ │ │ │ +00060 │ │ │ │ │ │ +00062 │ │ │ │ │ │ +~CSphjet(); │ │ │ │ │ │ +00063 │ │ │ │ │ │ +00064 │ │ │ │ │ │ +CSphmomentum v; │ │ │ │ │ │ +00065 │ │ │ │ │ │ +double E_tilde; │ │ │ │ │ │ +00066 │ │ │ │ │ │ +int n; │ │ │ │ │ │ +00067 │ │ │ │ │ │ +std::vector contents; │ │ │ │ │ │ +00068 │ │ │ │ │ │ +00080 │ │ │ │ │ │ +double sm_var2; │ │ │ │ │ │ +00081 │ │ │ │ │ │ +00083 │ │ │ │ │ │ +CSphtheta_phi_range range; │ │ │ │ │ │ +00084 │ │ │ │ │ │ +00089 │ │ │ │ │ │ +int pass; │ │ │ │ │ │ +00090 }; │ │ │ │ │ │ +00091 │ │ │ │ │ │ +00094 │ │ │ │ │ │ +00096 bool jets_E_less(const CSphjet &j1, const CSphjet &j2); │ │ │ │ │ │ +00097 │ │ │ │ │ │ +00098 │ │ │ │ │ │ +00106 enum Esplit_merge_scale { │ │ │ │ │ │ +00107 │ │ │ │ │ │ +SM_E, │ │ │ │ │ │ +00108 │ │ │ │ │ │ +SM_Etilde │ │ │ │ │ │ +00109 }; │ │ │ │ │ │ +00110 │ │ │ │ │ │ +00112 std::string split_merge_scale_name(Esplit_merge_scale sms); │ │ │ │ │ │ +00113 │ │ │ │ │ │ +00119 class CSphsplit_merge_ptcomparison{ │ │ │ │ │ │ +00120 public: │ │ │ │ │ │ +00122 │ │ │ │ │ │ +CSphsplit_merge_ptcomparison() : │ │ │ │ │ │ +00123 │ │ │ │ │ │ +particles(0), split_merge_scale(SM_Etilde){}; │ │ │ │ │ │ +00124 │ │ │ │ │ │ +00126 │ │ │ │ │ │ +std::string SM_scale_name() const { │ │ │ │ │ │ +00127 │ │ │ │ │ │ +return split_merge_scale_name(split_merge_scale);} │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00129 │ │ │ │ │ │ +std::vector * particles; │ │ │ │ │ │ +00130 │ │ │ │ │ │ +std::vector * particles_norm2; │ │ │ │ │ │ +00131 │ │ │ │ │ │ +00133 │ │ │ │ │ │ +bool operator()(const CSphjet &jet1, const CSphjet &jet2) const; │ │ │ │ │ │ +00134 │ │ │ │ │ │ +00146 │ │ │ │ │ │ +void get_difference(const CSphjet &j1, const CSphjet &j2, CSphmomentum *v, double *E_tilde) const; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +00158 │ │ │ │ │ │ +Esplit_merge_scale split_merge_scale; │ │ │ │ │ │ +00159 }; │ │ │ │ │ │ +00160 │ │ │ │ │ │ +00161 │ │ │ │ │ │ +00162 // iterator types │ │ │ │ │ │ +00164 typedef std::multiset::iterator │ │ │ │ │ │ +cjet_iterator; │ │ │ │ │ │ +00165 │ │ │ │ │ │ +00167 typedef std::vector::iterator jet_iterator; │ │ │ │ │ │ +00168 │ │ │ │ │ │ │ │ │ │ │ │ - 304 │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.47 split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ +297 │ │ │ │ │ │ + │ │ │ │ │ │ +00169 │ │ │ │ │ │ +00170 │ │ │ │ │ │ +00175 class CSphsplit_merge{ │ │ │ │ │ │ +00176 public: │ │ │ │ │ │ +00178 │ │ │ │ │ │ +CSphsplit_merge(); │ │ │ │ │ │ +00179 │ │ │ │ │ │ +00181 │ │ │ │ │ │ +~CSphsplit_merge(); │ │ │ │ │ │ +00182 │ │ │ │ │ │ +00183 │ │ │ │ │ │ +00185 │ │ │ │ │ │ +// initialisation functions // │ │ │ │ │ │ +00187 │ │ │ │ │ │ +00196 │ │ │ │ │ │ +int init(std::vector &_particles, std::vector *protocones, double R2, │ │ │ │ │ │ +double Emin=0.0); │ │ │ │ │ │ +00197 │ │ │ │ │ │ +00203 │ │ │ │ │ │ +int init_particles(std::vector &_particles); │ │ │ │ │ │ +00204 │ │ │ │ │ │ +00208 │ │ │ │ │ │ +int init_pleft(); │ │ │ │ │ │ +00209 │ │ │ │ │ │ +00221 │ │ │ │ │ │ +inline int set_E_weighted_splitting(bool _use_E_weighted_splitting){ │ │ │ │ │ │ +00222 │ │ │ │ │ │ +use_E_weighted_splitting = _use_E_weighted_splitting; │ │ │ │ │ │ +00223 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00224 │ │ │ │ │ │ +} │ │ │ │ │ │ +00225 │ │ │ │ │ │ +00227 │ │ │ │ │ │ +// cleaning functions // │ │ │ │ │ │ +00229 │ │ │ │ │ │ +00231 │ │ │ │ │ │ +int partial_clear(); │ │ │ │ │ │ +00232 │ │ │ │ │ │ +00234 │ │ │ │ │ │ +int full_clear(); │ │ │ │ │ │ +00235 │ │ │ │ │ │ +00237 │ │ │ │ │ │ +// user-defined stable-cone ordering // │ │ │ │ │ │ +00239 │ │ │ │ │ │ +00245 │ │ │ │ │ │ +class Cuser_scale_base{ │ │ │ │ │ │ +00246 │ │ │ │ │ │ +public: │ │ │ │ │ │ +00248 │ │ │ │ │ │ +virtual ~Cuser_scale_base(){} │ │ │ │ │ │ +00249 │ │ │ │ │ │ +00254 │ │ │ │ │ │ +virtual double operator()(const CSphjet & jet) const = 0; │ │ │ │ │ │ +00255 │ │ │ │ │ │ +00266 │ │ │ │ │ │ +virtual bool is_larger(const CSphjet & a, const CSphjet & b) const{ │ │ │ │ │ │ +00267 │ │ │ │ │ │ +return (a.sm_var2 > b.sm_var2); │ │ │ │ │ │ +00268 │ │ │ │ │ │ +} │ │ │ │ │ │ +00269 │ │ │ │ │ │ +}; │ │ │ │ │ │ +00270 │ │ │ │ │ │ +00275 │ │ │ │ │ │ +void set_user_scale(const Cuser_scale_base * user_scale_in){ │ │ │ │ │ │ +00276 │ │ │ │ │ │ +_user_scale = user_scale_in; │ │ │ │ │ │ +00277 │ │ │ │ │ │ +} │ │ │ │ │ │ +00278 │ │ │ │ │ │ +00280 │ │ │ │ │ │ +const Cuser_scale_base * user_scale() const { return _user_scale; } │ │ │ │ │ │ +00281 │ │ │ │ │ │ +00282 │ │ │ │ │ │ +00284 │ │ │ │ │ │ +// main parts of the algorithm // │ │ │ │ │ │ +00286 │ │ │ │ │ │ +00296 │ │ │ │ │ │ +int merge_collinear_and_remove_soft(); │ │ │ │ │ │ +00297 │ │ │ │ │ │ +00305 │ │ │ │ │ │ +int add_protocones(std::vector *protocones, double R2, double Emin=0.0); │ │ │ │ │ │ +00306 │ │ │ │ │ │ +00317 │ │ │ │ │ │ +int add_hardest_protocone_to_jets(std::vector *protocones, double R2, double │ │ │ │ │ │ +Emin=0.0); │ │ │ │ │ │ +00318 │ │ │ │ │ │ +00328 │ │ │ │ │ │ +int perform(double overlap_tshold, double Emin=0.0); │ │ │ │ │ │ +00329 │ │ │ │ │ │ +00330 │ │ │ │ │ │ +00332 │ │ │ │ │ │ +// save and debug functions // │ │ │ │ │ │ +00334 │ │ │ │ │ │ +00337 │ │ │ │ │ │ +int save_contents(FILE *flux); │ │ │ │ │ │ +00338 │ │ │ │ │ │ +00340 │ │ │ │ │ │ +int show(); │ │ │ │ │ │ +00341 │ │ │ │ │ │ +00342 │ │ │ │ │ │ +// particle information │ │ │ │ │ │ +00343 │ │ │ │ │ │ +int n; │ │ │ │ │ │ +00344 │ │ │ │ │ │ +std::vector particles; │ │ │ │ │ │ +00345 │ │ │ │ │ │ +std::vector particles_norm2; │ │ │ │ │ │ +00346 │ │ │ │ │ │ +int n_left; │ │ │ │ │ │ +00347 │ │ │ │ │ │ +std::vector p_remain; │ │ │ │ │ │ +00348 │ │ │ │ │ │ +std::vector p_uncol_hard; │ │ │ │ │ │ +00349 │ │ │ │ │ │ +int n_pass; │ │ │ │ │ │ +00350 │ │ │ │ │ │ +00354 │ │ │ │ │ │ +double most_ambiguous_split; │ │ │ │ │ │ +00355 │ │ │ │ │ │ +00356 │ │ │ │ │ │ +// jets information │ │ │ │ │ │ +00357 │ │ │ │ │ │ +std::vector jets; │ │ │ │ │ │ +00358 │ │ │ │ │ │ +00359 │ │ │ │ │ │ +// working entries │ │ │ │ │ │ +00360 │ │ │ │ │ │ +int *indices; │ │ │ │ │ │ +00361 │ │ │ │ │ │ +int idx_size; │ │ │ │ │ │ +00362 │ │ │ │ │ │ +00371 │ │ │ │ │ │ +bool merge_identical_protocones; │ │ │ │ │ │ +00372 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 298 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00374 │ │ │ │ │ │ +CSphsplit_merge_ptcomparison ptcomparison; │ │ │ │ │ │ +00375 │ │ │ │ │ │ +00382 │ │ │ │ │ │ +double SM_var2_hardest_cut_off; │ │ │ │ │ │ +00383 │ │ │ │ │ │ +00391 │ │ │ │ │ │ +double stable_cone_soft_E2_cutoff; │ │ │ │ │ │ +00392 │ │ │ │ │ │ +00393 private: │ │ │ │ │ │ +00401 │ │ │ │ │ │ +bool get_overlap(const CSphjet &j1, const CSphjet &j2, double *v); │ │ │ │ │ │ +00402 │ │ │ │ │ │ +00403 │ │ │ │ │ │ +00415 │ │ │ │ │ │ +bool split(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +00416 │ │ │ │ │ │ +00425 │ │ │ │ │ │ +bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +00426 │ │ │ │ │ │ +00433 │ │ │ │ │ │ +bool insert(CSphjet &jet); │ │ │ │ │ │ +00434 │ │ │ │ │ │ +00441 │ │ │ │ │ │ +double get_sm_var2(CSphmomentum &v, double &E_tilde); │ │ │ │ │ │ +00442 │ │ │ │ │ │ +00444 │ │ │ │ │ │ +void compute_Etilde(CSphjet &j); │ │ │ │ │ │ +00445 │ │ │ │ │ │ +00446 │ │ │ │ │ │ +// jet information │ │ │ │ │ │ +00448 #ifdef SISCONE_USES_UNIQUE_PTR_AS_AUTO_PTR │ │ │ │ │ │ +00449 │ │ │ │ │ │ +std::unique_ptr > candidates; │ │ │ │ │ │ +00450 #else │ │ │ │ │ │ +00451 │ │ │ │ │ │ +std::auto_ptr > candidates; │ │ │ │ │ │ +00452 #endif │ │ │ │ │ │ +00453 │ │ │ │ │ │ +00455 │ │ │ │ │ │ +double E_min; │ │ │ │ │ │ +00456 │ │ │ │ │ │ +00462 │ │ │ │ │ │ +bool use_E_weighted_splitting; │ │ │ │ │ │ +00463 │ │ │ │ │ │ +00466 │ │ │ │ │ │ +const Cuser_scale_base *_user_scale; │ │ │ │ │ │ +00467 │ │ │ │ │ │ +00468 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ +00470 │ │ │ │ │ │ +std::set cand_refs; │ │ │ │ │ │ +00471 #endif │ │ │ │ │ │ +00472 }; │ │ │ │ │ │ +00473 │ │ │ │ │ │ +00474 } │ │ │ │ │ │ +00475 │ │ │ │ │ │ +00476 │ │ │ │ │ │ +00477 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.48 │ │ │ │ │ │ + │ │ │ │ │ │ +split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: split_merge.h │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // Description: header file for splitting/merging (contains the CJet class) // │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00023 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // $Revision:: 405 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00025 // $Date:: 2016-05-23 20:15:02 +0200 (Mon, 23 May 2016) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 │ │ │ │ │ │ +00028 #ifndef __SPLIT_MERGE_H__ │ │ │ │ │ │ +00029 #define __SPLIT_MERGE_H__ │ │ │ │ │ │ +00030 │ │ │ │ │ │ +00031 #include │ │ │ │ │ │ +00032 #include "defines.h" │ │ │ │ │ │ +00033 #include "geom_2d.h" │ │ │ │ │ │ +00034 #include "momentum.h" │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include │ │ │ │ │ │ +00037 #include │ │ │ │ │ │ +00038 #include │ │ │ │ │ │ +00039 #include │ │ │ │ │ │ +00040 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.48 split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ +299 │ │ │ │ │ │ + │ │ │ │ │ │ +00041 namespace siscone{ │ │ │ │ │ │ +00042 │ │ │ │ │ │ +00043 const int CJET_INEXISTENT_PASS = -2; │ │ │ │ │ │ +00044 │ │ │ │ │ │ +00054 class Cjet{ │ │ │ │ │ │ +00055 public: │ │ │ │ │ │ +00057 │ │ │ │ │ │ +Cjet(); │ │ │ │ │ │ +00058 │ │ │ │ │ │ +00060 │ │ │ │ │ │ +~Cjet(); │ │ │ │ │ │ +00061 │ │ │ │ │ │ +00062 │ │ │ │ │ │ +Cmomentum v; │ │ │ │ │ │ +00063 │ │ │ │ │ │ +double pt_tilde; │ │ │ │ │ │ +00064 │ │ │ │ │ │ +int n; │ │ │ │ │ │ +00065 │ │ │ │ │ │ +std::vector contents; │ │ │ │ │ │ +00066 │ │ │ │ │ │ +00073 │ │ │ │ │ │ +double sm_var2; │ │ │ │ │ │ +00074 │ │ │ │ │ │ +00076 │ │ │ │ │ │ +Ceta_phi_range range; │ │ │ │ │ │ +00077 │ │ │ │ │ │ +00082 │ │ │ │ │ │ +int pass; │ │ │ │ │ │ +00083 }; │ │ │ │ │ │ +00084 │ │ │ │ │ │ +00086 bool jets_pt_less(const Cjet &j1, const Cjet &j2); │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00088 │ │ │ │ │ │ +00096 enum Esplit_merge_scale { │ │ │ │ │ │ +00097 │ │ │ │ │ │ +SM_pt, │ │ │ │ │ │ +00098 │ │ │ │ │ │ +SM_Et, │ │ │ │ │ │ +00100 │ │ │ │ │ │ +SM_mt, │ │ │ │ │ │ +00102 │ │ │ │ │ │ +SM_pttilde │ │ │ │ │ │ +00104 }; │ │ │ │ │ │ +00105 │ │ │ │ │ │ +00107 std::string split_merge_scale_name(Esplit_merge_scale sms); │ │ │ │ │ │ +00108 │ │ │ │ │ │ +00116 class Csplit_merge_ptcomparison{ │ │ │ │ │ │ +00117 public: │ │ │ │ │ │ +00119 │ │ │ │ │ │ +Csplit_merge_ptcomparison() : │ │ │ │ │ │ +00120 │ │ │ │ │ │ +particles(0), split_merge_scale(SM_pttilde){}; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +00123 │ │ │ │ │ │ +std::string SM_scale_name() const { │ │ │ │ │ │ +00124 │ │ │ │ │ │ +return split_merge_scale_name(split_merge_scale);} │ │ │ │ │ │ +00125 │ │ │ │ │ │ +00126 │ │ │ │ │ │ +std::vector * particles; │ │ │ │ │ │ +00127 │ │ │ │ │ │ +std::vector * pt; │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00130 │ │ │ │ │ │ +bool operator()(const Cjet &jet1, const Cjet &jet2) const; │ │ │ │ │ │ +00131 │ │ │ │ │ │ +00143 │ │ │ │ │ │ +void get_difference(const Cjet &j1, const Cjet &j2, Cmomentum *v, double *pt_tilde) const; │ │ │ │ │ │ +00144 │ │ │ │ │ │ +00163 │ │ │ │ │ │ +Esplit_merge_scale split_merge_scale; │ │ │ │ │ │ +00164 }; │ │ │ │ │ │ +00165 │ │ │ │ │ │ +00166 │ │ │ │ │ │ +00167 // iterator types │ │ │ │ │ │ +00169 typedef std::multiset::iterator cjet_iterator; │ │ │ │ │ │ +00170 │ │ │ │ │ │ +00172 typedef std::vector::iterator jet_iterator; │ │ │ │ │ │ +00173 │ │ │ │ │ │ +00174 │ │ │ │ │ │ +00175 │ │ │ │ │ │ +00180 class Csplit_merge{ │ │ │ │ │ │ +00181 public: │ │ │ │ │ │ +00183 │ │ │ │ │ │ +Csplit_merge(); │ │ │ │ │ │ +00184 │ │ │ │ │ │ +00186 │ │ │ │ │ │ +~Csplit_merge(); │ │ │ │ │ │ +00187 │ │ │ │ │ │ +00188 │ │ │ │ │ │ +00190 │ │ │ │ │ │ +// initialisation functions // │ │ │ │ │ │ +00192 │ │ │ │ │ │ +00201 │ │ │ │ │ │ +int init(std::vector &_particles, std::vector *protocones, double R2, double │ │ │ │ │ │ +ptmin=0.0); │ │ │ │ │ │ +00202 │ │ │ │ │ │ +00208 │ │ │ │ │ │ +int init_particles(std::vector &_particles); │ │ │ │ │ │ +00209 │ │ │ │ │ │ +00213 │ │ │ │ │ │ +int init_pleft(); │ │ │ │ │ │ +00214 │ │ │ │ │ │ +00226 │ │ │ │ │ │ +inline int set_pt_weighted_splitting(bool _use_pt_weighted_splitting){ │ │ │ │ │ │ +00227 │ │ │ │ │ │ +use_pt_weighted_splitting = _use_pt_weighted_splitting; │ │ │ │ │ │ +00228 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00229 │ │ │ │ │ │ +} │ │ │ │ │ │ +00230 │ │ │ │ │ │ +00232 │ │ │ │ │ │ +// cleaning functions // │ │ │ │ │ │ +00234 │ │ │ │ │ │ +00236 │ │ │ │ │ │ +int partial_clear(); │ │ │ │ │ │ +00237 │ │ │ │ │ │ +00239 │ │ │ │ │ │ +int full_clear(); │ │ │ │ │ │ +00240 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 300 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ +00242 │ │ │ │ │ │ +// user-defined stable-cone ordering // │ │ │ │ │ │ +00244 │ │ │ │ │ │ +00250 │ │ │ │ │ │ +class Cuser_scale_base{ │ │ │ │ │ │ +00251 │ │ │ │ │ │ +public: │ │ │ │ │ │ +00253 │ │ │ │ │ │ +virtual ~Cuser_scale_base(){} │ │ │ │ │ │ +00254 │ │ │ │ │ │ +00259 │ │ │ │ │ │ +virtual double operator()(const Cjet & jet) const = 0; │ │ │ │ │ │ +00260 │ │ │ │ │ │ +00271 │ │ │ │ │ │ +virtual bool is_larger(const Cjet & a, const Cjet & b) const{ │ │ │ │ │ │ +00272 │ │ │ │ │ │ +return (a.sm_var2 > b.sm_var2); │ │ │ │ │ │ +00273 │ │ │ │ │ │ +} │ │ │ │ │ │ +00274 │ │ │ │ │ │ +}; │ │ │ │ │ │ +00275 │ │ │ │ │ │ +00280 │ │ │ │ │ │ +void set_user_scale(const Cuser_scale_base * user_scale_in){ │ │ │ │ │ │ +00281 │ │ │ │ │ │ +_user_scale = user_scale_in; │ │ │ │ │ │ +00282 │ │ │ │ │ │ +} │ │ │ │ │ │ +00283 │ │ │ │ │ │ +00285 │ │ │ │ │ │ +const Cuser_scale_base * user_scale() const { return _user_scale; } │ │ │ │ │ │ +00286 │ │ │ │ │ │ +00287 │ │ │ │ │ │ +00289 │ │ │ │ │ │ +// main parts of the algorithm // │ │ │ │ │ │ +00291 │ │ │ │ │ │ +00299 │ │ │ │ │ │ +int merge_collinear_and_remove_soft(); │ │ │ │ │ │ +00300 │ │ │ │ │ │ +00308 │ │ │ │ │ │ +int add_protocones(std::vector *protocones, double R2, double ptmin=0.0); │ │ │ │ │ │ +00309 │ │ │ │ │ │ +00320 │ │ │ │ │ │ +int add_hardest_protocone_to_jets(std::vector *protocones, double R2, double ptmin=0.0); │ │ │ │ │ │ +00321 │ │ │ │ │ │ +00331 │ │ │ │ │ │ +int perform(double overlap_tshold, double ptmin=0.0); │ │ │ │ │ │ +00332 │ │ │ │ │ │ +00333 │ │ │ │ │ │ +00335 │ │ │ │ │ │ +// save and debug functions // │ │ │ │ │ │ +00337 │ │ │ │ │ │ +00340 │ │ │ │ │ │ +int save_contents(FILE *flux); │ │ │ │ │ │ +00341 │ │ │ │ │ │ +00343 │ │ │ │ │ │ +int show(); │ │ │ │ │ │ +00344 │ │ │ │ │ │ +00345 │ │ │ │ │ │ +// particle information │ │ │ │ │ │ +00346 │ │ │ │ │ │ +int n; │ │ │ │ │ │ +00347 │ │ │ │ │ │ +std::vector particles; │ │ │ │ │ │ +00348 │ │ │ │ │ │ +std::vector pt; │ │ │ │ │ │ +00349 │ │ │ │ │ │ +int n_left; │ │ │ │ │ │ +00350 │ │ │ │ │ │ +std::vector p_remain; │ │ │ │ │ │ +00351 │ │ │ │ │ │ +std::vector p_uncol_hard; │ │ │ │ │ │ +00352 │ │ │ │ │ │ +int n_pass; │ │ │ │ │ │ +00353 │ │ │ │ │ │ +00357 │ │ │ │ │ │ +double most_ambiguous_split; │ │ │ │ │ │ +00358 │ │ │ │ │ │ +00359 │ │ │ │ │ │ +// jets information │ │ │ │ │ │ +00360 │ │ │ │ │ │ +std::vector jets; │ │ │ │ │ │ +00361 │ │ │ │ │ │ +00362 │ │ │ │ │ │ +// working entries │ │ │ │ │ │ +00363 │ │ │ │ │ │ +int *indices; │ │ │ │ │ │ +00364 │ │ │ │ │ │ +int idx_size; │ │ │ │ │ │ +00365 │ │ │ │ │ │ +00374 │ │ │ │ │ │ +bool merge_identical_protocones; │ │ │ │ │ │ +00375 │ │ │ │ │ │ +00377 │ │ │ │ │ │ +Csplit_merge_ptcomparison ptcomparison; │ │ │ │ │ │ +00378 │ │ │ │ │ │ +00385 │ │ │ │ │ │ +double SM_var2_hardest_cut_off; │ │ │ │ │ │ +00386 │ │ │ │ │ │ +00394 │ │ │ │ │ │ +double stable_cone_soft_pt2_cutoff; │ │ │ │ │ │ +00395 │ │ │ │ │ │ +00396 private: │ │ │ │ │ │ +00404 │ │ │ │ │ │ +bool get_overlap(const Cjet &j1, const Cjet &j2, double *v); │ │ │ │ │ │ +00405 │ │ │ │ │ │ +00406 │ │ │ │ │ │ +00418 │ │ │ │ │ │ +bool split(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +00419 │ │ │ │ │ │ +00428 │ │ │ │ │ │ +bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +00429 │ │ │ │ │ │ +00436 │ │ │ │ │ │ +bool insert(Cjet &jet); │ │ │ │ │ │ +00437 │ │ │ │ │ │ +00444 │ │ │ │ │ │ +double get_sm_var2(Cmomentum &v, double &pt_tilde); │ │ │ │ │ │ +00445 │ │ │ │ │ │ +00446 │ │ │ │ │ │ +// jet information │ │ │ │ │ │ +00448 #ifdef SISCONE_USES_UNIQUE_PTR_AS_AUTO_PTR │ │ │ │ │ │ +00449 │ │ │ │ │ │ +std::unique_ptr > candidates; │ │ │ │ │ │ +00450 #else │ │ │ │ │ │ +00451 │ │ │ │ │ │ +std::auto_ptr > candidates; │ │ │ │ │ │ +00452 #endif │ │ │ │ │ │ +00453 │ │ │ │ │ │ +00455 │ │ │ │ │ │ +double pt_min2; │ │ │ │ │ │ +00456 │ │ │ │ │ │ +00462 │ │ │ │ │ │ +bool use_pt_weighted_splitting; │ │ │ │ │ │ +00463 │ │ │ │ │ │ +00466 │ │ │ │ │ │ +const Cuser_scale_base *_user_scale; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.49 vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +301 │ │ │ │ │ │ + │ │ │ │ │ │ +00467 │ │ │ │ │ │ +00468 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ +00470 │ │ │ │ │ │ +std::set cand_refs; │ │ │ │ │ │ +00471 #endif │ │ │ │ │ │ +00472 }; │ │ │ │ │ │ +00473 │ │ │ │ │ │ +00474 } │ │ │ │ │ │ +00475 │ │ │ │ │ │ +00476 │ │ │ │ │ │ +00477 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.49 │ │ │ │ │ │ + │ │ │ │ │ │ +vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00001 │ │ │ │ │ │ +00002 // File: vicinity.cpp │ │ │ │ │ │ +// │ │ │ │ │ │ +00003 // Description: source file for particle vicinity (Cvicinity class) │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // │ │ │ │ │ │ +an adaptation to spherical coordinates │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +00010 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00011 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ 00020 // │ │ │ │ │ │ // │ │ │ │ │ │ 00021 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ // │ │ │ │ │ │ 00022 // along with this program; if not, write to the Free Software │ │ │ │ │ │ // │ │ │ │ │ │ 00023 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ @@ -30133,14 +29748,23 @@ │ │ │ │ │ │ quadtree = NULL; │ │ │ │ │ │ 00068 #endif │ │ │ │ │ │ 00069 │ │ │ │ │ │ 00070 │ │ │ │ │ │ parent = NULL; │ │ │ │ │ │ 00071 │ │ │ │ │ │ VR2 = VR = 0.0; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 302 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 } │ │ │ │ │ │ 00074 │ │ │ │ │ │ 00075 // constructor with initialisation │ │ │ │ │ │ 00076 //--------------------------------00077 CSphvicinity::CSphvicinity(vector &_particle_list){ │ │ │ │ │ │ 00078 │ │ │ │ │ │ parent = NULL; │ │ │ │ │ │ @@ -30179,19 +29803,14 @@ │ │ │ │ │ │ 00103 * - n │ │ │ │ │ │ number of particles in the list │ │ │ │ │ │ 00104 ************************************************************/ │ │ │ │ │ │ 00105 void CSphvicinity::set_particle_list(vector &_particle_list){ │ │ │ │ │ │ 00106 │ │ │ │ │ │ int i,j; │ │ │ │ │ │ 00107 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.51 vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00108 │ │ │ │ │ │ double eta_max=0.0; │ │ │ │ │ │ 00109 #endif │ │ │ │ │ │ 00110 │ │ │ │ │ │ 00111 │ │ │ │ │ │ // if the particle list is not empty, destroy it ! │ │ │ │ │ │ 00112 │ │ │ │ │ │ @@ -30273,14 +29892,19 @@ │ │ │ │ │ │ eta_max+=0.1; │ │ │ │ │ │ 00155 │ │ │ │ │ │ quadtree = new siscone::Cquadtree(0.0, 0.0, eta_max, M_PI); │ │ │ │ │ │ 00156 #endif │ │ │ │ │ │ 00157 │ │ │ │ │ │ 00158 │ │ │ │ │ │ // append particle to the vicinity_elm list │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.49 vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00159 │ │ │ │ │ │ j = 0; │ │ │ │ │ │ 00160 │ │ │ │ │ │ for (i=0;iadd(&plist[i]); │ │ │ │ │ │ @@ -30333,23 +29957,14 @@ │ │ │ │ │ │ D2_R = 2.0*(1-cos(R)); │ │ │ │ │ │ 00192 │ │ │ │ │ │ //tmp = sqrt(D2_R); │ │ │ │ │ │ 00193 │ │ │ │ │ │ inv_R_EPS_COCIRC = 1.0 / R / EPSILON_COCIRCULAR; │ │ │ │ │ │ 00194 │ │ │ │ │ │ inv_R_2EPS_COCIRC = 0.5 / R / EPSILON_COCIRCULAR; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -305 │ │ │ │ │ │ - │ │ │ │ │ │ - 306 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00195 │ │ │ │ │ │ 00196 │ │ │ │ │ │ // clear vicinity │ │ │ │ │ │ 00197 │ │ │ │ │ │ vicinity.clear(); │ │ │ │ │ │ 00198 │ │ │ │ │ │ 00199 │ │ │ │ │ │ @@ -30423,62 +30038,78 @@ │ │ │ │ │ │ 00243 │ │ │ │ │ │ CSph3vector vnormal = *v; │ │ │ │ │ │ 00244 │ │ │ │ │ │ vnormal/=v->_norm; │ │ │ │ │ │ 00245 │ │ │ │ │ │ dot/=v->_norm; │ │ │ │ │ │ 00246 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +303 │ │ │ │ │ │ + │ │ │ │ │ │ + 304 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00247 │ │ │ │ │ │ -// really check if the distance is less than VR │ │ │ │ │ │ 00248 │ │ │ │ │ │ -if (dot>cosVR){ │ │ │ │ │ │ 00249 │ │ │ │ │ │ -CSph3vector cross = cross_product3(parent_centre,vnormal); │ │ │ │ │ │ 00250 │ │ │ │ │ │ 00251 │ │ │ │ │ │ -// for the centres │ │ │ │ │ │ 00252 │ │ │ │ │ │ -CSph3vector median = (parent_centre+vnormal); │ │ │ │ │ │ 00253 │ │ │ │ │ │ -double amplT = sqrt((tan2R*(1+dot)+(dot-1))*(1+dot)); │ │ │ │ │ │ 00254 │ │ │ │ │ │ -CSph3vector transverse = amplT*cross/cross._norm; │ │ │ │ │ │ 00255 │ │ │ │ │ │ 00256 │ │ │ │ │ │ -// first angle (+) │ │ │ │ │ │ 00257 │ │ │ │ │ │ -ve_list[i].centre = median + transverse; │ │ │ │ │ │ 00258 │ │ │ │ │ │ -ve_list[i].centre.build_norm(); │ │ │ │ │ │ 00259 │ │ │ │ │ │ -ve_list[i].centre/=ve_list[i].centre._norm; │ │ │ │ │ │ 00260 │ │ │ │ │ │ -CSph3vector diff = ve_list[i].centre - parent_centre; │ │ │ │ │ │ 00261 │ │ │ │ │ │ -//ve_list[i].angle = atan2(dot_product3(angular_dir2, diff),dot_product3(angular_dir1, diff)); │ │ │ │ │ │ 00262 │ │ │ │ │ │ -ve_list[i].angle = sort_angle(dot_product3(angular_dir2, diff),dot_product3(angular_dir1, diff)); │ │ │ │ │ │ 00263 │ │ │ │ │ │ -ve_list[i].side = true; │ │ │ │ │ │ 00264 │ │ │ │ │ │ -ve_list[i].cocircular.clear(); │ │ │ │ │ │ 00265 │ │ │ │ │ │ -vicinity.push_back(&(ve_list[i])); │ │ │ │ │ │ 00266 │ │ │ │ │ │ 00267 │ │ │ │ │ │ -// second angle (-) │ │ │ │ │ │ 00268 │ │ │ │ │ │ -ve_list[i+1].centre = median - transverse; │ │ │ │ │ │ 00269 │ │ │ │ │ │ -ve_list[i+1].centre.build_norm(); │ │ │ │ │ │ 00270 │ │ │ │ │ │ -ve_list[i+1].centre/=ve_list[i+1].centre._norm; │ │ │ │ │ │ 00271 │ │ │ │ │ │ -diff = ve_list[i+1].centre - parent_centre; │ │ │ │ │ │ 00272 │ │ │ │ │ │ + │ │ │ │ │ │ +// really check if the distance is less than VR │ │ │ │ │ │ +if (dot>cosVR){ │ │ │ │ │ │ +CSph3vector cross = cross_product3(parent_centre,vnormal); │ │ │ │ │ │ + │ │ │ │ │ │ +5.50 │ │ │ │ │ │ + │ │ │ │ │ │ +vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +// for the centres │ │ │ │ │ │ +CSph3vector median = (parent_centre+vnormal); │ │ │ │ │ │ +double amplT = sqrt((tan2R*(1+dot)+(dot-1))*(1+dot)); │ │ │ │ │ │ +CSph3vector transverse = amplT*cross/cross._norm; │ │ │ │ │ │ +// first angle (+) │ │ │ │ │ │ +ve_list[i].centre = median + transverse; │ │ │ │ │ │ +ve_list[i].centre.build_norm(); │ │ │ │ │ │ +ve_list[i].centre/=ve_list[i].centre._norm; │ │ │ │ │ │ +CSph3vector diff = ve_list[i].centre - parent_centre; │ │ │ │ │ │ +//ve_list[i].angle = atan2(dot_product3(angular_dir2, diff),dot_product3(angular_dir1, diff)); │ │ │ │ │ │ +ve_list[i].angle = sort_angle(dot_product3(angular_dir2, diff),dot_product3(angular_dir1, diff)); │ │ │ │ │ │ +ve_list[i].side = true; │ │ │ │ │ │ +ve_list[i].cocircular.clear(); │ │ │ │ │ │ +vicinity.push_back(&(ve_list[i])); │ │ │ │ │ │ + │ │ │ │ │ │ +// second angle (-) │ │ │ │ │ │ +ve_list[i+1].centre = median - transverse; │ │ │ │ │ │ +ve_list[i+1].centre.build_norm(); │ │ │ │ │ │ +ve_list[i+1].centre/=ve_list[i+1].centre._norm; │ │ │ │ │ │ +diff = ve_list[i+1].centre - parent_centre; │ │ │ │ │ │ ve_list[i+1].angle = sort_angle(dot_product3(angular_dir2, diff),dot_product3(angular_dir1, │ │ │ │ │ │ diff)); │ │ │ │ │ │ 00273 │ │ │ │ │ │ ve_list[i+1].side = false; │ │ │ │ │ │ 00274 │ │ │ │ │ │ ve_list[i+1].cocircular.clear(); │ │ │ │ │ │ 00275 │ │ │ │ │ │ @@ -30490,19 +30121,14 @@ │ │ │ │ │ │ // of angle within which the points stay within a distance │ │ │ │ │ │ 00279 │ │ │ │ │ │ // EPSILON_COCIRCULAR of circule │ │ │ │ │ │ 00280 │ │ │ │ │ │ // P = parent; C = child; O = Origin (center of circle) │ │ │ │ │ │ 00281 │ │ │ │ │ │ CSph3vector OP = parent_centre - ve_list[i+1].centre; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.52 vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00282 │ │ │ │ │ │ CSph3vector OC = vnormal - ve_list[i+1].centre; │ │ │ │ │ │ 00283 │ │ │ │ │ │ 00284 │ │ │ │ │ │ // two sources of error are (GPS CCN29-19) epsilon/(R sin theta) │ │ │ │ │ │ 00285 │ │ │ │ │ │ // and sqrt(2*epsilon/(R (1-cos theta))) and the way things work │ │ │ │ │ │ @@ -30530,18 +30156,14 @@ │ │ │ │ │ │ ve_list[i+1].cocircular_range = ve_list[i].cocircular_range; │ │ │ │ │ │ 00297 │ │ │ │ │ │ } │ │ │ │ │ │ 00298 } │ │ │ │ │ │ 00299 │ │ │ │ │ │ 00300 } │ │ │ │ │ │ │ │ │ │ │ │ -5.52 │ │ │ │ │ │ - │ │ │ │ │ │ -vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00001 │ │ │ │ │ │ 00002 // File: vicinity.cpp │ │ │ │ │ │ // │ │ │ │ │ │ 00003 // Description: source file for particle vicinity (Cvicinity class) │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ @@ -30581,14 +30203,19 @@ │ │ │ │ │ │ 00022 // │ │ │ │ │ │ // │ │ │ │ │ │ 00023 // $Revision:: 388 │ │ │ │ │ │ $// │ │ │ │ │ │ 00024 // $Date:: 2016-03-03 10:42:25 +0100 (Thu, 03 Mar 2016) │ │ │ │ │ │ $// │ │ │ │ │ │ 00026 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.50 vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00027 #include "vicinity.h" │ │ │ │ │ │ 00028 #include │ │ │ │ │ │ 00029 #include │ │ │ │ │ │ 00030 #include │ │ │ │ │ │ 00031 │ │ │ │ │ │ 00032 namespace siscone{ │ │ │ │ │ │ 00033 │ │ │ │ │ │ @@ -30625,23 +30252,14 @@ │ │ │ │ │ │ 00056 *************************************************************/ │ │ │ │ │ │ 00057 │ │ │ │ │ │ 00058 // default constructor │ │ │ │ │ │ 00059 //--------------------00060 Cvicinity::Cvicinity(){ │ │ │ │ │ │ 00061 │ │ │ │ │ │ n_part = 0; │ │ │ │ │ │ 00062 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -307 │ │ │ │ │ │ - │ │ │ │ │ │ - 308 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00063 │ │ │ │ │ │ ve_list = NULL; │ │ │ │ │ │ 00064 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00065 │ │ │ │ │ │ quadtree = NULL; │ │ │ │ │ │ 00066 #endif │ │ │ │ │ │ 00067 │ │ │ │ │ │ @@ -30705,14 +30323,23 @@ │ │ │ │ │ │ if (ve_list!=NULL){ │ │ │ │ │ │ 00111 │ │ │ │ │ │ delete[] ve_list; │ │ │ │ │ │ 00112 │ │ │ │ │ │ } │ │ │ │ │ │ 00113 │ │ │ │ │ │ vicinity.clear(); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +305 │ │ │ │ │ │ + │ │ │ │ │ │ + 306 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00114 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00115 │ │ │ │ │ │ if (quadtree!=NULL) │ │ │ │ │ │ 00116 │ │ │ │ │ │ delete quadtree; │ │ │ │ │ │ 00117 #endif │ │ │ │ │ │ 00118 │ │ │ │ │ │ @@ -30768,19 +30395,14 @@ │ │ │ │ │ │ 00146 │ │ │ │ │ │ } │ │ │ │ │ │ 00147 │ │ │ │ │ │ } │ │ │ │ │ │ 00148 │ │ │ │ │ │ 00149 │ │ │ │ │ │ // allocate quadtree and vicinity_elm list │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.52 vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00150 │ │ │ │ │ │ // note: we set phi in [-pi:pi] as it is the natural range for atan2! │ │ │ │ │ │ 00151 │ │ │ │ │ │ ve_list = new Cvicinity_elm[2*n_part]; │ │ │ │ │ │ 00152 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00153 │ │ │ │ │ │ eta_max+=0.1; │ │ │ │ │ │ @@ -30858,14 +30480,19 @@ │ │ │ │ │ │ 00197 │ │ │ │ │ │ append_to_vicinity(&plist[i]); │ │ │ │ │ │ 00198 │ │ │ │ │ │ } │ │ │ │ │ │ 00199 │ │ │ │ │ │ 00200 │ │ │ │ │ │ // sort the vicinity │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.50 vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00201 │ │ │ │ │ │ sort(vicinity.begin(), vicinity.end(), ve_less); │ │ │ │ │ │ 00202 │ │ │ │ │ │ 00203 │ │ │ │ │ │ vicinity_size = vicinity.size(); │ │ │ │ │ │ 00204 } │ │ │ │ │ │ 00205 │ │ │ │ │ │ @@ -30913,23 +30540,14 @@ │ │ │ │ │ │ if (dy>M_PI) │ │ │ │ │ │ 00235 │ │ │ │ │ │ dy -= twopi; │ │ │ │ │ │ 00236 │ │ │ │ │ │ else if (dy<-M_PI) │ │ │ │ │ │ 00237 │ │ │ │ │ │ dy += twopi; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -309 │ │ │ │ │ │ - │ │ │ │ │ │ - 310 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00238 │ │ │ │ │ │ 00239 │ │ │ │ │ │ d2 = dx*dx+dy*dy; │ │ │ │ │ │ 00240 │ │ │ │ │ │ 00241 │ │ │ │ │ │ // really check if the distance is less than VR │ │ │ │ │ │ 00242 │ │ │ │ │ │ @@ -31020,28 +30638,403 @@ │ │ │ │ │ │ c = dot_product(OP,OC); │ │ │ │ │ │ 00286 │ │ │ │ │ │ s = fabs(cross_product(OP,OC)); │ │ │ │ │ │ 00287 │ │ │ │ │ │ double inv_err1 = s * inv_R_EPS_COCIRC; │ │ │ │ │ │ 00288 │ │ │ │ │ │ double inv_err2_sq = (R2-c) * inv_R_2EPS_COCIRC; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +307 │ │ │ │ │ │ + │ │ │ │ │ │ + 308 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00289 │ │ │ │ │ │ ve_list[i].cocircular_range = pow2(inv_err1) > inv_err2_sq ? │ │ │ │ │ │ 00290 │ │ │ │ │ │ 1.0/inv_err1 : │ │ │ │ │ │ 00291 │ │ │ │ │ │ sqrt(1.0/inv_err2_sq); │ │ │ │ │ │ 00292 │ │ │ │ │ │ ve_list[i+1].cocircular_range = ve_list[i].cocircular_range; │ │ │ │ │ │ 00293 │ │ │ │ │ │ } │ │ │ │ │ │ 00294 } │ │ │ │ │ │ 00295 │ │ │ │ │ │ 00296 } │ │ │ │ │ │ │ │ │ │ │ │ +5.51 │ │ │ │ │ │ + │ │ │ │ │ │ +vicinity.h │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: vicinity.h │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // Description: header file for particle vicinity (Cvicinity class) │ │ │ │ │ │ +// │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // │ │ │ │ │ │ +an adaptation to spherical coordinates │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00010 // Copyright (c) 2006-2008 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +00011 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00023 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00025 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00026 // $Revision:: 255 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 // $Date:: 2008-07-12 17:40:35 +0200 (Sat, 12 Jul 2008) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00029 │ │ │ │ │ │ +00030 #ifndef __SPH_VICINITY_H__ │ │ │ │ │ │ +00031 #define __SPH_VICINITY_H__ │ │ │ │ │ │ +00032 │ │ │ │ │ │ +00033 #include │ │ │ │ │ │ +00034 #include │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include "momentum.h" │ │ │ │ │ │ +00037 #include │ │ │ │ │ │ +00038 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ +00039 #include │ │ │ │ │ │ +00040 #endif │ │ │ │ │ │ +00041 │ │ │ │ │ │ +00042 namespace siscone_spherical{ │ │ │ │ │ │ +00043 │ │ │ │ │ │ +00044 │ │ │ │ │ │ +00052 class CSphvicinity_elm{ │ │ │ │ │ │ +00053 public: │ │ │ │ │ │ +00055 │ │ │ │ │ │ +CSphmomentum *v; │ │ │ │ │ │ +00056 │ │ │ │ │ │ +00058 │ │ │ │ │ │ +siscone::Cvicinity_inclusion *is_inside; │ │ │ │ │ │ +00059 │ │ │ │ │ │ +00060 │ │ │ │ │ │ +// centre variables │ │ │ │ │ │ +00061 │ │ │ │ │ │ +CSph3vector centre; │ │ │ │ │ │ +00062 │ │ │ │ │ │ +double angle; │ │ │ │ │ │ +00063 │ │ │ │ │ │ +bool side; │ │ │ │ │ │ +00064 │ │ │ │ │ │ +double cocircular_range; │ │ │ │ │ │ +00066 │ │ │ │ │ │ +00069 │ │ │ │ │ │ +std::list cocircular; │ │ │ │ │ │ +00070 }; │ │ │ │ │ │ +00071 │ │ │ │ │ │ +00073 bool ve_less(CSphvicinity_elm *ve1, CSphvicinity_elm *ve2); │ │ │ │ │ │ +00074 │ │ │ │ │ │ +00075 │ │ │ │ │ │ +00083 class CSphvicinity{ │ │ │ │ │ │ +00084 public: │ │ │ │ │ │ +00086 │ │ │ │ │ │ +CSphvicinity(); │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00089 │ │ │ │ │ │ +CSphvicinity(std::vector &_particle_list); │ │ │ │ │ │ +00090 │ │ │ │ │ │ +00092 │ │ │ │ │ │ +~CSphvicinity(); │ │ │ │ │ │ +00093 │ │ │ │ │ │ +00098 │ │ │ │ │ │ +void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ +00099 │ │ │ │ │ │ +00105 │ │ │ │ │ │ +void build(CSphmomentum *_parent, double _VR); │ │ │ │ │ │ +00106 │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.52 vicinity.h │ │ │ │ │ │ + │ │ │ │ │ │ +00107 │ │ │ │ │ │ +// cone kinematical information │ │ │ │ │ │ +00108 │ │ │ │ │ │ +CSphmomentum *parent; │ │ │ │ │ │ +00109 │ │ │ │ │ │ +double VR; │ │ │ │ │ │ +00110 │ │ │ │ │ │ +double VR2; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +double cosVR; │ │ │ │ │ │ +00112 │ │ │ │ │ │ +double R; │ │ │ │ │ │ +00113 │ │ │ │ │ │ +double R2; │ │ │ │ │ │ +00114 │ │ │ │ │ │ +double tan2R; │ │ │ │ │ │ +00115 │ │ │ │ │ │ +double D2_R; │ │ │ │ │ │ +00116 │ │ │ │ │ │ +double inv_R_EPS_COCIRC; │ │ │ │ │ │ +00117 │ │ │ │ │ │ +double inv_R_2EPS_COCIRC; │ │ │ │ │ │ +00118 │ │ │ │ │ │ +00119 │ │ │ │ │ │ +// particle list information │ │ │ │ │ │ +00120 │ │ │ │ │ │ +int n_part; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +std::vector plist; │ │ │ │ │ │ +00123 │ │ │ │ │ │ +std::vector pincluded; │ │ │ │ │ │ +00124 │ │ │ │ │ │ +CSphvicinity_elm *ve_list; │ │ │ │ │ │ +00125 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ +00126 │ │ │ │ │ │ +siscone::Cquadtree *quadtree; │ │ │ │ │ │ +00127 #endif │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00129 │ │ │ │ │ │ +// vicinity information │ │ │ │ │ │ +00130 │ │ │ │ │ │ +std::vector vicinity; │ │ │ │ │ │ +00131 │ │ │ │ │ │ +unsigned int vicinity_size; │ │ │ │ │ │ +00132 │ │ │ │ │ │ +00133 protected: │ │ │ │ │ │ +00139 │ │ │ │ │ │ +void append_to_vicinity(CSphmomentum *v); │ │ │ │ │ │ +00140 │ │ │ │ │ │ +00141 │ │ │ │ │ │ +// internal variables │ │ │ │ │ │ +00142 │ │ │ │ │ │ +CSph3vector parent_centre; │ │ │ │ │ │ +00143 │ │ │ │ │ │ +CSph3vector angular_dir1; │ │ │ │ │ │ +00144 │ │ │ │ │ │ +CSph3vector angular_dir2; │ │ │ │ │ │ +00145 }; │ │ │ │ │ │ +00146 │ │ │ │ │ │ +00147 } │ │ │ │ │ │ +00148 │ │ │ │ │ │ +00149 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.52 │ │ │ │ │ │ + │ │ │ │ │ │ +vicinity.h │ │ │ │ │ │ + │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: vicinity.h │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // Description: header file for particle vicinity (Cvicinity class) │ │ │ │ │ │ +// │ │ │ │ │ │ +00005 // This file is part of the SISCone project. │ │ │ │ │ │ +// │ │ │ │ │ │ +00006 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ +// │ │ │ │ │ │ +00007 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00008 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ +// │ │ │ │ │ │ +00009 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00010 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ +// │ │ │ │ │ │ +00011 // it under the terms of the GNU General Public License as published by │ │ │ │ │ │ +// │ │ │ │ │ │ +00012 // the Free Software Foundation; either version 2 of the License, or │ │ │ │ │ │ +// │ │ │ │ │ │ +00013 // (at your option) any later version. │ │ │ │ │ │ +// │ │ │ │ │ │ +00014 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00015 // This program is distributed in the hope that it will be useful, │ │ │ │ │ │ +// │ │ │ │ │ │ +00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of │ │ │ │ │ │ +// │ │ │ │ │ │ +00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ +// │ │ │ │ │ │ +00018 // GNU General Public License for more details. │ │ │ │ │ │ +// │ │ │ │ │ │ +00019 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00020 // You should have received a copy of the GNU General Public License │ │ │ │ │ │ +// │ │ │ │ │ │ +00021 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +// │ │ │ │ │ │ +00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00023 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00024 // $Revision:: 123 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00025 // $Date:: 2007-03-01 02:52:16 +0100 (Thu, 01 Mar 2007) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00027 │ │ │ │ │ │ +00028 #ifndef __VICINITY_H__ │ │ │ │ │ │ +00029 #define __VICINITY_H__ │ │ │ │ │ │ +00030 │ │ │ │ │ │ +00031 #include │ │ │ │ │ │ +00032 #include │ │ │ │ │ │ +00033 #include "momentum.h" │ │ │ │ │ │ +00034 #include "defines.h" │ │ │ │ │ │ +00035 #include "quadtree.h" │ │ │ │ │ │ +00036 │ │ │ │ │ │ +00037 namespace siscone{ │ │ │ │ │ │ +00038 │ │ │ │ │ │ +00039 │ │ │ │ │ │ +00040 │ │ │ │ │ │ +00046 class Cvicinity_inclusion { │ │ │ │ │ │ +00047 public: │ │ │ │ │ │ +00049 │ │ │ │ │ │ +Cvicinity_inclusion() : cone(false), cocirc(false) {} │ │ │ │ │ │ +00050 │ │ │ │ │ │ +00051 │ │ │ │ │ │ +bool cone; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +309 │ │ │ │ │ │ + │ │ │ │ │ │ + 310 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00052 │ │ │ │ │ │ +bool cocirc; │ │ │ │ │ │ +00053 }; │ │ │ │ │ │ +00054 │ │ │ │ │ │ +00055 │ │ │ │ │ │ +00063 class Cvicinity_elm{ │ │ │ │ │ │ +00064 public: │ │ │ │ │ │ +00066 │ │ │ │ │ │ +Cmomentum *v; │ │ │ │ │ │ +00067 │ │ │ │ │ │ +00069 │ │ │ │ │ │ +Cvicinity_inclusion *is_inside; │ │ │ │ │ │ +00070 │ │ │ │ │ │ +00071 │ │ │ │ │ │ +// centre variables │ │ │ │ │ │ +00072 │ │ │ │ │ │ +double eta; │ │ │ │ │ │ +00073 │ │ │ │ │ │ +double phi; │ │ │ │ │ │ +00074 │ │ │ │ │ │ +double angle; │ │ │ │ │ │ +00075 │ │ │ │ │ │ +bool side; │ │ │ │ │ │ +00076 │ │ │ │ │ │ +double cocircular_range; │ │ │ │ │ │ +00078 │ │ │ │ │ │ +00081 │ │ │ │ │ │ +std::list cocircular; │ │ │ │ │ │ +00082 }; │ │ │ │ │ │ +00083 │ │ │ │ │ │ +00085 bool ve_less(Cvicinity_elm *ve1, Cvicinity_elm *ve2); │ │ │ │ │ │ +00086 │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00095 class Cvicinity{ │ │ │ │ │ │ +00096 public: │ │ │ │ │ │ +00098 │ │ │ │ │ │ +Cvicinity(); │ │ │ │ │ │ +00099 │ │ │ │ │ │ +00101 │ │ │ │ │ │ +Cvicinity(std::vector &_particle_list); │ │ │ │ │ │ +00102 │ │ │ │ │ │ +00104 │ │ │ │ │ │ +~Cvicinity(); │ │ │ │ │ │ +00105 │ │ │ │ │ │ +00110 │ │ │ │ │ │ +void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ +00111 │ │ │ │ │ │ +00117 │ │ │ │ │ │ +void build(Cmomentum *_parent, double _VR); │ │ │ │ │ │ +00118 │ │ │ │ │ │ +00119 │ │ │ │ │ │ +// cone kinematical information │ │ │ │ │ │ +00120 │ │ │ │ │ │ +Cmomentum *parent; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +double VR; │ │ │ │ │ │ +00122 │ │ │ │ │ │ +double VR2; │ │ │ │ │ │ +00123 │ │ │ │ │ │ +double R; │ │ │ │ │ │ +00124 │ │ │ │ │ │ +double R2; │ │ │ │ │ │ +00125 │ │ │ │ │ │ +double inv_R_EPS_COCIRC; │ │ │ │ │ │ +00126 │ │ │ │ │ │ +double inv_R_2EPS_COCIRC; │ │ │ │ │ │ +00127 │ │ │ │ │ │ +00128 │ │ │ │ │ │ +// particle list information │ │ │ │ │ │ +00129 │ │ │ │ │ │ +int n_part; │ │ │ │ │ │ +00130 │ │ │ │ │ │ +std::vector plist; │ │ │ │ │ │ +00131 │ │ │ │ │ │ +std::vector pincluded; │ │ │ │ │ │ +00132 │ │ │ │ │ │ +Cvicinity_elm *ve_list; │ │ │ │ │ │ +00133 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ +00134 │ │ │ │ │ │ +Cquadtree *quadtree; │ │ │ │ │ │ +00135 #endif │ │ │ │ │ │ +00136 │ │ │ │ │ │ +00137 │ │ │ │ │ │ +// vicinity information │ │ │ │ │ │ +00138 │ │ │ │ │ │ +std::vector vicinity; │ │ │ │ │ │ +00139 │ │ │ │ │ │ +unsigned int vicinity_size; │ │ │ │ │ │ +00140 │ │ │ │ │ │ +00141 protected: │ │ │ │ │ │ +00147 │ │ │ │ │ │ +void append_to_vicinity(Cmomentum *v); │ │ │ │ │ │ +00148 │ │ │ │ │ │ +00149 │ │ │ │ │ │ +// internal variables │ │ │ │ │ │ +00150 │ │ │ │ │ │ +double pcx; │ │ │ │ │ │ +00151 │ │ │ │ │ │ +double pcy; │ │ │ │ │ │ +00152 }; │ │ │ │ │ │ +00153 │ │ │ │ │ │ +00154 } │ │ │ │ │ │ +00155 │ │ │ │ │ │ +00156 #endif │ │ │ │ │ │ + │ │ │ │ │ │ Generated on Tue Jan 7 2025 11:57:28 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Index │ │ │ │ │ │ _norm │ │ │ │ │ │ siscone::Cjet_area, 31 │ │ │ │ │ │ siscone_spherical::CSph3vector, 71 │ │ │ │ │ │ add │ │ │ │ │ │ @@ -31281,22 +31274,22 @@ │ │ │ │ │ │ siscone::Ceta_phi_range, 20 │ │ │ │ │ │ eta_min │ │ │ │ │ │ siscone::Ceta_phi_range, 20 │ │ │ │ │ │ eta_range │ │ │ │ │ │ siscone::Ceta_phi_range, 21 │ │ │ │ │ │ ev_name │ │ │ │ │ │ Coptions, 42 │ │ │ │ │ │ -examples/area.cpp, 189 │ │ │ │ │ │ -examples/main.cpp, 179 │ │ │ │ │ │ -examples/options.cpp, 180 │ │ │ │ │ │ -examples/options.h, 183 │ │ │ │ │ │ -examples/sample.cpp, 184 │ │ │ │ │ │ -examples/spherical.cpp, 185 │ │ │ │ │ │ -examples/test.cpp, 186 │ │ │ │ │ │ -examples/times.cpp, 188 │ │ │ │ │ │ +examples/area.cpp, 179 │ │ │ │ │ │ +examples/main.cpp, 184 │ │ │ │ │ │ +examples/options.cpp, 186 │ │ │ │ │ │ +examples/options.h, 189 │ │ │ │ │ │ +examples/sample.cpp, 189 │ │ │ │ │ │ +examples/spherical.cpp, 191 │ │ │ │ │ │ +examples/test.cpp, 192 │ │ │ │ │ │ +examples/times.cpp, 193 │ │ │ │ │ │ │ │ │ │ │ │ 313 │ │ │ │ │ │ │ │ │ │ │ │ siscone::hash_cones, 167 │ │ │ │ │ │ siscone_spherical::sph_hash_cones, 174 │ │ │ │ │ │ hash_cones │ │ │ │ │ │ siscone::hash_cones, 165 │ │ │ │ │ │ @@ -31387,15 +31380,15 @@ │ │ │ │ │ │ 314 │ │ │ │ │ │ │ │ │ │ │ │ INDEX │ │ │ │ │ │ │ │ │ │ │ │ siscone::hash_element, 169 │ │ │ │ │ │ siscone_spherical::sph_hash_element, 177 │ │ │ │ │ │ j │ │ │ │ │ │ -siscone::ranlux_state_t, 171 │ │ │ │ │ │ +siscone::ranlux_state_t, 170 │ │ │ │ │ │ jet_areas │ │ │ │ │ │ siscone::Carea, 15 │ │ │ │ │ │ jets │ │ │ │ │ │ siscone::Csplit_merge, 136 │ │ │ │ │ │ siscone_spherical::CSphsplit_merge, 102 │ │ │ │ │ │ mask │ │ │ │ │ │ siscone::hash_cones, 167 │ │ │ │ │ │ @@ -31427,15 +31420,15 @@ │ │ │ │ │ │ n │ │ │ │ │ │ siscone::Cjet, 27 │ │ │ │ │ │ siscone::Csplit_merge, 137 │ │ │ │ │ │ siscone::ranlux_state_t, 171 │ │ │ │ │ │ siscone_spherical::CSphjet, 77 │ │ │ │ │ │ siscone_spherical::CSphsplit_merge, 103 │ │ │ │ │ │ n_cones │ │ │ │ │ │ -siscone::hash_cones, 168 │ │ │ │ │ │ +siscone::hash_cones, 167 │ │ │ │ │ │ siscone_spherical::sph_hash_cones, 175 │ │ │ │ │ │ n_left │ │ │ │ │ │ siscone::Csplit_merge, 137 │ │ │ │ │ │ siscone_spherical::CSphsplit_merge, 103 │ │ │ │ │ │ n_part │ │ │ │ │ │ siscone::Cvicinity, 157 │ │ │ │ │ │ siscone_spherical::CSphvicinity, 123 │ │ │ │ │ │ @@ -31633,23 +31626,23 @@ │ │ │ │ │ │ siscone_spherical::sph_hash_cones, 175 │ │ │ │ │ │ randomize │ │ │ │ │ │ siscone::Creference, 53 │ │ │ │ │ │ range │ │ │ │ │ │ siscone::Cjet, 27 │ │ │ │ │ │ siscone_spherical::CSphjet, 77 │ │ │ │ │ │ ranlux.h │ │ │ │ │ │ -ranlux_get, 220 │ │ │ │ │ │ -ranlux_init, 220 │ │ │ │ │ │ -ranlux_print_state, 220 │ │ │ │ │ │ +ranlux_get, 228 │ │ │ │ │ │ +ranlux_init, 228 │ │ │ │ │ │ +ranlux_print_state, 228 │ │ │ │ │ │ ranlux_get │ │ │ │ │ │ -ranlux.h, 220 │ │ │ │ │ │ +ranlux.h, 228 │ │ │ │ │ │ ranlux_init │ │ │ │ │ │ -ranlux.h, 220 │ │ │ │ │ │ +ranlux.h, 228 │ │ │ │ │ │ ranlux_print_state │ │ │ │ │ │ -ranlux.h, 220 │ │ │ │ │ │ +ranlux.h, 228 │ │ │ │ │ │ recompute_jets │ │ │ │ │ │ siscone::Csiscone, 61 │ │ │ │ │ │ siscone_spherical::CSphsiscone, 92 │ │ │ │ │ │ ref │ │ │ │ │ │ siscone::Cmomentum, 39 │ │ │ │ │ │ siscone::Creference, 53 │ │ │ │ │ │ siscone::hash_element, 170 │ │ │ │ │ │ @@ -31683,56 +31676,56 @@ │ │ │ │ │ │ siscone_spherical::CSphsplit_merge, 101 │ │ │ │ │ │ side │ │ │ │ │ │ siscone::Cvicinity_elm, 162 │ │ │ │ │ │ siscone_spherical::CSphvicinity_elm, 127 │ │ │ │ │ │ │ │ │ │ │ │ INDEX │ │ │ │ │ │ │ │ │ │ │ │ -siscone/area.cpp, 191 │ │ │ │ │ │ +siscone/area.cpp, 180 │ │ │ │ │ │ siscone/area.h, 195 │ │ │ │ │ │ siscone/circulator.h, 196 │ │ │ │ │ │ siscone/config.h, 197 │ │ │ │ │ │ siscone/config_raw.h, 198 │ │ │ │ │ │ siscone/defines.h, 199, 201 │ │ │ │ │ │ -siscone/geom_2d.cpp, 227 │ │ │ │ │ │ -siscone/geom_2d.h, 230 │ │ │ │ │ │ -siscone/hash.cpp, 233 │ │ │ │ │ │ -siscone/hash.h, 202 │ │ │ │ │ │ -siscone/momentum.cpp, 204 │ │ │ │ │ │ -siscone/momentum.h, 209 │ │ │ │ │ │ -siscone/protocones.cpp, 238 │ │ │ │ │ │ -siscone/protocones.h, 257 │ │ │ │ │ │ -siscone/quadtree.cpp, 213 │ │ │ │ │ │ -siscone/quadtree.h, 216 │ │ │ │ │ │ -siscone/ranlux.cpp, 217 │ │ │ │ │ │ -siscone/ranlux.h, 219, 220 │ │ │ │ │ │ -siscone/reference.cpp, 221 │ │ │ │ │ │ -siscone/reference.h, 222 │ │ │ │ │ │ -siscone/siscone.cpp, 261 │ │ │ │ │ │ -siscone/siscone.h, 223 │ │ │ │ │ │ -siscone/siscone_error.cpp, 225 │ │ │ │ │ │ -siscone/siscone_error.h, 226 │ │ │ │ │ │ -siscone/spherical/geom_2d.cpp, 228 │ │ │ │ │ │ -siscone/spherical/geom_2d.h, 232 │ │ │ │ │ │ -siscone/spherical/hash.cpp, 236 │ │ │ │ │ │ -siscone/spherical/hash.h, 203 │ │ │ │ │ │ -siscone/spherical/momentum.cpp, 206 │ │ │ │ │ │ -siscone/spherical/momentum.h, 211 │ │ │ │ │ │ -siscone/spherical/protocones.cpp, 247 │ │ │ │ │ │ -siscone/spherical/protocones.h, 259 │ │ │ │ │ │ -siscone/spherical/siscone.cpp, 264 │ │ │ │ │ │ -siscone/spherical/siscone.h, 224 │ │ │ │ │ │ -siscone/spherical/split_merge.cpp, 276 │ │ │ │ │ │ -siscone/spherical/split_merge.h, 268 │ │ │ │ │ │ -siscone/spherical/vicinity.cpp, 303 │ │ │ │ │ │ -siscone/spherical/vicinity.h, 273 │ │ │ │ │ │ -siscone/split_merge.cpp, 290 │ │ │ │ │ │ -siscone/split_merge.h, 271 │ │ │ │ │ │ -siscone/vicinity.cpp, 307 │ │ │ │ │ │ -siscone/vicinity.h, 275 │ │ │ │ │ │ +siscone/geom_2d.cpp, 233 │ │ │ │ │ │ +siscone/geom_2d.h, 237 │ │ │ │ │ │ +siscone/hash.cpp, 239 │ │ │ │ │ │ +siscone/hash.h, 244 │ │ │ │ │ │ +siscone/momentum.cpp, 246 │ │ │ │ │ │ +siscone/momentum.h, 252 │ │ │ │ │ │ +siscone/protocones.cpp, 202 │ │ │ │ │ │ +siscone/protocones.h, 255 │ │ │ │ │ │ +siscone/quadtree.cpp, 221 │ │ │ │ │ │ +siscone/quadtree.h, 225 │ │ │ │ │ │ +siscone/ranlux.cpp, 226 │ │ │ │ │ │ +siscone/ranlux.h, 228, 229 │ │ │ │ │ │ +siscone/reference.cpp, 229 │ │ │ │ │ │ +siscone/reference.h, 231 │ │ │ │ │ │ +siscone/siscone.cpp, 259 │ │ │ │ │ │ +siscone/siscone.h, 266 │ │ │ │ │ │ +siscone/siscone_error.cpp, 232 │ │ │ │ │ │ +siscone/siscone_error.h, 232 │ │ │ │ │ │ +siscone/spherical/geom_2d.cpp, 235 │ │ │ │ │ │ +siscone/spherical/geom_2d.h, 238 │ │ │ │ │ │ +siscone/spherical/hash.cpp, 242 │ │ │ │ │ │ +siscone/spherical/hash.h, 245 │ │ │ │ │ │ +siscone/spherical/momentum.cpp, 248 │ │ │ │ │ │ +siscone/spherical/momentum.h, 253 │ │ │ │ │ │ +siscone/spherical/protocones.cpp, 212 │ │ │ │ │ │ +siscone/spherical/protocones.h, 257 │ │ │ │ │ │ +siscone/spherical/siscone.cpp, 263 │ │ │ │ │ │ +siscone/spherical/siscone.h, 267 │ │ │ │ │ │ +siscone/spherical/split_merge.cpp, 268 │ │ │ │ │ │ +siscone/spherical/split_merge.h, 295 │ │ │ │ │ │ +siscone/spherical/vicinity.cpp, 301 │ │ │ │ │ │ +siscone/spherical/vicinity.h, 308 │ │ │ │ │ │ +siscone/split_merge.cpp, 282 │ │ │ │ │ │ +siscone/split_merge.h, 298 │ │ │ │ │ │ +siscone/vicinity.cpp, 304 │ │ │ │ │ │ +siscone/vicinity.h, 309 │ │ │ │ │ │ siscone::Carea, 7 │ │ │ │ │ │ ∼Carea, 13 │ │ │ │ │ │ Carea, 13 │ │ │ │ │ │ compute_active_areas, 13 │ │ │ │ │ │ compute_areas, 13 │ │ │ │ │ │ compute_passive_areas, 14 │ │ │ │ │ │ grid_eta_max, 15 │ │ │ │ │ │ @@ -31956,26 +31949,26 @@ │ │ │ │ │ │ siscone::hash_cones, 164 │ │ │ │ │ │ ∼hash_cones, 166 │ │ │ │ │ │ hash_array, 167 │ │ │ │ │ │ hash_cones, 165 │ │ │ │ │ │ insert, 166 │ │ │ │ │ │ is_inside, 167 │ │ │ │ │ │ mask, 167 │ │ │ │ │ │ -n_cones, 168 │ │ │ │ │ │ +n_cones, 167 │ │ │ │ │ │ R2, 168 │ │ │ │ │ │ siscone::hash_element, 168 │ │ │ │ │ │ eta, 169 │ │ │ │ │ │ is_stable, 169 │ │ │ │ │ │ next, 169 │ │ │ │ │ │ phi, 169 │ │ │ │ │ │ ref, 170 │ │ │ │ │ │ siscone::ranlux_state_t, 170 │ │ │ │ │ │ carry, 170 │ │ │ │ │ │ i, 170 │ │ │ │ │ │ -j, 171 │ │ │ │ │ │ +j, 170 │ │ │ │ │ │ n, 171 │ │ │ │ │ │ skip, 171 │ │ │ │ │ │ u, 171 │ │ │ │ │ │ siscone_spherical::CSph3vector, 64 │ │ │ │ │ │ _norm, 71 │ │ │ │ │ │ _phi, 71 │ │ │ │ │ │ _theta, 71 │ │ │ │ │ │ @@ -32182,15 +32175,15 @@ │ │ │ │ │ │ cocircular_range, 127 │ │ │ │ │ │ user_scale │ │ │ │ │ │ is_inside, 127 │ │ │ │ │ │ siscone::Csplit_merge, 135 │ │ │ │ │ │ side, 127 │ │ │ │ │ │ siscone_spherical::CSphsplit_merge, 101 │ │ │ │ │ │ v, 127 │ │ │ │ │ │ -siscone_spherical::sph_hash_cones, 172 │ │ │ │ │ │ +siscone_spherical::sph_hash_cones, 171 │ │ │ │ │ │ v │ │ │ │ │ │ ∼sph_hash_cones, 173 │ │ │ │ │ │ siscone::Cjet, 28 │ │ │ │ │ │ hash_array, 174 │ │ │ │ │ │ siscone::Cquadtree, 50 │ │ │ │ │ │ insert, 173, 174 │ │ │ │ │ │ siscone::Cvicinity_elm, 162