|
Rivet analyses reference
BELLE_2014_I1282136
Mass distributions in the decay $\tau^-\to\pi^-K^0_SK^0_S\pi^0$
Experiment: BELLE (KEKB)
Inspire ID: 1282136
Status: VALIDATED NOHEPDATA
Authors:
References:
- Phys.Rev.D 89 (2014) 7, 072009
Beams: * *
Beam energies: ANY
Run details:
- Any process producing tau leptons, originally e+e-
Measurements of mass distributions in $\tau^-\to\pi^-K^0_SK^0_S\pi^0$ decays. The data were read from the plots in the paper and are not corrected, although the backgrounds given in the paper have been subtracted. The plots should therefore only be used for qualitative comparisons however the data is useful as there are not corrected distributions for this decay mode.
Source code:
BELLE_2014_I1282136.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88 | // -*- C++ -*-
#include "Rivet/Analysis.hh"
#include "Rivet/Projections/UnstableParticles.hh"
#include "Rivet/Projections/DecayedParticles.hh"
namespace Rivet {
/// @brief tau -> pi- KS0 KS0 pi0 nu
class BELLE_2014_I1282136 : public Analysis {
public:
/// Constructor
RIVET_DEFAULT_ANALYSIS_CTOR(BELLE_2014_I1282136);
/// @name Analysis methods
/// @{
/// Book histograms and initialise projections before the run
void init() {
// Initialise and register projections
UnstableParticles ufs = UnstableParticles(Cuts::abspid==15);
declare(ufs, "UFS");
DecayedParticles TAU(ufs);
TAU.addStable(310);
TAU.addStable(111);
declare(TAU, "TAU");
// histograms
for(unsigned int ix=0;ix<7;++ix) {
if(ix<2) book(_h[ix],1,1,1+ix);
else book(_h[ix],2,1,ix-1);
}
}
/// Perform the per-event analysis
void analyze(const Event& event) {
static const map<PdgId,unsigned int> & mode = { { 310,2},{ 111,1}, {-211,1},{ 16,1}};
static const map<PdgId,unsigned int> & modeCC = { { 310,2},{ 111,1}, { 211,1},{-16,1}};
DecayedParticles TAU = apply<DecayedParticles>(event, "TAU");
// loop over particles
for(unsigned int ix=0;ix<TAU.decaying().size();++ix) {
int sign = 1;
if(TAU.decaying()[ix].pid()>0 &&
TAU.modeMatches(ix,5,mode)) sign=1;
else if (TAU.decaying()[ix].pid()<0 &&
TAU.modeMatches(ix,5,modeCC)) sign=-1;
else
continue;
const Particle & pi0 = TAU.decayProducts()[ix].at(111)[0];
const Particle & pim = TAU.decayProducts()[ix].at(-211*sign)[0];
const Particles & K0 = TAU.decayProducts()[ix].at( 310);
_h[0]->fill((pi0.momentum()+K0[0].momentum()+K0[1].momentum()).mass());
_h[2]->fill((pim.momentum()+pi0.momentum()).mass());
_h[4]->fill((K0[0].momentum()+K0[1].momentum()).mass());
_h[5]->fill((pim.momentum()+K0[0].momentum()+K0[1].momentum()).mass());
for(unsigned int ix=0;ix<2;++ix) {
_h[1]->fill((pim.momentum()+K0[ix].momentum()).mass());
_h[3]->fill((pi0.momentum()+K0[ix].momentum()).mass());
_h[6]->fill((pi0.momentum()+pim.momentum()+K0[ix].momentum()).mass());
}
}
}
/// Normalise histograms etc., after the run
void finalize() {
for(unsigned int ix=0;ix<7;++ix) {
normalize(_h[ix],1.,false);
}
}
/// @}
/// @name Histograms
/// @{
Histo1DPtr _h[7];
/// @}
};
RIVET_DECLARE_PLUGIN(BELLE_2014_I1282136);
}
|
|