ATLAS Offline Software
Public Types | Public Member Functions | Private Member Functions | Private Attributes | List of all members
ScaleEcalorimeter Struct Reference

#include <egammaLayerRecalibTool.h>

Inheritance diagram for ScaleEcalorimeter:
Collaboration diagram for ScaleEcalorimeter:

Public Types

enum  NullPoint {
  ZEROBASED, ONEBASED, ZEROBASED_ALPHA, ONEBASED_ALPHA,
  SHIFT, SCALE, SUBTRACT
}
 

Public Member Functions

 ScaleEcalorimeter (NullPoint base)
 
ScaleEcalorimeterclone () const
 
CP::CorrectionCode operator() (StdCalibrationInputs &, float amount) const
 

Private Member Functions

virtual void scale_inputs (StdCalibrationInputs &, float amount) const
 
virtual void shift_inputs (StdCalibrationInputs &, float amount) const
 

Private Attributes

NullPoint m_base
 

Detailed Description

Definition at line 295 of file egammaLayerRecalibTool.h.

Member Enumeration Documentation

◆ NullPoint

enum InputModifier::NullPoint
inherited
Enumerator
ZEROBASED 
ONEBASED 
ZEROBASED_ALPHA 
ONEBASED_ALPHA 
SHIFT 
SCALE 
SUBTRACT 

Definition at line 220 of file egammaLayerRecalibTool.h.

Constructor & Destructor Documentation

◆ ScaleEcalorimeter()

ScaleEcalorimeter::ScaleEcalorimeter ( NullPoint  base)
inline

Definition at line 297 of file egammaLayerRecalibTool.h.

297 : InputModifier(base) { };

Member Function Documentation

◆ clone()

ScaleEcalorimeter* ScaleEcalorimeter::clone ( ) const
inlinevirtual

Implements InputModifier.

Definition at line 298 of file egammaLayerRecalibTool.h.

298 { return new ScaleEcalorimeter(*this); };

◆ operator()()

CP::CorrectionCode InputModifier::operator() ( StdCalibrationInputs inputs,
float  amount 
) const
inherited

Definition at line 122 of file egammaLayerRecalibTool.cxx.

123 {
124  if (amount == VALUE_OVERFLOW) return CP::CorrectionCode::OutOfValidityRange;
125  switch (m_base)
126  {
127  case SHIFT: shift_inputs(inputs, amount); return CP::CorrectionCode::Ok;
128  case SUBTRACT: shift_inputs(inputs, -amount); return CP::CorrectionCode::Ok;
129  case SCALE: scale_inputs(inputs, amount); return CP::CorrectionCode::Ok;
130  case ZEROBASED: scale_inputs(inputs, 1. + amount); return CP::CorrectionCode::Ok;
131  case ONEBASED: scale_inputs(inputs, amount); return CP::CorrectionCode::Ok;
132  case ONEBASED_ALPHA: scale_inputs(inputs, 1. / amount); return CP::CorrectionCode::Ok;
133  case ZEROBASED_ALPHA: scale_inputs(inputs, 1. / (1. + amount)); return CP::CorrectionCode::Ok;
134  default: return CP::CorrectionCode::Error;
135  };
136 }

◆ scale_inputs()

void ScaleEcalorimeter::scale_inputs ( StdCalibrationInputs inputs,
float  amount 
) const
privatevirtual

Implements InputModifier.

Definition at line 185 of file egammaLayerRecalibTool.cxx.

186 {
187  inputs.E0raw *= amount;
188  inputs.E1raw *= amount;
189  inputs.E2raw *= amount;
190  inputs.E3raw *= amount;
191 }

◆ shift_inputs()

void ScaleEcalorimeter::shift_inputs ( StdCalibrationInputs inputs,
float  amount 
) const
privatevirtual

Implements InputModifier.

Definition at line 193 of file egammaLayerRecalibTool.cxx.

194 {
195  inputs.E0raw += amount;
196  inputs.E1raw += amount;
197  inputs.E2raw += amount;
198  inputs.E3raw += amount;
199 }

Member Data Documentation

◆ m_base

NullPoint InputModifier::m_base
privateinherited

Definition at line 231 of file egammaLayerRecalibTool.h.


The documentation for this struct was generated from the following files:
InputModifier::SCALE
@ SCALE
Definition: egammaLayerRecalibTool.h:220
base
std::string base
Definition: hcg.cxx:78
InputModifier::ZEROBASED
@ ZEROBASED
Definition: egammaLayerRecalibTool.h:220
InputModifier::SHIFT
@ SHIFT
Definition: egammaLayerRecalibTool.h:220
ScaleEcalorimeter::ScaleEcalorimeter
ScaleEcalorimeter(NullPoint base)
Definition: egammaLayerRecalibTool.h:297
InputModifier::shift_inputs
virtual void shift_inputs(StdCalibrationInputs &, float amount) const =0
InputModifier::SUBTRACT
@ SUBTRACT
Definition: egammaLayerRecalibTool.h:220
postInclude.inputs
inputs
Definition: postInclude.SortInput.py:15
InputModifier::ONEBASED_ALPHA
@ ONEBASED_ALPHA
Definition: egammaLayerRecalibTool.h:220
InputModifier::InputModifier
InputModifier()
Definition: egammaLayerRecalibTool.h:227
CP::CorrectionCode::OutOfValidityRange
@ OutOfValidityRange
Input object is out of validity range.
Definition: CorrectionCode.h:37
CP::CorrectionCode::Error
@ Error
Some error happened during the object correction.
Definition: CorrectionCode.h:36
InputModifier::ONEBASED
@ ONEBASED
Definition: egammaLayerRecalibTool.h:220
InputModifier::ZEROBASED_ALPHA
@ ZEROBASED_ALPHA
Definition: egammaLayerRecalibTool.h:220
InputModifier::scale_inputs
virtual void scale_inputs(StdCalibrationInputs &, float amount) const =0
CP::CorrectionCode::Ok
@ Ok
The correction was done successfully.
Definition: CorrectionCode.h:38
InputModifier::m_base
NullPoint m_base
Definition: egammaLayerRecalibTool.h:231