Rivet analyses referenceL3_1998_I447945$e^+e^-\to e^+e^-\eta^\prime$ via intermediate photons at 91.2 GeVExperiment: L3 (LEP) Inspire ID: 447945 Status: VALIDATED Authors:
Beam energies: (45.6, 45.6) GeV Run details:
Measurement of the cross section for the production of $\eta^\prime$ in photon-photon collisions, i.e. $e^+e^-\to \gamma\gamma e^+e^-$ followed by $\gamma\gamma\to\eta^\prime$, by the L3 experiment at 91.2 GeV. N.B. The measurement is the integrated crossd section in each $Q^2$ bin, not tyhe true differential cross section. Source code: L3_1998_I447945.cc 1// -*- C++ -*-
2#include "Rivet/Analysis.hh"
3#include "Rivet/Projections/FinalState.hh"
4#include "Rivet/Projections/UnstableParticles.hh"
5#include "Rivet/Projections/Beam.hh"
6
7namespace Rivet {
8
9
10 /// @brief e+e- > e+e- eta'
11 class L3_1998_I447945 : public Analysis {
12 public:
13
14 /// Constructor
15 RIVET_DEFAULT_ANALYSIS_CTOR(L3_1998_I447945);
16
17
18 /// @name Analysis methods
19 /// @{
20
21 /// Book histograms and initialise projections before the run
22 void init() {
23 // Initialise and register projections
24 declare(Beam(), "Beams");
25 declare(FinalState(),"FS");
26 declare(UnstableParticles(Cuts::pid==331), "UFS");
27 // book the histograms
28 book(_h_etap,"TMP/h_eta",refData(1,1,1));
29 }
30
31 void findChildren(const Particle & p,map<long,int> & nRes, int &ncount) {
32 for (const Particle &child : p.children()) {
33 if (child.children().empty()) {
34 --nRes[child.pid()];
35 --ncount;
36 } else {
37 findChildren(child,nRes,ncount);
38 }
39 }
40 }
41
42 bool findScattered(Particle beam, double& q2) {
43 bool found = false;
44 Particle scat = beam;
45 while (!scat.children().empty()) {
46 found = false;
47 for (const Particle & p : scat.children()) {
48 if (p.pid()==scat.pid()) {
49 scat=p;
50 found=true;
51 break;
52 }
53 }
54 if (!found) break;
55 }
56 if (!found) return false;
57 q2 = -(beam.momentum() - scat.momentum()).mass2();
58 return true;
59 }
60
61 /// Perform the per-event analysis
62 void analyze(const Event& event) {
63 // find scattered leptons and calc Q2
64 const Beam& beams = apply<Beam>(event, "Beams");
65 double q12 = -1, q22 = -1;
66 if (!findScattered(beams.beams().first, q12)) vetoEvent;
67 if (!findScattered(beams.beams().second, q22)) vetoEvent;
68 double scale = max(q12,q22);
69 // check the final state
70 const FinalState & fs = apply<FinalState>(event, "FS");
71 map<long,int> nCount;
72 int ntotal(0);
73 for (const Particle& p : fs.particles()) {
74 nCount[p.pid()] += 1;
75 ++ntotal;
76 }
77 // find the meson
78 const FinalState& ufs = apply<FinalState>(event, "UFS");
79 for (const Particle& p : ufs.particles()) {
80 if(p.children().empty()) continue;
81 map<long,int> nRes = nCount;
82 int ncount = ntotal;
83 findChildren(p,nRes,ncount);
84 bool matched = true;
85 for (const auto& val : nRes) {
86 if (abs(val.first)==11) {
87 if (val.second!=1) {
88 matched = false;
89 break;
90 }
91 }
92 else if(val.second!=0) {
93 matched = false;
94 break;
95 }
96 }
97 if (matched) {
98 _h_etap->fill(scale);
99 break;
100 }
101 }
102 }
103
104
105 /// Normalise histograms etc., after the run
106 void finalize() {
107 scale(_h_etap, crossSection()/picobarn/sumW());
108 Estimate1DPtr tmp;
109 book(tmp,1,1,1);
110 barchart(_h_etap,tmp);
111 }
112
113 /// @}
114
115
116 /// @name Histograms
117 /// @{
118 Histo1DPtr _h_etap;
119 /// @}
120
121
122 };
123
124
125 RIVET_DECLARE_PLUGIN(L3_1998_I447945);
126
127}
|