--- /srv/reproducible-results/rbuild-debian/r-b-build.iq7dBmid/b1/siscone_3.0.5-2_armhf.changes +++ /srv/reproducible-results/rbuild-debian/r-b-build.iq7dBmid/b2/siscone_3.0.5-2_armhf.changes ├── Files │ @@ -1,10 +1,10 @@ │ │ f5aefe325044f442f0e1c21d8a868f9e 79408 libdevel optional libsiscone-dev_3.0.5-2_armhf.deb │ 507f29e5f2459ac5cb9cc245abe74203 71216 libdevel optional libsiscone-spherical-dev_3.0.5-2_armhf.deb │ 44e05b4de2a760a3f3430f5d9d87ad1e 418456 debug optional libsiscone-spherical0v5-dbgsym_3.0.5-2_armhf.deb │ e637043cdd8bc7cf65038b9cd298e6a0 53756 libs optional libsiscone-spherical0v5_3.0.5-2_armhf.deb │ 2e9786485fea47bfbfa28be9cdc121dc 490968 debug optional libsiscone0v5-dbgsym_3.0.5-2_armhf.deb │ 9ccc8c1bcf761a550412179292b8aae9 59212 libs optional libsiscone0v5_3.0.5-2_armhf.deb │ - 8fbcf6339ebdd215f9af29826a63a6f9 1187652 doc optional siscone-doc-html_3.0.5-2_all.deb │ - 2b290b8734a2e0232b7af7b305417d23 1589240 doc optional siscone-doc-pdf_3.0.5-2_all.deb │ + 6e9df02ff9b8bd3c4db77a256db80a53 1187652 doc optional siscone-doc-html_3.0.5-2_all.deb │ + 7f083018554e662d8e12a6cfcd0ff8fb 1593280 doc optional siscone-doc-pdf_3.0.5-2_all.deb │ ee8a36e6ed6ae32143424e71fcc9dc11 34968 devel optional siscone-examples_3.0.5-2_all.deb ├── siscone-doc-html_3.0.5-2_all.deb │ ├── control.tar.xz │ │ ├── control.tar │ │ │ ├── ./control │ │ │ │ @@ -1,13 +1,13 @@ │ │ │ │ Package: siscone-doc-html │ │ │ │ Source: siscone │ │ │ │ Version: 3.0.5-2 │ │ │ │ Architecture: all │ │ │ │ Maintainer: Debian Science Maintainers │ │ │ │ -Installed-Size: 5828 │ │ │ │ +Installed-Size: 5829 │ │ │ │ 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 │ │ │ │ @@ -212,15 +212,15 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 3191 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_t.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2319 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_u.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 4264 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_v.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 30418 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_vars.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2155 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_x.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 5352 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/functions_~.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 31816 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 30773 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 31825 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/geom__2d_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2552 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/globals.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2434 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/globals_defs.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 2059 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/globals_vars.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 6197 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/graph_legend.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 23370 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/graph_legend.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 52933 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/hash_8cpp_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 22548 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/hash_8h_source.html │ │ │ │ @@ -280,16 +280,16 @@ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1670 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_7.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 255 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_8.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1737 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_8.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1317 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_9.map │ │ │ │ -rw-r--r-- 0 root (0) root (0) 10333 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherit_graph_9.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 14157 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/inherits.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 30265 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/main_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 41791 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8cpp_source.html │ │ │ │ --rw-r--r-- 0 root (0) root (0) 41439 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8h_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 43383 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8cpp_source.html │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 39163 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/momentum_8h_source.html │ │ │ │ -rw-r--r-- 0 root (0) root (0) 153 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_f.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 169 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_fd.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 95 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_g.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 98 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_h.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 114 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/nav_hd.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 123 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/open.png │ │ │ │ -rw-r--r-- 0 root (0) root (0) 52457 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-html/html/devel/options_8cpp_source.html │ │ │ ├── ./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 {} │ │ │ │ │ @@ -175,14 +175,18 @@ │ │ │ │ │ double modulus() const │ │ │ │ │ modulus of the vector │ │ │ │ │ Definition geom_2d.h:90 │ │ │ │ │ siscone::Ctwovect::Ctwovect │ │ │ │ │ Ctwovect(double _x, double _y) │ │ │ │ │ ctor with initialisation │ │ │ │ │ Definition geom_2d.h:81 │ │ │ │ │ +siscone::circulator │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +Definition circulator.h:36 │ │ │ │ │ defines.h │ │ │ │ │ twopi │ │ │ │ │ const double twopi │ │ │ │ │ definition of 2*M_PI which is useful a bit everyhere! │ │ │ │ │ Definition defines.h:114 │ │ │ │ │ │ │ │ │ │ =============================================================================== │ │ │ ├── ./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 {} │ │ │ │ │ @@ -145,15 +145,15 @@ │ │ │ │ │ 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){ │ │ │ │ │ + 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; │ │ │ │ │ @@ -230,10 +230,14 @@ │ │ │ │ │ siscone::Cmomentum::phi │ │ │ │ │ double phi │ │ │ │ │ particle azimuthal angle │ │ │ │ │ Definition momentum.h:115 │ │ │ │ │ siscone::Creference │ │ │ │ │ references used for checksums. │ │ │ │ │ Definition reference.h:43 │ │ │ │ │ +siscone::circulator │ │ │ │ │ +a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ +iterator; │ │ │ │ │ +Definition circulator.h:36 │ │ │ │ │ │ │ │ │ │ =============================================================================== │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by [doxygen] 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,15 +184,14 @@ │ │ │ │
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 {} │ │ │ │ │ @@ -89,15 +89,15 @@ │ │ │ │ │ 116 int parent_index; │ │ │ │ │ 117 int index; │ │ │ │ │ 118 │ │ │ │ │ 120 // the following part is used for checksums // │ │ │ │ │ 122 Creference ref; │ │ │ │ │ 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); │ │ │ │ │ 131 │ │ │ │ │ 133bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ 134 │ │ │ │ │ 135 │ │ │ │ │ 137// some handy utilities // │ │ │ │ │ @@ -215,18 +215,14 @@ │ │ │ │ │ siscone::Cmomentum::perpmass │ │ │ │ │ double perpmass() const │ │ │ │ │ transverse mass, mt = sqrt(pt^2+m^2) = sqrt(E^2 - pz^2) │ │ │ │ │ Definition momentum.h:76 │ │ │ │ │ siscone::Creference │ │ │ │ │ references used for checksums. │ │ │ │ │ Definition reference.h:43 │ │ │ │ │ -siscone::circulator │ │ │ │ │ -a circulator that is foreseen to take as template member either a pointer or an │ │ │ │ │ -iterator; │ │ │ │ │ -Definition circulator.h:36 │ │ │ │ │ defines.h │ │ │ │ │ twopi │ │ │ │ │ const double twopi │ │ │ │ │ definition of 2*M_PI which is useful a bit everyhere! │ │ │ │ │ Definition defines.h:114 │ │ │ │ │ │ │ │ │ │ =============================================================================== ├── siscone-doc-pdf_3.0.5-2_all.deb │ ├── file list │ │ @@ -1,3 +1,3 @@ │ │ -rw-r--r-- 0 0 0 4 2023-01-10 17:32:40.000000 debian-binary │ │ -rw-r--r-- 0 0 0 808 2023-01-10 17:32:40.000000 control.tar.xz │ │ --rw-r--r-- 0 0 0 1588240 2023-01-10 17:32:40.000000 data.tar.xz │ │ +-rw-r--r-- 0 0 0 1592280 2023-01-10 17:32:40.000000 data.tar.xz │ ├── control.tar.xz │ │ ├── control.tar │ │ │ ├── ./control │ │ │ │ @@ -1,13 +1,13 @@ │ │ │ │ Package: siscone-doc-pdf │ │ │ │ Source: siscone │ │ │ │ Version: 3.0.5-2 │ │ │ │ Architecture: all │ │ │ │ Maintainer: Debian Science Maintainers │ │ │ │ -Installed-Size: 1567 │ │ │ │ +Installed-Size: 1571 │ │ │ │ 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 2023-01-10 17:32:40.000000 ./usr/share/ │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2023-01-10 17:32:40.000000 ./usr/share/doc/ │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-pdf/ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 1125 2023-01-10 17:32:40.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 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-pdf/copyright │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-pdf/pdf/ │ │ │ │ --rw-r--r-- 0 root (0) root (0) 1573101 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-pdf/pdf/refman.pdf.gz │ │ │ │ +-rw-r--r-- 0 root (0) root (0) 1576968 2023-01-10 17:32:40.000000 ./usr/share/doc/siscone-doc-pdf/pdf/refman.pdf.gz │ │ │ │ drwxr-xr-x 0 root (0) root (0) 0 2023-01-10 17:32:40.000000 ./usr/share/doc-base/ │ │ │ │ -rw-r--r-- 0 root (0) root (0) 240 2023-01-10 17:32:40.000000 ./usr/share/doc-base/siscone-doc-pdf.siscone-pdf │ │ │ ├── ./usr/share/doc/siscone-doc-pdf/pdf/refman.pdf.gz │ │ │ │ ├── refman.pdf │ │ │ │ │ ├── pdftotext {} - │ │ │ │ │ │ @@ -1661,35 +1661,35 @@ │ │ │ │ │ │ 4.37.2.1 centre . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174 │ │ │ │ │ │ 4.37.2.2 is_stable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174 │ │ │ │ │ │ 4.37.2.3 next . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174 │ │ │ │ │ │ 5 File Documentation │ │ │ │ │ │ │ │ │ │ │ │ 175 │ │ │ │ │ │ │ │ │ │ │ │ -5.1 main.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 175 │ │ │ │ │ │ -5.2 options.cpp │ │ │ │ │ │ +5.1 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 175 │ │ │ │ │ │ +5.2 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 176 │ │ │ │ │ │ +5.3 main.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180 │ │ │ │ │ │ +5.4 options.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 176 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 182 │ │ │ │ │ │ │ │ │ │ │ │ -5.3 options.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179 │ │ │ │ │ │ -5.4 sample.cpp │ │ │ │ │ │ +5.5 options.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185 │ │ │ │ │ │ +5.6 sample.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185 │ │ │ │ │ │ │ │ │ │ │ │ -5.5 spherical.cpp │ │ │ │ │ │ +5.7 spherical.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187 │ │ │ │ │ │ │ │ │ │ │ │ -5.6 test.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 182 │ │ │ │ │ │ -5.7 times.cpp │ │ │ │ │ │ +5.8 test.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 188 │ │ │ │ │ │ +5.9 times.cpp │ │ │ │ │ │ │ │ │ │ │ │ -. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 184 │ │ │ │ │ │ +. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 │ │ │ │ │ │ │ │ │ │ │ │ -5.8 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185 │ │ │ │ │ │ -5.9 area.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187 │ │ │ │ │ │ 5.10 area.h │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 191 │ │ │ │ │ │ │ │ │ │ │ │ 5.11 circulator.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 192 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ @@ -1711,63 +1711,63 @@ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197 │ │ │ │ │ │ │ │ │ │ │ │ 5.14.2 Variable Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197 │ │ │ │ │ │ 5.14.2.1 twopi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197 │ │ │ │ │ │ 5.15 defines.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 197 │ │ │ │ │ │ 5.16 geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198 │ │ │ │ │ │ 5.17 geom_2d.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200 │ │ │ │ │ │ -5.18 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202 │ │ │ │ │ │ -5.19 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 203 │ │ │ │ │ │ -5.20 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204 │ │ │ │ │ │ -5.21 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 207 │ │ │ │ │ │ -5.22 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210 │ │ │ │ │ │ -5.23 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210 │ │ │ │ │ │ -5.24 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211 │ │ │ │ │ │ -5.25 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 213 │ │ │ │ │ │ -5.26 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 217 │ │ │ │ │ │ -5.27 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 226 │ │ │ │ │ │ +5.18 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202 │ │ │ │ │ │ +5.19 hash.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205 │ │ │ │ │ │ +5.20 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 207 │ │ │ │ │ │ +5.21 hash.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 208 │ │ │ │ │ │ +5.22 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209 │ │ │ │ │ │ +5.23 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210 │ │ │ │ │ │ +5.24 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 213 │ │ │ │ │ │ +5.25 protocones.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 222 │ │ │ │ │ │ +5.26 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 │ │ │ │ │ │ +5.27 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234 │ │ │ │ │ │ 5.28 quadtree.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236 │ │ │ │ │ │ 5.29 quadtree.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239 │ │ │ │ │ │ 5.30 ranlux.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240 │ │ │ │ │ │ 5.31 siscone/ranlux.h File Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242 │ │ │ │ │ │ -5.31.1 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243 │ │ │ │ │ │ -5.31.1.1 ranlux_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243 │ │ │ │ │ │ +5.31.1 Function Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242 │ │ │ │ │ │ +5.31.1.1 ranlux_get() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242 │ │ │ │ │ │ 5.31.1.2 ranlux_init() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243 │ │ │ │ │ │ 5.31.1.3 ranlux_print_state() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243 │ │ │ │ │ │ 5.32 ranlux.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243 │ │ │ │ │ │ 5.33 reference.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244 │ │ │ │ │ │ 5.34 reference.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245 │ │ │ │ │ │ 5.35 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246 │ │ │ │ │ │ -5.36 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 250 │ │ │ │ │ │ -5.37 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 253 │ │ │ │ │ │ -5.38 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 254 │ │ │ │ │ │ -5.39 siscone_error.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 255 │ │ │ │ │ │ -5.40 siscone_error.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 256 │ │ │ │ │ │ -5.41 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 257 │ │ │ │ │ │ -5.42 momentum.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258 │ │ │ │ │ │ +5.36 siscone.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 249 │ │ │ │ │ │ +5.37 siscone_error.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 253 │ │ │ │ │ │ +5.38 siscone_error.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 253 │ │ │ │ │ │ +5.39 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 254 │ │ │ │ │ │ +5.40 geom_2d.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 256 │ │ │ │ │ │ +5.41 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 256 │ │ │ │ │ │ +5.42 momentum.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 258 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ xvi │ │ │ │ │ │ │ │ │ │ │ │ -5.43 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 260 │ │ │ │ │ │ -5.44 protocones.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 262 │ │ │ │ │ │ +5.43 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 262 │ │ │ │ │ │ +5.44 siscone.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 263 │ │ │ │ │ │ 5.45 split_merge.cpp │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 264 │ │ │ │ │ │ │ │ │ │ │ │ 5.46 split_merge.cpp │ │ │ │ │ │ │ │ │ │ │ │ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 278 │ │ │ │ │ │ │ │ │ │ │ │ 5.47 split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 291 │ │ │ │ │ │ 5.48 split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 294 │ │ │ │ │ │ 5.49 vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 297 │ │ │ │ │ │ 5.50 vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 300 │ │ │ │ │ │ -5.51 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 304 │ │ │ │ │ │ +5.51 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303 │ │ │ │ │ │ 5.52 vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 305 │ │ │ │ │ │ Index │ │ │ │ │ │ │ │ │ │ │ │ 307 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ @@ -2026,46 +2026,46 @@ │ │ │ │ │ │ siscone/siscone_error.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/siscone_error.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/split_merge.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -185 │ │ │ │ │ │ 175 │ │ │ │ │ │ -176 │ │ │ │ │ │ -179 │ │ │ │ │ │ 180 │ │ │ │ │ │ -181 │ │ │ │ │ │ 182 │ │ │ │ │ │ -184 │ │ │ │ │ │ +185 │ │ │ │ │ │ +185 │ │ │ │ │ │ 187 │ │ │ │ │ │ +188 │ │ │ │ │ │ +189 │ │ │ │ │ │ +176 │ │ │ │ │ │ 191 │ │ │ │ │ │ 192 │ │ │ │ │ │ 193 │ │ │ │ │ │ 194 │ │ │ │ │ │ 195 │ │ │ │ │ │ 198 │ │ │ │ │ │ +254 │ │ │ │ │ │ 202 │ │ │ │ │ │ -204 │ │ │ │ │ │ -210 │ │ │ │ │ │ -211 │ │ │ │ │ │ -257 │ │ │ │ │ │ -217 │ │ │ │ │ │ -260 │ │ │ │ │ │ +207 │ │ │ │ │ │ +256 │ │ │ │ │ │ +209 │ │ │ │ │ │ +213 │ │ │ │ │ │ +232 │ │ │ │ │ │ 236 │ │ │ │ │ │ 239 │ │ │ │ │ │ 240 │ │ │ │ │ │ 242 │ │ │ │ │ │ 244 │ │ │ │ │ │ 245 │ │ │ │ │ │ 246 │ │ │ │ │ │ +262 │ │ │ │ │ │ +253 │ │ │ │ │ │ 253 │ │ │ │ │ │ -255 │ │ │ │ │ │ -256 │ │ │ │ │ │ 278 │ │ │ │ │ │ 294 │ │ │ │ │ │ 300 │ │ │ │ │ │ │ │ │ │ │ │ 6 │ │ │ │ │ │ │ │ │ │ │ │ File Index │ │ │ │ │ │ @@ -2084,27 +2084,27 @@ │ │ │ │ │ │ siscone/spherical/split_merge.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/split_merge.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/vicinity.cpp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ siscone/spherical/vicinity.h . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . │ │ │ │ │ │ │ │ │ │ │ │ 305 │ │ │ │ │ │ 200 │ │ │ │ │ │ -203 │ │ │ │ │ │ -207 │ │ │ │ │ │ -210 │ │ │ │ │ │ -213 │ │ │ │ │ │ +256 │ │ │ │ │ │ +205 │ │ │ │ │ │ +208 │ │ │ │ │ │ 258 │ │ │ │ │ │ -226 │ │ │ │ │ │ -262 │ │ │ │ │ │ -250 │ │ │ │ │ │ -254 │ │ │ │ │ │ +210 │ │ │ │ │ │ +222 │ │ │ │ │ │ +234 │ │ │ │ │ │ +249 │ │ │ │ │ │ +263 │ │ │ │ │ │ 264 │ │ │ │ │ │ 291 │ │ │ │ │ │ 297 │ │ │ │ │ │ -304 │ │ │ │ │ │ +303 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 4 │ │ │ │ │ │ │ │ │ │ │ │ Class Documentation │ │ │ │ │ │ │ │ │ │ │ │ @@ -10978,15 +10978,15 @@ │ │ │ │ │ │ • siscone/spherical/hash.h │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ Chapter 5 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ -5.1 main.cpp │ │ │ │ │ │ +5.1 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. │ │ │ │ │ │ // │ │ │ │ │ │ @@ -11021,14 +11021,846 @@ │ │ │ │ │ │ 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; │ │ │ │ │ │ +int i,N; │ │ │ │ │ │ +00041 │ │ │ │ │ │ +00042 │ │ │ │ │ │ +double px,py,pz,E; │ │ │ │ │ │ +00043 │ │ │ │ │ │ +Coptions opts; │ │ │ │ │ │ +char fline[512]; │ │ │ │ │ │ +00044 │ │ │ │ │ │ +00045 │ │ │ │ │ │ +if (opts.parse_options(argc, argv)) │ │ │ │ │ │ +00046 │ │ │ │ │ │ +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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 176 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00060 │ │ │ │ │ │ +// various files used to read input data and store results │ │ │ │ │ │ +00061 │ │ │ │ │ │ +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"); │ │ │ │ │ │ +if (flux==NULL){ │ │ │ │ │ │ +00068 │ │ │ │ │ │ +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)){ │ │ │ │ │ │ +if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ +00076 │ │ │ │ │ │ +00077 │ │ │ │ │ │ +if (sscanf(fline, "%le%le%le%le", &px, &py, &pz, &E)==4){ │ │ │ │ │ │ +00078 │ │ │ │ │ │ +particles.push_back(Cmomentum(px, py, pz, E)); │ │ │ │ │ │ +particles[N].eta, particles[N].phi); │ │ │ │ │ │ +00079 │ │ │ │ │ │ +fprintf(fpart, "%e\t%e\n", │ │ │ │ │ │ +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); │ │ │ │ │ │ +if (opts.verbose_flag) │ │ │ │ │ │ +00092 │ │ │ │ │ │ +00093 │ │ │ │ │ │ +cout « " working with " « N « " particles" « endl; │ │ │ │ │ │ +00094 │ │ │ │ │ │ +// compute jets │ │ │ │ │ │ +00095 │ │ │ │ │ │ +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); │ │ │ │ │ │ +if (opts.verbose_flag){ │ │ │ │ │ │ +00098 │ │ │ │ │ │ +unsigned int pass; │ │ │ │ │ │ +00099 │ │ │ │ │ │ +00100 │ │ │ │ │ │ +for (pass=0;pass::iterator ja; │ │ │ │ │ │ +for (ja=siscone_with_area.jet_areas.begin();ja!=siscone_with_area.jet_areas.end();ja++){ │ │ │ │ │ │ +00111 │ │ │ │ │ │ +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 │ │ │ │ │ │ +if (opts.verbose_flag) │ │ │ │ │ │ +00119 │ │ │ │ │ │ +00120 │ │ │ │ │ │ +cout « "bye..." « endl; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00122 │ │ │ │ │ │ +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 10 2023 17:32:40 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(){ │ │ │ │ │ │ +// 3600 particles added │ │ │ │ │ │ +00089 │ │ │ │ │ │ +grid_size = 60; │ │ │ │ │ │ +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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +177 │ │ │ │ │ │ + │ │ │ │ │ │ + 178 │ │ │ │ │ │ + │ │ │ │ │ │ +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. │ │ │ │ │ │ +list of particles │ │ │ │ │ │ +00109 * - _particles │ │ │ │ │ │ +00110 * - _radius │ │ │ │ │ │ +cone radius │ │ │ │ │ │ +shared energy threshold for splitting&merging │ │ │ │ │ │ +00111 * - _f │ │ │ │ │ │ +00112 * - _n_pass_max maximum number of passes (0=full search, the default) │ │ │ │ │ │ +the scale choice for the split-merge procedure │ │ │ │ │ │ +00113 * - _split_merge_scale │ │ │ │ │ │ +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(!) │ │ │ │ │ │ +SM_mt is IR safe for hadronic events, but not for decays of two │ │ │ │ │ │ +00116 * │ │ │ │ │ │ +00117 * │ │ │ │ │ │ +back-to-back particles of identical mass │ │ │ │ │ │ +SM_pttilde │ │ │ │ │ │ +00118 * │ │ │ │ │ │ +00119 * │ │ │ │ │ │ +is always IR safe, and also boost invariant (default) │ │ │ │ │ │ +when this is set on, only hard jets are computed │ │ │ │ │ │ +00120 * - _hard_only │ │ │ │ │ │ +and not the purely ghosted jets (default: false) │ │ │ │ │ │ +00121 * │ │ │ │ │ │ +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, │ │ │ │ │ │ +int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ +00126 │ │ │ │ │ │ +00127 │ │ │ │ │ │ +bool _hard_only){ │ │ │ │ │ │ +00128 │ │ │ │ │ │ +00129 │ │ │ │ │ │ +vector all_particles; │ │ │ │ │ │ +00130 │ │ │ │ │ │ +// put "hardest cut-off" if needed │ │ │ │ │ │ +00131 │ │ │ │ │ │ +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 │ │ │ │ │ │ +// clear potential previous runs │ │ │ │ │ │ +00138 │ │ │ │ │ │ +00139 │ │ │ │ │ │ +jet_areas.clear(); │ │ │ │ │ │ +00140 │ │ │ │ │ │ +// put initial set of particles in the list │ │ │ │ │ │ +00141 │ │ │ │ │ │ +00142 │ │ │ │ │ │ +int n_hard = _particles.size(); │ │ │ │ │ │ +00143 │ │ │ │ │ │ +all_particles = _particles; │ │ │ │ │ │ +00144 │ │ │ │ │ │ +// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ +00145 │ │ │ │ │ │ +00146 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +double eta_g,phi_g,pt_g; │ │ │ │ │ │ +00148 │ │ │ │ │ │ +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 │ │ │ │ │ │ +for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ +00170 │ │ │ │ │ │ +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 │ │ │ │ │ │ +// in the case of passive area, we do not need │ │ │ │ │ │ +00222 │ │ │ │ │ │ +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 │ │ │ │ │ │ +// clear potential previous runs │ │ │ │ │ │ +00228 │ │ │ │ │ │ +00229 │ │ │ │ │ │ +jet_areas.clear(); │ │ │ │ │ │ +00230 │ │ │ │ │ │ +// put initial set of particles in the list │ │ │ │ │ │ +00231 │ │ │ │ │ │ +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 │ │ │ │ │ │ +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); │ │ │ │ │ │ +for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ +00259 │ │ │ │ │ │ +00260 │ │ │ │ │ │ +j=0; │ │ │ │ │ │ +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 │ │ │ │ │ │ +// put "hardest cut-off" if needed │ │ │ │ │ │ +00297 │ │ │ │ │ │ +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 │ │ │ │ │ │ +// clear potential previous runs │ │ │ │ │ │ +00304 │ │ │ │ │ │ +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; │ │ │ │ │ │ +double eta_g,phi_g,pt_g; │ │ │ │ │ │ +00313 │ │ │ │ │ │ +00314 │ │ │ │ │ │ +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 │ │ │ │ │ │ +for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ +00336 │ │ │ │ │ │ +00337 │ │ │ │ │ │ +jet_areas.push_back(jets[i]); │ │ │ │ │ │ +00338 │ │ │ │ │ │ +j=0; │ │ │ │ │ │ +00339 │ │ │ │ │ │ +while ((j │ │ │ │ │ │ 00028 #include │ │ │ │ │ │ @@ -11041,57 +11873,50 @@ │ │ │ │ │ │ 00035 using namespace siscone; │ │ │ │ │ │ 00036 │ │ │ │ │ │ 00037 int main(int argc, char *argv[]){ │ │ │ │ │ │ 00038 │ │ │ │ │ │ vector particles; │ │ │ │ │ │ 00039 │ │ │ │ │ │ Csiscone siscone; │ │ │ │ │ │ -00040 │ │ │ │ │ │ int i,N; │ │ │ │ │ │ +00040 │ │ │ │ │ │ 00041 │ │ │ │ │ │ double px,py,pz,E; │ │ │ │ │ │ 00042 │ │ │ │ │ │ Coptions opts; │ │ │ │ │ │ char fline[512]; │ │ │ │ │ │ 00043 │ │ │ │ │ │ 00044 │ │ │ │ │ │ if (opts.parse_options(argc, argv)) │ │ │ │ │ │ 00045 │ │ │ │ │ │ 00046 │ │ │ │ │ │ exit(1); │ │ │ │ │ │ 00047 │ │ │ │ │ │ -00048 │ │ │ │ │ │ // deal with help message │ │ │ │ │ │ +00048 │ │ │ │ │ │ 00049 │ │ │ │ │ │ if (opts.help_flag){ │ │ │ │ │ │ 00050 │ │ │ │ │ │ opts.print_help(); │ │ │ │ │ │ 00051 │ │ │ │ │ │ exit(0); │ │ │ │ │ │ 00052 │ │ │ │ │ │ } │ │ │ │ │ │ 00053 │ │ │ │ │ │ -// deal with version flag │ │ │ │ │ │ 00054 │ │ │ │ │ │ +// deal with version flag │ │ │ │ │ │ 00055 │ │ │ │ │ │ if (opts.version_flag){ │ │ │ │ │ │ 00056 │ │ │ │ │ │ opts.print_version(); │ │ │ │ │ │ 00057 │ │ │ │ │ │ exit(0); │ │ │ │ │ │ 00058 │ │ │ │ │ │ } │ │ │ │ │ │ 00059 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 176 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00060 │ │ │ │ │ │ // various files used to read input data and store results │ │ │ │ │ │ 00061 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00062 │ │ │ │ │ │ FILE *fpart; │ │ │ │ │ │ 00063 │ │ │ │ │ │ @@ -11112,18 +11937,18 @@ │ │ │ │ │ │ 00071 │ │ │ │ │ │ } │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 │ │ │ │ │ │ N=0; │ │ │ │ │ │ 00074 │ │ │ │ │ │ fpart = fopen("particles.dat", "w+"); │ │ │ │ │ │ -00075 │ │ │ │ │ │ while ((opts.N_stop!=0) && (fgets(fline, 512, flux)!=NULL)){ │ │ │ │ │ │ -if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ +00075 │ │ │ │ │ │ 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)); │ │ │ │ │ │ particles[N].eta, particles[N].phi); │ │ │ │ │ │ 00079 │ │ │ │ │ │ fprintf(fpart, "%e\t%e\n", │ │ │ │ │ │ @@ -11147,43 +11972,52 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 00089 │ │ │ │ │ │ } │ │ │ │ │ │ 00090 │ │ │ │ │ │ fclose(flux); │ │ │ │ │ │ 00091 │ │ │ │ │ │ fclose(fpart); │ │ │ │ │ │ -if (opts.verbose_flag) │ │ │ │ │ │ 00092 │ │ │ │ │ │ +if (opts.verbose_flag) │ │ │ │ │ │ 00093 │ │ │ │ │ │ cout « " working with " « N « " particles" « endl; │ │ │ │ │ │ 00094 │ │ │ │ │ │ // compute jets │ │ │ │ │ │ 00095 │ │ │ │ │ │ 00096 │ │ │ │ │ │ if (opts.verbose_flag) cout « "computing jet contents" « endl; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +181 │ │ │ │ │ │ + │ │ │ │ │ │ + 182 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00097 │ │ │ │ │ │ i=siscone.compute_jets(particles, opts.R, opts.f, opts.npass, opts.ptmin, opts.SM_var); │ │ │ │ │ │ if (opts.verbose_flag){ │ │ │ │ │ │ 00098 │ │ │ │ │ │ -unsigned int pass; │ │ │ │ │ │ 00099 │ │ │ │ │ │ +unsigned int pass; │ │ │ │ │ │ 00100 │ │ │ │ │ │ for (pass=0;pass │ │ │ │ │ │ 00029 #include │ │ │ │ │ │ 00030 #include │ │ │ │ │ │ 00031 │ │ │ │ │ │ 00032 using namespace std; │ │ │ │ │ │ @@ -11278,161 +12109,154 @@ │ │ │ │ │ │ * │ │ │ │ │ │ 00045 * options for the ’cone’ sample │ │ │ │ │ │ * │ │ │ │ │ │ 00046 *******************************************/ │ │ │ │ │ │ 00047 │ │ │ │ │ │ 00048 // default ctor │ │ │ │ │ │ 00049 //-------------00050 Coptions::Coptions(){ │ │ │ │ │ │ -// set default flags values │ │ │ │ │ │ 00051 │ │ │ │ │ │ +// set default flags values │ │ │ │ │ │ 00052 │ │ │ │ │ │ help_flag=0; │ │ │ │ │ │ 00053 │ │ │ │ │ │ version_flag=0; │ │ │ │ │ │ 00054 │ │ │ │ │ │ verbose_flag=1; │ │ │ │ │ │ 00055 │ │ │ │ │ │ -// set default options values │ │ │ │ │ │ 00056 │ │ │ │ │ │ +// set default options values │ │ │ │ │ │ 00057 │ │ │ │ │ │ N_stop = N_DEFAULT; │ │ │ │ │ │ 00058 │ │ │ │ │ │ R = R_DEFAULT; │ │ │ │ │ │ 00059 │ │ │ │ │ │ f = THRESHOLD_DEFAULT; │ │ │ │ │ │ 00060 │ │ │ │ │ │ npass = NPASS_DEFAULT; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.4 options.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +183 │ │ │ │ │ │ + │ │ │ │ │ │ 00061 │ │ │ │ │ │ ev_name = NULL; │ │ │ │ │ │ 00062 │ │ │ │ │ │ SM_var = SM_DEFAULT; │ │ │ │ │ │ 00063 } │ │ │ │ │ │ 00064 │ │ │ │ │ │ 00065 │ │ │ │ │ │ 00066 // default dtor │ │ │ │ │ │ 00067 //-------------00068 Coptions::~Coptions(){ │ │ │ │ │ │ -00069 │ │ │ │ │ │ if (ev_name!=NULL) │ │ │ │ │ │ -delete[] ev_name; │ │ │ │ │ │ +00069 │ │ │ │ │ │ 00070 │ │ │ │ │ │ +delete[] ev_name; │ │ │ │ │ │ 00071 } │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 │ │ │ │ │ │ 00074 // parse oprions │ │ │ │ │ │ 00075 // - argc number of arguments from the command line │ │ │ │ │ │ 00076 // - argv arguments from the command line │ │ │ │ │ │ 00077 // return 1 on error, 0 on success │ │ │ │ │ │ 00078 //--------------------------------00079 int Coptions::parse_options(int argc, char **argv){ │ │ │ │ │ │ 00080 │ │ │ │ │ │ int opt_param; │ │ │ │ │ │ -00081 │ │ │ │ │ │ int option_index; │ │ │ │ │ │ -bool stop=false; │ │ │ │ │ │ +00081 │ │ │ │ │ │ 00082 │ │ │ │ │ │ +bool stop=false; │ │ │ │ │ │ 00083 │ │ │ │ │ │ -00084 │ │ │ │ │ │ // browse the command-line options{ │ │ │ │ │ │ +00084 │ │ │ │ │ │ 00085 │ │ │ │ │ │ static struct option siscone_options[]={ │ │ │ │ │ │ -00086 │ │ │ │ │ │ // options that set a flag │ │ │ │ │ │ +00086 │ │ │ │ │ │ 00087 │ │ │ │ │ │ {"verbose", no_argument, &verbose_flag, 1}, │ │ │ │ │ │ +no_argument, &verbose_flag, 0}, │ │ │ │ │ │ 00088 │ │ │ │ │ │ {"quiet", │ │ │ │ │ │ -no_argument, &verbose_flag, 0}, │ │ │ │ │ │ -no_argument, &help_flag │ │ │ │ │ │ -, 1}, │ │ │ │ │ │ 00089 │ │ │ │ │ │ {"help", │ │ │ │ │ │ +no_argument, &help_flag │ │ │ │ │ │ +, 1}, │ │ │ │ │ │ 00090 │ │ │ │ │ │ {"version", no_argument, &version_flag, 1}, │ │ │ │ │ │ -00091 │ │ │ │ │ │ // options setting parameters │ │ │ │ │ │ +00091 │ │ │ │ │ │ 00092 │ │ │ │ │ │ {"number", │ │ │ │ │ │ required_argument, NULL, ’N’}, │ │ │ │ │ │ +required_argument, NULL, ’R’}, │ │ │ │ │ │ 00093 │ │ │ │ │ │ {"radius", │ │ │ │ │ │ -required_argument, NULL, ’R’}, │ │ │ │ │ │ 00094 │ │ │ │ │ │ {"fraction", required_argument, NULL, ’f’}, │ │ │ │ │ │ 00095 │ │ │ │ │ │ {"ptmin", │ │ │ │ │ │ required_argument, NULL, ’p’}, │ │ │ │ │ │ required_argument, NULL, ’n’}, │ │ │ │ │ │ 00096 │ │ │ │ │ │ {"npass", │ │ │ │ │ │ 00097 │ │ │ │ │ │ {"event", │ │ │ │ │ │ required_argument, NULL, ’e’}, │ │ │ │ │ │ +required_argument, NULL, ’s’}, │ │ │ │ │ │ 00098 │ │ │ │ │ │ {"sm", │ │ │ │ │ │ -required_argument, NULL, ’s’}, │ │ │ │ │ │ 00099 │ │ │ │ │ │ {0,0,0,0} │ │ │ │ │ │ 00100 │ │ │ │ │ │ }; │ │ │ │ │ │ 00101 │ │ │ │ │ │ 00102 │ │ │ │ │ │ -do{ │ │ │ │ │ │ 00103 │ │ │ │ │ │ +do{ │ │ │ │ │ │ 00104 │ │ │ │ │ │ // getopt_long stores the option index here. │ │ │ │ │ │ 00105 │ │ │ │ │ │ option_index=0; │ │ │ │ │ │ 00106 │ │ │ │ │ │ // retreive options │ │ │ │ │ │ 00107 │ │ │ │ │ │ 00108 │ │ │ │ │ │ opt_param = getopt_long(argc, argv, "hvqN:R:f:p:n:e:s:", │ │ │ │ │ │ 00109 │ │ │ │ │ │ siscone_options, &option_index); │ │ │ │ │ │ 00110 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -177 │ │ │ │ │ │ - │ │ │ │ │ │ -$// │ │ │ │ │ │ -$// │ │ │ │ │ │ - │ │ │ │ │ │ - 178 │ │ │ │ │ │ - │ │ │ │ │ │ 00111 │ │ │ │ │ │ +// Detect the end of the options. │ │ │ │ │ │ 00112 │ │ │ │ │ │ +if (opt_param == -1) │ │ │ │ │ │ 00113 │ │ │ │ │ │ +stop=true; │ │ │ │ │ │ 00114 │ │ │ │ │ │ +// branch according to ’opt_param’ │ │ │ │ │ │ 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’ │ │ │ │ │ │ switch (opt_param){ │ │ │ │ │ │ case ’h’: help_flag = 1; │ │ │ │ │ │ break; // help │ │ │ │ │ │ +00117 │ │ │ │ │ │ +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); │ │ │ │ │ │ if (N_stop<=0){ │ │ │ │ │ │ +00122 │ │ │ │ │ │ +00123 │ │ │ │ │ │ cout « "Warning: the specified number of particles must be positive. Using default one" « │ │ │ │ │ │ endl; │ │ │ │ │ │ 00124 │ │ │ │ │ │ N_stop = N_DEFAULT; │ │ │ │ │ │ 00125 │ │ │ │ │ │ } │ │ │ │ │ │ break; │ │ │ │ │ │ @@ -11460,57 +12284,65 @@ │ │ │ │ │ │ 00137 │ │ │ │ │ │ cout « "Warning: the specified split/merge threshold must be in [0,1]. Using default one" « │ │ │ │ │ │ endl; │ │ │ │ │ │ 00138 │ │ │ │ │ │ f = THRESHOLD_DEFAULT; │ │ │ │ │ │ 00139 │ │ │ │ │ │ } │ │ │ │ │ │ -break; │ │ │ │ │ │ 00140 │ │ │ │ │ │ +break; │ │ │ │ │ │ case ’p’: │ │ │ │ │ │ 00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ sscanf(optarg, "%lf", &ptmin); │ │ │ │ │ │ -00143 │ │ │ │ │ │ if (ptmin<0){ │ │ │ │ │ │ +00143 │ │ │ │ │ │ 00144 │ │ │ │ │ │ cout « "Warning: the specified minimal pT must be non-negative. Using default one" « endl; │ │ │ │ │ │ 00145 │ │ │ │ │ │ ptmin = PTMIN_DEFAULT; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 184 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00146 │ │ │ │ │ │ -} │ │ │ │ │ │ -break; │ │ │ │ │ │ 00147 │ │ │ │ │ │ -case ’n’: // max number of paprticles │ │ │ │ │ │ 00148 │ │ │ │ │ │ 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 │ │ │ │ │ │ } │ │ │ │ │ │ break; │ │ │ │ │ │ 00154 │ │ │ │ │ │ 00155 │ │ │ │ │ │ case ’e’: │ │ │ │ │ │ -00156 │ │ │ │ │ │ if (ev_name==NULL){ │ │ │ │ │ │ +00156 │ │ │ │ │ │ 00157 │ │ │ │ │ │ ev_name = new char[strlen(optarg)+1]; │ │ │ │ │ │ 00158 │ │ │ │ │ │ strcpy(ev_name, optarg); │ │ │ │ │ │ 00159 │ │ │ │ │ │ } │ │ │ │ │ │ -break; │ │ │ │ │ │ 00160 │ │ │ │ │ │ +break; │ │ │ │ │ │ case ’s’: │ │ │ │ │ │ 00161 │ │ │ │ │ │ 00162 │ │ │ │ │ │ char tmp[512]; │ │ │ │ │ │ 00163 │ │ │ │ │ │ strcpy(tmp, optarg); │ │ │ │ │ │ if (strcmp(tmp, "pttilde")==0){ │ │ │ │ │ │ @@ -11534,63 +12366,56 @@ │ │ │ │ │ │ 00173 │ │ │ │ │ │ cout « "Warning: the specified varible for split--merge is not valid (should be pttilde, pt, │ │ │ │ │ │ mt or Et). Using pttilde as the default one." « endl; │ │ │ │ │ │ 00174 │ │ │ │ │ │ SM_var = SM_pttilde; │ │ │ │ │ │ 00175 │ │ │ │ │ │ } │ │ │ │ │ │ -00176 │ │ │ │ │ │ break; │ │ │ │ │ │ -case 0: │ │ │ │ │ │ +00176 │ │ │ │ │ │ 00177 │ │ │ │ │ │ +case 0: │ │ │ │ │ │ 00178 │ │ │ │ │ │ case -1: │ │ │ │ │ │ break; │ │ │ │ │ │ 00179 │ │ │ │ │ │ 00180 │ │ │ │ │ │ case ’?’: │ │ │ │ │ │ 00181 │ │ │ │ │ │ fprintf(stderr, "Giving up.\n"); │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00182 │ │ │ │ │ │ -00183 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ break; │ │ │ │ │ │ -default: │ │ │ │ │ │ +00183 │ │ │ │ │ │ 00184 │ │ │ │ │ │ +default: │ │ │ │ │ │ 00185 │ │ │ │ │ │ if (!help_flag){ │ │ │ │ │ │ 00186 │ │ │ │ │ │ fprintf(stderr, "unrecognized option %c. Giving up.\n", opt_param); │ │ │ │ │ │ 00187 │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00188 │ │ │ │ │ │ } │ │ │ │ │ │ 00189 │ │ │ │ │ │ } │ │ │ │ │ │ 00190 │ │ │ │ │ │ } while (!stop); │ │ │ │ │ │ 00191 │ │ │ │ │ │ -if (ev_name==NULL){ │ │ │ │ │ │ 00192 │ │ │ │ │ │ +if (ev_name==NULL){ │ │ │ │ │ │ 00193 │ │ │ │ │ │ ev_name = new char[strlen(DEFAULT_EVENT)+1]; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.3 options.h │ │ │ │ │ │ - │ │ │ │ │ │ -179 │ │ │ │ │ │ - │ │ │ │ │ │ 00194 │ │ │ │ │ │ strcpy(ev_name, DEFAULT_EVENT); │ │ │ │ │ │ 00195 │ │ │ │ │ │ } │ │ │ │ │ │ 00196 │ │ │ │ │ │ -00197 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00197 │ │ │ │ │ │ 00198 } │ │ │ │ │ │ 00199 │ │ │ │ │ │ 00200 │ │ │ │ │ │ 00201 // print the help message │ │ │ │ │ │ 00202 //-----------------------00203 int Coptions::print_help(){ │ │ │ │ │ │ 00204 │ │ │ │ │ │ cout « siscone_package_name() « " " « siscone_version() « endl; │ │ │ │ │ │ @@ -11612,20 +12437,20 @@ │ │ │ │ │ │ 00212 │ │ │ │ │ │ cout « " -p , --ptmin= │ │ │ │ │ │ endl; │ │ │ │ │ │ : set the maximal number of passes (0 for no limit) (" « │ │ │ │ │ │ 00213 │ │ │ │ │ │ cout « " -n , --npass= │ │ │ │ │ │ NPASS_DEFAULT « ")" « endl; │ │ │ │ │ │ +: set the event filename (" « DEFAULT_EVENT « ")" « endl; │ │ │ │ │ │ 00214 │ │ │ │ │ │ cout « " -e , --event= │ │ │ │ │ │ -: set the event filename (" « DEFAULT_EVENT « ")" « endl; │ │ │ │ │ │ -: variable for split--merge: pttilde, mt, pt or Et (pttilde)" « │ │ │ │ │ │ 00215 │ │ │ │ │ │ cout « " -s , --sm= │ │ │ │ │ │ +: variable for split--merge: pttilde, mt, pt or Et (pttilde)" « │ │ │ │ │ │ endl; │ │ │ │ │ │ 00216 │ │ │ │ │ │ cout « endl; │ │ │ │ │ │ 00217 │ │ │ │ │ │ cout « "Output flags" « endl; │ │ │ │ │ │ : show version information" « endl; │ │ │ │ │ │ 00218 │ │ │ │ │ │ @@ -11641,14 +12466,19 @@ │ │ │ │ │ │ cout « endl; │ │ │ │ │ │ 00223 │ │ │ │ │ │ 00224 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00225 } │ │ │ │ │ │ 00226 │ │ │ │ │ │ 00227 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 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 │ │ │ │ │ │ @@ -11666,18 +12496,18 @@ │ │ │ │ │ │ 00239 │ │ │ │ │ │ cout « "Please send bugs or comments to AUTHORS" « endl; │ │ │ │ │ │ 00240 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00241 │ │ │ │ │ │ 00242 } │ │ │ │ │ │ │ │ │ │ │ │ -5.3 options.h │ │ │ │ │ │ +5.5 options.h │ │ │ │ │ │ 00001 │ │ │ │ │ │ -// │ │ │ │ │ │ 00002 // File: options.h │ │ │ │ │ │ +// │ │ │ │ │ │ 00003 // Description: management of the cmdline options of the main program │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // │ │ │ │ │ │ @@ -11717,72 +12547,74 @@ │ │ │ │ │ │ $// │ │ │ │ │ │ 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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 180 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00030 #include "siscone/siscone.h" │ │ │ │ │ │ 00031 │ │ │ │ │ │ 00037 class Coptions{ │ │ │ │ │ │ 00038 public: │ │ │ │ │ │ 00040 │ │ │ │ │ │ Coptions(); │ │ │ │ │ │ 00041 │ │ │ │ │ │ 00043 │ │ │ │ │ │ ~Coptions(); │ │ │ │ │ │ 00044 │ │ │ │ │ │ 00049 │ │ │ │ │ │ int parse_options(int argc, char **argv); │ │ │ │ │ │ 00050 │ │ │ │ │ │ -00052 │ │ │ │ │ │ int print_help(); │ │ │ │ │ │ +00052 │ │ │ │ │ │ 00053 │ │ │ │ │ │ -int print_version(); │ │ │ │ │ │ 00055 │ │ │ │ │ │ +int print_version(); │ │ │ │ │ │ 00056 │ │ │ │ │ │ // flags │ │ │ │ │ │ 00057 │ │ │ │ │ │ 00058 │ │ │ │ │ │ int help_flag; │ │ │ │ │ │ -int version_flag; │ │ │ │ │ │ 00059 │ │ │ │ │ │ -00060 │ │ │ │ │ │ +int version_flag; │ │ │ │ │ │ int verbose_flag; │ │ │ │ │ │ +00060 │ │ │ │ │ │ 00061 │ │ │ │ │ │ -// options │ │ │ │ │ │ 00062 │ │ │ │ │ │ +// options │ │ │ │ │ │ 00063 │ │ │ │ │ │ int N_stop; │ │ │ │ │ │ 00064 │ │ │ │ │ │ double R; │ │ │ │ │ │ -00065 │ │ │ │ │ │ double f; │ │ │ │ │ │ -double ptmin; │ │ │ │ │ │ +00065 │ │ │ │ │ │ 00066 │ │ │ │ │ │ -00067 │ │ │ │ │ │ +double ptmin; │ │ │ │ │ │ char *ev_name; │ │ │ │ │ │ -int npass; │ │ │ │ │ │ +00067 │ │ │ │ │ │ 00068 │ │ │ │ │ │ +int npass; │ │ │ │ │ │ 00069 │ │ │ │ │ │ 00071 │ │ │ │ │ │ siscone::Esplit_merge_scale SM_var; │ │ │ │ │ │ 00072 }; │ │ │ │ │ │ 00073 │ │ │ │ │ │ 00074 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.4 sample.cpp │ │ │ │ │ │ +5.6 sample.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +185 │ │ │ │ │ │ + │ │ │ │ │ │ + 186 │ │ │ │ │ │ + │ │ │ │ │ │ +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 │ │ │ │ │ │ @@ -11827,16 +12659,16 @@ │ │ │ │ │ │ 00026 │ │ │ │ │ │ 00027 #include │ │ │ │ │ │ 00028 #include │ │ │ │ │ │ 00029 #include │ │ │ │ │ │ 00030 #include "siscone/momentum.h" │ │ │ │ │ │ 00031 #include "siscone/siscone.h" │ │ │ │ │ │ 00032 │ │ │ │ │ │ -00033 #define R │ │ │ │ │ │ 0.7 │ │ │ │ │ │ +00033 #define R │ │ │ │ │ │ 00034 #define f │ │ │ │ │ │ 0.5 │ │ │ │ │ │ 00035 #define f_alt 0.75 │ │ │ │ │ │ 00036 │ │ │ │ │ │ 00037 using namespace std; │ │ │ │ │ │ 00038 using namespace siscone; │ │ │ │ │ │ 00039 │ │ │ │ │ │ @@ -11856,121 +12688,122 @@ │ │ │ │ │ │ 00045 │ │ │ │ │ │ double px,py,pz,E; │ │ │ │ │ │ // particles 4-momentum │ │ │ │ │ │ 00046 │ │ │ │ │ │ char fline[512]; │ │ │ │ │ │ // line to read from a file │ │ │ │ │ │ 00047 │ │ │ │ │ │ -// read particles │ │ │ │ │ │ 00048 │ │ │ │ │ │ +// read particles │ │ │ │ │ │ 00049 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00050 │ │ │ │ │ │ flux = fopen("events/single-event.dat", "r"); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 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; │ │ │ │ │ │ +while (fgets(fline, 512, flux)!=NULL){ │ │ │ │ │ │ 00057 │ │ │ │ │ │ 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); │ │ │ │ │ │ +return 2; │ │ │ │ │ │ 00065 │ │ │ │ │ │ 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 │ │ │ │ │ │ +// then, recompute it with a different f │ │ │ │ │ │ 00076 │ │ │ │ │ │ 00077 │ │ │ │ │ │ +i=siscone.recompute_jets(f_alt); │ │ │ │ │ │ 00078 │ │ │ │ │ │ +cout « " " « i « " jets found with alternative f" « endl; │ │ │ │ │ │ 00079 │ │ │ │ │ │ +// one pass │ │ │ │ │ │ 00080 │ │ │ │ │ │ 00081 │ │ │ │ │ │ +i=siscone.compute_jets(particles, R, f, 1); │ │ │ │ │ │ 00082 │ │ │ │ │ │ +cout « " " « i « " jets found in single-pass run" « endl; │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00084 │ │ │ │ │ │ -00085 │ │ │ │ │ │ -00086 │ │ │ │ │ │ -00087 │ │ │ │ │ │ - │ │ │ │ │ │ -181 │ │ │ │ │ │ - │ │ │ │ │ │ -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; │ │ │ │ │ │ -fprintf(stdout, "# │ │ │ │ │ │ pT │ │ │ │ │ │ eta │ │ │ │ │ │ phi │ │ │ │ │ │ px │ │ │ │ │ │ py │ │ │ │ │ │ +00087 │ │ │ │ │ │ +fprintf(stdout, "# │ │ │ │ │ │ \n"); │ │ │ │ │ │ 00088 │ │ │ │ │ │ for (it_j = siscone.jets.begin(), i1=0 ; │ │ │ │ │ │ + │ │ │ │ │ │ +pz │ │ │ │ │ │ + │ │ │ │ │ │ +E │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 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 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ 00094 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ 00095 } │ │ │ │ │ │ │ │ │ │ │ │ -5.5 spherical.cpp │ │ │ │ │ │ +5.7 spherical.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ // │ │ │ │ │ │ 00002 // File: spherical.cpp │ │ │ │ │ │ 00003 // Description: example program for the CSphsiscone class (spherical SISCone)// │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // WARNING: this is not the main SISCone trunk but │ │ │ │ │ │ @@ -12020,27 +12853,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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -pz │ │ │ │ │ │ - │ │ │ │ │ │ -it_j->v.pz, │ │ │ │ │ │ - │ │ │ │ │ │ -E │ │ │ │ │ │ - │ │ │ │ │ │ - 182 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00035 #define R │ │ │ │ │ │ 0.7 │ │ │ │ │ │ 00036 #define f │ │ │ │ │ │ 0.5 │ │ │ │ │ │ 00037 #define f_alt 0.75 │ │ │ │ │ │ 00038 │ │ │ │ │ │ 00039 using namespace std; │ │ │ │ │ │ @@ -12061,16 +12881,16 @@ │ │ │ │ │ │ 00047 │ │ │ │ │ │ double px,py,pz,E; │ │ │ │ │ │ // particles 4-momentum │ │ │ │ │ │ 00048 │ │ │ │ │ │ char fline[512]; │ │ │ │ │ │ // line to read from a file │ │ │ │ │ │ 00049 │ │ │ │ │ │ -00050 │ │ │ │ │ │ // read particles │ │ │ │ │ │ +00050 │ │ │ │ │ │ 00051 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00052 │ │ │ │ │ │ flux = fopen("events/single-event.dat", "r"); │ │ │ │ │ │ if (flux==NULL){ │ │ │ │ │ │ 00053 │ │ │ │ │ │ 00054 │ │ │ │ │ │ @@ -12078,16 +12898,16 @@ │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00055 │ │ │ │ │ │ 00056 │ │ │ │ │ │ } │ │ │ │ │ │ 00057 │ │ │ │ │ │ 00058 │ │ │ │ │ │ N=0; │ │ │ │ │ │ -while (fgets(fline, 512, flux)!=NULL){ │ │ │ │ │ │ 00059 │ │ │ │ │ │ +while (fgets(fline, 512, flux)!=NULL){ │ │ │ │ │ │ if (fline[0]!=’#’){ // skip lines beginning with ’#’ │ │ │ │ │ │ 00060 │ │ │ │ │ │ 00061 │ │ │ │ │ │ if (sscanf(fline, "%le%le%le%le", &px, &py, &pz, &E)==4){ │ │ │ │ │ │ 00062 │ │ │ │ │ │ particles.push_back(CSphmomentum(px, py, pz, E)); │ │ │ │ │ │ 00063 │ │ │ │ │ │ @@ -12105,16 +12925,27 @@ │ │ │ │ │ │ 00069 │ │ │ │ │ │ } │ │ │ │ │ │ 00070 │ │ │ │ │ │ } │ │ │ │ │ │ 00071 │ │ │ │ │ │ fclose(flux); │ │ │ │ │ │ 00072 │ │ │ │ │ │ -// compute jets │ │ │ │ │ │ 00073 │ │ │ │ │ │ +// compute jets │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +187 │ │ │ │ │ │ + │ │ │ │ │ │ +it_j->v.pz, │ │ │ │ │ │ + │ │ │ │ │ │ + 188 │ │ │ │ │ │ + │ │ │ │ │ │ +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 │ │ │ │ │ │ @@ -12132,25 +12963,25 @@ │ │ │ │ │ │ 00084 │ │ │ │ │ │ cout « " " « i « " jets found in single-pass run" « endl; │ │ │ │ │ │ 00085 │ │ │ │ │ │ // show jets │ │ │ │ │ │ 00086 │ │ │ │ │ │ 00087 │ │ │ │ │ │ vector::iterator it_j; │ │ │ │ │ │ -int i1; │ │ │ │ │ │ 00088 │ │ │ │ │ │ +int i1; │ │ │ │ │ │ 00089 │ │ │ │ │ │ fprintf(stdout, "# │ │ │ │ │ │ theta │ │ │ │ │ │ phi │ │ │ │ │ │ px │ │ │ │ │ │ py │ │ │ │ │ │ pz │ │ │ │ │ │ -00090 │ │ │ │ │ │ for (it_j = siscone.jets.begin(), i1=0 ; │ │ │ │ │ │ +00090 │ │ │ │ │ │ 00091 │ │ │ │ │ │ it_j != siscone.jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00092 │ │ │ │ │ │ fprintf(stdout, "Jet %3d: %8.3f %8.3f %10.3f %10.3f %10.3f %10.3f\n", │ │ │ │ │ │ 00093 │ │ │ │ │ │ i1, it_j->v._theta, it_j->v._phi, it_j->v.px, it_j->v.py, it_j->v.pz, │ │ │ │ │ │ 00094 │ │ │ │ │ │ @@ -12162,58 +12993,49 @@ │ │ │ │ │ │ │ │ │ │ │ │ E │ │ │ │ │ │ │ │ │ │ │ │ \n"); │ │ │ │ │ │ │ │ │ │ │ │ it_j->v.E); │ │ │ │ │ │ │ │ │ │ │ │ -5.6 test.cpp │ │ │ │ │ │ +5.8 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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.6 test.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -183 │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -12256,56 +13078,63 @@ │ │ │ │ │ │ 00049 int main(int argc, char* argv[]){ │ │ │ │ │ │ 00050 │ │ │ │ │ │ vector particles; │ │ │ │ │ │ 00051 │ │ │ │ │ │ Cmomentum *v; │ │ │ │ │ │ double phi=0, eta=0, pt=1; │ │ │ │ │ │ 00052 │ │ │ │ │ │ -00053 │ │ │ │ │ │ unsigned int N; │ │ │ │ │ │ +00053 │ │ │ │ │ │ 00054 │ │ │ │ │ │ -unsigned int i; │ │ │ │ │ │ 00055 │ │ │ │ │ │ +unsigned int i; │ │ │ │ │ │ 00056 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00057 │ │ │ │ │ │ -if (argc==1){ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.9 times.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +189 │ │ │ │ │ │ + │ │ │ │ │ │ 00058 │ │ │ │ │ │ -00059 │ │ │ │ │ │ +if (argc==1){ │ │ │ │ │ │ //cout « "using default number of particles" « endl; │ │ │ │ │ │ +00059 │ │ │ │ │ │ 00060 │ │ │ │ │ │ N = N_default; │ │ │ │ │ │ 00061 │ │ │ │ │ │ } else { │ │ │ │ │ │ 00062 │ │ │ │ │ │ sscanf(argv[1], "%u", &N); │ │ │ │ │ │ -//cout « "using " « N « " particles" « endl; │ │ │ │ │ │ 00063 │ │ │ │ │ │ +//cout « "using " « N « " particles" « endl; │ │ │ │ │ │ 00064 │ │ │ │ │ │ } │ │ │ │ │ │ 00065 │ │ │ │ │ │ -// Initialise random number generator │ │ │ │ │ │ 00066 │ │ │ │ │ │ +// Initialise random number generator │ │ │ │ │ │ 00067 │ │ │ │ │ │ timeval timestamp; │ │ │ │ │ │ 00068 │ │ │ │ │ │ gettimeofday(×tamp, NULL); │ │ │ │ │ │ 00069 │ │ │ │ │ │ srand(timestamp.tv_usec); │ │ │ │ │ │ 00070 │ │ │ │ │ │ // build particle list │ │ │ │ │ │ 00071 │ │ │ │ │ │ 00072 │ │ │ │ │ │ cout « "build particle list" « endl; │ │ │ │ │ │ 00073 │ │ │ │ │ │ flux = fopen("particles.dat", "w+"); │ │ │ │ │ │ -00074 │ │ │ │ │ │ for (i=0;ieta, v->phi, v->perp()); │ │ │ │ │ │ 00112 │ │ │ │ │ │ } │ │ │ │ │ │ 00113 │ │ │ │ │ │ @@ -12385,48 +13207,56 @@ │ │ │ │ │ │ 00116 │ │ │ │ │ │ cout « "bye..." « endl; │ │ │ │ │ │ 00117 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00118 │ │ │ │ │ │ 00119 } │ │ │ │ │ │ │ │ │ │ │ │ -5.7 times.cpp │ │ │ │ │ │ +5.9 times.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ -// │ │ │ │ │ │ 00002 // File: times.cpp │ │ │ │ │ │ 00003 // Description: example program that computes execution times │ │ │ │ │ │ -// │ │ │ │ │ │ 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. │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ // │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 190 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 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 // │ │ │ │ │ │ @@ -12487,41 +13317,36 @@ │ │ │ │ │ │ 00062 │ │ │ │ │ │ 00063 │ │ │ │ │ │ 00064 int main(){ │ │ │ │ │ │ 00065 │ │ │ │ │ │ vector particles; │ │ │ │ │ │ 00066 │ │ │ │ │ │ Csiscone siscone; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.8 area.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00067 │ │ │ │ │ │ double eta,phi; │ │ │ │ │ │ 00068 │ │ │ │ │ │ // number of events and particles │ │ │ │ │ │ 00069 │ │ │ │ │ │ 00070 │ │ │ │ │ │ int i, N; │ │ │ │ │ │ -int n_ev, part_inc; │ │ │ │ │ │ 00071 │ │ │ │ │ │ +int n_ev, part_inc; │ │ │ │ │ │ 00072 │ │ │ │ │ │ // time statistics variables │ │ │ │ │ │ 00073 │ │ │ │ │ │ 00074 │ │ │ │ │ │ int time_siscone; │ │ │ │ │ │ 00075 │ │ │ │ │ │ // save files │ │ │ │ │ │ 00076 │ │ │ │ │ │ 00077 │ │ │ │ │ │ FILE *flux; │ │ │ │ │ │ 00078 │ │ │ │ │ │ -// initialise random number generator │ │ │ │ │ │ 00079 │ │ │ │ │ │ +// initialise random number generator │ │ │ │ │ │ 00080 │ │ │ │ │ │ cout « "initialise random number generator" « endl; │ │ │ │ │ │ 00081 │ │ │ │ │ │ timeval timestamp; │ │ │ │ │ │ 00082 │ │ │ │ │ │ 00083 │ │ │ │ │ │ gettimeofday(×tamp, NULL); │ │ │ │ │ │ @@ -12538,55 +13363,60 @@ │ │ │ │ │ │ do{ │ │ │ │ │ │ 00090 │ │ │ │ │ │ 00091 │ │ │ │ │ │ fprintf(stdout, "\r%5d particles\n", N); │ │ │ │ │ │ 00092 │ │ │ │ │ │ time_siscone=0; │ │ │ │ │ │ 00093 │ │ │ │ │ │ -for (n_ev=0;n_ev │ │ │ │ │ │ -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; │ │ │ │ │ │ -int i,N; │ │ │ │ │ │ -00041 │ │ │ │ │ │ -double px,py,pz,E; │ │ │ │ │ │ -00042 │ │ │ │ │ │ -00043 │ │ │ │ │ │ -Coptions opts; │ │ │ │ │ │ -char fline[512]; │ │ │ │ │ │ -00044 │ │ │ │ │ │ -00045 │ │ │ │ │ │ -00046 │ │ │ │ │ │ -if (opts.parse_options(argc, argv)) │ │ │ │ │ │ -00047 │ │ │ │ │ │ -exit(1); │ │ │ │ │ │ -00048 │ │ │ │ │ │ -// deal with help message │ │ │ │ │ │ -00049 │ │ │ │ │ │ -00050 │ │ │ │ │ │ -if (opts.help_flag){ │ │ │ │ │ │ -00051 │ │ │ │ │ │ -opts.print_help(); │ │ │ │ │ │ -00052 │ │ │ │ │ │ -exit(0); │ │ │ │ │ │ -00053 │ │ │ │ │ │ -} │ │ │ │ │ │ -00054 │ │ │ │ │ │ -// deal with version flag │ │ │ │ │ │ -00055 │ │ │ │ │ │ -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"); │ │ │ │ │ │ -if (flux==NULL){ │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00069 │ │ │ │ │ │ -cerr « "cannot read event" « endl; │ │ │ │ │ │ -return 1; │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 │ │ │ │ │ │ -} │ │ │ │ │ │ -00072 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -N=0; │ │ │ │ │ │ -00074 │ │ │ │ │ │ -fpart = fopen("particles.dat", "w+"); │ │ │ │ │ │ -while ((opts.N_stop!=0) && (fgets(fline, 512, flux)!=NULL)){ │ │ │ │ │ │ -00075 │ │ │ │ │ │ -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 │ │ │ │ │ │ -// compute jets │ │ │ │ │ │ -00095 │ │ │ │ │ │ -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){ │ │ │ │ │ │ -unsigned int pass; │ │ │ │ │ │ -00099 │ │ │ │ │ │ -00100 │ │ │ │ │ │ -for (pass=0;pass::iterator ja; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 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 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00122 │ │ │ │ │ │ -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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -187 │ │ │ │ │ │ - │ │ │ │ │ │ - 188 │ │ │ │ │ │ - │ │ │ │ │ │ -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 │ │ │ │ │ │ -shared energy threshold for splitting&merging │ │ │ │ │ │ -00111 * - _f │ │ │ │ │ │ -00112 * - _n_pass_max maximum number of passes (0=full search, the default) │ │ │ │ │ │ -the scale choice for the split-merge procedure │ │ │ │ │ │ -00113 * - _split_merge_scale │ │ │ │ │ │ -00114 * │ │ │ │ │ │ -NOTE: SM_pt leads to IR unsafety for some events with momentum conservation. │ │ │ │ │ │ -SM_Et is IR safe but not boost invariant and not implemented(!) │ │ │ │ │ │ -00115 * │ │ │ │ │ │ -00116 * │ │ │ │ │ │ -SM_mt is IR safe for hadronic events, but not for decays of two │ │ │ │ │ │ -00117 * │ │ │ │ │ │ -back-to-back particles of identical mass │ │ │ │ │ │ -SM_pttilde │ │ │ │ │ │ -00118 * │ │ │ │ │ │ -00119 * │ │ │ │ │ │ -is always IR safe, and also boost invariant (default) │ │ │ │ │ │ -when this is set on, only hard jets are computed │ │ │ │ │ │ -00120 * - _hard_only │ │ │ │ │ │ -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, │ │ │ │ │ │ -int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ -00126 │ │ │ │ │ │ -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 │ │ │ │ │ │ -// put initial set of particles in the list │ │ │ │ │ │ -00141 │ │ │ │ │ │ -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; │ │ │ │ │ │ -double eta_g,phi_g,pt_g; │ │ │ │ │ │ -00147 │ │ │ │ │ │ -00148 │ │ │ │ │ │ -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 │ │ │ │ │ │ -for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ -00170 │ │ │ │ │ │ -00171 │ │ │ │ │ │ -jet_areas.push_back(jets[i]); │ │ │ │ │ │ -00172 │ │ │ │ │ │ -j=0; │ │ │ │ │ │ -while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ -00218 │ │ │ │ │ │ -int _n_pass_max, Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ -00219 │ │ │ │ │ │ -00220 │ │ │ │ │ │ -vector all_particles; │ │ │ │ │ │ -00221 │ │ │ │ │ │ -// in the case of passive area, we do not need │ │ │ │ │ │ -00222 │ │ │ │ │ │ -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 │ │ │ │ │ │ -// clear potential previous runs │ │ │ │ │ │ -00228 │ │ │ │ │ │ -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 │ │ │ │ │ │ -// build the set of ghost particles and add them to the particle list │ │ │ │ │ │ -00235 │ │ │ │ │ │ -00236 │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ -00237 │ │ │ │ │ │ -double eta_g,phi_g,pt_g; │ │ │ │ │ │ -00238 │ │ │ │ │ │ -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; │ │ │ │ │ │ -while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ -00292 │ │ │ │ │ │ -int _n_pass_max, Esplit_merge_scale _split_merge_scale, │ │ │ │ │ │ -bool _hard_only){ │ │ │ │ │ │ -00293 │ │ │ │ │ │ -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 │ │ │ │ │ │ -// put initial set of particles in the list │ │ │ │ │ │ -00307 │ │ │ │ │ │ -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 │ │ │ │ │ │ -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 │ │ │ │ │ │ -for (i=0;i<(int) jets.size();i++){ │ │ │ │ │ │ -00336 │ │ │ │ │ │ -00337 │ │ │ │ │ │ -jet_areas.push_back(jets[i]); │ │ │ │ │ │ -00338 │ │ │ │ │ │ -j=0; │ │ │ │ │ │ -00339 │ │ │ │ │ │ -while ((j &_particles, double _radius, double _f, │ │ │ │ │ │ 00101 │ │ │ │ │ │ int _n_pass_max=0, Esplit_merge_scale _split_merge_scale=SM_pttilde, │ │ │ │ │ │ bool _hard_only=false); │ │ │ │ │ │ 00102 │ │ │ │ │ │ 00103 │ │ │ │ │ │ -00112 │ │ │ │ │ │ int compute_active_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ -int _n_pass_max=0, Esplit_merge_scale _split_merge_scale=SM_pttilde, │ │ │ │ │ │ +00112 │ │ │ │ │ │ 00113 │ │ │ │ │ │ +int _n_pass_max=0, Esplit_merge_scale _split_merge_scale=SM_pttilde, │ │ │ │ │ │ bool _hard_only=false); │ │ │ │ │ │ 00114 │ │ │ │ │ │ +00115 │ │ │ │ │ │ +int compute_passive_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ +00123 │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 191 │ │ │ │ │ │ │ │ │ │ │ │ 192 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00115 │ │ │ │ │ │ -int compute_passive_areas(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ -00123 │ │ │ │ │ │ 00124 │ │ │ │ │ │ int _n_pass_max=0, Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ 00125 │ │ │ │ │ │ int grid_size; │ │ │ │ │ │ 00126 │ │ │ │ │ │ 00127 │ │ │ │ │ │ double grid_eta_max; │ │ │ │ │ │ double grid_shift; │ │ │ │ │ │ 00128 │ │ │ │ │ │ 00129 │ │ │ │ │ │ double pt_soft; │ │ │ │ │ │ 00130 │ │ │ │ │ │ 00131 │ │ │ │ │ │ double pt_shift; │ │ │ │ │ │ -00132 │ │ │ │ │ │ double pt_soft_min; │ │ │ │ │ │ +00132 │ │ │ │ │ │ 00133 │ │ │ │ │ │ 00135 │ │ │ │ │ │ std::vector jet_areas; │ │ │ │ │ │ 00136 }; │ │ │ │ │ │ 00137 │ │ │ │ │ │ 00138 } │ │ │ │ │ │ 00139 #endif │ │ │ │ │ │ @@ -13649,36 +13643,36 @@ │ │ │ │ │ │ 00066 │ │ │ │ │ │ 00068 │ │ │ │ │ │ inline circulator & operator--() { │ │ │ │ │ │ if (m_here == m_begin) m_here = m_end; │ │ │ │ │ │ 00069 │ │ │ │ │ │ 00070 │ │ │ │ │ │ --m_here; │ │ │ │ │ │ -00071 │ │ │ │ │ │ return *this; │ │ │ │ │ │ +00071 │ │ │ │ │ │ 00072 │ │ │ │ │ │ } │ │ │ │ │ │ 00073 │ │ │ │ │ │ 00077 │ │ │ │ │ │ bool operator==(const circulator & other) const {return m_here == other.m_here;} │ │ │ │ │ │ 00078 │ │ │ │ │ │ bool operator!=(const circulator & other) const {return m_here != other.m_here;} │ │ │ │ │ │ 00082 │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00084 private: │ │ │ │ │ │ 00085 │ │ │ │ │ │ T m_here, m_begin, m_end; │ │ │ │ │ │ 00086 }; │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00088 } │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 5.12 config.h │ │ │ │ │ │ │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00088 } │ │ │ │ │ │ 00089 │ │ │ │ │ │ 00090 #endif // __CIRCULATOR_H__ │ │ │ │ │ │ │ │ │ │ │ │ 5.12 config.h │ │ │ │ │ │ 00001 #ifndef _SISCONE_CONFIG_H │ │ │ │ │ │ 00002 #define _SISCONE_CONFIG_H 1 │ │ │ │ │ │ 00003 │ │ │ │ │ │ @@ -13751,25 +13745,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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 193 │ │ │ │ │ │ │ │ │ │ │ │ 194 │ │ │ │ │ │ │ │ │ │ │ │ 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" │ │ │ │ │ │ @@ -13809,15 +13803,15 @@ │ │ │ │ │ │ 00117 #define SISCONE_VERSION "3.0.5" │ │ │ │ │ │ 00118 #endif │ │ │ │ │ │ 00119 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -13844,25 +13838,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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 5.14 siscone/defines.h File Reference │ │ │ │ │ │ │ │ │ │ │ │ 195 │ │ │ │ │ │ │ │ │ │ │ │ -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 "" │ │ │ │ │ │ @@ -14703,343 +14695,36 @@ │ │ │ │ │ │ 00174 │ │ │ │ │ │ return tmp; │ │ │ │ │ │ 00175 │ │ │ │ │ │ 00176 } │ │ │ │ │ │ 00177 │ │ │ │ │ │ 00178 } │ │ │ │ │ │ │ │ │ │ │ │ -5.18 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 // │ │ │ │ │ │ -// │ │ │ │ │ │ -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:: 422 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00025 // $Date:: 2020-04-22 11:51:09 +0200 (Wed, 22 Apr 2020) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 │ │ │ │ │ │ -00028 #ifndef __GEOM_2D_H__ │ │ │ │ │ │ -00029 #define __GEOM_2D_H__ │ │ │ │ │ │ -00030 │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ -00032 #include │ │ │ │ │ │ -00033 #include "defines.h" │ │ │ │ │ │ -00034 │ │ │ │ │ │ -00035 #ifndef M_PI │ │ │ │ │ │ -00036 #define M_PI 3.141592653589793238462643383279502884197 │ │ │ │ │ │ -00037 #endif │ │ │ │ │ │ -00038 │ │ │ │ │ │ -00039 namespace siscone{ │ │ │ │ │ │ -00040 │ │ │ │ │ │ -00043 inline double phi_in_range(double phi) { │ │ │ │ │ │ -00044 │ │ │ │ │ │ -if │ │ │ │ │ │ -(phi <= -M_PI) phi += twopi; │ │ │ │ │ │ -else if (phi > │ │ │ │ │ │ -M_PI) phi -= twopi; │ │ │ │ │ │ -00045 │ │ │ │ │ │ -return phi; │ │ │ │ │ │ -00046 │ │ │ │ │ │ -00047 } │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.19 geom_2d.h │ │ │ │ │ │ - │ │ │ │ │ │ -203 │ │ │ │ │ │ - │ │ │ │ │ │ -00048 │ │ │ │ │ │ -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) { │ │ │ │ │ │ -00061 │ │ │ │ │ │ -double delta = fabs(phi1-phi2); │ │ │ │ │ │ -return delta > M_PI ? twopi-delta : delta; │ │ │ │ │ │ -00062 │ │ │ │ │ │ -00063 } │ │ │ │ │ │ -00064 │ │ │ │ │ │ -00066 inline double pow2(double x) {return x*x;} │ │ │ │ │ │ -00067 │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00073 class Ctwovect { │ │ │ │ │ │ -00074 public: │ │ │ │ │ │ -00076 │ │ │ │ │ │ -Ctwovect() : x(0.0), y(0.0) {} │ │ │ │ │ │ -00077 │ │ │ │ │ │ -00081 │ │ │ │ │ │ -Ctwovect(double _x, double _y) : x(_x), y(_y) {} │ │ │ │ │ │ -00082 │ │ │ │ │ │ -double x, y; │ │ │ │ │ │ -00084 │ │ │ │ │ │ -00085 │ │ │ │ │ │ -00087 │ │ │ │ │ │ -inline double mod2() const {return pow2(x)+pow2(y);} │ │ │ │ │ │ -00088 │ │ │ │ │ │ -inline double modulus() const {return sqrt(mod2());} │ │ │ │ │ │ -00090 │ │ │ │ │ │ -00091 }; │ │ │ │ │ │ -00092 │ │ │ │ │ │ -00093 │ │ │ │ │ │ -00098 inline double dot_product(const Ctwovect & a, const Ctwovect & b) { │ │ │ │ │ │ -00099 │ │ │ │ │ │ -return a.x*b.x + a.y*b.y; │ │ │ │ │ │ -00100 } │ │ │ │ │ │ -00101 │ │ │ │ │ │ -00102 │ │ │ │ │ │ -00107 inline double cross_product(const Ctwovect & a, const Ctwovect & b) { │ │ │ │ │ │ -00108 │ │ │ │ │ │ -return a.x*b.y - a.y*b.x; │ │ │ │ │ │ -00109 } │ │ │ │ │ │ -00110 │ │ │ │ │ │ -00111 │ │ │ │ │ │ -00120 class Ceta_phi_range{ │ │ │ │ │ │ -00121 public: │ │ │ │ │ │ -00123 │ │ │ │ │ │ -Ceta_phi_range(); │ │ │ │ │ │ -00124 │ │ │ │ │ │ -00130 │ │ │ │ │ │ -Ceta_phi_range(double c_eta, double c_phi, double R); │ │ │ │ │ │ -00131 │ │ │ │ │ │ -00134 │ │ │ │ │ │ -Ceta_phi_range& operator = (const Ceta_phi_range &r); │ │ │ │ │ │ -00135 │ │ │ │ │ │ -int add_particle(const double eta, const double phi); │ │ │ │ │ │ -00140 │ │ │ │ │ │ -00141 │ │ │ │ │ │ -00143 │ │ │ │ │ │ -unsigned int eta_range; │ │ │ │ │ │ -00144 │ │ │ │ │ │ -unsigned int phi_range; │ │ │ │ │ │ -00146 │ │ │ │ │ │ -00147 │ │ │ │ │ │ -// extremal value for eta │ │ │ │ │ │ -00148 │ │ │ │ │ │ -00149 │ │ │ │ │ │ -static double eta_min; │ │ │ │ │ │ -00150 │ │ │ │ │ │ -static double eta_max; │ │ │ │ │ │ -00151 │ │ │ │ │ │ -00152 private: │ │ │ │ │ │ -00154 │ │ │ │ │ │ -inline unsigned int get_eta_cell(double eta){ │ │ │ │ │ │ -return (unsigned int) (1u « ((int) (32*((eta-eta_min)/(eta_max-eta_min))))); │ │ │ │ │ │ -00155 │ │ │ │ │ │ -00156 │ │ │ │ │ │ -} │ │ │ │ │ │ -00157 │ │ │ │ │ │ -00159 │ │ │ │ │ │ -inline unsigned int get_phi_cell(double phi){ │ │ │ │ │ │ -00160 │ │ │ │ │ │ -return (unsigned int) (1u « ((int) (32*phi/twopi+16)%32)); │ │ │ │ │ │ -00161 │ │ │ │ │ │ -} │ │ │ │ │ │ -00162 }; │ │ │ │ │ │ -00163 │ │ │ │ │ │ -00168 bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2); │ │ │ │ │ │ -00169 │ │ │ │ │ │ -00175 const Ceta_phi_range range_union(const Ceta_phi_range &r1, const Ceta_phi_range &r2); │ │ │ │ │ │ -00176 │ │ │ │ │ │ -00177 } │ │ │ │ │ │ -00178 │ │ │ │ │ │ -00179 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.19 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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 204 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -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:: 422 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00027 // $Date:: 2020-04-22 11:51:09 +0200 (Wed, 22 Apr 2020) │ │ │ │ │ │ -$// │ │ │ │ │ │ -00029 │ │ │ │ │ │ -00030 #ifndef __SPH_GEOM_2D_H__ │ │ │ │ │ │ -00031 #define __SPH_GEOM_2D_H__ │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 #include │ │ │ │ │ │ -00034 #include │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include │ │ │ │ │ │ -00037 │ │ │ │ │ │ -00038 #ifndef M_PI │ │ │ │ │ │ -00039 #define M_PI 3.141592653589793238462643383279502884197 │ │ │ │ │ │ -00040 #endif │ │ │ │ │ │ -00041 │ │ │ │ │ │ -00042 namespace siscone_spherical{ │ │ │ │ │ │ -00043 │ │ │ │ │ │ -00052 class CSphtheta_phi_range{ │ │ │ │ │ │ -00053 public: │ │ │ │ │ │ -00055 │ │ │ │ │ │ -CSphtheta_phi_range(); │ │ │ │ │ │ -00056 │ │ │ │ │ │ -00062 │ │ │ │ │ │ -CSphtheta_phi_range(double c_theta, double c_phi, double R); │ │ │ │ │ │ -00063 │ │ │ │ │ │ -00066 │ │ │ │ │ │ -CSphtheta_phi_range& operator = (const CSphtheta_phi_range &r); │ │ │ │ │ │ -00067 │ │ │ │ │ │ -int add_particle(const double theta, const double phi); │ │ │ │ │ │ -00072 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -unsigned int theta_range; │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -unsigned int phi_range; │ │ │ │ │ │ -00078 │ │ │ │ │ │ -00079 │ │ │ │ │ │ -00081 │ │ │ │ │ │ -static double theta_min; │ │ │ │ │ │ -static double theta_max; │ │ │ │ │ │ -00082 │ │ │ │ │ │ -00083 │ │ │ │ │ │ -00084 private: │ │ │ │ │ │ -00086 │ │ │ │ │ │ -inline unsigned int get_theta_cell(double theta){ │ │ │ │ │ │ -if (theta>=theta_max) return 1u«31; │ │ │ │ │ │ -00087 │ │ │ │ │ │ -00088 │ │ │ │ │ │ -return (unsigned int) (1u « ((int) (32*((theta-theta_min)/(theta_max-theta_min))))); │ │ │ │ │ │ -00089 │ │ │ │ │ │ -} │ │ │ │ │ │ -00090 │ │ │ │ │ │ -00092 │ │ │ │ │ │ -inline unsigned int get_phi_cell(double phi){ │ │ │ │ │ │ -return (unsigned int) (1u « ((int) (32*phi/twopi+16)%32)); │ │ │ │ │ │ -00093 │ │ │ │ │ │ -00094 │ │ │ │ │ │ -} │ │ │ │ │ │ -00095 }; │ │ │ │ │ │ -00096 │ │ │ │ │ │ -00101 bool is_range_overlap(const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2); │ │ │ │ │ │ -00102 │ │ │ │ │ │ -00108 const CSphtheta_phi_range range_union(const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2); │ │ │ │ │ │ -00109 │ │ │ │ │ │ -00110 } │ │ │ │ │ │ -00111 │ │ │ │ │ │ -00112 #endif │ │ │ │ │ │ - │ │ │ │ │ │ -5.20 hash.cpp │ │ │ │ │ │ +5.18 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 │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ // │ │ │ │ │ │ +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 │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.20 hash.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -15080,43 +14765,48 @@ │ │ │ │ │ │ * │ │ │ │ │ │ 00040 * functions to manipulate them. │ │ │ │ │ │ * │ │ │ │ │ │ 00041 **************************************************************/ │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 // constructor with initialisation │ │ │ │ │ │ 00044 // - _Np number of particles │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.18 hash.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00045 // - _R2 cone radius (squared) │ │ │ │ │ │ 00046 //----------------------------------00047 hash_cones::hash_cones(int _Np, double _R2){ │ │ │ │ │ │ -int i; │ │ │ │ │ │ 00048 │ │ │ │ │ │ +int i; │ │ │ │ │ │ 00049 │ │ │ │ │ │ 00050 │ │ │ │ │ │ n_cones = 0; │ │ │ │ │ │ 00051 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00052 │ │ │ │ │ │ n_occupied_cells = 0; │ │ │ │ │ │ 00053 #endif │ │ │ │ │ │ 00054 │ │ │ │ │ │ -// determine hash size │ │ │ │ │ │ 00055 │ │ │ │ │ │ +// determine hash size │ │ │ │ │ │ 00056 │ │ │ │ │ │ // for a ymax=5 and R=0.7, we observed an occupancy around 1/8 N^2 ~ N2 R2/4 │ │ │ │ │ │ 00057 │ │ │ │ │ │ //mask = 1 « (int) (2*log(double(_Np))/log(2.0)); │ │ │ │ │ │ 00058 │ │ │ │ │ │ //if (mask<=1) mask=2; │ │ │ │ │ │ 00059 │ │ │ │ │ │ int nbits = (int) (log(_Np*_R2*_Np/4.0)/log(2.0)); │ │ │ │ │ │ 00060 │ │ │ │ │ │ if (nbits<1) nbits=1; │ │ │ │ │ │ 00061 │ │ │ │ │ │ mask = 1 « nbits; │ │ │ │ │ │ 00062 │ │ │ │ │ │ -00063 │ │ │ │ │ │ // create hash │ │ │ │ │ │ +00063 │ │ │ │ │ │ 00064 │ │ │ │ │ │ hash_array = new hash_element*[mask]; │ │ │ │ │ │ 00065 │ │ │ │ │ │ mask--; │ │ │ │ │ │ 00066 │ │ │ │ │ │ 00067 │ │ │ │ │ │ // set the array to 0 │ │ │ │ │ │ @@ -15129,59 +14819,50 @@ │ │ │ │ │ │ 00071 │ │ │ │ │ │ 00072 │ │ │ │ │ │ R2 = _R2; │ │ │ │ │ │ 00073 } │ │ │ │ │ │ 00074 │ │ │ │ │ │ 00075 // destructor │ │ │ │ │ │ 00076 //-----------00077 hash_cones::~hash_cones(){ │ │ │ │ │ │ -int i; │ │ │ │ │ │ 00078 │ │ │ │ │ │ +int i; │ │ │ │ │ │ 00079 │ │ │ │ │ │ hash_element *elm; │ │ │ │ │ │ 00080 │ │ │ │ │ │ 00081 │ │ │ │ │ │ for (i=0;inext; │ │ │ │ │ │ -delete elm; │ │ │ │ │ │ 00085 │ │ │ │ │ │ +delete elm; │ │ │ │ │ │ 00086 │ │ │ │ │ │ } │ │ │ │ │ │ 00087 │ │ │ │ │ │ } │ │ │ │ │ │ 00088 │ │ │ │ │ │ -00089 │ │ │ │ │ │ delete[] hash_array; │ │ │ │ │ │ +00089 │ │ │ │ │ │ 00090 } │ │ │ │ │ │ 00091 │ │ │ │ │ │ 00092 │ │ │ │ │ │ 00093 /* │ │ │ │ │ │ 00094 * insert a new candidate into the hash. │ │ │ │ │ │ -00095 * - v │ │ │ │ │ │ 4-momentum of the cone to add │ │ │ │ │ │ +00095 * - v │ │ │ │ │ │ 00096 * - parent parent particle defining the cone │ │ │ │ │ │ child particle defining the cone │ │ │ │ │ │ 00097 * - child │ │ │ │ │ │ 00098 * - p_io │ │ │ │ │ │ whether the parent has to belong to the cone or not │ │ │ │ │ │ -whether the child has to belong to the cone or not │ │ │ │ │ │ 00099 * - c_io │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -205 │ │ │ │ │ │ - │ │ │ │ │ │ - 206 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +whether the child has to belong to the cone or not │ │ │ │ │ │ 00100 * return 0 on success, 1 on error │ │ │ │ │ │ 00101 ***********************************************************************/ │ │ │ │ │ │ 00102 int hash_cones::insert(Cmomentum *v, Cmomentum *parent, Cmomentum *child, bool p_io, bool c_io){ │ │ │ │ │ │ 00103 │ │ │ │ │ │ hash_element *elm; │ │ │ │ │ │ int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ 00104 │ │ │ │ │ │ @@ -15196,20 +14877,20 @@ │ │ │ │ │ │ if (elm==NULL) │ │ │ │ │ │ 00111 │ │ │ │ │ │ n_occupied_cells++; │ │ │ │ │ │ 00112 #endif │ │ │ │ │ │ 00113 │ │ │ │ │ │ 00114 │ │ │ │ │ │ do{ │ │ │ │ │ │ -00115 │ │ │ │ │ │ // if it is not present, add it │ │ │ │ │ │ +00115 │ │ │ │ │ │ 00116 │ │ │ │ │ │ if (elm==NULL){ │ │ │ │ │ │ -00117 │ │ │ │ │ │ // create element │ │ │ │ │ │ +00117 │ │ │ │ │ │ 00118 │ │ │ │ │ │ elm = new hash_element; │ │ │ │ │ │ 00119 │ │ │ │ │ │ // set its varibles │ │ │ │ │ │ 00120 │ │ │ │ │ │ 00121 │ │ │ │ │ │ // Note: at this level, eta and phi have already been computed │ │ │ │ │ │ @@ -15223,22 +14904,31 @@ │ │ │ │ │ │ 00125 │ │ │ │ │ │ 00126 │ │ │ │ │ │ v->build_etaphi(); │ │ │ │ │ │ 00127 │ │ │ │ │ │ elm->eta = v->eta; │ │ │ │ │ │ 00128 │ │ │ │ │ │ elm->phi = v->phi; │ │ │ │ │ │ -00129 │ │ │ │ │ │ // if at least one of the two is_inside tests gives a result != from the expected, │ │ │ │ │ │ +00129 │ │ │ │ │ │ 00130 │ │ │ │ │ │ // the || will be true hence !(...) false as wanted │ │ │ │ │ │ 00131 │ │ │ │ │ │ elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io)); │ │ │ │ │ │ -//cout « "-- new status of " « v->ref[0] « ":" « elm->is_stable « endl; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +203 │ │ │ │ │ │ + │ │ │ │ │ │ + 204 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00132 │ │ │ │ │ │ +//cout « "-- new status of " « v->ref[0] « ":" « elm->is_stable « endl; │ │ │ │ │ │ 00133 │ │ │ │ │ │ 00134 │ │ │ │ │ │ // update hash │ │ │ │ │ │ 00135 │ │ │ │ │ │ elm->next = hash_array[index]; │ │ │ │ │ │ 00136 │ │ │ │ │ │ hash_array[index] = elm; │ │ │ │ │ │ @@ -15250,16 +14940,16 @@ │ │ │ │ │ │ 00140 │ │ │ │ │ │ } │ │ │ │ │ │ 00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ // if the cone is already there, simply update stability status │ │ │ │ │ │ 00143 │ │ │ │ │ │ if (v->ref == elm->ref){ │ │ │ │ │ │ -// there is only an update to perform to see if the cone is still stable │ │ │ │ │ │ 00144 │ │ │ │ │ │ +// there is only an update to perform to see if the cone is still stable │ │ │ │ │ │ 00145 │ │ │ │ │ │ if (elm->is_stable){ │ │ │ │ │ │ 00146 │ │ │ │ │ │ v->build_etaphi(); │ │ │ │ │ │ 00147 │ │ │ │ │ │ elm->is_stable = !((is_inside(v, parent)^p_io)||(is_inside(v, child)^c_io)); │ │ │ │ │ │ 00148 │ │ │ │ │ │ @@ -15274,102 +14964,95 @@ │ │ │ │ │ │ //cout « "-- rep status of " « v->ref[0] « ":" « elm->is_stable « endl; │ │ │ │ │ │ 00152 │ │ │ │ │ │ //cout « v->eta « " " « v->phi « endl; │ │ │ │ │ │ 00153 │ │ │ │ │ │ //cout « (child->eta) « " " « child->phi « endl; │ │ │ │ │ │ 00154 │ │ │ │ │ │ } │ │ │ │ │ │ -00155 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00155 │ │ │ │ │ │ 00156 │ │ │ │ │ │ } │ │ │ │ │ │ 00157 │ │ │ │ │ │ 00158 │ │ │ │ │ │ elm = elm->next; │ │ │ │ │ │ 00159 │ │ │ │ │ │ } while (1); │ │ │ │ │ │ 00160 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00161 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00162 } │ │ │ │ │ │ 00163 │ │ │ │ │ │ 00164 /* │ │ │ │ │ │ 00165 * insert a new candidate into the hash. │ │ │ │ │ │ -00166 * - v │ │ │ │ │ │ 4-momentum of te cone to add │ │ │ │ │ │ +00166 * - v │ │ │ │ │ │ 00167 * Note, in this case, we assume stability. We also assume │ │ │ │ │ │ 00168 * that eta and phi are computed for v │ │ │ │ │ │ 00169 * return 0 on success, 1 on error │ │ │ │ │ │ 00170 ***********************************************************************/ │ │ │ │ │ │ 00171 int hash_cones::insert(Cmomentum *v){ │ │ │ │ │ │ 00172 │ │ │ │ │ │ hash_element *elm; │ │ │ │ │ │ -int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ 00173 │ │ │ │ │ │ -00174 │ │ │ │ │ │ +int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ //cout « "-- stable candidate: " « v->ref[0] « ":" « endl; │ │ │ │ │ │ +00174 │ │ │ │ │ │ 00175 │ │ │ │ │ │ -00176 │ │ │ │ │ │ // check the array cell corresponding to our reference │ │ │ │ │ │ +00176 │ │ │ │ │ │ 00177 │ │ │ │ │ │ elm = hash_array[index]; │ │ │ │ │ │ -00178 │ │ │ │ │ │ do{ │ │ │ │ │ │ -// if it is not present, add it │ │ │ │ │ │ +00178 │ │ │ │ │ │ 00179 │ │ │ │ │ │ +// if it is not present, add it │ │ │ │ │ │ 00180 │ │ │ │ │ │ if (elm==NULL){ │ │ │ │ │ │ -00181 │ │ │ │ │ │ // create element │ │ │ │ │ │ +00181 │ │ │ │ │ │ 00182 │ │ │ │ │ │ elm = new hash_element; │ │ │ │ │ │ 00183 │ │ │ │ │ │ -00184 │ │ │ │ │ │ // set its varibles │ │ │ │ │ │ +00184 │ │ │ │ │ │ 00185 │ │ │ │ │ │ // Note: at this level, eta and phi have already been computed │ │ │ │ │ │ 00186 │ │ │ │ │ │ // │ │ │ │ │ │ through Cmomentum::build_etaphi. │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.21 hash.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -207 │ │ │ │ │ │ - │ │ │ │ │ │ 00187 │ │ │ │ │ │ elm->ref = v->ref; │ │ │ │ │ │ 00188 │ │ │ │ │ │ elm->eta = v->eta; │ │ │ │ │ │ 00189 │ │ │ │ │ │ elm->phi = v->phi; │ │ │ │ │ │ 00190 │ │ │ │ │ │ elm->is_stable = true; │ │ │ │ │ │ 00191 │ │ │ │ │ │ -// update hash │ │ │ │ │ │ 00192 │ │ │ │ │ │ +// update hash │ │ │ │ │ │ 00193 │ │ │ │ │ │ elm->next = hash_array[index]; │ │ │ │ │ │ 00194 │ │ │ │ │ │ hash_array[index] = elm; │ │ │ │ │ │ 00195 │ │ │ │ │ │ 00196 │ │ │ │ │ │ n_cones++; │ │ │ │ │ │ -00197 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00197 │ │ │ │ │ │ 00198 │ │ │ │ │ │ } │ │ │ │ │ │ 00199 │ │ │ │ │ │ -// if the cone is already there, we have nothing to do │ │ │ │ │ │ 00200 │ │ │ │ │ │ +// if the cone is already there, we have nothing to do │ │ │ │ │ │ 00201 │ │ │ │ │ │ if (v->ref == elm->ref){ │ │ │ │ │ │ -00202 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00202 │ │ │ │ │ │ 00203 │ │ │ │ │ │ } │ │ │ │ │ │ 00204 │ │ │ │ │ │ 00205 │ │ │ │ │ │ elm = elm->next; │ │ │ │ │ │ 00206 │ │ │ │ │ │ } while (1); │ │ │ │ │ │ @@ -15378,43 +15061,50 @@ │ │ │ │ │ │ 00208 │ │ │ │ │ │ 00209 } │ │ │ │ │ │ 00210 │ │ │ │ │ │ 00211 /* │ │ │ │ │ │ 00212 * test if a particle is inside a cone of given centre. │ │ │ │ │ │ 00213 * check if the particle of coordinates ’v’ is inside the circle of radius R │ │ │ │ │ │ 00214 * centered at ’centre’. │ │ │ │ │ │ -00215 * - centre │ │ │ │ │ │ centre of the circle │ │ │ │ │ │ +00215 * - centre │ │ │ │ │ │ particle to test │ │ │ │ │ │ 00216 * - v │ │ │ │ │ │ 00217 * return true if inside, false if outside │ │ │ │ │ │ 00218 ******************************************************************************/ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.19 hash.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +205 │ │ │ │ │ │ + │ │ │ │ │ │ 00219 inline bool hash_cones::is_inside(Cmomentum *centre, Cmomentum *v){ │ │ │ │ │ │ -00220 │ │ │ │ │ │ double dx, dy; │ │ │ │ │ │ +00220 │ │ │ │ │ │ 00221 │ │ │ │ │ │ 00222 │ │ │ │ │ │ dx = centre->eta - v->eta; │ │ │ │ │ │ 00223 │ │ │ │ │ │ dy = fabs(centre->phi - v->phi); │ │ │ │ │ │ -if (dy>M_PI) │ │ │ │ │ │ 00224 │ │ │ │ │ │ +if (dy>M_PI) │ │ │ │ │ │ 00225 │ │ │ │ │ │ dy -= 2.0*M_PI; │ │ │ │ │ │ 00226 │ │ │ │ │ │ -00227 │ │ │ │ │ │ return dx*dx+dy*dy │ │ │ │ │ │ 00033 │ │ │ │ │ │ 00034 namespace siscone_spherical{ │ │ │ │ │ │ 00035 │ │ │ │ │ │ 00036 using namespace std; │ │ │ │ │ │ 00037 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 208 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00038 /************************************************************** │ │ │ │ │ │ 00039 * implementation of sph_hash_cones │ │ │ │ │ │ * │ │ │ │ │ │ 00040 * list of cones candidates. │ │ │ │ │ │ * │ │ │ │ │ │ 00041 * We store in this class all the sph_hash_element and give │ │ │ │ │ │ * │ │ │ │ │ │ @@ -15513,23 +15194,32 @@ │ │ │ │ │ │ 00061 │ │ │ │ │ │ int nbits = (int) (log(_Np*_radius*_radius*_Np/4.0)/log(2.0)); │ │ │ │ │ │ 00062 │ │ │ │ │ │ if (nbits<1) nbits=1; │ │ │ │ │ │ 00063 │ │ │ │ │ │ mask = 1 « nbits; │ │ │ │ │ │ 00064 │ │ │ │ │ │ -// create hash │ │ │ │ │ │ 00065 │ │ │ │ │ │ +// create hash │ │ │ │ │ │ 00066 │ │ │ │ │ │ hash_array = new sph_hash_element*[mask]; │ │ │ │ │ │ 00067 │ │ │ │ │ │ mask--; │ │ │ │ │ │ 00068 │ │ │ │ │ │ // set the array to 0 │ │ │ │ │ │ 00069 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 206 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00070 │ │ │ │ │ │ //? needed ? │ │ │ │ │ │ 00071 │ │ │ │ │ │ for (i=0;inext; │ │ │ │ │ │ -00088 │ │ │ │ │ │ delete elm; │ │ │ │ │ │ +00088 │ │ │ │ │ │ 00089 │ │ │ │ │ │ } │ │ │ │ │ │ 00090 │ │ │ │ │ │ } │ │ │ │ │ │ 00091 │ │ │ │ │ │ -delete[] hash_array; │ │ │ │ │ │ 00092 │ │ │ │ │ │ +delete[] hash_array; │ │ │ │ │ │ 00093 } │ │ │ │ │ │ 00094 │ │ │ │ │ │ 00095 │ │ │ │ │ │ 00096 /* │ │ │ │ │ │ 00097 * insert a new candidate into the hash. │ │ │ │ │ │ -4-momentum of the cone to add │ │ │ │ │ │ 00098 * - v │ │ │ │ │ │ +4-momentum of the cone to add │ │ │ │ │ │ 00099 * - parent parent particle defining the cone │ │ │ │ │ │ -child particle defining the cone │ │ │ │ │ │ 00100 * - child │ │ │ │ │ │ -00101 * - p_io │ │ │ │ │ │ +child particle defining the cone │ │ │ │ │ │ whether the parent has to belong to the cone or not │ │ │ │ │ │ -whether the child has to belong to the cone or not │ │ │ │ │ │ +00101 * - p_io │ │ │ │ │ │ 00102 * - c_io │ │ │ │ │ │ +whether the child has to belong to the cone or not │ │ │ │ │ │ 00103 * return 0 on success, 1 on error │ │ │ │ │ │ 00104 ***********************************************************************/ │ │ │ │ │ │ 00105 int sph_hash_cones::insert(CSphmomentum *v, CSphmomentum *parent, CSphmomentum *child, bool p_io, bool │ │ │ │ │ │ c_io){ │ │ │ │ │ │ 00106 │ │ │ │ │ │ sph_hash_element *elm; │ │ │ │ │ │ int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ @@ -15596,30 +15286,25 @@ │ │ │ │ │ │ if (elm==NULL) │ │ │ │ │ │ 00114 │ │ │ │ │ │ n_occupied_cells++; │ │ │ │ │ │ 00115 #endif │ │ │ │ │ │ 00116 │ │ │ │ │ │ 00117 │ │ │ │ │ │ do{ │ │ │ │ │ │ -00118 │ │ │ │ │ │ // if it is not present, add it │ │ │ │ │ │ +00118 │ │ │ │ │ │ 00119 │ │ │ │ │ │ if (elm==NULL){ │ │ │ │ │ │ -00120 │ │ │ │ │ │ // create element │ │ │ │ │ │ +00120 │ │ │ │ │ │ 00121 │ │ │ │ │ │ elm = new sph_hash_element; │ │ │ │ │ │ 00122 │ │ │ │ │ │ -00123 │ │ │ │ │ │ // set its varibles │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.21 hash.cpp │ │ │ │ │ │ - │ │ │ │ │ │ +00123 │ │ │ │ │ │ 00124 │ │ │ │ │ │ // Note: at this level, eta and phi have already been computed │ │ │ │ │ │ 00125 │ │ │ │ │ │ // │ │ │ │ │ │ through CSphmomentum::build_thetaphi. │ │ │ │ │ │ 00126 │ │ │ │ │ │ elm->centre = *v; │ │ │ │ │ │ @@ -15638,87 +15323,92 @@ │ │ │ │ │ │ 00134 │ │ │ │ │ │ elm->next = hash_array[index]; │ │ │ │ │ │ 00135 │ │ │ │ │ │ hash_array[index] = elm; │ │ │ │ │ │ 00136 │ │ │ │ │ │ 00137 │ │ │ │ │ │ n_cones++; │ │ │ │ │ │ -return 0; │ │ │ │ │ │ 00138 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ 00139 │ │ │ │ │ │ } │ │ │ │ │ │ 00140 │ │ │ │ │ │ // if the cone is already there, simply update stability status │ │ │ │ │ │ 00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ if (v->ref == elm->centre.ref){ │ │ │ │ │ │ 00143 │ │ │ │ │ │ // there is only an update to perform to see if the cone is still stable │ │ │ │ │ │ 00144 │ │ │ │ │ │ if (elm->is_stable){ │ │ │ │ │ │ 00145 │ │ │ │ │ │ elm->is_stable = !((is_closer(v, parent, tan2R)^p_io)||(is_closer(v, child, tan2R)^c_io)); │ │ │ │ │ │ -00146 │ │ │ │ │ │ //cout « " parent/child: " │ │ │ │ │ │ +00146 │ │ │ │ │ │ 00147 │ │ │ │ │ │ // │ │ │ │ │ │ « parent->ref[0] « ":" « is_closer(v, parent) « ":" « p_io « " " │ │ │ │ │ │ 00148 │ │ │ │ │ │ // │ │ │ │ │ │ « child->ref[0] « ":" « is_closer(v, child) « ":" « c_io « endl; │ │ │ │ │ │ 00149 │ │ │ │ │ │ //cout « "-- rep status of " « v->ref[0] « ":" « elm->is_stable « endl; │ │ │ │ │ │ 00150 │ │ │ │ │ │ //cout « v->eta « " " « v->phi « endl; │ │ │ │ │ │ 00151 │ │ │ │ │ │ //cout « (child->eta) « " " « child->phi « endl; │ │ │ │ │ │ 00152 │ │ │ │ │ │ } │ │ │ │ │ │ -00153 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00153 │ │ │ │ │ │ 00154 │ │ │ │ │ │ } │ │ │ │ │ │ 00155 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.20 hash.h │ │ │ │ │ │ + │ │ │ │ │ │ 00156 │ │ │ │ │ │ elm = elm->next; │ │ │ │ │ │ 00157 │ │ │ │ │ │ } while (1); │ │ │ │ │ │ 00158 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00159 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00160 } │ │ │ │ │ │ 00161 │ │ │ │ │ │ 00162 /* │ │ │ │ │ │ 00163 * insert a new candidate into the hash. │ │ │ │ │ │ 00164 * - v │ │ │ │ │ │ 4-momentum of te cone to add │ │ │ │ │ │ 00165 * Note, in this case, we assume stability. We also assume │ │ │ │ │ │ 00166 * that eta and phi are computed for v │ │ │ │ │ │ 00167 * return 0 on success, 1 on error │ │ │ │ │ │ 00168 ***********************************************************************/ │ │ │ │ │ │ 00169 int sph_hash_cones::insert(CSphmomentum *v){ │ │ │ │ │ │ 00170 │ │ │ │ │ │ sph_hash_element *elm; │ │ │ │ │ │ -int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ 00171 │ │ │ │ │ │ -00172 │ │ │ │ │ │ +int index = (v->ref.ref[0]) & mask; │ │ │ │ │ │ //cout « "-- stable candidate: " « v->ref[0] « ":" « endl; │ │ │ │ │ │ +00172 │ │ │ │ │ │ 00173 │ │ │ │ │ │ -00174 │ │ │ │ │ │ // check the array cell corresponding to our reference │ │ │ │ │ │ +00174 │ │ │ │ │ │ 00175 │ │ │ │ │ │ elm = hash_array[index]; │ │ │ │ │ │ -00176 │ │ │ │ │ │ do{ │ │ │ │ │ │ -// if it is not present, add it │ │ │ │ │ │ +00176 │ │ │ │ │ │ 00177 │ │ │ │ │ │ +// if it is not present, add it │ │ │ │ │ │ 00178 │ │ │ │ │ │ if (elm==NULL){ │ │ │ │ │ │ -00179 │ │ │ │ │ │ // create element │ │ │ │ │ │ +00179 │ │ │ │ │ │ 00180 │ │ │ │ │ │ elm = new sph_hash_element; │ │ │ │ │ │ 00181 │ │ │ │ │ │ // set its varibles │ │ │ │ │ │ 00182 │ │ │ │ │ │ 00183 │ │ │ │ │ │ // Note: at this level, eta and phi have already been computed │ │ │ │ │ │ @@ -15735,48 +15425,40 @@ │ │ │ │ │ │ 00189 │ │ │ │ │ │ elm->next = hash_array[index]; │ │ │ │ │ │ 00190 │ │ │ │ │ │ hash_array[index] = elm; │ │ │ │ │ │ 00191 │ │ │ │ │ │ 00192 │ │ │ │ │ │ n_cones++; │ │ │ │ │ │ -00193 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00193 │ │ │ │ │ │ 00194 │ │ │ │ │ │ } │ │ │ │ │ │ 00195 │ │ │ │ │ │ -// if the cone is already there, we have nothing to do │ │ │ │ │ │ 00196 │ │ │ │ │ │ +// if the cone is already there, we have nothing to do │ │ │ │ │ │ 00197 │ │ │ │ │ │ if (v->ref == elm->centre.ref){ │ │ │ │ │ │ -00198 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00198 │ │ │ │ │ │ 00199 │ │ │ │ │ │ } │ │ │ │ │ │ 00200 │ │ │ │ │ │ 00201 │ │ │ │ │ │ elm = elm->next; │ │ │ │ │ │ 00202 │ │ │ │ │ │ } while (1); │ │ │ │ │ │ 00203 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00204 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00205 } │ │ │ │ │ │ 00206 │ │ │ │ │ │ 00207 } │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -209 │ │ │ │ │ │ - │ │ │ │ │ │ - 210 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -5.22 hash.h │ │ │ │ │ │ +5.20 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 │ │ │ │ │ │ @@ -15818,44 +15500,53 @@ │ │ │ │ │ │ $// │ │ │ │ │ │ 00025 // $Date:: 2008-05-16 19:58:30 +0200 (Fri, 16 May 2008) │ │ │ │ │ │ $// │ │ │ │ │ │ 00027 │ │ │ │ │ │ 00028 #ifndef __HASH_H__ │ │ │ │ │ │ 00029 #define __HASH_H__ │ │ │ │ │ │ 00030 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +207 │ │ │ │ │ │ + │ │ │ │ │ │ + 208 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00031 #include "momentum.h" │ │ │ │ │ │ 00032 #include "reference.h" │ │ │ │ │ │ 00033 │ │ │ │ │ │ 00034 namespace siscone{ │ │ │ │ │ │ 00035 │ │ │ │ │ │ 00045 class hash_element{ │ │ │ │ │ │ 00046 public: │ │ │ │ │ │ 00047 │ │ │ │ │ │ Creference ref; │ │ │ │ │ │ double eta; │ │ │ │ │ │ 00048 │ │ │ │ │ │ 00049 │ │ │ │ │ │ double phi; │ │ │ │ │ │ -bool is_stable; │ │ │ │ │ │ 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); │ │ │ │ │ │ +00081 │ │ │ │ │ │ 00082 │ │ │ │ │ │ int insert(Cmomentum *v); │ │ │ │ │ │ 00090 │ │ │ │ │ │ 00091 │ │ │ │ │ │ 00093 │ │ │ │ │ │ hash_element **hash_array; │ │ │ │ │ │ 00094 │ │ │ │ │ │ @@ -15876,40 +15567,31 @@ │ │ │ │ │ │ inline bool is_inside(Cmomentum *centre, Cmomentum *v); │ │ │ │ │ │ 00118 │ │ │ │ │ │ 00119 }; │ │ │ │ │ │ 00120 │ │ │ │ │ │ 00121 } │ │ │ │ │ │ 00122 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.23 hash.h │ │ │ │ │ │ +5.21 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 // │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ // │ │ │ │ │ │ +00008 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ +00009 // │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.24 momentum.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -211 │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -15947,40 +15629,47 @@ │ │ │ │ │ │ 00034 │ │ │ │ │ │ 00035 namespace siscone_spherical{ │ │ │ │ │ │ 00036 │ │ │ │ │ │ 00046 class sph_hash_element{ │ │ │ │ │ │ 00047 public: │ │ │ │ │ │ 00048 │ │ │ │ │ │ CSph3vector centre; │ │ │ │ │ │ -00049 │ │ │ │ │ │ bool is_stable; │ │ │ │ │ │ +00049 │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.22 momentum.h │ │ │ │ │ │ + │ │ │ │ │ │ 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 │ │ │ │ │ │ -int insert(CSphmomentum *v, CSphmomentum *parent, CSphmomentum *child, bool p_io, bool c_io); │ │ │ │ │ │ 00079 │ │ │ │ │ │ +int insert(CSphmomentum *v, CSphmomentum *parent, CSphmomentum *child, bool p_io, bool c_io); │ │ │ │ │ │ 00080 │ │ │ │ │ │ int insert(CSphmomentum *v); │ │ │ │ │ │ 00088 │ │ │ │ │ │ 00089 │ │ │ │ │ │ 00091 │ │ │ │ │ │ sph_hash_element **hash_array; │ │ │ │ │ │ 00092 │ │ │ │ │ │ -int n_cones; │ │ │ │ │ │ 00094 │ │ │ │ │ │ +int n_cones; │ │ │ │ │ │ 00095 │ │ │ │ │ │ 00097 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00098 │ │ │ │ │ │ int n_occupied_cells; │ │ │ │ │ │ 00099 #endif │ │ │ │ │ │ 00100 │ │ │ │ │ │ 00102 │ │ │ │ │ │ @@ -15992,686 +15681,504 @@ │ │ │ │ │ │ double tan2R; │ │ │ │ │ │ 00109 │ │ │ │ │ │ 00110 }; │ │ │ │ │ │ 00111 │ │ │ │ │ │ 00112 } │ │ │ │ │ │ 00113 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.24 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 // 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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ +5.22 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 │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ - 212 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00020 // along with this program; if not, write to the Free Software │ │ │ │ │ │ +00021 // 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 // │ │ │ │ │ │ +00022 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ +00023 // │ │ │ │ │ │ // │ │ │ │ │ │ -00023 // $Revision:: 123 │ │ │ │ │ │ +00024 // $Revision:: 163 │ │ │ │ │ │ $// │ │ │ │ │ │ -00024 // $Date:: 2007-03-01 02:52:16 +0100 (Thu, 01 Mar 2007) │ │ │ │ │ │ +00025 // $Date:: 2007-04-26 22:31:02 +0200 (Thu, 26 Apr 2007) │ │ │ │ │ │ $// │ │ │ │ │ │ -00026 │ │ │ │ │ │ -00027 #include "momentum.h" │ │ │ │ │ │ -00028 #include │ │ │ │ │ │ -00029 #include │ │ │ │ │ │ +00027 │ │ │ │ │ │ +00028 #ifndef __VECTOR_H__ │ │ │ │ │ │ +00029 #define __VECTOR_H__ │ │ │ │ │ │ 00030 │ │ │ │ │ │ -00031 namespace siscone{ │ │ │ │ │ │ -00032 │ │ │ │ │ │ -00033 /************************************************************************* │ │ │ │ │ │ -00034 * class Cmomentum │ │ │ │ │ │ -* │ │ │ │ │ │ -00035 * This class contains the information for particle or group of │ │ │ │ │ │ -* │ │ │ │ │ │ -00036 * particles management. │ │ │ │ │ │ -* │ │ │ │ │ │ -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){ │ │ │ │ │ │ +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 │ │ │ │ │ │ -px = _px; │ │ │ │ │ │ -00054 │ │ │ │ │ │ -py = _py; │ │ │ │ │ │ 00055 │ │ │ │ │ │ -pz = _pz; │ │ │ │ │ │ +Cmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ 00056 │ │ │ │ │ │ -E = _E; │ │ │ │ │ │ -00057 │ │ │ │ │ │ -// compute eta and phi │ │ │ │ │ │ 00058 │ │ │ │ │ │ +Cmomentum(double _eta, double _phi, Creference _ref); │ │ │ │ │ │ 00059 │ │ │ │ │ │ -build_etaphi(); │ │ │ │ │ │ -00060 │ │ │ │ │ │ -ref = Creference(); │ │ │ │ │ │ -00061 } │ │ │ │ │ │ +00061 │ │ │ │ │ │ +~Cmomentum(); │ │ │ │ │ │ 00062 │ │ │ │ │ │ -00063 // ctor with detailed initialisation │ │ │ │ │ │ -00064 //----------------------------------00065 Cmomentum::Cmomentum(double _eta, double _phi, Creference _ref){ │ │ │ │ │ │ -00066 │ │ │ │ │ │ -eta = _eta; │ │ │ │ │ │ +00064 │ │ │ │ │ │ +inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ +00065 │ │ │ │ │ │ +inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ 00067 │ │ │ │ │ │ -phi = _phi; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +209 │ │ │ │ │ │ + │ │ │ │ │ │ + 210 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00068 │ │ │ │ │ │ -00069 │ │ │ │ │ │ -ref = _ref; │ │ │ │ │ │ -00070 } │ │ │ │ │ │ +inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ +00070 │ │ │ │ │ │ 00071 │ │ │ │ │ │ -00072 // default dtor │ │ │ │ │ │ -00073 //-------------00074 Cmomentum::~Cmomentum(){ │ │ │ │ │ │ -00075 │ │ │ │ │ │ -00076 } │ │ │ │ │ │ +00073 │ │ │ │ │ │ +inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ +00074 │ │ │ │ │ │ +inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ +00076 │ │ │ │ │ │ 00077 │ │ │ │ │ │ -00078 // assignment of vectors │ │ │ │ │ │ -00079 //----------------------00080 Cmomentum& Cmomentum::operator = (const Cmomentum &v){ │ │ │ │ │ │ -00081 │ │ │ │ │ │ -px = v.px; │ │ │ │ │ │ +inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ +00079 │ │ │ │ │ │ +00080 │ │ │ │ │ │ +inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ 00082 │ │ │ │ │ │ -py = v.py; │ │ │ │ │ │ 00083 │ │ │ │ │ │ -pz = v.pz; │ │ │ │ │ │ -00084 │ │ │ │ │ │ -E = v.E; │ │ │ │ │ │ +inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ 00085 │ │ │ │ │ │ 00086 │ │ │ │ │ │ -eta = v.eta; │ │ │ │ │ │ -00087 │ │ │ │ │ │ -phi = v.phi; │ │ │ │ │ │ 00088 │ │ │ │ │ │ +Cmomentum& operator = (const Cmomentum &v); │ │ │ │ │ │ 00089 │ │ │ │ │ │ -ref = v.ref; │ │ │ │ │ │ -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){ │ │ │ │ │ │ +const Cmomentum operator + (const Cmomentum &v); │ │ │ │ │ │ +00093 │ │ │ │ │ │ +00096 │ │ │ │ │ │ +Cmomentum& operator += (const Cmomentum &v); │ │ │ │ │ │ 00097 │ │ │ │ │ │ -Cmomentum tmp = *this; │ │ │ │ │ │ -00098 │ │ │ │ │ │ -return tmp+=v; │ │ │ │ │ │ -00099 } │ │ │ │ │ │ 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; │ │ │ │ │ │ -00106 │ │ │ │ │ │ -py+=v.py; │ │ │ │ │ │ +Cmomentum& operator -= (const Cmomentum &v); │ │ │ │ │ │ +00101 │ │ │ │ │ │ +void build_etaphi(); │ │ │ │ │ │ 00107 │ │ │ │ │ │ -pz+=v.pz; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.25 momentum.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -213 │ │ │ │ │ │ - │ │ │ │ │ │ 00108 │ │ │ │ │ │ -E +=v.E; │ │ │ │ │ │ +double px; │ │ │ │ │ │ 00109 │ │ │ │ │ │ 00110 │ │ │ │ │ │ -ref+=v.ref; │ │ │ │ │ │ +double py; │ │ │ │ │ │ +double pz; │ │ │ │ │ │ 00111 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ 00112 │ │ │ │ │ │ -00113 } │ │ │ │ │ │ +double E; │ │ │ │ │ │ +00113 │ │ │ │ │ │ +double eta; │ │ │ │ │ │ 00114 │ │ │ │ │ │ -00115 // incrementation of vectors │ │ │ │ │ │ -00116 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00117 //-----------------------------------------------00118 Cmomentum& Cmomentum::operator -= (const Cmomentum &v){ │ │ │ │ │ │ -00119 │ │ │ │ │ │ -px-=v.px; │ │ │ │ │ │ +00115 │ │ │ │ │ │ +double phi; │ │ │ │ │ │ +int parent_index; │ │ │ │ │ │ +00116 │ │ │ │ │ │ +00117 │ │ │ │ │ │ +int index; │ │ │ │ │ │ +00118 │ │ │ │ │ │ +// the following part is used for checksums // │ │ │ │ │ │ 00120 │ │ │ │ │ │ -py-=v.py; │ │ │ │ │ │ -00121 │ │ │ │ │ │ -pz-=v.pz; │ │ │ │ │ │ 00122 │ │ │ │ │ │ -E -=v.E; │ │ │ │ │ │ -00123 │ │ │ │ │ │ +Creference ref; │ │ │ │ │ │ +00123 }; │ │ │ │ │ │ 00124 │ │ │ │ │ │ -ref-=v.ref; │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00125 │ │ │ │ │ │ -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(){ │ │ │ │ │ │ -// note: the factor n (ref.nb) cancels in all expressions !! │ │ │ │ │ │ +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 │ │ │ │ │ │ -00136 │ │ │ │ │ │ -eta = 0.5*log((E+pz)/(E-pz)); │ │ │ │ │ │ -00137 │ │ │ │ │ │ -phi = atan2(py,px); │ │ │ │ │ │ -00138 } │ │ │ │ │ │ +00137 // some handy utilities // │ │ │ │ │ │ 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){ │ │ │ │ │ │ -return v1.ref < v2.ref; │ │ │ │ │ │ +00144 inline double get_distance(double eta, double phi, Cmomentum *v){ │ │ │ │ │ │ 00145 │ │ │ │ │ │ -00146 } │ │ │ │ │ │ +double dx, dy; │ │ │ │ │ │ +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){ │ │ │ │ │ │ +dx = eta - v->eta; │ │ │ │ │ │ +00148 │ │ │ │ │ │ +dy = fabs(phi - v->phi); │ │ │ │ │ │ +if (dy>M_PI) │ │ │ │ │ │ +00149 │ │ │ │ │ │ +00150 │ │ │ │ │ │ +dy -= twopi; │ │ │ │ │ │ 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){ │ │ │ │ │ │ -return v1.perp2() < v2.perp2(); │ │ │ │ │ │ -00157 │ │ │ │ │ │ -00158 } │ │ │ │ │ │ -00159 │ │ │ │ │ │ -00160 } │ │ │ │ │ │ -00161 │ │ │ │ │ │ +00152 │ │ │ │ │ │ +return dx*dx+dy*dy; │ │ │ │ │ │ +00153 } │ │ │ │ │ │ +00154 │ │ │ │ │ │ +00155 } │ │ │ │ │ │ +00156 │ │ │ │ │ │ +00157 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.23 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 // 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 // │ │ │ │ │ │ │ │ │ │ │ │ -5.25 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 // │ │ │ │ │ │ // │ │ │ │ │ │ -00025 // $Revision:: 255 │ │ │ │ │ │ -$// │ │ │ │ │ │ -00026 // $Date:: 2008-07-12 17:40:35 +0200 (Sat, 12 Jul 2008) │ │ │ │ │ │ -$// │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 214 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ + 5.23 momentum.h │ │ │ │ │ │ │ │ │ │ │ │ -00028 │ │ │ │ │ │ -00029 #include "momentum.h" │ │ │ │ │ │ -00030 #include │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ +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:: 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 namespace siscone_spherical{ │ │ │ │ │ │ -00034 │ │ │ │ │ │ -00035 /************************************************************************* │ │ │ │ │ │ -00036 * class CSph3vector │ │ │ │ │ │ -* │ │ │ │ │ │ -00037 * This class contains the information for particle or group of │ │ │ │ │ │ -* │ │ │ │ │ │ -00038 * particles management. │ │ │ │ │ │ -* │ │ │ │ │ │ -00039 *************************************************************************/ │ │ │ │ │ │ +00033 #include │ │ │ │ │ │ +00034 #include │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include "geom_2d.h" │ │ │ │ │ │ +00037 #include │ │ │ │ │ │ +00038 │ │ │ │ │ │ +00039 namespace siscone_spherical{ │ │ │ │ │ │ 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 │ │ │ │ │ │ +00054 class CSph3vector{ │ │ │ │ │ │ +00055 public: │ │ │ │ │ │ 00057 │ │ │ │ │ │ -build_norm(); │ │ │ │ │ │ +CSph3vector(); │ │ │ │ │ │ 00058 │ │ │ │ │ │ -00059 │ │ │ │ │ │ -ref = siscone::Creference(); │ │ │ │ │ │ -00060 } │ │ │ │ │ │ +00060 │ │ │ │ │ │ +CSph3vector(double _px, double _py, double _pz); │ │ │ │ │ │ 00061 │ │ │ │ │ │ -00062 // default dtor │ │ │ │ │ │ -00063 //-------------00064 CSph3vector::~CSph3vector(){ │ │ │ │ │ │ -00065 │ │ │ │ │ │ -00066 } │ │ │ │ │ │ +00063 │ │ │ │ │ │ +~CSph3vector(); │ │ │ │ │ │ +00064 │ │ │ │ │ │ +00066 │ │ │ │ │ │ +CSph3vector& operator = (const CSph3vector &v); │ │ │ │ │ │ 00067 │ │ │ │ │ │ -00068 │ │ │ │ │ │ -00069 // assignment of vectors │ │ │ │ │ │ -00070 //----------------------00071 CSph3vector& CSph3vector::operator = (const CSph3vector &v){ │ │ │ │ │ │ -00072 │ │ │ │ │ │ -px = v.px; │ │ │ │ │ │ -00073 │ │ │ │ │ │ -py = v.py; │ │ │ │ │ │ +const CSph3vector operator + (const CSph3vector &v); │ │ │ │ │ │ +00070 │ │ │ │ │ │ +00071 │ │ │ │ │ │ +const CSph3vector operator - (const CSph3vector &v); │ │ │ │ │ │ 00074 │ │ │ │ │ │ -pz = v.pz; │ │ │ │ │ │ 00075 │ │ │ │ │ │ -00076 │ │ │ │ │ │ -_norm = v._norm; │ │ │ │ │ │ -00077 │ │ │ │ │ │ -_theta = v._theta; │ │ │ │ │ │ +const CSph3vector operator / (const double &r); │ │ │ │ │ │ 00078 │ │ │ │ │ │ -_phi │ │ │ │ │ │ -= v._phi; │ │ │ │ │ │ 00079 │ │ │ │ │ │ -00080 │ │ │ │ │ │ -ref = v.ref; │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00081 │ │ │ │ │ │ -00082 } │ │ │ │ │ │ +00082 │ │ │ │ │ │ +CSph3vector& operator += (const CSph3vector &v); │ │ │ │ │ │ 00083 │ │ │ │ │ │ -00084 // addition of vectors │ │ │ │ │ │ -00085 //-----------------------------------------------00086 const CSph3vector CSph3vector::operator + (const CSph3vector &v){ │ │ │ │ │ │ +00086 │ │ │ │ │ │ +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){ │ │ │ │ │ │ +CSph3vector& operator *= (const double &r); │ │ │ │ │ │ +00091 │ │ │ │ │ │ 00094 │ │ │ │ │ │ -CSph3vector tmp = *this; │ │ │ │ │ │ +CSph3vector& operator /= (const double &r); │ │ │ │ │ │ 00095 │ │ │ │ │ │ -return tmp-=v; │ │ │ │ │ │ -00096 } │ │ │ │ │ │ +inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ 00097 │ │ │ │ │ │ -00098 // division by constant │ │ │ │ │ │ -00099 //-----------------------------------------------00100 const CSph3vector CSph3vector::operator / (const double &r){ │ │ │ │ │ │ +00098 │ │ │ │ │ │ +inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ +00100 │ │ │ │ │ │ 00101 │ │ │ │ │ │ -CSph3vector tmp = *this; │ │ │ │ │ │ -00102 │ │ │ │ │ │ -return tmp/=r; │ │ │ │ │ │ -00103 } │ │ │ │ │ │ +inline double norm() const {return sqrt(px*px+py*py+pz*pz);} │ │ │ │ │ │ +00103 │ │ │ │ │ │ 00104 │ │ │ │ │ │ -00105 // incrementation │ │ │ │ │ │ -00106 //-----------------------------------------------00107 CSph3vector& CSph3vector::operator += (const CSph3vector &v){ │ │ │ │ │ │ -00108 │ │ │ │ │ │ -px+=v.px; │ │ │ │ │ │ +00106 │ │ │ │ │ │ +inline double norm2() const {return px*px+py*py+pz*pz;} │ │ │ │ │ │ +00107 │ │ │ │ │ │ +inline double phi() const {return atan2(py, px);} │ │ │ │ │ │ 00109 │ │ │ │ │ │ -py+=v.py; │ │ │ │ │ │ 00110 │ │ │ │ │ │ -pz+=v.pz; │ │ │ │ │ │ -00111 │ │ │ │ │ │ +inline double theta() const {return atan2(perp(),pz);} │ │ │ │ │ │ 00112 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00113 } │ │ │ │ │ │ -00114 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.25 momentum.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00115 // decrementation │ │ │ │ │ │ -00116 //-----------------------------------------------00117 CSph3vector& CSph3vector::operator -= (const CSph3vector &v){ │ │ │ │ │ │ -00118 │ │ │ │ │ │ -px-=v.px; │ │ │ │ │ │ -00119 │ │ │ │ │ │ -py-=v.py; │ │ │ │ │ │ +00113 │ │ │ │ │ │ +void build_norm(); │ │ │ │ │ │ 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; │ │ │ │ │ │ +void build_thetaphi(); │ │ │ │ │ │ +00125 │ │ │ │ │ │ +00126 │ │ │ │ │ │ +void get_angular_directions(CSph3vector &angular_dir1, CSph3vector &angular_dir2); │ │ │ │ │ │ 00129 │ │ │ │ │ │ -py*=r; │ │ │ │ │ │ 00130 │ │ │ │ │ │ -pz*=r; │ │ │ │ │ │ 00131 │ │ │ │ │ │ +double px; │ │ │ │ │ │ +double py; │ │ │ │ │ │ 00132 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00133 } │ │ │ │ │ │ +00133 │ │ │ │ │ │ +double pz; │ │ │ │ │ │ 00134 │ │ │ │ │ │ -00135 // division by a constant │ │ │ │ │ │ -00136 //-----------------------------------------------00137 CSph3vector& CSph3vector::operator /= (const double &r){ │ │ │ │ │ │ +double _norm; │ │ │ │ │ │ +00135 │ │ │ │ │ │ +double _theta; │ │ │ │ │ │ +00136 │ │ │ │ │ │ +00137 │ │ │ │ │ │ +double _phi; │ │ │ │ │ │ 00138 │ │ │ │ │ │ -px/=r; │ │ │ │ │ │ -00139 │ │ │ │ │ │ -py/=r; │ │ │ │ │ │ +// the following part is used for checksums // │ │ │ │ │ │ 00140 │ │ │ │ │ │ -pz/=r; │ │ │ │ │ │ -00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ -_norm/=r; │ │ │ │ │ │ -00143 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ +siscone::Creference ref; │ │ │ │ │ │ +00143 }; │ │ │ │ │ │ 00144 │ │ │ │ │ │ -00145 } │ │ │ │ │ │ -00146 │ │ │ │ │ │ -00147 // build norm from 3-momentum info │ │ │ │ │ │ -00148 void CSph3vector::build_norm(){ │ │ │ │ │ │ -00149 │ │ │ │ │ │ -_norm = norm(); │ │ │ │ │ │ -00150 } │ │ │ │ │ │ -00151 │ │ │ │ │ │ -00152 // build norm from 3-momentum info │ │ │ │ │ │ -00153 void CSph3vector::build_thetaphi(){ │ │ │ │ │ │ -00154 │ │ │ │ │ │ -_theta = theta(); │ │ │ │ │ │ -00155 │ │ │ │ │ │ -_phi = phi(); │ │ │ │ │ │ -00156 } │ │ │ │ │ │ -00157 │ │ │ │ │ │ -00158 │ │ │ │ │ │ -00159 // for this direction, compute the two reference directions │ │ │ │ │ │ -00160 // used to measure angles │ │ │ │ │ │ -00161 void CSph3vector::get_angular_directions(CSph3vector &angular_dir1, CSph3vector &angular_dir2){ │ │ │ │ │ │ +00158 class CSphmomentum : public CSph3vector{ │ │ │ │ │ │ +00159 public: │ │ │ │ │ │ +00161 │ │ │ │ │ │ +CSphmomentum(); │ │ │ │ │ │ 00162 │ │ │ │ │ │ -if (px < py){ │ │ │ │ │ │ -00163 │ │ │ │ │ │ -if (pz < px){ │ │ │ │ │ │ -// z smallest │ │ │ │ │ │ 00164 │ │ │ │ │ │ +CSphmomentum(CSph3vector &init, double E=0.0); │ │ │ │ │ │ 00165 │ │ │ │ │ │ -angular_dir1 = CSph3vector(-py, px, 0.0); │ │ │ │ │ │ -00166 │ │ │ │ │ │ -} else { │ │ │ │ │ │ 00167 │ │ │ │ │ │ -// x smallest │ │ │ │ │ │ +CSphmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ 00168 │ │ │ │ │ │ -angular_dir1 = CSph3vector(0.0, -pz, py); │ │ │ │ │ │ -00169 │ │ │ │ │ │ -} │ │ │ │ │ │ +//CSphmomentum(double _eta, double _phi, siscone::Creference _ref); │ │ │ │ │ │ 00170 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -if (pz < py){ │ │ │ │ │ │ 00171 │ │ │ │ │ │ -00172 │ │ │ │ │ │ -// z smallest │ │ │ │ │ │ 00173 │ │ │ │ │ │ -angular_dir1 = CSph3vector(-py, px, 0.0); │ │ │ │ │ │ +~CSphmomentum(); │ │ │ │ │ │ 00174 │ │ │ │ │ │ -} else { │ │ │ │ │ │ -00175 │ │ │ │ │ │ -// y smallest │ │ │ │ │ │ +inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ 00176 │ │ │ │ │ │ -angular_dir1 = CSph3vector(-pz, 0.0, px); │ │ │ │ │ │ 00177 │ │ │ │ │ │ -} │ │ │ │ │ │ -00178 │ │ │ │ │ │ -} │ │ │ │ │ │ 00179 │ │ │ │ │ │ -angular_dir2 = cross_product3(*this, angular_dir1); │ │ │ │ │ │ -00180 │ │ │ │ │ │ -// We’ll simply take x & y so the reflection symmetry is not broken │ │ │ │ │ │ -00181 │ │ │ │ │ │ -//angular_dir1 = CSph3vector(0.0, -pz, py); │ │ │ │ │ │ -00182 │ │ │ │ │ │ -//angular_dir2 = CSph3vector(-pz, 0.0, -px); │ │ │ │ │ │ -00183 } │ │ │ │ │ │ -00184 │ │ │ │ │ │ -00185 /************************************************************************* │ │ │ │ │ │ -00186 * class CSphmomentum │ │ │ │ │ │ -* │ │ │ │ │ │ -00187 * This class contains the information for particle or group of │ │ │ │ │ │ -* │ │ │ │ │ │ -00188 * particles management. │ │ │ │ │ │ -* │ │ │ │ │ │ -00189 * It includes all Lorentz properties as well as tools for summing them. * │ │ │ │ │ │ -00190 *************************************************************************/ │ │ │ │ │ │ -00191 │ │ │ │ │ │ -00192 // default ctor │ │ │ │ │ │ -00193 //-------------00194 CSphmomentum::CSphmomentum(){ │ │ │ │ │ │ -00195 │ │ │ │ │ │ -E=0.0; │ │ │ │ │ │ -00196 │ │ │ │ │ │ -index = -1; │ │ │ │ │ │ -00197 } │ │ │ │ │ │ -00198 │ │ │ │ │ │ -00199 // ctor with initialisation │ │ │ │ │ │ -00200 //-------------------------00201 CSphmomentum::CSphmomentum(double _px, double _py, double _pz, double _E) │ │ │ │ │ │ +inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ -215 │ │ │ │ │ │ +211 │ │ │ │ │ │ │ │ │ │ │ │ - 216 │ │ │ │ │ │ + 212 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ +00180 │ │ │ │ │ │ +inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ +00182 │ │ │ │ │ │ +00183 │ │ │ │ │ │ +00185 │ │ │ │ │ │ +inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ +00186 │ │ │ │ │ │ +inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ +00188 │ │ │ │ │ │ +00189 │ │ │ │ │ │ +inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ +00191 │ │ │ │ │ │ +00192 │ │ │ │ │ │ +00194 │ │ │ │ │ │ +CSphmomentum& operator = (const CSphmomentum &v); │ │ │ │ │ │ +00195 │ │ │ │ │ │ +const CSphmomentum operator + (const CSphmomentum &v); │ │ │ │ │ │ +00198 │ │ │ │ │ │ +00199 │ │ │ │ │ │ 00202 │ │ │ │ │ │ -: CSph3vector(_px, _py, _pz) { │ │ │ │ │ │ +CSphmomentum& operator += (const CSphmomentum &v); │ │ │ │ │ │ 00203 │ │ │ │ │ │ -E = _E; │ │ │ │ │ │ -00204 │ │ │ │ │ │ -00205 │ │ │ │ │ │ -// compute the angles │ │ │ │ │ │ 00206 │ │ │ │ │ │ -build_thetaphi(); │ │ │ │ │ │ -00207 } │ │ │ │ │ │ +CSphmomentum& operator -= (const CSphmomentum &v); │ │ │ │ │ │ +00207 │ │ │ │ │ │ +double E; │ │ │ │ │ │ 00208 │ │ │ │ │ │ -00209 // ctor with initialisation │ │ │ │ │ │ -00210 //-------------------------00211 CSphmomentum::CSphmomentum(CSph3vector &_v, double _E) │ │ │ │ │ │ -00212 │ │ │ │ │ │ -: CSph3vector(_v.px, _v.py, _v.pz) { │ │ │ │ │ │ +00209 │ │ │ │ │ │ +int parent_index; │ │ │ │ │ │ +00210 │ │ │ │ │ │ +int index; │ │ │ │ │ │ +00211 │ │ │ │ │ │ +00212 }; │ │ │ │ │ │ 00213 │ │ │ │ │ │ -E = _E; │ │ │ │ │ │ -00214 } │ │ │ │ │ │ -00215 │ │ │ │ │ │ -00216 // default dtor │ │ │ │ │ │ -00217 //-------------00218 CSphmomentum::~CSphmomentum(){ │ │ │ │ │ │ -00219 │ │ │ │ │ │ -00220 } │ │ │ │ │ │ -00221 │ │ │ │ │ │ -00222 // assignment of vectors │ │ │ │ │ │ -00223 //----------------------00224 CSphmomentum& CSphmomentum::operator = (const CSphmomentum &v){ │ │ │ │ │ │ -00225 │ │ │ │ │ │ -px = v.px; │ │ │ │ │ │ -00226 │ │ │ │ │ │ -py = v.py; │ │ │ │ │ │ -00227 │ │ │ │ │ │ -pz = v.pz; │ │ │ │ │ │ +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 │ │ │ │ │ │ -E = v.E; │ │ │ │ │ │ -00229 │ │ │ │ │ │ -00230 │ │ │ │ │ │ -_norm = v._norm; │ │ │ │ │ │ +00230 inline double sqr(double x){return x*x;} │ │ │ │ │ │ 00231 │ │ │ │ │ │ -_theta = v._theta; │ │ │ │ │ │ -00232 │ │ │ │ │ │ -_phi │ │ │ │ │ │ -= v._phi; │ │ │ │ │ │ -00233 │ │ │ │ │ │ -00234 │ │ │ │ │ │ -ref = v.ref; │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00235 │ │ │ │ │ │ -00236 } │ │ │ │ │ │ +00235 inline double dot_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ +//double tmp = v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ +00236 │ │ │ │ │ │ 00237 │ │ │ │ │ │ -00238 // addition of vectors │ │ │ │ │ │ -00239 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00240 //-----------------------------------------------00241 const CSphmomentum CSphmomentum::operator + (const CSphmomentum &v){ │ │ │ │ │ │ +//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 │ │ │ │ │ │ -CSphmomentum tmp = *this; │ │ │ │ │ │ +//} │ │ │ │ │ │ 00243 │ │ │ │ │ │ -return tmp+=v; │ │ │ │ │ │ +return v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ 00244 } │ │ │ │ │ │ 00245 │ │ │ │ │ │ -00246 // incrementation of vectors │ │ │ │ │ │ -00247 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00248 //-----------------------------------------------00249 CSphmomentum& CSphmomentum::operator += (const CSphmomentum &v){ │ │ │ │ │ │ +00249 inline CSph3vector cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ 00250 │ │ │ │ │ │ -px+=v.px; │ │ │ │ │ │ +//CSph3vector tmp; │ │ │ │ │ │ 00251 │ │ │ │ │ │ -py+=v.py; │ │ │ │ │ │ +//tmp.px = v1.py*v2.pz-v1.pz*v2.py; │ │ │ │ │ │ 00252 │ │ │ │ │ │ -pz+=v.pz; │ │ │ │ │ │ +//tmp.py = v1.pz*v2.px-v1.px*v2.pz; │ │ │ │ │ │ 00253 │ │ │ │ │ │ -E +=v.E; │ │ │ │ │ │ +//tmp.pz = v1.px*v2.py-v1.py*v2.px; │ │ │ │ │ │ 00254 │ │ │ │ │ │ +//return tmp; │ │ │ │ │ │ 00255 │ │ │ │ │ │ -ref+=v.ref; │ │ │ │ │ │ +return CSph3vector(v1.py*v2.pz-v1.pz*v2.py, │ │ │ │ │ │ 00256 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ +v1.pz*v2.px-v1.px*v2.pz, │ │ │ │ │ │ 00257 │ │ │ │ │ │ +v1.px*v2.py-v1.py*v2.px); │ │ │ │ │ │ 00258 } │ │ │ │ │ │ 00259 │ │ │ │ │ │ -00260 // decrementation of vectors │ │ │ │ │ │ -00261 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ -00262 //-----------------------------------------------00263 CSphmomentum& CSphmomentum::operator -= (const CSphmomentum &v){ │ │ │ │ │ │ +00263 inline double norm2_cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ +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); │ │ │ │ │ │ 00264 │ │ │ │ │ │ -px-=v.px; │ │ │ │ │ │ -00265 │ │ │ │ │ │ -py-=v.py; │ │ │ │ │ │ +00265 } │ │ │ │ │ │ 00266 │ │ │ │ │ │ -pz-=v.pz; │ │ │ │ │ │ -00267 │ │ │ │ │ │ -E -=v.E; │ │ │ │ │ │ -00268 │ │ │ │ │ │ -00269 │ │ │ │ │ │ -ref-=v.ref; │ │ │ │ │ │ -00270 │ │ │ │ │ │ -return *this; │ │ │ │ │ │ -00271 } │ │ │ │ │ │ -00272 │ │ │ │ │ │ +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 │ │ │ │ │ │ -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){ │ │ │ │ │ │ +00277 inline double get_distance(const CSph3vector *v1, const CSph3vector *v2){ │ │ │ │ │ │ 00278 │ │ │ │ │ │ -return v1.ref < v2.ref; │ │ │ │ │ │ +return atan2(sqrt(norm2_cross_product3(*v1,*v2)), dot_product3(*v1,*v2)); │ │ │ │ │ │ 00279 } │ │ │ │ │ │ 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){ │ │ │ │ │ │ -return v1._theta < v2._theta; │ │ │ │ │ │ -00284 │ │ │ │ │ │ -00285 } │ │ │ │ │ │ -00286 │ │ │ │ │ │ -00287 // ordering of vectors in pt │ │ │ │ │ │ -00288 //--------------------------- │ │ │ │ │ │ +00289 inline bool is_closer(const CSph3vector *v1, const CSph3vector *v2, const double tan2R){ │ │ │ │ │ │ +double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ +00290 │ │ │ │ │ │ +00291 │ │ │ │ │ │ +return (dot>=0) && (norm2_cross_product3(*v1,*v2)<=tan2R*dot*dot); │ │ │ │ │ │ +00292 } │ │ │ │ │ │ +00293 │ │ │ │ │ │ +00299 inline bool is_closer_safer(const CSph3vector *v1, const CSph3vector *v2, const double cosR){ │ │ │ │ │ │ +return dot_product3(*v1,*v2)>=cosR*sqrt(v1->norm2()*v2->norm2()); │ │ │ │ │ │ +00300 │ │ │ │ │ │ +00301 │ │ │ │ │ │ +//double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ +00302 │ │ │ │ │ │ +//return (dot>=0) && (norm2_cross_product3(*v1,*v2) &_particle_list){ │ │ │ │ │ │ -// check already allocated mem │ │ │ │ │ │ 00115 │ │ │ │ │ │ +// check already allocated mem │ │ │ │ │ │ 00116 │ │ │ │ │ │ if (hc!=NULL){ │ │ │ │ │ │ -delete hc; │ │ │ │ │ │ 00117 │ │ │ │ │ │ +delete hc; │ │ │ │ │ │ 00118 │ │ │ │ │ │ } │ │ │ │ │ │ -00119 │ │ │ │ │ │ if (protocones.size()!=0) │ │ │ │ │ │ +00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ protocones.clear(); │ │ │ │ │ │ 00121 │ │ │ │ │ │ 00122 │ │ │ │ │ │ multiple_centre_done.clear(); │ │ │ │ │ │ 00123 │ │ │ │ │ │ -// initialisation │ │ │ │ │ │ 00124 │ │ │ │ │ │ +// initialisation │ │ │ │ │ │ 00125 │ │ │ │ │ │ set_particle_list(_particle_list); │ │ │ │ │ │ 00126 } │ │ │ │ │ │ 00127 │ │ │ │ │ │ 00128 │ │ │ │ │ │ // │ │ │ │ │ │ 00130 // ALGORITHM MAIN ENTRY │ │ │ │ │ │ @@ -16881,16 +16389,16 @@ │ │ │ │ │ │ 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 │ │ │ │ │ │ int p_idx; │ │ │ │ │ │ +00142 │ │ │ │ │ │ 00143 │ │ │ │ │ │ // check if everything is correctly initialised │ │ │ │ │ │ 00144 │ │ │ │ │ │ 00145 │ │ │ │ │ │ if (n_part==0){ │ │ │ │ │ │ 00146 │ │ │ │ │ │ return 0; │ │ │ │ │ │ @@ -16907,60 +16415,60 @@ │ │ │ │ │ │ 00153 │ │ │ │ │ │ hc = new hash_cones(n_part, R2); │ │ │ │ │ │ 00154 │ │ │ │ │ │ // browse all particles │ │ │ │ │ │ 00155 │ │ │ │ │ │ 00156 │ │ │ │ │ │ for (p_idx=0;p_idxv; │ │ │ │ │ │ 00216 │ │ │ │ │ │ centre_idx = first_cone; │ │ │ │ │ │ 00217 │ │ │ │ │ │ @@ -17049,16 +16557,16 @@ │ │ │ │ │ │ 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 │ │ │ │ │ │ -00243 │ │ │ │ │ │ // here are the tests entering the first series: │ │ │ │ │ │ +00243 │ │ │ │ │ │ 00244 │ │ │ │ │ │ // 1. check if the cone is already inserted │ │ │ │ │ │ 00245 │ │ │ │ │ │ // 2. check cone stability for the parent and child particles │ │ │ │ │ │ 00246 │ │ │ │ │ │ 00247 │ │ │ │ │ │ if (centre->side){ │ │ │ │ │ │ @@ -17066,51 +16574,51 @@ │ │ │ │ │ │ 00248 │ │ │ │ │ │ 00249 │ │ │ │ │ │ // or when both are in. │ │ │ │ │ │ 00250 │ │ │ │ │ │ // Note: for the totally exclusive case, test emptyness before │ │ │ │ │ │ 00251 │ │ │ │ │ │ cone_candidate = cone; │ │ │ │ │ │ -00252 │ │ │ │ │ │ if (cone.ref.not_empty()){ │ │ │ │ │ │ +00252 │ │ │ │ │ │ 00253 │ │ │ │ │ │ hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ 00254 │ │ │ │ │ │ } │ │ │ │ │ │ 00255 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -219 │ │ │ │ │ │ - │ │ │ │ │ │ - 220 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00256 │ │ │ │ │ │ cone_candidate = cone; │ │ │ │ │ │ 00257 │ │ │ │ │ │ cone_candidate+= *parent + *child; │ │ │ │ │ │ 00258 │ │ │ │ │ │ hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ 00259 │ │ │ │ │ │ } else { │ │ │ │ │ │ -// test when 1! of the particles is in the cone │ │ │ │ │ │ 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 │ │ │ │ │ │ cone_candidate = cone + *child; │ │ │ │ │ │ 00265 │ │ │ │ │ │ hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ 00266 │ │ │ │ │ │ } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +215 │ │ │ │ │ │ + │ │ │ │ │ │ + 216 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00267 │ │ │ │ │ │ 00268 │ │ │ │ │ │ nb_tot+=2; │ │ │ │ │ │ 00269 │ │ │ │ │ │ 00270 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00271 } │ │ │ │ │ │ @@ -17118,39 +16626,39 @@ │ │ │ │ │ │ 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(){ │ │ │ │ │ │ -00280 │ │ │ │ │ │ // get the next child and centre │ │ │ │ │ │ +00280 │ │ │ │ │ │ 00281 │ │ │ │ │ │ centre_idx++; │ │ │ │ │ │ 00282 │ │ │ │ │ │ if (centre_idx==vicinity_size) │ │ │ │ │ │ 00283 │ │ │ │ │ │ centre_idx=0; │ │ │ │ │ │ if (centre_idx==first_cone) │ │ │ │ │ │ 00284 │ │ │ │ │ │ -00285 │ │ │ │ │ │ return 1; │ │ │ │ │ │ +00285 │ │ │ │ │ │ 00286 │ │ │ │ │ │ // update the cone w.r.t. the old child │ │ │ │ │ │ 00287 │ │ │ │ │ │ 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 │ │ │ │ │ │ // inside iff its side is -. │ │ │ │ │ │ 00291 │ │ │ │ │ │ if (!centre->side){ │ │ │ │ │ │ -00292 │ │ │ │ │ │ // update cone │ │ │ │ │ │ +00292 │ │ │ │ │ │ 00293 │ │ │ │ │ │ cone += (*child); │ │ │ │ │ │ 00294 │ │ │ │ │ │ // update info on particles inside │ │ │ │ │ │ 00295 │ │ │ │ │ │ 00296 │ │ │ │ │ │ centre->is_inside->cone = true; │ │ │ │ │ │ @@ -17158,66 +16666,66 @@ │ │ │ │ │ │ // update stability check quantities │ │ │ │ │ │ 00298 │ │ │ │ │ │ 00299 │ │ │ │ │ │ dpt += fabs(child->px)+fabs(child->py); │ │ │ │ │ │ 00300 │ │ │ │ │ │ } │ │ │ │ │ │ 00301 │ │ │ │ │ │ -// update centre and child to correspond to the new position │ │ │ │ │ │ 00302 │ │ │ │ │ │ +// update centre and child to correspond to the new position │ │ │ │ │ │ 00303 │ │ │ │ │ │ centre = vicinity[centre_idx]; │ │ │ │ │ │ 00304 │ │ │ │ │ │ child = centre->v; │ │ │ │ │ │ 00305 │ │ │ │ │ │ -00306 │ │ │ │ │ │ // check cocircularity │ │ │ │ │ │ +00306 │ │ │ │ │ │ 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()) │ │ │ │ │ │ -return update_cone(); │ │ │ │ │ │ 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 │ │ │ │ │ │ +00320 │ │ │ │ │ │ 00321 │ │ │ │ │ │ cone -= (*child); │ │ │ │ │ │ 00322 │ │ │ │ │ │ -00323 │ │ │ │ │ │ // update info on particles inside │ │ │ │ │ │ +00323 │ │ │ │ │ │ 00324 │ │ │ │ │ │ centre->is_inside->cone = false; │ │ │ │ │ │ 00325 │ │ │ │ │ │ // update stability check quantities │ │ │ │ │ │ 00326 │ │ │ │ │ │ 00327 │ │ │ │ │ │ dpt += fabs(child->px)+fabs(child->py); //child->perp2(); │ │ │ │ │ │ 00328 │ │ │ │ │ │ } │ │ │ │ │ │ 00329 │ │ │ │ │ │ -00330 │ │ │ │ │ │ // check that the addition and subtraction of vectors does │ │ │ │ │ │ +00330 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17233,54 +16741,54 @@ │ │ │ │ │ │ 00339 │ │ │ │ │ │ cone = Cmomentum(); │ │ │ │ │ │ 00340 │ │ │ │ │ │ dpt=0.0; │ │ │ │ │ │ 00341 │ │ │ │ │ │ } │ │ │ │ │ │ 00342 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.26 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 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; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.24 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00354 │ │ │ │ │ │ hash_element *elm; │ │ │ │ │ │ 00355 │ │ │ │ │ │ //n=0; │ │ │ │ │ │ 00356 │ │ │ │ │ │ 00357 │ │ │ │ │ │ for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ -00358 │ │ │ │ │ │ // test ith cell of the hash array │ │ │ │ │ │ +00358 │ │ │ │ │ │ 00359 │ │ │ │ │ │ elm = hc->hash_array[i]; │ │ │ │ │ │ 00360 │ │ │ │ │ │ // browse elements therein │ │ │ │ │ │ 00361 │ │ │ │ │ │ 00362 │ │ │ │ │ │ while (elm!=NULL){ │ │ │ │ │ │ -// test stability │ │ │ │ │ │ 00363 │ │ │ │ │ │ +// test stability │ │ │ │ │ │ 00364 │ │ │ │ │ │ if (elm->is_stable){ │ │ │ │ │ │ -00365 │ │ │ │ │ │ // stability is not ensured by all pairs of "edges" already browsed │ │ │ │ │ │ +00365 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17329,35 +16837,35 @@ │ │ │ │ │ │ 00393 #endif │ │ │ │ │ │ 00394 │ │ │ │ │ │ 00395 │ │ │ │ │ │ delete hc; │ │ │ │ │ │ 00396 │ │ │ │ │ │ hc=NULL; │ │ │ │ │ │ 00397 │ │ │ │ │ │ -00398 │ │ │ │ │ │ return protocones.size(); │ │ │ │ │ │ +00398 │ │ │ │ │ │ 00399 } │ │ │ │ │ │ 00400 │ │ │ │ │ │ 00401 │ │ │ │ │ │ -// │ │ │ │ │ │ 00403 // ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ +// │ │ │ │ │ │ 00404 // - cocircular_pt_less(v1, v2) │ │ │ │ │ │ // │ │ │ │ │ │ 00405 // - prepare_cocircular_list() │ │ │ │ │ │ // │ │ │ │ │ │ 00406 // - test_cone_cocircular() │ │ │ │ │ │ // │ │ │ │ │ │ 00407 // - test_stability(candidate, border_vect) │ │ │ │ │ │ // │ │ │ │ │ │ 00408 // - updat_cone_cocircular() │ │ │ │ │ │ // │ │ │ │ │ │ 00410 │ │ │ │ │ │ 00412 bool cocircular_pt_less(Cmomentum *v1, Cmomentum *v2){ │ │ │ │ │ │ -00413 │ │ │ │ │ │ return v1->perp2() < v2->perp2(); │ │ │ │ │ │ +00413 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17371,27 +16879,18 @@ │ │ │ │ │ │ vicinity.begin(), │ │ │ │ │ │ 00427 │ │ │ │ │ │ vicinity.end()); │ │ │ │ │ │ 00428 │ │ │ │ │ │ 00429 │ │ │ │ │ │ circulator::iterator > search(here); │ │ │ │ │ │ 00430 │ │ │ │ │ │ -00431 │ │ │ │ │ │ do { │ │ │ │ │ │ +00431 │ │ │ │ │ │ 00432 │ │ │ │ │ │ Cvicinity_elm* here_pntr = *here(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -221 │ │ │ │ │ │ - │ │ │ │ │ │ - 222 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00433 │ │ │ │ │ │ search.set_position(here); │ │ │ │ │ │ 00434 │ │ │ │ │ │ // search forwards for things that should have "here" included in │ │ │ │ │ │ 00435 │ │ │ │ │ │ 00436 │ │ │ │ │ │ // their cocircularity list │ │ │ │ │ │ @@ -17405,41 +16904,50 @@ │ │ │ │ │ │ here_pntr->cocircular_range │ │ │ │ │ │ 00441 │ │ │ │ │ │ && search() != here()) { │ │ │ │ │ │ 00442 │ │ │ │ │ │ (*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ 00443 │ │ │ │ │ │ } else { │ │ │ │ │ │ -break; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +217 │ │ │ │ │ │ + │ │ │ │ │ │ + 218 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00444 │ │ │ │ │ │ +break; │ │ │ │ │ │ 00445 │ │ │ │ │ │ } │ │ │ │ │ │ 00446 │ │ │ │ │ │ } │ │ │ │ │ │ 00447 │ │ │ │ │ │ -00448 │ │ │ │ │ │ // search backwards │ │ │ │ │ │ +00448 │ │ │ │ │ │ 00449 │ │ │ │ │ │ search.set_position(here); │ │ │ │ │ │ -00450 │ │ │ │ │ │ while (true) { │ │ │ │ │ │ +00450 │ │ │ │ │ │ 00451 │ │ │ │ │ │ --search; │ │ │ │ │ │ if ( abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ 00452 │ │ │ │ │ │ 00453 │ │ │ │ │ │ here_pntr->cocircular_range │ │ │ │ │ │ 00454 │ │ │ │ │ │ && search() != here()) { │ │ │ │ │ │ 00455 │ │ │ │ │ │ (*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ 00456 │ │ │ │ │ │ } else { │ │ │ │ │ │ -00457 │ │ │ │ │ │ break; │ │ │ │ │ │ +00457 │ │ │ │ │ │ 00458 │ │ │ │ │ │ } │ │ │ │ │ │ 00459 │ │ │ │ │ │ } │ │ │ │ │ │ 00460 │ │ │ │ │ │ 00461 │ │ │ │ │ │ ++here; │ │ │ │ │ │ @@ -17459,71 +16967,71 @@ │ │ │ │ │ │ 00474 │ │ │ │ │ │ list & border_list) { │ │ │ │ │ │ 00475 │ │ │ │ │ │ vector border_vect; │ │ │ │ │ │ 00476 │ │ │ │ │ │ 00477 │ │ │ │ │ │ border_vect.reserve(border_list.size()); │ │ │ │ │ │ -for (list::iterator it = border_list.begin(); │ │ │ │ │ │ 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 │ │ │ │ │ │ +00483 │ │ │ │ │ │ 00484 │ │ │ │ │ │ sort(border_vect.begin(), border_vect.end()); │ │ │ │ │ │ 00485 │ │ │ │ │ │ // set up some circulators, since these will help us go around the │ │ │ │ │ │ 00486 │ │ │ │ │ │ 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 │ │ │ │ │ │ -// test the borderless cone │ │ │ │ │ │ 00492 │ │ │ │ │ │ +// test the borderless cone │ │ │ │ │ │ 00493 │ │ │ │ │ │ Cmomentum candidate = borderless_cone; │ │ │ │ │ │ 00494 │ │ │ │ │ │ candidate.build_etaphi(); │ │ │ │ │ │ if (candidate.ref.not_empty()) │ │ │ │ │ │ 00495 │ │ │ │ │ │ 00496 │ │ │ │ │ │ test_stability(candidate, border_vect); │ │ │ │ │ │ 00497 │ │ │ │ │ │ -do { │ │ │ │ │ │ 00498 │ │ │ │ │ │ +do { │ │ │ │ │ │ 00499 │ │ │ │ │ │ // reset status wrt inclusion in the cone │ │ │ │ │ │ 00500 │ │ │ │ │ │ mid = start; │ │ │ │ │ │ -do { │ │ │ │ │ │ 00501 │ │ │ │ │ │ +do { │ │ │ │ │ │ 00502 │ │ │ │ │ │ mid()->is_in = false; │ │ │ │ │ │ 00503 │ │ │ │ │ │ } while (++mid != start); │ │ │ │ │ │ 00504 │ │ │ │ │ │ // now run over all inclusion possibilities with this starting point │ │ │ │ │ │ 00505 │ │ │ │ │ │ 00506 │ │ │ │ │ │ candidate = borderless_cone; │ │ │ │ │ │ -00507 │ │ │ │ │ │ while (++mid != start) { │ │ │ │ │ │ -// will begin with start+1 and go up to start-1 │ │ │ │ │ │ +00507 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17536,21 +17044,14 @@ │ │ │ │ │ │ 00516 │ │ │ │ │ │ 00517 │ │ │ │ │ │ // full cone │ │ │ │ │ │ 00518 │ │ │ │ │ │ mid()->is_in = true; │ │ │ │ │ │ 00519 │ │ │ │ │ │ candidate += *(mid()->mom); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.26 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -223 │ │ │ │ │ │ - │ │ │ │ │ │ 00520 │ │ │ │ │ │ test_stability(candidate, border_vect); │ │ │ │ │ │ 00521 } │ │ │ │ │ │ 00522 │ │ │ │ │ │ 00523 │ │ │ │ │ │ 00530 void Cstable_cones::test_stability(Cmomentum & candidate, const vector & border_vect) { │ │ │ │ │ │ 00531 │ │ │ │ │ │ @@ -17559,20 +17060,25 @@ │ │ │ │ │ │ 00533 │ │ │ │ │ │ candidate.build_etaphi(); │ │ │ │ │ │ 00534 │ │ │ │ │ │ bool stable = true; │ │ │ │ │ │ 00535 │ │ │ │ │ │ 00536 │ │ │ │ │ │ for (unsigned i = 0; i < border_vect.size(); i++) { │ │ │ │ │ │ -if (is_inside(&candidate, border_vect[i].mom) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.24 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00537 │ │ │ │ │ │ +if (is_inside(&candidate, border_vect[i].mom) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ 00538 │ │ │ │ │ │ stable = false; │ │ │ │ │ │ -break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ 00539 │ │ │ │ │ │ +break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ 00540 │ │ │ │ │ │ } │ │ │ │ │ │ 00541 │ │ │ │ │ │ } │ │ │ │ │ │ 00542 │ │ │ │ │ │ if (stable) hc->insert(&candidate); │ │ │ │ │ │ 00543 │ │ │ │ │ │ @@ -17595,41 +17101,41 @@ │ │ │ │ │ │ 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 │ │ │ │ │ │ -if (centre->cocircular.empty()) return false; │ │ │ │ │ │ 00561 │ │ │ │ │ │ +if (centre->cocircular.empty()) return false; │ │ │ │ │ │ 00562 │ │ │ │ │ │ // first get cone into status required at end... │ │ │ │ │ │ 00563 │ │ │ │ │ │ 00564 │ │ │ │ │ │ if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ -// update cone │ │ │ │ │ │ 00565 │ │ │ │ │ │ +// update cone │ │ │ │ │ │ 00566 │ │ │ │ │ │ cone -= (*child); │ │ │ │ │ │ 00567 │ │ │ │ │ │ // update info on particles inside │ │ │ │ │ │ 00568 │ │ │ │ │ │ 00569 │ │ │ │ │ │ centre->is_inside->cone = false; │ │ │ │ │ │ 00570 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ 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 │ │ │ │ │ │ +00576 │ │ │ │ │ │ 00577 │ │ │ │ │ │ // first make sure parent and child are in! │ │ │ │ │ │ 00578 │ │ │ │ │ │ 00579 │ │ │ │ │ │ list removed_from_cone; │ │ │ │ │ │ 00580 │ │ │ │ │ │ list put_in_border; │ │ │ │ │ │ @@ -17639,42 +17145,42 @@ │ │ │ │ │ │ 00583 │ │ │ │ │ │ Cmomentum cone_removal; │ │ │ │ │ │ 00584 │ │ │ │ │ │ Cmomentum border = *parent; │ │ │ │ │ │ 00585 │ │ │ │ │ │ border_list.push_back(parent); │ │ │ │ │ │ 00586 │ │ │ │ │ │ -// make sure child appears in the border region │ │ │ │ │ │ 00587 │ │ │ │ │ │ +// make sure child appears in the border region │ │ │ │ │ │ 00588 │ │ │ │ │ │ centre->cocircular.push_back(centre); │ │ │ │ │ │ 00589 │ │ │ │ │ │ // now establish the full contents of the cone minus the cocircular │ │ │ │ │ │ 00590 │ │ │ │ │ │ 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) { │ │ │ │ │ │ +00595 │ │ │ │ │ │ 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 │ │ │ │ │ │ +00601 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17688,24 +17194,17 @@ │ │ │ │ │ │ 00609 │ │ │ │ │ │ border_list.push_back((*it)->v); │ │ │ │ │ │ 00610 │ │ │ │ │ │ } │ │ │ │ │ │ 00611 │ │ │ │ │ │ } │ │ │ │ │ │ 00612 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 224 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00613 │ │ │ │ │ │ -// figure out whether this pairing has been observed before │ │ │ │ │ │ 00614 │ │ │ │ │ │ +// figure out whether this pairing has been observed before │ │ │ │ │ │ 00615 │ │ │ │ │ │ Cmomentum borderless_cone = cone; │ │ │ │ │ │ 00616 │ │ │ │ │ │ borderless_cone -= cone_removal; │ │ │ │ │ │ bool consider = true; │ │ │ │ │ │ 00617 │ │ │ │ │ │ 00618 │ │ │ │ │ │ @@ -17715,38 +17214,47 @@ │ │ │ │ │ │ 00620 │ │ │ │ │ │ (multiple_centre_done[i].second==border.ref)) │ │ │ │ │ │ 00621 │ │ │ │ │ │ consider = false; │ │ │ │ │ │ 00622 │ │ │ │ │ │ } │ │ │ │ │ │ 00623 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +219 │ │ │ │ │ │ + │ │ │ │ │ │ + 220 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00624 │ │ │ │ │ │ // now prepare the hard work │ │ │ │ │ │ 00625 │ │ │ │ │ │ if (consider) { │ │ │ │ │ │ -// record the fact that we’ve now seen this combination │ │ │ │ │ │ 00626 │ │ │ │ │ │ +// record the fact that we’ve now seen this combination │ │ │ │ │ │ 00627 │ │ │ │ │ │ multiple_centre_done.push_back(pair(borderless_cone.ref, │ │ │ │ │ │ 00628 │ │ │ │ │ │ border.ref)); │ │ │ │ │ │ 00629 │ │ │ │ │ │ // first figure out whether our cone momentum is good │ │ │ │ │ │ 00630 │ │ │ │ │ │ 00631 │ │ │ │ │ │ double local_dpt = fabs(cone_removal.px) + fabs(cone_removal.py); │ │ │ │ │ │ -00632 │ │ │ │ │ │ double total_dpt = dpt + local_dpt; │ │ │ │ │ │ +00632 │ │ │ │ │ │ 00633 │ │ │ │ │ │ 00634 │ │ │ │ │ │ recompute_cone_contents_if_needed(borderless_cone, total_dpt); │ │ │ │ │ │ 00635 │ │ │ │ │ │ if (total_dpt == 0) { │ │ │ │ │ │ -// a recomputation has taken place -- so take advantage of this │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17754,38 +17262,38 @@ │ │ │ │ │ │ 00641 │ │ │ │ │ │ 00642 │ │ │ │ │ │ test_cone_cocircular(borderless_cone, border_list); │ │ │ │ │ │ 00643 │ │ │ │ │ │ } │ │ │ │ │ │ 00644 │ │ │ │ │ │ 00645 │ │ │ │ │ │ -00646 │ │ │ │ │ │ // relabel things that were in the cone but got removed │ │ │ │ │ │ +00646 │ │ │ │ │ │ 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 │ │ │ │ │ │ -// relabel things that got put into the border │ │ │ │ │ │ 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 │ │ │ │ │ │ -// we’re done with everything -- return true to signal to user that we’ve │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17803,95 +17311,95 @@ │ │ │ │ │ │ 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 │ │ │ │ │ │ +00685 │ │ │ │ │ │ 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 │ │ │ │ │ │ -do { │ │ │ │ │ │ 00691 │ │ │ │ │ │ -00692 │ │ │ │ │ │ +do { │ │ │ │ │ │ // as we leave this position a particle enters if its side is │ │ │ │ │ │ +00692 │ │ │ │ │ │ 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 │ │ │ │ │ │ +00697 │ │ │ │ │ │ 00698 │ │ │ │ │ │ ++here; │ │ │ │ │ │ 00699 │ │ │ │ │ │ // as we arrive at this position a particle leaves if its side is positive │ │ │ │ │ │ 00700 │ │ │ │ │ │ 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 │ │ │ │ │ │ +00704 │ │ │ │ │ │ 00705 │ │ │ │ │ │ // 100% complete, so we can use it to calculate the cone contents │ │ │ │ │ │ 00706 │ │ │ │ │ │ // and then exit │ │ │ │ │ │ 00707 │ │ │ │ │ │ recompute_cone_contents(); │ │ │ │ │ │ -return; │ │ │ │ │ │ 00708 │ │ │ │ │ │ +return; │ │ │ │ │ │ 00709 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.26 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 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; │ │ │ │ │ │ +00719 │ │ │ │ │ │ 00720 │ │ │ │ │ │ -// set momentum to 0 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.24 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00721 │ │ │ │ │ │ +// set momentum to 0 │ │ │ │ │ │ 00722 │ │ │ │ │ │ cone = Cmomentum(); │ │ │ │ │ │ 00723 │ │ │ │ │ │ -// Important note: we can browse only the particles │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -17905,27 +17413,27 @@ │ │ │ │ │ │ 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, │ │ │ │ │ │ -double & this_dpt){ │ │ │ │ │ │ 00747 │ │ │ │ │ │ +double & this_dpt){ │ │ │ │ │ │ 00748 │ │ │ │ │ │ if (this_dpt > PT_TSHOLD*(fabs(this_cone.px)+fabs(this_cone.py))) { │ │ │ │ │ │ 00749 │ │ │ │ │ │ 00750 │ │ │ │ │ │ if (cone.ref.is_empty()) { │ │ │ │ │ │ 00751 │ │ │ │ │ │ this_cone = Cmomentum(); │ │ │ │ │ │ 00752 │ │ │ │ │ │ } else { │ │ │ │ │ │ -00753 │ │ │ │ │ │ // set momentum to 0 │ │ │ │ │ │ +00753 │ │ │ │ │ │ 00754 │ │ │ │ │ │ this_cone = Cmomentum(); │ │ │ │ │ │ 00755 │ │ │ │ │ │ // Important note: we can browse only the particles │ │ │ │ │ │ 00756 │ │ │ │ │ │ 00757 │ │ │ │ │ │ // in vicinity since all particles in the this_cone are │ │ │ │ │ │ @@ -17954,93 +17462,93 @@ │ │ │ │ │ │ this_dpt = 0.0; │ │ │ │ │ │ 00770 │ │ │ │ │ │ } │ │ │ │ │ │ 00771 │ │ │ │ │ │ 00772 } │ │ │ │ │ │ 00773 │ │ │ │ │ │ 00774 │ │ │ │ │ │ -00776 // VARIOUS TOOLS │ │ │ │ │ │ // │ │ │ │ │ │ +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 │ │ │ │ │ │ -circle centre y coordinate │ │ │ │ │ │ +00787 * - cx │ │ │ │ │ │ 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; │ │ │ │ │ │ -double dx, dy; │ │ │ │ │ │ +00793 │ │ │ │ │ │ 00794 │ │ │ │ │ │ +double dx, dy; │ │ │ │ │ │ 00795 │ │ │ │ │ │ -00796 │ │ │ │ │ │ for (i=0;iM_PI) │ │ │ │ │ │ 00803 │ │ │ │ │ │ dy -= twopi; │ │ │ │ │ │ 00804 │ │ │ │ │ │ -// really check if the distance is less than VR │ │ │ │ │ │ 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); │ │ │ │ │ │ if (dy>M_PI) │ │ │ │ │ │ 00826 │ │ │ │ │ │ @@ -18050,38 +17558,38 @@ │ │ │ │ │ │ 00829 │ │ │ │ │ │ return dx*dx+dy*dyM_PI) │ │ │ │ │ │ 00843 │ │ │ │ │ │ +if (dphi>M_PI) │ │ │ │ │ │ 00844 │ │ │ │ │ │ dphi = dphi-twopi; │ │ │ │ │ │ 00845 │ │ │ │ │ │ 00846 │ │ │ │ │ │ return dphi; │ │ │ │ │ │ 00847 } │ │ │ │ │ │ 00848 │ │ │ │ │ │ 00849 } │ │ │ │ │ │ │ │ │ │ │ │ -5.27 protocones.cpp │ │ │ │ │ │ +5.25 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. │ │ │ │ │ │ // │ │ │ │ │ │ @@ -18129,19 +17637,14 @@ │ │ │ │ │ │ $// │ │ │ │ │ │ 00026 // $Date:: 2011-10-05 23:27:09 +0200 (Wed, 05 Oct 2011) │ │ │ │ │ │ $// │ │ │ │ │ │ 00028 │ │ │ │ │ │ 00029 /******************************************************* │ │ │ │ │ │ 00030 * Introductory note: │ │ │ │ │ │ * │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.27 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00031 * Since this file has many member functions, we have * │ │ │ │ │ │ 00032 * structured them in categories: │ │ │ │ │ │ * │ │ │ │ │ │ 00033 * INITIALISATION FUNCTIONS │ │ │ │ │ │ * │ │ │ │ │ │ 00034 * - ctor() │ │ │ │ │ │ * │ │ │ │ │ │ @@ -18155,14 +17658,19 @@ │ │ │ │ │ │ * │ │ │ │ │ │ 00039 * - get_stable_cone(radius) │ │ │ │ │ │ * │ │ │ │ │ │ 00040 * ALGORITHM MAIN STEPS │ │ │ │ │ │ * │ │ │ │ │ │ 00041 * - init_cone() │ │ │ │ │ │ * │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.25 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00042 * - test_cone() │ │ │ │ │ │ * │ │ │ │ │ │ 00043 * - update_cone() │ │ │ │ │ │ * │ │ │ │ │ │ 00044 * - proceed_with_stability() │ │ │ │ │ │ * │ │ │ │ │ │ 00045 * ALGORITHM MAIN STEPS FOR COCIRCULAR SITUATIONS │ │ │ │ │ │ @@ -18216,16 +17724,16 @@ │ │ │ │ │ │ * │ │ │ │ │ │ 00077 * it is used to compute the list of stable cones given a list │ │ │ │ │ │ * │ │ │ │ │ │ 00078 * of particles. │ │ │ │ │ │ * │ │ │ │ │ │ 00079 **********************************************************************/ │ │ │ │ │ │ 00080 │ │ │ │ │ │ -00082 // INITIALISATION FUNCTIONS │ │ │ │ │ │ // │ │ │ │ │ │ +00082 // INITIALISATION FUNCTIONS │ │ │ │ │ │ 00083 // - ctor() │ │ │ │ │ │ // │ │ │ │ │ │ 00084 // - ctor(particle_list) │ │ │ │ │ │ // │ │ │ │ │ │ 00085 // - dtor() │ │ │ │ │ │ // │ │ │ │ │ │ 00086 // - init(particle_list) │ │ │ │ │ │ @@ -18248,40 +17756,31 @@ │ │ │ │ │ │ nb_tot = 0; │ │ │ │ │ │ 00102 │ │ │ │ │ │ hc = NULL; │ │ │ │ │ │ 00103 } │ │ │ │ │ │ 00104 │ │ │ │ │ │ 00105 // default dtor │ │ │ │ │ │ 00106 //-------------00107 CSphstable_cones::~CSphstable_cones(){ │ │ │ │ │ │ -if (hc!=NULL) delete hc; │ │ │ │ │ │ 00108 │ │ │ │ │ │ +if (hc!=NULL) delete hc; │ │ │ │ │ │ 00109 } │ │ │ │ │ │ 00110 │ │ │ │ │ │ 00111 /* │ │ │ │ │ │ 00112 * initialisation │ │ │ │ │ │ 00113 * - _particle_list list of particles │ │ │ │ │ │ -number of particles │ │ │ │ │ │ 00114 * - _n │ │ │ │ │ │ +number of particles │ │ │ │ │ │ 00115 *********************************************************************/ │ │ │ │ │ │ 00116 void CSphstable_cones::init(vector &_particle_list){ │ │ │ │ │ │ -// check already allocated mem │ │ │ │ │ │ 00117 │ │ │ │ │ │ +// check already allocated mem │ │ │ │ │ │ 00118 │ │ │ │ │ │ if (hc!=NULL){ │ │ │ │ │ │ -00119 │ │ │ │ │ │ delete hc; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -227 │ │ │ │ │ │ - │ │ │ │ │ │ - 228 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ } │ │ │ │ │ │ if (protocones.size()!=0) │ │ │ │ │ │ 00121 │ │ │ │ │ │ 00122 │ │ │ │ │ │ protocones.clear(); │ │ │ │ │ │ 00123 │ │ │ │ │ │ @@ -18291,29 +17790,38 @@ │ │ │ │ │ │ 00126 │ │ │ │ │ │ // initialisation │ │ │ │ │ │ 00127 │ │ │ │ │ │ set_particle_list(_particle_list); │ │ │ │ │ │ 00128 } │ │ │ │ │ │ 00129 │ │ │ │ │ │ 00130 │ │ │ │ │ │ -// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +223 │ │ │ │ │ │ + │ │ │ │ │ │ + 224 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 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; │ │ │ │ │ │ +00144 │ │ │ │ │ │ 00145 │ │ │ │ │ │ // check if everything is correctly initialised │ │ │ │ │ │ 00146 │ │ │ │ │ │ 00147 │ │ │ │ │ │ if (n_part==0){ │ │ │ │ │ │ 00148 │ │ │ │ │ │ return 0; │ │ │ │ │ │ @@ -18325,25 +17833,25 @@ │ │ │ │ │ │ 00152 │ │ │ │ │ │ R2 = R*R; │ │ │ │ │ │ 00153 │ │ │ │ │ │ tan2R = tan(R); │ │ │ │ │ │ 00154 │ │ │ │ │ │ tan2R *= tan2R; │ │ │ │ │ │ 00155 │ │ │ │ │ │ -// allow hash for cones candidates │ │ │ │ │ │ 00156 │ │ │ │ │ │ +// allow hash for cones candidates │ │ │ │ │ │ 00157 │ │ │ │ │ │ hc = new sph_hash_cones(n_part, R); │ │ │ │ │ │ 00158 │ │ │ │ │ │ // browse all particles │ │ │ │ │ │ 00159 │ │ │ │ │ │ 00160 │ │ │ │ │ │ for (p_idx=0;p_idx_phi « ", " « parent->_theta « endl; │ │ │ │ │ │ 00177 #endif │ │ │ │ │ │ 00178 │ │ │ │ │ │ -00179 │ │ │ │ │ │ // step 1: initialise with the first cone candidate │ │ │ │ │ │ +00179 │ │ │ │ │ │ 00180 │ │ │ │ │ │ init_cone(); │ │ │ │ │ │ 00181 │ │ │ │ │ │ -00182 │ │ │ │ │ │ do{ │ │ │ │ │ │ -// step 2: test cone stability for that pair (P,C) │ │ │ │ │ │ +00182 │ │ │ │ │ │ 00183 │ │ │ │ │ │ +// step 2: test cone stability for that pair (P,C) │ │ │ │ │ │ 00184 │ │ │ │ │ │ test_cone(); │ │ │ │ │ │ 00185 │ │ │ │ │ │ // step 3: go to the next cone child candidate C │ │ │ │ │ │ 00186 │ │ │ │ │ │ 00187 │ │ │ │ │ │ } while (!update_cone()); │ │ │ │ │ │ @@ -18392,16 +17900,16 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 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() │ │ │ │ │ │ @@ -18410,23 +17918,18 @@ │ │ │ │ │ │ 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(){ │ │ │ │ │ │ -// The previous version of the algorithm was starting the │ │ │ │ │ │ 00209 │ │ │ │ │ │ +// The previous version of the algorithm was starting the │ │ │ │ │ │ 00210 │ │ │ │ │ │ // loop around vicinity elements with the "most isolated" child. │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.27 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -18439,17 +17942,22 @@ │ │ │ │ │ │ 00218 │ │ │ │ │ │ 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 ! │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.25 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00222 │ │ │ │ │ │ -00223 │ │ │ │ │ │ // init set child C │ │ │ │ │ │ +00223 │ │ │ │ │ │ 00224 │ │ │ │ │ │ centre = vicinity[first_cone]; │ │ │ │ │ │ 00225 │ │ │ │ │ │ child = centre->v; │ │ │ │ │ │ 00226 │ │ │ │ │ │ centre_idx = first_cone; │ │ │ │ │ │ 00227 │ │ │ │ │ │ @@ -18457,44 +17965,44 @@ │ │ │ │ │ │ 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; │ │ │ │ │ │ +00233 │ │ │ │ │ │ 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, │ │ │ │ │ │ +00246 │ │ │ │ │ │ 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 │ │ │ │ │ │ -// here are the tests entering the first series: │ │ │ │ │ │ 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 │ │ │ │ │ │ //UPDATED(see below): if (centre->side){ │ │ │ │ │ │ 00257 │ │ │ │ │ │ @@ -18552,58 +18060,49 @@ │ │ │ │ │ │ 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 │ │ │ │ │ │ +00280 │ │ │ │ │ │ 00281 │ │ │ │ │ │ // when the parent has an energy bigger than the child │ │ │ │ │ │ 00282 │ │ │ │ │ │ if (parent->E >= child->E){ │ │ │ │ │ │ // test when both particles are not in the cone │ │ │ │ │ │ 00283 │ │ │ │ │ │ 00284 │ │ │ │ │ │ // Note: for the totally exclusive case, test emptiness before │ │ │ │ │ │ 00285 │ │ │ │ │ │ cone_candidate = cone; │ │ │ │ │ │ -if (cone.ref.not_empty()){ │ │ │ │ │ │ 00286 │ │ │ │ │ │ +if (cone.ref.not_empty()){ │ │ │ │ │ │ 00287 │ │ │ │ │ │ hc->insert(&cone_candidate, parent, child, false, false); │ │ │ │ │ │ 00288 │ │ │ │ │ │ } │ │ │ │ │ │ 00289 │ │ │ │ │ │ -// test when 1! of the particles is in the cone │ │ │ │ │ │ 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 │ │ │ │ │ │ 00294 │ │ │ │ │ │ cone_candidate = cone; │ │ │ │ │ │ 00295 │ │ │ │ │ │ cone_candidate += *child; │ │ │ │ │ │ 00296 │ │ │ │ │ │ hc->insert(&cone_candidate, parent, child, false, true); │ │ │ │ │ │ 00297 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -229 │ │ │ │ │ │ - │ │ │ │ │ │ - 230 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00298 │ │ │ │ │ │ // test when both are in. │ │ │ │ │ │ +00298 │ │ │ │ │ │ 00299 │ │ │ │ │ │ cone_candidate += *parent; │ │ │ │ │ │ 00300 │ │ │ │ │ │ hc->insert(&cone_candidate, parent, child, true, true); │ │ │ │ │ │ 00301 │ │ │ │ │ │ 00302 │ │ │ │ │ │ nb_tot += 4; │ │ │ │ │ │ @@ -18611,14 +18110,23 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 00304 │ │ │ │ │ │ 00305 │ │ │ │ │ │ 00306 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00307 } │ │ │ │ │ │ 00308 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +225 │ │ │ │ │ │ + │ │ │ │ │ │ + 226 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00309 │ │ │ │ │ │ 00310 /* │ │ │ │ │ │ 00311 * update the cone │ │ │ │ │ │ 00312 * go to the next child for that parent and update ’cone’ appropriately │ │ │ │ │ │ 00313 * return 0 if update candidate found, 1 otherwise │ │ │ │ │ │ 00314 ***********************************************************************/ │ │ │ │ │ │ 00315 int CSphstable_cones::update_cone(){ │ │ │ │ │ │ @@ -18627,26 +18135,26 @@ │ │ │ │ │ │ cout « "call ’circles_plot.gp’ ’" « centre->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 │ │ │ │ │ │ +00322 │ │ │ │ │ │ 00323 │ │ │ │ │ │ centre_idx++; │ │ │ │ │ │ 00324 │ │ │ │ │ │ if (centre_idx==vicinity_size) │ │ │ │ │ │ 00325 │ │ │ │ │ │ centre_idx=0; │ │ │ │ │ │ if (centre_idx==first_cone) │ │ │ │ │ │ 00326 │ │ │ │ │ │ -00327 │ │ │ │ │ │ return 1; │ │ │ │ │ │ +00327 │ │ │ │ │ │ 00328 │ │ │ │ │ │ // update the cone w.r.t. the old child │ │ │ │ │ │ 00329 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -18664,30 +18172,30 @@ │ │ │ │ │ │ cone += (*child); │ │ │ │ │ │ 00339 │ │ │ │ │ │ // update info on particles inside │ │ │ │ │ │ 00340 │ │ │ │ │ │ 00341 │ │ │ │ │ │ centre->is_inside->cone = true; │ │ │ │ │ │ 00342 │ │ │ │ │ │ -// update stability check quantities │ │ │ │ │ │ 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 │ │ │ │ │ │ +00347 │ │ │ │ │ │ 00348 │ │ │ │ │ │ centre = vicinity[centre_idx]; │ │ │ │ │ │ 00349 │ │ │ │ │ │ child = centre->v; │ │ │ │ │ │ 00350 │ │ │ │ │ │ -// check cocircularity │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -18699,31 +18207,31 @@ │ │ │ │ │ │ cout « " Co-circular case detected" « endl; │ │ │ │ │ │ 00359 #endif │ │ │ │ │ │ 00360 │ │ │ │ │ │ return update_cone(); │ │ │ │ │ │ 00361 │ │ │ │ │ │ } │ │ │ │ │ │ 00362 │ │ │ │ │ │ -// update the cone w.r.t. the new child │ │ │ │ │ │ 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 │ │ │ │ │ │ +00372 │ │ │ │ │ │ 00373 │ │ │ │ │ │ cone -= (*child); │ │ │ │ │ │ 00374 │ │ │ │ │ │ // update info on particles inside │ │ │ │ │ │ 00375 │ │ │ │ │ │ 00376 │ │ │ │ │ │ centre->is_inside->cone = false; │ │ │ │ │ │ @@ -18731,25 +18239,20 @@ │ │ │ │ │ │ // update stability check quantities │ │ │ │ │ │ 00378 │ │ │ │ │ │ 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 │ │ │ │ │ │ +00382 │ │ │ │ │ │ 00383 │ │ │ │ │ │ // not lead to too much rounding error │ │ │ │ │ │ 00384 │ │ │ │ │ │ // for that, we compute the sum of pt modifications and of |pt| │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.27 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -18762,14 +18265,19 @@ │ │ │ │ │ │ cone = CSphmomentum(); │ │ │ │ │ │ 00392 │ │ │ │ │ │ dpt=0.0; │ │ │ │ │ │ 00393 │ │ │ │ │ │ } │ │ │ │ │ │ 00394 │ │ │ │ │ │ 00395 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.25 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00396 │ │ │ │ │ │ cout « "’" « endl; │ │ │ │ │ │ 00397 #endif │ │ │ │ │ │ 00398 │ │ │ │ │ │ 00399 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00400 } │ │ │ │ │ │ @@ -18777,36 +18285,36 @@ │ │ │ │ │ │ 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; │ │ │ │ │ │ +00409 │ │ │ │ │ │ 00410 │ │ │ │ │ │ sph_hash_element *elm; │ │ │ │ │ │ 00411 │ │ │ │ │ │ -for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ 00412 │ │ │ │ │ │ +for (i=0;i<=hc->mask;i++){ │ │ │ │ │ │ 00413 │ │ │ │ │ │ // test ith cell of the hash array │ │ │ │ │ │ 00414 │ │ │ │ │ │ elm = hc->hash_array[i]; │ │ │ │ │ │ 00415 │ │ │ │ │ │ // browse elements therein │ │ │ │ │ │ 00416 │ │ │ │ │ │ 00417 │ │ │ │ │ │ while (elm!=NULL){ │ │ │ │ │ │ 00418 │ │ │ │ │ │ // test stability │ │ │ │ │ │ 00419 │ │ │ │ │ │ if (elm->is_stable){ │ │ │ │ │ │ -// stability is not ensured by all pairs of "edges" already browsed │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -18815,16 +18323,16 @@ │ │ │ │ │ │ if (circle_intersect(elm->centre)==elm->centre.ref) │ │ │ │ │ │ 00427 #endif │ │ │ │ │ │ 00428 │ │ │ │ │ │ protocones.push_back(CSphmomentum(elm->centre,1.0)); │ │ │ │ │ │ 00429 │ │ │ │ │ │ } │ │ │ │ │ │ 00430 │ │ │ │ │ │ -// jump to the next one │ │ │ │ │ │ 00431 │ │ │ │ │ │ +// jump to the next one │ │ │ │ │ │ 00432 │ │ │ │ │ │ elm = elm->next; │ │ │ │ │ │ 00433 │ │ │ │ │ │ } │ │ │ │ │ │ 00434 │ │ │ │ │ │ } │ │ │ │ │ │ 00435 │ │ │ │ │ │ @@ -18842,21 +18350,21 @@ │ │ │ │ │ │ 00442 #endif │ │ │ │ │ │ 00443 │ │ │ │ │ │ 00444 │ │ │ │ │ │ delete hc; │ │ │ │ │ │ 00445 │ │ │ │ │ │ hc=NULL; │ │ │ │ │ │ 00446 │ │ │ │ │ │ -00447 │ │ │ │ │ │ return protocones.size(); │ │ │ │ │ │ +00447 │ │ │ │ │ │ 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) │ │ │ │ │ │ @@ -18874,23 +18382,14 @@ │ │ │ │ │ │ 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() { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -231 │ │ │ │ │ │ - │ │ │ │ │ │ - 232 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00475 │ │ │ │ │ │ siscone::circulator::iterator > here(vicinity.begin(), │ │ │ │ │ │ 00476 │ │ │ │ │ │ vicinity.begin(), │ │ │ │ │ │ 00477 │ │ │ │ │ │ vicinity.end()); │ │ │ │ │ │ 00478 │ │ │ │ │ │ @@ -18902,57 +18401,66 @@ │ │ │ │ │ │ 00482 │ │ │ │ │ │ CSphvicinity_elm* here_pntr = *here(); │ │ │ │ │ │ 00483 │ │ │ │ │ │ search.set_position(here); │ │ │ │ │ │ 00484 │ │ │ │ │ │ 00485 │ │ │ │ │ │ // search forwards for things that should have "here" included in │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +227 │ │ │ │ │ │ + │ │ │ │ │ │ + 228 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00486 │ │ │ │ │ │ // their cocircularity list │ │ │ │ │ │ 00487 │ │ │ │ │ │ while (true) { │ │ │ │ │ │ 00488 │ │ │ │ │ │ ++search; │ │ │ │ │ │ -if ( siscone::abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ 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; │ │ │ │ │ │ +00494 │ │ │ │ │ │ 00495 │ │ │ │ │ │ } │ │ │ │ │ │ 00496 │ │ │ │ │ │ } │ │ │ │ │ │ 00497 │ │ │ │ │ │ -// search backwards │ │ │ │ │ │ 00498 │ │ │ │ │ │ +// search backwards │ │ │ │ │ │ 00499 │ │ │ │ │ │ search.set_position(here); │ │ │ │ │ │ -while (true) { │ │ │ │ │ │ 00500 │ │ │ │ │ │ +while (true) { │ │ │ │ │ │ 00501 │ │ │ │ │ │ --search; │ │ │ │ │ │ if ( siscone::abs_dphi((*search())->angle, here_pntr->angle) < │ │ │ │ │ │ 00502 │ │ │ │ │ │ 00503 │ │ │ │ │ │ here_pntr->cocircular_range │ │ │ │ │ │ 00504 │ │ │ │ │ │ && search() != here()) { │ │ │ │ │ │ 00505 │ │ │ │ │ │ (*search())->cocircular.push_back(here_pntr); │ │ │ │ │ │ 00506 │ │ │ │ │ │ } else { │ │ │ │ │ │ -break; │ │ │ │ │ │ 00507 │ │ │ │ │ │ +break; │ │ │ │ │ │ 00508 │ │ │ │ │ │ } │ │ │ │ │ │ 00509 │ │ │ │ │ │ } │ │ │ │ │ │ 00510 │ │ │ │ │ │ 00511 │ │ │ │ │ │ ++here; │ │ │ │ │ │ @@ -18987,90 +18495,90 @@ │ │ │ │ │ │ 00531 │ │ │ │ │ │ // now we have te reference axis, create the CSphborder_store structure │ │ │ │ │ │ 00532 │ │ │ │ │ │ 00533 │ │ │ │ │ │ vector border_vect; │ │ │ │ │ │ 00534 │ │ │ │ │ │ border_vect.reserve(border_list.size()); │ │ │ │ │ │ -00535 │ │ │ │ │ │ for (list::iterator it = border_list.begin(); │ │ │ │ │ │ +00535 │ │ │ │ │ │ 00536 │ │ │ │ │ │ it != border_list.end(); it++) { │ │ │ │ │ │ 00537 │ │ │ │ │ │ border_vect.push_back(CSphborder_store(*it, centre->centre, angl_dir1, angl_dir2)); │ │ │ │ │ │ 00538 │ │ │ │ │ │ } │ │ │ │ │ │ 00539 │ │ │ │ │ │ -// get them into order of angle │ │ │ │ │ │ 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 │ │ │ │ │ │ +00543 │ │ │ │ │ │ 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 │ │ │ │ │ │ +00549 │ │ │ │ │ │ 00550 │ │ │ │ │ │ CSphmomentum candidate = borderless_cone; │ │ │ │ │ │ -00551 │ │ │ │ │ │ //candidate.build_etaphi(); │ │ │ │ │ │ +00551 │ │ │ │ │ │ 00552 │ │ │ │ │ │ if (candidate.ref.not_empty()) │ │ │ │ │ │ 00553 │ │ │ │ │ │ test_stability(candidate, border_vect); │ │ │ │ │ │ 00554 │ │ │ │ │ │ 00555 │ │ │ │ │ │ do { │ │ │ │ │ │ -00556 │ │ │ │ │ │ // reset status wrt inclusion in the cone │ │ │ │ │ │ +00556 │ │ │ │ │ │ 00557 │ │ │ │ │ │ mid = start; │ │ │ │ │ │ -00558 │ │ │ │ │ │ do { │ │ │ │ │ │ +00558 │ │ │ │ │ │ 00559 │ │ │ │ │ │ mid()->is_in = false; │ │ │ │ │ │ 00560 │ │ │ │ │ │ } while (++mid != start); │ │ │ │ │ │ 00561 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.27 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00562 │ │ │ │ │ │ // now run over all inclusion possibilities with this starting point │ │ │ │ │ │ +00562 │ │ │ │ │ │ 00563 │ │ │ │ │ │ candidate = borderless_cone; │ │ │ │ │ │ 00564 │ │ │ │ │ │ while (++mid != start) { │ │ │ │ │ │ -00565 │ │ │ │ │ │ // will begin with start+1 and go up to start-1 │ │ │ │ │ │ +00565 │ │ │ │ │ │ 00566 │ │ │ │ │ │ mid()->is_in = true; │ │ │ │ │ │ 00567 │ │ │ │ │ │ candidate += *(mid()->mom); │ │ │ │ │ │ 00568 │ │ │ │ │ │ test_stability(candidate, border_vect); │ │ │ │ │ │ 00569 │ │ │ │ │ │ } │ │ │ │ │ │ 00570 │ │ │ │ │ │ 00571 │ │ │ │ │ │ } while (++start != end); │ │ │ │ │ │ 00572 │ │ │ │ │ │ -// mid corresponds to momentum that we need to include to get the │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.25 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -19082,24 +18590,24 @@ │ │ │ │ │ │ border_vect) { │ │ │ │ │ │ 00588 │ │ │ │ │ │ 00589 │ │ │ │ │ │ // this almost certainly has not been done... │ │ │ │ │ │ 00590 │ │ │ │ │ │ //candidate.build_etaphi(); │ │ │ │ │ │ 00591 │ │ │ │ │ │ -bool stable = true; │ │ │ │ │ │ 00592 │ │ │ │ │ │ +bool stable = true; │ │ │ │ │ │ 00593 │ │ │ │ │ │ for (unsigned i = 0; i < border_vect.size(); i++) { │ │ │ │ │ │ if (is_closer(&candidate, border_vect[i].mom,tan2R) ^ (border_vect[i].is_in)) { │ │ │ │ │ │ 00594 │ │ │ │ │ │ 00595 │ │ │ │ │ │ stable = false; │ │ │ │ │ │ -00596 │ │ │ │ │ │ break; // it’s unstable so there’s no point continuing │ │ │ │ │ │ +00596 │ │ │ │ │ │ 00597 │ │ │ │ │ │ } │ │ │ │ │ │ 00598 │ │ │ │ │ │ } │ │ │ │ │ │ 00599 │ │ │ │ │ │ 00600 │ │ │ │ │ │ if (stable) hc->insert(&candidate); │ │ │ │ │ │ @@ -19109,36 +18617,36 @@ │ │ │ │ │ │ 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(){ │ │ │ │ │ │ -// check if many configurations have the same centre. │ │ │ │ │ │ 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 │ │ │ │ │ │ -if (centre->cocircular.empty()) return false; │ │ │ │ │ │ 00618 │ │ │ │ │ │ +if (centre->cocircular.empty()) return false; │ │ │ │ │ │ 00619 │ │ │ │ │ │ // first get cone into status required at end... │ │ │ │ │ │ 00620 │ │ │ │ │ │ 00621 │ │ │ │ │ │ if ((centre->side) && (cone.ref.not_empty())){ │ │ │ │ │ │ -00622 │ │ │ │ │ │ // update cone │ │ │ │ │ │ +00622 │ │ │ │ │ │ 00623 │ │ │ │ │ │ cone -= (*child); │ │ │ │ │ │ 00624 │ │ │ │ │ │ // update info on particles inside │ │ │ │ │ │ 00625 │ │ │ │ │ │ 00626 │ │ │ │ │ │ centre->is_inside->cone = false; │ │ │ │ │ │ @@ -19185,102 +18693,101 @@ │ │ │ │ │ │ it != centre->cocircular.end(); it++) { │ │ │ │ │ │ 00651 │ │ │ │ │ │ 00652 │ │ │ │ │ │ if ((*it)->is_inside->cone) { │ │ │ │ │ │ 00653 │ │ │ │ │ │ cone_removal │ │ │ │ │ │ += *((*it)->v); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -233 │ │ │ │ │ │ - │ │ │ │ │ │ - 234 │ │ │ │ │ │ - │ │ │ │ │ │ 00654 │ │ │ │ │ │ +(*it)->is_inside->cone = false; │ │ │ │ │ │ 00655 │ │ │ │ │ │ +removed_from_cone.push_back((*it)->is_inside); │ │ │ │ │ │ 00656 │ │ │ │ │ │ +} │ │ │ │ │ │ 00657 │ │ │ │ │ │ +// if a point appears twice (i.e. with + and - sign) in the list of │ │ │ │ │ │ 00658 │ │ │ │ │ │ 00659 │ │ │ │ │ │ +// points on the border, we take care not to include it twice. │ │ │ │ │ │ 00660 │ │ │ │ │ │ +// Note that this situation may appear when a point is at a distance │ │ │ │ │ │ 00661 │ │ │ │ │ │ +// close to 2R from the parent │ │ │ │ │ │ 00662 │ │ │ │ │ │ +if (!(*it)->is_inside->cocirc) { │ │ │ │ │ │ 00663 │ │ │ │ │ │ +border += *((*it)->v); │ │ │ │ │ │ 00664 │ │ │ │ │ │ -00665 │ │ │ │ │ │ -00666 │ │ │ │ │ │ -00667 │ │ │ │ │ │ +(*it)->is_inside->cocirc = true; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +229 │ │ │ │ │ │ + │ │ │ │ │ │ + 230 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -(*it)->is_inside->cone = false; │ │ │ │ │ │ -removed_from_cone.push_back((*it)->is_inside); │ │ │ │ │ │ -} │ │ │ │ │ │ +00665 │ │ │ │ │ │ +00666 │ │ │ │ │ │ +00667 │ │ │ │ │ │ │ │ │ │ │ │ -// 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 │ │ │ │ │ │ -// figure out whether this pairing has been observed before │ │ │ │ │ │ 00672 │ │ │ │ │ │ +// figure out whether this pairing has been observed before │ │ │ │ │ │ 00673 │ │ │ │ │ │ CSphmomentum borderless_cone = cone; │ │ │ │ │ │ 00674 │ │ │ │ │ │ borderless_cone -= cone_removal; │ │ │ │ │ │ -00675 │ │ │ │ │ │ bool consider = true; │ │ │ │ │ │ -for (unsigned int i=0;i(borderless_cone.ref, │ │ │ │ │ │ 00686 │ │ │ │ │ │ border.ref)); │ │ │ │ │ │ 00687 │ │ │ │ │ │ -00688 │ │ │ │ │ │ // first figure out whether our cone momentum is good │ │ │ │ │ │ +00688 │ │ │ │ │ │ 00689 │ │ │ │ │ │ double local_dpt = fabs(cone_removal.px) + fabs(cone_removal.py); │ │ │ │ │ │ -double total_dpt = dpt + local_dpt; │ │ │ │ │ │ 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 │ │ │ │ │ │ +00694 │ │ │ │ │ │ 00695 │ │ │ │ │ │ // and update the member cone momentum │ │ │ │ │ │ 00696 │ │ │ │ │ │ cone = borderless_cone + cone_removal; │ │ │ │ │ │ 00697 │ │ │ │ │ │ dpt = local_dpt; │ │ │ │ │ │ 00698 │ │ │ │ │ │ @@ -19288,27 +18795,27 @@ │ │ │ │ │ │ 00699 │ │ │ │ │ │ 00700 │ │ │ │ │ │ test_cone_cocircular(borderless_cone, border_list); │ │ │ │ │ │ 00701 │ │ │ │ │ │ } │ │ │ │ │ │ 00702 │ │ │ │ │ │ 00703 │ │ │ │ │ │ -// relabel things that were in the cone but got removed │ │ │ │ │ │ 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 │ │ │ │ │ │ +00710 │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -19319,16 +18826,16 @@ │ │ │ │ │ │ 00717 │ │ │ │ │ │ // been through the co-circularity rigmarole │ │ │ │ │ │ 00718 │ │ │ │ │ │ return true; │ │ │ │ │ │ 00719 } │ │ │ │ │ │ 00720 │ │ │ │ │ │ 00721 │ │ │ │ │ │ -00723 // RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ // │ │ │ │ │ │ +00723 // RECOMPUTATION OF CONE CONTENTS │ │ │ │ │ │ 00724 // - compute_cone_contents() │ │ │ │ │ │ // │ │ │ │ │ │ 00725 // - recompute_cone_contents() │ │ │ │ │ │ // │ │ │ │ │ │ 00726 // - recompute_cone_contents_if_needed() │ │ │ │ │ │ // │ │ │ │ │ │ 00728 │ │ │ │ │ │ @@ -19337,78 +18844,78 @@ │ │ │ │ │ │ siscone::circulator::iterator > │ │ │ │ │ │ 00739 │ │ │ │ │ │ start(vicinity.begin()+first_cone, vicinity.begin(), vicinity.end()); │ │ │ │ │ │ 00740 │ │ │ │ │ │ 00741 │ │ │ │ │ │ siscone::circulator::iterator > here(start); │ │ │ │ │ │ 00742 │ │ │ │ │ │ -// note that in the following algorithm, the cone contents never includes │ │ │ │ │ │ 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 { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.27 protocones.cpp │ │ │ │ │ │ - │ │ │ │ │ │ +00749 │ │ │ │ │ │ 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 │ │ │ │ │ │ -// move on to the next position │ │ │ │ │ │ 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); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.25 protocones.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00761 │ │ │ │ │ │ // once we’ve reached the start the ’is_inside’ information should be │ │ │ │ │ │ 00762 │ │ │ │ │ │ 00763 │ │ │ │ │ │ // 100% complete, so we can use it to calculate the cone contents │ │ │ │ │ │ 00764 │ │ │ │ │ │ // and then exit │ │ │ │ │ │ 00765 │ │ │ │ │ │ recompute_cone_contents(); │ │ │ │ │ │ -return; │ │ │ │ │ │ 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(){ │ │ │ │ │ │ unsigned int i; │ │ │ │ │ │ 00777 │ │ │ │ │ │ 00778 │ │ │ │ │ │ -00779 │ │ │ │ │ │ // set momentum to 0 │ │ │ │ │ │ +00779 │ │ │ │ │ │ 00780 │ │ │ │ │ │ cone = CSphmomentum(); │ │ │ │ │ │ 00781 │ │ │ │ │ │ // Important note: we can browse only the particles │ │ │ │ │ │ 00782 │ │ │ │ │ │ 00783 │ │ │ │ │ │ // in vicinity since all particles in the cone are │ │ │ │ │ │ @@ -19416,50 +18923,50 @@ │ │ │ │ │ │ // 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 │ │ │ │ │ │ +00793 │ │ │ │ │ │ 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){ │ │ │ │ │ │ +00805 │ │ │ │ │ │ 00806 │ │ │ │ │ │ if (this_dpt > PT_TSHOLD*(fabs(this_cone.px)+fabs(this_cone.py))) { │ │ │ │ │ │ 00807 │ │ │ │ │ │ -if (cone.ref.is_empty()) { │ │ │ │ │ │ 00808 │ │ │ │ │ │ +if (cone.ref.is_empty()) { │ │ │ │ │ │ 00809 │ │ │ │ │ │ this_cone = CSphmomentum(); │ │ │ │ │ │ 00810 │ │ │ │ │ │ } else { │ │ │ │ │ │ -// set momentum to 0 │ │ │ │ │ │ 00811 │ │ │ │ │ │ +// set momentum to 0 │ │ │ │ │ │ 00812 │ │ │ │ │ │ this_cone = CSphmomentum(); │ │ │ │ │ │ 00813 │ │ │ │ │ │ // Important note: we can browse only the particles │ │ │ │ │ │ 00814 │ │ │ │ │ │ 00815 │ │ │ │ │ │ // in vicinity since all particles in the this_cone are │ │ │ │ │ │ @@ -19467,27 +18974,27 @@ │ │ │ │ │ │ // 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 │ │ │ │ │ │ +00826 │ │ │ │ │ │ 00827 │ │ │ │ │ │ this_dpt = 0.0; │ │ │ │ │ │ 00828 │ │ │ │ │ │ } │ │ │ │ │ │ 00829 │ │ │ │ │ │ 00830 } │ │ │ │ │ │ 00831 │ │ │ │ │ │ @@ -19496,62 +19003,594 @@ │ │ │ │ │ │ // │ │ │ │ │ │ 00835 // - circle_intersect() │ │ │ │ │ │ // │ │ │ │ │ │ 00836 // - is_inside() │ │ │ │ │ │ // │ │ │ │ │ │ 00837 // - abs_dangle() │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -235 │ │ │ │ │ │ - │ │ │ │ │ │ - 236 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ circle centre y coordinate │ │ │ │ │ │ 00846 * - cy │ │ │ │ │ │ 00847 * return the checkxor for the intersection │ │ │ │ │ │ 00848 ******************************************************************/ │ │ │ │ │ │ 00849 siscone::Creference CSphstable_cones::circle_intersect(CSph3vector &cone_centre){ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +231 │ │ │ │ │ │ + │ │ │ │ │ │ + 232 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00850 │ │ │ │ │ │ siscone::Creference intersection; │ │ │ │ │ │ int i; │ │ │ │ │ │ 00851 │ │ │ │ │ │ 00852 │ │ │ │ │ │ -for (i=0;i │ │ │ │ │ │ +00034 #include │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include "hash.h" │ │ │ │ │ │ +00037 │ │ │ │ │ │ +00038 #include "defines.h" │ │ │ │ │ │ +00039 │ │ │ │ │ │ +00040 namespace siscone{ │ │ │ │ │ │ +00041 │ │ │ │ │ │ +00053 class Cborder_store{ │ │ │ │ │ │ +00054 public: │ │ │ │ │ │ +00056 │ │ │ │ │ │ +Cborder_store(Cmomentum * momentum, double centre_eta, double centre_phi) : │ │ │ │ │ │ +00057 │ │ │ │ │ │ +mom(momentum), is_in(false) { │ │ │ │ │ │ +00058 │ │ │ │ │ │ +angle = atan2(mom->phi - centre_phi, mom->eta - centre_eta); │ │ │ │ │ │ +00059 │ │ │ │ │ │ +} │ │ │ │ │ │ +00060 │ │ │ │ │ │ +00061 │ │ │ │ │ │ +Cmomentum * mom; │ │ │ │ │ │ +double angle; │ │ │ │ │ │ +00062 │ │ │ │ │ │ +bool │ │ │ │ │ │ +is_in; │ │ │ │ │ │ +00063 │ │ │ │ │ │ +00064 }; │ │ │ │ │ │ +00065 │ │ │ │ │ │ +00066 │ │ │ │ │ │ +00069 inline bool operator<(const Cborder_store & a, const Cborder_store & b) { │ │ │ │ │ │ +return a.angle < b.angle; │ │ │ │ │ │ +00070 │ │ │ │ │ │ +00071 } │ │ │ │ │ │ +00072 │ │ │ │ │ │ +00073 │ │ │ │ │ │ +00082 class Cstable_cones : public Cvicinity{ │ │ │ │ │ │ +00083 public: │ │ │ │ │ │ +00085 │ │ │ │ │ │ +Cstable_cones(); │ │ │ │ │ │ +00086 │ │ │ │ │ │ +00088 │ │ │ │ │ │ +Cstable_cones(std::vector &_particle_list); │ │ │ │ │ │ +00089 │ │ │ │ │ │ +00091 │ │ │ │ │ │ +~Cstable_cones(); │ │ │ │ │ │ +00092 │ │ │ │ │ │ +void init(std::vector &_particle_list); │ │ │ │ │ │ +00097 │ │ │ │ │ │ +00098 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.26 protocones.h │ │ │ │ │ │ + │ │ │ │ │ │ +00106 │ │ │ │ │ │ +int get_stable_cones(double _radius); │ │ │ │ │ │ +00107 │ │ │ │ │ │ +00109 │ │ │ │ │ │ +std::vector protocones; │ │ │ │ │ │ +00110 │ │ │ │ │ │ +00112 │ │ │ │ │ │ +hash_cones *hc; │ │ │ │ │ │ +00113 │ │ │ │ │ │ +int nb_tot; │ │ │ │ │ │ +00115 │ │ │ │ │ │ +00116 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00117 │ │ │ │ │ │ +int nb_hash_cones, nb_hash_occupied; │ │ │ │ │ │ +00118 #endif │ │ │ │ │ │ +00119 │ │ │ │ │ │ +00120 protected: │ │ │ │ │ │ +00122 │ │ │ │ │ │ +double R; │ │ │ │ │ │ +00123 │ │ │ │ │ │ +double R2; │ │ │ │ │ │ +00125 │ │ │ │ │ │ +00126 │ │ │ │ │ │ +00127 private: │ │ │ │ │ │ +00130 │ │ │ │ │ │ +Cmomentum cone; │ │ │ │ │ │ +00131 │ │ │ │ │ │ +00133 │ │ │ │ │ │ +Cmomentum *child; │ │ │ │ │ │ +00134 │ │ │ │ │ │ +00136 │ │ │ │ │ │ +Cvicinity_elm *centre; │ │ │ │ │ │ +00137 │ │ │ │ │ │ +00139 │ │ │ │ │ │ +unsigned int centre_idx; │ │ │ │ │ │ +00140 │ │ │ │ │ │ +unsigned int first_cone; │ │ │ │ │ │ +00142 │ │ │ │ │ │ +00143 │ │ │ │ │ │ +int init_cone(); │ │ │ │ │ │ +00149 │ │ │ │ │ │ +00150 │ │ │ │ │ │ +00157 │ │ │ │ │ │ +int test_cone(); │ │ │ │ │ │ +00158 │ │ │ │ │ │ +int update_cone(); │ │ │ │ │ │ +00164 │ │ │ │ │ │ +00165 │ │ │ │ │ │ +/* │ │ │ │ │ │ +00166 │ │ │ │ │ │ +00167 │ │ │ │ │ │ +* run through the vicinity of the current parent and for each child │ │ │ │ │ │ +00168 │ │ │ │ │ │ +* indicate which members are cocircular... │ │ │ │ │ │ +00169 │ │ │ │ │ │ +*/ │ │ │ │ │ │ +00170 │ │ │ │ │ │ +void prepare_cocircular_lists(); │ │ │ │ │ │ +00171 │ │ │ │ │ │ +bool cocircular_check(); │ │ │ │ │ │ +00179 │ │ │ │ │ │ +00180 │ │ │ │ │ │ +00185 │ │ │ │ │ │ +void test_cone_cocircular(Cmomentum & borderless_cone, │ │ │ │ │ │ +00186 │ │ │ │ │ │ +std::list & border_list); │ │ │ │ │ │ +00187 │ │ │ │ │ │ +void test_stability(Cmomentum & candidate, │ │ │ │ │ │ +00194 │ │ │ │ │ │ +00195 │ │ │ │ │ │ +const std::vector & border_vect); │ │ │ │ │ │ +00196 │ │ │ │ │ │ +void compute_cone_contents(); │ │ │ │ │ │ +00203 │ │ │ │ │ │ +00204 │ │ │ │ │ │ +void recompute_cone_contents(); │ │ │ │ │ │ +00210 │ │ │ │ │ │ +00211 │ │ │ │ │ │ +/* │ │ │ │ │ │ +00212 │ │ │ │ │ │ +00213 │ │ │ │ │ │ +* if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ +00214 │ │ │ │ │ │ +* the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ +00215 │ │ │ │ │ │ +* ’pincluded’ information from the Cvicinity class, but we don’t │ │ │ │ │ │ +00216 │ │ │ │ │ │ +* change the member cone, only the locally supplied one │ │ │ │ │ │ +00217 │ │ │ │ │ │ +*/ │ │ │ │ │ │ +00218 │ │ │ │ │ │ +void recompute_cone_contents_if_needed(Cmomentum & this_cone, double & this_dpt); │ │ │ │ │ │ +00219 │ │ │ │ │ │ +int proceed_with_stability(); │ │ │ │ │ │ +00225 │ │ │ │ │ │ +00226 │ │ │ │ │ │ +/* │ │ │ │ │ │ +00227 │ │ │ │ │ │ +00228 │ │ │ │ │ │ +* circle intersection. │ │ │ │ │ │ +00229 │ │ │ │ │ │ +* computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ +00230 │ │ │ │ │ │ +* The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ +00231 │ │ │ │ │ │ +circle centre x coordinate │ │ │ │ │ │ +* - cx │ │ │ │ │ │ +00232 │ │ │ │ │ │ +circle centre y coordinate │ │ │ │ │ │ +* - cy │ │ │ │ │ │ +00233 │ │ │ │ │ │ +* return the checkxor for the intersection │ │ │ │ │ │ +00234 │ │ │ │ │ │ +******************************************************************/ │ │ │ │ │ │ +00235 │ │ │ │ │ │ +Creference circle_intersect(double cx, double cy); │ │ │ │ │ │ +00236 │ │ │ │ │ │ +00238 │ │ │ │ │ │ +Cmomentum cone_candidate; │ │ │ │ │ │ +00239 │ │ │ │ │ │ +00241 │ │ │ │ │ │ +std::vector child_list; │ │ │ │ │ │ +00242 │ │ │ │ │ │ +00245 │ │ │ │ │ │ +std::vector< std::pair > multiple_centre_done; │ │ │ │ │ │ +00246 │ │ │ │ │ │ +// information for updating cone contents to avoid rounding errors │ │ │ │ │ │ +00247 │ │ │ │ │ │ +00248 │ │ │ │ │ │ +double dpt; │ │ │ │ │ │ +00249 │ │ │ │ │ │ +inline bool is_inside(Cmomentum *centre, Cmomentum *v); │ │ │ │ │ │ +00258 │ │ │ │ │ │ +00259 }; │ │ │ │ │ │ +00260 │ │ │ │ │ │ +00261 /* │ │ │ │ │ │ +00262 * compute the absolute value of the difference between 2 angles. │ │ │ │ │ │ +00263 * We take care of the 2pi periodicity │ │ │ │ │ │ +first angle │ │ │ │ │ │ +00264 * \param angle1 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +233 │ │ │ │ │ │ + │ │ │ │ │ │ + 234 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +second angle │ │ │ │ │ │ +00265 * \param angle2 │ │ │ │ │ │ +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.27 protocones.h │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: protocones.h │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // Description: header file for stable cones determination (Cstable_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:: 255 │ │ │ │ │ │ +$// │ │ │ │ │ │ +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 │ │ │ │ │ │ +00037 #include │ │ │ │ │ │ +00038 #include "hash.h" │ │ │ │ │ │ +00039 │ │ │ │ │ │ +00040 #include │ │ │ │ │ │ +00041 │ │ │ │ │ │ +00042 namespace siscone_spherical{ │ │ │ │ │ │ +00043 │ │ │ │ │ │ +00055 class CSphborder_store{ │ │ │ │ │ │ +00056 public: │ │ │ │ │ │ +00058 │ │ │ │ │ │ +CSphborder_store(CSphmomentum * momentum, CSph3vector ¢re, CSph3vector &angl_dir1, CSph3vector │ │ │ │ │ │ +&angl_dir2) : │ │ │ │ │ │ +00059 │ │ │ │ │ │ +mom(momentum), is_in(false) { │ │ │ │ │ │ +00060 │ │ │ │ │ │ +CSph3vector diff = (*momentum) - centre; │ │ │ │ │ │ +00061 │ │ │ │ │ │ +angle = atan2(dot_product3(diff, angl_dir2), dot_product3(diff, angl_dir1)); │ │ │ │ │ │ +00062 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00063 │ │ │ │ │ │ +std::cout « " adding point " « momentum->_theta « ", " « momentum->_phi │ │ │ │ │ │ +00064 │ │ │ │ │ │ +« " at an angle of " « angle « std::endl; │ │ │ │ │ │ +00065 #endif │ │ │ │ │ │ +00066 │ │ │ │ │ │ +} │ │ │ │ │ │ +00067 │ │ │ │ │ │ +00068 │ │ │ │ │ │ +CSphmomentum * mom; │ │ │ │ │ │ +00069 │ │ │ │ │ │ +double angle; │ │ │ │ │ │ +bool │ │ │ │ │ │ +is_in; │ │ │ │ │ │ +00070 │ │ │ │ │ │ +00071 }; │ │ │ │ │ │ +00072 │ │ │ │ │ │ +00073 │ │ │ │ │ │ +00076 inline bool operator<(const CSphborder_store & a, const CSphborder_store & b) { │ │ │ │ │ │ +return a.angle < b.angle; │ │ │ │ │ │ +00077 │ │ │ │ │ │ +00078 } │ │ │ │ │ │ +00079 │ │ │ │ │ │ +00080 │ │ │ │ │ │ +00089 class CSphstable_cones : public CSphvicinity{ │ │ │ │ │ │ +00090 public: │ │ │ │ │ │ +00092 │ │ │ │ │ │ +CSphstable_cones(); │ │ │ │ │ │ +00093 │ │ │ │ │ │ +00095 │ │ │ │ │ │ +CSphstable_cones(std::vector &_particle_list); │ │ │ │ │ │ +00096 │ │ │ │ │ │ +00098 │ │ │ │ │ │ +~CSphstable_cones(); │ │ │ │ │ │ +00099 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.27 protocones.h │ │ │ │ │ │ + │ │ │ │ │ │ +00104 │ │ │ │ │ │ +void init(std::vector &_particle_list); │ │ │ │ │ │ +00105 │ │ │ │ │ │ +int get_stable_cones(double _radius); │ │ │ │ │ │ +00113 │ │ │ │ │ │ +00114 │ │ │ │ │ │ +00116 │ │ │ │ │ │ +std::vector protocones; │ │ │ │ │ │ +00117 │ │ │ │ │ │ +00119 │ │ │ │ │ │ +sph_hash_cones *hc; │ │ │ │ │ │ +00120 │ │ │ │ │ │ +int nb_tot; │ │ │ │ │ │ +00122 │ │ │ │ │ │ +00123 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ +00124 │ │ │ │ │ │ +int nb_hash_cones, nb_hash_occupied; │ │ │ │ │ │ +00125 #endif │ │ │ │ │ │ +00126 │ │ │ │ │ │ +00127 protected: │ │ │ │ │ │ +00129 │ │ │ │ │ │ +double R; │ │ │ │ │ │ +00130 │ │ │ │ │ │ +double R2; │ │ │ │ │ │ +00132 │ │ │ │ │ │ +00133 │ │ │ │ │ │ +double tan2R; │ │ │ │ │ │ +00135 │ │ │ │ │ │ +00136 │ │ │ │ │ │ +00137 private: │ │ │ │ │ │ +00140 │ │ │ │ │ │ +CSphmomentum cone; │ │ │ │ │ │ +00141 │ │ │ │ │ │ +00143 │ │ │ │ │ │ +CSphmomentum *child; │ │ │ │ │ │ +00144 │ │ │ │ │ │ +00146 │ │ │ │ │ │ +CSphvicinity_elm *centre; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +unsigned int centre_idx; │ │ │ │ │ │ +00149 │ │ │ │ │ │ +00150 │ │ │ │ │ │ +00152 │ │ │ │ │ │ +unsigned int first_cone; │ │ │ │ │ │ +00153 │ │ │ │ │ │ +int init_cone(); │ │ │ │ │ │ +00159 │ │ │ │ │ │ +00160 │ │ │ │ │ │ +int test_cone(); │ │ │ │ │ │ +00167 │ │ │ │ │ │ +00168 │ │ │ │ │ │ +int update_cone(); │ │ │ │ │ │ +00174 │ │ │ │ │ │ +00175 │ │ │ │ │ │ +/* │ │ │ │ │ │ +00176 │ │ │ │ │ │ +00177 │ │ │ │ │ │ +* run through the vicinity of the current parent and for each child │ │ │ │ │ │ +00178 │ │ │ │ │ │ +* indicate which members are cocircular... │ │ │ │ │ │ +00179 │ │ │ │ │ │ +*/ │ │ │ │ │ │ +00180 │ │ │ │ │ │ +void prepare_cocircular_lists(); │ │ │ │ │ │ +00181 │ │ │ │ │ │ +bool cocircular_check(); │ │ │ │ │ │ +00189 │ │ │ │ │ │ +00190 │ │ │ │ │ │ +void test_cone_cocircular(CSphmomentum & borderless_cone, │ │ │ │ │ │ +00195 │ │ │ │ │ │ +00196 │ │ │ │ │ │ +std::list & border_list); │ │ │ │ │ │ +00197 │ │ │ │ │ │ +00204 │ │ │ │ │ │ +void test_stability(CSphmomentum & candidate, │ │ │ │ │ │ +const std::vector & border_vect); │ │ │ │ │ │ +00205 │ │ │ │ │ │ +00206 │ │ │ │ │ │ +void compute_cone_contents(); │ │ │ │ │ │ +00213 │ │ │ │ │ │ +00214 │ │ │ │ │ │ +void recompute_cone_contents(); │ │ │ │ │ │ +00220 │ │ │ │ │ │ +00221 │ │ │ │ │ │ +00222 │ │ │ │ │ │ +/* │ │ │ │ │ │ +00223 │ │ │ │ │ │ +* if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ +00224 │ │ │ │ │ │ +* the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ +00225 │ │ │ │ │ │ +* ’pincluded’ information from the CSphvicinity class, but we don’t │ │ │ │ │ │ +00226 │ │ │ │ │ │ +* change the member cone, only the locally supplied one │ │ │ │ │ │ +00227 │ │ │ │ │ │ +*/ │ │ │ │ │ │ +00228 │ │ │ │ │ │ +void recompute_cone_contents_if_needed(CSphmomentum & this_cone, double & this_dpt); │ │ │ │ │ │ +00229 │ │ │ │ │ │ +int proceed_with_stability(); │ │ │ │ │ │ +00235 │ │ │ │ │ │ +00236 │ │ │ │ │ │ +/* │ │ │ │ │ │ +00237 │ │ │ │ │ │ +00238 │ │ │ │ │ │ +* circle intersection. │ │ │ │ │ │ +00239 │ │ │ │ │ │ +* computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ +00240 │ │ │ │ │ │ +* The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ +circle centre x coordinate │ │ │ │ │ │ +00241 │ │ │ │ │ │ +* - cx │ │ │ │ │ │ +00242 │ │ │ │ │ │ +circle centre y coordinate │ │ │ │ │ │ +* - cy │ │ │ │ │ │ +00243 │ │ │ │ │ │ +* return the checkxor for the intersection │ │ │ │ │ │ +00244 │ │ │ │ │ │ +******************************************************************/ │ │ │ │ │ │ +00245 │ │ │ │ │ │ +siscone::Creference circle_intersect(CSph3vector &cone_centre); │ │ │ │ │ │ +00246 │ │ │ │ │ │ +00248 │ │ │ │ │ │ +CSphmomentum cone_candidate; │ │ │ │ │ │ +00249 │ │ │ │ │ │ +00251 │ │ │ │ │ │ +std::vector child_list; │ │ │ │ │ │ +00252 │ │ │ │ │ │ +00255 │ │ │ │ │ │ +std::vector< std::pair > multiple_centre_done; │ │ │ │ │ │ +00256 │ │ │ │ │ │ +// information for updating cone contents to avoid rounding errors │ │ │ │ │ │ +00257 │ │ │ │ │ │ +00258 │ │ │ │ │ │ +double dpt; │ │ │ │ │ │ +00259 }; │ │ │ │ │ │ +00260 │ │ │ │ │ │ +00261 } │ │ │ │ │ │ +00262 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +235 │ │ │ │ │ │ + │ │ │ │ │ │ + 236 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 5.28 quadtree.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ -00002 // File: quadtree.cpp │ │ │ │ │ │ // │ │ │ │ │ │ +00002 // File: quadtree.cpp │ │ │ │ │ │ 00003 // Description: source file for quadtree management (Cquadtree class) │ │ │ │ │ │ // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // │ │ │ │ │ │ @@ -19624,19 +19663,14 @@ │ │ │ │ │ │ 00051 │ │ │ │ │ │ 00052 │ │ │ │ │ │ 00053 // ctor with initialisation (see init for details) │ │ │ │ │ │ 00054 //-------------------------00055 Cquadtree::Cquadtree(double _x, double _y, double _half_size_x, double _half_size_y){ │ │ │ │ │ │ 00056 │ │ │ │ │ │ v = NULL; │ │ │ │ │ │ 00057 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.28 quadtree.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00058 │ │ │ │ │ │ children[0][0] = children[0][1] = children[1][0] = children[1][1] = NULL; │ │ │ │ │ │ 00059 │ │ │ │ │ │ has_child = false; │ │ │ │ │ │ 00060 │ │ │ │ │ │ 00061 │ │ │ │ │ │ init(_x, _y, _half_size_x, _half_size_y); │ │ │ │ │ │ @@ -19669,18 +19703,23 @@ │ │ │ │ │ │ 00082 * By initializing the tree, we mean setting the cell parameters │ │ │ │ │ │ 00083 * and preparing the object to act as a seed for a new tree. │ │ │ │ │ │ x-position of the center │ │ │ │ │ │ 00084 * - _x │ │ │ │ │ │ 00085 * - _y │ │ │ │ │ │ y-position of the center │ │ │ │ │ │ 00086 * - half_size_x half x-size of the cell │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.28 quadtree.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00087 * - half_size_y half y-size of the cell │ │ │ │ │ │ 00088 * return 0 on success, 1 on error. Note that if the cell │ │ │ │ │ │ -is already filled, we return an error. │ │ │ │ │ │ 00089 * │ │ │ │ │ │ +is already filled, we return an error. │ │ │ │ │ │ 00090 ******************************************************************/ │ │ │ │ │ │ 00091 int Cquadtree::init(double _x, double _y, double _half_size_x, double _half_size_y){ │ │ │ │ │ │ 00092 │ │ │ │ │ │ if (v!=NULL) │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00093 │ │ │ │ │ │ 00094 │ │ │ │ │ │ @@ -19698,21 +19737,21 @@ │ │ │ │ │ │ 00101 } │ │ │ │ │ │ 00102 │ │ │ │ │ │ 00103 │ │ │ │ │ │ 00104 /* │ │ │ │ │ │ 00105 * adding a particle to the tree. │ │ │ │ │ │ 00106 * This method adds one vector to the quadtree structure which │ │ │ │ │ │ 00107 * is updated consequently. │ │ │ │ │ │ -vector to add │ │ │ │ │ │ 00108 * - v │ │ │ │ │ │ +vector to add │ │ │ │ │ │ 00109 * return 0 on success 1 on error │ │ │ │ │ │ 00110 ******************************************************************/ │ │ │ │ │ │ 00111 int Cquadtree::add(Cmomentum *v_add){ │ │ │ │ │ │ -00112 │ │ │ │ │ │ // Description of the method: │ │ │ │ │ │ +00112 │ │ │ │ │ │ 00113 │ │ │ │ │ │ // -------------------------00114 │ │ │ │ │ │ // the addition process goes as follows: │ │ │ │ │ │ 00115 │ │ │ │ │ │ // 1. check if the cell is empty, in which case, add the particle │ │ │ │ │ │ 00116 │ │ │ │ │ │ // │ │ │ │ │ │ @@ -19738,32 +19777,32 @@ │ │ │ │ │ │ 00124 │ │ │ │ │ │ 00125 │ │ │ │ │ │ // step 1: the case of empty cells │ │ │ │ │ │ 00126 │ │ │ │ │ │ if (v==NULL){ │ │ │ │ │ │ 00127 │ │ │ │ │ │ v = v_add; │ │ │ │ │ │ -return 0; │ │ │ │ │ │ 00128 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ 00129 │ │ │ │ │ │ } │ │ │ │ │ │ 00130 │ │ │ │ │ │ -00131 │ │ │ │ │ │ // step 2: additional work if 1! particle already present │ │ │ │ │ │ +00131 │ │ │ │ │ │ 00132 │ │ │ │ │ │ // │ │ │ │ │ │ we use the fact that only 1-particle systems have no child │ │ │ │ │ │ 00133 │ │ │ │ │ │ if (!has_child){ │ │ │ │ │ │ 00134 │ │ │ │ │ │ double new_half_size_x = 0.5*half_size_x; │ │ │ │ │ │ -double new_half_size_y = 0.5*half_size_y; │ │ │ │ │ │ 00135 │ │ │ │ │ │ -00136 │ │ │ │ │ │ +double new_half_size_y = 0.5*half_size_y; │ │ │ │ │ │ // create children │ │ │ │ │ │ +00136 │ │ │ │ │ │ 00137 │ │ │ │ │ │ children[0][0] = new Cquadtree(centre_x-new_half_size_x, centre_y-new_half_size_y, │ │ │ │ │ │ 00138 │ │ │ │ │ │ new_half_size_x, new_half_size_y); │ │ │ │ │ │ 00139 │ │ │ │ │ │ children[0][1] = new Cquadtree(centre_x-new_half_size_x, centre_y+new_half_size_y, │ │ │ │ │ │ 00140 │ │ │ │ │ │ @@ -19772,45 +19811,36 @@ │ │ │ │ │ │ children[1][0] = new Cquadtree(centre_x+new_half_size_x, centre_y-new_half_size_y, │ │ │ │ │ │ 00142 │ │ │ │ │ │ new_half_size_x, new_half_size_y); │ │ │ │ │ │ 00143 │ │ │ │ │ │ children[1][1] = new Cquadtree(centre_x+new_half_size_x, centre_y+new_half_size_y, │ │ │ │ │ │ 00144 │ │ │ │ │ │ new_half_size_x, new_half_size_y); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -237 │ │ │ │ │ │ - │ │ │ │ │ │ - 238 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00145 │ │ │ │ │ │ 00146 │ │ │ │ │ │ has_child = true; │ │ │ │ │ │ 00147 │ │ │ │ │ │ -00148 │ │ │ │ │ │ // forward to child │ │ │ │ │ │ +00148 │ │ │ │ │ │ 00149 │ │ │ │ │ │ //? The following line assumes ’true’==1 and ’false’==0 │ │ │ │ │ │ 00150 │ │ │ │ │ │ // Note: v being a single particle, eta and phi are correct │ │ │ │ │ │ 00151 │ │ │ │ │ │ children[v->eta>centre_x][v->phi>centre_y]->add(v); │ │ │ │ │ │ 00152 │ │ │ │ │ │ // copy physical params │ │ │ │ │ │ 00153 │ │ │ │ │ │ 00154 │ │ │ │ │ │ v = new Cmomentum(*v); │ │ │ │ │ │ 00155 │ │ │ │ │ │ } │ │ │ │ │ │ 00156 │ │ │ │ │ │ -00157 │ │ │ │ │ │ // step 3: add new particle │ │ │ │ │ │ +00157 │ │ │ │ │ │ 00158 │ │ │ │ │ │ // Note: v_add being a single particle, eta and phi are correct │ │ │ │ │ │ 00159 │ │ │ │ │ │ children[v_add->eta>centre_x][v_add->phi>centre_y]->add(v_add); │ │ │ │ │ │ 00160 │ │ │ │ │ │ *v+=*v_add; │ │ │ │ │ │ 00161 │ │ │ │ │ │ @@ -19824,21 +19854,30 @@ │ │ │ │ │ │ 00168 * computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ 00169 * The output takes the form of a quadtree with all squares included │ │ │ │ │ │ 00170 * in the circle. │ │ │ │ │ │ circle centre x coordinate │ │ │ │ │ │ 00171 * - cx │ │ │ │ │ │ 00172 * - cy │ │ │ │ │ │ circle centre y coordinate │ │ │ │ │ │ -00173 * - cR2 │ │ │ │ │ │ circle radius SQUARED │ │ │ │ │ │ +00173 * - cR2 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +237 │ │ │ │ │ │ + │ │ │ │ │ │ + 238 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00174 * return the checksum for the intersection │ │ │ │ │ │ 00175 ******************************************************************/ │ │ │ │ │ │ 00176 Creference Cquadtree::circle_intersect(double cx, double cy, double cR2){ │ │ │ │ │ │ -// Description of the method: │ │ │ │ │ │ 00177 │ │ │ │ │ │ +// Description of the method: │ │ │ │ │ │ 00178 │ │ │ │ │ │ // -------------------------00179 │ │ │ │ │ │ // 1. check if cell is empty => no intersection │ │ │ │ │ │ 00180 │ │ │ │ │ │ // 2. if cell has 1! particle, check if it is inside the circle. │ │ │ │ │ │ 00181 │ │ │ │ │ │ // │ │ │ │ │ │ @@ -19853,101 +19892,94 @@ │ │ │ │ │ │ 00185 │ │ │ │ │ │ // 5. check intersections with children. │ │ │ │ │ │ 00186 │ │ │ │ │ │ // step 1: if there is no particle inside te square, no reason to go further │ │ │ │ │ │ 00187 │ │ │ │ │ │ 00188 │ │ │ │ │ │ if (v==NULL) │ │ │ │ │ │ -return Creference(); │ │ │ │ │ │ 00189 │ │ │ │ │ │ +return Creference(); │ │ │ │ │ │ 00190 │ │ │ │ │ │ double dx, dy; │ │ │ │ │ │ 00191 │ │ │ │ │ │ 00192 │ │ │ │ │ │ -00193 │ │ │ │ │ │ // step 2: if there is only one particle inside the square, test if it is in │ │ │ │ │ │ +00193 │ │ │ │ │ │ 00194 │ │ │ │ │ │ // │ │ │ │ │ │ the circle, in which case return associated reference │ │ │ │ │ │ 00195 │ │ │ │ │ │ if (!has_child){ │ │ │ │ │ │ -// compute the distance │ │ │ │ │ │ 00196 │ │ │ │ │ │ +// compute the distance │ │ │ │ │ │ 00197 │ │ │ │ │ │ // Note: v has only one particle => eta and phi are defined │ │ │ │ │ │ 00198 │ │ │ │ │ │ dx = cx - v->eta; │ │ │ │ │ │ 00199 │ │ │ │ │ │ dy = fabs(cy - v->phi); │ │ │ │ │ │ -00200 │ │ │ │ │ │ if (dy>M_PI) │ │ │ │ │ │ +00200 │ │ │ │ │ │ 00201 │ │ │ │ │ │ dy -= 2.0*M_PI; │ │ │ │ │ │ 00202 │ │ │ │ │ │ -// test distance │ │ │ │ │ │ 00203 │ │ │ │ │ │ +// test distance │ │ │ │ │ │ 00204 │ │ │ │ │ │ if (dx*dx+dy*dyref; │ │ │ │ │ │ 00206 │ │ │ │ │ │ } │ │ │ │ │ │ 00207 │ │ │ │ │ │ -return Creference(); │ │ │ │ │ │ 00208 │ │ │ │ │ │ +return Creference(); │ │ │ │ │ │ 00209 │ │ │ │ │ │ } │ │ │ │ │ │ 00210 │ │ │ │ │ │ -00211 │ │ │ │ │ │ // step 3: check if there is an intersection │ │ │ │ │ │ +00211 │ │ │ │ │ │ 00212 │ │ │ │ │ │ //double ryp, rym; │ │ │ │ │ │ 00213 │ │ │ │ │ │ double dx_c, dy_c; │ │ │ │ │ │ 00214 │ │ │ │ │ │ -// store distance with the centre of the square │ │ │ │ │ │ 00215 │ │ │ │ │ │ +// store distance with the centre of the square │ │ │ │ │ │ 00216 │ │ │ │ │ │ dx_c = fabs(cx-centre_x); │ │ │ │ │ │ 00217 │ │ │ │ │ │ dy_c = fabs(cy-centre_y); │ │ │ │ │ │ if (dy_c>M_PI) dy_c = 2.0*M_PI-dy_c; │ │ │ │ │ │ 00218 │ │ │ │ │ │ 00219 │ │ │ │ │ │ // compute (minimal) the distance (pay attention to the periodicity in phi). │ │ │ │ │ │ 00220 │ │ │ │ │ │ 00221 │ │ │ │ │ │ dx = dx_c-half_size_x; │ │ │ │ │ │ -if (dx<0) dx=0; │ │ │ │ │ │ 00222 │ │ │ │ │ │ +if (dx<0) dx=0; │ │ │ │ │ │ 00223 │ │ │ │ │ │ dy = dy_c-half_size_y; │ │ │ │ │ │ if (dy<0) dy=0; │ │ │ │ │ │ 00224 │ │ │ │ │ │ 00225 │ │ │ │ │ │ -00226 │ │ │ │ │ │ // check the distance │ │ │ │ │ │ +00226 │ │ │ │ │ │ 00227 │ │ │ │ │ │ if (dx*dx+dy*dy>=cR2){ │ │ │ │ │ │ 00228 │ │ │ │ │ │ // no intersection │ │ │ │ │ │ 00229 │ │ │ │ │ │ return Creference(); │ │ │ │ │ │ 00230 │ │ │ │ │ │ } │ │ │ │ │ │ 00231 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.29 quadtree.h │ │ │ │ │ │ - │ │ │ │ │ │ -239 │ │ │ │ │ │ - │ │ │ │ │ │ -00232 │ │ │ │ │ │ // step 4: check if included │ │ │ │ │ │ +00232 │ │ │ │ │ │ 00233 │ │ │ │ │ │ 00234 │ │ │ │ │ │ // compute the (maximal) distance │ │ │ │ │ │ 00235 │ │ │ │ │ │ dx = dx_c+half_size_x; │ │ │ │ │ │ 00236 │ │ │ │ │ │ dy = dy_c+half_size_y; │ │ │ │ │ │ @@ -19959,16 +19991,16 @@ │ │ │ │ │ │ 00240 │ │ │ │ │ │ if (dx*dx+dy*dyref; │ │ │ │ │ │ 00242 │ │ │ │ │ │ } │ │ │ │ │ │ 00243 │ │ │ │ │ │ -00244 │ │ │ │ │ │ // step 5: the square is not fully in. Recurse to children │ │ │ │ │ │ +00244 │ │ │ │ │ │ 00245 │ │ │ │ │ │ return children[0][0]->circle_intersect(cx, cy, cR2) │ │ │ │ │ │ 00246 │ │ │ │ │ │ + children[0][1]->circle_intersect(cx, cy, cR2) │ │ │ │ │ │ 00247 │ │ │ │ │ │ + children[1][0]->circle_intersect(cx, cy, cR2) │ │ │ │ │ │ 00248 │ │ │ │ │ │ @@ -19981,23 +20013,28 @@ │ │ │ │ │ │ 00254 * This can be used to output a data file containing all the │ │ │ │ │ │ 00255 * grid subdivisions. The file contents is as follows: │ │ │ │ │ │ 00256 * first and second columns give center of the cell, the third │ │ │ │ │ │ 00257 * gives the size. │ │ │ │ │ │ 00258 * - flux opened stream to write to │ │ │ │ │ │ 00259 * return 0 on success, 1 on error │ │ │ │ │ │ 00260 ******************************************************************/ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.29 quadtree.h │ │ │ │ │ │ + │ │ │ │ │ │ 00261 int Cquadtree::save(FILE *flux){ │ │ │ │ │ │ 00262 │ │ │ │ │ │ if (flux==NULL) │ │ │ │ │ │ 00263 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00264 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00265 │ │ │ │ │ │ -00266 │ │ │ │ │ │ if (has_child){ │ │ │ │ │ │ +00266 │ │ │ │ │ │ 00267 │ │ │ │ │ │ fprintf(flux, "%e\t%e\t%e\t%e\n", centre_x, centre_y, half_size_x, half_size_y); │ │ │ │ │ │ 00268 │ │ │ │ │ │ children[0][0]->save(flux); │ │ │ │ │ │ 00269 │ │ │ │ │ │ children[0][1]->save(flux); │ │ │ │ │ │ 00270 │ │ │ │ │ │ @@ -20021,27 +20058,27 @@ │ │ │ │ │ │ 00284 * - flux opened stream to write to │ │ │ │ │ │ 00285 * return 0 on success, 1 on error │ │ │ │ │ │ 00286 ******************************************************************/ │ │ │ │ │ │ 00287 int Cquadtree::save_leaves(FILE *flux){ │ │ │ │ │ │ 00288 │ │ │ │ │ │ if (flux==NULL) │ │ │ │ │ │ 00289 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00290 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00291 │ │ │ │ │ │ -00292 │ │ │ │ │ │ if (has_child){ │ │ │ │ │ │ +00292 │ │ │ │ │ │ if (children[0][0]!=NULL) children[0][0]->save_leaves(flux); │ │ │ │ │ │ 00293 │ │ │ │ │ │ 00294 │ │ │ │ │ │ if (children[0][1]!=NULL) children[0][1]->save_leaves(flux); │ │ │ │ │ │ -if (children[1][0]!=NULL) children[1][0]->save_leaves(flux); │ │ │ │ │ │ 00295 │ │ │ │ │ │ -00296 │ │ │ │ │ │ +if (children[1][0]!=NULL) children[1][0]->save_leaves(flux); │ │ │ │ │ │ if (children[1][1]!=NULL) children[1][1]->save_leaves(flux); │ │ │ │ │ │ +00296 │ │ │ │ │ │ 00297 │ │ │ │ │ │ } else { │ │ │ │ │ │ 00298 │ │ │ │ │ │ fprintf(flux, "%e\t%e\t%e\t%e\n", centre_x, centre_y, half_size_x, half_size_y); │ │ │ │ │ │ 00299 │ │ │ │ │ │ } │ │ │ │ │ │ 00300 │ │ │ │ │ │ @@ -20049,33 +20086,25 @@ │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00302 } │ │ │ │ │ │ 00303 │ │ │ │ │ │ 00304 } │ │ │ │ │ │ │ │ │ │ │ │ 5.29 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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ // │ │ │ │ │ │ +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 │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ - 240 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -20114,14 +20143,23 @@ │ │ │ │ │ │ 00033 │ │ │ │ │ │ 00034 namespace siscone{ │ │ │ │ │ │ 00035 │ │ │ │ │ │ 00043 class Cquadtree{ │ │ │ │ │ │ 00044 public: │ │ │ │ │ │ 00046 │ │ │ │ │ │ Cquadtree(); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +239 │ │ │ │ │ │ + │ │ │ │ │ │ + 240 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00047 │ │ │ │ │ │ 00049 │ │ │ │ │ │ Cquadtree(double _x, double _y, double _half_size_x, double _half_size_y); │ │ │ │ │ │ 00050 │ │ │ │ │ │ 00054 │ │ │ │ │ │ ~Cquadtree(); │ │ │ │ │ │ 00055 │ │ │ │ │ │ @@ -20136,30 +20174,30 @@ │ │ │ │ │ │ 00089 │ │ │ │ │ │ int save(FILE *flux); │ │ │ │ │ │ 00099 │ │ │ │ │ │ 00100 │ │ │ │ │ │ int save_leaves(FILE *flux); │ │ │ │ │ │ 00110 │ │ │ │ │ │ 00111 │ │ │ │ │ │ -double centre_x; │ │ │ │ │ │ 00112 │ │ │ │ │ │ -00113 │ │ │ │ │ │ +double centre_x; │ │ │ │ │ │ double centre_y; │ │ │ │ │ │ -double half_size_x; │ │ │ │ │ │ +00113 │ │ │ │ │ │ 00114 │ │ │ │ │ │ -00115 │ │ │ │ │ │ +double half_size_x; │ │ │ │ │ │ double half_size_y; │ │ │ │ │ │ +00115 │ │ │ │ │ │ 00116 │ │ │ │ │ │ 00117 │ │ │ │ │ │ Cmomentum *v; │ │ │ │ │ │ 00118 │ │ │ │ │ │ 00119 │ │ │ │ │ │ Cquadtree* children[2][2]; │ │ │ │ │ │ -00120 │ │ │ │ │ │ bool has_child; │ │ │ │ │ │ +00120 │ │ │ │ │ │ 00121 }; │ │ │ │ │ │ 00122 │ │ │ │ │ │ 00123 } │ │ │ │ │ │ 00124 #endif │ │ │ │ │ │ │ │ │ │ │ │ 5.30 ranlux.cpp │ │ │ │ │ │ 00001 // file: ranlux.xpp │ │ │ │ │ │ @@ -20181,94 +20219,94 @@ │ │ │ │ │ │ 00013 │ │ │ │ │ │ where after 24 samples a group of p integers are "skipped", to │ │ │ │ │ │ 00014 │ │ │ │ │ │ reduce correlations. By default p = 199, but can be increased to │ │ │ │ │ │ 00015 │ │ │ │ │ │ 365. │ │ │ │ │ │ 00016 │ │ │ │ │ │ -The period of the generator is around 10^171. │ │ │ │ │ │ 00017 │ │ │ │ │ │ +The period of the generator is around 10^171. │ │ │ │ │ │ 00018 │ │ │ │ │ │ -From: M. Luescher, "A portable high-quality random number generator │ │ │ │ │ │ 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 │ │ │ │ │ │ -Available on the net as hep-lat/9309020 at http://xxx.lanl.gov/ │ │ │ │ │ │ 00023 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.30 ranlux.cpp │ │ │ │ │ │ - │ │ │ │ │ │ +Available on the net as hep-lat/9309020 at http://xxx.lanl.gov/ │ │ │ │ │ │ 00024 │ │ │ │ │ │ See also, │ │ │ │ │ │ 00025 │ │ │ │ │ │ 00026 │ │ │ │ │ │ -00027 │ │ │ │ │ │ F. James, "RANLUX: A Fortran implementation of the high-quality │ │ │ │ │ │ +00027 │ │ │ │ │ │ 00028 │ │ │ │ │ │ pseudo-random number generator of Luscher", Computer Physics │ │ │ │ │ │ 00029 │ │ │ │ │ │ Communications, 79 (1994) 111-114 │ │ │ │ │ │ 00030 │ │ │ │ │ │ 00031 │ │ │ │ │ │ Kenneth G. Hamilton, F. James, "Acceleration of RANLUX", Computer │ │ │ │ │ │ 00032 │ │ │ │ │ │ Physics Communications, 101 (1997) 241-248 │ │ │ │ │ │ 00033 │ │ │ │ │ │ -00034 │ │ │ │ │ │ Kenneth G. Hamilton, "Assembler RANLUX for PCs", Computer Physics │ │ │ │ │ │ +00034 │ │ │ │ │ │ 00035 │ │ │ │ │ │ Communications, 101 (1997) 249-253 */ │ │ │ │ │ │ 00036 │ │ │ │ │ │ 00037 namespace siscone{ │ │ │ │ │ │ 00038 │ │ │ │ │ │ 00039 static const unsigned long int mask_lo = 0x00ffffffUL; // 2^24 - 1 │ │ │ │ │ │ 00040 static const unsigned long int mask_hi = ~0x00ffffffUL; │ │ │ │ │ │ -00041 static const unsigned long int two24 = 16777216; │ │ │ │ │ │ // 2^24 │ │ │ │ │ │ +00041 static const unsigned long int two24 = 16777216; │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 │ │ │ │ │ │ 00044 // internal generator structure │ │ │ │ │ │ 00045 //-----------------------------00046 typedef struct { │ │ │ │ │ │ -unsigned int i; │ │ │ │ │ │ 00047 │ │ │ │ │ │ -00048 │ │ │ │ │ │ +unsigned int i; │ │ │ │ │ │ unsigned int j; │ │ │ │ │ │ -unsigned int n; │ │ │ │ │ │ +00048 │ │ │ │ │ │ 00049 │ │ │ │ │ │ -00050 │ │ │ │ │ │ +unsigned int n; │ │ │ │ │ │ unsigned int skip; │ │ │ │ │ │ +00050 │ │ │ │ │ │ unsigned int carry; │ │ │ │ │ │ 00051 │ │ │ │ │ │ -00052 │ │ │ │ │ │ unsigned long int u[24]; │ │ │ │ │ │ +00052 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.30 ranlux.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00053 } ranlux_state_t; │ │ │ │ │ │ 00054 │ │ │ │ │ │ 00055 │ │ │ │ │ │ 00056 // internal generator state │ │ │ │ │ │ 00057 //-------------------------00058 ranlux_state_t local_ranlux_state; │ │ │ │ │ │ 00059 │ │ │ │ │ │ 00060 │ │ │ │ │ │ 00061 // incrementation of the generator state │ │ │ │ │ │ 00062 //--------------------------------------00063 static inline unsigned long int increment_state(){ │ │ │ │ │ │ -00064 │ │ │ │ │ │ unsigned int i = local_ranlux_state.i; │ │ │ │ │ │ +00064 │ │ │ │ │ │ 00065 │ │ │ │ │ │ unsigned int j = local_ranlux_state.j; │ │ │ │ │ │ long int delta = local_ranlux_state.u[j] - local_ranlux_state.u[i] │ │ │ │ │ │ 00066 │ │ │ │ │ │ 00067 │ │ │ │ │ │ - local_ranlux_state.carry; │ │ │ │ │ │ 00068 │ │ │ │ │ │ -if (delta & mask_hi){ │ │ │ │ │ │ 00069 │ │ │ │ │ │ +if (delta & mask_hi){ │ │ │ │ │ │ 00070 │ │ │ │ │ │ local_ranlux_state.carry = 1; │ │ │ │ │ │ 00071 │ │ │ │ │ │ delta &= mask_lo; │ │ │ │ │ │ 00072 │ │ │ │ │ │ } else { │ │ │ │ │ │ 00073 │ │ │ │ │ │ @@ -20287,69 +20325,60 @@ │ │ │ │ │ │ 00080 │ │ │ │ │ │ 00081 │ │ │ │ │ │ i--; │ │ │ │ │ │ 00082 │ │ │ │ │ │ 00083 │ │ │ │ │ │ local_ranlux_state.i = i; │ │ │ │ │ │ 00084 │ │ │ │ │ │ -00085 │ │ │ │ │ │ if (j == 0) │ │ │ │ │ │ +00085 │ │ │ │ │ │ 00086 │ │ │ │ │ │ j = 23; │ │ │ │ │ │ -else │ │ │ │ │ │ 00087 │ │ │ │ │ │ +else │ │ │ │ │ │ 00088 │ │ │ │ │ │ j--; │ │ │ │ │ │ 00089 │ │ │ │ │ │ 00090 │ │ │ │ │ │ local_ranlux_state.j = j; │ │ │ │ │ │ 00091 │ │ │ │ │ │ -00092 │ │ │ │ │ │ return delta; │ │ │ │ │ │ +00092 │ │ │ │ │ │ 00093 } │ │ │ │ │ │ 00094 │ │ │ │ │ │ 00095 │ │ │ │ │ │ 00096 // set generator state │ │ │ │ │ │ 00097 //--------------------00098 static void ranlux_set(unsigned long int s){ │ │ │ │ │ │ int i; │ │ │ │ │ │ 00099 │ │ │ │ │ │ 00100 │ │ │ │ │ │ long int seed; │ │ │ │ │ │ 00101 │ │ │ │ │ │ if (s==0) │ │ │ │ │ │ 00102 │ │ │ │ │ │ -/* default seed is 314159265 */ │ │ │ │ │ │ 00103 │ │ │ │ │ │ s = 314159265; │ │ │ │ │ │ +/* default seed is 314159265 */ │ │ │ │ │ │ 00104 │ │ │ │ │ │ 00105 │ │ │ │ │ │ seed = s; │ │ │ │ │ │ 00106 │ │ │ │ │ │ 00107 │ │ │ │ │ │ /* This is the initialization algorithm of F. James, widely in use │ │ │ │ │ │ 00108 │ │ │ │ │ │ for RANLUX. */ │ │ │ │ │ │ 00109 │ │ │ │ │ │ 00110 │ │ │ │ │ │ for (i=0;i<24;i++){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -241 │ │ │ │ │ │ - │ │ │ │ │ │ - 242 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00111 │ │ │ │ │ │ unsigned long int k = seed/53668; │ │ │ │ │ │ +00111 │ │ │ │ │ │ 00112 │ │ │ │ │ │ seed = 40014*(seed-k*53668)-k*12211; │ │ │ │ │ │ -if (seed<0){ │ │ │ │ │ │ 00113 │ │ │ │ │ │ +if (seed<0){ │ │ │ │ │ │ 00114 │ │ │ │ │ │ seed += 2147483563; │ │ │ │ │ │ 00115 │ │ │ │ │ │ } │ │ │ │ │ │ 00116 │ │ │ │ │ │ local_ranlux_state.u[i] = seed%two24; │ │ │ │ │ │ 00117 │ │ │ │ │ │ @@ -20360,69 +20389,78 @@ │ │ │ │ │ │ 00120 │ │ │ │ │ │ local_ranlux_state.j = 9; │ │ │ │ │ │ 00121 │ │ │ │ │ │ local_ranlux_state.n = 0; │ │ │ │ │ │ 00122 │ │ │ │ │ │ local_ranlux_state.skip = 389-24; // 389 => best decorrelation │ │ │ │ │ │ 00123 │ │ │ │ │ │ -if (local_ranlux_state.u[23]&mask_hi){ │ │ │ │ │ │ 00124 │ │ │ │ │ │ +if (local_ranlux_state.u[23]&mask_hi){ │ │ │ │ │ │ 00125 │ │ │ │ │ │ local_ranlux_state.carry = 1; │ │ │ │ │ │ 00126 │ │ │ │ │ │ } else { │ │ │ │ │ │ 00127 │ │ │ │ │ │ local_ranlux_state.carry = 0; │ │ │ │ │ │ 00128 │ │ │ │ │ │ } │ │ │ │ │ │ 00129 } │ │ │ │ │ │ 00130 │ │ │ │ │ │ 00131 │ │ │ │ │ │ 00132 // generator initialization │ │ │ │ │ │ 00133 //-------------------------00134 void ranlux_init(){ │ │ │ │ │ │ -00135 │ │ │ │ │ │ // seed the generator │ │ │ │ │ │ +00135 │ │ │ │ │ │ 00136 │ │ │ │ │ │ ranlux_set(0); │ │ │ │ │ │ 00137 } │ │ │ │ │ │ 00138 │ │ │ │ │ │ 00139 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +241 │ │ │ │ │ │ + │ │ │ │ │ │ + 242 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00140 // get random number │ │ │ │ │ │ 00141 //------------------00142 unsigned long int ranlux_get(){ │ │ │ │ │ │ -const unsigned int skip = local_ranlux_state.skip; │ │ │ │ │ │ 00143 │ │ │ │ │ │ -00144 │ │ │ │ │ │ +const unsigned int skip = local_ranlux_state.skip; │ │ │ │ │ │ unsigned long int r = increment_state(); │ │ │ │ │ │ +00144 │ │ │ │ │ │ 00145 │ │ │ │ │ │ 00146 │ │ │ │ │ │ local_ranlux_state.n++; │ │ │ │ │ │ 00147 │ │ │ │ │ │ -if (local_ranlux_state.n == 24){ │ │ │ │ │ │ 00148 │ │ │ │ │ │ +if (local_ranlux_state.n == 24){ │ │ │ │ │ │ 00149 │ │ │ │ │ │ unsigned int i; │ │ │ │ │ │ 00150 │ │ │ │ │ │ local_ranlux_state.n = 0; │ │ │ │ │ │ for (i = 0; i < skip; i++) │ │ │ │ │ │ 00151 │ │ │ │ │ │ 00152 │ │ │ │ │ │ increment_state(); │ │ │ │ │ │ 00153 │ │ │ │ │ │ } │ │ │ │ │ │ 00154 │ │ │ │ │ │ -return r; │ │ │ │ │ │ 00155 │ │ │ │ │ │ +return r; │ │ │ │ │ │ 00156 } │ │ │ │ │ │ 00157 │ │ │ │ │ │ 00158 // print generator state │ │ │ │ │ │ 00159 //----------------------00160 void ranlux_print_state(){ │ │ │ │ │ │ 00161 │ │ │ │ │ │ size_t i; │ │ │ │ │ │ -unsigned char *p = (unsigned char *) (&local_ranlux_state); │ │ │ │ │ │ 00162 │ │ │ │ │ │ +unsigned char *p = (unsigned char *) (&local_ranlux_state); │ │ │ │ │ │ 00163 │ │ │ │ │ │ const size_t n = sizeof (ranlux_state_t); │ │ │ │ │ │ 00164 │ │ │ │ │ │ for (i=0;i &_particles, double _radius, double _f, │ │ │ │ │ │ 00080 │ │ │ │ │ │ int _n_pass_max, double _ptmin, │ │ │ │ │ │ 00081 │ │ │ │ │ │ Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ @@ -21011,29 +21045,20 @@ │ │ │ │ │ │ 00092 │ │ │ │ │ │ 00093 │ │ │ │ │ │ 00094 │ │ │ │ │ │ ptcomparison.split_merge_scale = _split_merge_scale; │ │ │ │ │ │ 00095 │ │ │ │ │ │ partial_clear(); // make sure some things are initialised properly │ │ │ │ │ │ 00096 │ │ │ │ │ │ -// init the split_merge algorithm with the initial list of particles │ │ │ │ │ │ 00097 │ │ │ │ │ │ +// init the split_merge algorithm with the initial list of particles │ │ │ │ │ │ 00098 │ │ │ │ │ │ // this initialises particle list p_left of remaining particles to deal with │ │ │ │ │ │ 00099 │ │ │ │ │ │ init_particles(_particles); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -247 │ │ │ │ │ │ - │ │ │ │ │ │ - 248 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00100 │ │ │ │ │ │ bool finished = false; │ │ │ │ │ │ 00101 │ │ │ │ │ │ 00102 │ │ │ │ │ │ 00103 │ │ │ │ │ │ rerun_allowed = false; │ │ │ │ │ │ 00104 │ │ │ │ │ │ @@ -21042,31 +21067,31 @@ │ │ │ │ │ │ 00106 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00107 │ │ │ │ │ │ nb_hash_cones_total = 0; │ │ │ │ │ │ 00108 │ │ │ │ │ │ nb_hash_occupied_total = 0; │ │ │ │ │ │ 00109 #endif │ │ │ │ │ │ 00110 │ │ │ │ │ │ -do{ │ │ │ │ │ │ 00111 │ │ │ │ │ │ -00112 │ │ │ │ │ │ +do{ │ │ │ │ │ │ // initialise stable_cone finder │ │ │ │ │ │ +00112 │ │ │ │ │ │ 00113 │ │ │ │ │ │ // here we use the list of remaining particles │ │ │ │ │ │ 00114 │ │ │ │ │ │ // AFTER COLLINEAR CLUSTERING !!!!!! │ │ │ │ │ │ 00115 │ │ │ │ │ │ Cstable_cones::init(p_uncol_hard); │ │ │ │ │ │ 00116 │ │ │ │ │ │ -// get stable cones │ │ │ │ │ │ 00117 │ │ │ │ │ │ +// get stable cones │ │ │ │ │ │ 00118 │ │ │ │ │ │ if (get_stable_cones(_radius)){ │ │ │ │ │ │ -00119 │ │ │ │ │ │ // we have some new protocones; add them to candidates │ │ │ │ │ │ +00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ // Note that add_protocones has to be called first │ │ │ │ │ │ 00121 │ │ │ │ │ │ // if we want the 4-vect components to be available │ │ │ │ │ │ 00122 │ │ │ │ │ │ // on top of eta and phi. │ │ │ │ │ │ 00123 │ │ │ │ │ │ @@ -21075,14 +21100,23 @@ │ │ │ │ │ │ protocones_list.push_back(protocones); │ │ │ │ │ │ 00125 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00126 │ │ │ │ │ │ nb_hash_cones_total += nb_hash_cones; │ │ │ │ │ │ 00127 │ │ │ │ │ │ nb_hash_occupied_total += nb_hash_occupied; │ │ │ │ │ │ 00128 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +247 │ │ │ │ │ │ + │ │ │ │ │ │ + 248 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00129 │ │ │ │ │ │ } else { │ │ │ │ │ │ // no new protocone: leave │ │ │ │ │ │ 00130 │ │ │ │ │ │ 00131 │ │ │ │ │ │ finished=true; │ │ │ │ │ │ 00132 │ │ │ │ │ │ @@ -21092,100 +21126,93 @@ │ │ │ │ │ │ _n_pass_max--; │ │ │ │ │ │ 00135 │ │ │ │ │ │ } while ((!finished) && (n_left>0) && (_n_pass_max!=0)); │ │ │ │ │ │ 00136 │ │ │ │ │ │ 00137 │ │ │ │ │ │ rerun_allowed = true; │ │ │ │ │ │ 00138 │ │ │ │ │ │ -// split & merge │ │ │ │ │ │ 00139 │ │ │ │ │ │ +// split & merge │ │ │ │ │ │ 00140 │ │ │ │ │ │ return perform(_f, _ptmin); │ │ │ │ │ │ 00141 } │ │ │ │ │ │ 00142 │ │ │ │ │ │ 00143 │ │ │ │ │ │ 00144 /* │ │ │ │ │ │ 00145 * compute the jets from a given particle set doing multiple passes │ │ │ │ │ │ 00146 * such pass N looks for jets among all particles not put into jets │ │ │ │ │ │ 00147 * during previous passes. │ │ │ │ │ │ list of particles │ │ │ │ │ │ 00148 * - _particles │ │ │ │ │ │ 00149 * - _radius │ │ │ │ │ │ cone radius │ │ │ │ │ │ 00150 * - _n_pass_max maximum number of runs │ │ │ │ │ │ -00151 * - _ptmin │ │ │ │ │ │ minimum pT of the protojets │ │ │ │ │ │ -the ordering scale to decide which stable │ │ │ │ │ │ +00151 * - _ptmin │ │ │ │ │ │ 00152 * - _ordering_scale │ │ │ │ │ │ -00153 * │ │ │ │ │ │ +the ordering scale to decide which stable │ │ │ │ │ │ cone is removed │ │ │ │ │ │ +00153 * │ │ │ │ │ │ 00154 * return the number of jets found. │ │ │ │ │ │ 00155 **********************************************************************/ │ │ │ │ │ │ 00156 int Csiscone::compute_jets_progressive_removal(vector &_particles, double _radius, │ │ │ │ │ │ 00157 │ │ │ │ │ │ int _n_pass_max, double _ptmin, │ │ │ │ │ │ 00158 │ │ │ │ │ │ Esplit_merge_scale _ordering_scale){ │ │ │ │ │ │ 00159 │ │ │ │ │ │ _initialise_if_needed(); │ │ │ │ │ │ 00160 │ │ │ │ │ │ -00161 │ │ │ │ │ │ // run some general safety tests (NB: f will be checked in split-merge) │ │ │ │ │ │ +00161 │ │ │ │ │ │ 00162 │ │ │ │ │ │ if (_radius <= 0.0 || _radius >= 0.5*M_PI) { │ │ │ │ │ │ 00163 │ │ │ │ │ │ ostringstream message; │ │ │ │ │ │ 00164 │ │ │ │ │ │ message « "Illegal value for cone radius, R = " « _radius │ │ │ │ │ │ 00165 │ │ │ │ │ │ « " (legal values are 0flags()); │ │ │ │ │ │ 00250 │ │ │ │ │ │ 00251 │ │ │ │ │ │ (*_banner_ostr) « "#ooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo" « endl; │ │ │ │ │ │ -SISCone │ │ │ │ │ │ -version " « setw(28) « left « siscone_version() │ │ │ │ │ │ 00252 │ │ │ │ │ │ (*_banner_ostr) « "# │ │ │ │ │ │ +SISCone │ │ │ │ │ │ +version " « setw(28) « left « siscone_version() │ │ │ │ │ │ « "o" « endl; │ │ │ │ │ │ 00253 │ │ │ │ │ │ (*_banner_ostr) « "# │ │ │ │ │ │ http://projects.hepforge.org/siscone │ │ │ │ │ │ o" « endl; │ │ │ │ │ │ o" « endl; │ │ │ │ │ │ 00254 │ │ │ │ │ │ (*_banner_ostr) « "# │ │ │ │ │ │ 00255 │ │ │ │ │ │ (*_banner_ostr) « "# This is SISCone: the Seedless Infrared Safe Cone Jet Algorithm │ │ │ │ │ │ o" « endl; │ │ │ │ │ │ -o" « endl; │ │ │ │ │ │ 00256 │ │ │ │ │ │ (*_banner_ostr) « "# SISCone was written by Gavin Salam and Gregory Soyez │ │ │ │ │ │ +o" « endl; │ │ │ │ │ │ 00257 │ │ │ │ │ │ (*_banner_ostr) « "# It is released under the terms of the GNU General Public License o" « endl; │ │ │ │ │ │ -o" « endl; │ │ │ │ │ │ 00258 │ │ │ │ │ │ (*_banner_ostr) « "# │ │ │ │ │ │ +o" « endl; │ │ │ │ │ │ +o" « endl; │ │ │ │ │ │ 00259 │ │ │ │ │ │ (*_banner_ostr) « "# A description of the algorithm is available in the publication │ │ │ │ │ │ -o" « endl; │ │ │ │ │ │ 00260 │ │ │ │ │ │ (*_banner_ostr) « "# JHEP 05 (2007) 086 [arXiv:0704.0292 (hep-ph)]. │ │ │ │ │ │ o" « endl; │ │ │ │ │ │ o" « endl; │ │ │ │ │ │ 00261 │ │ │ │ │ │ (*_banner_ostr) « "# Please cite it if you use SISCone. │ │ │ │ │ │ 00262 │ │ │ │ │ │ @@ -21330,23 +21364,15 @@ │ │ │ │ │ │ _banner_ostr->flags(flags_to_restore); │ │ │ │ │ │ 00267 │ │ │ │ │ │ } │ │ │ │ │ │ 00268 } │ │ │ │ │ │ 00269 │ │ │ │ │ │ 00270 // finally, a bunch of functions to access to │ │ │ │ │ │ 00271 // basic information (package name, version) │ │ │ │ │ │ -00272 //--------------------------------------------- │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 250 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00273 │ │ │ │ │ │ +00272 //--------------------------------------------00273 │ │ │ │ │ │ 00274 /* │ │ │ │ │ │ 00275 * return SISCone package name. │ │ │ │ │ │ 00276 * This is nothing but "SISCone", it is a replacement to the │ │ │ │ │ │ 00277 * SISCONE_PACKAGE_NAME string defined in config.h and which is not │ │ │ │ │ │ 00278 * guaranteed to be public. │ │ │ │ │ │ 00279 * return the SISCone name as a string │ │ │ │ │ │ 00280 */ │ │ │ │ │ │ @@ -21354,28 +21380,35 @@ │ │ │ │ │ │ 00282 │ │ │ │ │ │ return SISCONE_PACKAGE_NAME; │ │ │ │ │ │ 00283 } │ │ │ │ │ │ 00284 │ │ │ │ │ │ 00285 /* │ │ │ │ │ │ 00286 * return SISCone version number. │ │ │ │ │ │ 00287 * return a string of the form "X.Y.Z" with possible additional tag │ │ │ │ │ │ -(alpha, beta, devel) to mention stability status │ │ │ │ │ │ 00288 * │ │ │ │ │ │ +(alpha, beta, devel) to mention stability status │ │ │ │ │ │ 00289 */ │ │ │ │ │ │ 00290 string siscone_version(){ │ │ │ │ │ │ -return SISCONE_VERSION; │ │ │ │ │ │ 00291 │ │ │ │ │ │ +return SISCONE_VERSION; │ │ │ │ │ │ 00292 } │ │ │ │ │ │ 00293 │ │ │ │ │ │ 00294 } │ │ │ │ │ │ │ │ │ │ │ │ 5.36 siscone.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ -// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 250 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 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 │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // │ │ │ │ │ │ @@ -21451,19 +21484,14 @@ │ │ │ │ │ │ 00052 //-------------00053 CSphsiscone::CSphsiscone(){ │ │ │ │ │ │ 00054 │ │ │ │ │ │ rerun_allowed = false; │ │ │ │ │ │ 00055 } │ │ │ │ │ │ 00056 │ │ │ │ │ │ 00057 // default dtor │ │ │ │ │ │ 00058 //-------------00059 CSphsiscone::~CSphsiscone(){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.36 siscone.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00060 │ │ │ │ │ │ rerun_allowed = false; │ │ │ │ │ │ 00061 } │ │ │ │ │ │ 00062 │ │ │ │ │ │ 00063 bool CSphsiscone::init_done=false; │ │ │ │ │ │ 00064 std::ostream* CSphsiscone::_banner_ostr=&cout; │ │ │ │ │ │ 00065 │ │ │ │ │ │ @@ -21476,46 +21504,53 @@ │ │ │ │ │ │ 00071 * - _radius │ │ │ │ │ │ cone radius │ │ │ │ │ │ shared energy threshold for splitting&merging │ │ │ │ │ │ 00072 * - _f │ │ │ │ │ │ 00073 * - _n_pass_max maximum number of runs │ │ │ │ │ │ minimum energy of the protojets │ │ │ │ │ │ 00074 * - _Emin │ │ │ │ │ │ -the scale choice for the split-merge procedure │ │ │ │ │ │ 00075 * - _split_merge_scale │ │ │ │ │ │ +the scale choice for the split-merge procedure │ │ │ │ │ │ 00076 * │ │ │ │ │ │ NOTE: using pt leads to IR unsafety for some events with momentum │ │ │ │ │ │ conservation. So we strongly advise not to change the default │ │ │ │ │ │ 00077 * │ │ │ │ │ │ 00078 * │ │ │ │ │ │ value. │ │ │ │ │ │ 00079 * return the number of jets found. │ │ │ │ │ │ 00080 **********************************************************************/ │ │ │ │ │ │ 00081 int CSphsiscone::compute_jets(vector &_particles, double _radius, double _f, │ │ │ │ │ │ -00082 │ │ │ │ │ │ int _n_pass_max, double _Emin, │ │ │ │ │ │ +00082 │ │ │ │ │ │ 00083 │ │ │ │ │ │ Esplit_merge_scale _split_merge_scale){ │ │ │ │ │ │ -// make sure things are initialised │ │ │ │ │ │ 00084 │ │ │ │ │ │ +// make sure things are initialised │ │ │ │ │ │ 00085 │ │ │ │ │ │ _initialise_if_needed(); │ │ │ │ │ │ 00086 │ │ │ │ │ │ -// run some general safety tests (NB: f will be checked in split-merge) │ │ │ │ │ │ 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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.36 siscone.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +251 │ │ │ │ │ │ + │ │ │ │ │ │ 00090 │ │ │ │ │ │ message « "Illegal value for cone radius, R = " « _radius │ │ │ │ │ │ 00091 │ │ │ │ │ │ « " (legal values are 0= 0.5*M_PI) { │ │ │ │ │ │ 00164 │ │ │ │ │ │ ostringstream message; │ │ │ │ │ │ 00165 │ │ │ │ │ │ message « "Illegal value for cone radius, R = " « _radius │ │ │ │ │ │ 00166 │ │ │ │ │ │ @@ -21656,47 +21682,54 @@ │ │ │ │ │ │ // init the split_merge algorithm with the initial list of particles │ │ │ │ │ │ 00174 │ │ │ │ │ │ // this initialises particle list p_left of remaining particles to deal with │ │ │ │ │ │ 00175 │ │ │ │ │ │ // │ │ │ │ │ │ 00176 │ │ │ │ │ │ // this stores the "processed" particles in p_uncol_hard │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 252 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00177 │ │ │ │ │ │ init_particles(_particles); │ │ │ │ │ │ 00178 │ │ │ │ │ │ jets.clear(); │ │ │ │ │ │ 00179 │ │ │ │ │ │ 00180 │ │ │ │ │ │ bool unclustered_left; │ │ │ │ │ │ 00181 │ │ │ │ │ │ rerun_allowed = false; │ │ │ │ │ │ 00182 │ │ │ │ │ │ protocones_list.clear(); │ │ │ │ │ │ 00183 │ │ │ │ │ │ -do{ │ │ │ │ │ │ 00184 │ │ │ │ │ │ -00185 │ │ │ │ │ │ +do{ │ │ │ │ │ │ //cout « n_left « " particle left" « endl; │ │ │ │ │ │ +00185 │ │ │ │ │ │ 00186 │ │ │ │ │ │ 00187 │ │ │ │ │ │ // initialise stable_cone finder │ │ │ │ │ │ 00188 │ │ │ │ │ │ // here we use the list of remaining particles │ │ │ │ │ │ 00189 │ │ │ │ │ │ // AFTER COLLINEAR CLUSTERING !!!!!! │ │ │ │ │ │ 00190 │ │ │ │ │ │ CSphstable_cones::init(p_uncol_hard); │ │ │ │ │ │ 00191 │ │ │ │ │ │ -// get stable cones (stored in ’protocones’) │ │ │ │ │ │ 00192 │ │ │ │ │ │ +// get stable cones (stored in ’protocones’) │ │ │ │ │ │ 00193 │ │ │ │ │ │ unclustered_left = get_stable_cones(_radius); │ │ │ │ │ │ 00194 │ │ │ │ │ │ -00195 │ │ │ │ │ │ // add the hardest stable cone to the list of jets │ │ │ │ │ │ +00195 │ │ │ │ │ │ 00196 │ │ │ │ │ │ if (add_hardest_protocone_to_jets(&protocones, R2, _Emin)) break; │ │ │ │ │ │ 00197 │ │ │ │ │ │ 00198 │ │ │ │ │ │ _n_pass_max--; │ │ │ │ │ │ 00199 │ │ │ │ │ │ } while ((unclustered_left) && (n_left>0) && (_n_pass_max!=0)); │ │ │ │ │ │ @@ -21705,22 +21738,22 @@ │ │ │ │ │ │ 00201 │ │ │ │ │ │ 00202 │ │ │ │ │ │ return jets.size(); │ │ │ │ │ │ 00203 } │ │ │ │ │ │ 00204 /* │ │ │ │ │ │ 00205 * recompute the jets with a different overlap parameter. │ │ │ │ │ │ 00206 * we use the same particles and R as in the preceeding call. │ │ │ │ │ │ -shared energy threshold for splitting&merging │ │ │ │ │ │ 00207 * - _f │ │ │ │ │ │ -00208 * - _Emin │ │ │ │ │ │ +shared energy threshold for splitting&merging │ │ │ │ │ │ minimum Energy of the protojets │ │ │ │ │ │ -the scale choice for the split-merge procedure │ │ │ │ │ │ +00208 * - _Emin │ │ │ │ │ │ 00209 * - _split_merge_scale │ │ │ │ │ │ -00210 * │ │ │ │ │ │ +the scale choice for the split-merge procedure │ │ │ │ │ │ NOTE: using pt leads to IR unsafety for some events with momentum │ │ │ │ │ │ +00210 * │ │ │ │ │ │ conservation. So we strongly advise not to change the default │ │ │ │ │ │ 00211 * │ │ │ │ │ │ 00212 * │ │ │ │ │ │ value. │ │ │ │ │ │ 00213 * return the number of jets found, -1 if recomputation not allowed. │ │ │ │ │ │ 00214 ********************************************************************/ │ │ │ │ │ │ 00215 int CSphsiscone::recompute_jets(double _f, double _Emin, │ │ │ │ │ │ @@ -21737,35 +21770,28 @@ │ │ │ │ │ │ // restore particle list │ │ │ │ │ │ 00222 │ │ │ │ │ │ 00223 │ │ │ │ │ │ partial_clear(); │ │ │ │ │ │ 00224 │ │ │ │ │ │ init_pleft(); │ │ │ │ │ │ 00225 │ │ │ │ │ │ -// initialise split/merge algorithm │ │ │ │ │ │ 00226 │ │ │ │ │ │ +// initialise split/merge algorithm │ │ │ │ │ │ 00227 │ │ │ │ │ │ unsigned int i; │ │ │ │ │ │ -00228 │ │ │ │ │ │ for (i=0;iflush(); │ │ │ │ │ │ @@ -21866,313 +21899,38 @@ │ │ │ │ │ │ 00288 /* │ │ │ │ │ │ 00289 * return SISCone version number. │ │ │ │ │ │ 00290 * return a string of the form "X.Y.Z" with possible additional tag │ │ │ │ │ │ 00291 * │ │ │ │ │ │ (alpha, beta, devel) to mention stability status │ │ │ │ │ │ 00292 */ │ │ │ │ │ │ 00293 string siscone_version(){ │ │ │ │ │ │ -return SISCONE_VERSION; │ │ │ │ │ │ 00294 │ │ │ │ │ │ +return SISCONE_VERSION; │ │ │ │ │ │ 00295 } │ │ │ │ │ │ 00296 │ │ │ │ │ │ 00297 } │ │ │ │ │ │ │ │ │ │ │ │ -5.37 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 │ │ │ │ │ │ -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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 254 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -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 │ │ │ │ │ │ -int compute_jets(std::vector &_particles, double _radius, double _f, │ │ │ │ │ │ -00076 │ │ │ │ │ │ -int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ │ -00077 │ │ │ │ │ │ -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 │ │ │ │ │ │ -int recompute_jets(double _f, double _ptmin = 0.0, │ │ │ │ │ │ -00113 │ │ │ │ │ │ -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 │ │ │ │ │ │ -static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ -00137 │ │ │ │ │ │ -00138 │ │ │ │ │ │ -static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ -00143 │ │ │ │ │ │ -00144 │ │ │ │ │ │ -00145 private: │ │ │ │ │ │ -bool rerun_allowed; │ │ │ │ │ │ -00146 │ │ │ │ │ │ -00147 │ │ │ │ │ │ -static std::ostream * _banner_ostr; │ │ │ │ │ │ -00148 │ │ │ │ │ │ -void _initialise_if_needed(); │ │ │ │ │ │ -00150 │ │ │ │ │ │ -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.38 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 │ │ │ │ │ │ -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 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.39 siscone_error.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -255 │ │ │ │ │ │ - │ │ │ │ │ │ -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 │ │ │ │ │ │ -int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ -00094 │ │ │ │ │ │ -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 │ │ │ │ │ │ -// random number initialisation │ │ │ │ │ │ -00116 │ │ │ │ │ │ -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 │ │ │ │ │ │ -static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ -00140 │ │ │ │ │ │ -00141 │ │ │ │ │ │ -00142 private: │ │ │ │ │ │ -bool rerun_allowed; │ │ │ │ │ │ -00143 │ │ │ │ │ │ -00144 │ │ │ │ │ │ -static std::ostream * _banner_ostr; │ │ │ │ │ │ -00145 │ │ │ │ │ │ -void _initialise_if_needed(); │ │ │ │ │ │ -00147 │ │ │ │ │ │ -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.39 siscone_error.cpp │ │ │ │ │ │ +5.37 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 │ │ │ │ │ │ -00006 // │ │ │ │ │ │ -00007 // Copyright (c) 2006 Gavin Salam and Gregory Soyez │ │ │ │ │ │ -00008 // │ │ │ │ │ │ -00009 // This program is free software; you can redistribute it and/or modify │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ // │ │ │ │ │ │ +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 │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ - 256 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 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 // │ │ │ │ │ │ @@ -22203,25 +21961,33 @@ │ │ │ │ │ │ 00028 │ │ │ │ │ │ 00029 namespace siscone{ │ │ │ │ │ │ 00030 │ │ │ │ │ │ 00031 bool Csiscone_error::m_print_errors = true; │ │ │ │ │ │ 00032 │ │ │ │ │ │ 00033 } │ │ │ │ │ │ │ │ │ │ │ │ -5.40 siscone_error.h │ │ │ │ │ │ +5.38 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 // │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ // │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 254 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -22290,22 +22056,18 @@ │ │ │ │ │ │ static bool m_print_errors; │ │ │ │ │ │ 00060 │ │ │ │ │ │ 00061 }; │ │ │ │ │ │ 00062 │ │ │ │ │ │ 00063 } │ │ │ │ │ │ 00064 #endif │ │ │ │ │ │ │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.41 momentum.h │ │ │ │ │ │ - │ │ │ │ │ │ -5.41 momentum.h │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: momentum.h │ │ │ │ │ │ +5.39 geom_2d.h │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: geom_2d.h │ │ │ │ │ │ // │ │ │ │ │ │ -00004 // Description: header file for 4-momentum class Cmomentum │ │ │ │ │ │ +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 // │ │ │ │ │ │ // │ │ │ │ │ │ @@ -22336,150 +22098,158 @@ │ │ │ │ │ │ 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 │ │ │ │ │ │ +00024 // $Revision:: 422 │ │ │ │ │ │ $// │ │ │ │ │ │ -00025 // $Date:: 2007-04-26 22:31:02 +0200 (Thu, 26 Apr 2007) │ │ │ │ │ │ +00025 // $Date:: 2020-04-22 11:51:09 +0200 (Wed, 22 Apr 2020) │ │ │ │ │ │ $// │ │ │ │ │ │ 00027 │ │ │ │ │ │ -00028 #ifndef __VECTOR_H__ │ │ │ │ │ │ -00029 #define __VECTOR_H__ │ │ │ │ │ │ +00028 #ifndef __GEOM_2D_H__ │ │ │ │ │ │ +00029 #define __GEOM_2D_H__ │ │ │ │ │ │ 00030 │ │ │ │ │ │ -00031 #include │ │ │ │ │ │ +00031 #include │ │ │ │ │ │ 00032 #include │ │ │ │ │ │ -00033 #include "reference.h" │ │ │ │ │ │ -00034 #include "geom_2d.h" │ │ │ │ │ │ -00035 #include "defines.h" │ │ │ │ │ │ -00036 │ │ │ │ │ │ -00037 namespace siscone{ │ │ │ │ │ │ +00033 #include "defines.h" │ │ │ │ │ │ +00034 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.39 geom_2d.h │ │ │ │ │ │ + │ │ │ │ │ │ +00035 #ifndef M_PI │ │ │ │ │ │ +00036 #define M_PI 3.141592653589793238462643383279502884197 │ │ │ │ │ │ +00037 #endif │ │ │ │ │ │ 00038 │ │ │ │ │ │ -00049 class Cmomentum{ │ │ │ │ │ │ -00050 public: │ │ │ │ │ │ -00052 │ │ │ │ │ │ -Cmomentum(); │ │ │ │ │ │ +00039 namespace siscone{ │ │ │ │ │ │ +00040 │ │ │ │ │ │ +00043 inline double phi_in_range(double phi) { │ │ │ │ │ │ +00044 │ │ │ │ │ │ +if │ │ │ │ │ │ +(phi <= -M_PI) phi += twopi; │ │ │ │ │ │ +else if (phi > │ │ │ │ │ │ +M_PI) phi -= twopi; │ │ │ │ │ │ +00045 │ │ │ │ │ │ +00046 │ │ │ │ │ │ +return phi; │ │ │ │ │ │ +00047 } │ │ │ │ │ │ +00048 │ │ │ │ │ │ +00052 inline double dphi(double phi1, double phi2) { │ │ │ │ │ │ +return phi_in_range(phi1-phi2); │ │ │ │ │ │ 00053 │ │ │ │ │ │ +00054 } │ │ │ │ │ │ 00055 │ │ │ │ │ │ -Cmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ 00056 │ │ │ │ │ │ -00058 │ │ │ │ │ │ -Cmomentum(double _eta, double _phi, Creference _ref); │ │ │ │ │ │ -00059 │ │ │ │ │ │ +00060 inline double abs_dphi(double phi1, double phi2) { │ │ │ │ │ │ +double delta = fabs(phi1-phi2); │ │ │ │ │ │ 00061 │ │ │ │ │ │ -~Cmomentum(); │ │ │ │ │ │ 00062 │ │ │ │ │ │ -inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ +return delta > M_PI ? twopi-delta : delta; │ │ │ │ │ │ +00063 } │ │ │ │ │ │ 00064 │ │ │ │ │ │ -00065 │ │ │ │ │ │ -inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ +00066 inline double pow2(double x) {return x*x;} │ │ │ │ │ │ 00067 │ │ │ │ │ │ 00068 │ │ │ │ │ │ -inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ -00074 │ │ │ │ │ │ -inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ +00073 class Ctwovect { │ │ │ │ │ │ +00074 public: │ │ │ │ │ │ 00076 │ │ │ │ │ │ +Ctwovect() : x(0.0), y(0.0) {} │ │ │ │ │ │ 00077 │ │ │ │ │ │ -inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ -00079 │ │ │ │ │ │ -00080 │ │ │ │ │ │ -inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ +00081 │ │ │ │ │ │ +Ctwovect(double _x, double _y) : x(_x), y(_y) {} │ │ │ │ │ │ 00082 │ │ │ │ │ │ -00083 │ │ │ │ │ │ -inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ +double x, y; │ │ │ │ │ │ +00084 │ │ │ │ │ │ 00085 │ │ │ │ │ │ -00086 │ │ │ │ │ │ +inline double mod2() const {return pow2(x)+pow2(y);} │ │ │ │ │ │ +00087 │ │ │ │ │ │ 00088 │ │ │ │ │ │ -Cmomentum& operator = (const Cmomentum &v); │ │ │ │ │ │ -00089 │ │ │ │ │ │ -const Cmomentum operator + (const Cmomentum &v); │ │ │ │ │ │ +inline double modulus() const {return sqrt(mod2());} │ │ │ │ │ │ +00090 │ │ │ │ │ │ +00091 }; │ │ │ │ │ │ 00092 │ │ │ │ │ │ 00093 │ │ │ │ │ │ -00096 │ │ │ │ │ │ -Cmomentum& operator += (const Cmomentum &v); │ │ │ │ │ │ -00097 │ │ │ │ │ │ -00100 │ │ │ │ │ │ -Cmomentum& operator -= (const Cmomentum &v); │ │ │ │ │ │ +00098 inline double dot_product(const Ctwovect & a, const Ctwovect & b) { │ │ │ │ │ │ +00099 │ │ │ │ │ │ +return a.x*b.x + a.y*b.y; │ │ │ │ │ │ +00100 } │ │ │ │ │ │ 00101 │ │ │ │ │ │ -void build_etaphi(); │ │ │ │ │ │ -00107 │ │ │ │ │ │ +00102 │ │ │ │ │ │ +00107 inline double cross_product(const Ctwovect & a, const Ctwovect & b) { │ │ │ │ │ │ 00108 │ │ │ │ │ │ -double px; │ │ │ │ │ │ -00109 │ │ │ │ │ │ +return a.x*b.y - a.y*b.x; │ │ │ │ │ │ +00109 } │ │ │ │ │ │ 00110 │ │ │ │ │ │ -double py; │ │ │ │ │ │ -double pz; │ │ │ │ │ │ 00111 │ │ │ │ │ │ -00112 │ │ │ │ │ │ -double E; │ │ │ │ │ │ -00113 │ │ │ │ │ │ -double eta; │ │ │ │ │ │ -00114 │ │ │ │ │ │ -00115 │ │ │ │ │ │ -double phi; │ │ │ │ │ │ -int parent_index; │ │ │ │ │ │ -00116 │ │ │ │ │ │ -00117 │ │ │ │ │ │ -int index; │ │ │ │ │ │ -00118 │ │ │ │ │ │ -// the following part is used for checksums // │ │ │ │ │ │ -00120 │ │ │ │ │ │ -00122 │ │ │ │ │ │ -Creference ref; │ │ │ │ │ │ -00123 }; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -257 │ │ │ │ │ │ - │ │ │ │ │ │ - 258 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +00120 class Ceta_phi_range{ │ │ │ │ │ │ +00121 public: │ │ │ │ │ │ +00123 │ │ │ │ │ │ +Ceta_phi_range(); │ │ │ │ │ │ 00124 │ │ │ │ │ │ -00127 bool operator < (const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ -00128 │ │ │ │ │ │ -00130 bool momentum_eta_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ +00130 │ │ │ │ │ │ +Ceta_phi_range(double c_eta, double c_phi, double R); │ │ │ │ │ │ 00131 │ │ │ │ │ │ -00133 bool momentum_pt_less(const Cmomentum &v1, const Cmomentum &v2); │ │ │ │ │ │ 00134 │ │ │ │ │ │ +Ceta_phi_range& operator = (const Ceta_phi_range &r); │ │ │ │ │ │ 00135 │ │ │ │ │ │ -00137 // some handy utilities // │ │ │ │ │ │ -00139 │ │ │ │ │ │ -00144 inline double get_distance(double eta, double phi, Cmomentum *v){ │ │ │ │ │ │ -double dx, dy; │ │ │ │ │ │ -00145 │ │ │ │ │ │ +int add_particle(const double eta, const double phi); │ │ │ │ │ │ +00140 │ │ │ │ │ │ +00141 │ │ │ │ │ │ +unsigned int eta_range; │ │ │ │ │ │ +00143 │ │ │ │ │ │ +00144 │ │ │ │ │ │ +unsigned int phi_range; │ │ │ │ │ │ 00146 │ │ │ │ │ │ 00147 │ │ │ │ │ │ -dx = eta - v->eta; │ │ │ │ │ │ +// extremal value for eta │ │ │ │ │ │ 00148 │ │ │ │ │ │ -dy = fabs(phi - v->phi); │ │ │ │ │ │ 00149 │ │ │ │ │ │ -if (dy>M_PI) │ │ │ │ │ │ +static double eta_min; │ │ │ │ │ │ +static double eta_max; │ │ │ │ │ │ 00150 │ │ │ │ │ │ -dy -= twopi; │ │ │ │ │ │ 00151 │ │ │ │ │ │ -return dx*dx+dy*dy; │ │ │ │ │ │ -00152 │ │ │ │ │ │ -00153 } │ │ │ │ │ │ +00152 private: │ │ │ │ │ │ +inline unsigned int get_eta_cell(double eta){ │ │ │ │ │ │ 00154 │ │ │ │ │ │ -00155 } │ │ │ │ │ │ +00155 │ │ │ │ │ │ +return (unsigned int) (1u « ((int) (32*((eta-eta_min)/(eta_max-eta_min))))); │ │ │ │ │ │ 00156 │ │ │ │ │ │ -00157 #endif │ │ │ │ │ │ +} │ │ │ │ │ │ +00157 │ │ │ │ │ │ +inline unsigned int get_phi_cell(double phi){ │ │ │ │ │ │ +00159 │ │ │ │ │ │ +00160 │ │ │ │ │ │ +return (unsigned int) (1u « ((int) (32*phi/twopi+16)%32)); │ │ │ │ │ │ +00161 │ │ │ │ │ │ +} │ │ │ │ │ │ +00162 }; │ │ │ │ │ │ +00163 │ │ │ │ │ │ +00168 bool is_range_overlap(const Ceta_phi_range &r1, const Ceta_phi_range &r2); │ │ │ │ │ │ +00169 │ │ │ │ │ │ +00175 const Ceta_phi_range range_union(const Ceta_phi_range &r1, const Ceta_phi_range &r2); │ │ │ │ │ │ +00176 │ │ │ │ │ │ +00177 } │ │ │ │ │ │ +00178 │ │ │ │ │ │ +00179 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.42 momentum.h │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: momentum.h │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +255 │ │ │ │ │ │ + │ │ │ │ │ │ + 256 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +5.40 geom_2d.h │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: geom_2d.h │ │ │ │ │ │ // │ │ │ │ │ │ -00004 // Description: header file for 4-momentum class Cmomentum │ │ │ │ │ │ +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 │ │ │ │ │ │ @@ -22515,279 +22285,757 @@ │ │ │ │ │ │ 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:: 256 │ │ │ │ │ │ +00026 // $Revision:: 422 │ │ │ │ │ │ $// │ │ │ │ │ │ -00027 // $Date:: 2008-07-14 13:52:16 +0200 (Mon, 14 Jul 2008) │ │ │ │ │ │ +00027 // $Date:: 2020-04-22 11:51:09 +0200 (Wed, 22 Apr 2020) │ │ │ │ │ │ $// │ │ │ │ │ │ 00029 │ │ │ │ │ │ -00030 #ifndef __SPH_VECTOR_H__ │ │ │ │ │ │ -00031 #define __SPH_VECTOR_H__ │ │ │ │ │ │ +00030 #ifndef __SPH_GEOM_2D_H__ │ │ │ │ │ │ +00031 #define __SPH_GEOM_2D_H__ │ │ │ │ │ │ 00032 │ │ │ │ │ │ -00033 #include │ │ │ │ │ │ +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 │ │ │ │ │ │ +00035 #include │ │ │ │ │ │ +00036 #include │ │ │ │ │ │ +00037 │ │ │ │ │ │ +00038 #ifndef M_PI │ │ │ │ │ │ +00039 #define M_PI 3.141592653589793238462643383279502884197 │ │ │ │ │ │ +00040 #endif │ │ │ │ │ │ +00041 │ │ │ │ │ │ +00042 namespace siscone_spherical{ │ │ │ │ │ │ +00043 │ │ │ │ │ │ +00052 class CSphtheta_phi_range{ │ │ │ │ │ │ +00053 public: │ │ │ │ │ │ +00055 │ │ │ │ │ │ +CSphtheta_phi_range(); │ │ │ │ │ │ +00056 │ │ │ │ │ │ +00062 │ │ │ │ │ │ +CSphtheta_phi_range(double c_theta, double c_phi, double R); │ │ │ │ │ │ 00063 │ │ │ │ │ │ -~CSph3vector(); │ │ │ │ │ │ -00064 │ │ │ │ │ │ 00066 │ │ │ │ │ │ -CSph3vector& operator = (const CSph3vector &v); │ │ │ │ │ │ +CSphtheta_phi_range& operator = (const CSphtheta_phi_range &r); │ │ │ │ │ │ 00067 │ │ │ │ │ │ -const CSph3vector operator + (const CSph3vector &v); │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 │ │ │ │ │ │ -const CSph3vector operator - (const CSph3vector &v); │ │ │ │ │ │ -00074 │ │ │ │ │ │ +int add_particle(const double theta, const double phi); │ │ │ │ │ │ +00072 │ │ │ │ │ │ +00073 │ │ │ │ │ │ +unsigned int theta_range; │ │ │ │ │ │ 00075 │ │ │ │ │ │ -const CSph3vector operator / (const double &r); │ │ │ │ │ │ +00076 │ │ │ │ │ │ +unsigned int phi_range; │ │ │ │ │ │ 00078 │ │ │ │ │ │ 00079 │ │ │ │ │ │ +static double theta_min; │ │ │ │ │ │ +00081 │ │ │ │ │ │ 00082 │ │ │ │ │ │ -CSph3vector& operator += (const CSph3vector &v); │ │ │ │ │ │ +static double theta_max; │ │ │ │ │ │ 00083 │ │ │ │ │ │ +00084 private: │ │ │ │ │ │ +00086 │ │ │ │ │ │ +inline unsigned int get_theta_cell(double theta){ │ │ │ │ │ │ +if (theta>=theta_max) return 1u«31; │ │ │ │ │ │ +00087 │ │ │ │ │ │ +00088 │ │ │ │ │ │ +return (unsigned int) (1u « ((int) (32*((theta-theta_min)/(theta_max-theta_min))))); │ │ │ │ │ │ +00089 │ │ │ │ │ │ +} │ │ │ │ │ │ +00090 │ │ │ │ │ │ +inline unsigned int get_phi_cell(double phi){ │ │ │ │ │ │ +00092 │ │ │ │ │ │ +00093 │ │ │ │ │ │ +return (unsigned int) (1u « ((int) (32*phi/twopi+16)%32)); │ │ │ │ │ │ +00094 │ │ │ │ │ │ +} │ │ │ │ │ │ +00095 }; │ │ │ │ │ │ +00096 │ │ │ │ │ │ +00101 bool is_range_overlap(const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2); │ │ │ │ │ │ +00102 │ │ │ │ │ │ +00108 const CSphtheta_phi_range range_union(const CSphtheta_phi_range &r1, const CSphtheta_phi_range &r2); │ │ │ │ │ │ +00109 │ │ │ │ │ │ +00110 } │ │ │ │ │ │ +00111 │ │ │ │ │ │ +00112 #endif │ │ │ │ │ │ + │ │ │ │ │ │ +5.41 momentum.cpp │ │ │ │ │ │ +00001 │ │ │ │ │ │ +00002 // File: momentum.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ - 5.42 momentum.h │ │ │ │ │ │ + 5.41 momentum.cpp │ │ │ │ │ │ │ │ │ │ │ │ +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 // │ │ │ │ │ │ +// │ │ │ │ │ │ +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 // │ │ │ │ │ │ +// │ │ │ │ │ │ +00023 // $Revision:: 123 │ │ │ │ │ │ +$// │ │ │ │ │ │ +00024 // $Date:: 2007-03-01 02:52:16 +0100 (Thu, 01 Mar 2007) │ │ │ │ │ │ +$// │ │ │ │ │ │ +00026 │ │ │ │ │ │ +00027 #include "momentum.h" │ │ │ │ │ │ +00028 #include │ │ │ │ │ │ +00029 #include │ │ │ │ │ │ +00030 │ │ │ │ │ │ +00031 namespace siscone{ │ │ │ │ │ │ +00032 │ │ │ │ │ │ +00033 /************************************************************************* │ │ │ │ │ │ +00034 * class Cmomentum │ │ │ │ │ │ +* │ │ │ │ │ │ +00035 * This class contains the information for particle or group of │ │ │ │ │ │ +* │ │ │ │ │ │ +00036 * particles management. │ │ │ │ │ │ +* │ │ │ │ │ │ +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 │ │ │ │ │ │ +// compute eta and phi │ │ │ │ │ │ +00058 │ │ │ │ │ │ +00059 │ │ │ │ │ │ +build_etaphi(); │ │ │ │ │ │ +00060 │ │ │ │ │ │ +ref = Creference(); │ │ │ │ │ │ +00061 } │ │ │ │ │ │ +00062 │ │ │ │ │ │ +00063 // ctor with detailed initialisation │ │ │ │ │ │ +00064 //----------------------------------00065 Cmomentum::Cmomentum(double _eta, double _phi, Creference _ref){ │ │ │ │ │ │ +00066 │ │ │ │ │ │ +eta = _eta; │ │ │ │ │ │ +00067 │ │ │ │ │ │ +phi = _phi; │ │ │ │ │ │ +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 │ │ │ │ │ │ 00086 │ │ │ │ │ │ -CSph3vector& operator -= (const CSph3vector &v); │ │ │ │ │ │ +eta = v.eta; │ │ │ │ │ │ 00087 │ │ │ │ │ │ +phi = v.phi; │ │ │ │ │ │ +00088 │ │ │ │ │ │ +00089 │ │ │ │ │ │ +ref = v.ref; │ │ │ │ │ │ 00090 │ │ │ │ │ │ -CSph3vector& operator *= (const double &r); │ │ │ │ │ │ -00091 │ │ │ │ │ │ -00094 │ │ │ │ │ │ -CSph3vector& operator /= (const double &r); │ │ │ │ │ │ -00095 │ │ │ │ │ │ -inline double perp() const {return sqrt(perp2());} │ │ │ │ │ │ +return *this; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +257 │ │ │ │ │ │ + │ │ │ │ │ │ + 258 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00091 } │ │ │ │ │ │ +00092 │ │ │ │ │ │ +00093 // addition of vectors │ │ │ │ │ │ +00094 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00095 //-----------------------------------------------00096 const Cmomentum Cmomentum::operator + (const Cmomentum &v){ │ │ │ │ │ │ 00097 │ │ │ │ │ │ +Cmomentum tmp = *this; │ │ │ │ │ │ 00098 │ │ │ │ │ │ -inline double perp2() const {return px*px+py*py;} │ │ │ │ │ │ +return tmp+=v; │ │ │ │ │ │ +00099 } │ │ │ │ │ │ 00100 │ │ │ │ │ │ -00101 │ │ │ │ │ │ -00103 │ │ │ │ │ │ -inline double norm() const {return sqrt(px*px+py*py+pz*pz);} │ │ │ │ │ │ -00104 │ │ │ │ │ │ -inline double norm2() const {return px*px+py*py+pz*pz;} │ │ │ │ │ │ +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 │ │ │ │ │ │ +py+=v.py; │ │ │ │ │ │ 00107 │ │ │ │ │ │ -inline double phi() const {return atan2(py, px);} │ │ │ │ │ │ +pz+=v.pz; │ │ │ │ │ │ +00108 │ │ │ │ │ │ +E +=v.E; │ │ │ │ │ │ 00109 │ │ │ │ │ │ 00110 │ │ │ │ │ │ -inline double theta() const {return atan2(perp(),pz);} │ │ │ │ │ │ +ref+=v.ref; │ │ │ │ │ │ +00111 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ 00112 │ │ │ │ │ │ -00113 │ │ │ │ │ │ -void build_norm(); │ │ │ │ │ │ +00113 } │ │ │ │ │ │ +00114 │ │ │ │ │ │ +00115 // incrementation of vectors │ │ │ │ │ │ +00116 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00117 //-----------------------------------------------00118 Cmomentum& Cmomentum::operator -= (const Cmomentum &v){ │ │ │ │ │ │ +00119 │ │ │ │ │ │ +px-=v.px; │ │ │ │ │ │ 00120 │ │ │ │ │ │ +py-=v.py; │ │ │ │ │ │ 00121 │ │ │ │ │ │ -void build_thetaphi(); │ │ │ │ │ │ +pz-=v.pz; │ │ │ │ │ │ +00122 │ │ │ │ │ │ +E -=v.E; │ │ │ │ │ │ +00123 │ │ │ │ │ │ +00124 │ │ │ │ │ │ +ref-=v.ref; │ │ │ │ │ │ +return *this; │ │ │ │ │ │ 00125 │ │ │ │ │ │ -00126 │ │ │ │ │ │ +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(){ │ │ │ │ │ │ +// note: the factor n (ref.nb) cancels in all expressions !! │ │ │ │ │ │ +00135 │ │ │ │ │ │ +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.42 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 │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.42 momentum.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +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 │ │ │ │ │ │ +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 │ │ │ │ │ │ +// compute the norm │ │ │ │ │ │ +00056 │ │ │ │ │ │ +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; │ │ │ │ │ │ +return tmp-=v; │ │ │ │ │ │ +00095 │ │ │ │ │ │ +00096 } │ │ │ │ │ │ +00097 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +259 │ │ │ │ │ │ + │ │ │ │ │ │ + 260 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +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 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00122 │ │ │ │ │ │ +00123 } │ │ │ │ │ │ +00124 │ │ │ │ │ │ +00125 // multiplication by a constant │ │ │ │ │ │ +00126 //-----------------------------------------------00127 CSph3vector& CSph3vector::operator *= (const double &r){ │ │ │ │ │ │ +00128 │ │ │ │ │ │ +px*=r; │ │ │ │ │ │ 00129 │ │ │ │ │ │ -void get_angular_directions(CSph3vector &angular_dir1, CSph3vector &angular_dir2); │ │ │ │ │ │ +py*=r; │ │ │ │ │ │ 00130 │ │ │ │ │ │ -double px; │ │ │ │ │ │ +pz*=r; │ │ │ │ │ │ 00131 │ │ │ │ │ │ -double py; │ │ │ │ │ │ 00132 │ │ │ │ │ │ -00133 │ │ │ │ │ │ -double pz; │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00133 } │ │ │ │ │ │ 00134 │ │ │ │ │ │ -double _norm; │ │ │ │ │ │ -00135 │ │ │ │ │ │ -00136 │ │ │ │ │ │ -double _theta; │ │ │ │ │ │ -double _phi; │ │ │ │ │ │ -00137 │ │ │ │ │ │ +00135 // division by a constant │ │ │ │ │ │ +00136 //-----------------------------------------------00137 CSph3vector& CSph3vector::operator /= (const double &r){ │ │ │ │ │ │ 00138 │ │ │ │ │ │ -// the following part is used for checksums // │ │ │ │ │ │ +px/=r; │ │ │ │ │ │ +00139 │ │ │ │ │ │ +py/=r; │ │ │ │ │ │ 00140 │ │ │ │ │ │ +pz/=r; │ │ │ │ │ │ +00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ -siscone::Creference ref; │ │ │ │ │ │ -00143 }; │ │ │ │ │ │ +_norm/=r; │ │ │ │ │ │ +00143 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ 00144 │ │ │ │ │ │ -00158 class CSphmomentum : public CSph3vector{ │ │ │ │ │ │ -00159 public: │ │ │ │ │ │ -00161 │ │ │ │ │ │ -CSphmomentum(); │ │ │ │ │ │ +00145 } │ │ │ │ │ │ +00146 │ │ │ │ │ │ +00147 // build norm from 3-momentum info │ │ │ │ │ │ +00148 void CSph3vector::build_norm(){ │ │ │ │ │ │ +00149 │ │ │ │ │ │ +_norm = norm(); │ │ │ │ │ │ +00150 } │ │ │ │ │ │ +00151 │ │ │ │ │ │ +00152 // build norm from 3-momentum info │ │ │ │ │ │ +00153 void CSph3vector::build_thetaphi(){ │ │ │ │ │ │ +00154 │ │ │ │ │ │ +_theta = theta(); │ │ │ │ │ │ +00155 │ │ │ │ │ │ +_phi = phi(); │ │ │ │ │ │ +00156 } │ │ │ │ │ │ +00157 │ │ │ │ │ │ +00158 │ │ │ │ │ │ +00159 // for this direction, compute the two reference directions │ │ │ │ │ │ +00160 // used to measure angles │ │ │ │ │ │ +00161 void CSph3vector::get_angular_directions(CSph3vector &angular_dir1, CSph3vector &angular_dir2){ │ │ │ │ │ │ 00162 │ │ │ │ │ │ +if (px < py){ │ │ │ │ │ │ +if (pz < px){ │ │ │ │ │ │ +00163 │ │ │ │ │ │ 00164 │ │ │ │ │ │ -CSphmomentum(CSph3vector &init, double E=0.0); │ │ │ │ │ │ +// z smallest │ │ │ │ │ │ 00165 │ │ │ │ │ │ +angular_dir1 = CSph3vector(-py, px, 0.0); │ │ │ │ │ │ +00166 │ │ │ │ │ │ +} else { │ │ │ │ │ │ 00167 │ │ │ │ │ │ -CSphmomentum(double _px, double _py, double _pz, double _E); │ │ │ │ │ │ +// x smallest │ │ │ │ │ │ 00168 │ │ │ │ │ │ -//CSphmomentum(double _eta, double _phi, siscone::Creference _ref); │ │ │ │ │ │ +angular_dir1 = CSph3vector(0.0, -pz, py); │ │ │ │ │ │ +00169 │ │ │ │ │ │ +} │ │ │ │ │ │ 00170 │ │ │ │ │ │ +} else { │ │ │ │ │ │ 00171 │ │ │ │ │ │ +if (pz < py){ │ │ │ │ │ │ +00172 │ │ │ │ │ │ +// z smallest │ │ │ │ │ │ 00173 │ │ │ │ │ │ -~CSphmomentum(); │ │ │ │ │ │ +angular_dir1 = CSph3vector(-py, px, 0.0); │ │ │ │ │ │ 00174 │ │ │ │ │ │ +} else { │ │ │ │ │ │ +// y smallest │ │ │ │ │ │ +00175 │ │ │ │ │ │ 00176 │ │ │ │ │ │ -inline double mass() const {return sqrt(mass2());} │ │ │ │ │ │ +angular_dir1 = CSph3vector(-pz, 0.0, px); │ │ │ │ │ │ 00177 │ │ │ │ │ │ -inline double mass2() const {return perpmass2()-perp2();} │ │ │ │ │ │ +} │ │ │ │ │ │ +00178 │ │ │ │ │ │ +} │ │ │ │ │ │ 00179 │ │ │ │ │ │ +angular_dir2 = cross_product3(*this, angular_dir1); │ │ │ │ │ │ 00180 │ │ │ │ │ │ -inline double perpmass() const {return sqrt((E-pz)*(E+pz));} │ │ │ │ │ │ +// We’ll simply take x & y so the reflection symmetry is not broken │ │ │ │ │ │ +00181 │ │ │ │ │ │ +//angular_dir1 = CSph3vector(0.0, -pz, py); │ │ │ │ │ │ 00182 │ │ │ │ │ │ -00183 │ │ │ │ │ │ -inline double perpmass2() const {return (E-pz)*(E+pz);} │ │ │ │ │ │ -00185 │ │ │ │ │ │ -00186 │ │ │ │ │ │ -inline double Et() const {return E/sqrt(1.0+pz*pz/perp2());} │ │ │ │ │ │ -00188 │ │ │ │ │ │ -00189 │ │ │ │ │ │ -inline double Et2() const {return E*E/(1.0+pz*pz/perp2());} │ │ │ │ │ │ +//angular_dir2 = CSph3vector(-pz, 0.0, -px); │ │ │ │ │ │ +00183 } │ │ │ │ │ │ +00184 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.42 momentum.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00185 /************************************************************************* │ │ │ │ │ │ +00186 * class CSphmomentum │ │ │ │ │ │ +* │ │ │ │ │ │ +00187 * This class contains the information for particle or group of │ │ │ │ │ │ +* │ │ │ │ │ │ +00188 * particles management. │ │ │ │ │ │ +* │ │ │ │ │ │ +00189 * It includes all Lorentz properties as well as tools for summing them. * │ │ │ │ │ │ +00190 *************************************************************************/ │ │ │ │ │ │ 00191 │ │ │ │ │ │ -00192 │ │ │ │ │ │ -00194 │ │ │ │ │ │ -CSphmomentum& operator = (const CSphmomentum &v); │ │ │ │ │ │ +00192 // default ctor │ │ │ │ │ │ +00193 //-------------00194 CSphmomentum::CSphmomentum(){ │ │ │ │ │ │ 00195 │ │ │ │ │ │ -const CSphmomentum operator + (const CSphmomentum &v); │ │ │ │ │ │ +E=0.0; │ │ │ │ │ │ +00196 │ │ │ │ │ │ +index = -1; │ │ │ │ │ │ +00197 } │ │ │ │ │ │ 00198 │ │ │ │ │ │ -00199 │ │ │ │ │ │ +00199 // ctor with initialisation │ │ │ │ │ │ +00200 //-------------------------00201 CSphmomentum::CSphmomentum(double _px, double _py, double _pz, double _E) │ │ │ │ │ │ 00202 │ │ │ │ │ │ -CSphmomentum& operator += (const CSphmomentum &v); │ │ │ │ │ │ +: CSph3vector(_px, _py, _pz) { │ │ │ │ │ │ 00203 │ │ │ │ │ │ +E = _E; │ │ │ │ │ │ +00204 │ │ │ │ │ │ +// compute the angles │ │ │ │ │ │ +00205 │ │ │ │ │ │ 00206 │ │ │ │ │ │ -CSphmomentum& operator -= (const CSphmomentum &v); │ │ │ │ │ │ -00207 │ │ │ │ │ │ -double E; │ │ │ │ │ │ +build_thetaphi(); │ │ │ │ │ │ +00207 } │ │ │ │ │ │ 00208 │ │ │ │ │ │ -00209 │ │ │ │ │ │ -int parent_index; │ │ │ │ │ │ -00210 │ │ │ │ │ │ -00211 │ │ │ │ │ │ -int index; │ │ │ │ │ │ -00212 }; │ │ │ │ │ │ +00209 // ctor with initialisation │ │ │ │ │ │ +00210 //-------------------------00211 CSphmomentum::CSphmomentum(CSph3vector &_v, double _E) │ │ │ │ │ │ +00212 │ │ │ │ │ │ +: CSph3vector(_v.px, _v.py, _v.pz) { │ │ │ │ │ │ 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 // │ │ │ │ │ │ +E = _E; │ │ │ │ │ │ +00214 } │ │ │ │ │ │ +00215 │ │ │ │ │ │ +00216 // default dtor │ │ │ │ │ │ +00217 //-------------00218 CSphmomentum::~CSphmomentum(){ │ │ │ │ │ │ +00219 │ │ │ │ │ │ +00220 } │ │ │ │ │ │ +00221 │ │ │ │ │ │ +00222 // assignment of vectors │ │ │ │ │ │ +00223 //----------------------00224 CSphmomentum& CSphmomentum::operator = (const CSphmomentum &v){ │ │ │ │ │ │ +00225 │ │ │ │ │ │ +px = v.px; │ │ │ │ │ │ +00226 │ │ │ │ │ │ +py = v.py; │ │ │ │ │ │ +00227 │ │ │ │ │ │ +pz = v.pz; │ │ │ │ │ │ 00228 │ │ │ │ │ │ -00230 inline double sqr(double x){return x*x;} │ │ │ │ │ │ +E = v.E; │ │ │ │ │ │ +00229 │ │ │ │ │ │ +00230 │ │ │ │ │ │ +_norm = v._norm; │ │ │ │ │ │ 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; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -259 │ │ │ │ │ │ - │ │ │ │ │ │ - 260 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +_theta = v._theta; │ │ │ │ │ │ +00232 │ │ │ │ │ │ +_phi │ │ │ │ │ │ += v._phi; │ │ │ │ │ │ +00233 │ │ │ │ │ │ +00234 │ │ │ │ │ │ +ref = v.ref; │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00235 │ │ │ │ │ │ +00236 } │ │ │ │ │ │ 00237 │ │ │ │ │ │ -00238 │ │ │ │ │ │ -00239 │ │ │ │ │ │ - │ │ │ │ │ │ -//if (!isfinite(tmp)){ │ │ │ │ │ │ -// std::cout « "dot_product inf: " « std::endl; │ │ │ │ │ │ -// 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; │ │ │ │ │ │ +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 │ │ │ │ │ │ -return v1.px*v2.px + v1.py*v2.py + v1.pz*v2.pz; │ │ │ │ │ │ +return tmp+=v; │ │ │ │ │ │ 00244 } │ │ │ │ │ │ 00245 │ │ │ │ │ │ -00249 inline CSph3vector cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ -//CSph3vector tmp; │ │ │ │ │ │ +00246 // incrementation of vectors │ │ │ │ │ │ +00247 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00248 //-----------------------------------------------00249 CSphmomentum& CSphmomentum::operator += (const CSphmomentum &v){ │ │ │ │ │ │ 00250 │ │ │ │ │ │ +px+=v.px; │ │ │ │ │ │ 00251 │ │ │ │ │ │ -//tmp.px = v1.py*v2.pz-v1.pz*v2.py; │ │ │ │ │ │ +py+=v.py; │ │ │ │ │ │ 00252 │ │ │ │ │ │ -//tmp.py = v1.pz*v2.px-v1.px*v2.pz; │ │ │ │ │ │ +pz+=v.pz; │ │ │ │ │ │ 00253 │ │ │ │ │ │ -//tmp.pz = v1.px*v2.py-v1.py*v2.px; │ │ │ │ │ │ +E +=v.E; │ │ │ │ │ │ 00254 │ │ │ │ │ │ -//return tmp; │ │ │ │ │ │ 00255 │ │ │ │ │ │ -return CSph3vector(v1.py*v2.pz-v1.pz*v2.py, │ │ │ │ │ │ +ref+=v.ref; │ │ │ │ │ │ 00256 │ │ │ │ │ │ -v1.pz*v2.px-v1.px*v2.pz, │ │ │ │ │ │ 00257 │ │ │ │ │ │ -v1.px*v2.py-v1.py*v2.px); │ │ │ │ │ │ +return *this; │ │ │ │ │ │ 00258 } │ │ │ │ │ │ 00259 │ │ │ │ │ │ -00263 inline double norm2_cross_product3(const CSph3vector &v1, const CSph3vector &v2){ │ │ │ │ │ │ +00260 // decrementation of vectors │ │ │ │ │ │ +00261 // !!! WARNING !!! no updating of eta and phi !!! │ │ │ │ │ │ +00262 //-----------------------------------------------00263 CSphmomentum& CSphmomentum::operator -= (const CSphmomentum &v){ │ │ │ │ │ │ 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 } │ │ │ │ │ │ +px-=v.px; │ │ │ │ │ │ +00265 │ │ │ │ │ │ +py-=v.py; │ │ │ │ │ │ 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 } │ │ │ │ │ │ +pz-=v.pz; │ │ │ │ │ │ +00267 │ │ │ │ │ │ +E -=v.E; │ │ │ │ │ │ +00268 │ │ │ │ │ │ +00269 │ │ │ │ │ │ +ref-=v.ref; │ │ │ │ │ │ +00270 │ │ │ │ │ │ +return *this; │ │ │ │ │ │ +00271 } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +261 │ │ │ │ │ │ + │ │ │ │ │ │ + 262 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ +00272 │ │ │ │ │ │ 00273 │ │ │ │ │ │ -00277 inline double get_distance(const CSph3vector *v1, const CSph3vector *v2){ │ │ │ │ │ │ -return atan2(sqrt(norm2_cross_product3(*v1,*v2)), dot_product3(*v1,*v2)); │ │ │ │ │ │ +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){ │ │ │ │ │ │ +return v1.ref < v2.ref; │ │ │ │ │ │ 00278 │ │ │ │ │ │ 00279 } │ │ │ │ │ │ 00280 │ │ │ │ │ │ -00289 inline bool is_closer(const CSph3vector *v1, const CSph3vector *v2, const double tan2R){ │ │ │ │ │ │ +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 │ │ │ │ │ │ +return v1._theta < v2._theta; │ │ │ │ │ │ +00285 } │ │ │ │ │ │ +00286 │ │ │ │ │ │ +00287 // ordering of vectors in pt │ │ │ │ │ │ +00288 //--------------------------00289 bool momentum_pt_less(const CSphmomentum &v1, const CSphmomentum &v2){ │ │ │ │ │ │ +return v1.perp2() < v2.perp2(); │ │ │ │ │ │ 00290 │ │ │ │ │ │ -double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ -return (dot>=0) && (norm2_cross_product3(*v1,*v2)<=tan2R*dot*dot); │ │ │ │ │ │ -00291 │ │ │ │ │ │ -00292 } │ │ │ │ │ │ -00293 │ │ │ │ │ │ -00299 inline bool is_closer_safer(const CSph3vector *v1, const CSph3vector *v2, const double cosR){ │ │ │ │ │ │ -return dot_product3(*v1,*v2)>=cosR*sqrt(v1->norm2()*v2->norm2()); │ │ │ │ │ │ -00300 │ │ │ │ │ │ -00301 │ │ │ │ │ │ -//double dot = dot_product3(*v1,*v2); │ │ │ │ │ │ -00302 │ │ │ │ │ │ -//return (dot>=0) && (norm2_cross_product3(*v1,*v2) │ │ │ │ │ │ -00034 #include │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include "hash.h" │ │ │ │ │ │ -00037 │ │ │ │ │ │ -00038 #include "defines.h" │ │ │ │ │ │ -00039 │ │ │ │ │ │ -00040 namespace siscone{ │ │ │ │ │ │ -00041 │ │ │ │ │ │ -00053 class Cborder_store{ │ │ │ │ │ │ -00054 public: │ │ │ │ │ │ -00056 │ │ │ │ │ │ -Cborder_store(Cmomentum * momentum, double centre_eta, double centre_phi) : │ │ │ │ │ │ -00057 │ │ │ │ │ │ -mom(momentum), is_in(false) { │ │ │ │ │ │ -00058 │ │ │ │ │ │ -angle = atan2(mom->phi - centre_phi, mom->eta - centre_eta); │ │ │ │ │ │ -00059 │ │ │ │ │ │ -} │ │ │ │ │ │ -00060 │ │ │ │ │ │ -00061 │ │ │ │ │ │ -Cmomentum * mom; │ │ │ │ │ │ -double angle; │ │ │ │ │ │ -00062 │ │ │ │ │ │ -bool │ │ │ │ │ │ -is_in; │ │ │ │ │ │ -00063 │ │ │ │ │ │ -00064 }; │ │ │ │ │ │ -00065 │ │ │ │ │ │ -00066 │ │ │ │ │ │ -00069 inline bool operator<(const Cborder_store & a, const Cborder_store & b) { │ │ │ │ │ │ -return a.angle < b.angle; │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 } │ │ │ │ │ │ -00072 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -00082 class Cstable_cones : public Cvicinity{ │ │ │ │ │ │ -00083 public: │ │ │ │ │ │ -00085 │ │ │ │ │ │ -Cstable_cones(); │ │ │ │ │ │ -00086 │ │ │ │ │ │ -00088 │ │ │ │ │ │ -Cstable_cones(std::vector &_particle_list); │ │ │ │ │ │ -00089 │ │ │ │ │ │ -00091 │ │ │ │ │ │ -~Cstable_cones(); │ │ │ │ │ │ -00092 │ │ │ │ │ │ -void init(std::vector &_particle_list); │ │ │ │ │ │ +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, │ │ │ │ │ │ +int _n_pass_max=0, double _ptmin=0.0, │ │ │ │ │ │ +00077 │ │ │ │ │ │ +00078 │ │ │ │ │ │ +Esplit_merge_scale _split_merge_scale=SM_pttilde); │ │ │ │ │ │ +00079 │ │ │ │ │ │ 00097 │ │ │ │ │ │ +int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ 00098 │ │ │ │ │ │ -int get_stable_cones(double _radius); │ │ │ │ │ │ -00106 │ │ │ │ │ │ -00107 │ │ │ │ │ │ -00109 │ │ │ │ │ │ -std::vector protocones; │ │ │ │ │ │ -00110 │ │ │ │ │ │ -00112 │ │ │ │ │ │ -hash_cones *hc; │ │ │ │ │ │ +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 │ │ │ │ │ │ -int nb_tot; │ │ │ │ │ │ -00116 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00117 │ │ │ │ │ │ -int nb_hash_cones, nb_hash_occupied; │ │ │ │ │ │ -00118 #endif │ │ │ │ │ │ +std::vector > protocones_list; │ │ │ │ │ │ +00118 │ │ │ │ │ │ +// random number initialisation │ │ │ │ │ │ 00119 │ │ │ │ │ │ -00120 protected: │ │ │ │ │ │ -double R; │ │ │ │ │ │ -00122 │ │ │ │ │ │ +00120 │ │ │ │ │ │ +static bool init_done; │ │ │ │ │ │ +00121 │ │ │ │ │ │ +00122 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00123 │ │ │ │ │ │ -double R2; │ │ │ │ │ │ +int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.44 siscone.h │ │ │ │ │ │ + │ │ │ │ │ │ +00124 #endif │ │ │ │ │ │ 00125 │ │ │ │ │ │ -00126 │ │ │ │ │ │ -00127 private: │ │ │ │ │ │ -00130 │ │ │ │ │ │ -Cmomentum cone; │ │ │ │ │ │ -00131 │ │ │ │ │ │ -00133 │ │ │ │ │ │ -Cmomentum *child; │ │ │ │ │ │ -00134 │ │ │ │ │ │ -00136 │ │ │ │ │ │ -Cvicinity_elm *centre; │ │ │ │ │ │ 00137 │ │ │ │ │ │ -unsigned int centre_idx; │ │ │ │ │ │ -00139 │ │ │ │ │ │ -00140 │ │ │ │ │ │ -unsigned int first_cone; │ │ │ │ │ │ -00142 │ │ │ │ │ │ +static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ +00138 │ │ │ │ │ │ +static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ 00143 │ │ │ │ │ │ -int init_cone(); │ │ │ │ │ │ -00149 │ │ │ │ │ │ +00144 │ │ │ │ │ │ +00145 private: │ │ │ │ │ │ +00146 │ │ │ │ │ │ +bool rerun_allowed; │ │ │ │ │ │ +static std::ostream * _banner_ostr; │ │ │ │ │ │ +00147 │ │ │ │ │ │ +00148 │ │ │ │ │ │ 00150 │ │ │ │ │ │ -int test_cone(); │ │ │ │ │ │ -00157 │ │ │ │ │ │ -00158 │ │ │ │ │ │ -int update_cone(); │ │ │ │ │ │ -00164 │ │ │ │ │ │ -00165 │ │ │ │ │ │ -/* │ │ │ │ │ │ -00166 │ │ │ │ │ │ +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 │ │ │ │ │ │ -* run through the vicinity of the current parent and for each child │ │ │ │ │ │ -00168 │ │ │ │ │ │ -* indicate which members are cocircular... │ │ │ │ │ │ -00169 │ │ │ │ │ │ -*/ │ │ │ │ │ │ -00170 │ │ │ │ │ │ -void prepare_cocircular_lists(); │ │ │ │ │ │ -00171 │ │ │ │ │ │ -bool cocircular_check(); │ │ │ │ │ │ -00179 │ │ │ │ │ │ -00180 │ │ │ │ │ │ -void test_cone_cocircular(Cmomentum & borderless_cone, │ │ │ │ │ │ -00185 │ │ │ │ │ │ -00186 │ │ │ │ │ │ -std::list & border_list); │ │ │ │ │ │ -00187 │ │ │ │ │ │ -00194 │ │ │ │ │ │ -void test_stability(Cmomentum & candidate, │ │ │ │ │ │ -const std::vector & border_vect); │ │ │ │ │ │ -00195 │ │ │ │ │ │ -00196 │ │ │ │ │ │ -00203 │ │ │ │ │ │ -void compute_cone_contents(); │ │ │ │ │ │ -00204 │ │ │ │ │ │ -00210 │ │ │ │ │ │ -void recompute_cone_contents(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -261 │ │ │ │ │ │ - │ │ │ │ │ │ - 262 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00211 │ │ │ │ │ │ -/* │ │ │ │ │ │ -00212 │ │ │ │ │ │ -00213 │ │ │ │ │ │ -* if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ -00214 │ │ │ │ │ │ -* the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ -00215 │ │ │ │ │ │ -* ’pincluded’ information from the Cvicinity class, but we don’t │ │ │ │ │ │ -00216 │ │ │ │ │ │ -* change the member cone, only the locally supplied one │ │ │ │ │ │ -00217 │ │ │ │ │ │ -*/ │ │ │ │ │ │ -00218 │ │ │ │ │ │ -void recompute_cone_contents_if_needed(Cmomentum & this_cone, double & this_dpt); │ │ │ │ │ │ -00219 │ │ │ │ │ │ -int proceed_with_stability(); │ │ │ │ │ │ -00225 │ │ │ │ │ │ -00226 │ │ │ │ │ │ -/* │ │ │ │ │ │ -00227 │ │ │ │ │ │ -00228 │ │ │ │ │ │ -* circle intersection. │ │ │ │ │ │ -00229 │ │ │ │ │ │ -* computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ -00230 │ │ │ │ │ │ -* The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ -circle centre x coordinate │ │ │ │ │ │ -00231 │ │ │ │ │ │ -* - cx │ │ │ │ │ │ -00232 │ │ │ │ │ │ -circle centre y coordinate │ │ │ │ │ │ -* - cy │ │ │ │ │ │ -00233 │ │ │ │ │ │ -* return the checkxor for the intersection │ │ │ │ │ │ -00234 │ │ │ │ │ │ -******************************************************************/ │ │ │ │ │ │ -00235 │ │ │ │ │ │ -Creference circle_intersect(double cx, double cy); │ │ │ │ │ │ -00236 │ │ │ │ │ │ -00238 │ │ │ │ │ │ -Cmomentum cone_candidate; │ │ │ │ │ │ -00239 │ │ │ │ │ │ -00241 │ │ │ │ │ │ -std::vector child_list; │ │ │ │ │ │ -00242 │ │ │ │ │ │ -00245 │ │ │ │ │ │ -std::vector< std::pair > multiple_centre_done; │ │ │ │ │ │ -00246 │ │ │ │ │ │ -// information for updating cone contents to avoid rounding errors │ │ │ │ │ │ -00247 │ │ │ │ │ │ -00248 │ │ │ │ │ │ -double dpt; │ │ │ │ │ │ -00249 │ │ │ │ │ │ -inline bool is_inside(Cmomentum *centre, Cmomentum *v); │ │ │ │ │ │ -00258 │ │ │ │ │ │ -00259 }; │ │ │ │ │ │ -00260 │ │ │ │ │ │ -00261 /* │ │ │ │ │ │ -00262 * compute the absolute value of the difference between 2 angles. │ │ │ │ │ │ -00263 * We take care of the 2pi periodicity │ │ │ │ │ │ -first angle │ │ │ │ │ │ -00264 * \param angle1 │ │ │ │ │ │ -00265 * \param angle2 │ │ │ │ │ │ -second angle │ │ │ │ │ │ -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 │ │ │ │ │ │ +00173 std::string siscone_version(); │ │ │ │ │ │ +00174 │ │ │ │ │ │ +00175 } │ │ │ │ │ │ +00176 #endif │ │ │ │ │ │ │ │ │ │ │ │ -5.44 protocones.h │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: protocones.h │ │ │ │ │ │ +5.44 siscone.h │ │ │ │ │ │ +00001 // -*- C++ -*00003 // File: siscone.h │ │ │ │ │ │ // │ │ │ │ │ │ -00004 // Description: header file for stable cones determination (Cstable_cones) │ │ │ │ │ │ +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 │ │ │ │ │ │ @@ -23087,236 +23199,103 @@ │ │ │ │ │ │ 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_PROTOCONES_H__ │ │ │ │ │ │ -00031 #define __SPH_PROTOCONES_H__ │ │ │ │ │ │ +00030 #ifndef __SPH_SISCONE_H__ │ │ │ │ │ │ +00031 #define __SPH_SISCONE_H__ │ │ │ │ │ │ 00032 │ │ │ │ │ │ -00033 #include "momentum.h" │ │ │ │ │ │ -00034 #include "vicinity.h" │ │ │ │ │ │ -00035 #include │ │ │ │ │ │ -00036 #include │ │ │ │ │ │ -00037 #include │ │ │ │ │ │ -00038 #include "hash.h" │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.44 protocones.h │ │ │ │ │ │ - │ │ │ │ │ │ -263 │ │ │ │ │ │ - │ │ │ │ │ │ -00039 │ │ │ │ │ │ -00040 #include │ │ │ │ │ │ -00041 │ │ │ │ │ │ -00042 namespace siscone_spherical{ │ │ │ │ │ │ -00043 │ │ │ │ │ │ -00055 class CSphborder_store{ │ │ │ │ │ │ -00056 public: │ │ │ │ │ │ -00058 │ │ │ │ │ │ -CSphborder_store(CSphmomentum * momentum, CSph3vector ¢re, CSph3vector &angl_dir1, CSph3vector │ │ │ │ │ │ -&angl_dir2) : │ │ │ │ │ │ -00059 │ │ │ │ │ │ -mom(momentum), is_in(false) { │ │ │ │ │ │ -00060 │ │ │ │ │ │ -CSph3vector diff = (*momentum) - centre; │ │ │ │ │ │ -00061 │ │ │ │ │ │ -angle = atan2(dot_product3(diff, angl_dir2), dot_product3(diff, angl_dir1)); │ │ │ │ │ │ -00062 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00063 │ │ │ │ │ │ -std::cout « " adding point " « momentum->_theta « ", " « momentum->_phi │ │ │ │ │ │ -00064 │ │ │ │ │ │ -« " at an angle of " « angle « std::endl; │ │ │ │ │ │ -00065 #endif │ │ │ │ │ │ -00066 │ │ │ │ │ │ -} │ │ │ │ │ │ -00067 │ │ │ │ │ │ -00068 │ │ │ │ │ │ -CSphmomentum * mom; │ │ │ │ │ │ -00069 │ │ │ │ │ │ -double angle; │ │ │ │ │ │ -bool │ │ │ │ │ │ -is_in; │ │ │ │ │ │ -00070 │ │ │ │ │ │ -00071 }; │ │ │ │ │ │ -00072 │ │ │ │ │ │ -00073 │ │ │ │ │ │ -00076 inline bool operator<(const CSphborder_store & a, const CSphborder_store & b) { │ │ │ │ │ │ -return a.angle < b.angle; │ │ │ │ │ │ +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 │ │ │ │ │ │ -00078 } │ │ │ │ │ │ +int _n_pass_max=0, double _Emin=0.0, │ │ │ │ │ │ +00078 │ │ │ │ │ │ +Esplit_merge_scale _split_merge_scale=SM_Etilde); │ │ │ │ │ │ 00079 │ │ │ │ │ │ -00080 │ │ │ │ │ │ -00089 class CSphstable_cones : public CSphvicinity{ │ │ │ │ │ │ -00090 public: │ │ │ │ │ │ -00092 │ │ │ │ │ │ -CSphstable_cones(); │ │ │ │ │ │ -00093 │ │ │ │ │ │ +00094 │ │ │ │ │ │ +int compute_jets_progressive_removal(std::vector &_particles, double _radius, │ │ │ │ │ │ +int _n_pass_max=0, double _Emin=0.0, │ │ │ │ │ │ 00095 │ │ │ │ │ │ -CSphstable_cones(std::vector &_particle_list); │ │ │ │ │ │ 00096 │ │ │ │ │ │ -00098 │ │ │ │ │ │ -~CSphstable_cones(); │ │ │ │ │ │ -00099 │ │ │ │ │ │ -00104 │ │ │ │ │ │ -void init(std::vector &_particle_list); │ │ │ │ │ │ -00105 │ │ │ │ │ │ -int get_stable_cones(double _radius); │ │ │ │ │ │ -00113 │ │ │ │ │ │ +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 │ │ │ │ │ │ +// random number initialisation │ │ │ │ │ │ 00116 │ │ │ │ │ │ -std::vector protocones; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +263 │ │ │ │ │ │ + │ │ │ │ │ │ + 264 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00117 │ │ │ │ │ │ -00119 │ │ │ │ │ │ -sph_hash_cones *hc; │ │ │ │ │ │ +static bool init_done; │ │ │ │ │ │ +00118 │ │ │ │ │ │ +00119 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ 00120 │ │ │ │ │ │ +int nb_hash_cones_total, nb_hash_occupied_total; │ │ │ │ │ │ +00121 #endif │ │ │ │ │ │ 00122 │ │ │ │ │ │ -int nb_tot; │ │ │ │ │ │ -00123 #ifdef DEBUG_STABLE_CONES │ │ │ │ │ │ -00124 │ │ │ │ │ │ -int nb_hash_cones, nb_hash_occupied; │ │ │ │ │ │ -00125 #endif │ │ │ │ │ │ -00126 │ │ │ │ │ │ -00127 protected: │ │ │ │ │ │ -double R; │ │ │ │ │ │ -00129 │ │ │ │ │ │ -00130 │ │ │ │ │ │ -double R2; │ │ │ │ │ │ -00132 │ │ │ │ │ │ -00133 │ │ │ │ │ │ +static void set_banner_stream(std::ostream * ostr) {_banner_ostr = ostr;} │ │ │ │ │ │ +00134 │ │ │ │ │ │ 00135 │ │ │ │ │ │ -double tan2R; │ │ │ │ │ │ -00136 │ │ │ │ │ │ -00137 private: │ │ │ │ │ │ +static std::ostream * banner_stream() {return _banner_ostr;} │ │ │ │ │ │ 00140 │ │ │ │ │ │ -CSphmomentum cone; │ │ │ │ │ │ 00141 │ │ │ │ │ │ +00142 private: │ │ │ │ │ │ +bool rerun_allowed; │ │ │ │ │ │ 00143 │ │ │ │ │ │ -CSphmomentum *child; │ │ │ │ │ │ 00144 │ │ │ │ │ │ -00146 │ │ │ │ │ │ -CSphvicinity_elm *centre; │ │ │ │ │ │ +static std::ostream * _banner_ostr; │ │ │ │ │ │ +00145 │ │ │ │ │ │ +void _initialise_if_needed(); │ │ │ │ │ │ 00147 │ │ │ │ │ │ -unsigned int centre_idx; │ │ │ │ │ │ -00149 │ │ │ │ │ │ +00148 │ │ │ │ │ │ +00149 }; │ │ │ │ │ │ 00150 │ │ │ │ │ │ -unsigned int first_cone; │ │ │ │ │ │ -00152 │ │ │ │ │ │ -00153 │ │ │ │ │ │ -int init_cone(); │ │ │ │ │ │ -00159 │ │ │ │ │ │ -00160 │ │ │ │ │ │ -int test_cone(); │ │ │ │ │ │ -00167 │ │ │ │ │ │ -00168 │ │ │ │ │ │ -int update_cone(); │ │ │ │ │ │ -00174 │ │ │ │ │ │ -00175 │ │ │ │ │ │ -00176 │ │ │ │ │ │ -/* │ │ │ │ │ │ -00177 │ │ │ │ │ │ -* run through the vicinity of the current parent and for each child │ │ │ │ │ │ -00178 │ │ │ │ │ │ -* indicate which members are cocircular... │ │ │ │ │ │ -00179 │ │ │ │ │ │ -*/ │ │ │ │ │ │ -00180 │ │ │ │ │ │ -void prepare_cocircular_lists(); │ │ │ │ │ │ -00181 │ │ │ │ │ │ -bool cocircular_check(); │ │ │ │ │ │ -00189 │ │ │ │ │ │ -00190 │ │ │ │ │ │ -void test_cone_cocircular(CSphmomentum & borderless_cone, │ │ │ │ │ │ -00195 │ │ │ │ │ │ -00196 │ │ │ │ │ │ -std::list & border_list); │ │ │ │ │ │ -00197 │ │ │ │ │ │ -00204 │ │ │ │ │ │ -void test_stability(CSphmomentum & candidate, │ │ │ │ │ │ -00205 │ │ │ │ │ │ -const std::vector & border_vect); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 264 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00206 │ │ │ │ │ │ -void compute_cone_contents(); │ │ │ │ │ │ -00213 │ │ │ │ │ │ -00214 │ │ │ │ │ │ -00220 │ │ │ │ │ │ -void recompute_cone_contents(); │ │ │ │ │ │ -00221 │ │ │ │ │ │ -/* │ │ │ │ │ │ -00222 │ │ │ │ │ │ -00223 │ │ │ │ │ │ -* if we have gone beyond the acceptable threshold of change, compute │ │ │ │ │ │ -00224 │ │ │ │ │ │ -* the cone momentum from particle list. in this version, we use the │ │ │ │ │ │ -00225 │ │ │ │ │ │ -* ’pincluded’ information from the CSphvicinity class, but we don’t │ │ │ │ │ │ -00226 │ │ │ │ │ │ -* change the member cone, only the locally supplied one │ │ │ │ │ │ -00227 │ │ │ │ │ │ -*/ │ │ │ │ │ │ -00228 │ │ │ │ │ │ -void recompute_cone_contents_if_needed(CSphmomentum & this_cone, double & this_dpt); │ │ │ │ │ │ -00229 │ │ │ │ │ │ -int proceed_with_stability(); │ │ │ │ │ │ -00235 │ │ │ │ │ │ -00236 │ │ │ │ │ │ -00237 │ │ │ │ │ │ -/* │ │ │ │ │ │ -00238 │ │ │ │ │ │ -* circle intersection. │ │ │ │ │ │ -00239 │ │ │ │ │ │ -* computes the intersection with a circle of given centre and radius. │ │ │ │ │ │ -00240 │ │ │ │ │ │ -* The output takes the form of a checkxor of the intersection’s particles │ │ │ │ │ │ -circle centre x coordinate │ │ │ │ │ │ -00241 │ │ │ │ │ │ -* - cx │ │ │ │ │ │ -00242 │ │ │ │ │ │ -circle centre y coordinate │ │ │ │ │ │ -* - cy │ │ │ │ │ │ -00243 │ │ │ │ │ │ -* return the checkxor for the intersection │ │ │ │ │ │ -00244 │ │ │ │ │ │ -******************************************************************/ │ │ │ │ │ │ -00245 │ │ │ │ │ │ -siscone::Creference circle_intersect(CSph3vector &cone_centre); │ │ │ │ │ │ -00246 │ │ │ │ │ │ -00248 │ │ │ │ │ │ -CSphmomentum cone_candidate; │ │ │ │ │ │ -00249 │ │ │ │ │ │ -00251 │ │ │ │ │ │ -std::vector child_list; │ │ │ │ │ │ -00252 │ │ │ │ │ │ -00255 │ │ │ │ │ │ -std::vector< std::pair > multiple_centre_done; │ │ │ │ │ │ -00256 │ │ │ │ │ │ -// information for updating cone contents to avoid rounding errors │ │ │ │ │ │ -00257 │ │ │ │ │ │ -00258 │ │ │ │ │ │ -double dpt; │ │ │ │ │ │ -00259 }; │ │ │ │ │ │ -00260 │ │ │ │ │ │ -00261 } │ │ │ │ │ │ -00262 #endif │ │ │ │ │ │ +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.45 split_merge.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ // │ │ │ │ │ │ 00002 // File: split_merge.cpp │ │ │ │ │ │ 00003 // Description: source file for splitting/merging (contains the CJet class) // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ @@ -23380,31 +23359,32 @@ │ │ │ │ │ │ 00039 namespace siscone_spherical{ │ │ │ │ │ │ 00040 │ │ │ │ │ │ 00041 using namespace std; │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 /******************************************************** │ │ │ │ │ │ 00044 * class CSphjet implementation │ │ │ │ │ │ * │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.45 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00045 * real Jet information. │ │ │ │ │ │ * │ │ │ │ │ │ 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 │ │ │ │ │ │ * │ │ │ │ │ │ 00050 ********************************************************/ │ │ │ │ │ │ 00051 // default ctor │ │ │ │ │ │ -00052 //-------------00053 CSphjet::CSphjet(){ │ │ │ │ │ │ +00052 //-------------- │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +00053 CSphjet::CSphjet(){ │ │ │ │ │ │ 00054 │ │ │ │ │ │ n = 0; │ │ │ │ │ │ 00055 │ │ │ │ │ │ v = CSphmomentum(); │ │ │ │ │ │ 00056 │ │ │ │ │ │ E_tilde = 0.0; │ │ │ │ │ │ 00057 │ │ │ │ │ │ @@ -23418,16 +23398,16 @@ │ │ │ │ │ │ 00062 // default dtor │ │ │ │ │ │ 00063 //-------------00064 CSphjet::~CSphjet(){ │ │ │ │ │ │ 00065 │ │ │ │ │ │ 00066 } │ │ │ │ │ │ 00067 │ │ │ │ │ │ 00068 // ordering of jets in E (e.g. used in final jets ordering) │ │ │ │ │ │ 00069 //---------------------------------------------------------00070 bool jets_E_less(const CSphjet &j1, const CSphjet &j2){ │ │ │ │ │ │ -00071 │ │ │ │ │ │ return j1.v.E > j2.v.E; │ │ │ │ │ │ +00071 │ │ │ │ │ │ 00072 } │ │ │ │ │ │ 00073 │ │ │ │ │ │ 00074 │ │ │ │ │ │ 00075 /******************************************************** │ │ │ │ │ │ 00076 * CSphsplit_merge_ptcomparison implementation │ │ │ │ │ │ * │ │ │ │ │ │ 00077 * This deals with the ordering of the jets candidates * │ │ │ │ │ │ @@ -23445,28 +23425,28 @@ │ │ │ │ │ │ 00089 // │ │ │ │ │ │ 00090 // NB: there is a potential issue in momentum-conserving events, │ │ │ │ │ │ 00091 // whereby the harder of two jets becomes ill-defined when a soft │ │ │ │ │ │ 00092 // particle is emitted --- this may have a knock-on effect on │ │ │ │ │ │ 00093 // subsequent split-merge steps in cases with sufficiently large R │ │ │ │ │ │ 00094 // (but we don’t know what the limit is...) │ │ │ │ │ │ 00095 //-----------------------------------------------------------------00096 bool CSphsplit_merge_ptcomparison::operator ()(const CSphjet &jet1, const CSphjet &jet2) const{ │ │ │ │ │ │ -00097 │ │ │ │ │ │ double q1, q2; │ │ │ │ │ │ +00097 │ │ │ │ │ │ 00098 │ │ │ │ │ │ // compute the value for comparison for both jets │ │ │ │ │ │ 00099 │ │ │ │ │ │ 00100 │ │ │ │ │ │ // This depends on the choice of variable (mt is the default) │ │ │ │ │ │ 00101 │ │ │ │ │ │ q1 = jet1.sm_var2; │ │ │ │ │ │ 00102 │ │ │ │ │ │ q2 = jet2.sm_var2; │ │ │ │ │ │ 00103 │ │ │ │ │ │ -00104 │ │ │ │ │ │ bool res = q1 > q2; │ │ │ │ │ │ +00104 │ │ │ │ │ │ 00105 │ │ │ │ │ │ // if we enable the refined version of the comparison (see defines.h), │ │ │ │ │ │ 00106 │ │ │ │ │ │ 00107 │ │ │ │ │ │ // we compute the difference more precisely when the two jets are very │ │ │ │ │ │ 00108 │ │ │ │ │ │ // close in the ordering variable. │ │ │ │ │ │ @@ -23479,89 +23459,89 @@ │ │ │ │ │ │ 00113 │ │ │ │ │ │ cout « "Using high-precision ordering tests" « endl; │ │ │ │ │ │ 00114 #endif │ │ │ │ │ │ 00115 │ │ │ │ │ │ // get the momentum of the difference │ │ │ │ │ │ 00116 │ │ │ │ │ │ CSphmomentum difference; │ │ │ │ │ │ -double E_tilde_difference; │ │ │ │ │ │ 00117 │ │ │ │ │ │ +double E_tilde_difference; │ │ │ │ │ │ 00118 │ │ │ │ │ │ get_difference(jet1,jet2,&difference,&E_tilde_difference); │ │ │ │ │ │ 00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ // use the following relation: pt1^2 - pt2^2 = (pt1+pt2)*(pt1-pt2) │ │ │ │ │ │ 00121 │ │ │ │ │ │ double qdiff; │ │ │ │ │ │ 00122 │ │ │ │ │ │ CSphmomentum sum = jet1.v ; │ │ │ │ │ │ 00123 │ │ │ │ │ │ sum += jet2.v; │ │ │ │ │ │ -double E_tilde_sum = jet1.E_tilde + jet2.E_tilde; │ │ │ │ │ │ 00124 │ │ │ │ │ │ +double E_tilde_sum = jet1.E_tilde + jet2.E_tilde; │ │ │ │ │ │ 00125 │ │ │ │ │ │ -00126 │ │ │ │ │ │ // depending on the choice of ordering variable, set the result │ │ │ │ │ │ +00126 │ │ │ │ │ │ 00127 │ │ │ │ │ │ switch (split_merge_scale){ │ │ │ │ │ │ -00128 │ │ │ │ │ │ case SM_Etilde: │ │ │ │ │ │ +00128 │ │ │ │ │ │ 00129 │ │ │ │ │ │ qdiff = E_tilde_sum*E_tilde_difference; │ │ │ │ │ │ break; │ │ │ │ │ │ 00130 │ │ │ │ │ │ 00131 │ │ │ │ │ │ case SM_E: │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -265 │ │ │ │ │ │ - │ │ │ │ │ │ - 266 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00132 │ │ │ │ │ │ qdiff = sum.E*difference.E; │ │ │ │ │ │ break; │ │ │ │ │ │ 00133 │ │ │ │ │ │ 00134 │ │ │ │ │ │ default: │ │ │ │ │ │ -00135 │ │ │ │ │ │ throw siscone::Csiscone_error("Unsupported split-merge scale choice: " │ │ │ │ │ │ +00135 │ │ │ │ │ │ 00136 │ │ │ │ │ │ + SM_scale_name()); │ │ │ │ │ │ 00137 │ │ │ │ │ │ } │ │ │ │ │ │ 00138 │ │ │ │ │ │ res = qdiff > 0; │ │ │ │ │ │ 00139 │ │ │ │ │ │ } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +265 │ │ │ │ │ │ + │ │ │ │ │ │ + 266 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00140 #endif // EPSILON_SPLITMERGE │ │ │ │ │ │ 00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ return res; │ │ │ │ │ │ 00143 } │ │ │ │ │ │ 00144 │ │ │ │ │ │ 00145 │ │ │ │ │ │ 00148 std::string split_merge_scale_name(Esplit_merge_scale sms) { │ │ │ │ │ │ 00149 │ │ │ │ │ │ switch(sms) { │ │ │ │ │ │ case SM_E: │ │ │ │ │ │ 00150 │ │ │ │ │ │ 00151 │ │ │ │ │ │ return "E (IR unsafe for pairs of identical decayed heavy particles)"; │ │ │ │ │ │ -case SM_Etilde: │ │ │ │ │ │ 00152 │ │ │ │ │ │ -00153 │ │ │ │ │ │ +case SM_Etilde: │ │ │ │ │ │ return "Etilde (sum of E.[1+sin^2(theta_{i,jet})])"; │ │ │ │ │ │ -default: │ │ │ │ │ │ +00153 │ │ │ │ │ │ 00154 │ │ │ │ │ │ -00155 │ │ │ │ │ │ +default: │ │ │ │ │ │ return "[SM scale without a name]"; │ │ │ │ │ │ +00155 │ │ │ │ │ │ 00156 │ │ │ │ │ │ } │ │ │ │ │ │ 00157 } │ │ │ │ │ │ 00158 │ │ │ │ │ │ 00159 │ │ │ │ │ │ 00160 // get the difference between 2 jets │ │ │ │ │ │ 00161 // - j1 │ │ │ │ │ │ @@ -23575,16 +23555,16 @@ │ │ │ │ │ │ 00165 // return true if overlapping, false if disjoint │ │ │ │ │ │ 00166 //----------------------------------------------00167 void CSphsplit_merge_ptcomparison::get_difference(const CSphjet &j1, const CSphjet &j2, │ │ │ │ │ │ 00168 │ │ │ │ │ │ CSphmomentum *v, double *E_tilde) const { │ │ │ │ │ │ int i1,i2; │ │ │ │ │ │ 00169 │ │ │ │ │ │ 00170 │ │ │ │ │ │ -// initialise │ │ │ │ │ │ 00171 │ │ │ │ │ │ +// initialise │ │ │ │ │ │ 00172 │ │ │ │ │ │ i1=i2=0; │ │ │ │ │ │ 00173 │ │ │ │ │ │ *v = CSphmomentum(); │ │ │ │ │ │ 00174 │ │ │ │ │ │ *E_tilde = 0.0; │ │ │ │ │ │ 00175 │ │ │ │ │ │ @@ -23597,26 +23577,26 @@ │ │ │ │ │ │ 00179 │ │ │ │ │ │ CSph3vector jet2_axis = j2.v; │ │ │ │ │ │ //jet2_axis /= j2.v._norm; │ │ │ │ │ │ 00180 │ │ │ │ │ │ 00181 │ │ │ │ │ │ jet2_axis /= j2.v.E; │ │ │ │ │ │ 00182 │ │ │ │ │ │ -// compute overlap │ │ │ │ │ │ 00183 │ │ │ │ │ │ +// compute overlap │ │ │ │ │ │ 00184 │ │ │ │ │ │ // at the same time, we store union in indices │ │ │ │ │ │ 00185 │ │ │ │ │ │ // note tat for Etilde, we’ll add the direct energy contributino at the end │ │ │ │ │ │ 00186 │ │ │ │ │ │ do{ │ │ │ │ │ │ -if (j1.contents[i1]==j2.contents[i2]) { │ │ │ │ │ │ 00187 │ │ │ │ │ │ -00188 │ │ │ │ │ │ +if (j1.contents[i1]==j2.contents[i2]) { │ │ │ │ │ │ const CSphmomentum & p = (*particles)[j1.contents[i1]]; │ │ │ │ │ │ +00188 │ │ │ │ │ │ 00189 │ │ │ │ │ │ (*E_tilde) += │ │ │ │ │ │ p.E*((norm2_cross_product3(p,jet1_axis)-norm2_cross_product3(p,jet2_axis))/(*particles_norm2)[j1.contents[i1]]); │ │ │ │ │ │ 00190 │ │ │ │ │ │ i1++; │ │ │ │ │ │ 00191 │ │ │ │ │ │ i2++; │ │ │ │ │ │ @@ -23628,73 +23608,73 @@ │ │ │ │ │ │ (*v) += p; │ │ │ │ │ │ 00195 │ │ │ │ │ │ (*E_tilde) += p.E*norm2_cross_product3(p,jet1_axis)/(*particles_norm2)[j1.contents[i1]]; │ │ │ │ │ │ 00196 │ │ │ │ │ │ i1++; │ │ │ │ │ │ 00197 │ │ │ │ │ │ } else if (j1.contents[i1]>j2.contents[i2]){ │ │ │ │ │ │ -const CSphmomentum &p = (*particles)[j2.contents[i2]]; │ │ │ │ │ │ 00198 │ │ │ │ │ │ +const CSphmomentum &p = (*particles)[j2.contents[i2]]; │ │ │ │ │ │ 00199 │ │ │ │ │ │ (*v) -= p; │ │ │ │ │ │ 00200 │ │ │ │ │ │ (*E_tilde) -= p.E*norm2_cross_product3(p,jet2_axis)/(*particles_norm2)[j2.contents[i2]]; │ │ │ │ │ │ 00201 │ │ │ │ │ │ i2++; │ │ │ │ │ │ 00202 │ │ │ │ │ │ } else { │ │ │ │ │ │ -throw siscone::Csiscone_error("get_non_overlap reached part it should never have seen..."); │ │ │ │ │ │ 00203 │ │ │ │ │ │ +throw siscone::Csiscone_error("get_non_overlap reached part it should never have seen..."); │ │ │ │ │ │ 00204 │ │ │ │ │ │ } │ │ │ │ │ │ 00205 │ │ │ │ │ │ } while ((i1E; │ │ │ │ │ │ 00223 } │ │ │ │ │ │ 00224 │ │ │ │ │ │ 00225 │ │ │ │ │ │ 00226 /******************************************************** │ │ │ │ │ │ 00227 * class CSphsplit_merge implementation │ │ │ │ │ │ * │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00228 * Class used to split and merge jets. │ │ │ │ │ │ * │ │ │ │ │ │ 00229 ********************************************************/ │ │ │ │ │ │ 00230 // default ctor │ │ │ │ │ │ 00231 //-------------00232 CSphsplit_merge::CSphsplit_merge(){ │ │ │ │ │ │ 00233 │ │ │ │ │ │ merge_identical_protocones = false; │ │ │ │ │ │ @@ -23719,16 +23699,16 @@ │ │ │ │ │ │ candidates.reset(new multiset(ptcomparison)); │ │ │ │ │ │ 00246 │ │ │ │ │ │ // no hardest cut (col-unsafe) │ │ │ │ │ │ 00247 │ │ │ │ │ │ 00248 │ │ │ │ │ │ SM_var2_hardest_cut_off = -numeric_limits::max(); │ │ │ │ │ │ 00249 │ │ │ │ │ │ -// no energy cutoff for the particles to put in p_uncol_hard │ │ │ │ │ │ 00250 │ │ │ │ │ │ +// no energy cutoff for the particles to put in p_uncol_hard │ │ │ │ │ │ 00251 │ │ │ │ │ │ stable_cone_soft_E2_cutoff = -1.0; │ │ │ │ │ │ 00252 │ │ │ │ │ │ // no pt-weighted splitting │ │ │ │ │ │ 00253 │ │ │ │ │ │ 00254 │ │ │ │ │ │ use_E_weighted_splitting = false; │ │ │ │ │ │ @@ -23747,16 +23727,16 @@ │ │ │ │ │ │ 00267 // - protocones list of protocones (initial jet candidates) │ │ │ │ │ │ 00268 // - R2 │ │ │ │ │ │ cone radius (squared) │ │ │ │ │ │ 00269 // - Emin │ │ │ │ │ │ minimal energy allowed for jets │ │ │ │ │ │ 00270 //------------------------------------------------------------00271 int CSphsplit_merge::init(vector & /*_particles*/, vector *protocones, │ │ │ │ │ │ double R2, double Emin){ │ │ │ │ │ │ -// browse protocones │ │ │ │ │ │ 00272 │ │ │ │ │ │ +// browse protocones │ │ │ │ │ │ 00273 │ │ │ │ │ │ return add_protocones(protocones, R2, Emin); │ │ │ │ │ │ 00274 } │ │ │ │ │ │ 00275 │ │ │ │ │ │ 00276 │ │ │ │ │ │ 00277 // initialisation function for particle list │ │ │ │ │ │ 00278 // - _particles list of particles │ │ │ │ │ │ @@ -23771,62 +23751,62 @@ │ │ │ │ │ │ 00285 │ │ │ │ │ │ // with infinite rapidity (colinear with the beam) │ │ │ │ │ │ 00286 │ │ │ │ │ │ particles = _particles; │ │ │ │ │ │ 00287 │ │ │ │ │ │ n = particles.size(); │ │ │ │ │ │ 00288 │ │ │ │ │ │ -// store the particle norm^2 │ │ │ │ │ │ 00289 │ │ │ │ │ │ +// store the particle norm^2 │ │ │ │ │ │ 00290 │ │ │ │ │ │ particles_norm2.resize(n); │ │ │ │ │ │ -for (int i=0;i(ptcomparison)); │ │ │ │ │ │ 00368 │ │ │ │ │ │ -// start off with huge number │ │ │ │ │ │ 00369 │ │ │ │ │ │ +// start off with huge number │ │ │ │ │ │ 00370 │ │ │ │ │ │ most_ambiguous_split = numeric_limits::max(); │ │ │ │ │ │ 00371 │ │ │ │ │ │ 00372 │ │ │ │ │ │ jets.clear(); │ │ │ │ │ │ 00373 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 00374 │ │ │ │ │ │ @@ -23952,186 +23932,186 @@ │ │ │ │ │ │ // clear previously allocated memory │ │ │ │ │ │ 00390 │ │ │ │ │ │ if (indices != NULL){ │ │ │ │ │ │ delete[] indices; │ │ │ │ │ │ 00391 │ │ │ │ │ │ 00392 │ │ │ │ │ │ } │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.45 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -269 │ │ │ │ │ │ - │ │ │ │ │ │ 00393 │ │ │ │ │ │ particles.clear(); │ │ │ │ │ │ 00394 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ 00395 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ 00396 } │ │ │ │ │ │ 00397 │ │ │ │ │ │ 00398 │ │ │ │ │ │ 00399 // build the list ’p_uncol_hard’ from p_remain by clustering collinear particles │ │ │ │ │ │ 00400 // note that thins in only used for stable-cone detection │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +269 │ │ │ │ │ │ + │ │ │ │ │ │ 00401 // so the parent_index field is unnecessary │ │ │ │ │ │ 00402 //------------------------------------------------------------------------00403 int CSphsplit_merge::merge_collinear_and_remove_soft(){ │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ 00404 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ 00405 │ │ │ │ │ │ vector p_sorted; │ │ │ │ │ │ bool collinear; │ │ │ │ │ │ 00406 │ │ │ │ │ │ -00407 │ │ │ │ │ │ double dphi; │ │ │ │ │ │ +00407 │ │ │ │ │ │ 00408 │ │ │ │ │ │ 00409 │ │ │ │ │ │ p_uncol_hard.clear(); │ │ │ │ │ │ 00410 │ │ │ │ │ │ -// we first sort the particles according to their theta angle │ │ │ │ │ │ 00411 │ │ │ │ │ │ +// we first sort the particles according to their theta angle │ │ │ │ │ │ 00412 │ │ │ │ │ │ for (i=0;iM_PI) dphi = twopi-dphi; │ │ │ │ │ │ -if (dphi *protocones, double R2, double Emin){ │ │ │ │ │ │ -00463 │ │ │ │ │ │ int i; │ │ │ │ │ │ +00463 │ │ │ │ │ │ 00464 │ │ │ │ │ │ CSphmomentum *c; │ │ │ │ │ │ 00465 │ │ │ │ │ │ CSphmomentum *v; │ │ │ │ │ │ 00466 │ │ │ │ │ │ double tan2R; │ │ │ │ │ │ 00467 │ │ │ │ │ │ CSphjet jet; │ │ │ │ │ │ 00468 │ │ │ │ │ │ -if (protocones->size()==0) │ │ │ │ │ │ 00469 │ │ │ │ │ │ -00470 │ │ │ │ │ │ +if (protocones->size()==0) │ │ │ │ │ │ return 1; │ │ │ │ │ │ +00470 │ │ │ │ │ │ 00471 │ │ │ │ │ │ 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: "; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 270 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00479 │ │ │ │ │ │ for (int i2=0;i2::iterator p_it = protocones->begin();p_it != protocones->end();p_it++){ │ │ │ │ │ │ 00489 │ │ │ │ │ │ // initialise variables │ │ │ │ │ │ 00490 │ │ │ │ │ │ @@ -24160,16 +24140,16 @@ │ │ │ │ │ │ 00502 │ │ │ │ │ │ } │ │ │ │ │ │ 00503 │ │ │ │ │ │ } │ │ │ │ │ │ 00504 │ │ │ │ │ │ jet.n=jet.contents.size(); │ │ │ │ │ │ 00505 │ │ │ │ │ │ -00506 │ │ │ │ │ │ // compute Etilde for that jet. │ │ │ │ │ │ +00506 │ │ │ │ │ │ 00507 │ │ │ │ │ │ // we can’t do that before as it requires knowledge of the jet axis │ │ │ │ │ │ 00508 │ │ │ │ │ │ // which has just been computed. │ │ │ │ │ │ 00509 │ │ │ │ │ │ compute_Etilde(jet); │ │ │ │ │ │ 00510 │ │ │ │ │ │ @@ -24178,33 +24158,33 @@ │ │ │ │ │ │ 00512 │ │ │ │ │ │ // (it was only known through its spatial coordinates up to now) │ │ │ │ │ │ 00513 │ │ │ │ │ │ *c = jet.v; │ │ │ │ │ │ 00514 │ │ │ │ │ │ c->build_thetaphi(); │ │ │ │ │ │ 00515 │ │ │ │ │ │ -// set the jet range │ │ │ │ │ │ 00516 │ │ │ │ │ │ +// set the jet range │ │ │ │ │ │ 00517 │ │ │ │ │ │ jet.range=CSphtheta_phi_range(c->_theta,c->_phi,R); │ │ │ │ │ │ 00518 │ │ │ │ │ │ 00519 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00520 │ │ │ │ │ │ cout « "adding protojet: "; │ │ │ │ │ │ 00521 │ │ │ │ │ │ unsigned int phirange=jet.range.phi_range; │ │ │ │ │ │ 00522 │ │ │ │ │ │ -for (unsigned int i2=0;i2<32;i2++) fprintf(stdout, "%d", (phirange&(1«i2)) » i2 ); │ │ │ │ │ │ 00523 │ │ │ │ │ │ +for (unsigned int i2=0;i2<32;i2++) fprintf(stdout, "%d", (phirange&(1«i2)) » i2 ); │ │ │ │ │ │ 00524 │ │ │ │ │ │ fprintf(stdout, "\t"); │ │ │ │ │ │ -unsigned int thetarange=jet.range.theta_range; │ │ │ │ │ │ 00525 │ │ │ │ │ │ -00526 │ │ │ │ │ │ +unsigned int thetarange=jet.range.theta_range; │ │ │ │ │ │ for (unsigned int i2=0;i2<32;i2++) fprintf(stdout, "%d", (thetarange&(1«i2)) » i2); │ │ │ │ │ │ +00526 │ │ │ │ │ │ 00527 │ │ │ │ │ │ fprintf(stdout, "\t"); │ │ │ │ │ │ 00528 │ │ │ │ │ │ for (int i2=0;i2size()==0) │ │ │ │ │ │ 00589 │ │ │ │ │ │ -return 1; │ │ │ │ │ │ 00590 │ │ │ │ │ │ +return 1; │ │ │ │ │ │ 00591 │ │ │ │ │ │ 00592 │ │ │ │ │ │ E_min = Emin; │ │ │ │ │ │ 00593 │ │ │ │ │ │ R = sqrt(R2); │ │ │ │ │ │ 00594 │ │ │ │ │ │ tan2R = tan(R); │ │ │ │ │ │ @@ -24336,16 +24316,16 @@ │ │ │ │ │ │ 00603 │ │ │ │ │ │ 00604 │ │ │ │ │ │ // note that jet is always initialised with default values at this level │ │ │ │ │ │ 00605 │ │ │ │ │ │ jet_candidate.v = CSphmomentum(); │ │ │ │ │ │ 00606 │ │ │ │ │ │ jet_candidate.contents.clear(); │ │ │ │ │ │ -for (i=0;iparent_index); │ │ │ │ │ │ 00611 │ │ │ │ │ │ @@ -24389,16 +24369,16 @@ │ │ │ │ │ │ 00632 │ │ │ │ │ │ continue; │ │ │ │ │ │ 00633 │ │ │ │ │ │ // assign the split-merge (or progressive-removal) squared scale variable │ │ │ │ │ │ 00634 │ │ │ │ │ │ 00635 │ │ │ │ │ │ if (_user_scale) { │ │ │ │ │ │ -00636 │ │ │ │ │ │ // sm_var2 is the signed square of the user scale returned │ │ │ │ │ │ +00636 │ │ │ │ │ │ 00637 │ │ │ │ │ │ // for the jet candidate │ │ │ │ │ │ 00638 │ │ │ │ │ │ jet_candidate.sm_var2 = (*_user_scale)(jet_candidate); │ │ │ │ │ │ 00639 │ │ │ │ │ │ jet_candidate.sm_var2 *= abs(jet_candidate.sm_var2); │ │ │ │ │ │ 00640 │ │ │ │ │ │ @@ -24420,53 +24400,53 @@ │ │ │ │ │ │ jet = jet_candidate; │ │ │ │ │ │ 00649 │ │ │ │ │ │ found_jet = true; │ │ │ │ │ │ 00650 │ │ │ │ │ │ } │ │ │ │ │ │ 00651 │ │ │ │ │ │ } │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 272 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00652 │ │ │ │ │ │ // make sure at least one of the jets has passed the selection │ │ │ │ │ │ 00653 │ │ │ │ │ │ 00654 │ │ │ │ │ │ if (!found_jet) return 1; │ │ │ │ │ │ 00655 │ │ │ │ │ │ // add the jet to the list of jets │ │ │ │ │ │ 00656 │ │ │ │ │ │ 00657 │ │ │ │ │ │ jets.push_back(jet); │ │ │ │ │ │ 00658 │ │ │ │ │ │ jets[jets.size()-1].v.build_thetaphi(); │ │ │ │ │ │ 00659 │ │ │ │ │ │ jets[jets.size()-1].v.build_norm(); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 272 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00660 │ │ │ │ │ │ 00661 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00662 │ │ │ │ │ │ cout « "PR-Jet " « jets.size() « " [size " « jet.contents.size() « "]:"; │ │ │ │ │ │ 00663 #endif │ │ │ │ │ │ 00664 │ │ │ │ │ │ -// update the list of what particles are left │ │ │ │ │ │ 00665 │ │ │ │ │ │ +// update the list of what particles are left │ │ │ │ │ │ 00666 │ │ │ │ │ │ int p_remain_index = 0; │ │ │ │ │ │ 00667 │ │ │ │ │ │ int contents_index = 0; │ │ │ │ │ │ //sort(next_jet.contents.begin(),next_jet.contents.end()); │ │ │ │ │ │ 00668 │ │ │ │ │ │ 00669 │ │ │ │ │ │ for (int index=0;indexsize()==0) │ │ │ │ │ │ -00723 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00723 │ │ │ │ │ │ 00724 │ │ │ │ │ │ if (overlap_tshold>=1.0 || overlap_tshold <= 0) { │ │ │ │ │ │ 00725 │ │ │ │ │ │ 00726 │ │ │ │ │ │ ostringstream message; │ │ │ │ │ │ 00727 │ │ │ │ │ │ message « "Illegal value for overlap_tshold, f = " « overlap_tshold; │ │ │ │ │ │ 00728 │ │ │ │ │ │ message « " (legal values are 0size()>0){ │ │ │ │ │ │ -00742 │ │ │ │ │ │ // browse for the first jet │ │ │ │ │ │ +00742 │ │ │ │ │ │ 00743 │ │ │ │ │ │ j1 = candidates->begin(); │ │ │ │ │ │ 00744 │ │ │ │ │ │ // if hardest jet does not pass threshold then nothing else will │ │ │ │ │ │ 00745 │ │ │ │ │ │ 00746 │ │ │ │ │ │ // either so one stops the split merge. │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00747 │ │ │ │ │ │ //if (j1->sm_var2sm_var2v.E « endl«endl; │ │ │ │ │ │ @@ -24640,16 +24620,16 @@ │ │ │ │ │ │ cout « " --> split" « endl«endl; │ │ │ │ │ │ 00772 #endif │ │ │ │ │ │ 00773 │ │ │ │ │ │ // split jets │ │ │ │ │ │ 00774 │ │ │ │ │ │ split(j1, j2); │ │ │ │ │ │ 00775 │ │ │ │ │ │ -// update iterators │ │ │ │ │ │ 00776 │ │ │ │ │ │ +// update iterators │ │ │ │ │ │ 00777 │ │ │ │ │ │ j2 = j1 = candidates->begin(); │ │ │ │ │ │ 00778 │ │ │ │ │ │ j2_relindex = 0; │ │ │ │ │ │ 00779 │ │ │ │ │ │ } else { │ │ │ │ │ │ 00780 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ @@ -24677,16 +24657,16 @@ │ │ │ │ │ │ // Emin to disappear, so the total number of jets may │ │ │ │ │ │ 00793 │ │ │ │ │ │ // have changed by more than expected and j2 might already by │ │ │ │ │ │ 00794 │ │ │ │ │ │ // the end of the candidates list... │ │ │ │ │ │ 00795 │ │ │ │ │ │ j2_relindex++; │ │ │ │ │ │ -00796 │ │ │ │ │ │ if (j2 != candidates->end()) j2++; │ │ │ │ │ │ +00796 │ │ │ │ │ │ 00797 │ │ │ │ │ │ } // end of loop on the second jet │ │ │ │ │ │ 00798 │ │ │ │ │ │ 00799 │ │ │ │ │ │ if (j1 != candidates->end()) { │ │ │ │ │ │ // all "second jet" passed without overlapping │ │ │ │ │ │ 00800 │ │ │ │ │ │ @@ -24729,75 +24709,75 @@ │ │ │ │ │ │ 00821 │ │ │ │ │ │ show(); │ │ │ │ │ │ 00822 #endif │ │ │ │ │ │ 00823 │ │ │ │ │ │ return jets.size(); │ │ │ │ │ │ 00824 │ │ │ │ │ │ 00825 } │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -273 │ │ │ │ │ │ - │ │ │ │ │ │ - 274 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00826 │ │ │ │ │ │ 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 │ │ │ │ │ │ jet_iterator it_j; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +273 │ │ │ │ │ │ + │ │ │ │ │ │ + 274 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00834 │ │ │ │ │ │ CSphjet *j1; │ │ │ │ │ │ -00835 │ │ │ │ │ │ int i1, i2; │ │ │ │ │ │ +00835 │ │ │ │ │ │ 00836 │ │ │ │ │ │ 00837 │ │ │ │ │ │ fprintf(flux, "# %d jets found\n", (int) jets.size()); │ │ │ │ │ │ 00838 │ │ │ │ │ │ fprintf(flux, "# columns are: px, py, pz, E and number of particles for each jet\n"); │ │ │ │ │ │ -for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00839 │ │ │ │ │ │ +for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00840 │ │ │ │ │ │ j1 = &(*it_j); │ │ │ │ │ │ 00841 │ │ │ │ │ │ fprintf(flux, "%e\t%e\t%e\t%e\t%d\n", │ │ │ │ │ │ 00842 │ │ │ │ │ │ j1->v.px, j1->v.py, j1->v.pz, j1->v.E, j1->n); │ │ │ │ │ │ 00843 │ │ │ │ │ │ } │ │ │ │ │ │ 00844 │ │ │ │ │ │ 00845 │ │ │ │ │ │ fprintf(flux, "# jet contents\n"); │ │ │ │ │ │ 00846 │ │ │ │ │ │ fprintf(flux, "# columns are: px, py, pz, E, particle index and jet number\n"); │ │ │ │ │ │ -00847 │ │ │ │ │ │ for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ +00847 │ │ │ │ │ │ 00848 │ │ │ │ │ │ j1 = &(*it_j); │ │ │ │ │ │ -for (i2=0;i2n;i2++) │ │ │ │ │ │ 00849 │ │ │ │ │ │ +for (i2=0;i2n;i2++) │ │ │ │ │ │ 00850 │ │ │ │ │ │ fprintf(flux, "%e\t%e\t%e\t%e\t%d\t%d\n", │ │ │ │ │ │ 00851 │ │ │ │ │ │ particles[j1->contents[i2]].px, particles[j1->contents[i2]].py, │ │ │ │ │ │ 00852 │ │ │ │ │ │ particles[j1->contents[i2]].pz, particles[j1->contents[i2]].E, │ │ │ │ │ │ 00853 │ │ │ │ │ │ j1->contents[i2], i1); │ │ │ │ │ │ 00854 │ │ │ │ │ │ } │ │ │ │ │ │ 00855 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ 00856 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ 00857 } │ │ │ │ │ │ 00858 │ │ │ │ │ │ 00859 │ │ │ │ │ │ 00860 // show current jets/candidate status │ │ │ │ │ │ 00861 //-----------------------------------00862 int CSphsplit_merge::show(){ │ │ │ │ │ │ 00863 │ │ │ │ │ │ jet_iterator it_j; │ │ │ │ │ │ @@ -24817,108 +24797,108 @@ │ │ │ │ │ │ 00871 │ │ │ │ │ │ fprintf(stdout, "jet %2d: %e\t%e\t%e\t%e\t", i1+1, │ │ │ │ │ │ 00872 │ │ │ │ │ │ j->v.px, j->v.py, j->v.pz, j->v.E); │ │ │ │ │ │ 00873 │ │ │ │ │ │ 00874 │ │ │ │ │ │ unsigned int phirange=j->range.phi_range; │ │ │ │ │ │ -for (i2=0;i2<32;i2++) fprintf(stdout, "%d", (phirange&(1«i2)) » i2 ); │ │ │ │ │ │ 00875 │ │ │ │ │ │ +for (i2=0;i2<32;i2++) fprintf(stdout, "%d", (phirange&(1«i2)) » i2 ); │ │ │ │ │ │ 00876 │ │ │ │ │ │ fprintf(stdout, "\t"); │ │ │ │ │ │ -unsigned int thetarange=j->range.theta_range; │ │ │ │ │ │ 00877 │ │ │ │ │ │ -00878 │ │ │ │ │ │ +unsigned int thetarange=j->range.theta_range; │ │ │ │ │ │ for (i2=0;i2<32;i2++) fprintf(stdout, "%d", (thetarange&(1«i2)) » i2); │ │ │ │ │ │ +00878 │ │ │ │ │ │ 00879 │ │ │ │ │ │ fprintf(stdout, "\t"); │ │ │ │ │ │ 00880 │ │ │ │ │ │ -00881 │ │ │ │ │ │ for (i2=0;i2n;i2++) │ │ │ │ │ │ +00881 │ │ │ │ │ │ 00882 │ │ │ │ │ │ fprintf(stdout, "%d ", j->contents[i2]); │ │ │ │ │ │ 00883 │ │ │ │ │ │ fprintf(stdout, "\n"); │ │ │ │ │ │ 00884 │ │ │ │ │ │ } │ │ │ │ │ │ 00885 │ │ │ │ │ │ -00886 │ │ │ │ │ │ for (it_c = candidates->begin(), i1=0 ; it_c != candidates->end() ; it_c++, i1++){ │ │ │ │ │ │ +00886 │ │ │ │ │ │ 00887 │ │ │ │ │ │ c = &(*it_c); │ │ │ │ │ │ 00888 │ │ │ │ │ │ fprintf(stdout, "cdt %2d: %e\t%e\t%e\t%e\t%e\t", i1+1, │ │ │ │ │ │ 00889 │ │ │ │ │ │ c->v.px, c->v.py, c->v.pz, c->v.E, sqrt(c->sm_var2)); │ │ │ │ │ │ 00890 │ │ │ │ │ │ -unsigned int phirange=c->range.phi_range; │ │ │ │ │ │ 00891 │ │ │ │ │ │ -00892 │ │ │ │ │ │ +unsigned int phirange=c->range.phi_range; │ │ │ │ │ │ for (i2=0;i2<32;i2++) fprintf(stdout, "%d", (phirange&(1«i2)) » i2 ); │ │ │ │ │ │ +00892 │ │ │ │ │ │ 00893 │ │ │ │ │ │ fprintf(stdout, "\t"); │ │ │ │ │ │ -unsigned int thetarange=c->range.theta_range; │ │ │ │ │ │ 00894 │ │ │ │ │ │ -00895 │ │ │ │ │ │ +unsigned int thetarange=c->range.theta_range; │ │ │ │ │ │ for (i2=0;i2<32;i2++) fprintf(stdout, "%d", (thetarange&(1«i2)) » i2); │ │ │ │ │ │ +00895 │ │ │ │ │ │ 00896 │ │ │ │ │ │ fprintf(stdout, "\t"); │ │ │ │ │ │ 00897 │ │ │ │ │ │ for (i2=0;i2n;i2++) │ │ │ │ │ │ 00898 │ │ │ │ │ │ 00899 │ │ │ │ │ │ fprintf(stdout, "%d ", c->contents[i2]); │ │ │ │ │ │ 00900 │ │ │ │ │ │ fprintf(stdout, "\n"); │ │ │ │ │ │ 00901 │ │ │ │ │ │ } │ │ │ │ │ │ 00902 │ │ │ │ │ │ 00903 │ │ │ │ │ │ fprintf(stdout, "\n"); │ │ │ │ │ │ -00904 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00904 │ │ │ │ │ │ 00905 } │ │ │ │ │ │ 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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.45 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00913 //--------------------------------------------------------------------00914 bool CSphsplit_merge::get_overlap(const CSphjet &j1, const CSphjet &j2, double *overlap2){ │ │ │ │ │ │ -// check if ranges overlap │ │ │ │ │ │ 00915 │ │ │ │ │ │ +// check if ranges overlap │ │ │ │ │ │ 00916 │ │ │ │ │ │ if (!is_range_overlap(j1.range,j2.range)) │ │ │ │ │ │ -return false; │ │ │ │ │ │ 00917 │ │ │ │ │ │ +return false; │ │ │ │ │ │ 00918 │ │ │ │ │ │ int i1,i2; │ │ │ │ │ │ 00919 │ │ │ │ │ │ 00920 │ │ │ │ │ │ bool is_overlap; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00921 │ │ │ │ │ │ // initialise │ │ │ │ │ │ 00922 │ │ │ │ │ │ 00923 │ │ │ │ │ │ i1=i2=idx_size=0; │ │ │ │ │ │ 00924 │ │ │ │ │ │ is_overlap = false; │ │ │ │ │ │ 00925 │ │ │ │ │ │ CSphmomentum v; │ │ │ │ │ │ 00926 │ │ │ │ │ │ -00927 │ │ │ │ │ │ // compute overlap │ │ │ │ │ │ +00927 │ │ │ │ │ │ 00928 │ │ │ │ │ │ // at the same time, we store union in indices │ │ │ │ │ │ 00929 │ │ │ │ │ │ do{ │ │ │ │ │ │ 00930 │ │ │ │ │ │ if (j1.contents[i1]" all over the place │ │ │ │ │ │ 00986 │ │ │ │ │ │ @@ -25021,62 +25001,62 @@ │ │ │ │ │ │ const CSphjet & j2 = * it_j2; │ │ │ │ │ │ 00989 │ │ │ │ │ │ 00990 │ │ │ │ │ │ i1=i2=0; │ │ │ │ │ │ 00991 │ │ │ │ │ │ jet2.v = jet1.v = CSphmomentum(); │ │ │ │ │ │ 00992 │ │ │ │ │ │ -// compute centroids │ │ │ │ │ │ 00993 │ │ │ │ │ │ +// compute centroids │ │ │ │ │ │ 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 │ │ │ │ │ │ // This is stored in E{1,2}_weight │ │ │ │ │ │ 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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -275 │ │ │ │ │ │ - │ │ │ │ │ │ - 276 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -01001 │ │ │ │ │ │ // compute jet splitting │ │ │ │ │ │ +01001 │ │ │ │ │ │ 01002 │ │ │ │ │ │ do{ │ │ │ │ │ │ 01003 │ │ │ │ │ │ if (j1.contents[i1]_theta,v->_phi); │ │ │ │ │ │ 01011 │ │ │ │ │ │ } else if (j1.contents[i1]>j2.contents[i2]){ │ │ │ │ │ │ -// particle i2 belong only to jet 2 │ │ │ │ │ │ 01012 │ │ │ │ │ │ +// particle i2 belong only to jet 2 │ │ │ │ │ │ 01013 │ │ │ │ │ │ v = &(particles[j2.contents[i2]]); │ │ │ │ │ │ 01014 │ │ │ │ │ │ jet2.contents.push_back(j2.contents[i2]); │ │ │ │ │ │ 01015 │ │ │ │ │ │ jet2.v += *v; │ │ │ │ │ │ 01016 │ │ │ │ │ │ @@ -25088,31 +25068,31 @@ │ │ │ │ │ │ 01019 │ │ │ │ │ │ } else { // (j1.contents[i1]==j2.contents[i2]) │ │ │ │ │ │ 01020 │ │ │ │ │ │ // common particle, decide which is the closest centre │ │ │ │ │ │ 01021 │ │ │ │ │ │ v = &(particles[j1.contents[i1]]); │ │ │ │ │ │ 01022 │ │ │ │ │ │ -01023 │ │ │ │ │ │ //TODO: improve this brutal use of atan2 and sqrt !!!! │ │ │ │ │ │ +01023 │ │ │ │ │ │ 01024 │ │ │ │ │ │ -01025 │ │ │ │ │ │ //? what when == ? │ │ │ │ │ │ +01025 │ │ │ │ │ │ 01026 │ │ │ │ │ │ // When use_E_weighted_splitting is activated, the │ │ │ │ │ │ 01027 │ │ │ │ │ │ // "geometrical" distance is weighted by the inverse │ │ │ │ │ │ 01028 │ │ │ │ │ │ // of the E of the protojet │ │ │ │ │ │ 01029 │ │ │ │ │ │ double d1 = get_distance(&(j1.v), v)*E1_weight; │ │ │ │ │ │ 01030 │ │ │ │ │ │ double d2 = get_distance(&(j2.v), v)*E2_weight; │ │ │ │ │ │ -// do bookkeeping on most ambiguous split │ │ │ │ │ │ 01031 │ │ │ │ │ │ +// do bookkeeping on most ambiguous split │ │ │ │ │ │ 01032 │ │ │ │ │ │ if (fabs(d1-d2) < most_ambiguous_split) │ │ │ │ │ │ 01033 │ │ │ │ │ │ most_ambiguous_split = fabs(d1-d2); │ │ │ │ │ │ 01034 │ │ │ │ │ │ 01035 │ │ │ │ │ │ if (d1_theta,v->_phi); │ │ │ │ │ │ 01061 │ │ │ │ │ │ } │ │ │ │ │ │ -01062 │ │ │ │ │ │ while (i2_theta,v->_phi); │ │ │ │ │ │ 01069 │ │ │ │ │ │ } │ │ │ │ │ │ 01070 │ │ │ │ │ │ @@ -25193,45 +25173,47 @@ │ │ │ │ │ │ 01075 │ │ │ │ │ │ // now the jet axis is known, we can compute Etilde │ │ │ │ │ │ 01076 │ │ │ │ │ │ compute_Etilde(jet1); │ │ │ │ │ │ 01077 │ │ │ │ │ │ compute_Etilde(jet2); │ │ │ │ │ │ 01078 │ │ │ │ │ │ -01079 │ │ │ │ │ │ // remove previous jets │ │ │ │ │ │ +01079 │ │ │ │ │ │ 01080 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 01081 │ │ │ │ │ │ cand_refs.erase(j1.v.ref); │ │ │ │ │ │ 01082 │ │ │ │ │ │ cand_refs.erase(j2.v.ref); │ │ │ │ │ │ 01083 #endif │ │ │ │ │ │ 01084 │ │ │ │ │ │ candidates->erase(it_j1); │ │ │ │ │ │ 01085 │ │ │ │ │ │ candidates->erase(it_j2); │ │ │ │ │ │ 01086 │ │ │ │ │ │ 01087 │ │ │ │ │ │ // reinsert new ones │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.45 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 01088 │ │ │ │ │ │ insert(jet1); │ │ │ │ │ │ 01089 │ │ │ │ │ │ insert(jet2); │ │ │ │ │ │ 01090 │ │ │ │ │ │ 01091 │ │ │ │ │ │ return true; │ │ │ │ │ │ 01092 } │ │ │ │ │ │ 01093 │ │ │ │ │ │ 01094 // merge the two given jet. │ │ │ │ │ │ 01095 // during this procedure, the jets j1 & j2 are replaced │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.45 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +277 │ │ │ │ │ │ + │ │ │ │ │ │ 01096 // by 1 single jets containing both of them. │ │ │ │ │ │ 01097 // - it_j1 iterator of the first jet in ’candidates’ │ │ │ │ │ │ 01098 // - it_j2 iterator of the second jet in ’candidates’ │ │ │ │ │ │ 01099 // return true on success, false on error │ │ │ │ │ │ 01101 bool CSphsplit_merge::merge(cjet_iterator &it_j1, cjet_iterator &it_j2){ │ │ │ │ │ │ 01102 │ │ │ │ │ │ CSphjet jet; │ │ │ │ │ │ @@ -25244,31 +25226,31 @@ │ │ │ │ │ │ // note: particles within j1 & j2 have already been stored in indices │ │ │ │ │ │ 01107 │ │ │ │ │ │ for (i=0;irange, it_j2->range); │ │ │ │ │ │ 01118 │ │ │ │ │ │ -// remove old candidates │ │ │ │ │ │ 01119 │ │ │ │ │ │ +// remove old candidates │ │ │ │ │ │ 01120 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 01121 │ │ │ │ │ │ if (merge_identical_protocones){ │ │ │ │ │ │ 01122 │ │ │ │ │ │ cand_refs.erase(it_j1->v.ref); │ │ │ │ │ │ 01123 │ │ │ │ │ │ cand_refs.erase(it_j2->v.ref); │ │ │ │ │ │ @@ -25276,128 +25258,126 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 01125 #endif │ │ │ │ │ │ 01126 │ │ │ │ │ │ candidates->erase(it_j1); │ │ │ │ │ │ 01127 │ │ │ │ │ │ candidates->erase(it_j2); │ │ │ │ │ │ 01128 │ │ │ │ │ │ -01129 │ │ │ │ │ │ // reinsert new candidate │ │ │ │ │ │ +01129 │ │ │ │ │ │ 01130 │ │ │ │ │ │ insert(jet); │ │ │ │ │ │ 01131 │ │ │ │ │ │ return true; │ │ │ │ │ │ 01132 │ │ │ │ │ │ 01133 } │ │ │ │ │ │ 01134 │ │ │ │ │ │ 01140 bool CSphsplit_merge::insert(CSphjet &jet){ │ │ │ │ │ │ 01141 │ │ │ │ │ │ -01142 │ │ │ │ │ │ // eventually check that no other candidate are present with the │ │ │ │ │ │ +01142 │ │ │ │ │ │ 01143 │ │ │ │ │ │ // same cone contents. We recall that this automatic merging of │ │ │ │ │ │ 01144 │ │ │ │ │ │ // identical protocones can lead to infrared-unsafe situations. │ │ │ │ │ │ 01145 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 01146 │ │ │ │ │ │ if ((merge_identical_protocones) && (!cand_refs.insert(jet.v.ref).second)) │ │ │ │ │ │ -return false; │ │ │ │ │ │ 01147 │ │ │ │ │ │ +return false; │ │ │ │ │ │ 01148 #endif │ │ │ │ │ │ 01149 │ │ │ │ │ │ -// check that the protojet has large enough energy │ │ │ │ │ │ 01150 │ │ │ │ │ │ +// check that the protojet has large enough energy │ │ │ │ │ │ 01151 │ │ │ │ │ │ if (jet.v.Einsert(jet); │ │ │ │ │ │ 01159 │ │ │ │ │ │ return true; │ │ │ │ │ │ 01160 │ │ │ │ │ │ 01161 } │ │ │ │ │ │ 01162 │ │ │ │ │ │ 01169 double CSphsplit_merge::get_sm_var2(CSphmomentum &v, double &E_tilde){ │ │ │ │ │ │ -switch(ptcomparison.split_merge_scale) { │ │ │ │ │ │ 01170 │ │ │ │ │ │ -01171 │ │ │ │ │ │ +switch(ptcomparison.split_merge_scale) { │ │ │ │ │ │ case SM_E: │ │ │ │ │ │ return v.E*v.E; │ │ │ │ │ │ -case SM_Etilde: return E_tilde*E_tilde; │ │ │ │ │ │ +01171 │ │ │ │ │ │ 01172 │ │ │ │ │ │ -01173 │ │ │ │ │ │ +case SM_Etilde: return E_tilde*E_tilde; │ │ │ │ │ │ default: │ │ │ │ │ │ +01173 │ │ │ │ │ │ 01174 │ │ │ │ │ │ throw siscone::Csiscone_error("Unsupported split-merge scale choice: " │ │ │ │ │ │ 01175 │ │ │ │ │ │ + ptcomparison.SM_scale_name()); │ │ │ │ │ │ 01176 │ │ │ │ │ │ } │ │ │ │ │ │ 01177 │ │ │ │ │ │ -01178 │ │ │ │ │ │ //return 0.0; │ │ │ │ │ │ +01178 │ │ │ │ │ │ 01179 } │ │ │ │ │ │ 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; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -277 │ │ │ │ │ │ - │ │ │ │ │ │ - 278 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -01188 │ │ │ │ │ │ //if (jet.v._norm==0){ │ │ │ │ │ │ +01188 │ │ │ │ │ │ 01189 │ │ │ │ │ │ // jet_axis = CSph3vector(0.0,0.0,0.0); │ │ │ │ │ │ 01190 │ │ │ │ │ │ //} else { │ │ │ │ │ │ 01191 │ │ │ │ │ │ jet_axis/=jet.v.E; │ │ │ │ │ │ -//} │ │ │ │ │ │ 01192 │ │ │ │ │ │ +//} │ │ │ │ │ │ 01193 │ │ │ │ │ │ //cout « "~~~ Axis: " « jet.v.px « " " « jet.v.py « " " « jet.v.pz « " " « jet.v._norm « endl; │ │ │ │ │ │ 01194 │ │ │ │ │ │ //cout « "~~~ Axis: " « jet_axis.px « " " « jet_axis.py « " " « jet_axis.pz « endl; │ │ │ │ │ │ 01195 │ │ │ │ │ │ for (vector::iterator cont_it=jet.contents.begin(); cont_it!=jet.contents.end(); cont_it++){ │ │ │ │ │ │ -const CSphmomentum &p = particles[*cont_it]; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 278 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 01196 │ │ │ │ │ │ +const CSphmomentum &p = particles[*cont_it]; │ │ │ │ │ │ 01197 │ │ │ │ │ │ jet.E_tilde+=p.E*(1.0+norm2_cross_product3(p,jet_axis)/particles_norm2[*cont_it]); │ │ │ │ │ │ 01198 │ │ │ │ │ │ } │ │ │ │ │ │ 01199 } │ │ │ │ │ │ 01200 │ │ │ │ │ │ 01201 } │ │ │ │ │ │ │ │ │ │ │ │ 5.46 split_merge.cpp │ │ │ │ │ │ 00001 │ │ │ │ │ │ -00002 // File: split_merge.cpp │ │ │ │ │ │ // │ │ │ │ │ │ +00002 // File: split_merge.cpp │ │ │ │ │ │ 00003 // Description: source file for splitting/merging (contains the CJet class) // │ │ │ │ │ │ 00004 // This file is part of the SISCone project. │ │ │ │ │ │ // │ │ │ │ │ │ 00005 // For more details, see http://projects.hepforge.org/siscone │ │ │ │ │ │ // │ │ │ │ │ │ 00006 // │ │ │ │ │ │ // │ │ │ │ │ │ @@ -25483,30 +25463,29 @@ │ │ │ │ │ │ 00059 │ │ │ │ │ │ 00060 // default dtor │ │ │ │ │ │ 00061 //-------------00062 Cjet::~Cjet(){ │ │ │ │ │ │ 00063 │ │ │ │ │ │ 00064 } │ │ │ │ │ │ 00065 │ │ │ │ │ │ 00066 // ordering of jets in pt (e.g. used in final jets ordering) │ │ │ │ │ │ -00067 //----------------------------------------------------------- │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.46 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00068 bool jets_pt_less(const Cjet &j1, const Cjet &j2){ │ │ │ │ │ │ +00067 //----------------------------------------------------------00068 bool jets_pt_less(const Cjet &j1, const Cjet &j2){ │ │ │ │ │ │ return j1.v.perp2() > j2.v.perp2(); │ │ │ │ │ │ 00069 │ │ │ │ │ │ 00070 } │ │ │ │ │ │ 00071 │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 /******************************************************** │ │ │ │ │ │ 00074 * Csplit_merge_ptcomparison implementation │ │ │ │ │ │ * │ │ │ │ │ │ 00075 * This deals with the ordering of the jets candidates * │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00076 ********************************************************/ │ │ │ │ │ │ 00077 │ │ │ │ │ │ 00078 // odering of two jets │ │ │ │ │ │ 00079 // The variable of the ordering is pt or mt │ │ │ │ │ │ 00080 // depending on ’split_merge_scale’ choice │ │ │ │ │ │ 00081 // │ │ │ │ │ │ 00082 // with EPSILON_SPLITMERGE defined, this attempts to identify │ │ │ │ │ │ @@ -25517,19 +25496,19 @@ │ │ │ │ │ │ 00087 // │ │ │ │ │ │ 00088 // NB: there is a potential issue in momentum-conserving events, │ │ │ │ │ │ 00089 // whereby the harder of two jets becomes ill-defined when a soft │ │ │ │ │ │ 00090 // particle is emitted --- this may have a knock-on effect on │ │ │ │ │ │ 00091 // subsequent split-merge steps in cases with sufficiently large R │ │ │ │ │ │ 00092 // (but we don’t know what the limit is...) │ │ │ │ │ │ 00093 //-----------------------------------------------------------------00094 bool Csplit_merge_ptcomparison::operator ()(const Cjet &jet1, const Cjet &jet2) const{ │ │ │ │ │ │ -double q1, q2; │ │ │ │ │ │ 00095 │ │ │ │ │ │ +double q1, q2; │ │ │ │ │ │ 00096 │ │ │ │ │ │ -00097 │ │ │ │ │ │ // compute the value for comparison for both jets │ │ │ │ │ │ +00097 │ │ │ │ │ │ 00098 │ │ │ │ │ │ // This depends on the choice of variable (mt is the default) │ │ │ │ │ │ 00099 │ │ │ │ │ │ q1 = jet1.sm_var2; │ │ │ │ │ │ 00100 │ │ │ │ │ │ q2 = jet2.sm_var2; │ │ │ │ │ │ 00101 │ │ │ │ │ │ @@ -25543,60 +25522,60 @@ │ │ │ │ │ │ 00106 │ │ │ │ │ │ // close in the ordering variable. │ │ │ │ │ │ 00107 #ifdef EPSILON_SPLITMERGE │ │ │ │ │ │ 00108 │ │ │ │ │ │ if ( (fabs(q1-q2) < EPSILON_SPLITMERGE*max(q1,q2)) && │ │ │ │ │ │ 00109 │ │ │ │ │ │ (jet1.v.ref != jet2.v.ref) ) { │ │ │ │ │ │ -// get the momentum of the difference │ │ │ │ │ │ 00110 │ │ │ │ │ │ +// get the momentum of the difference │ │ │ │ │ │ 00111 │ │ │ │ │ │ Cmomentum difference; │ │ │ │ │ │ -double pt_tilde_difference; │ │ │ │ │ │ 00112 │ │ │ │ │ │ +double pt_tilde_difference; │ │ │ │ │ │ 00113 │ │ │ │ │ │ get_difference(jet1,jet2,&difference,&pt_tilde_difference); │ │ │ │ │ │ 00114 │ │ │ │ │ │ -00115 │ │ │ │ │ │ // use the following relation: pt1^2 - pt2^2 = (pt1+pt2)*(pt1-pt2) │ │ │ │ │ │ +00115 │ │ │ │ │ │ 00116 │ │ │ │ │ │ double qdiff; │ │ │ │ │ │ 00117 │ │ │ │ │ │ Cmomentum sum = jet1.v ; │ │ │ │ │ │ 00118 │ │ │ │ │ │ sum += jet2.v; │ │ │ │ │ │ -double pt_tilde_sum = jet1.pt_tilde + jet2.pt_tilde; │ │ │ │ │ │ 00119 │ │ │ │ │ │ +double pt_tilde_sum = jet1.pt_tilde + jet2.pt_tilde; │ │ │ │ │ │ 00120 │ │ │ │ │ │ // depending on the choice of ordering variable, set the result │ │ │ │ │ │ 00121 │ │ │ │ │ │ 00122 │ │ │ │ │ │ switch (split_merge_scale){ │ │ │ │ │ │ 00123 │ │ │ │ │ │ case SM_mt: │ │ │ │ │ │ 00124 │ │ │ │ │ │ qdiff = sum.E*difference.E - sum.pz*difference.pz; │ │ │ │ │ │ break; │ │ │ │ │ │ 00125 │ │ │ │ │ │ -case SM_pt: │ │ │ │ │ │ 00126 │ │ │ │ │ │ +case SM_pt: │ │ │ │ │ │ 00127 │ │ │ │ │ │ qdiff = sum.px*difference.px + sum.py*difference.py; │ │ │ │ │ │ -00128 │ │ │ │ │ │ break; │ │ │ │ │ │ +00128 │ │ │ │ │ │ case SM_pttilde: │ │ │ │ │ │ 00129 │ │ │ │ │ │ 00130 │ │ │ │ │ │ qdiff = pt_tilde_sum*pt_tilde_difference; │ │ │ │ │ │ -break; │ │ │ │ │ │ 00131 │ │ │ │ │ │ -00132 │ │ │ │ │ │ +break; │ │ │ │ │ │ case SM_Et: │ │ │ │ │ │ -// diff = E^2 (dpt^2 pz^2- pt^2 dpz^2) │ │ │ │ │ │ +00132 │ │ │ │ │ │ 00133 │ │ │ │ │ │ +// diff = E^2 (dpt^2 pz^2- pt^2 dpz^2) │ │ │ │ │ │ 00134 │ │ │ │ │ │ // │ │ │ │ │ │ + dE^2 (pt^2+pz^2) pt2^2 │ │ │ │ │ │ 00135 │ │ │ │ │ │ // where, unless explicitely specified the variables │ │ │ │ │ │ 00136 │ │ │ │ │ │ // refer to the first jet or differences jet1-jet2. │ │ │ │ │ │ @@ -25608,61 +25587,61 @@ │ │ │ │ │ │ -jet1.v.perp2()*sum.pz*difference.pz) │ │ │ │ │ │ 00140 │ │ │ │ │ │ +sum.E*difference.E*(jet1.v.perp2()+jet1.v.pz*jet1.v.pz)*jet2.v.perp2(); │ │ │ │ │ │ break; │ │ │ │ │ │ 00141 │ │ │ │ │ │ 00142 │ │ │ │ │ │ default: │ │ │ │ │ │ -throw Csiscone_error("Unsupported split-merge scale choice: " │ │ │ │ │ │ 00143 │ │ │ │ │ │ +throw Csiscone_error("Unsupported split-merge scale choice: " │ │ │ │ │ │ 00144 │ │ │ │ │ │ + SM_scale_name()); │ │ │ │ │ │ 00145 │ │ │ │ │ │ } │ │ │ │ │ │ 00146 │ │ │ │ │ │ res = qdiff > 0; │ │ │ │ │ │ 00147 │ │ │ │ │ │ } │ │ │ │ │ │ 00148 #endif // EPSILON_SPLITMERGE │ │ │ │ │ │ 00149 │ │ │ │ │ │ -return res; │ │ │ │ │ │ 00150 │ │ │ │ │ │ +return res; │ │ │ │ │ │ 00151 } │ │ │ │ │ │ 00152 │ │ │ │ │ │ 00153 │ │ │ │ │ │ 00156 std::string split_merge_scale_name(Esplit_merge_scale sms) { │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -279 │ │ │ │ │ │ - │ │ │ │ │ │ - 280 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ -00157 │ │ │ │ │ │ switch(sms) { │ │ │ │ │ │ -case SM_pt: │ │ │ │ │ │ +00157 │ │ │ │ │ │ 00158 │ │ │ │ │ │ +case SM_pt: │ │ │ │ │ │ 00159 │ │ │ │ │ │ return "pt (IR unsafe)"; │ │ │ │ │ │ -00160 │ │ │ │ │ │ case SM_Et: │ │ │ │ │ │ -return "Et (boost dep.)"; │ │ │ │ │ │ +00160 │ │ │ │ │ │ 00161 │ │ │ │ │ │ -00162 │ │ │ │ │ │ +return "Et (boost dep.)"; │ │ │ │ │ │ case SM_mt: │ │ │ │ │ │ +00162 │ │ │ │ │ │ return "mt (IR safe except for pairs of identical decayed heavy particles)"; │ │ │ │ │ │ 00163 │ │ │ │ │ │ 00164 │ │ │ │ │ │ case SM_pttilde: │ │ │ │ │ │ -return "pttilde (scalar sum of pt’s)"; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +279 │ │ │ │ │ │ + │ │ │ │ │ │ + 280 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00165 │ │ │ │ │ │ -00166 │ │ │ │ │ │ +return "pttilde (scalar sum of pt’s)"; │ │ │ │ │ │ default: │ │ │ │ │ │ +00166 │ │ │ │ │ │ 00167 │ │ │ │ │ │ return "[SM scale without a name]"; │ │ │ │ │ │ 00168 │ │ │ │ │ │ } │ │ │ │ │ │ 00169 } │ │ │ │ │ │ 00170 │ │ │ │ │ │ 00171 │ │ │ │ │ │ @@ -25674,28 +25653,28 @@ │ │ │ │ │ │ 00175 // - v │ │ │ │ │ │ jet1-jet2 │ │ │ │ │ │ 00176 // - pt_tilde │ │ │ │ │ │ jet1-jet2 pt_tilde │ │ │ │ │ │ 00177 // return true if overlapping, false if disjoint │ │ │ │ │ │ 00178 //----------------------------------------------00179 void Csplit_merge_ptcomparison::get_difference(const Cjet &j1, const Cjet &j2, Cmomentum *v, double │ │ │ │ │ │ *pt_tilde) const { │ │ │ │ │ │ -00180 │ │ │ │ │ │ int i1,i2; │ │ │ │ │ │ +00180 │ │ │ │ │ │ 00181 │ │ │ │ │ │ // initialise │ │ │ │ │ │ 00182 │ │ │ │ │ │ 00183 │ │ │ │ │ │ i1=i2=0; │ │ │ │ │ │ 00184 │ │ │ │ │ │ *v = Cmomentum(); │ │ │ │ │ │ 00185 │ │ │ │ │ │ *pt_tilde = 0.0; │ │ │ │ │ │ 00186 │ │ │ │ │ │ -00187 │ │ │ │ │ │ // compute overlap │ │ │ │ │ │ +00187 │ │ │ │ │ │ 00188 │ │ │ │ │ │ // at the same time, we store union in indices │ │ │ │ │ │ 00189 │ │ │ │ │ │ do{ │ │ │ │ │ │ 00190 │ │ │ │ │ │ if (j1.contents[i1]==j2.contents[i2]) { │ │ │ │ │ │ 00191 │ │ │ │ │ │ @@ -25716,16 +25695,16 @@ │ │ │ │ │ │ (*v) -= (*particles)[j2.contents[i2]]; │ │ │ │ │ │ 00199 │ │ │ │ │ │ (*pt_tilde) -= (*pt)[j2.contents[i2]]; │ │ │ │ │ │ 00200 │ │ │ │ │ │ i2++; │ │ │ │ │ │ 00201 │ │ │ │ │ │ } else { │ │ │ │ │ │ -throw Csiscone_error("get_non_overlap reached part it should never have seen..."); │ │ │ │ │ │ 00202 │ │ │ │ │ │ +throw Csiscone_error("get_non_overlap reached part it should never have seen..."); │ │ │ │ │ │ 00203 │ │ │ │ │ │ } │ │ │ │ │ │ 00204 │ │ │ │ │ │ } while ((i1(ptcomparison)); │ │ │ │ │ │ 00240 │ │ │ │ │ │ // no hardest cut (col-unsafe) │ │ │ │ │ │ 00241 │ │ │ │ │ │ 00242 │ │ │ │ │ │ SM_var2_hardest_cut_off = -numeric_limits::max(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.46 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -281 │ │ │ │ │ │ - │ │ │ │ │ │ 00243 │ │ │ │ │ │ // no pt cutoff for the particles to put in p_uncol_hard │ │ │ │ │ │ 00244 │ │ │ │ │ │ 00245 │ │ │ │ │ │ stable_cone_soft_pt2_cutoff = -1.0; │ │ │ │ │ │ 00246 │ │ │ │ │ │ // no pt-weighted splitting │ │ │ │ │ │ 00247 │ │ │ │ │ │ 00248 │ │ │ │ │ │ use_pt_weighted_splitting = false; │ │ │ │ │ │ 00249 } │ │ │ │ │ │ 00250 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ +281 │ │ │ │ │ │ + │ │ │ │ │ │ 00251 │ │ │ │ │ │ 00252 // default dtor │ │ │ │ │ │ 00253 //-------------00254 Csplit_merge::~Csplit_merge(){ │ │ │ │ │ │ 00255 │ │ │ │ │ │ full_clear(); │ │ │ │ │ │ 00256 } │ │ │ │ │ │ 00257 │ │ │ │ │ │ @@ -25818,44 +25797,44 @@ │ │ │ │ │ │ 00261 // - protocones list of protocones (initial jet candidates) │ │ │ │ │ │ 00262 // - R2 │ │ │ │ │ │ cone radius (squared) │ │ │ │ │ │ 00263 // - ptmin │ │ │ │ │ │ minimal pT allowed for jets │ │ │ │ │ │ 00264 //------------------------------------------------------------00265 int Csplit_merge::init(vector & /*_particles*/, vector *protocones, double R2, │ │ │ │ │ │ double ptmin){ │ │ │ │ │ │ -00266 │ │ │ │ │ │ // browse protocones │ │ │ │ │ │ +00266 │ │ │ │ │ │ 00267 │ │ │ │ │ │ return add_protocones(protocones, R2, ptmin); │ │ │ │ │ │ 00268 } │ │ │ │ │ │ 00269 │ │ │ │ │ │ 00270 │ │ │ │ │ │ 00271 // initialisation function for particle list │ │ │ │ │ │ 00272 // - _particles list of particles │ │ │ │ │ │ 00273 //------------------------------------------------------------00274 int Csplit_merge::init_particles(vector &_particles){ │ │ │ │ │ │ 00275 │ │ │ │ │ │ full_clear(); │ │ │ │ │ │ 00276 │ │ │ │ │ │ -00277 │ │ │ │ │ │ // compute the list of particles │ │ │ │ │ │ +00277 │ │ │ │ │ │ 00278 │ │ │ │ │ │ // here, we do not need to throw away particles │ │ │ │ │ │ 00279 │ │ │ │ │ │ // with infinite rapidity (colinear with the beam) │ │ │ │ │ │ 00280 │ │ │ │ │ │ particles = _particles; │ │ │ │ │ │ 00281 │ │ │ │ │ │ n = particles.size(); │ │ │ │ │ │ 00282 │ │ │ │ │ │ 00283 │ │ │ │ │ │ // build the vector of particles’ pt │ │ │ │ │ │ 00284 │ │ │ │ │ │ pt.resize(n); │ │ │ │ │ │ -00285 │ │ │ │ │ │ for (int i=0;i(ptcomparison)); │ │ │ │ │ │ 00371 │ │ │ │ │ │ @@ -26019,67 +25998,60 @@ │ │ │ │ │ │ 00378 │ │ │ │ │ │ cand_refs.clear(); │ │ │ │ │ │ 00379 #endif │ │ │ │ │ │ 00380 │ │ │ │ │ │ 00381 │ │ │ │ │ │ p_remain.clear(); │ │ │ │ │ │ 00382 │ │ │ │ │ │ -00383 │ │ │ │ │ │ return 0; │ │ │ │ │ │ +00383 │ │ │ │ │ │ 00384 } │ │ │ │ │ │ 00385 │ │ │ │ │ │ 00386 │ │ │ │ │ │ 00387 // full clearance │ │ │ │ │ │ 00388 //---------------00389 int Csplit_merge::full_clear(){ │ │ │ │ │ │ 00390 │ │ │ │ │ │ partial_clear(); │ │ │ │ │ │ 00391 │ │ │ │ │ │ -// clear previously allocated memory │ │ │ │ │ │ 00392 │ │ │ │ │ │ +// clear previously allocated memory │ │ │ │ │ │ 00393 │ │ │ │ │ │ if (indices != NULL){ │ │ │ │ │ │ -delete[] indices; │ │ │ │ │ │ 00394 │ │ │ │ │ │ +delete[] indices; │ │ │ │ │ │ 00395 │ │ │ │ │ │ } │ │ │ │ │ │ 00396 │ │ │ │ │ │ particles.clear(); │ │ │ │ │ │ 00397 │ │ │ │ │ │ 00398 │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00399 } │ │ │ │ │ │ 00400 │ │ │ │ │ │ 00401 │ │ │ │ │ │ 00402 // build the list ’p_uncol_hard’ from p_remain by clustering collinear particles │ │ │ │ │ │ 00403 // note that thins in only used for stable-cone detection │ │ │ │ │ │ 00404 // so the parent_index field is unnecessary │ │ │ │ │ │ 00405 //------------------------------------------------------------------------00406 int Csplit_merge::merge_collinear_and_remove_soft(){ │ │ │ │ │ │ -00407 │ │ │ │ │ │ int i,j; │ │ │ │ │ │ +00407 │ │ │ │ │ │ 00408 │ │ │ │ │ │ vector p_sorted; │ │ │ │ │ │ bool collinear; │ │ │ │ │ │ 00409 │ │ │ │ │ │ 00410 │ │ │ │ │ │ double dphi; │ │ │ │ │ │ 00411 │ │ │ │ │ │ 00412 │ │ │ │ │ │ p_uncol_hard.clear(); │ │ │ │ │ │ 00413 │ │ │ │ │ │ // we first sort the particles according to their rapidity │ │ │ │ │ │ 00414 │ │ │ │ │ │ 00415 │ │ │ │ │ │ for (i=0;iM_PI) dphi = twopi-dphi; │ │ │ │ │ │ 00436 │ │ │ │ │ │ -00437 │ │ │ │ │ │ if (dphi *protocones, double R2, double ptmin){ │ │ │ │ │ │ -00461 │ │ │ │ │ │ int i; │ │ │ │ │ │ +00461 │ │ │ │ │ │ 00462 │ │ │ │ │ │ Cmomentum *c; │ │ │ │ │ │ 00463 │ │ │ │ │ │ Cmomentum *v; │ │ │ │ │ │ 00464 │ │ │ │ │ │ double eta, phi; │ │ │ │ │ │ -double dx, dy; │ │ │ │ │ │ 00465 │ │ │ │ │ │ -00466 │ │ │ │ │ │ +double dx, dy; │ │ │ │ │ │ double R; │ │ │ │ │ │ +00466 │ │ │ │ │ │ 00467 │ │ │ │ │ │ Cjet jet; │ │ │ │ │ │ 00468 │ │ │ │ │ │ if (protocones->size()==0) │ │ │ │ │ │ 00469 │ │ │ │ │ │ -00470 │ │ │ │ │ │ return 1; │ │ │ │ │ │ +00470 │ │ │ │ │ │ 00471 │ │ │ │ │ │ 00472 │ │ │ │ │ │ pt_min2 = ptmin*ptmin; │ │ │ │ │ │ 00473 │ │ │ │ │ │ R = sqrt(R2); │ │ │ │ │ │ 00474 │ │ │ │ │ │ 00475 │ │ │ │ │ │ @@ -26218,33 +26197,26 @@ │ │ │ │ │ │ // NO NEEDED ANYMORE SINCE REMOVED FROM p_remain FROM THE BEGINNING │ │ │ │ │ │ 00494 │ │ │ │ │ │ //if (fabs(v->pz)!=v->E){ │ │ │ │ │ │ 00495 │ │ │ │ │ │ dx = eta - v->eta; │ │ │ │ │ │ 00496 │ │ │ │ │ │ dy = fabs(phi - v->phi); │ │ │ │ │ │ -00497 │ │ │ │ │ │ if (dy>M_PI) │ │ │ │ │ │ +00497 │ │ │ │ │ │ 00498 │ │ │ │ │ │ dy -= twopi; │ │ │ │ │ │ if (dx*dx+dy*dyparent_index); │ │ │ │ │ │ 00501 │ │ │ │ │ │ jet.v+= *v; │ │ │ │ │ │ 00502 │ │ │ │ │ │ jet.pt_tilde+= pt[v->parent_index]; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 284 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00503 │ │ │ │ │ │ v->index=0; │ │ │ │ │ │ 00504 │ │ │ │ │ │ } │ │ │ │ │ │ 00505 │ │ │ │ │ │ } │ │ │ │ │ │ 00506 │ │ │ │ │ │ @@ -26252,37 +26224,44 @@ │ │ │ │ │ │ 00507 │ │ │ │ │ │ 00508 │ │ │ │ │ │ // set the momentum in protocones │ │ │ │ │ │ 00509 │ │ │ │ │ │ // (it was only known through eta and phi up to now) │ │ │ │ │ │ 00510 │ │ │ │ │ │ *c = jet.v; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 284 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00511 │ │ │ │ │ │ c->eta = eta; // restore exact original coords │ │ │ │ │ │ 00512 │ │ │ │ │ │ c->phi = phi; // to avoid rounding error inconsistencies │ │ │ │ │ │ 00513 │ │ │ │ │ │ -// set the jet range │ │ │ │ │ │ 00514 │ │ │ │ │ │ +// set the jet range │ │ │ │ │ │ 00515 │ │ │ │ │ │ jet.range=Ceta_phi_range(eta,phi,R); │ │ │ │ │ │ 00516 │ │ │ │ │ │ 00517 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00518 │ │ │ │ │ │ cout « "adding jet: "; │ │ │ │ │ │ for (int i2=0;i2 *protocones, double R2, double │ │ │ │ │ │ ptmin){ │ │ │ │ │ │ @@ -26357,18 +26336,18 @@ │ │ │ │ │ │ 00573 │ │ │ │ │ │ 00574 │ │ │ │ │ │ Cmomentum *c; │ │ │ │ │ │ 00575 │ │ │ │ │ │ Cmomentum *v; │ │ │ │ │ │ 00576 │ │ │ │ │ │ double eta, phi; │ │ │ │ │ │ -double dx, dy; │ │ │ │ │ │ 00577 │ │ │ │ │ │ -00578 │ │ │ │ │ │ +double dx, dy; │ │ │ │ │ │ double R; │ │ │ │ │ │ +00578 │ │ │ │ │ │ 00579 │ │ │ │ │ │ Cjet jet, jet_candidate; │ │ │ │ │ │ bool found_jet = false; │ │ │ │ │ │ 00580 │ │ │ │ │ │ 00581 │ │ │ │ │ │ if (protocones->size()==0) │ │ │ │ │ │ 00582 │ │ │ │ │ │ @@ -26376,39 +26355,39 @@ │ │ │ │ │ │ return 1; │ │ │ │ │ │ 00584 │ │ │ │ │ │ 00585 │ │ │ │ │ │ pt_min2 = ptmin*ptmin; │ │ │ │ │ │ 00586 │ │ │ │ │ │ R = sqrt(R2); │ │ │ │ │ │ 00587 │ │ │ │ │ │ -// browse protocones │ │ │ │ │ │ 00588 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.46 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ +// browse protocones │ │ │ │ │ │ 00589 │ │ │ │ │ │ // for each of them, build the list of particles in them │ │ │ │ │ │ 00590 │ │ │ │ │ │ for (vector::iterator p_it = protocones->begin();p_it != protocones->end();p_it++){ │ │ │ │ │ │ 00591 │ │ │ │ │ │ // initialise variables │ │ │ │ │ │ 00592 │ │ │ │ │ │ c = &(*p_it); │ │ │ │ │ │ 00593 │ │ │ │ │ │ -// note: cones have been tested => their (eta,phi) coordinates are computed │ │ │ │ │ │ 00594 │ │ │ │ │ │ +// note: cones have been tested => their (eta,phi) coordinates are computed │ │ │ │ │ │ 00595 │ │ │ │ │ │ eta = c->eta; │ │ │ │ │ │ 00596 │ │ │ │ │ │ phi = c->phi; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00597 │ │ │ │ │ │ -00598 │ │ │ │ │ │ // NOTE: this is common to this method and add_protocones, so it │ │ │ │ │ │ +00598 │ │ │ │ │ │ 00599 │ │ │ │ │ │ // could be moved into a ’build_jet_from_protocone’ method │ │ │ │ │ │ 00600 │ │ │ │ │ │ // │ │ │ │ │ │ 00601 │ │ │ │ │ │ // browse particles to create cone contents │ │ │ │ │ │ 00602 │ │ │ │ │ │ @@ -26417,26 +26396,26 @@ │ │ │ │ │ │ jet_candidate.pt_tilde=0; │ │ │ │ │ │ 00604 │ │ │ │ │ │ jet_candidate.contents.clear(); │ │ │ │ │ │ 00605 │ │ │ │ │ │ for (i=0;ipz)!=v->E){ │ │ │ │ │ │ 00610 │ │ │ │ │ │ dx = eta - v->eta; │ │ │ │ │ │ 00611 │ │ │ │ │ │ dy = fabs(phi - v->phi); │ │ │ │ │ │ -if (dy>M_PI) │ │ │ │ │ │ 00612 │ │ │ │ │ │ +if (dy>M_PI) │ │ │ │ │ │ 00613 │ │ │ │ │ │ dy -= twopi; │ │ │ │ │ │ if (dx*dx+dy*dyparent_index); │ │ │ │ │ │ 00616 │ │ │ │ │ │ @@ -26459,47 +26438,47 @@ │ │ │ │ │ │ 00625 │ │ │ │ │ │ *c = jet_candidate.v; │ │ │ │ │ │ 00626 │ │ │ │ │ │ c->eta = eta; // restore exact original coords │ │ │ │ │ │ 00627 │ │ │ │ │ │ c->phi = phi; // to avoid rounding error inconsistencies │ │ │ │ │ │ 00628 │ │ │ │ │ │ -00629 │ │ │ │ │ │ // set the jet range │ │ │ │ │ │ +00629 │ │ │ │ │ │ 00630 │ │ │ │ │ │ jet_candidate.range=Ceta_phi_range(eta,phi,R); │ │ │ │ │ │ 00631 │ │ │ │ │ │ // check that the protojet has large enough pt │ │ │ │ │ │ 00632 │ │ │ │ │ │ 00633 │ │ │ │ │ │ if (jet_candidate.v.perp2()is_larger(jet_candidate, jet) │ │ │ │ │ │ 00649 │ │ │ │ │ │ : ptcomparison(jet_candidate, jet))){ │ │ │ │ │ │ 00650 │ │ │ │ │ │ @@ -26524,57 +26503,57 @@ │ │ │ │ │ │ jets[jets.size()-1].v.build_etaphi(); │ │ │ │ │ │ 00661 │ │ │ │ │ │ 00662 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00663 │ │ │ │ │ │ cout « "PR-Jet " « jets.size() « " [size " « jet.contents.size() « "]:"; │ │ │ │ │ │ 00664 #endif │ │ │ │ │ │ 00665 │ │ │ │ │ │ -// update the list of what particles are left │ │ │ │ │ │ 00666 │ │ │ │ │ │ +// update the list of what particles are left │ │ │ │ │ │ 00667 │ │ │ │ │ │ int p_remain_index = 0; │ │ │ │ │ │ -int contents_index = 0; │ │ │ │ │ │ 00668 │ │ │ │ │ │ -00669 │ │ │ │ │ │ +int contents_index = 0; │ │ │ │ │ │ //sort(next_jet.contents.begin(),next_jet.contents.end()); │ │ │ │ │ │ +00669 │ │ │ │ │ │ 00670 │ │ │ │ │ │ for (int index=0;indexsize()>0){ │ │ │ │ │ │ +00742 │ │ │ │ │ │ 00743 │ │ │ │ │ │ // browse for the first jet │ │ │ │ │ │ 00744 │ │ │ │ │ │ j1 = candidates->begin(); │ │ │ │ │ │ 00745 │ │ │ │ │ │ // if hardest jet does not pass threshold then nothing else will │ │ │ │ │ │ 00746 │ │ │ │ │ │ 00747 │ │ │ │ │ │ // either so one stops the split merge. │ │ │ │ │ │ 00748 │ │ │ │ │ │ if (j1->sm_var2end()){ │ │ │ │ │ │ 00755 │ │ │ │ │ │ +while (j2 != candidates->end()){ │ │ │ │ │ │ 00756 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00757 │ │ │ │ │ │ show(); │ │ │ │ │ │ 00758 #endif │ │ │ │ │ │ 00759 │ │ │ │ │ │ // check overlapping │ │ │ │ │ │ 00760 │ │ │ │ │ │ if (get_overlap(*j1, *j2, &overlap2)){ │ │ │ │ │ │ // check if overlapping energy passes threshold │ │ │ │ │ │ 00761 │ │ │ │ │ │ 00762 │ │ │ │ │ │ // Note that this depends on the ordering variable │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.46 split_merge.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00763 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 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){ │ │ │ │ │ │ -00768 │ │ │ │ │ │ // split jets │ │ │ │ │ │ +00768 │ │ │ │ │ │ 00769 │ │ │ │ │ │ split(j1, j2); │ │ │ │ │ │ 00770 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.46 split_merge.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00771 │ │ │ │ │ │ // update iterators │ │ │ │ │ │ 00772 │ │ │ │ │ │ j2 = j1 = candidates->begin(); │ │ │ │ │ │ 00773 │ │ │ │ │ │ j2_relindex = 0; │ │ │ │ │ │ 00774 │ │ │ │ │ │ } else { │ │ │ │ │ │ -00775 │ │ │ │ │ │ // merge jets │ │ │ │ │ │ +00775 │ │ │ │ │ │ 00776 │ │ │ │ │ │ merge(j1, j2); │ │ │ │ │ │ 00777 │ │ │ │ │ │ -00778 │ │ │ │ │ │ // update iterators │ │ │ │ │ │ +00778 │ │ │ │ │ │ 00779 │ │ │ │ │ │ j2 = j1 = candidates->begin(); │ │ │ │ │ │ 00780 │ │ │ │ │ │ j2_relindex = 0; │ │ │ │ │ │ 00781 │ │ │ │ │ │ } │ │ │ │ │ │ 00782 │ │ │ │ │ │ } │ │ │ │ │ │ -// watch out: split/merge might have caused new jets with pt < │ │ │ │ │ │ 00783 │ │ │ │ │ │ +// watch out: split/merge might have caused new jets with pt < │ │ │ │ │ │ 00784 │ │ │ │ │ │ // ptmin to disappear, so the total number of jets may │ │ │ │ │ │ 00785 │ │ │ │ │ │ // have changed by more than expected and j2 might already by │ │ │ │ │ │ 00786 │ │ │ │ │ │ // the end of the candidates list... │ │ │ │ │ │ 00787 │ │ │ │ │ │ j2_relindex++; │ │ │ │ │ │ -if (j2 != candidates->end()) j2++; │ │ │ │ │ │ 00788 │ │ │ │ │ │ +if (j2 != candidates->end()) j2++; │ │ │ │ │ │ 00789 │ │ │ │ │ │ } // end of loop on the second jet │ │ │ │ │ │ 00790 │ │ │ │ │ │ -00791 │ │ │ │ │ │ if (j1 != candidates->end()) { │ │ │ │ │ │ +00791 │ │ │ │ │ │ 00792 │ │ │ │ │ │ // all "second jet" passed without overlapping │ │ │ │ │ │ 00793 │ │ │ │ │ │ // (otherwise we won’t leave the j2 loop) │ │ │ │ │ │ 00794 │ │ │ │ │ │ // => store jet 1 as real jet │ │ │ │ │ │ 00795 │ │ │ │ │ │ jets.push_back(*j1); │ │ │ │ │ │ 00796 │ │ │ │ │ │ jets[jets.size()-1].v.build_etaphi(); │ │ │ │ │ │ -00797 │ │ │ │ │ │ // a bug where the contents has non-zero size has been cropping │ │ │ │ │ │ +00797 │ │ │ │ │ │ 00798 │ │ │ │ │ │ // up in many contexts -- so catch it! │ │ │ │ │ │ 00799 │ │ │ │ │ │ assert(j1->contents.size() > 0); │ │ │ │ │ │ 00800 │ │ │ │ │ │ jets[jets.size()-1].pass = particles[j1->contents[0]].index; │ │ │ │ │ │ 00801 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ @@ -26806,16 +26785,16 @@ │ │ │ │ │ │ 00816 │ │ │ │ │ │ sort(jets.begin(), jets.end(), jets_pt_less); │ │ │ │ │ │ 00817 #ifdef DEBUG_SPLIT_MERGE │ │ │ │ │ │ 00818 │ │ │ │ │ │ show(); │ │ │ │ │ │ 00819 #endif │ │ │ │ │ │ 00820 │ │ │ │ │ │ -00821 │ │ │ │ │ │ return jets.size(); │ │ │ │ │ │ +00821 │ │ │ │ │ │ 00822 } │ │ │ │ │ │ 00823 │ │ │ │ │ │ 00824 │ │ │ │ │ │ 00825 │ │ │ │ │ │ 00826 // save the event on disk │ │ │ │ │ │ 00827 // - flux │ │ │ │ │ │ stream used to save jet contents │ │ │ │ │ │ @@ -26827,16 +26806,16 @@ │ │ │ │ │ │ 00832 │ │ │ │ │ │ int i1, i2; │ │ │ │ │ │ 00833 │ │ │ │ │ │ 00834 │ │ │ │ │ │ fprintf(flux, "# %d jets found\n", (int) jets.size()); │ │ │ │ │ │ 00835 │ │ │ │ │ │ fprintf(flux, "# columns are: eta, phi, pt and number of particles for each jet\n"); │ │ │ │ │ │ -for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00836 │ │ │ │ │ │ +for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ 00837 │ │ │ │ │ │ j1 = &(*it_j); │ │ │ │ │ │ 00838 │ │ │ │ │ │ j1->v.build_etaphi(); │ │ │ │ │ │ 00839 │ │ │ │ │ │ fprintf(flux, "%f\t%f\t%e\t%d\n", │ │ │ │ │ │ 00840 │ │ │ │ │ │ @@ -26856,46 +26835,47 @@ │ │ │ │ │ │ 00847 │ │ │ │ │ │ 00848 │ │ │ │ │ │ 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 │ │ │ │ │ │ +} │ │ │ │ │ │ +00852 │ │ │ │ │ │ +00853 │ │ │ │ │ │ +return 0; │ │ │ │ │ │ +00854 } │ │ │ │ │ │ +00855 │ │ │ │ │ │ +00856 │ │ │ │ │ │ +00857 // show current jets/candidate status │ │ │ │ │ │ +00858 //------------------------------------ │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 287 │ │ │ │ │ │ │ │ │ │ │ │ 288 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00851 │ │ │ │ │ │ -} │ │ │ │ │ │ -00852 │ │ │ │ │ │ -return 0; │ │ │ │ │ │ -00853 │ │ │ │ │ │ -00854 } │ │ │ │ │ │ -00855 │ │ │ │ │ │ -00856 │ │ │ │ │ │ -00857 // show current jets/candidate status │ │ │ │ │ │ -00858 //-----------------------------------00859 int Csplit_merge::show(){ │ │ │ │ │ │ +00859 int Csplit_merge::show(){ │ │ │ │ │ │ 00860 │ │ │ │ │ │ jet_iterator it_j; │ │ │ │ │ │ 00861 │ │ │ │ │ │ cjet_iterator it_c; │ │ │ │ │ │ 00862 │ │ │ │ │ │ Cjet *j; │ │ │ │ │ │ -00863 │ │ │ │ │ │ const Cjet *c; │ │ │ │ │ │ -int i1, i2; │ │ │ │ │ │ +00863 │ │ │ │ │ │ 00864 │ │ │ │ │ │ +int i1, i2; │ │ │ │ │ │ 00865 │ │ │ │ │ │ -00866 │ │ │ │ │ │ for (it_j = jets.begin(), i1=0 ; it_j != jets.end() ; it_j++, i1++){ │ │ │ │ │ │ +00866 │ │ │ │ │ │ 00867 │ │ │ │ │ │ j = &(*it_j); │ │ │ │ │ │ 00868 │ │ │ │ │ │ fprintf(stdout, "jet %2d: %e\t%e\t%e\t%e\t", i1+1, │ │ │ │ │ │ 00869 │ │ │ │ │ │ j->v.px, j->v.py, j->v.pz, j->v.E); │ │ │ │ │ │ for (i2=0;i2n;i2++) │ │ │ │ │ │ @@ -26903,16 +26883,16 @@ │ │ │ │ │ │ 00871 │ │ │ │ │ │ fprintf(stdout, "%d ", j->contents[i2]); │ │ │ │ │ │ 00872 │ │ │ │ │ │ fprintf(stdout, "\n"); │ │ │ │ │ │ 00873 │ │ │ │ │ │ } │ │ │ │ │ │ 00874 │ │ │ │ │ │ -for (it_c = candidates->begin(), i1=0 ; it_c != candidates->end() ; it_c++, i1++){ │ │ │ │ │ │ 00875 │ │ │ │ │ │ +for (it_c = candidates->begin(), i1=0 ; it_c != candidates->end() ; it_c++, i1++){ │ │ │ │ │ │ 00876 │ │ │ │ │ │ c = &(*it_c); │ │ │ │ │ │ 00877 │ │ │ │ │ │ fprintf(stdout, "cdt %2d: %e\t%e\t%e\t%e\t%e\t", i1+1, │ │ │ │ │ │ 00878 │ │ │ │ │ │ c->v.px, c->v.py, c->v.pz, c->v.E, sqrt(c->sm_var2)); │ │ │ │ │ │ for (i2=0;i2n;i2++) │ │ │ │ │ │ @@ -26935,36 +26915,36 @@ │ │ │ │ │ │ 00890 // - j1 │ │ │ │ │ │ first jet │ │ │ │ │ │ 00891 // - j2 │ │ │ │ │ │ second jet │ │ │ │ │ │ 00892 // - overlap2 returned overlap^2 (determined by the choice of SM variable) │ │ │ │ │ │ 00893 // return true if overlapping, false if disjoint │ │ │ │ │ │ 00894 //--------------------------------------------------------------------00895 bool Csplit_merge::get_overlap(const Cjet &j1, const Cjet &j2, double *overlap2){ │ │ │ │ │ │ -00896 │ │ │ │ │ │ // check if ranges overlap │ │ │ │ │ │ +00896 │ │ │ │ │ │ 00897 │ │ │ │ │ │ if (!is_range_overlap(j1.range,j2.range)) │ │ │ │ │ │ -00898 │ │ │ │ │ │ return false; │ │ │ │ │ │ +00898 │ │ │ │ │ │ 00899 │ │ │ │ │ │ -int i1,i2; │ │ │ │ │ │ 00900 │ │ │ │ │ │ -00901 │ │ │ │ │ │ +int i1,i2; │ │ │ │ │ │ bool is_overlap; │ │ │ │ │ │ +00901 │ │ │ │ │ │ 00902 │ │ │ │ │ │ // initialise │ │ │ │ │ │ 00903 │ │ │ │ │ │ 00904 │ │ │ │ │ │ i1=i2=idx_size=0; │ │ │ │ │ │ 00905 │ │ │ │ │ │ is_overlap = false; │ │ │ │ │ │ 00906 │ │ │ │ │ │ Cmomentum v; │ │ │ │ │ │ -double pt_tilde=0.0; │ │ │ │ │ │ 00907 │ │ │ │ │ │ +double pt_tilde=0.0; │ │ │ │ │ │ 00908 │ │ │ │ │ │ // compute overlap │ │ │ │ │ │ 00909 │ │ │ │ │ │ 00910 │ │ │ │ │ │ // at the same time, we store union in indices │ │ │ │ │ │ 00911 │ │ │ │ │ │ do{ │ │ │ │ │ │ @@ -27013,36 +26993,36 @@ │ │ │ │ │ │ indices[idx_size] = j1.contents[i1]; │ │ │ │ │ │ 00934 │ │ │ │ │ │ i1++; │ │ │ │ │ │ 00935 │ │ │ │ │ │ idx_size++; │ │ │ │ │ │ 00936 │ │ │ │ │ │ } │ │ │ │ │ │ -while (i2" all over the place │ │ │ │ │ │ 00971 │ │ │ │ │ │ const Cjet & j1 = * it_j1; │ │ │ │ │ │ -00972 │ │ │ │ │ │ const Cjet & j2 = * it_j2; │ │ │ │ │ │ +00972 │ │ │ │ │ │ 00973 │ │ │ │ │ │ 00974 │ │ │ │ │ │ i1=i2=0; │ │ │ │ │ │ 00975 │ │ │ │ │ │ jet2.v = jet1.v = Cmomentum(); │ │ │ │ │ │ 00976 │ │ │ │ │ │ jet2.pt_tilde = jet1.pt_tilde = 0.0; │ │ │ │ │ │ @@ -27138,16 +27118,16 @@ │ │ │ │ │ │ jet1.pt_tilde += pt[j1.contents[i1]]; │ │ │ │ │ │ 01005 │ │ │ │ │ │ i1++; │ │ │ │ │ │ 01006 │ │ │ │ │ │ jet1.range.add_particle(v->eta,v->phi); │ │ │ │ │ │ 01007 │ │ │ │ │ │ } else if (j1.contents[i1]>j2.contents[i2]){ │ │ │ │ │ │ -01008 │ │ │ │ │ │ // particle i2 belong only to jet 2 │ │ │ │ │ │ +01008 │ │ │ │ │ │ 01009 │ │ │ │ │ │ v = &(particles[j2.contents[i2]]); │ │ │ │ │ │ 01010 │ │ │ │ │ │ jet2.contents.push_back(j2.contents[i2]); │ │ │ │ │ │ 01011 │ │ │ │ │ │ jet2.v += *v; │ │ │ │ │ │ 01012 │ │ │ │ │ │ @@ -27165,53 +27145,53 @@ │ │ │ │ │ │ 01018 │ │ │ │ │ │ // distance w.r.t. centroid 1 │ │ │ │ │ │ 01019 │ │ │ │ │ │ 01020 │ │ │ │ │ │ dx1 = eta1 - v->eta; │ │ │ │ │ │ 01021 │ │ │ │ │ │ dy1 = fabs(phi1 - v->phi); │ │ │ │ │ │ -if (dy1>M_PI) │ │ │ │ │ │ 01022 │ │ │ │ │ │ +if (dy1>M_PI) │ │ │ │ │ │ 01023 │ │ │ │ │ │ dy1 -= twopi; │ │ │ │ │ │ 01024 │ │ │ │ │ │ 01025 │ │ │ │ │ │ // distance w.r.t. centroid 2 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -289 │ │ │ │ │ │ - │ │ │ │ │ │ - 290 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 01026 │ │ │ │ │ │ dx2 = eta2 - v->eta; │ │ │ │ │ │ 01027 │ │ │ │ │ │ dy2 = fabs(phi2 - v->phi); │ │ │ │ │ │ -if (dy2>M_PI) │ │ │ │ │ │ 01028 │ │ │ │ │ │ +if (dy2>M_PI) │ │ │ │ │ │ 01029 │ │ │ │ │ │ dy2 -= twopi; │ │ │ │ │ │ 01030 │ │ │ │ │ │ -01031 │ │ │ │ │ │ //? what when == ? │ │ │ │ │ │ +01031 │ │ │ │ │ │ 01032 │ │ │ │ │ │ // When use_pt_weighted_splitting is activated, the │ │ │ │ │ │ 01033 │ │ │ │ │ │ // "geometrical" distance is weighted by the inverse │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +289 │ │ │ │ │ │ + │ │ │ │ │ │ + 290 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 01034 │ │ │ │ │ │ // of the pt of the protojet │ │ │ │ │ │ 01035 │ │ │ │ │ │ double d1sq = (dx1*dx1+dy1*dy1)*pt1_weight; │ │ │ │ │ │ 01036 │ │ │ │ │ │ double d2sq = (dx2*dx2+dy2*dy2)*pt2_weight; │ │ │ │ │ │ -// do bookkeeping on most ambiguous split │ │ │ │ │ │ 01037 │ │ │ │ │ │ +// do bookkeeping on most ambiguous split │ │ │ │ │ │ 01038 │ │ │ │ │ │ if (fabs(d1sq-d2sq) < most_ambiguous_split) │ │ │ │ │ │ 01039 │ │ │ │ │ │ most_ambiguous_split = fabs(d1sq-d2sq); │ │ │ │ │ │ 01040 │ │ │ │ │ │ 01041 │ │ │ │ │ │ if (d1sqeta,v->phi); │ │ │ │ │ │ 01067 │ │ │ │ │ │ } │ │ │ │ │ │ -while (i2erase(it_j1); │ │ │ │ │ │ 01090 │ │ │ │ │ │ candidates->erase(it_j2); │ │ │ │ │ │ 01091 │ │ │ │ │ │ -01092 │ │ │ │ │ │ // reinsert new ones │ │ │ │ │ │ +01092 │ │ │ │ │ │ 01093 │ │ │ │ │ │ insert(jet1); │ │ │ │ │ │ 01094 │ │ │ │ │ │ insert(jet2); │ │ │ │ │ │ 01095 │ │ │ │ │ │ -return true; │ │ │ │ │ │ 01096 │ │ │ │ │ │ +return true; │ │ │ │ │ │ 01097 } │ │ │ │ │ │ 01098 │ │ │ │ │ │ 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){ │ │ │ │ │ │ 01107 │ │ │ │ │ │ Cjet jet; │ │ │ │ │ │ -01108 │ │ │ │ │ │ int i; │ │ │ │ │ │ +01108 │ │ │ │ │ │ 01109 │ │ │ │ │ │ // build new jet │ │ │ │ │ │ 01110 │ │ │ │ │ │ 01111 │ │ │ │ │ │ // note: particles within j1 & j2 have already been stored in indices │ │ │ │ │ │ 01112 │ │ │ │ │ │ for (i=0;irange, it_j2->range); │ │ │ │ │ │ 01121 │ │ │ │ │ │ -// remove old candidates │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.47 split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ +291 │ │ │ │ │ │ + │ │ │ │ │ │ 01122 │ │ │ │ │ │ +// remove old candidates │ │ │ │ │ │ 01123 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 01124 │ │ │ │ │ │ if (merge_identical_protocones){ │ │ │ │ │ │ 01125 │ │ │ │ │ │ cand_refs.erase(it_j1->v.ref); │ │ │ │ │ │ 01126 │ │ │ │ │ │ cand_refs.erase(it_j2->v.ref); │ │ │ │ │ │ @@ -27372,16 +27352,16 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 01128 #endif │ │ │ │ │ │ 01129 │ │ │ │ │ │ candidates->erase(it_j1); │ │ │ │ │ │ 01130 │ │ │ │ │ │ candidates->erase(it_j2); │ │ │ │ │ │ 01131 │ │ │ │ │ │ -// reinsert new candidate │ │ │ │ │ │ 01132 │ │ │ │ │ │ +// reinsert new candidate │ │ │ │ │ │ 01133 │ │ │ │ │ │ insert(jet); │ │ │ │ │ │ 01134 │ │ │ │ │ │ return true; │ │ │ │ │ │ 01135 │ │ │ │ │ │ 01136 } │ │ │ │ │ │ 01137 │ │ │ │ │ │ @@ -27392,112 +27372,102 @@ │ │ │ │ │ │ 01146 │ │ │ │ │ │ // same cone contents. We recall that this automatic merging of │ │ │ │ │ │ 01147 │ │ │ │ │ │ // identical protocones can lead to infrared-unsafe situations. │ │ │ │ │ │ 01148 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 01149 │ │ │ │ │ │ if ((merge_identical_protocones) && (!cand_refs.insert(jet.v.ref).second)) │ │ │ │ │ │ -01150 │ │ │ │ │ │ return false; │ │ │ │ │ │ +01150 │ │ │ │ │ │ 01151 #endif │ │ │ │ │ │ 01152 │ │ │ │ │ │ 01153 │ │ │ │ │ │ // check that the protojet has large enough pt │ │ │ │ │ │ 01154 │ │ │ │ │ │ if (jet.v.perp2()insert(jet); │ │ │ │ │ │ 01162 │ │ │ │ │ │ return true; │ │ │ │ │ │ 01163 │ │ │ │ │ │ 01164 } │ │ │ │ │ │ 01165 │ │ │ │ │ │ 01172 double Csplit_merge::get_sm_var2(Cmomentum &v, double &pt_tilde){ │ │ │ │ │ │ 01173 │ │ │ │ │ │ switch(ptcomparison.split_merge_scale) { │ │ │ │ │ │ +01174 │ │ │ │ │ │ case SM_pt: │ │ │ │ │ │ return v.perp2(); │ │ │ │ │ │ -01174 │ │ │ │ │ │ -01175 │ │ │ │ │ │ case SM_mt: │ │ │ │ │ │ return v.perpmass2(); │ │ │ │ │ │ -case SM_pttilde: return pt_tilde*pt_tilde; │ │ │ │ │ │ +01175 │ │ │ │ │ │ 01176 │ │ │ │ │ │ -01177 │ │ │ │ │ │ +case SM_pttilde: return pt_tilde*pt_tilde; │ │ │ │ │ │ case SM_Et: │ │ │ │ │ │ return v.Et2(); │ │ │ │ │ │ -default: │ │ │ │ │ │ +01177 │ │ │ │ │ │ 01178 │ │ │ │ │ │ -01179 │ │ │ │ │ │ +default: │ │ │ │ │ │ throw Csiscone_error("Unsupported split-merge scale choice: " │ │ │ │ │ │ +01179 │ │ │ │ │ │ 01180 │ │ │ │ │ │ + ptcomparison.SM_scale_name()); │ │ │ │ │ │ 01181 │ │ │ │ │ │ } │ │ │ │ │ │ 01182 │ │ │ │ │ │ -//return 0.0; │ │ │ │ │ │ 01183 │ │ │ │ │ │ +//return 0.0; │ │ │ │ │ │ 01184 } │ │ │ │ │ │ 01185 │ │ │ │ │ │ 01186 } │ │ │ │ │ │ │ │ │ │ │ │ 5.47 split_merge.h │ │ │ │ │ │ 00001 // -*- C++ -*00003 // File: split_merge.h │ │ │ │ │ │ -00004 // Description: header file for splitting/merging (contains the CJet class) │ │ │ │ │ │ +// │ │ │ │ │ │ +00004 // Description: header file for splitting/merging (contains the CJet 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 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 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 │ │ │ │ │ │ // │ │ │ │ │ │ +00019 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the │ │ │ │ │ │ // │ │ │ │ │ │ - │ │ │ │ │ │ - 292 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -27505,14 +27475,23 @@ │ │ │ │ │ │ 00024 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA // │ │ │ │ │ │ 00025 // │ │ │ │ │ │ // │ │ │ │ │ │ 00026 // $Revision:: 404 │ │ │ │ │ │ $// │ │ │ │ │ │ 00027 // $Date:: 2016-05-22 12:14:42 +0200 (Sun, 22 May 2016) │ │ │ │ │ │ $// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 292 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00029 │ │ │ │ │ │ 00030 #ifndef __SPH_SPLIT_MERGE_H__ │ │ │ │ │ │ 00031 #define __SPH_SPLIT_MERGE_H__ │ │ │ │ │ │ 00032 │ │ │ │ │ │ 00033 #include │ │ │ │ │ │ 00034 #include │ │ │ │ │ │ 00035 #include "geom_2d.h" │ │ │ │ │ │ @@ -27540,22 +27519,22 @@ │ │ │ │ │ │ double E_tilde; │ │ │ │ │ │ 00065 │ │ │ │ │ │ 00066 │ │ │ │ │ │ int n; │ │ │ │ │ │ 00067 │ │ │ │ │ │ std::vector contents; │ │ │ │ │ │ 00068 │ │ │ │ │ │ -double sm_var2; │ │ │ │ │ │ 00080 │ │ │ │ │ │ +double sm_var2; │ │ │ │ │ │ 00081 │ │ │ │ │ │ 00083 │ │ │ │ │ │ CSphtheta_phi_range range; │ │ │ │ │ │ 00084 │ │ │ │ │ │ -00089 │ │ │ │ │ │ int pass; │ │ │ │ │ │ +00089 │ │ │ │ │ │ 00090 }; │ │ │ │ │ │ 00091 │ │ │ │ │ │ 00094 │ │ │ │ │ │ 00096 bool jets_E_less(const CSphjet &j1, const CSphjet &j2); │ │ │ │ │ │ 00097 │ │ │ │ │ │ 00098 │ │ │ │ │ │ 00106 enum Esplit_merge_scale { │ │ │ │ │ │ @@ -27583,16 +27562,16 @@ │ │ │ │ │ │ std::vector * particles; │ │ │ │ │ │ 00130 │ │ │ │ │ │ std::vector * particles_norm2; │ │ │ │ │ │ 00131 │ │ │ │ │ │ 00133 │ │ │ │ │ │ bool operator()(const CSphjet &jet1, const CSphjet &jet2) const; │ │ │ │ │ │ 00134 │ │ │ │ │ │ -void get_difference(const CSphjet &j1, const CSphjet &j2, CSphmomentum *v, double *E_tilde) const; │ │ │ │ │ │ 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 │ │ │ │ │ │ @@ -27606,26 +27585,30 @@ │ │ │ │ │ │ 00175 class CSphsplit_merge{ │ │ │ │ │ │ 00176 public: │ │ │ │ │ │ 00178 │ │ │ │ │ │ CSphsplit_merge(); │ │ │ │ │ │ 00179 │ │ │ │ │ │ 00181 │ │ │ │ │ │ ~CSphsplit_merge(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.47 split_merge.h │ │ │ │ │ │ - │ │ │ │ │ │ 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); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.47 split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ 00204 │ │ │ │ │ │ 00208 │ │ │ │ │ │ 00209 │ │ │ │ │ │ 00221 │ │ │ │ │ │ 00222 │ │ │ │ │ │ 00223 │ │ │ │ │ │ 00224 │ │ │ │ │ │ @@ -27696,21 +27679,23 @@ │ │ │ │ │ │ 00374 │ │ │ │ │ │ 00375 │ │ │ │ │ │ 00382 │ │ │ │ │ │ 00383 │ │ │ │ │ │ 00391 │ │ │ │ │ │ 00392 │ │ │ │ │ │ 00393 │ │ │ │ │ │ +00401 │ │ │ │ │ │ +00402 │ │ │ │ │ │ +00403 │ │ │ │ │ │ +00415 │ │ │ │ │ │ +00416 │ │ │ │ │ │ +00425 │ │ │ │ │ │ +00426 │ │ │ │ │ │ +00433 │ │ │ │ │ │ │ │ │ │ │ │ -293 │ │ │ │ │ │ - │ │ │ │ │ │ -// initialisation functions // │ │ │ │ │ │ -int init(std::vector &_particles, std::vector *protocones, double R2, │ │ │ │ │ │ -double Emin=0.0); │ │ │ │ │ │ -int init_particles(std::vector &_particles); │ │ │ │ │ │ int init_pleft(); │ │ │ │ │ │ inline int set_E_weighted_splitting(bool _use_E_weighted_splitting){ │ │ │ │ │ │ use_E_weighted_splitting = _use_E_weighted_splitting; │ │ │ │ │ │ return 0; │ │ │ │ │ │ } │ │ │ │ │ │ // cleaning functions // │ │ │ │ │ │ int partial_clear(); │ │ │ │ │ │ @@ -27753,55 +27738,49 @@ │ │ │ │ │ │ int *indices; │ │ │ │ │ │ int idx_size; │ │ │ │ │ │ bool merge_identical_protocones; │ │ │ │ │ │ CSphsplit_merge_ptcomparison ptcomparison; │ │ │ │ │ │ double SM_var2_hardest_cut_off; │ │ │ │ │ │ double stable_cone_soft_E2_cutoff; │ │ │ │ │ │ private: │ │ │ │ │ │ +bool get_overlap(const CSphjet &j1, const CSphjet &j2, double *v); │ │ │ │ │ │ +bool split(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +bool insert(CSphjet &jet); │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ +293 │ │ │ │ │ │ + │ │ │ │ │ │ 294 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -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 │ │ │ │ │ │ -bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ -00425 │ │ │ │ │ │ -00426 │ │ │ │ │ │ -bool insert(CSphjet &jet); │ │ │ │ │ │ -00433 │ │ │ │ │ │ 00434 │ │ │ │ │ │ double get_sm_var2(CSphmomentum &v, double &E_tilde); │ │ │ │ │ │ 00441 │ │ │ │ │ │ 00442 │ │ │ │ │ │ -void compute_Etilde(CSphjet &j); │ │ │ │ │ │ 00444 │ │ │ │ │ │ +void compute_Etilde(CSphjet &j); │ │ │ │ │ │ 00445 │ │ │ │ │ │ // jet information │ │ │ │ │ │ 00446 │ │ │ │ │ │ 00448 #ifdef SISCONE_USES_UNIQUE_PTR_AS_AUTO_PTR │ │ │ │ │ │ 00449 │ │ │ │ │ │ std::unique_ptr > candidates; │ │ │ │ │ │ 00450 #else │ │ │ │ │ │ 00451 │ │ │ │ │ │ std::auto_ptr > candidates; │ │ │ │ │ │ 00452 #endif │ │ │ │ │ │ 00453 │ │ │ │ │ │ -double E_min; │ │ │ │ │ │ 00455 │ │ │ │ │ │ +double E_min; │ │ │ │ │ │ 00456 │ │ │ │ │ │ -00462 │ │ │ │ │ │ bool use_E_weighted_splitting; │ │ │ │ │ │ +00462 │ │ │ │ │ │ 00463 │ │ │ │ │ │ const Cuser_scale_base *_user_scale; │ │ │ │ │ │ 00466 │ │ │ │ │ │ 00467 │ │ │ │ │ │ 00468 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 00470 │ │ │ │ │ │ std::set cand_refs; │ │ │ │ │ │ @@ -27876,42 +27855,42 @@ │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 const int CJET_INEXISTENT_PASS = -2; │ │ │ │ │ │ 00044 │ │ │ │ │ │ 00054 class Cjet{ │ │ │ │ │ │ 00055 public: │ │ │ │ │ │ 00057 │ │ │ │ │ │ Cjet(); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.48 split_merge.h │ │ │ │ │ │ - │ │ │ │ │ │ -295 │ │ │ │ │ │ - │ │ │ │ │ │ 00058 │ │ │ │ │ │ 00060 │ │ │ │ │ │ ~Cjet(); │ │ │ │ │ │ 00061 │ │ │ │ │ │ 00062 │ │ │ │ │ │ Cmomentum v; │ │ │ │ │ │ -double pt_tilde; │ │ │ │ │ │ 00063 │ │ │ │ │ │ -00064 │ │ │ │ │ │ +double pt_tilde; │ │ │ │ │ │ int n; │ │ │ │ │ │ +00064 │ │ │ │ │ │ 00065 │ │ │ │ │ │ std::vector contents; │ │ │ │ │ │ 00066 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.48 split_merge.h │ │ │ │ │ │ + │ │ │ │ │ │ +295 │ │ │ │ │ │ + │ │ │ │ │ │ 00073 │ │ │ │ │ │ double sm_var2; │ │ │ │ │ │ 00074 │ │ │ │ │ │ 00076 │ │ │ │ │ │ Ceta_phi_range range; │ │ │ │ │ │ 00077 │ │ │ │ │ │ -00082 │ │ │ │ │ │ int pass; │ │ │ │ │ │ +00082 │ │ │ │ │ │ 00083 }; │ │ │ │ │ │ 00084 │ │ │ │ │ │ 00086 bool jets_pt_less(const Cjet &j1, const Cjet &j2); │ │ │ │ │ │ 00087 │ │ │ │ │ │ 00088 │ │ │ │ │ │ 00096 enum Esplit_merge_scale { │ │ │ │ │ │ 00097 │ │ │ │ │ │ @@ -27931,24 +27910,24 @@ │ │ │ │ │ │ 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);} │ │ │ │ │ │ +00124 │ │ │ │ │ │ 00125 │ │ │ │ │ │ 00126 │ │ │ │ │ │ std::vector * particles; │ │ │ │ │ │ 00127 │ │ │ │ │ │ std::vector * pt; │ │ │ │ │ │ 00128 │ │ │ │ │ │ -bool operator()(const Cjet &jet1, const Cjet &jet2) const; │ │ │ │ │ │ 00130 │ │ │ │ │ │ +bool operator()(const Cjet &jet1, const Cjet &jet2) const; │ │ │ │ │ │ 00131 │ │ │ │ │ │ void get_difference(const Cjet &j1, const Cjet &j2, Cmomentum *v, double *pt_tilde) const; │ │ │ │ │ │ 00143 │ │ │ │ │ │ 00144 │ │ │ │ │ │ 00163 │ │ │ │ │ │ Esplit_merge_scale split_merge_scale; │ │ │ │ │ │ 00164 }; │ │ │ │ │ │ @@ -27966,208 +27945,207 @@ │ │ │ │ │ │ 00183 │ │ │ │ │ │ Csplit_merge(); │ │ │ │ │ │ 00184 │ │ │ │ │ │ 00186 │ │ │ │ │ │ ~Csplit_merge(); │ │ │ │ │ │ 00187 │ │ │ │ │ │ 00188 │ │ │ │ │ │ -00190 │ │ │ │ │ │ // initialisation functions // │ │ │ │ │ │ +00190 │ │ │ │ │ │ 00192 │ │ │ │ │ │ 00201 │ │ │ │ │ │ int init(std::vector &_particles, std::vector *protocones, double R2, double │ │ │ │ │ │ ptmin=0.0); │ │ │ │ │ │ 00202 │ │ │ │ │ │ int init_particles(std::vector &_particles); │ │ │ │ │ │ 00208 │ │ │ │ │ │ 00209 │ │ │ │ │ │ -00213 │ │ │ │ │ │ int init_pleft(); │ │ │ │ │ │ +00213 │ │ │ │ │ │ 00214 │ │ │ │ │ │ inline int set_pt_weighted_splitting(bool _use_pt_weighted_splitting){ │ │ │ │ │ │ 00226 │ │ │ │ │ │ 00227 │ │ │ │ │ │ use_pt_weighted_splitting = _use_pt_weighted_splitting; │ │ │ │ │ │ return 0; │ │ │ │ │ │ 00228 │ │ │ │ │ │ 00229 │ │ │ │ │ │ } │ │ │ │ │ │ 00230 │ │ │ │ │ │ 00232 │ │ │ │ │ │ // cleaning functions // │ │ │ │ │ │ 00234 │ │ │ │ │ │ -00236 │ │ │ │ │ │ int partial_clear(); │ │ │ │ │ │ +00236 │ │ │ │ │ │ 00237 │ │ │ │ │ │ int full_clear(); │ │ │ │ │ │ 00239 │ │ │ │ │ │ 00240 │ │ │ │ │ │ // user-defined stable-cone ordering // │ │ │ │ │ │ 00242 │ │ │ │ │ │ 00244 │ │ │ │ │ │ -class Cuser_scale_base{ │ │ │ │ │ │ 00250 │ │ │ │ │ │ -00251 │ │ │ │ │ │ +class Cuser_scale_base{ │ │ │ │ │ │ public: │ │ │ │ │ │ -virtual ~Cuser_scale_base(){} │ │ │ │ │ │ +00251 │ │ │ │ │ │ 00253 │ │ │ │ │ │ +virtual ~Cuser_scale_base(){} │ │ │ │ │ │ 00254 │ │ │ │ │ │ -00259 │ │ │ │ │ │ virtual double operator()(const Cjet & jet) const = 0; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 296 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ +00259 │ │ │ │ │ │ 00260 │ │ │ │ │ │ virtual bool is_larger(const Cjet & a, const Cjet & b) const{ │ │ │ │ │ │ 00271 │ │ │ │ │ │ 00272 │ │ │ │ │ │ return (a.sm_var2 > b.sm_var2); │ │ │ │ │ │ 00273 │ │ │ │ │ │ } │ │ │ │ │ │ 00274 │ │ │ │ │ │ }; │ │ │ │ │ │ 00275 │ │ │ │ │ │ void set_user_scale(const Cuser_scale_base * user_scale_in){ │ │ │ │ │ │ 00280 │ │ │ │ │ │ 00281 │ │ │ │ │ │ _user_scale = user_scale_in; │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 296 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00282 │ │ │ │ │ │ } │ │ │ │ │ │ 00283 │ │ │ │ │ │ -00285 │ │ │ │ │ │ const Cuser_scale_base * user_scale() const { return _user_scale; } │ │ │ │ │ │ +00285 │ │ │ │ │ │ 00286 │ │ │ │ │ │ 00287 │ │ │ │ │ │ -// main parts of the algorithm // │ │ │ │ │ │ 00289 │ │ │ │ │ │ +// main parts of the algorithm // │ │ │ │ │ │ 00291 │ │ │ │ │ │ 00299 │ │ │ │ │ │ int merge_collinear_and_remove_soft(); │ │ │ │ │ │ 00300 │ │ │ │ │ │ int add_protocones(std::vector *protocones, double R2, double ptmin=0.0); │ │ │ │ │ │ 00308 │ │ │ │ │ │ 00309 │ │ │ │ │ │ int add_hardest_protocone_to_jets(std::vector *protocones, double R2, double ptmin=0.0); │ │ │ │ │ │ 00320 │ │ │ │ │ │ 00321 │ │ │ │ │ │ int perform(double overlap_tshold, double ptmin=0.0); │ │ │ │ │ │ 00331 │ │ │ │ │ │ 00332 │ │ │ │ │ │ 00333 │ │ │ │ │ │ -// save and debug functions // │ │ │ │ │ │ 00335 │ │ │ │ │ │ +// save and debug functions // │ │ │ │ │ │ 00337 │ │ │ │ │ │ -00340 │ │ │ │ │ │ int save_contents(FILE *flux); │ │ │ │ │ │ +00340 │ │ │ │ │ │ 00341 │ │ │ │ │ │ int show(); │ │ │ │ │ │ 00343 │ │ │ │ │ │ 00344 │ │ │ │ │ │ -// particle information │ │ │ │ │ │ 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; │ │ │ │ │ │ -int n_pass; │ │ │ │ │ │ 00352 │ │ │ │ │ │ +int n_pass; │ │ │ │ │ │ 00353 │ │ │ │ │ │ double most_ambiguous_split; │ │ │ │ │ │ 00357 │ │ │ │ │ │ 00358 │ │ │ │ │ │ -00359 │ │ │ │ │ │ // jets information │ │ │ │ │ │ +00359 │ │ │ │ │ │ 00360 │ │ │ │ │ │ std::vector jets; │ │ │ │ │ │ 00361 │ │ │ │ │ │ // working entries │ │ │ │ │ │ 00362 │ │ │ │ │ │ 00363 │ │ │ │ │ │ int *indices; │ │ │ │ │ │ -int idx_size; │ │ │ │ │ │ 00364 │ │ │ │ │ │ +int idx_size; │ │ │ │ │ │ 00365 │ │ │ │ │ │ -00374 │ │ │ │ │ │ bool merge_identical_protocones; │ │ │ │ │ │ +00374 │ │ │ │ │ │ 00375 │ │ │ │ │ │ 00377 │ │ │ │ │ │ Csplit_merge_ptcomparison ptcomparison; │ │ │ │ │ │ 00378 │ │ │ │ │ │ double SM_var2_hardest_cut_off; │ │ │ │ │ │ 00385 │ │ │ │ │ │ 00386 │ │ │ │ │ │ double stable_cone_soft_pt2_cutoff; │ │ │ │ │ │ 00394 │ │ │ │ │ │ 00395 │ │ │ │ │ │ 00396 private: │ │ │ │ │ │ -00404 │ │ │ │ │ │ bool get_overlap(const Cjet &j1, const Cjet &j2, double *v); │ │ │ │ │ │ +00404 │ │ │ │ │ │ 00405 │ │ │ │ │ │ 00406 │ │ │ │ │ │ -00418 │ │ │ │ │ │ bool split(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ +00418 │ │ │ │ │ │ 00419 │ │ │ │ │ │ bool merge(cjet_iterator &it_j1, cjet_iterator &it_j2); │ │ │ │ │ │ 00428 │ │ │ │ │ │ 00429 │ │ │ │ │ │ bool insert(Cjet &jet); │ │ │ │ │ │ 00436 │ │ │ │ │ │ 00437 │ │ │ │ │ │ double get_sm_var2(Cmomentum &v, double &pt_tilde); │ │ │ │ │ │ 00444 │ │ │ │ │ │ 00445 │ │ │ │ │ │ -// jet information │ │ │ │ │ │ 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 │ │ │ │ │ │ -double pt_min2; │ │ │ │ │ │ 00455 │ │ │ │ │ │ +double pt_min2; │ │ │ │ │ │ 00456 │ │ │ │ │ │ bool use_pt_weighted_splitting; │ │ │ │ │ │ 00462 │ │ │ │ │ │ 00463 │ │ │ │ │ │ const Cuser_scale_base *_user_scale; │ │ │ │ │ │ 00466 │ │ │ │ │ │ 00467 │ │ │ │ │ │ 00468 #ifdef ALLOW_MERGE_IDENTICAL_PROTOCONES │ │ │ │ │ │ 00470 │ │ │ │ │ │ std::set cand_refs; │ │ │ │ │ │ 00471 #endif │ │ │ │ │ │ 00472 }; │ │ │ │ │ │ 00473 │ │ │ │ │ │ 00474 } │ │ │ │ │ │ +00475 │ │ │ │ │ │ +00476 │ │ │ │ │ │ +00477 #endif │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 5.49 vicinity.cpp │ │ │ │ │ │ │ │ │ │ │ │ 297 │ │ │ │ │ │ │ │ │ │ │ │ -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. │ │ │ │ │ │ @@ -28234,16 +28212,16 @@ │ │ │ │ │ │ * │ │ │ │ │ │ 00042 * of a parent point. │ │ │ │ │ │ * │ │ │ │ │ │ 00043 *************************************************************/ │ │ │ │ │ │ 00044 │ │ │ │ │ │ 00045 // ordering pointers to CSphvicinity_elm │ │ │ │ │ │ 00046 //--------------------------------------00047 bool ve_less(CSphvicinity_elm *ve1, CSphvicinity_elm *ve2){ │ │ │ │ │ │ -return ve1->angle < ve2->angle; │ │ │ │ │ │ 00048 │ │ │ │ │ │ +return ve1->angle < ve2->angle; │ │ │ │ │ │ 00049 } │ │ │ │ │ │ 00050 │ │ │ │ │ │ 00051 │ │ │ │ │ │ 00052 /************************************************************* │ │ │ │ │ │ 00053 * CSphvicinity implementation │ │ │ │ │ │ * │ │ │ │ │ │ 00054 * list of element in the vicinity of a parent. │ │ │ │ │ │ @@ -28274,100 +28252,100 @@ │ │ │ │ │ │ 00072 │ │ │ │ │ │ 00073 } │ │ │ │ │ │ 00074 │ │ │ │ │ │ 00075 // constructor with initialisation │ │ │ │ │ │ 00076 //--------------------------------00077 CSphvicinity::CSphvicinity(vector &_particle_list){ │ │ │ │ │ │ 00078 │ │ │ │ │ │ parent = NULL; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ - 298 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00079 │ │ │ │ │ │ ve_list = NULL; │ │ │ │ │ │ 00080 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00081 │ │ │ │ │ │ quadtree = NULL; │ │ │ │ │ │ 00082 #endif │ │ │ │ │ │ 00083 │ │ │ │ │ │ cosVR = VR2 = tan2R = VR = 0.0; │ │ │ │ │ │ 00084 │ │ │ │ │ │ 00085 │ │ │ │ │ │ set_particle_list(_particle_list); │ │ │ │ │ │ 00086 } │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ + 298 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00087 │ │ │ │ │ │ 00088 // default destructor │ │ │ │ │ │ 00089 //-------------------00090 CSphvicinity::~CSphvicinity(){ │ │ │ │ │ │ -00091 │ │ │ │ │ │ if (ve_list!=NULL) │ │ │ │ │ │ -delete[] ve_list; │ │ │ │ │ │ +00091 │ │ │ │ │ │ 00092 │ │ │ │ │ │ +delete[] ve_list; │ │ │ │ │ │ 00093 │ │ │ │ │ │ 00094 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00095 │ │ │ │ │ │ if (quadtree!=NULL) │ │ │ │ │ │ 00096 │ │ │ │ │ │ delete quadtree; │ │ │ │ │ │ 00097 #endif │ │ │ │ │ │ 00098 } │ │ │ │ │ │ 00099 │ │ │ │ │ │ 00100 /* │ │ │ │ │ │ 00101 * set the particle_list │ │ │ │ │ │ -00102 * - particle_list │ │ │ │ │ │ list of particles (type CSphmomentum) │ │ │ │ │ │ -number of particles in the list │ │ │ │ │ │ +00102 * - particle_list │ │ │ │ │ │ 00103 * - n │ │ │ │ │ │ +number of particles in the list │ │ │ │ │ │ 00104 ************************************************************/ │ │ │ │ │ │ 00105 void CSphvicinity::set_particle_list(vector &_particle_list){ │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ 00106 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ 00107 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00108 │ │ │ │ │ │ double eta_max=0.0; │ │ │ │ │ │ 00109 #endif │ │ │ │ │ │ 00110 │ │ │ │ │ │ -// if the particle list is not empty, destroy it ! │ │ │ │ │ │ 00111 │ │ │ │ │ │ +// if the particle list is not empty, destroy it ! │ │ │ │ │ │ 00112 │ │ │ │ │ │ if (ve_list!=NULL){ │ │ │ │ │ │ 00113 │ │ │ │ │ │ delete[] ve_list; │ │ │ │ │ │ 00114 │ │ │ │ │ │ } │ │ │ │ │ │ 00115 │ │ │ │ │ │ vicinity.clear(); │ │ │ │ │ │ 00116 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00117 │ │ │ │ │ │ if (quadtree!=NULL) │ │ │ │ │ │ -delete quadtree; │ │ │ │ │ │ 00118 │ │ │ │ │ │ +delete quadtree; │ │ │ │ │ │ 00119 #endif │ │ │ │ │ │ 00120 │ │ │ │ │ │ -// allocate memory array for particles │ │ │ │ │ │ 00121 │ │ │ │ │ │ +// allocate memory array for particles │ │ │ │ │ │ 00122 │ │ │ │ │ │ // Note: - we compute max for |eta| │ │ │ │ │ │ 00123 │ │ │ │ │ │ // │ │ │ │ │ │ - we allocate indices to particles │ │ │ │ │ │ 00124 │ │ │ │ │ │ n_part = 0; │ │ │ │ │ │ 00125 │ │ │ │ │ │ plist.clear(); │ │ │ │ │ │ 00126 │ │ │ │ │ │ pincluded.clear(); │ │ │ │ │ │ 00127 │ │ │ │ │ │ for (i=0;i<(int) _particle_list.size();i++){ │ │ │ │ │ │ -// if a particle is colinear with the beam (infinite rapidity) │ │ │ │ │ │ 00128 │ │ │ │ │ │ +// if a particle is colinear with the beam (infinite rapidity) │ │ │ │ │ │ 00129 │ │ │ │ │ │ // we do not take it into account │ │ │ │ │ │ 00130 │ │ │ │ │ │ //if (fabs(_particle_list[i].pz)!=_particle_list[i].E){ │ │ │ │ │ │ 00131 │ │ │ │ │ │ plist.push_back(_particle_list[i]); │ │ │ │ │ │ 00132 │ │ │ │ │ │ @@ -28380,27 +28358,27 @@ │ │ │ │ │ │ 00136 │ │ │ │ │ │ // Hence, it is not required here any longer. │ │ │ │ │ │ 00137 │ │ │ │ │ │ // plist[n_part].parent_index = i; │ │ │ │ │ │ 00138 │ │ │ │ │ │ plist[n_part].index = n_part; │ │ │ │ │ │ 00139 │ │ │ │ │ │ -00140 │ │ │ │ │ │ // make sure the reference is randomly created │ │ │ │ │ │ +00140 │ │ │ │ │ │ 00141 │ │ │ │ │ │ plist[n_part].ref.randomize(); │ │ │ │ │ │ 00142 │ │ │ │ │ │ 00143 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00144 │ │ │ │ │ │ if (fabs(plist[n_part].eta)>eta_max) eta_max=fabs(plist[n_part].eta); │ │ │ │ │ │ 00145 #endif │ │ │ │ │ │ 00146 │ │ │ │ │ │ n_part++; │ │ │ │ │ │ -//} │ │ │ │ │ │ 00147 │ │ │ │ │ │ +//} │ │ │ │ │ │ 00148 │ │ │ │ │ │ } │ │ │ │ │ │ 00149 │ │ │ │ │ │ // allocate quadtree and vicinity_elm list │ │ │ │ │ │ 00150 │ │ │ │ │ │ 00151 │ │ │ │ │ │ // note: we set phi in [-pi:pi] as it is the natural range for atan2! │ │ │ │ │ │ @@ -28409,51 +28387,51 @@ │ │ │ │ │ │ 00153 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00154 │ │ │ │ │ │ eta_max+=0.1; │ │ │ │ │ │ 00155 │ │ │ │ │ │ quadtree = new siscone::Cquadtree(0.0, 0.0, eta_max, M_PI); │ │ │ │ │ │ 00156 #endif │ │ │ │ │ │ 00157 │ │ │ │ │ │ -// append particle to the vicinity_elm list │ │ │ │ │ │ 00158 │ │ │ │ │ │ +// append particle to the vicinity_elm list │ │ │ │ │ │ 00159 │ │ │ │ │ │ j = 0; │ │ │ │ │ │ 00160 │ │ │ │ │ │ for (i=0;iadd(&plist[i]); │ │ │ │ │ │ 00163 #endif │ │ │ │ │ │ 00164 │ │ │ │ │ │ ve_list[j].v = ve_list[j+1].v = &plist[i]; │ │ │ │ │ │ 00165 │ │ │ │ │ │ ve_list[j].is_inside = ve_list[j+1].is_inside = &(pincluded[i]); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.49 vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00166 │ │ │ │ │ │ j+=2; │ │ │ │ │ │ 00167 │ │ │ │ │ │ } │ │ │ │ │ │ 00168 │ │ │ │ │ │ 00169 } │ │ │ │ │ │ 00170 │ │ │ │ │ │ 00171 │ │ │ │ │ │ 00172 /* │ │ │ │ │ │ 00173 * build the vicinity list from a list of points. │ │ │ │ │ │ -00174 * - _parent │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.49 vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ reference particle │ │ │ │ │ │ +00174 * - _parent │ │ │ │ │ │ 00175 * - _VR │ │ │ │ │ │ vicinity radius │ │ │ │ │ │ 00176 ************************************************************/ │ │ │ │ │ │ 00177 void CSphvicinity::build(CSphmomentum *_parent, double _VR){ │ │ │ │ │ │ -00178 │ │ │ │ │ │ int i; │ │ │ │ │ │ +00178 │ │ │ │ │ │ 00179 │ │ │ │ │ │ // set parent and radius │ │ │ │ │ │ 00180 │ │ │ │ │ │ 00181 │ │ │ │ │ │ parent = _parent; │ │ │ │ │ │ 00182 │ │ │ │ │ │ 00183 │ │ │ │ │ │ @@ -28520,100 +28498,100 @@ │ │ │ │ │ │ 00216 │ │ │ │ │ │ vicinity_size = vicinity.size(); │ │ │ │ │ │ 00217 } │ │ │ │ │ │ 00218 │ │ │ │ │ │ 00219 │ │ │ │ │ │ 00221 //TODO// │ │ │ │ │ │ 00222 inline double sort_angle(double s, double c){ │ │ │ │ │ │ -if (s==0) return (c>0) ? 0.0 : 2.0; │ │ │ │ │ │ 00223 │ │ │ │ │ │ -00224 │ │ │ │ │ │ +if (s==0) return (c>0) ? 0.0 : 2.0; │ │ │ │ │ │ double t=c/s; │ │ │ │ │ │ -return (s>0) ? 1-t/(1+fabs(t)) : 3-t/(1+fabs(t)); │ │ │ │ │ │ +00224 │ │ │ │ │ │ 00225 │ │ │ │ │ │ +return (s>0) ? 1-t/(1+fabs(t)) : 3-t/(1+fabs(t)); │ │ │ │ │ │ 00226 } │ │ │ │ │ │ 00227 │ │ │ │ │ │ 00228 │ │ │ │ │ │ 00229 /* │ │ │ │ │ │ 00230 * append a particle to the ’vicinity’ list after │ │ │ │ │ │ 00231 * having computed the angular-ordering quantities │ │ │ │ │ │ -00232 * - v │ │ │ │ │ │ vector to test │ │ │ │ │ │ +00232 * - v │ │ │ │ │ │ 00233 **********************************************************/ │ │ │ │ │ │ 00234 void CSphvicinity::append_to_vicinity(CSphmomentum *v){ │ │ │ │ │ │ -// skip the particle itself) │ │ │ │ │ │ 00235 │ │ │ │ │ │ +// skip the particle itself) │ │ │ │ │ │ 00236 │ │ │ │ │ │ if (v==parent) │ │ │ │ │ │ -return; │ │ │ │ │ │ 00237 │ │ │ │ │ │ +return; │ │ │ │ │ │ 00238 │ │ │ │ │ │ int i=2*(v->index); │ │ │ │ │ │ 00239 │ │ │ │ │ │ 00240 │ │ │ │ │ │ -00241 │ │ │ │ │ │ // compute the distance of the i-th particle with the parent │ │ │ │ │ │ +00241 │ │ │ │ │ │ 00242 │ │ │ │ │ │ double dot = dot_product3(parent_centre,*v); │ │ │ │ │ │ 00243 │ │ │ │ │ │ CSph3vector vnormal = *v; │ │ │ │ │ │ 00244 │ │ │ │ │ │ vnormal/=v->_norm; │ │ │ │ │ │ 00245 │ │ │ │ │ │ dot/=v->_norm; │ │ │ │ │ │ 00246 │ │ │ │ │ │ -00247 │ │ │ │ │ │ // really check if the distance is less than VR │ │ │ │ │ │ +00247 │ │ │ │ │ │ 00248 │ │ │ │ │ │ if (dot>cosVR){ │ │ │ │ │ │ 00249 │ │ │ │ │ │ CSph3vector cross = cross_product3(parent_centre,vnormal); │ │ │ │ │ │ 00250 │ │ │ │ │ │ -// for the centres │ │ │ │ │ │ 00251 │ │ │ │ │ │ +// for the centres │ │ │ │ │ │ 00252 │ │ │ │ │ │ CSph3vector median = (parent_centre+vnormal); │ │ │ │ │ │ 00253 │ │ │ │ │ │ double amplT = sqrt((tan2R*(1+dot)+(dot-1))*(1+dot)); │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -299 │ │ │ │ │ │ - │ │ │ │ │ │ - 300 │ │ │ │ │ │ - │ │ │ │ │ │ 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)); │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +299 │ │ │ │ │ │ + │ │ │ │ │ │ + 300 │ │ │ │ │ │ + │ │ │ │ │ │ 00262 │ │ │ │ │ │ 00263 │ │ │ │ │ │ 00264 │ │ │ │ │ │ 00265 │ │ │ │ │ │ 00266 │ │ │ │ │ │ 00267 │ │ │ │ │ │ 00268 │ │ │ │ │ │ 00269 │ │ │ │ │ │ 00270 │ │ │ │ │ │ 00271 │ │ │ │ │ │ 00272 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -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; │ │ │ │ │ │ @@ -28638,32 +28616,32 @@ │ │ │ │ │ │ 00280 │ │ │ │ │ │ // P = parent; C = child; O = Origin (center of circle) │ │ │ │ │ │ 00281 │ │ │ │ │ │ CSph3vector OP = parent_centre - ve_list[i+1].centre; │ │ │ │ │ │ 00282 │ │ │ │ │ │ CSph3vector OC = vnormal - ve_list[i+1].centre; │ │ │ │ │ │ 00283 │ │ │ │ │ │ -// two sources of error are (GPS CCN29-19) epsilon/(R sin theta) │ │ │ │ │ │ 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 │ │ │ │ │ │ 00286 │ │ │ │ │ │ // out, it is the _smaller_ of the two that is relevant [NB have │ │ │ │ │ │ 00287 │ │ │ │ │ │ // changed definition of theta here relative to that used in │ │ │ │ │ │ 00288 │ │ │ │ │ │ // CCN29] [NB2: write things so as to avoid zero denominators and │ │ │ │ │ │ 00289 │ │ │ │ │ │ // to minimize the multiplications, divisions and above all sqrts │ │ │ │ │ │ 00290 │ │ │ │ │ │ // -- that means that c & s are defined including a factor of VR2] │ │ │ │ │ │ 00291 │ │ │ │ │ │ double inv_err1 = cross_product3(OP,OC)._norm * inv_R_EPS_COCIRC; │ │ │ │ │ │ -double inv_err2_sq = (D2_R-dot_product3(OP,OC)) * inv_R_2EPS_COCIRC; │ │ │ │ │ │ 00292 │ │ │ │ │ │ +double inv_err2_sq = (D2_R-dot_product3(OP,OC)) * inv_R_2EPS_COCIRC; │ │ │ │ │ │ 00293 │ │ │ │ │ │ ve_list[i].cocircular_range = siscone::pow2(inv_err1) > inv_err2_sq ? │ │ │ │ │ │ 00294 │ │ │ │ │ │ 1.0/inv_err1 : │ │ │ │ │ │ 00295 │ │ │ │ │ │ sqrt(1.0/inv_err2_sq); │ │ │ │ │ │ 00296 │ │ │ │ │ │ @@ -28725,36 +28703,36 @@ │ │ │ │ │ │ 00027 #include "vicinity.h" │ │ │ │ │ │ 00028 #include │ │ │ │ │ │ 00029 #include │ │ │ │ │ │ 00030 #include │ │ │ │ │ │ 00031 │ │ │ │ │ │ 00032 namespace siscone{ │ │ │ │ │ │ 00033 │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.50 vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ 00034 using namespace std; │ │ │ │ │ │ 00035 │ │ │ │ │ │ 00036 /************************************************************* │ │ │ │ │ │ 00037 * Cvicinity_elm implementation │ │ │ │ │ │ * │ │ │ │ │ │ 00038 * element in the vicinity of a parent. │ │ │ │ │ │ * │ │ │ │ │ │ 00039 * class used to manage one points in the vicinity │ │ │ │ │ │ * │ │ │ │ │ │ 00040 * of a parent point. │ │ │ │ │ │ * │ │ │ │ │ │ 00041 *************************************************************/ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.50 vicinity.cpp │ │ │ │ │ │ + │ │ │ │ │ │ 00042 │ │ │ │ │ │ 00043 // ordering pointers to Cvicinity_elm │ │ │ │ │ │ 00044 //-----------------------------------00045 bool ve_less(Cvicinity_elm *ve1, Cvicinity_elm *ve2){ │ │ │ │ │ │ -00046 │ │ │ │ │ │ return ve1->angle < ve2->angle; │ │ │ │ │ │ +00046 │ │ │ │ │ │ 00047 } │ │ │ │ │ │ 00048 │ │ │ │ │ │ 00049 │ │ │ │ │ │ 00050 /************************************************************* │ │ │ │ │ │ 00051 * Cvicinity implementation │ │ │ │ │ │ * │ │ │ │ │ │ 00052 * list of element in the vicinity of a parent. │ │ │ │ │ │ @@ -28802,94 +28780,94 @@ │ │ │ │ │ │ set_particle_list(_particle_list); │ │ │ │ │ │ 00084 } │ │ │ │ │ │ 00085 │ │ │ │ │ │ 00086 // default destructor │ │ │ │ │ │ 00087 //-------------------00088 Cvicinity::~Cvicinity(){ │ │ │ │ │ │ 00089 │ │ │ │ │ │ if (ve_list!=NULL) │ │ │ │ │ │ -delete[] ve_list; │ │ │ │ │ │ 00090 │ │ │ │ │ │ +delete[] ve_list; │ │ │ │ │ │ 00091 │ │ │ │ │ │ 00092 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00093 │ │ │ │ │ │ if (quadtree!=NULL) │ │ │ │ │ │ 00094 │ │ │ │ │ │ delete quadtree; │ │ │ │ │ │ 00095 #endif │ │ │ │ │ │ 00096 } │ │ │ │ │ │ 00097 │ │ │ │ │ │ 00098 /* │ │ │ │ │ │ 00099 * set the particle_list │ │ │ │ │ │ 00100 * - particle_list │ │ │ │ │ │ list of particles (type Cmomentum) │ │ │ │ │ │ -number of particles in the list │ │ │ │ │ │ 00101 * - n │ │ │ │ │ │ +number of particles in the list │ │ │ │ │ │ 00102 ************************************************************/ │ │ │ │ │ │ 00103 void Cvicinity::set_particle_list(vector &_particle_list){ │ │ │ │ │ │ -int i,j; │ │ │ │ │ │ 00104 │ │ │ │ │ │ +int i,j; │ │ │ │ │ │ 00105 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00106 │ │ │ │ │ │ double eta_max=0.0; │ │ │ │ │ │ 00107 #endif │ │ │ │ │ │ 00108 │ │ │ │ │ │ -// if the particle list is not empty, destroy it ! │ │ │ │ │ │ 00109 │ │ │ │ │ │ +// if the particle list is not empty, destroy it ! │ │ │ │ │ │ 00110 │ │ │ │ │ │ if (ve_list!=NULL){ │ │ │ │ │ │ -delete[] ve_list; │ │ │ │ │ │ 00111 │ │ │ │ │ │ +delete[] ve_list; │ │ │ │ │ │ 00112 │ │ │ │ │ │ } │ │ │ │ │ │ 00113 │ │ │ │ │ │ vicinity.clear(); │ │ │ │ │ │ 00114 #ifdef USE_QUADTREE_FOR_STABILITY_TEST │ │ │ │ │ │ 00115 │ │ │ │ │ │ if (quadtree!=NULL) │ │ │ │ │ │ -delete quadtree; │ │ │ │ │ │ 00116 │ │ │ │ │ │ +delete quadtree; │ │ │ │ │ │ 00117 #endif │ │ │ │ │ │ 00118 │ │ │ │ │ │ // allocate memory array for particles │ │ │ │ │ │ 00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ // Note: - we compute max for |eta| │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -301 │ │ │ │ │ │ - │ │ │ │ │ │ - 302 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00121 │ │ │ │ │ │ // │ │ │ │ │ │ - we allocate indices to particles │ │ │ │ │ │ 00122 │ │ │ │ │ │ n_part = 0; │ │ │ │ │ │ 00123 │ │ │ │ │ │ plist.clear(); │ │ │ │ │ │ 00124 │ │ │ │ │ │ pincluded.clear(); │ │ │ │ │ │ 00125 │ │ │ │ │ │ for (i=0;i<(int) _particle_list.size();i++){ │ │ │ │ │ │ -00126 │ │ │ │ │ │ // if a particle is colinear with the beam (infinite rapidity) │ │ │ │ │ │ +00126 │ │ │ │ │ │ 00127 │ │ │ │ │ │ // we do not take it into account │ │ │ │ │ │ 00128 │ │ │ │ │ │ if (fabs(_particle_list[i].pz)!=_particle_list[i].E){ │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +301 │ │ │ │ │ │ + │ │ │ │ │ │ + 302 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00129 │ │ │ │ │ │ plist.push_back(_particle_list[i]); │ │ │ │ │ │ 00130 │ │ │ │ │ │ pincluded.push_back(Cvicinity_inclusion()); // zero inclusion status │ │ │ │ │ │ 00131 │ │ │ │ │ │ -// the parent_index is handled in the split_merge because │ │ │ │ │ │ 00132 │ │ │ │ │ │ +// the parent_index is handled in the split_merge because │ │ │ │ │ │ 00133 │ │ │ │ │ │ // of our multiple-pass procedure. │ │ │ │ │ │ 00134 │ │ │ │ │ │ // Hence, it is not required here any longer. │ │ │ │ │ │ 00135 │ │ │ │ │ │ // plist[n_part].parent_index = i; │ │ │ │ │ │ 00136 │ │ │ │ │ │ @@ -28908,16 +28886,16 @@ │ │ │ │ │ │ 00145 │ │ │ │ │ │ n_part++; │ │ │ │ │ │ 00146 │ │ │ │ │ │ } │ │ │ │ │ │ 00147 │ │ │ │ │ │ } │ │ │ │ │ │ 00148 │ │ │ │ │ │ -00149 │ │ │ │ │ │ // allocate quadtree and vicinity_elm list │ │ │ │ │ │ +00149 │ │ │ │ │ │ 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; │ │ │ │ │ │ @@ -28925,16 +28903,16 @@ │ │ │ │ │ │ quadtree = new Cquadtree(0.0, 0.0, eta_max, M_PI); │ │ │ │ │ │ 00155 #endif │ │ │ │ │ │ 00156 │ │ │ │ │ │ 00157 │ │ │ │ │ │ // append particle to the vicinity_elm list │ │ │ │ │ │ 00158 │ │ │ │ │ │ j = 0; │ │ │ │ │ │ -00159 │ │ │ │ │ │ for (i=0;iadd(&plist[i]); │ │ │ │ │ │ 00162 #endif │ │ │ │ │ │ 00163 │ │ │ │ │ │ ve_list[j].v = ve_list[j+1].v = &plist[i]; │ │ │ │ │ │ 00164 │ │ │ │ │ │ @@ -28945,22 +28923,22 @@ │ │ │ │ │ │ } │ │ │ │ │ │ 00167 │ │ │ │ │ │ 00168 } │ │ │ │ │ │ 00169 │ │ │ │ │ │ 00170 │ │ │ │ │ │ 00171 /* │ │ │ │ │ │ 00172 * build the vicinity list from a list of points. │ │ │ │ │ │ -reference particle │ │ │ │ │ │ 00173 * - _parent │ │ │ │ │ │ -00174 * - _VR │ │ │ │ │ │ +reference particle │ │ │ │ │ │ vicinity radius │ │ │ │ │ │ +00174 * - _VR │ │ │ │ │ │ 00175 ************************************************************/ │ │ │ │ │ │ 00176 void Cvicinity::build(Cmomentum *_parent, double _VR){ │ │ │ │ │ │ -int i; │ │ │ │ │ │ 00177 │ │ │ │ │ │ +int i; │ │ │ │ │ │ 00178 │ │ │ │ │ │ // set parent and radius │ │ │ │ │ │ 00179 │ │ │ │ │ │ 00180 │ │ │ │ │ │ parent = _parent; │ │ │ │ │ │ 00181 │ │ │ │ │ │ VR = _VR; │ │ │ │ │ │ @@ -28972,16 +28950,16 @@ │ │ │ │ │ │ R │ │ │ │ │ │ = 0.5*VR; │ │ │ │ │ │ 00185 │ │ │ │ │ │ inv_R_EPS_COCIRC = 1.0 / R / EPSILON_COCIRCULAR; │ │ │ │ │ │ 00186 │ │ │ │ │ │ inv_R_2EPS_COCIRC = 0.5 / R / EPSILON_COCIRCULAR; │ │ │ │ │ │ 00187 │ │ │ │ │ │ -00188 │ │ │ │ │ │ // clear vicinity │ │ │ │ │ │ +00188 │ │ │ │ │ │ 00189 │ │ │ │ │ │ vicinity.clear(); │ │ │ │ │ │ 00190 │ │ │ │ │ │ // init parent variables │ │ │ │ │ │ 00191 │ │ │ │ │ │ 00192 │ │ │ │ │ │ pcx = parent->eta; │ │ │ │ │ │ @@ -29004,57 +28982,57 @@ │ │ │ │ │ │ 00202 │ │ │ │ │ │ 00203 │ │ │ │ │ │ vicinity_size = vicinity.size(); │ │ │ │ │ │ 00204 } │ │ │ │ │ │ 00205 │ │ │ │ │ │ 00206 │ │ │ │ │ │ 00208 inline double sort_angle(double s, double c){ │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.50 vicinity.cpp │ │ │ │ │ │ - │ │ │ │ │ │ -00209 │ │ │ │ │ │ if (s==0) return (c>0) ? 0.0 : 2.0; │ │ │ │ │ │ -double t=c/s; │ │ │ │ │ │ +00209 │ │ │ │ │ │ 00210 │ │ │ │ │ │ +double t=c/s; │ │ │ │ │ │ 00211 │ │ │ │ │ │ return (s>0) ? 1-t/(1+fabs(t)) : 3-t/(1+fabs(t)); │ │ │ │ │ │ 00212 } │ │ │ │ │ │ 00213 │ │ │ │ │ │ 00214 │ │ │ │ │ │ 00215 /* │ │ │ │ │ │ 00216 * append a particle to the ’vicinity’ list after │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.51 vicinity.h │ │ │ │ │ │ + │ │ │ │ │ │ 00217 * having computed the angular-ordering quantities │ │ │ │ │ │ 00218 * - v │ │ │ │ │ │ vector to test │ │ │ │ │ │ 00219 **********************************************************/ │ │ │ │ │ │ 00220 void Cvicinity::append_to_vicinity(Cmomentum *v){ │ │ │ │ │ │ -00221 │ │ │ │ │ │ double dx, dy, d2; │ │ │ │ │ │ +00221 │ │ │ │ │ │ 00222 │ │ │ │ │ │ // skip the particle itself) │ │ │ │ │ │ 00223 │ │ │ │ │ │ 00224 │ │ │ │ │ │ if (v==parent) │ │ │ │ │ │ return; │ │ │ │ │ │ 00225 │ │ │ │ │ │ 00226 │ │ │ │ │ │ -int i=2*(v->index); │ │ │ │ │ │ 00227 │ │ │ │ │ │ +int i=2*(v->index); │ │ │ │ │ │ 00228 │ │ │ │ │ │ // compute the distance of the i-th particle with the parent │ │ │ │ │ │ 00229 │ │ │ │ │ │ 00230 │ │ │ │ │ │ dx = v->eta - pcx; │ │ │ │ │ │ 00231 │ │ │ │ │ │ dy = v->phi - pcy; │ │ │ │ │ │ 00232 │ │ │ │ │ │ -// pay attention to the periodicity in phi ! │ │ │ │ │ │ 00233 │ │ │ │ │ │ +// pay attention to the periodicity in phi ! │ │ │ │ │ │ 00234 │ │ │ │ │ │ if (dy>M_PI) │ │ │ │ │ │ 00235 │ │ │ │ │ │ dy -= twopi; │ │ │ │ │ │ else if (dy<-M_PI) │ │ │ │ │ │ 00236 │ │ │ │ │ │ 00237 │ │ │ │ │ │ @@ -29076,16 +29054,16 @@ │ │ │ │ │ │ // - build temporary variables used for the computation │ │ │ │ │ │ 00247 │ │ │ │ │ │ //d │ │ │ │ │ │ = sqrt(d2); │ │ │ │ │ │ 00248 │ │ │ │ │ │ tmp = sqrt(VR2/d2-1); │ │ │ │ │ │ 00249 │ │ │ │ │ │ -00250 │ │ │ │ │ │ // first angle (+) │ │ │ │ │ │ +00250 │ │ │ │ │ │ 00251 │ │ │ │ │ │ c = 0.5*(dx-dy*tmp); // cosine of (parent,child) pair w.r.t. horizontal │ │ │ │ │ │ 00252 │ │ │ │ │ │ s = 0.5*(dy+dx*tmp); // sine │ │ │ │ │ │ of (parent,child) pair w.r.t. horizontal │ │ │ │ │ │ 00253 │ │ │ │ │ │ ve_list[i].angle = sort_angle(s,c); │ │ │ │ │ │ @@ -29096,16 +29074,16 @@ │ │ │ │ │ │ 00256 │ │ │ │ │ │ ve_list[i].side = true; │ │ │ │ │ │ 00257 │ │ │ │ │ │ ve_list[i].cocircular.clear(); │ │ │ │ │ │ 00258 │ │ │ │ │ │ vicinity.push_back(&(ve_list[i])); │ │ │ │ │ │ 00259 │ │ │ │ │ │ -// second angle (-) │ │ │ │ │ │ 00260 │ │ │ │ │ │ +// second angle (-) │ │ │ │ │ │ 00261 │ │ │ │ │ │ c = 0.5*(dx+dy*tmp); // cosine of (parent,child) pair w.r.t. horizontal │ │ │ │ │ │ 00262 │ │ │ │ │ │ s = 0.5*(dy-dx*tmp); // sine │ │ │ │ │ │ of (parent,child) pair w.r.t. horizontal │ │ │ │ │ │ 00263 │ │ │ │ │ │ ve_list[i+1].angle = sort_angle(s,c); │ │ │ │ │ │ @@ -29116,16 +29094,16 @@ │ │ │ │ │ │ 00266 │ │ │ │ │ │ ve_list[i+1].side = false; │ │ │ │ │ │ 00267 │ │ │ │ │ │ ve_list[i+1].cocircular.clear(); │ │ │ │ │ │ 00268 │ │ │ │ │ │ vicinity.push_back(&(ve_list[i+1])); │ │ │ │ │ │ 00269 │ │ │ │ │ │ -00270 │ │ │ │ │ │ // now work out the cocircularity range for the two points (range │ │ │ │ │ │ +00270 │ │ │ │ │ │ 00271 │ │ │ │ │ │ // of angle within which the points stay within a distance │ │ │ │ │ │ 00272 │ │ │ │ │ │ // EPSILON_COCIRCULAR of circule │ │ │ │ │ │ 00273 │ │ │ │ │ │ // P = parent; C = child; O = Origin (center of circle) │ │ │ │ │ │ 00274 │ │ │ │ │ │ @@ -29151,41 +29129,42 @@ │ │ │ │ │ │ // -- that means that c & s are defined including a factor of VR2] │ │ │ │ │ │ 00285 │ │ │ │ │ │ c = dot_product(OP,OC); │ │ │ │ │ │ 00286 │ │ │ │ │ │ s = fabs(cross_product(OP,OC)); │ │ │ │ │ │ double inv_err1 = s * inv_R_EPS_COCIRC; │ │ │ │ │ │ 00287 │ │ │ │ │ │ -double inv_err2_sq = (R2-c) * inv_R_2EPS_COCIRC; │ │ │ │ │ │ 00288 │ │ │ │ │ │ +double inv_err2_sq = (R2-c) * inv_R_2EPS_COCIRC; │ │ │ │ │ │ 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++ -*- │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ │ │ │ │ │ │ 303 │ │ │ │ │ │ │ │ │ │ │ │ 304 │ │ │ │ │ │ │ │ │ │ │ │ File Documentation │ │ │ │ │ │ │ │ │ │ │ │ -00296 } │ │ │ │ │ │ - │ │ │ │ │ │ -5.51 vicinity.h │ │ │ │ │ │ -00001 // -*- C++ -*00003 // File: vicinity.h │ │ │ │ │ │ +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 │ │ │ │ │ │ // │ │ │ │ │ │ @@ -29250,24 +29229,24 @@ │ │ │ │ │ │ 00053 public: │ │ │ │ │ │ 00055 │ │ │ │ │ │ CSphmomentum *v; │ │ │ │ │ │ 00056 │ │ │ │ │ │ 00058 │ │ │ │ │ │ siscone::Cvicinity_inclusion *is_inside; │ │ │ │ │ │ 00059 │ │ │ │ │ │ -// centre variables │ │ │ │ │ │ 00060 │ │ │ │ │ │ +// centre variables │ │ │ │ │ │ 00061 │ │ │ │ │ │ CSph3vector centre; │ │ │ │ │ │ -00062 │ │ │ │ │ │ double angle; │ │ │ │ │ │ -bool side; │ │ │ │ │ │ +00062 │ │ │ │ │ │ 00063 │ │ │ │ │ │ -00064 │ │ │ │ │ │ +bool side; │ │ │ │ │ │ double cocircular_range; │ │ │ │ │ │ +00064 │ │ │ │ │ │ 00066 │ │ │ │ │ │ 00069 │ │ │ │ │ │ std::list cocircular; │ │ │ │ │ │ 00070 }; │ │ │ │ │ │ 00071 │ │ │ │ │ │ 00073 bool ve_less(CSphvicinity_elm *ve1, CSphvicinity_elm *ve2); │ │ │ │ │ │ 00074 │ │ │ │ │ │ @@ -29279,41 +29258,34 @@ │ │ │ │ │ │ 00087 │ │ │ │ │ │ 00089 │ │ │ │ │ │ CSphvicinity(std::vector &_particle_list); │ │ │ │ │ │ 00090 │ │ │ │ │ │ 00092 │ │ │ │ │ │ ~CSphvicinity(); │ │ │ │ │ │ 00093 │ │ │ │ │ │ -00098 │ │ │ │ │ │ void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ +00098 │ │ │ │ │ │ 00099 │ │ │ │ │ │ void build(CSphmomentum *_parent, double _VR); │ │ │ │ │ │ 00105 │ │ │ │ │ │ 00106 │ │ │ │ │ │ // cone kinematical information │ │ │ │ │ │ 00107 │ │ │ │ │ │ 00108 │ │ │ │ │ │ CSphmomentum *parent; │ │ │ │ │ │ -double VR; │ │ │ │ │ │ 00109 │ │ │ │ │ │ +double VR; │ │ │ │ │ │ 00110 │ │ │ │ │ │ double VR2; │ │ │ │ │ │ double cosVR; │ │ │ │ │ │ 00111 │ │ │ │ │ │ -double R; │ │ │ │ │ │ 00112 │ │ │ │ │ │ +double R; │ │ │ │ │ │ double R2; │ │ │ │ │ │ 00113 │ │ │ │ │ │ - │ │ │ │ │ │ -// │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ - 5.52 vicinity.h │ │ │ │ │ │ - │ │ │ │ │ │ 00114 │ │ │ │ │ │ double tan2R; │ │ │ │ │ │ double D2_R; │ │ │ │ │ │ 00115 │ │ │ │ │ │ 00116 │ │ │ │ │ │ double inv_R_EPS_COCIRC; │ │ │ │ │ │ 00117 │ │ │ │ │ │ @@ -29323,27 +29295,34 @@ │ │ │ │ │ │ 00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ int n_part; │ │ │ │ │ │ 00121 │ │ │ │ │ │ std::vector plist; │ │ │ │ │ │ 00123 │ │ │ │ │ │ std::vector pincluded; │ │ │ │ │ │ + │ │ │ │ │ │ +// │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ + 5.52 vicinity.h │ │ │ │ │ │ + │ │ │ │ │ │ 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; │ │ │ │ │ │ -unsigned int vicinity_size; │ │ │ │ │ │ 00131 │ │ │ │ │ │ +unsigned int vicinity_size; │ │ │ │ │ │ 00132 │ │ │ │ │ │ 00133 protected: │ │ │ │ │ │ 00139 │ │ │ │ │ │ void append_to_vicinity(CSphmomentum *v); │ │ │ │ │ │ 00140 │ │ │ │ │ │ // internal variables │ │ │ │ │ │ 00141 │ │ │ │ │ │ @@ -29420,50 +29399,50 @@ │ │ │ │ │ │ 00039 │ │ │ │ │ │ 00040 │ │ │ │ │ │ 00046 class Cvicinity_inclusion { │ │ │ │ │ │ 00047 public: │ │ │ │ │ │ 00049 │ │ │ │ │ │ Cvicinity_inclusion() : cone(false), cocirc(false) {} │ │ │ │ │ │ 00050 │ │ │ │ │ │ -00051 │ │ │ │ │ │ bool cone; │ │ │ │ │ │ -bool cocirc; │ │ │ │ │ │ +00051 │ │ │ │ │ │ 00052 │ │ │ │ │ │ +bool cocirc; │ │ │ │ │ │ 00053 }; │ │ │ │ │ │ 00054 │ │ │ │ │ │ 00055 │ │ │ │ │ │ 00063 class Cvicinity_elm{ │ │ │ │ │ │ 00064 public: │ │ │ │ │ │ 00066 │ │ │ │ │ │ Cmomentum *v; │ │ │ │ │ │ - │ │ │ │ │ │ -Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ - │ │ │ │ │ │ -305 │ │ │ │ │ │ - │ │ │ │ │ │ - 306 │ │ │ │ │ │ - │ │ │ │ │ │ -File Documentation │ │ │ │ │ │ - │ │ │ │ │ │ 00067 │ │ │ │ │ │ 00069 │ │ │ │ │ │ Cvicinity_inclusion *is_inside; │ │ │ │ │ │ 00070 │ │ │ │ │ │ -// centre variables │ │ │ │ │ │ 00071 │ │ │ │ │ │ +// centre variables │ │ │ │ │ │ 00072 │ │ │ │ │ │ double eta; │ │ │ │ │ │ 00073 │ │ │ │ │ │ double phi; │ │ │ │ │ │ double angle; │ │ │ │ │ │ 00074 │ │ │ │ │ │ -00075 │ │ │ │ │ │ bool side; │ │ │ │ │ │ +00075 │ │ │ │ │ │ double cocircular_range; │ │ │ │ │ │ 00076 │ │ │ │ │ │ + │ │ │ │ │ │ +Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ + │ │ │ │ │ │ +305 │ │ │ │ │ │ + │ │ │ │ │ │ + 306 │ │ │ │ │ │ + │ │ │ │ │ │ +File Documentation │ │ │ │ │ │ + │ │ │ │ │ │ 00078 │ │ │ │ │ │ 00081 │ │ │ │ │ │ std::list cocircular; │ │ │ │ │ │ 00082 }; │ │ │ │ │ │ 00083 │ │ │ │ │ │ 00085 bool ve_less(Cvicinity_elm *ve1, Cvicinity_elm *ve2); │ │ │ │ │ │ 00086 │ │ │ │ │ │ @@ -29475,36 +29454,36 @@ │ │ │ │ │ │ 00099 │ │ │ │ │ │ 00101 │ │ │ │ │ │ Cvicinity(std::vector &_particle_list); │ │ │ │ │ │ 00102 │ │ │ │ │ │ 00104 │ │ │ │ │ │ ~Cvicinity(); │ │ │ │ │ │ 00105 │ │ │ │ │ │ -void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ 00110 │ │ │ │ │ │ +void set_particle_list(std::vector &_particle_list); │ │ │ │ │ │ 00111 │ │ │ │ │ │ void build(Cmomentum *_parent, double _VR); │ │ │ │ │ │ 00117 │ │ │ │ │ │ 00118 │ │ │ │ │ │ // cone kinematical information │ │ │ │ │ │ 00119 │ │ │ │ │ │ 00120 │ │ │ │ │ │ Cmomentum *parent; │ │ │ │ │ │ -double VR; │ │ │ │ │ │ 00121 │ │ │ │ │ │ +double VR; │ │ │ │ │ │ 00122 │ │ │ │ │ │ double VR2; │ │ │ │ │ │ double R; │ │ │ │ │ │ 00123 │ │ │ │ │ │ 00124 │ │ │ │ │ │ double R2; │ │ │ │ │ │ -00125 │ │ │ │ │ │ double inv_R_EPS_COCIRC; │ │ │ │ │ │ -double inv_R_2EPS_COCIRC; │ │ │ │ │ │ +00125 │ │ │ │ │ │ 00126 │ │ │ │ │ │ +double inv_R_2EPS_COCIRC; │ │ │ │ │ │ 00127 │ │ │ │ │ │ // particle list information │ │ │ │ │ │ 00128 │ │ │ │ │ │ 00129 │ │ │ │ │ │ int n_part; │ │ │ │ │ │ 00130 │ │ │ │ │ │ std::vector plist; │ │ │ │ │ │ @@ -29517,27 +29496,27 @@ │ │ │ │ │ │ Cquadtree *quadtree; │ │ │ │ │ │ 00135 #endif │ │ │ │ │ │ 00136 │ │ │ │ │ │ // vicinity information │ │ │ │ │ │ 00137 │ │ │ │ │ │ 00138 │ │ │ │ │ │ std::vector vicinity; │ │ │ │ │ │ -00139 │ │ │ │ │ │ unsigned int vicinity_size; │ │ │ │ │ │ +00139 │ │ │ │ │ │ 00140 │ │ │ │ │ │ 00141 protected: │ │ │ │ │ │ void append_to_vicinity(Cmomentum *v); │ │ │ │ │ │ 00147 │ │ │ │ │ │ 00148 │ │ │ │ │ │ // internal variables │ │ │ │ │ │ 00149 │ │ │ │ │ │ 00150 │ │ │ │ │ │ double pcx; │ │ │ │ │ │ -00151 │ │ │ │ │ │ double pcy; │ │ │ │ │ │ +00151 │ │ │ │ │ │ 00152 }; │ │ │ │ │ │ 00153 │ │ │ │ │ │ 00154 } │ │ │ │ │ │ 00155 │ │ │ │ │ │ 00156 #endif │ │ │ │ │ │ │ │ │ │ │ │ Generated on Tue Jan 10 2023 17:32:40 for SISCone by Doxygen │ │ │ │ │ │ @@ -29786,22 +29765,22 @@ │ │ │ │ │ │ siscone::Ceta_phi_range, 20 │ │ │ │ │ │ eta_min │ │ │ │ │ │ siscone::Ceta_phi_range, 20 │ │ │ │ │ │ eta_range │ │ │ │ │ │ siscone::Ceta_phi_range, 21 │ │ │ │ │ │ ev_name │ │ │ │ │ │ Coptions, 41 │ │ │ │ │ │ -examples/area.cpp, 185 │ │ │ │ │ │ -examples/main.cpp, 175 │ │ │ │ │ │ -examples/options.cpp, 176 │ │ │ │ │ │ -examples/options.h, 179 │ │ │ │ │ │ -examples/sample.cpp, 180 │ │ │ │ │ │ -examples/spherical.cpp, 181 │ │ │ │ │ │ -examples/test.cpp, 182 │ │ │ │ │ │ -examples/times.cpp, 184 │ │ │ │ │ │ +examples/area.cpp, 175 │ │ │ │ │ │ +examples/main.cpp, 180 │ │ │ │ │ │ +examples/options.cpp, 182 │ │ │ │ │ │ +examples/options.h, 185 │ │ │ │ │ │ +examples/sample.cpp, 185 │ │ │ │ │ │ +examples/spherical.cpp, 187 │ │ │ │ │ │ +examples/test.cpp, 188 │ │ │ │ │ │ +examples/times.cpp, 189 │ │ │ │ │ │ │ │ │ │ │ │ 309 │ │ │ │ │ │ │ │ │ │ │ │ siscone::hash_cones, 165 │ │ │ │ │ │ siscone_spherical::sph_hash_cones, 172 │ │ │ │ │ │ hash_cones │ │ │ │ │ │ siscone::hash_cones, 163 │ │ │ │ │ │ @@ -30138,21 +30117,21 @@ │ │ │ │ │ │ siscone_spherical::sph_hash_cones, 172 │ │ │ │ │ │ randomize │ │ │ │ │ │ siscone::Creference, 51 │ │ │ │ │ │ range │ │ │ │ │ │ siscone::Cjet, 27 │ │ │ │ │ │ siscone_spherical::CSphjet, 75 │ │ │ │ │ │ ranlux.h │ │ │ │ │ │ -ranlux_get, 243 │ │ │ │ │ │ -ranlux_init, 243 │ │ │ │ │ │ +ranlux_get, 242 │ │ │ │ │ │ +ranlux_init, 242 │ │ │ │ │ │ ranlux_print_state, 243 │ │ │ │ │ │ ranlux_get │ │ │ │ │ │ -ranlux.h, 243 │ │ │ │ │ │ +ranlux.h, 242 │ │ │ │ │ │ ranlux_init │ │ │ │ │ │ -ranlux.h, 243 │ │ │ │ │ │ +ranlux.h, 242 │ │ │ │ │ │ ranlux_print_state │ │ │ │ │ │ ranlux.h, 243 │ │ │ │ │ │ recompute_jets │ │ │ │ │ │ siscone::Csiscone, 59 │ │ │ │ │ │ siscone_spherical::CSphsiscone, 90 │ │ │ │ │ │ ref │ │ │ │ │ │ siscone::Cmomentum, 38 │ │ │ │ │ │ @@ -30188,52 +30167,52 @@ │ │ │ │ │ │ siscone_spherical::CSphsplit_merge, 99 │ │ │ │ │ │ side │ │ │ │ │ │ siscone::Cvicinity_elm, 160 │ │ │ │ │ │ siscone_spherical::CSphvicinity_elm, 125 │ │ │ │ │ │ │ │ │ │ │ │ INDEX │ │ │ │ │ │ │ │ │ │ │ │ -siscone/area.cpp, 187 │ │ │ │ │ │ +siscone/area.cpp, 176 │ │ │ │ │ │ siscone/area.h, 191 │ │ │ │ │ │ siscone/circulator.h, 192 │ │ │ │ │ │ siscone/config.h, 193 │ │ │ │ │ │ siscone/config_raw.h, 194 │ │ │ │ │ │ siscone/defines.h, 195, 197 │ │ │ │ │ │ siscone/geom_2d.cpp, 198 │ │ │ │ │ │ -siscone/geom_2d.h, 202 │ │ │ │ │ │ -siscone/hash.cpp, 204 │ │ │ │ │ │ -siscone/hash.h, 210 │ │ │ │ │ │ -siscone/momentum.cpp, 211 │ │ │ │ │ │ -siscone/momentum.h, 257 │ │ │ │ │ │ -siscone/protocones.cpp, 217 │ │ │ │ │ │ -siscone/protocones.h, 260 │ │ │ │ │ │ +siscone/geom_2d.h, 254 │ │ │ │ │ │ +siscone/hash.cpp, 202 │ │ │ │ │ │ +siscone/hash.h, 207 │ │ │ │ │ │ +siscone/momentum.cpp, 256 │ │ │ │ │ │ +siscone/momentum.h, 209 │ │ │ │ │ │ +siscone/protocones.cpp, 213 │ │ │ │ │ │ +siscone/protocones.h, 232 │ │ │ │ │ │ siscone/quadtree.cpp, 236 │ │ │ │ │ │ siscone/quadtree.h, 239 │ │ │ │ │ │ siscone/ranlux.cpp, 240 │ │ │ │ │ │ siscone/ranlux.h, 242, 243 │ │ │ │ │ │ siscone/reference.cpp, 244 │ │ │ │ │ │ siscone/reference.h, 245 │ │ │ │ │ │ siscone/siscone.cpp, 246 │ │ │ │ │ │ -siscone/siscone.h, 253 │ │ │ │ │ │ -siscone/siscone_error.cpp, 255 │ │ │ │ │ │ -siscone/siscone_error.h, 256 │ │ │ │ │ │ +siscone/siscone.h, 262 │ │ │ │ │ │ +siscone/siscone_error.cpp, 253 │ │ │ │ │ │ +siscone/siscone_error.h, 253 │ │ │ │ │ │ siscone/spherical/geom_2d.cpp, 200 │ │ │ │ │ │ -siscone/spherical/geom_2d.h, 203 │ │ │ │ │ │ -siscone/spherical/hash.cpp, 207 │ │ │ │ │ │ -siscone/spherical/hash.h, 210 │ │ │ │ │ │ -siscone/spherical/momentum.cpp, 213 │ │ │ │ │ │ -siscone/spherical/momentum.h, 258 │ │ │ │ │ │ -siscone/spherical/protocones.cpp, 226 │ │ │ │ │ │ -siscone/spherical/protocones.h, 262 │ │ │ │ │ │ -siscone/spherical/siscone.cpp, 250 │ │ │ │ │ │ -siscone/spherical/siscone.h, 254 │ │ │ │ │ │ +siscone/spherical/geom_2d.h, 256 │ │ │ │ │ │ +siscone/spherical/hash.cpp, 205 │ │ │ │ │ │ +siscone/spherical/hash.h, 208 │ │ │ │ │ │ +siscone/spherical/momentum.cpp, 258 │ │ │ │ │ │ +siscone/spherical/momentum.h, 210 │ │ │ │ │ │ +siscone/spherical/protocones.cpp, 222 │ │ │ │ │ │ +siscone/spherical/protocones.h, 234 │ │ │ │ │ │ +siscone/spherical/siscone.cpp, 249 │ │ │ │ │ │ +siscone/spherical/siscone.h, 263 │ │ │ │ │ │ siscone/spherical/split_merge.cpp, 264 │ │ │ │ │ │ siscone/spherical/split_merge.h, 291 │ │ │ │ │ │ siscone/spherical/vicinity.cpp, 297 │ │ │ │ │ │ -siscone/spherical/vicinity.h, 304 │ │ │ │ │ │ +siscone/spherical/vicinity.h, 303 │ │ │ │ │ │ siscone/split_merge.cpp, 278 │ │ │ │ │ │ siscone/split_merge.h, 294 │ │ │ │ │ │ siscone/vicinity.cpp, 300 │ │ │ │ │ │ siscone/vicinity.h, 305 │ │ │ │ │ │ siscone::Carea, 7 │ │ │ │ │ │ ∼Carea, 13 │ │ │ │ │ │ Carea, 13