Main Page
Namespaces
Classes
Package Documentation
JetMETCorrections
MCJet
plugins
JetUtilMC.h
Go to the documentation of this file.
1
#ifndef JETUTILMC_H
2
#define JETUTILMC_H
3
4
#include <cmath>
5
namespace
{
6
class
PtGreater
{
7
public
:
8
template
<
typename
T>
bool
operator ()
(
const
T
&
i
,
const
T
& j) {
9
return
(i.pt() > j.pt());
10
}
11
};
12
13
double
Phi_0_2pi(
double
x
) {
14
while
(x >= 2*
M_PI
) x -= 2*
M_PI
;
15
while
(x < 0.) x += 2*
M_PI
;
16
return
x
;
17
}
18
19
double
Phi_mpi_pi(
double
x) {
20
while
(x >=
M_PI
) x -= 2*
M_PI
;
21
while
(x < -
M_PI
) x += 2*
M_PI
;
22
return
x
;
23
}
24
25
inline
double
dPhi(
double
phi1,
double
phi2){
26
phi1=Phi_0_2pi(phi1);
27
phi2=Phi_0_2pi(phi2);
28
return
Phi_mpi_pi(phi1-phi2);
29
}
30
31
double
radius
(
double
eta1,
double
phi1,
double
eta2,
double
phi2){
32
33
const
double
TWOPI
= 2.0*
M_PI
;
34
35
phi1=Phi_0_2pi(phi1);
36
phi2=Phi_0_2pi(phi2);
37
38
double
dphi=Phi_0_2pi(phi1-phi2);
39
dphi =
TMath::Min
(dphi,TWOPI-dphi);
40
double
deta = eta1-eta2;
41
42
return
sqrt
(deta*deta+dphi*dphi);
43
}
44
45
template
<
typename
T1,
typename
T2>
double
radius
(
const
T1& t1,
const
T2&
t2
){
46
return
radius
(t1->eta(),t1->phi(),t2->eta(),t2->phi());
47
}
48
}
49
50
#endif
mps_fire.i
i
Definition:
mps_fire.py:156
Min
T Min(T a, T b)
Definition:
MathUtil.h:39
reco::t2
auto const T2 &decltype(t1.eta()) t2
Definition:
deltaR.h:16
mathSSE::sqrt
T sqrt(T t)
Definition:
SSEVec.h:18
TWOPI
#define TWOPI
EgammaCoreTools.
Definition:
DQMSourcePi0.cc:40
M_PI
#define M_PI
Definition:
BXVectorInputProducer.cc:51
TCMET_cfi.radius
radius
Definition:
TCMET_cfi.py:32
PtGreater
Definition:
SusyDQM.h:43
DDAxes::x
T
long double T
Definition:
Basic3DVectorLD.h:57
PtGreater::operator()
bool operator()(const T &i, const T &j)
Definition:
SusyDQM.h:46
Generated for CMSSW Reference Manual by
1.8.11