CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions
alpha_T Struct Reference

#include <alpha_T.h>

Public Member Functions

template<class LVs >
double operator() (const LVs &p4s) const
 

Static Public Member Functions

static double minimum_deltaSumPT (const std::vector< double > &pTs)
 

Detailed Description

Definition at line 10 of file alpha_T.h.

Member Function Documentation

static double alpha_T::minimum_deltaSumPT ( const std::vector< double > &  pTs)
inlinestatic

Definition at line 26 of file alpha_T.h.

References diffTreeTool::diff, mps_fire::i, x, and y.

Referenced by operator()().

26  {
27  std::vector<double> diff( 1<<(pTs.size()-1) , 0. );
28  for(unsigned i=0; i < diff.size(); i++)
29  for(unsigned j=0; j < pTs.size(); j++)
30  diff[i] += pTs[j] * ( 1 - 2 * (int(i>>j)&1) ) ;
31 
32  return fabs( *min_element( diff.begin(), diff.end(),
33  [](auto x, auto y){return fabs(x) < fabs(y);} ) );
34  }
template<class LVs >
double alpha_T::operator() ( const LVs &  p4s) const
inline

Definition at line 13 of file alpha_T.h.

References minimum_deltaSumPT(), reco::tau::disc::Pt(), mathSSE::sqrt(), and create_public_lumi_plots::transform.

13  { typedef typename LVs::value_type LorentzV;
14  if( p4s.size() < 2 ) return 0;
15 
16  std::vector<double> pTs;
17  transform( p4s.begin(), p4s.end(), back_inserter(pTs), std::mem_fn(&LorentzV::Pt));
18 
19  const double DsumPT = minimum_deltaSumPT( pTs );
20  const double sumPT = accumulate( pTs.begin(), pTs.end(), double(0) );
21  const LorentzV sumP4 = accumulate( p4s.begin(), p4s.end(), LorentzV() );
22 
23  return 0.5 * ( sumPT - DsumPT ) / sqrt( sumPT*sumPT - sumP4.Perp2() );
24  }
static double minimum_deltaSumPT(const std::vector< double > &pTs)
Definition: alpha_T.h:26
T sqrt(T t)
Definition: SSEVec.h:18
ROOT::Math::LorentzVector< ROOT::Math::PtEtaPhiM4D< double > > LorentzV