CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Public Attributes
PhysicsTools::MVAComputer::DerivContext Struct Reference

Public Member Functions

int * conf () const
 
 DerivContext ()
 
void eval (const VarProcessor *proc, int *outConf, double *output, int *loop, unsigned int offset, unsigned int out) const
 
unsigned int n () const
 
double output (unsigned int output, std::vector< double > &derivs) const
 
double * values () const
 

Public Attributes

std::vector< int > conf_
 
std::vector< double > deriv_
 
unsigned int n_
 
std::vector< double > values_
 

Detailed Description

Definition at line 159 of file MVAComputer.h.

Constructor & Destructor Documentation

PhysicsTools::MVAComputer::DerivContext::DerivContext ( )
inline

Definition at line 160 of file MVAComputer.h.

160 : n_(0) {}

Member Function Documentation

int* PhysicsTools::MVAComputer::DerivContext::conf ( ) const
inline

Definition at line 170 of file MVAComputer.h.

Referenced by eval().

170 { return &conf_.front(); }
void PhysicsTools::MVAComputer::DerivContext::eval ( const VarProcessor proc,
int *  outConf,
double *  output,
int *  loop,
unsigned int  offset,
unsigned int  out 
) const

Definition at line 310 of file MVAComputer.cc.

References conf(), PhysicsTools::VarProcessor::deriv(), deriv_, n(), and values().

313 {
314  proc->deriv(values(), conf(), output, outConf,
315  loop, offset, n(), out, deriv_);
316 }
double output(unsigned int output, std::vector< double > &derivs) const
Definition: MVAComputer.cc:318
TrainProcessor *const proc
Definition: MVATrainer.cc:101
unsigned int offset(bool)
tuple out
Definition: dbtoconf.py:99
unsigned int PhysicsTools::MVAComputer::DerivContext::n ( void  ) const
inline

Definition at line 171 of file MVAComputer.h.

Referenced by eval().

171 { return n_; }
double PhysicsTools::MVAComputer::DerivContext::output ( unsigned int  output,
std::vector< double > &  derivs 
) const

Definition at line 318 of file MVAComputer.cc.

References filterCSVwithJSON::copy, PhysicsTools::MVAComputer::output, and pos.

320 {
321  derivs.clear();
322  derivs.reserve(n_);
323 
324  int pos = conf_[output];
325  if (pos >= (int)n_)
326  std::copy(&deriv_.front() + n_ * (pos - n_),
327  &deriv_.front() + n_ * (pos - n_ + 1),
328  std::back_inserter(derivs));
329  else {
330  derivs.resize(n_);
331  derivs[pos] = 1.;
332  }
333 
334  return values_[pos];
335 }
double output(unsigned int output, std::vector< double > &derivs) const
Definition: MVAComputer.cc:318
double* PhysicsTools::MVAComputer::DerivContext::values ( ) const
inline

Definition at line 169 of file MVAComputer.h.

Referenced by eval().

169 { return &values_.front(); }

Member Data Documentation

std::vector<int> PhysicsTools::MVAComputer::DerivContext::conf_
mutable

Definition at line 175 of file MVAComputer.h.

std::vector<double> PhysicsTools::MVAComputer::DerivContext::deriv_
mutable

Definition at line 174 of file MVAComputer.h.

Referenced by eval().

unsigned int PhysicsTools::MVAComputer::DerivContext::n_

Definition at line 176 of file MVAComputer.h.

std::vector<double> PhysicsTools::MVAComputer::DerivContext::values_
mutable

Definition at line 173 of file MVAComputer.h.